/* ==========================================================
   MARKUS — Merged Stylesheet
   ========================================================== */

/* ===== Reset & Shared Variables ===== */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
:root{
  --mk-black:#241614;--mk-text:#241614;--mk-text-sub:#5a4a42;--mk-text-muted:#8a7d76;
  --mk-bg:#F7F5F1;--mk-bg-light:#F0EDE8;--mk-bg-gray:#E8E4DE;--mk-border:#DDD8D0;
  --mk-accent:#FBEA35;--mk-accent-dark:#e6d520;--mk-accent-light:#fef9c3;
  --mk-dark:#241614;
  --mk-font:'Noto Sans JP','Inter',sans-serif;
  --mk-container:1200px;
  --mk-radius:12px;--mk-radius-lg:20px;
  --mk-shadow:0 2px 8px rgba(36,22,20,.08);--mk-shadow-md:0 4px 20px rgba(36,22,20,.1);
}
html{scroll-behavior:smooth;font-size:16px;-webkit-font-smoothing:antialiased;}
body{font-family:var(--mk-font);color:var(--mk-text);background:var(--mk-bg);line-height:1.8;overflow-x:hidden;}
.mk-container{max-width:var(--mk-container);margin:0 auto;padding:0 24px;}

/* ===== Scroll Reveal (shared) ===== */
.mk-reveal{opacity:0;transform:translateY(30px);transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1);}
.mk-reveal.visible{opacity:1;transform:translateY(0);}
.mk-reveal-d1{transition-delay:.1s;}
.mk-reveal-d2{transition-delay:.2s;}
.mk-reveal-d3{transition-delay:.3s;}
.mk-reveal-d4{transition-delay:.4s;}
.mk-reveal-d5{transition-delay:.5s;}


/* ==========================================================
   HERO SECTION
   ========================================================== */
.hero-section{
  position:relative;
  background:var(--mk-bg);
  overflow:hidden;
}

.hero-section::after{
  content: '';
  position: absolute;
  top: 0;
  right: 0;
  height: calc(1 / 1 * var(--mk-container));
  bottom: 0;
  width: calc(4 / 13 * var(--mk-container));
  background: #fff;
  z-index: 0;
}

.hero-inner{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns:8fr 5fr;
  min-height:560px;
}

/* ----- Left: Copy ----- */
.hero-copy{
  display:flex;
  flex-direction:column;
  justify-content:center;
  padding:80px 48px 80px 0;
}

.hero-label{
  font-size:18px;
  font-weight:600;
  color:var(-mk-text);
  letter-spacing:.12em;
  margin-bottom:8px;
}

.hero-title{
  font-size:clamp(30px,3.6vw,50px);
  font-weight:900;
  line-height:1.35;
  color:var(--mk-black);
  margin-bottom:20px;
  margin-top: 8px;
}

.hero-badge{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:6px 16px 6px 0;
  font-size:13px;
  font-weight:700;
  color:var(--mk-dark);
  margin-bottom:18px;
  width:fit-content;
}
.hero-badge img {
  max-width: 280px;
}
.hero-cta{
  display:inline-flex;
  align-items:center;
  gap:8px;
  background:var(--mk-accent);
  color:var(--mk-dark);
  padding:14px 32px;
  border-radius:100px;
  font-size:15px;
  font-weight:700;
  text-decoration:none;
  box-shadow:0 4px 14px rgba(251,234,53,.4);
  transition:all .2s;
  width:fit-content;
}
.hero-cta:hover{
  background:var(--mk-accent-dark);
  transform:translateY(-2px);
  box-shadow:0 6px 20px rgba(251,234,53,.5);
}

/* ----- Right: Form ----- */
.hero-form-wrap{
  display:flex;
  align-items:center;
  justify-content:center;
  padding:5rem 0 0;
  background:#fff;
}

.hero-form{
  width:100%;
  max-width:400px;
}

.hero-form-heading{
  font-size:18px;
  font-weight:800;
  color:var(--mk-black);
  margin-bottom:6px;
  text-align:center;
}
.hero-form-sub{
  font-size:13px;
  color:var(--mk-text-muted);
  text-align:center;
  margin-bottom:24px;
}

