/* ============================================================
   SUKOON — Wellness & Coaching
   Design system
   ============================================================ */
:root{
  /* Warm greige grounds (from logo) */
  --paper:#F7F4EC;
  --greige:#EFEBE0;
  --greige-deep:#E6E0D2;
  --card:#FBF9F3;

  /* Greens from the logo */
  --sage:#90B68C;          /* the "Sukoon" wordmark green */
  --sage-soft:#AECBA8;
  --leaf:#6FBF7B;          /* brighter leaf */
  --forest:#56683F;        /* deep olive stem */
  --forest-deep:#3F4D2F;

  /* Warm earth accents */
  --clay:#BE8862;
  --clay-soft:#D8B894;
  --sand:#E7D7BE;

  /* Ink + muted text (warm) */
  --ink:#2C2A22;
  --ink-soft:#54503F;
  --muted:#857E6A;
  --line:#DAD2C0;
  --line-soft:#E5DECE;

  /* Type */
  --serif:"Cormorant Garamond", Georgia, serif;
  --sans:"Montserrat", "Helvetica Neue", Arial, sans-serif;

  --maxw:1200px;
  --radius:4px;
  --shadow-sm:0 1px 2px rgba(63,77,47,.05), 0 6px 18px rgba(63,77,47,.05);
  --shadow-md:0 4px 12px rgba(63,77,47,.07), 0 24px 48px rgba(63,77,47,.08);
  --shadow-lg:0 12px 40px rgba(63,77,47,.12), 0 40px 80px rgba(63,77,47,.10);
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  background:var(--greige);
  color:var(--ink);
  font-family:var(--sans);
  font-size:16px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
::selection{background:var(--sage-soft);color:var(--forest-deep);}

/* ---------- Typography ---------- */
h1,h2,h3,h4{font-family:var(--serif);font-weight:500;line-height:1.12;margin:0;letter-spacing:.005em;}
h1{font-size:clamp(2.9rem,6vw,5.2rem);line-height:1.1;}
h2{font-size:clamp(2.2rem,4.6vw,3.6rem);}
h3{font-size:clamp(1.5rem,2.6vw,2rem);}
p{margin:0 0 1.1em;text-wrap:pretty;}
.lead{font-size:clamp(1.05rem,1.5vw,1.3rem);color:var(--ink-soft);line-height:1.7;}
/* headings that introduce body copy need breathing room below */
.hero-copy h1,.intro h2,.app-copy h2,.coach-copy h2,.sec-head h2,.cta-band h2{margin-bottom:.5em;}

.eyebrow{
  font-family:var(--sans);
  font-size:.72rem;
  font-weight:600;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:var(--forest);
}
.serif-accent{font-family:var(--serif);font-style:italic;color:var(--sage);}

/* ---------- Layout helpers ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 32px;}
.wrap-narrow{max-width:840px;margin:0 auto;padding:0 32px;}
section{position:relative;}
.section-pad{padding:clamp(72px,11vw,140px) 0;}
.center{text-align:center;}
.divider{width:54px;height:1px;background:var(--forest);opacity:.5;margin:22px 0;}
.center .divider{margin-left:auto;margin-right:auto;}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.6em;
  font-family:var(--sans);font-size:.78rem;font-weight:600;
  letter-spacing:.16em;text-transform:uppercase;
  padding:16px 30px;border-radius:40px;border:1px solid transparent;
  cursor:pointer;transition:all .25s ease;white-space:nowrap;
}
.btn-primary{background:var(--forest);color:var(--paper);}
.btn-primary:hover{background:var(--forest-deep);transform:translateY(-2px);box-shadow:var(--shadow-md);}
.btn-outline{background:transparent;color:var(--forest);border-color:var(--forest);}
.btn-outline:hover{background:var(--forest);color:var(--paper);}
.btn-light{background:var(--paper);color:var(--forest-deep);}
.btn-light:hover{background:#fff;transform:translateY(-2px);box-shadow:var(--shadow-md);}
.btn-ghost{padding-left:0;padding-right:0;background:none;color:var(--forest);letter-spacing:.14em;}
.btn-ghost .arrow{transition:transform .25s ease;}
.btn-ghost:hover .arrow{transform:translateX(5px);}
.btn-sm{padding:12px 22px;font-size:.72rem;}
.btn-block{display:flex;width:100%;justify-content:center;}

/* ---------- Header ---------- */
.site-header{
  position:sticky;top:0;z-index:60;
  background:rgba(239,235,224,.82);
  backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line-soft);
}
.nav{display:flex;align-items:center;justify-content:space-between;height:92px;}
.brand{display:flex;align-items:center;gap:12px;}
.brand img{height:66px;width:auto;display:block;}
.brand .brand-fallback{font-family:var(--serif);font-size:1.7rem;color:var(--sage);line-height:1;}
.nav-links{display:flex;align-items:center;gap:34px;list-style:none;margin:0;padding:0;}
.nav-links a{
  font-size:.74rem;font-weight:600;letter-spacing:.13em;text-transform:uppercase;
  color:var(--ink-soft);position:relative;padding:6px 0;transition:color .2s;
}
.nav-links a:hover,.nav-links a.active{color:var(--forest);}
.nav-links a.active::after{
  content:"";position:absolute;left:0;right:0;bottom:-2px;height:1.5px;background:var(--sage);
}
.nav-right{display:flex;align-items:center;gap:18px;}

/* currency switcher */
.currency-select{
  position:relative;font-size:.72rem;font-weight:600;letter-spacing:.1em;
}
.currency-select select{
  appearance:none;-webkit-appearance:none;
  font-family:var(--sans);font-size:.72rem;font-weight:600;letter-spacing:.08em;
  color:var(--forest);background:transparent;border:1px solid var(--line);
  border-radius:30px;padding:9px 34px 9px 16px;cursor:pointer;
}
.currency-select::after{
  content:"";position:absolute;right:14px;top:50%;width:6px;height:6px;
  border-right:1.5px solid var(--forest);border-bottom:1.5px solid var(--forest);
  transform:translateY(-65%) rotate(45deg);pointer-events:none;
}
.nav-toggle{display:none;background:none;border:none;cursor:pointer;width:30px;height:24px;position:relative;}
.nav-toggle span{position:absolute;left:0;right:0;height:2px;background:var(--forest);transition:.3s;}
.nav-toggle span:nth-child(1){top:2px;}
.nav-toggle span:nth-child(2){top:11px;}
.nav-toggle span:nth-child(3){top:20px;}