.hero-field{
  display:flex;
  flex-direction:column;
  margin-bottom:16px;
}
.hero-field label{
  font-size:13px;
  font-weight:600;
  color:var(--mk-text);
  margin-bottom:4px;
}
.hero-field label .hero-req{
  color:#ef4444;
  font-size:11px;
  margin-left:4px;
}
.hero-field input,
.hero-field select,
.hero-field textarea{
  font-family:var(--mk-font);
  font-size:14px;
  padding:10px 14px;
  border:1px solid var(--mk-border);
  border-radius:8px;
  outline:none;
  transition:border-color .2s;
  background:#fff;
  color:var(--mk-text);
}
.hero-field input:focus,
.hero-field select:focus,
.hero-field textarea:focus{
  border-color:var(--mk-accent);
}
.hero-field textarea{resize:vertical;min-height:80px;}

.hero-form-btn{
  display:block;
  width:100%;
  padding:14px;
  background:var(--mk-accent);
  color:var(--mk-dark);
  border:none;
  border-radius:100px;
  font-family:var(--mk-font);
  font-size:15px;
  font-weight:700;
  cursor:pointer;
  transition:background .2s;
  margin-top:8px;
}
.hero-form-btn:hover{background:var(--mk-accent-dark);}

.hero-form-note{
  font-size:11px;
  color:var(--mk-text-muted);
  text-align:center;
  margin-top:12px;
  line-height:1.6;
}

/* ==========================================================
   LOGO SLIDER
   ========================================================== */
.hero-logos{
  background:#fff;
  border:1px solid var(--mk-text);
  padding:8px 0;
  overflow:hidden;
  position:relative;
  z-index:1;
}

.hero-logos-track{
  display:flex;
  gap:0px;
  width:max-content;
  animation:heroLogoScroll 40s linear infinite;
}

.hero-logos-track:hover{
  animation-play-state:paused;
}

.hero-logo-item{
  flex-shrink:0;
  width:180px;
  height:90px;
  background:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
  color:var(--mk-text-muted);
}
.hero-logo-item img {
  object-fit: contain;
  width: 100%;
}
@keyframes heroLogoScroll{
  0%{transform:translateX(0);}
  100%{transform:translateX(-50%);}
}

/* ==========================================================
   Wide: hero-section::after width fix (1900px+)
   ========================================================== */
@media(min-width:1900px){
  .hero-section::after{
    width: calc(9 / 13 * var(--mk-container));
  }
}

/* ==========================================================
   SP: Logo Grid 3 columns
   ========================================================== */
@media(max-width:768px){
  .hero-section::after{
    top:auto;
    left:0;
    right:0;
    width:100%;
    height:auto;
    bottom:0;
  }
  .hero-form-wrap {
    padding: 0;
  }
  .hero-inner{
    grid-template-columns:1fr;
    min-height:auto;
  }

  .hero-copy{
    padding:80px 0 40px;
    text-align:center;
    align-items:center;
  }

  .hero-form-wrap{
    padding:20px 0 20px;
    background:#fff;
    margin:0 -24px;
    padding-left:24px;
    padding-right:24px;
  }

  .hero-form{max-width:100%;}

  .hero-logos{padding:24px 16px;}

  .hero-logos-track{
    animation:none;
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:12px;
    width:100%;
  }

  .hero-logo-item.hero-logo-dup{
    display:none;
  }

  .hero-logo-item{
    width: 100%;
    height: 42px;
    font-size: 10px;
    margin: 8px;
  }
  .hero-logos-track{
    width: 90%;
    margin: 1em 5%;
  }
}

@media(max-width:480px){
  .hero-title{font-size:26px;}
  .hero-copy{padding:78px 0 32px;}
}

/* ==========================================================
   ABOUT SECTION — マーカスとは
   ========================================================== */
.about-section{
  background:#f7f5f3;
  border-bottom: 1px solid #241513;
}

.about-top{
  display:grid;
  grid-template-columns:1fr 2fr;
  align-items:stretch;
}

.about-left{
  padding:48px 40px;
  border-right:1px solid var(--mk-text);
  display:flex;
  align-items:flex-start;
}

.about-title{
  font-size:clamp(24px,3vw,32px);
  font-weight:900;
  line-height:1.4;
}

.about-right{
  display:flex;
  flex-direction:column;
}

.about-desc{
  font-size:16px;
  line-height:2;
  color:var(--mk-text);
  text-align:right;
  padding:48px 40px;
}

.about-steps-img{
  flex:1;
  min-height:280px;
  background:#f7f5f2;
  display:flex;
  align-items:center;
  justify-content:center;
  color:var(--mk-text-muted);
  font-size:14px;
  font-weight:500;
  letter-spacing:.05em;
  padding: 3em;
}
.about-steps-img img {
  width: 100%;
}

/* ==========================================================
   SERVICE SECTION — マーカスのサービス
   ========================================================== */
.svc-section{
  background:#f7f5f3;
  border-bottom: 1px solid #241513;
}

.svc-inner{
  display:grid;
  grid-template-columns:3fr 1fr;
  align-items:stretch;
  background:#fff;
}

.svc-title-area{
  display:flex;
  align-items:flex-start;
  justify-content:center;
  padding:2em 40px;
  border-left:1px solid #241614;
  background:var(--mk-bg);
}

.svc-title{
  font-size:clamp(24px,3vw,32px);
  font-weight:900;
  line-height:1.4;
}

.svc-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  background:#f7f5f2;
  padding: 4em 3em 4em 0;
}

.svc-tile{
  padding:32px 24px;
  text-align:center;
  border:1px solid var(--mk-border);
  background:#fff;
  transition:background .2s;
}

.svc-tile:hover{
  background:var(--mk-accent-light);
}

.svc-tile-icon{
  width:48px;
  height:48px;
  margin:0 auto 14px;
  display:flex;
  align-items:center;
  justify-content:center;
}

.svc-tile-name{
  font-size:14px;
  font-weight:700;
  color:var(--mk-dark);
  margin-bottom:8px;
  line-height:1.4;
}

.svc-tile-desc{
  font-size:12px;
  color:var(--mk-text-sub);
  line-height:1.7;
}

/* ==========================================================
   PC / SP
   ========================================================== */
@media(min-width:768px){
  .sp-only {
    display: none;
  }
  .pc-only {
    display: block;
  }
}
@media(max-width:768px){
  .pc-only {
    display: none;
  }
  .sp-only {
    display: block;
  }
}

/* ==========================================================
   Responsive
   ========================================================== */
@media(max-width:768px){

  /* About */
  .about-top{
    grid-template-columns:1fr;
  }
  .about-left{
    padding:28px 24px;
    border-right:none;
    border-bottom:1px solid #241614;
    justify-content:center;
  }
  .about-title{text-align:center;}
  .about-desc{text-align:left;padding:8px 4px;}
  .about-steps-img{min-height:180px;padding: 2em 0;}

  /* Service */
  .svc-inner{
    grid-template-columns:1fr;
  }
  .svc-title-area{
    text-align:center;
    justify-content:center;
    order:-1;
    border-left:none;
    border-bottom:1px solid var(--mk-border);
    padding:28px 24px;
  }
  .svc-grid{
    grid-template-columns:repeat(2,1fr);padding: 0 0 30px;
  }
}

/* ==========================================================
   CHALLENGE SECTION — こんな課題ありませんか？
   ========================================================== */
.challenge-section{
  background:#f7f5f3;
  border-bottom:1px solid #241614;
  padding:64px 0 80px;
}

.challenge-header{
  text-align:center;
  margin-bottom:40px;
}

.challenge-title{
  font-size:clamp(24px,3vw,32px);
  font-weight:900;
  line-height:1.4;
  margin-bottom:16px;
}

.challenge-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:16px;
  padding:0 2em;
}