/* ---------- Footer ---------- */
.site-footer{background:var(--forest-deep);color:#D9DDCB;padding:80px 0 36px;}
.site-footer a{color:#D9DDCB;opacity:.82;transition:opacity .2s;}
.site-footer a:hover{opacity:1;}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.3fr;gap:48px;}
.footer-brand .fmark{font-family:var(--serif);font-size:2.4rem;color:#fff;line-height:1;}
.footer-brand .ftag{font-size:.66rem;letter-spacing:.26em;text-transform:uppercase;color:var(--sage-soft);margin-top:6px;}
.footer-brand .footer-logo{width:210px;max-width:72%;height:auto;display:block;margin:-6px 0 2px -4px;}
.footer-social{display:flex;gap:10px;margin-top:20px;flex-wrap:wrap;}
.social-link{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;border:1px solid rgba(255,255,255,.22);border-radius:30px;font-size:.78rem;letter-spacing:.03em;color:#E4E8D6;transition:background .25s ease,border-color .25s ease;}
.social-link:hover{background:rgba(255,255,255,.08);border-color:var(--sage-soft);}
.social-link svg{width:16px;height:16px;flex-shrink:0;color:var(--sage-soft);}
.about-linkedin{display:inline-flex;align-items:center;gap:8px;font-size:.92rem;font-weight:500;color:var(--forest);align-self:center;transition:color .2s ease;}
.about-linkedin svg{width:19px;height:19px;color:var(--sage);transition:color .2s ease;}
.about-linkedin:hover{color:var(--sage);}
.about-linkedin:hover svg{color:var(--forest);}
.footer-col h4{font-family:var(--sans);font-size:.72rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:#fff;margin-bottom:18px;}
.footer-col ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:11px;font-size:.92rem;}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;gap:20px;margin-top:60px;padding-top:26px;border-top:1px solid rgba(255,255,255,.12);font-size:.78rem;opacity:.7;flex-wrap:wrap;}
.footer-disclaimer{margin-top:54px;font-size:.78rem;line-height:1.65;opacity:.62;max-width:760px;}
.footer-disclaimer a{color:#fff;text-decoration:underline;text-underline-offset:2px;}
.footer-disclaimer + .footer-bottom{margin-top:22px;}

/* ---------- Decorative vine ---------- */
.vine{position:absolute;pointer-events:none;opacity:.5;}
.leaf-tag{font-family:var(--mono,ui-monospace,monospace);}

/* ---------- Pills / chips ---------- */
.pill{
  display:inline-flex;align-items:center;gap:7px;
  font-size:.68rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;
  padding:7px 15px;border-radius:30px;background:var(--card);border:1px solid var(--line);color:var(--forest);
}
.pill .dot{width:6px;height:6px;border-radius:50%;background:var(--leaf);}

/* ---------- Cards ---------- */
.card{background:var(--card);border:1px solid var(--line-soft);border-radius:var(--radius);box-shadow:var(--shadow-sm);}

/* ---------- Image placeholder slots ---------- */
.slot-img{display:block;object-fit:cover;background:var(--greige-deep);}
.slot-img.contain{object-fit:contain;}
image-slot{--slot-bg:var(--greige-deep);}
.slot-elegant{
  background:
    repeating-linear-gradient(135deg,rgba(86,104,63,.05) 0 2px,transparent 2px 11px),
    var(--greige-deep);
  border:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;
  color:var(--muted);
}

/* ---------- Reveal animation ----------
   Base state is VISIBLE so content can never get stuck hidden if a
   transition/animation stalls (e.g. off-screen capture or a backgrounded
   tab). The entrance is a one-shot keyframe applied when JS adds .in. */
.reveal{opacity:1;}
.reveal.in{animation:sukoonReveal .8s cubic-bezier(.2,.7,.2,1) both;}
/* hard safety: once revealed, never allow a stalled animation to keep
   content hidden — force the final visible state. */
.reveal.reveal-done{animation:none !important;opacity:1 !important;transform:none !important;}
.reveal.d1.in{animation-delay:.08s;}
.reveal.d2.in{animation-delay:.16s;}
.reveal.d3.in{animation-delay:.24s;}
.reveal.d4.in{animation-delay:.32s;}
@keyframes sukoonReveal{from{opacity:0;transform:translateY(22px);}to{opacity:1;transform:none;}}
@media(prefers-reduced-motion:reduce){.reveal.in{animation:none;}}

/* chip bar */
.svc-chip-bar{position:sticky;top:78px;z-index:40;background:rgba(247,244,236,.9);backdrop-filter:blur(10px);border-bottom:1px solid var(--line-soft);}
.svc-chips{display:flex;gap:10px;padding:16px 32px;flex-wrap:wrap;justify-content:center;}
.chip-link{font-size:.72rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--forest);
  padding:9px 18px;border:1px solid var(--line);border-radius:30px;transition:all .2s;background:var(--card);}
.chip-link:hover{background:var(--forest);color:var(--paper);border-color:var(--forest);}

/* how it works */
.how-sec{background:var(--paper);}
.how-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;}
.how-step{position:relative;padding:34px 28px;background:var(--card);border:1px solid var(--line-soft);border-radius:6px;}
.how-num{font-family:var(--serif);font-size:2.6rem;color:var(--sage);line-height:1;display:block;margin-bottom:16px;}
.how-step h3{font-size:1.35rem;margin-bottom:8px;}
.how-step p{font-size:.92rem;color:var(--ink-soft);margin:0;}
@media(max-width:860px){.how-grid{grid-template-columns:1fr 1fr;}}
@media(max-width:520px){.how-grid{grid-template-columns:1fr;}}

/* ============================================================
   BOOKING FLOW
   ============================================================ */
.book-wrap{padding:clamp(36px,5vw,64px) 0 clamp(60px,8vw,100px);}
.book-layout{display:grid;grid-template-columns:1.6fr .9fr;gap:40px;align-items:start;}

/* stepper */
.stepper{display:flex;gap:6px;margin-bottom:36px;flex-wrap:wrap;}
.step-pip{display:flex;align-items:center;gap:10px;font-size:.72rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);}
.step-pip .pip-num{width:28px;height:28px;border-radius:50%;border:1.5px solid var(--line);display:grid;place-items:center;font-size:.78rem;background:var(--card);transition:all .25s;}
.step-pip.active .pip-num{background:var(--forest);color:var(--paper);border-color:var(--forest);}
.step-pip.done .pip-num{background:var(--sage);color:#fff;border-color:var(--sage);}
.step-pip.active{color:var(--forest);}
.step-pip .pip-line{width:24px;height:1.5px;background:var(--line);}
@media(max-width:680px){.step-pip .pip-label{display:none;}.step-pip .pip-line{width:14px;}}

.book-panel{background:var(--card);border:1px solid var(--line-soft);border-radius:10px;padding:clamp(28px,4vw,44px);box-shadow:var(--shadow-sm);}
.book-step{display:none;}
.book-step.active{display:block;animation:sukoonReveal .45s ease both;}
.book-step h2{font-size:clamp(1.7rem,3vw,2.3rem);margin-bottom:8px;}
.book-step .step-sub{color:var(--ink-soft);margin-bottom:30px;}

/* option cards (service + tier) */
.opt-list{display:grid;gap:14px;}
.opt-card{display:flex;align-items:center;gap:18px;padding:20px 22px;border:1.5px solid var(--line);border-radius:8px;cursor:pointer;background:var(--paper);transition:all .2s;text-align:left;width:100%;font-family:inherit;}
.opt-card:hover{border-color:var(--sage);transform:translateX(3px);}
.opt-card.selected{border-color:var(--forest);background:#fff;box-shadow:var(--shadow-sm);}
.opt-card .opt-ico{width:48px;height:48px;flex-shrink:0;border-radius:50%;background:var(--greige-deep);display:grid;place-items:center;color:var(--forest);}
.opt-card .opt-ico svg{width:24px;height:24px;}
.opt-card .opt-body{flex:1;display:flex;flex-direction:column;gap:3px;}
.opt-card .opt-title{display:block;font-family:var(--serif);font-size:1.4rem;line-height:1.1;color:var(--ink);}
.opt-card .opt-meta{display:block;font-size:.84rem;color:var(--muted);margin-top:0;}
.opt-card .opt-price{font-family:var(--serif);font-size:1.5rem;color:var(--forest);white-space:nowrap;}
.opt-card .opt-price small{display:block;font-family:var(--sans);font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);text-align:right;}
.opt-card .opt-check{width:24px;height:24px;flex-shrink:0;border-radius:50%;border:1.5px solid var(--line);display:grid;place-items:center;color:transparent;}
.opt-card.selected .opt-check{background:var(--forest);border-color:var(--forest);color:#fff;}
.opt-card .opt-check svg{width:14px;height:14px;}
.opt-card.free-card{background:var(--forest);border-color:var(--forest);color:var(--paper);}
.opt-card.free-card .opt-title{color:#fff;}
.opt-card.free-card .opt-meta{color:#C8CFBA;}
.opt-card.free-card .opt-ico{background:rgba(255,255,255,.12);color:#fff;}
.opt-card.free-card .opt-price{color:var(--sage-soft);}

/* calendar */
.cal{background:var(--paper);border:1px solid var(--line);border-radius:10px;padding:22px;}
.cal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;}
.cal-head .cal-title{font-family:var(--serif);font-size:1.35rem;}
.cal-nav{background:var(--card);border:1px solid var(--line);width:36px;height:36px;border-radius:50%;cursor:pointer;display:grid;place-items:center;color:var(--forest);transition:all .2s;}
.cal-nav:hover{background:var(--forest);color:#fff;}
.cal-nav:disabled{opacity:.35;cursor:not-allowed;}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;}
.cal-dow{text-align:center;font-size:.66rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);padding:6px 0;font-weight:600;}
.cal-day{aspect-ratio:1;border:none;background:none;border-radius:8px;cursor:pointer;font-family:inherit;font-size:.92rem;color:var(--ink);display:grid;place-items:center;transition:all .15s;position:relative;}
.cal-day:hover:not(:disabled){background:var(--greige-deep);}
.cal-day.empty{pointer-events:none;}
.cal-day:disabled{color:var(--line);cursor:default;}
.cal-day.available::after{content:"";position:absolute;bottom:5px;left:50%;transform:translateX(-50%);width:4px;height:4px;border-radius:50%;background:var(--leaf);}
.cal-day.selected{background:var(--forest);color:#fff;}
.cal-day.selected::after{background:#fff;}
.cal-day.today{font-weight:700;color:var(--forest);}

.slots{margin-top:24px;}
.slots h4{font-family:var(--sans);font-size:.74rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--forest);margin-bottom:14px;}
.slot-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(96px,1fr));gap:10px;}
.slot{padding:12px 8px;border:1.5px solid var(--line);border-radius:8px;background:var(--paper);cursor:pointer;font-family:inherit;font-size:.86rem;color:var(--ink);transition:all .18s;text-align:center;}
.slot:hover{border-color:var(--sage);}
.slot.selected{background:var(--forest);color:#fff;border-color:var(--forest);}
.slot-empty{color:var(--muted);font-size:.9rem;font-style:italic;}

/* forms */
.field{margin-bottom:20px;}
.field label{display:block;font-size:.74rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--forest);margin-bottom:8px;}
.field input,.field textarea,.field select{width:100%;font-family:inherit;font-size:.98rem;color:var(--ink);background:var(--paper);border:1.5px solid var(--line);border-radius:8px;padding:14px 16px;transition:border-color .2s;}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--sage);}
.field textarea{resize:vertical;min-height:96px;}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.field-error input,.field-error textarea{border-color:var(--clay);}
.err-msg{color:var(--clay);font-size:.78rem;margin-top:6px;display:none;}
.field-error .err-msg{display:block;}