.challenge-card{
  border-radius:var(--mk-radius);
  overflow:hidden;
  display:flex;
  flex-direction:column;
}

.challenge-icon{
  background:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:32px 24px;
}

.challenge-icon img{
  width:56px;
  height:56px;
  object-fit:contain;
}

.challenge-text{
  background:var(--mk-accent);
  padding:24px 20px;
  text-align:center;
  flex:1;
  display:flex;
  align-items:center;
  justify-content:center;
}

.challenge-text p{
  font-size:14px;
  font-weight:700;
  line-height:1.7;
  color:var(--mk-dark);
}

@media(max-width:768px){
  .challenge-grid{
    grid-template-columns:1fr;
    gap:12px;
    padding:0;
  }
}

/* ==========================================================
   FEATURE SECTION — マーカスの特徴
   ========================================================== */
.feat-section{
  display:flex;
  background:#f7f5f3;
  border-bottom:1px solid #241614;
}
.feat-container {
  display:flex;
  max-width: 1200px;
  justify-content: center;
  margin: 0 auto;
}

.feat-sticky{
  position:sticky;
  top:0;
  align-self:flex-start;
  width:33.333%;
  height:100vh;
  display:flex;
  flex-direction:column;
  justify-content:flex-start;
  padding:94px 40px;
  border-right:1px solid #241614;
  flex-shrink:0;
  background:#f7f5f3;
}

.feat-sticky-title{
  font-size:clamp(24px,2.6vw,32px);
  font-weight:900;
  line-height:1.4;
}

.feat-content{
  flex:1;
  padding:64px 48px 80px;
  display:flex;
  flex-direction:column;
  gap:64px;
}

.feat-block{
  display:flex;
  flex-direction:column;
  gap:16px;
}

.feat-num{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:40px;
  height:40px;
  background:var(--mk-dark);
  color:#fff;
  font-family:'Inter',sans-serif;
  font-size:18px;
  font-weight:800;
}

.feat-block-title{
  font-size:clamp(18px,2vw,24px);
  font-weight:800;
  line-height:1.4;
}

.feat-block-text{
  font-size:16px;
  color:var(--mk-text-sub);
  line-height:2;
}

.feat-block-text li{
  list-style:none;
  padding-left:1em;
  text-indent:-1em;
}
.feat-block-text li::before{
  content:'・';
}

.feat-block-img{
  width:100%;
  max-width:790px;
  display:flex;
  align-items:center;
  justify-content:center;
  color:rgba(255,255,255,.5);
  font-size:13px;
  font-weight:500;
  letter-spacing:.05em;
  margin-top:8px;
  overflow:hidden;
  position:relative;
}
.feat-block-img img {
  width: 100%;
}

@media(max-width:1024px){
  .feat-section,.feat-container{
    flex-direction:column;
  }
  .feat-sticky{
    position:static;
    width:100%;
    height:auto;
    border-right:none;
    border-bottom:1px solid #241614;
    padding:40px 24px;
    text-align:center;
    justify-content:flex-start;
    width: 90%;
    margin: 0 5%;
  }
  .feat-content{
    padding:48px 24px 64px;
    gap:48px;
  }
}

@media(max-width:768px){
  .feat-block-img{
    max-width:100%;
  }
}

/* ==========================================================
   CASE SECTION — 実績・導入事例
   ========================================================== */
.case-section{
  display:flex;
  background:#f7f5f3;
  border-bottom:1px solid #241614;
}
.case-container {
  display:flex;
  max-width: 1200px;
  justify-content: center;
  margin: 0 auto;
}

.case-sticky{
  position:sticky;
  top:0;
  align-self:flex-start;
  width:28%;
  height:100vh;
  display:flex;
  flex-direction:column;
  justify-content:flex-start;
  padding:94px 40px;
  border-left:1px solid #241614;
  flex-shrink:0;
  background:#f7f5f3;
  order:2;
}

.case-sticky-title{
  font-size:clamp(22px,2.6vw,30px);
  font-weight:900;
  line-height:1.4;
}

.case-content{
  flex:1;
  padding:64px 48px 80px;
  display:flex;
  flex-direction:column;
  gap:72px;
  order:1;
}

.case-num{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:40px;height:40px;
  background:var(--mk-dark);color:#fff;
  font-family:'Inter',sans-serif;font-size:18px;font-weight:800;
  margin-bottom:12px;
}

.case-industry{
  font-size:20px;font-weight:800;margin-bottom:4px;
}

.case-summary{
  font-size:16px;color:var(--mk-text-sub);margin-bottom:20px;line-height:1.8;
}

.case-chart{
  overflow:hidden;
  background:#f7f5f3;
  position: relative;
}

.case-chart-top{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap: 2em;
  position: relative;
}

.case-chart-col{
  padding:20px 24px;
  background: #fff;
  font-size:13px;
  line-height:1.8;
  color:var(--mk-text-sub);
  z-index: 1;
  border:1px solid var(--mk-border);
}

.case-chart-col:first-child{
  border-right:1px solid var(--mk-border);
}

.case-chart-label{
  display:inline-block;
  font-size:12px;font-weight:700;color:#fff;
  padding:2px 12px;border-radius:4px;
  margin-bottom:10px;
  background:var(--mk-dark);
}

.case-chart-label.type-support{
  background:var(--mk-text-muted);
}

.case-chart-col ul{
  list-style:none;
  padding:0;
}
.case-chart-col li{
  padding-left:1em;text-indent:-1em;font-size:14px;
}
.case-chart-col li::before{content:'・';}

.case-chart-arrow{
  display:flex;
  align-items:center;
  justify-content:center;
  padding:0;
  border-bottom:1px solid var(--mk-text);
  border-left:1px solid var(--mk-text);
  border-right:1px solid var(--mk-text);
  position:absolute;
  height:40px;
  width: 50%;
  margin: 1% 25%;
  top: 35%;
  z-index: 0;
}
.case-chart-arrow.nth-3 {
  top: 24%;
}
.case-chart-arrow.nth-4 {
  top: 26%;
}

.case-chart-arrow-label{
  display: inline-block;
  font-size: 14px;
  width: 10%;
  text-align: center;
  margin: 0 auto;
  font-weight: 700;
  background: var(--mk-dark);
  color: #fff;
  padding: 2px 16px;
  border-radius: 4px;
  position: relative;
  z-index: 1;
}

.case-chart-arrow::before{
  content:'';
  position:absolute;
  top:40px;left:50%;
  width:1px;height:50%;
  background:var(--mk-text);
}
.case-chart-arrow::after{
  content:'';
  position:absolute;
  top:54px;
  left:50%;
  transform:translateX(-50%);
  border-left:6px solid transparent;
  border-right:6px solid transparent;
  border-top:8px solid var(--mk-text);
}

.case-result-wrap {
  background-color: #FFF;
  border: 1px solid var(--mk-border);
  padding: 1em;
  display: flex;
  flex-wrap: nowrap;
  flex-direction: column;
  margin-top: 3em;
}
.case-chart-results{
  display:grid;
  grid-template-columns:repeat(var(--case-result-cols,2),1fr);
  gap: 2em;
}

.case-result-item{
  padding:20px;
  display:flex;
  gap:20px;
  align-items:flex-start;
  font-size:15px;
  font-weight: 600;
  line-height:1.7;
  color:var(--mk-text-sub);
  background-color: #f7f5f3;
  margin-top: 2em;
}
.case-result-item.tate {
  flex-direction: column;
}

.case-result-item.tate .case-result-icon{
  width: 100%;
  margin: 0 auto;
}

.case-result-icon{
  flex-shrink:0;
  width:20%;height:auto;
  max-width: 70px;
  display:flex;
  align-items:center;
  justify-content:center;
}
.case-result-icon img {
  max-width: 70px;
}