/* payment methods */
.pay-method-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:24px;}
.pay-method{padding:16px 12px;border:1.5px solid var(--line);border-radius:8px;background:var(--paper);cursor:pointer;text-align:center;font-size:.78rem;font-weight:600;color:var(--ink-soft);transition:all .18s;}
.pay-method:hover{border-color:var(--sage);}
.pay-method.selected{border-color:var(--forest);background:#fff;color:var(--forest);box-shadow:var(--shadow-sm);}
.pay-method .pm-name{display:block;}
.pay-method .pm-sub{font-size:.64rem;font-weight:500;letter-spacing:.04em;color:var(--muted);text-transform:uppercase;margin-top:3px;}
.card-form{padding:22px;background:var(--paper);border:1px solid var(--line);border-radius:10px;margin-bottom:8px;}
.pay-alt-note{text-align:center;padding:24px;background:var(--paper);border:1px dashed var(--line);border-radius:10px;color:var(--ink-soft);font-size:.92rem;}

/* nav buttons */
.book-nav{display:flex;justify-content:space-between;gap:14px;margin-top:32px;}
.book-nav .btn-back{background:none;border:1px solid var(--line);color:var(--ink-soft);}
.book-nav .btn-back:hover{border-color:var(--forest);color:var(--forest);background:none;transform:none;}
.book-nav .spacer{flex:1;}

/* summary */
.book-summary{position:sticky;top:100px;background:var(--forest-deep);color:#E4E8D6;border-radius:12px;padding:32px 30px;}
.book-summary h3{font-family:var(--serif);color:#fff;font-size:1.5rem;margin-bottom:20px;}
.sum-row{display:flex;justify-content:space-between;gap:14px;padding:13px 0;border-bottom:1px solid rgba(255,255,255,.12);font-size:.9rem;}
.sum-row .sum-k{color:#AEB89C;}
.sum-row .sum-v{color:#fff;text-align:right;font-weight:500;}
.sum-row .sum-v.empty{color:#7E8B6B;font-style:italic;font-weight:400;}
.sum-total{display:flex;justify-content:space-between;align-items:baseline;margin-top:20px;padding-top:18px;}
.sum-total .st-k{font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:var(--sage-soft);}
.sum-total .st-v{font-family:var(--serif);font-size:2.1rem;color:#fff;}
.sum-note{font-size:.74rem;color:#AEB89C;margin-top:16px;line-height:1.5;}
.sum-trust{display:flex;align-items:center;gap:8px;margin-top:18px;font-size:.74rem;color:#C8CFBA;}
.sum-trust svg{width:16px;height:16px;color:var(--sage-soft);flex-shrink:0;}

/* confirmation */
.confirm{text-align:center;padding:20px 0;}
.confirm .check-circle{width:84px;height:84px;border-radius:50%;background:var(--sage);display:grid;place-items:center;margin:0 auto 26px;color:#fff;}
.confirm .check-circle svg{width:42px;height:42px;}
.confirm h2{margin-bottom:12px;}
.confirm .conf-card{background:var(--paper);border:1px solid var(--line);border-radius:10px;padding:26px;margin:28px auto 0;max-width:440px;text-align:left;}
.confirm .conf-card .sum-row .sum-k{color:var(--muted);}
.confirm .conf-card .sum-row .sum-v{color:var(--ink);}
.confirm .conf-card .sum-row{border-color:var(--line-soft);}
.confirm .cal-embed{margin:30px auto 0;max-width:760px;background:var(--card);border:1px solid var(--line-soft);border-radius:12px;padding:10px;box-shadow:var(--shadow-sm);overflow:hidden;}
.confirm .cal-embed iframe{display:block;}
@media(max-width:560px){.confirm .cal-embed iframe{height:560px;}}

@media(max-width:920px){
  .book-layout{grid-template-columns:1fr;gap:28px;}
  .book-summary{position:static;order:-1;}
}
@media(max-width:520px){
  .pay-method-grid{grid-template-columns:1fr 1fr;}
  .field-row{grid-template-columns:1fr;}
  .opt-card{flex-wrap:wrap;}
}

/* ============================================================
   ABOUT — Coach Kay
   ============================================================ */
.about-hero{padding:clamp(48px,7vw,90px) 0 clamp(40px,5vw,70px);}
.about-hero-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,80px);align-items:center;}
.about-hero-media{position:relative;}
.about-hero-media .about-badge{position:absolute;right:-20px;bottom:30px;background:var(--paper);border:1px solid var(--line-soft);border-radius:50px;padding:14px 22px;box-shadow:var(--shadow-md);text-align:center;}
.about-hero-media .about-badge strong{display:block;font-family:var(--serif);font-size:1.9rem;color:var(--forest);line-height:1;}
.about-hero-media .about-badge span{font-size:.64rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);}

.stat-band{background:var(--forest);color:#E4E8D6;}
.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;padding:48px 0;}
.stat-item{text-align:center;}
.stat-item strong{font-family:var(--serif);font-size:clamp(2.4rem,4vw,3.2rem);color:#fff;display:block;line-height:1;}
.stat-item span{font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;color:var(--sage-soft);margin-top:8px;display:block;}

.story-sec .story-grid{display:grid;grid-template-columns:1fr 1.3fr;gap:clamp(36px,5vw,70px);}
.story-sec h2{margin-bottom:.4em;}
.story-aside{position:sticky;top:120px;align-self:start;}
.story-aside .pill{margin-bottom:14px;}

.cred-sec{background:var(--paper);}
.cred-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:46px;}
.cred-card{background:var(--card);border:1px solid var(--line-soft);border-radius:6px;padding:30px 28px;}
.cred-card .cred-ico{width:46px;height:46px;border-radius:50%;background:var(--greige-deep);display:grid;place-items:center;color:var(--forest);margin-bottom:18px;}
.cred-card .cred-ico svg{width:22px;height:22px;}
.cred-card h3{font-size:1.25rem;margin-bottom:6px;}
.cred-card p{font-size:.9rem;color:var(--ink-soft);margin:0;}

.expertise-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px 40px;margin-top:30px;}
.expertise-grid .tick li{font-size:.98rem;}

.philosophy{background:var(--sage);color:var(--forest-deep);text-align:center;}
.philosophy blockquote{max-width:820px;margin:0 auto;font-family:var(--serif);font-style:italic;font-size:clamp(1.6rem,3.2vw,2.5rem);line-height:1.32;}
.philosophy .ph-attr{margin-top:26px;font-size:.76rem;letter-spacing:.16em;text-transform:uppercase;color:var(--forest-deep);opacity:.8;}

@media(max-width:860px){
  .about-hero-grid{grid-template-columns:1fr;gap:36px;}
  .about-hero-media{max-width:440px;}
  .stat-grid{grid-template-columns:1fr 1fr;gap:32px 24px;}
  .story-sec .story-grid{grid-template-columns:1fr;gap:28px;}
  .story-aside{position:static;}
  .cred-grid{grid-template-columns:1fr;}
  .expertise-grid{grid-template-columns:1fr;}
}

/* ============================================================
   PACKAGES / PRICING
   ============================================================ */
.pkg-tabs{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin-bottom:14px;}
.pkg-tab{display:flex;align-items:center;gap:9px;font-size:.74rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;
  color:var(--ink-soft);padding:12px 20px;border:1px solid var(--line);border-radius:40px;background:var(--card);cursor:pointer;transition:all .22s;}
.pkg-tab svg{width:18px;height:18px;}
.pkg-tab:hover{border-color:var(--sage);color:var(--forest);}
.pkg-tab.active{background:var(--forest);color:var(--paper);border-color:var(--forest);}
.pkg-tab.active svg{color:var(--paper);}
.pkg-cat-intro{text-align:center;max-width:600px;margin:0 auto 50px;color:var(--ink-soft);}
.pkg-cat-intro h2{margin-bottom:.3em;}

.pkg-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;align-items:stretch;max-width:760px;margin:0 auto;}
.pkg-grid.three{grid-template-columns:repeat(3,1fr);max-width:1080px;}

/* parent / category note callouts */
.pkg-cat-note{max-width:700px;margin:18px auto 0;text-align:center;font-size:.88rem;line-height:1.55;color:var(--forest);background:var(--sand);border-radius:12px;padding:14px 26px;}
.svc-parent-note{margin:8px 0 4px;font-size:.9rem;line-height:1.55;color:var(--forest);background:var(--sand);border-radius:12px;padding:14px 18px;max-width:560px;}
.book-parent-note{display:flex;gap:12px;align-items:flex-start;margin:0 0 22px;font-size:.9rem;line-height:1.55;color:var(--forest);background:var(--sand);border-radius:12px;padding:14px 18px;text-align:left;}
.book-parent-note svg{width:22px;height:22px;flex-shrink:0;color:var(--clay);margin-top:1px;}
.pkg-card{display:flex;flex-direction:column;background:var(--card);border:1px solid var(--line-soft);border-radius:8px;padding:38px 32px;position:relative;transition:transform .3s ease,box-shadow .3s ease;}
.pkg-card.core{border-color:var(--sage);box-shadow:var(--shadow-md);}
.pkg-card.premium{background:var(--forest-deep);color:#E4E8D6;border-color:var(--forest-deep);}
.pkg-ribbon{position:absolute;top:0;left:50%;transform:translate(-50%,-50%);background:var(--sage);color:var(--forest-deep);
  font-size:.64rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;padding:7px 16px;border-radius:30px;white-space:nowrap;}
.pkg-card.premium .pkg-ribbon{background:var(--clay);color:#fff;}
.pkg-level{font-size:.68rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--forest);}
.pkg-card.premium .pkg-level{color:var(--sage-soft);}
.pkg-name{font-family:var(--serif);font-size:2.2rem;line-height:1;margin:10px 0 6px;}
.pkg-dur{font-size:.82rem;letter-spacing:.06em;color:var(--muted);text-transform:uppercase;}
.pkg-card.premium .pkg-dur{color:#AEB89C;}
.pkg-price-row{display:flex;align-items:baseline;gap:8px;margin:22px 0 4px;padding-bottom:22px;border-bottom:1px solid var(--line);}
.pkg-card.premium .pkg-price-row{border-color:rgba(255,255,255,.15);}
.pkg-price{font-family:var(--serif);font-size:2.7rem;line-height:1;color:var(--ink);}
.pkg-card.premium .pkg-price{color:#fff;}
.pkg-price-sub{font-size:.78rem;color:var(--muted);}
.pkg-card.premium .pkg-price-sub{color:#AEB89C;}
.pkg-desc{font-size:.92rem;color:var(--ink-soft);margin:20px 0 18px;line-height:1.55;}
.pkg-card.premium .pkg-desc{color:#C8CFBA;}
.pkg-feats{list-style:none;margin:0 0 26px;padding:0;display:grid;gap:12px;flex:1;}
.pkg-feats li{position:relative;padding-left:27px;font-size:.9rem;color:var(--ink-soft);line-height:1.45;}
.pkg-card.premium .pkg-feats li{color:#D5DBC7;}
.pkg-feats li svg{position:absolute;left:0;top:.18em;width:16px;height:16px;color:var(--sage);}
.pkg-card.premium .pkg-feats li svg{color:var(--leaf);}
.pkg-feats li.app-feat{font-weight:600;color:var(--forest);}
.pkg-card.premium .pkg-feats li.app-feat{color:#fff;}
.pkg-app-badge{display:inline-flex;align-items:center;gap:8px;font-size:.66rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  background:var(--clay);color:#fff;padding:6px 12px;border-radius:30px;margin-bottom:18px;align-self:flex-start;}
.pkg-pay-note{font-size:.76rem;color:var(--muted);text-align:center;margin-top:14px;}
.pkg-card.premium .pkg-pay-note{color:#AEB89C;}

/* trust / payment channels */
.pay-strip{background:var(--paper);border-top:1px solid var(--line-soft);border-bottom:1px solid var(--line-soft);}
.pay-inner{display:flex;align-items:center;justify-content:center;gap:30px;padding:26px 32px;flex-wrap:wrap;}
.pay-inner > span{font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);font-weight:600;}
.pay-methods{display:flex;gap:12px;flex-wrap:wrap;align-items:center;}
.pay-chip{font-size:.74rem;font-weight:600;letter-spacing:.04em;color:var(--forest);background:var(--card);border:1px solid var(--line);border-radius:8px;padding:9px 15px;}

/* compare note */
.pkg-foot-note{text-align:center;max-width:680px;margin:46px auto 0;font-size:.92rem;color:var(--ink-soft);}

/* FAQ */
.faq-sec{background:var(--paper);}
.faq-list{max-width:760px;margin:0 auto;}
.faq-item{border-bottom:1px solid var(--line);}
.faq-q{width:100%;text-align:left;background:none;border:none;cursor:pointer;padding:26px 40px 26px 0;position:relative;
  font-family:var(--serif);font-size:1.4rem;color:var(--ink);}
.faq-q::after{content:"+";position:absolute;right:6px;top:50%;transform:translateY(-50%);font-family:var(--sans);font-size:1.6rem;color:var(--sage);font-weight:300;transition:transform .3s;}
.faq-item.open .faq-q::after{content:"–";}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s ease;}
.faq-a p{margin:0 0 26px;color:var(--ink-soft);font-size:.98rem;}

@media(max-width:860px){.pkg-grid{grid-template-columns:1fr;max-width:440px;margin:0 auto;}}
@media(max-width:980px){.pkg-grid.three{grid-template-columns:1fr;max-width:440px;margin:0 auto;}}

/* ============================================================
   SUBPAGE HERO (shared: services, packages, about, book)
   ============================================================ */
.page-hero{background:var(--paper);padding:clamp(56px,8vw,104px) 0 clamp(48px,6vw,80px);text-align:center;position:relative;overflow:hidden;}
.page-hero .eyebrow{margin-bottom:18px;}
.page-hero h1{font-size:clamp(2.6rem,5.5vw,4.4rem);margin-bottom:.4em;}
.page-hero .lead{max-width:620px;margin:0 auto;}
.page-hero .divider{margin:22px auto;}
.page-hero-vine{position:absolute;left:50%;bottom:-120px;width:420px;height:280px;transform:translateX(-50%);
  background:radial-gradient(ellipse at center,rgba(144,182,140,.18),transparent 65%);pointer-events:none;}

/* ============================================================
   SERVICES DETAIL
   ============================================================ */
.svc-detail{padding:clamp(56px,8vw,96px) 0;border-bottom:1px solid var(--line-soft);}
.svc-detail:nth-child(even){background:var(--paper);}
.svc-detail-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(40px,6vw,84px);align-items:center;}
.svc-detail.flip .svc-detail-media{order:2;}
.svc-detail-copy .service-ico{margin-bottom:18px;}
.svc-detail-copy h2{margin:8px 0 0;}
.svc-detail-copy .lead{margin:.4em 0 1em;color:var(--forest);}
.svc-detail-lists{display:grid;grid-template-columns:1fr 1fr;gap:30px;margin:30px 0 34px;}
.svc-detail-lists h4{font-family:var(--sans);font-size:.72rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--forest);margin-bottom:14px;}
ul.tick{list-style:none;margin:0;padding:0;display:grid;gap:11px;}
ul.tick li{position:relative;padding-left:26px;font-size:.92rem;color:var(--ink-soft);line-height:1.5;}
ul.tick li::before{content:"";position:absolute;left:0;top:.42em;width:13px;height:13px;border-radius:50%;border:1.5px solid var(--sage);background:radial-gradient(circle,var(--leaf) 0 35%,transparent 38%);}
.svc-detail-foot{display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap;padding-top:24px;border-top:1px solid var(--line);}
.svc-from{font-size:.8rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);}
.svc-from strong{font-family:var(--serif);font-size:1.7rem;letter-spacing:0;color:var(--forest);text-transform:none;}

/* line illustration (frameless, woven into the layout) — characters animate */
.svc-illo{position:relative;display:grid;place-items:center;padding:clamp(8px,2vw,22px);}
.svc-illo::before{content:"";position:absolute;inset:0 2%;border-radius:50%;
  background:radial-gradient(circle at 50% 48%,rgba(174,203,168,.26),transparent 68%);}
.svc-illo-fig{position:relative;z-index:2;display:grid;place-items:center;}
.svc-illo-fig svg{width:min(108%,470px);height:auto;color:var(--forest);}
.svc-illo-fig svg [class^="a-"]{transform-box:fill-box;}

/* Wellness — hands rise & fall, chest breathes */
.a-medArms{transform-origin:50% 0;animation:medArms 3.4s ease-in-out infinite;}
@keyframes medArms{0%,100%{transform:translateY(0)}50%{transform:translateY(-7px)}}
.a-breathe{transform-origin:50% 100%;animation:chestBreathe 3.4s ease-in-out infinite;}
@keyframes chestBreathe{0%,100%{transform:scaleY(1)}50%{transform:scaleY(1.14)}}
/* Life — arms open & lift, sun pulses */
.a-lifeArms{transform-origin:50% 100%;animation:lifeArms 3.6s ease-in-out infinite;}
@keyframes lifeArms{0%,100%{transform:scale(1) translateY(0)}50%{transform:scale(1.12) translateY(-9px)}}
.a-sun{transform-origin:50% 39%;animation:sunPulse 4.2s ease-in-out infinite;}
@keyframes sunPulse{0%,100%{transform:scale(1);opacity:.92}50%{transform:scale(1.07);opacity:1}}
/* Teens — head nods, spark twinkles */
.a-nod{transform-origin:50% 92%;animation:nod 3.2s ease-in-out infinite;}
@keyframes nod{0%,100%{transform:rotate(-4deg)}50%{transform:rotate(4deg)}}
.a-twinkle{transform-origin:center;animation:twinkle 2s ease-in-out infinite;animation-delay:var(--tw,0s);}
@keyframes twinkle{0%,100%{transform:scale(.6) rotate(0);opacity:.45}50%{transform:scale(1.25) rotate(90deg);opacity:1}}
/* New Moms — rock the baby closer, heart beats */
.a-rock{transform-origin:16% 28%;animation:rock 3s ease-in-out infinite;}
@keyframes rock{0%,100%{transform:translate(0,0) rotate(0)}50%{transform:translate(-6px,-7px) rotate(-7deg)}}
.a-heart{transform-origin:center;animation:heartPulse 1.7s ease-in-out infinite;}
@keyframes heartPulse{0%,100%{transform:scale(1)}28%{transform:scale(1.32)}55%{transform:scale(1.02)}}
/* Movement — the reach extends & releases, body eases */
.a-reach{transform-origin:0% 100%;animation:reach 3.2s ease-in-out infinite;}
@keyframes reach{0%,100%{transform:rotate(0)}50%{transform:rotate(-15deg)}}
.a-stretch{transform-origin:50% 100%;animation:stretchSway 3.8s ease-in-out infinite;}
@keyframes stretchSway{0%,100%{transform:rotate(-4deg)}50%{transform:rotate(4deg)}}
/* NLP — the inner spiral turns */
.a-spin{transform-origin:50% 50%;animation:spin 9s linear infinite;}
@keyframes spin{to{transform:rotate(360deg)}}
.a-leaf{transform-origin:50% 100%;animation:leafEase 3.6s ease-in-out infinite;}
@keyframes leafEase{0%,100%{transform:rotate(-7deg)}50%{transform:rotate(7deg)}}

@media(max-width:860px){.svc-illo-fig svg{width:min(80%,360px);}}
@media(prefers-reduced-motion:reduce){.svc-illo-fig svg [class^="a-"]{animation:none!important;}}
.svc-foot-btns{display:flex;gap:12px;flex-wrap:wrap;}

@media(max-width:860px){
  .svc-detail-grid{grid-template-columns:1fr;gap:34px;}
  .svc-detail.flip .svc-detail-media{order:0;}
  .svc-detail-media{max-width:440px;}
}
@media(max-width:520px){
  .svc-detail-lists{grid-template-columns:1fr;gap:24px;}
}

/* ============================================================
   PAGE SECTIONS (shared across pages)
   ============================================================ */
.hide-mobile{}

/* ---- Hero ---- */
.hero{position:relative;overflow:hidden;padding:clamp(48px,8vw,96px) 0 clamp(60px,8vw,100px);min-height:82vh;display:flex;align-items:center;}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(40px,6vw,84px);align-items:center;width:100%;}
.hero-solo{grid-template-columns:1fr;max-width:900px;margin:0 auto;text-align:center;justify-items:center;}
.hero-copy{position:relative;z-index:2;}
.hero-solo .hero-copy h1{font-size:clamp(3.2rem,8vw,6.4rem);}
.hero-solo .hero-cta{justify-content:center;}
.hero-solo .hero-meta{justify-content:center;}
.hero-copy h1{margin:16px 0 28px;padding-bottom:.08em;}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:30px;}
.hero-meta{display:flex;align-items:center;gap:26px;margin-top:46px;flex-wrap:wrap;}
.hero-meta strong{font-family:var(--serif);font-size:2rem;color:var(--forest);display:block;line-height:1;}
.hero-meta span{font-size:.7rem;letter-spacing:.13em;text-transform:uppercase;color:var(--muted);}
.hero-meta .hm-line{width:1px;height:38px;background:var(--line);}
.hero-media{position:relative;}
.hero-badge{
  position:absolute;left:-26px;bottom:34px;display:flex;align-items:center;gap:12px;
  background:var(--paper);padding:14px 20px 14px 14px;border-radius:50px;box-shadow:var(--shadow-md);border:1px solid var(--line-soft);
}
.hero-badge .badge-mark{width:38px;height:38px;border-radius:50%;background:var(--sage);color:#fff;display:grid;place-items:center;font-size:1rem;}
.hero-badge strong{display:block;font-family:var(--sans);font-size:.8rem;font-weight:700;color:var(--ink);}
.hero-badge span{font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);}
.hero-vine{position:absolute;right:-60px;top:-40px;width:340px;height:340px;border-radius:50%;
  background:radial-gradient(circle,rgba(144,182,140,.22),transparent 68%);pointer-events:none;z-index:-1;}

/* ---- Hero motion ---- */
.hero-glow{position:absolute;width:560px;height:560px;border-radius:50%;pointer-events:none;z-index:0;filter:blur(10px);
  background:radial-gradient(circle,rgba(144,182,140,.34),rgba(144,182,140,0) 66%);
  top:-140px;right:-120px;animation:sukoonBreathe 9s ease-in-out infinite;}
.hero-glow-2{width:460px;height:460px;left:-160px;top:auto;bottom:-160px;right:auto;
  background:radial-gradient(circle,rgba(111,191,123,.26),rgba(111,191,123,0) 66%);
  animation:sukoonBreathe 11s ease-in-out infinite 1.5s;}
.hero-glow-3{width:680px;height:680px;left:50%;top:50%;right:auto;transform:translate(-50%,-50%);
  background:radial-gradient(circle,rgba(174,203,168,.22),rgba(174,203,168,0) 62%);
  animation:sukoonBreatheSlow 14s ease-in-out infinite;}
@keyframes sukoonBreathe{0%,100%{transform:scale(1);opacity:.7;}50%{transform:scale(1.18);opacity:1;}}
@keyframes sukoonBreatheSlow{0%,100%{transform:translate(-50%,-50%) scale(1);opacity:.5;}50%{transform:translate(-50%,-50%) scale(1.22);opacity:.85;}}

.hero-leaves{position:absolute;inset:0;overflow:hidden;pointer-events:none;z-index:1;}
.hero-leaf{position:absolute;will-change:transform;color:var(--leaf);}
.hero-leaf svg{display:block;width:100%;height:100%;}
/* leaves that float gently in place — always visible */
@keyframes sukoonFloat{
  0%{transform:translate(0,0) rotate(var(--r0,0deg));}
  25%{transform:translate(var(--x1,18px),var(--y1,-22px)) rotate(var(--r1,18deg));}
  50%{transform:translate(var(--x2,-14px),var(--y2,-38px)) rotate(var(--r2,-12deg));}
  75%{transform:translate(var(--x3,20px),var(--y3,-20px)) rotate(var(--r3,22deg));}
  100%{transform:translate(0,0) rotate(var(--r0,0deg));}
}
/* leaves that rise and recycle */
@keyframes sukoonRise{
  0%{transform:translate(0,120%) rotate(0deg);opacity:0;}
  12%{opacity:.6;}
  88%{opacity:.55;}
  100%{transform:translate(var(--dx,40px),-40vh) rotate(var(--dr,170deg));opacity:0;}
}
.hero-copy h1 .serif-accent{animation:sukoonHue 8s ease-in-out infinite;}
@keyframes sukoonHue{0%,100%{opacity:1;}50%{opacity:.82;}}

@media(prefers-reduced-motion:reduce){
  .hero-glow,.hero-glow-2,.hero-glow-3,.hero-leaf,.hero-copy h1 .serif-accent{animation:none !important;}
  .hero-leaves{display:none;}
}

/* ---- Static certifications row ---- */
.cert-row{background:var(--forest);color:#E4E8D6;}
.cert-inner{display:flex;align-items:center;justify-content:center;gap:22px;padding:18px 32px;flex-wrap:wrap;}
.cert-item{font-size:.76rem;letter-spacing:.14em;text-transform:uppercase;color:#E4E8D6;font-weight:500;white-space:nowrap;}
.cert-sep{color:var(--sage-soft);font-size:.7rem;}
@media(max-width:600px){.cert-inner{gap:14px;}.cert-sep{display:none;}}

/* ---- Trust strip ---- */
.trust-strip{background:var(--forest);color:#E4E8D6;}
.trust-inner{display:flex;align-items:center;gap:34px;padding:20px 32px;flex-wrap:wrap;}
.trust-inner > span{font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--sage-soft);font-weight:600;}
.trust-inner ul{display:flex;gap:30px;list-style:none;margin:0;padding:0;flex-wrap:wrap;}
.trust-inner li{font-size:.8rem;letter-spacing:.08em;opacity:.92;position:relative;}
.trust-inner li::before{content:"·";position:absolute;left:-17px;opacity:.5;}
.trust-inner li:first-child::before{display:none;}

/* ---- Intro ---- */
.intro{background:var(--paper);}
.intro h2{font-size:clamp(1.7rem,3.3vw,2.7rem);line-height:1.18;}

/* ---- Section heads ---- */
.sec-head{display:flex;justify-content:space-between;align-items:flex-end;gap:40px;margin-bottom:56px;flex-wrap:wrap;}
.sec-head h2{margin-top:10px;}
.sec-head-note{max-width:360px;color:var(--ink-soft);font-size:.98rem;}

/* ---- Service grid ---- */
.service-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
.service-card{
  background:var(--card);border:1px solid var(--line-soft);border-radius:6px;padding:38px 32px;
  display:flex;flex-direction:column;transition:transform .3s ease,box-shadow .3s ease,border-color .3s;
}
.service-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-md);border-color:var(--sage-soft);}
.service-ico{width:54px;height:54px;flex-shrink:0;border-radius:50%;background:var(--greige-deep);display:grid;place-items:center;margin-bottom:22px;color:var(--forest);}
.service-ico svg{width:26px;height:26px;}
.service-card h3{font-size:1.5rem;margin-bottom:8px;flex-shrink:0;}
.service-card .svc-tag{font-size:.95rem;color:var(--ink-soft);flex:1;}
.service-card .svc-link{margin-top:22px;font-size:.72rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--forest);display:inline-flex;align-items:center;gap:8px;}
.service-card .svc-link .arrow{transition:transform .25s;}
.service-card:hover .svc-link .arrow{transform:translateX(5px);}

/* ---- Coach section ---- */
.coach-sec{background:var(--paper);}
.coach-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(40px,6vw,80px);align-items:center;}
.coach-media{position:relative;}
.coach-vine{position:absolute;left:-30px;bottom:-30px;width:160px;height:160px;border-radius:50%;background:radial-gradient(circle,rgba(111,191,123,.22),transparent 70%);z-index:-1;}
.cred-list{list-style:none;margin:26px 0 30px;padding:0;display:grid;gap:13px;}
.cred-list li{position:relative;padding-left:30px;font-size:.96rem;color:var(--ink-soft);}
.cred-list li::before{content:"";position:absolute;left:0;top:.45em;width:14px;height:14px;border-radius:50%;border:1.5px solid var(--sage);background:radial-gradient(circle,var(--leaf) 0 35%,transparent 38%);}

/* ---- App band ---- */
.app-band{background:var(--forest-deep);color:#E4E8D6;padding:clamp(64px,9vw,110px) 0;overflow:hidden;}
.app-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:60px;align-items:center;}
.app-band .eyebrow.light{color:var(--sage-soft);}
.app-band h2{color:#fff;}
.lead.light{color:#CBD2BC;}
.app-feats{list-style:none;margin:24px 0 32px;padding:0;display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.app-feats li{position:relative;padding-left:26px;font-size:.92rem;color:#D5DBC7;}
.app-feats li::before{content:"";position:absolute;left:0;top:.5em;width:12px;height:12px;border-radius:50%;background:var(--sage);}
.app-media{position:relative;}
.app-media::before{content:"";position:absolute;inset:-30px;background:radial-gradient(circle,rgba(144,182,140,.25),transparent 65%);}

/* ---- Package teaser ---- */
.pkg-teaser{background:var(--greige);}
.tier-row{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;max-width:680px;margin:0 auto;}
.tier-mini{background:var(--card);border:1px solid var(--line-soft);border-radius:6px;padding:34px 30px;text-align:center;}
.tier-mini.featured{background:var(--forest);color:var(--paper);border-color:var(--forest);transform:scale(1.04);}
.tier-mini .tier-tag{font-size:.66rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--forest);}
.tier-mini.featured .tier-tag{color:var(--sage-soft);}
.tier-mini h3{font-size:1.7rem;margin:10px 0 12px;}
.tier-mini p{font-size:.92rem;color:var(--ink-soft);min-height:3em;}
.tier-mini.featured p{color:#CBD2BC;}
.tier-from{font-size:.82rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);}
.tier-mini.featured .tier-from{color:#B9C2A6;}
.tier-from strong{font-family:var(--serif);font-size:1.5rem;letter-spacing:0;color:var(--forest);text-transform:none;}
.tier-mini.featured .tier-from strong{color:#fff;}

/* ---- Quotes ---- */
.quotes-sec{background:var(--paper);}
.quote-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:40px;}
.quote-card{margin:0;background:var(--card);border:1px solid var(--line-soft);border-radius:6px;padding:34px 32px;}
.quote-card blockquote{margin:0 0 20px;font-family:var(--serif);font-size:1.32rem;line-height:1.45;color:var(--ink);font-style:italic;}
.quote-card blockquote::before{content:"\201C";font-family:var(--serif);font-size:2.4rem;color:var(--sage);line-height:0;vertical-align:-.3em;margin-right:.05em;}
.quote-card figcaption{font-size:.82rem;letter-spacing:.06em;color:var(--muted);}
.quote-card figcaption span{color:var(--forest);font-weight:600;}

/* ---- CTA band ---- */
.cta-band{background:var(--sage);color:var(--forest-deep);padding:clamp(70px,10vw,120px) 0;text-align:center;position:relative;overflow:hidden;}
.cta-band .eyebrow.light{color:var(--forest-deep);opacity:.8;}
.cta-band h2{color:var(--forest-deep);margin:14px 0 18px;}
.cta-band .lead.light{color:#3F4D2F;opacity:.92;max-width:560px;margin-left:auto;margin-right:auto;}
.cta-band .btn-light{margin-top:30px;}
.cta-band .serif-accent{color:var(--paper);}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:920px){
  .footer-grid{grid-template-columns:1fr 1fr;gap:36px;}
  .service-grid,.tier-row,.quote-grid{grid-template-columns:1fr;}
  .hero-grid,.coach-grid,.app-grid{grid-template-columns:1fr;}
  .coach-media{max-width:420px;}
  .app-feats{grid-template-columns:1fr;}
  .tier-mini.featured{transform:none;}
}
@media(max-width:820px){
  .hide-mobile{display:none;}
}
@media(max-width:820px){
  .nav-toggle{display:block;}
  .nav-links{
    position:absolute;top:78px;left:0;right:0;flex-direction:column;gap:0;
    background:var(--paper);border-bottom:1px solid var(--line);
    max-height:0;overflow:hidden;transition:max-height .35s ease;
  }
  .nav-links.open{max-height:420px;}
  .nav-links li{width:100%;border-top:1px solid var(--line-soft);}
  .nav-links a{display:block;padding:18px 32px;}
  .nav-links a.active::after{display:none;}
}
@media(max-width:560px){
  .wrap,.wrap-narrow{padding:0 22px;}
  .footer-grid{grid-template-columns:1fr;}
}

/* ---- Subtle leaf motion behind the story section ---- */
.story-sec .story-grid{position:relative;z-index:2;}