@media(max-width:1024px){
  .case-container{flex-direction:column;}
  .case-section{flex-direction:column;}
  .case-sticky{
    position:static;
    width:100%;height:auto;
    border-left:none;
    border-bottom:1px solid #241614;
    padding:40px 24px;
    text-align:center;
    order:0;
    width: 90%;
    margin: 0 5%
  }
  .case-content{
    padding:48px 24px 64px;
    gap:56px;
    order:1;
  }
}

@media(max-width:600px){
  .case-chart-top{grid-template-columns:1fr 1fr; gap:1em;}
  .case-chart-arrow {
    top:41%;
  }
  .case-chart-arrow-label {
    width: 30%;
  }
  .case-chart-col:first-child{border:1px solid var(--mk-border);}
  .case-chart-results{grid-template-columns:1fr; gap: 1em;}
  .case-result-item:not(:last-child){border-right:none;}
  .case-result-item {margin-top: 1em!important;}
  .case-chart-arrow.nth-2 {
    top: 40%;
  }
  .case-chart-arrow.nth-3{
    top: 27%;
  }
  .case-chart-arrow.nth-4{
    top: 27%;
  }
}
@media(max-width:425px){
  .case-chart-arrow.nth-3{
    top: 25%;
  }
  .case-chart-arrow.nth-4{
    top: 24%;
  }
}

/* ==========================================================
   PRICE SECTION — 料金プラン
   ========================================================== */
.price-section{
  background:#f7f5f3;
  border-bottom:1px solid #241614;
  padding:80px 0;
}

.price-title{
  font-size:clamp(28px,4vw,44px);
  font-weight:900;
  text-align:center;
  margin-bottom:48px;
}

.price-plans{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;
  margin-bottom:8px;
}

.price-card{
  border:1px solid var(--mk-border);
  border-radius:var(--mk-radius);
  padding:28px 24px 32px;
  text-align:center;
  background:#fff;
}

.price-card-label{
  display:inline-block;
  font-family:'Inter',sans-serif;
  font-size:13px;
  font-weight:700;
  color:#fff;
  background:var(--mk-dark);
  padding:4px 20px;
  border-radius:4px;
  margin-bottom:20px;
  letter-spacing:.04em;
}

.price-card-amount-wrap{
  background:#f7f5f3;
  border-radius:8px;
  padding:24px 16px;
}

.price-card-monthly{
  font-size:13px;
  color:var(--mk-text-muted);
  margin-bottom:4px;
}

.price-card-amount{
  font-family:'Inter',sans-serif;
  font-size:clamp(28px,3vw,36px);
  font-weight:800;
  color:var(--mk-dark);
  line-height:1.2;
}

.price-card-amount small{
  font-size:16px;
  font-weight:600;
}

.price-plus-row{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;
  text-align:center;
  padding:16px 0;
}

.price-plus{
  font-size:24px;
  font-weight:300;
  color:var(--mk-text);
  line-height:1;
}

.price-bar{
  border:1px solid var(--mk-border);
  border-radius:var(--mk-radius);
  padding:24px 32px;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:16px;
  background:#fff;
  text-align:center;
  margin-top: 1em;
}

.price-bar-label{
  font-size:14px;
  color:var(--mk-text-muted);
}

.price-bar-value{
  font-family:'Inter',sans-serif;
  font-size:clamp(22px,2.5vw,30px);
  font-weight:800;
  color:var(--mk-dark);
}

.price-bar-value small{
  font-size:14px;
  font-weight:500;
  color:var(--mk-text-sub);
  vertical-align: middle;
}

.price-plus-single{
  text-align:center;
  padding:16px 0;
  font-size:24px;
  font-weight:300;
  color:var(--mk-text);
  line-height:1;
}

.price-note{
  text-align:center;
  font-size:13px;
  color:var(--mk-text-sub);
  margin-top:32px;
  line-height:1.8;
}

@media(max-width:768px){
  .price-plans{
    grid-template-columns:1fr;
    gap:16px;
  }

  .price-plus-row{
    grid-template-columns:1fr;
    gap:0;
    padding:8px 0;
  }
  .price-plus-row .price-plus:not(:first-child){
    display:none;
  }

  .price-bar{
    padding:20px 16px;
    flex-direction:column;
    gap:4px;
  }
}

/* ==========================================================
   MEMBER SECTION
   ========================================================== */
.member-section{
  display:flex;
  background:#f7f5f3;
  border-bottom:1px solid #241614;
}

.member-container{
  display:flex;
  max-width:1200px;
  margin:0 auto;
  width:100%;
}

.member-sticky{
  position:sticky;
  top:0;
  align-self:flex-start;
  width:28%;
  height:100vh;
  display:flex;
  flex-direction:column;
  justify-content:flex-start;
  padding:94px 40px;
  border-right:1px solid #241614;
  flex-shrink:0;
  background:#f7f5f3;
}

.member-sticky-title{
  font-size:clamp(22px,2.6vw,30px);
  font-weight:900;
  line-height:1.4;
}

.member-content{
  flex:1;
  padding:64px 48px 80px;
  display:flex;
  flex-direction:column;
  gap:24px;
}

.member-card{
  display:flex;
  gap:24px;
  align-items:center;
  border:1px solid var(--mk-border);
  border-radius:var(--mk-radius);
  padding:28px;
  background:#fff;
}

.member-card:nth-child(even){
  flex-direction:row-reverse;
}

.member-photo{
  flex-shrink:0;
  width:88px;
  height:88px;
  border-radius:50%;
  background:linear-gradient(135deg,#c8c0b8,#a89e94);
  overflow:hidden;
  display:flex;
  align-items:center;
  justify-content:center;
  color:rgba(255,255,255,.4);
  font-size:11px;
}
.member-photo img {
  width: 100%;
}

.member-info{
  flex:1;
}

.member-label-wrap{
  display:flex;
  flex-wrap:wrap;
  gap:4px;
  margin-bottom:8px;
}

.member-label{
  display:inline-block;
  font-size:11px;
  font-weight:700;
  color:#fff;
  background:var(--mk-dark);
  padding:3px 12px;
  border-radius:4px;
  line-height:1.6;
  white-space:nowrap;
}

.member-desc{
  font-size:13px;
  color:var(--mk-text-sub);
  line-height:1.8;
}

@media(max-width:1024px){
  .member-container{flex-direction:column;}
  .member-sticky{
    position:static;
    width:100%;height:auto;
    border-right:none;
    border-bottom:1px solid #241614;
    padding:40px 24px;
    text-align:center;
    width: 90%;
    margin: 0 5%
  }
  .member-content{
    padding:48px 24px 64px;
    gap:20px;
  }
}

@media(max-width:768px){
  .member-card,
  .member-card:nth-child(even){
    flex-direction:row;
  }
  .member-card{
    padding:20px;
    gap:16px;
  }
  .member-photo{
    width:64px;
    height:64px;
  }
}

/* ==========================================================
   CTA SECTION
   ========================================================== */
.cta-section{
  background:var(--mk-bg);
  padding:64px 0;
  border-bottom:1px solid #241614;
}

.cta-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:24px;
}

.cta-btn{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:16px;
  background:var(--mk-dark);
  color:#fff;
  padding:48px 32px;
  text-decoration:none;
  transition:opacity .2s;
}

.cta-btn:hover .cta-btn-text{
  font-size:calc(clamp(18px,2vw,24px) * 1.1);
  color:#fff;
}

.cta-btn-icon{
  flex-shrink:0;
  width:32px;
  height:32px;
  display:flex;
  align-items:center;
  justify-content:center;
}

.cta-btn-text{
  font-size:clamp(18px,2vw,24px);
  font-weight:800;
  letter-spacing:.05em;
  transition:font-size .3s ease;
}

@media(max-width:768px){
  .cta-section{
    padding:0;
  }
  .cta-section .mk-container{
    padding:0;
    max-width:100%;
  }
  .cta-grid{
    grid-template-columns:1fr;
    gap:0;
  }
  .cta-btn{
    padding:40px 24px;
    border-bottom:1px solid rgba(255,255,255,.15);
  }
  .cta-btn:last-child{
    border-bottom:none;
  }
}
