/* ============================================================
   cart.hospital — shared stylesheet
   ============================================================ */

:root{
  /* Live site brand palette (sampled from cart.hospital with Claude in Chrome) */
  --mint:#41DAA4;          /* primary CTA */
  --mint-2:#2eb583;        /* primary CTA hover */
  --mint-soft:#e3f9ef;     /* tinted backgrounds */
  --cyan:#41C3DA;          /* accent panels, kickers, links */
  --cyan-2:#2c9fb6;        /* link hover */
  --cyan-soft:#e2f4f8;     /* tinted backgrounds */
  --cyan-card:#eaf8fc;     /* card-background tint (sampled from live site #e0faff with slight warm) */
  --cyan-border:#b9e2eb;   /* cyan card border */
  /* Aliases for legacy class references (--amber, --coral, --teal) so existing rules stay valid */
  --amber:#41DAA4;
  --amber-2:#2eb583;
  --coral:#41DAA4;
  --coral-2:#2eb583;
  --coral-soft:#e3f9ef;
  --teal:#41C3DA;
  --teal-2:#2c9fb6;
  /* Dark anchors */
  --navy:#1f2937;
  --navy-2:#374151;
  /* Neutrals */
  --ink:#333333;
  --ink-2:#5a5e66;
  --line:#dcdee2;
  --bg:#e8e8e8;            /* live site body bg */
  --card:#ffffff;
  --soft:#f1f2f4;          /* lighter than --bg, for soft section variant */
  --soft-2:#e0e2e6;
  --ok:#198754;
  --warn:#b45309;
  --warn-bg:#fef3c7;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:"Nunito","Helvetica Neue",-apple-system,BlinkMacSystemFont,"Segoe UI",Arial,sans-serif;
  color:var(--ink);
  background:var(--bg);
  line-height:1.55;
  font-weight:400;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:var(--cyan-2);text-decoration:none}
a:hover{color:var(--cyan);text-decoration:underline}
.container{max-width:1180px;margin:0 auto;padding:0 24px}
h1,h2,h3,h4,h5{
  font-family:"Unbounded","Nunito","Helvetica Neue",sans-serif;
  color:var(--navy);line-height:1.15;font-weight:400;letter-spacing:-0.01em;
}
h1{font-size:clamp(2rem,4.2vw,3.2rem);letter-spacing:-0.02em;font-weight:400;line-height:1.1}
h2{font-size:clamp(1.5rem,3vw,2.15rem);margin-bottom:.5em;font-weight:400;line-height:1.2}
h3{font-size:1.2rem;margin-bottom:.4em;font-weight:500;letter-spacing:-0.005em}
h4{font-size:1.05rem;margin-bottom:.3em;font-weight:500;letter-spacing:0}
p{color:var(--ink-2)}
.kicker{
  display:inline-block;font-family:"Nunito",sans-serif;font-size:.82rem;font-weight:700;letter-spacing:.12em;
  text-transform:uppercase;color:var(--cyan-2);margin-bottom:14px;
}
.lead{font-size:1.18rem;color:var(--ink-2)}

/* ---------- BUTTONS ---------- */
.btn{
  display:inline-block;padding:14px 28px;border-radius:26px;font-weight:600;font-size:1rem;
  border:none;cursor:pointer;transition:transform .08s ease, box-shadow .15s ease, background .15s ease;
  text-decoration:none;text-align:center;font-family:"Nunito",sans-serif;
}
.btn-primary{background:var(--mint);color:#fff;box-shadow:0 4px 12px -2px rgba(65,218,164,.35)}
.btn-primary:hover{background:var(--mint-2);text-decoration:none;color:#fff;box-shadow:0 6px 16px -2px rgba(65,218,164,.45);transform:translateY(-1px)}
.btn-outline{background:#fff;color:var(--ink);border:1.5px solid var(--cyan)}
.btn-outline:hover{background:var(--cyan);color:#fff;text-decoration:none;border-color:var(--cyan)}
.btn-ghost{background:transparent;color:var(--ink);font-weight:600}
.btn-ghost:hover{text-decoration:underline;color:var(--cyan-2)}

/* ---------- ANNOUNCE BAR ---------- */
.announce{background:var(--navy);color:#dbe6f2;font-size:.85rem}
.announce .container{display:flex;justify-content:space-between;align-items:center;height:36px;flex-wrap:wrap;gap:8px}
.announce a{color:#fff;font-weight:600}
.announce b{color:#fff}
.channels{display:flex;gap:12px;align-items:center}
.channels img{width:18px;height:18px;filter:brightness(0) invert(1);opacity:.85}
.channels a:hover img{opacity:1}

/* ---------- HEADER ---------- */
header.top{position:sticky;top:0;z-index:50;background:#fff;border-bottom:1px solid var(--line)}
.nav-row{display:flex;align-items:center;gap:20px;height:72px;position:relative}
.brand{display:flex;align-items:center;gap:10px;flex-shrink:0;line-height:0}
.brand img{height:34px !important;width:auto !important;max-height:34px;max-width:160px;display:block}
.mainnav{display:flex;gap:22px;margin-left:8px;flex:1;flex-wrap:nowrap;align-items:center}
.mainnav a{color:var(--ink);font-weight:600;font-size:.93rem;padding:6px 0;border-bottom:2px solid transparent;white-space:nowrap;font-family:"Nunito",sans-serif}
.mainnav a:hover,.mainnav a.active{color:var(--mint-2);border-bottom-color:var(--mint);text-decoration:none}
.lang{display:flex;gap:2px;align-items:center;margin-right:4px}
.lang button{
  background:none;border:1px solid transparent;color:var(--ink-2);font-size:.82rem;
  font-weight:700;padding:6px 10px;border-radius:8px;cursor:pointer;letter-spacing:.04em;font-family:"Nunito",sans-serif;
}
.lang button.active{background:var(--mint-soft);color:var(--mint-2);border-color:transparent}
.lang button:hover:not(.active){color:var(--ink);background:var(--soft)}
.nav-row .btn{padding:11px 22px;font-size:.92rem;white-space:nowrap}
.mobile-toggle{display:none;background:none;border:1px solid var(--line);border-radius:8px;padding:8px 10px;cursor:pointer}
.mobile-toggle span{display:block;width:20px;height:2px;background:var(--ink);margin:4px 0}

/* ---------- HERO ---------- */
.hero{
  background:#fff;
  padding:56px 0 72px;
  border-bottom:1px solid var(--line);
  position:relative;
  overflow:hidden;
}
.hero::before{
  content:"";position:absolute;right:-200px;top:-200px;width:520px;height:520px;
  background:radial-gradient(circle at center, rgba(65,195,218,.18), transparent 65%);
  pointer-events:none;
}
.hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:56px;align-items:center;position:relative}
.hero-sub{
  font-family:"Nunito",sans-serif;
  font-size:1rem;font-weight:600;color:var(--cyan-2);
  margin:8px 0 22px;letter-spacing:0;
}
.hero-promise{
  display:inline-flex;align-items:center;gap:8px;background:var(--mint-soft);border:1px solid #b5e8d0;
  border-radius:999px;padding:6px 14px;font-size:.82rem;color:var(--mint-2);font-weight:700;
  margin-bottom:16px;letter-spacing:.02em;
}
.hero-promise::before{content:"●";color:var(--mint);font-size:.6rem;margin-right:2px;animation:pulse 2s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
.form-trust{
  display:flex;flex-direction:column;gap:6px;margin-top:14px;padding:14px 16px;
  background:var(--mint-soft);border:1px solid #cef0e0;border-radius:10px;
  font-size:.82rem;color:var(--mint-2);
}
.form-trust div{display:flex;align-items:flex-start;gap:8px;line-height:1.5;color:var(--ink-2)}
.form-trust div::before{content:"✓";color:var(--mint-2);font-weight:700;flex-shrink:0}
.form-trust b{color:var(--ink)}
.form-trust a{color:var(--cyan-2);text-decoration:underline}

/* ---------- GDPR EXPLICIT CONSENT CHECKBOX ---------- */
.consent-check{
  display:flex;align-items:flex-start;gap:12px;padding:16px 18px;
  border:1.5px solid var(--cyan);background:var(--cyan-soft);border-radius:14px;
  margin:18px 0 8px;cursor:pointer;
}
.consent-check input{margin-top:3px;flex-shrink:0;accent-color:var(--cyan-2);width:18px;height:18px}
.consent-check span{font-size:.88rem;color:var(--ink);line-height:1.5}
.consent-check span a{color:var(--cyan-2);text-decoration:underline;font-weight:600}
.consent-check.invalid{border-color:#dc3545;background:#fef2f2}

/* ---------- COOKIE CONSENT BANNER ---------- */
.cookie-banner{
  position:fixed;bottom:0;left:0;right:0;z-index:1000;background:#fff;
  border-top:1px solid var(--line);padding:18px 24px;
  box-shadow:0 -8px 30px -10px rgba(0,0,0,.18);display:none;
  font-family:-apple-system,"Segoe UI",Arial,sans-serif;
}
.cookie-banner.show{display:block;animation:slideUp .25s ease}
@keyframes slideUp{from{transform:translateY(100%)}to{transform:translateY(0)}}
.cookie-banner .cb-inner{max-width:1180px;margin:0 auto;display:flex;gap:20px;align-items:center;flex-wrap:wrap}
.cookie-banner .cb-text{flex:1;min-width:280px;font-size:.92rem;color:var(--ink);line-height:1.5}
.cookie-banner .cb-text b{color:var(--navy)}
.cookie-banner .cb-text a{color:var(--cyan-2);text-decoration:underline;font-weight:600}
.cookie-banner .cb-buttons{display:flex;gap:10px;flex-shrink:0;flex-wrap:wrap}
.cookie-banner .btn{padding:10px 22px;font-size:.9rem;border-radius:22px}
.cookie-banner .btn-ghost{border:1.5px solid var(--line);background:#fff;color:var(--ink-2)}
.cookie-banner .btn-ghost:hover{border-color:var(--ink-2);color:var(--ink)}
@media (max-width:680px){
  .cookie-banner{padding:14px 18px}
  .cookie-banner .cb-text{font-size:.85rem}
  .cookie-banner .cb-buttons{width:100%}
  .cookie-banner .btn{flex:1}
}
.hero p.lead{margin:18px 0 26px;max-width:540px}
.hero-ctas{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:32px}
.hero-trust{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;padding-top:24px;border-top:1px solid var(--line);max-width:580px}
.hero-trust div{text-align:left}
.hero-trust .num{font-size:1.6rem;font-weight:800;color:var(--coral);line-height:1}
.hero-trust .lbl{font-size:.78rem;color:var(--ink-2);margin-top:4px;line-height:1.3}
.hero-visual{position:relative;border-radius:14px;overflow:hidden;aspect-ratio:4/3;background:#eef1f5;box-shadow:0 24px 60px -20px rgba(14,42,71,.25)}
.hero-visual img{width:100%;height:100%;object-fit:cover}
.hero-badge{position:absolute;left:18px;bottom:18px;background:rgba(255,255,255,.97);border-radius:10px;padding:12px 16px;backdrop-filter:blur(6px);box-shadow:0 4px 12px -4px rgba(0,0,0,.15)}
.hero-badge .l{font-size:.7rem;color:var(--ink-2);font-weight:700;text-transform:uppercase;letter-spacing:.08em}
.hero-badge .v{font-size:1rem;font-weight:700;color:var(--navy)}

/* Slim hero variant for non-home pages */
.hero-slim{padding:48px 0 40px;background:#fff;border-bottom:1px solid var(--line);position:relative;overflow:hidden}
.hero-slim::before{
  content:"";position:absolute;right:-150px;top:-150px;width:400px;height:400px;
  background:radial-gradient(circle at center, rgba(65,195,218,.14), transparent 65%);
  pointer-events:none;
}
.hero-slim .container{position:relative}
.hero-slim h1{font-size:clamp(1.8rem,3.6vw,2.6rem)}
.hero-slim p{max-width:680px;margin-top:14px}
.crumb{font-size:.85rem;color:var(--ink-2);margin-bottom:14px}
.crumb a{color:var(--ink-2)}
.crumb a:hover{color:var(--navy)}

/* ---------- SECTIONS ---------- */
section{padding:72px 0}
.bg-white{background:#fff;border-bottom:1px solid var(--line)}
.bg-soft{background:var(--soft)}
.bg-navy{background:var(--navy);color:#fff}
.bg-navy h2,.bg-navy h3,.bg-navy h4{color:#fff}
.bg-navy .kicker{color:var(--mint)}
.bg-navy p{color:#c8d3e2}

/* ---------- TWO-COLUMN ---------- */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start}
.two-col ul{list-style:none;margin-top:18px}
.two-col li{padding:14px 0;border-top:1px solid var(--line);display:flex;gap:14px;align-items:start}
.two-col li:first-child{border-top:none}
.two-col li .n{flex-shrink:0;width:30px;height:30px;border-radius:50%;background:var(--soft);color:var(--navy);font-weight:700;display:flex;align-items:center;justify-content:center;font-size:.85rem}
.two-col li b{color:var(--ink);display:block;margin-bottom:2px}

/* ---------- INDICATION GRIDS ---------- */
.ind-block{margin-top:32px}
.ind-block h3{font-size:1.1rem;color:var(--navy);margin-bottom:14px;display:flex;align-items:center;gap:10px}
.ind-block h3::before{content:"";display:inline-block;width:10px;height:10px;border-radius:50%;background:var(--mint)}
.ind-block.emerging h3::before{background:var(--cyan)}
.ind-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.ind{background:var(--cyan-card);border:1px solid var(--cyan-border);border-radius:18px;padding:22px;transition:transform .15s ease, box-shadow .15s ease}
.ind:hover{transform:translateY(-2px);box-shadow:0 8px 24px -12px rgba(65,195,218,.35);border-color:var(--cyan)}
.ind .tag{font-size:.72rem;font-weight:700;color:var(--mint-2);letter-spacing:.08em;text-transform:uppercase;margin-bottom:8px}
.ind.emerging .tag{color:var(--cyan-2)}
.ind h4{font-size:1rem;color:var(--navy);margin-bottom:6px}
.ind p{font-size:.88rem;color:var(--ink-2);margin:0}

/* ---------- PROCESS STEPS ---------- */
.steps{display:grid;grid-template-columns:repeat(5,1fr);gap:0;margin-top:36px;position:relative}
.step{padding:24px 18px 18px;position:relative}
.step .sn{font-size:1.6rem;font-weight:800;color:var(--amber);display:block;margin-bottom:10px}
.step h4{color:#fff;font-size:1rem;margin-bottom:6px}
.step p{color:#a5b6cb;font-size:.85rem;margin:0}
.step::before{content:"";position:absolute;left:0;top:38px;height:2px;width:100%;background:rgba(255,255,255,.08);z-index:0}
.step:first-child::before{left:50%;width:50%}
.step:last-child::before{width:50%}
.step .sn,.step h4,.step p{position:relative;z-index:1}

/* Detailed step list (how-it-works) */
.step-detail{display:grid;grid-template-columns:80px 1fr;gap:24px;padding:32px 0;border-top:1px solid var(--line)}
.step-detail:first-of-type{border-top:none}
.step-detail .num{font-size:2.4rem;font-weight:800;color:var(--amber);line-height:1}
.step-detail h3{font-size:1.25rem;color:var(--navy)}
.step-detail .timing{display:inline-block;background:var(--soft);color:var(--ink-2);font-size:.78rem;padding:3px 10px;border-radius:999px;margin-top:6px;font-weight:600}
.step-detail .body p{margin-top:10px}

/* ---------- HOSPITAL CARDS ---------- */
.h-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:32px}
.hosp{background:var(--cyan-card);border:1px solid var(--cyan-border);border-radius:20px;overflow:hidden;display:flex;flex-direction:column}
.hosp:hover{border-color:var(--cyan)}
.hosp .pic{aspect-ratio:16/10;overflow:hidden;background:#eef1f5}
.hosp .pic img{width:100%;height:100%;object-fit:cover}
.hosp .body{padding:24px;flex:1;display:flex;flex-direction:column}
.hosp .acc{display:inline-block;background:var(--mint-soft);color:var(--mint-2);font-size:.72rem;font-weight:700;letter-spacing:.06em;padding:5px 12px;border-radius:999px;margin-bottom:12px;text-transform:uppercase;width:fit-content}
.hosp h3{margin-bottom:6px}
.hosp .loc{color:var(--ink-2);font-size:.9rem;margin-bottom:10px}
.hosp p{font-size:.92rem}
.hosp ul{list-style:none;margin-top:14px;font-size:.88rem;color:var(--ink-2)}
.hosp li{padding:4px 0;padding-left:18px;position:relative}
.hosp li::before{content:"✓";position:absolute;left:0;color:var(--teal);font-weight:700}

/* ---------- DOCTOR GRID ---------- */
.doc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:32px}
.doc{background:var(--cyan-card);border-radius:18px;overflow:hidden;border:1px solid var(--cyan-border);transition:transform .15s ease, box-shadow .15s ease}
.doc:hover{transform:translateY(-3px);box-shadow:0 14px 30px -16px rgba(65,195,218,.35);border-color:var(--cyan)}
.doc .pic{aspect-ratio:1/1;overflow:hidden;background:#e3e8f0}
.doc .pic img{width:100%;height:100%;object-fit:cover}
.doc .body{padding:18px}
.doc h4{font-size:1.02rem;color:var(--navy);margin-bottom:4px;line-height:1.25}
.doc .title{font-size:.78rem;color:var(--cyan-2);font-weight:700;margin-bottom:6px;line-height:1.35}
.doc .flag{font-size:.78rem;color:var(--ink-2);margin-bottom:8px}
.doc .spec{font-size:.85rem;color:var(--ink);min-height:54px}
.doc.doc-detailed .spec{min-height:auto;font-weight:600}
.doc .bio{font-size:.82rem;color:var(--ink-2);margin:10px 0 0;line-height:1.5;border-top:1px solid var(--line);padding-top:10px}
.doc .source{display:inline-block;font-size:.76rem;color:var(--cyan-2);margin-top:10px;font-weight:600}
.doc .source:hover{color:var(--cyan);text-decoration:underline}
.doc-cta{text-align:center;margin-top:32px}

/* ---------- OUTCOMES (data cards) ---------- */
.out-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:26px}
.out{background:var(--cyan-card);border:1px solid var(--cyan-border);border-radius:18px;padding:24px 22px}
.out .v{font-size:1.9rem;font-weight:800;color:var(--navy);line-height:1.1;margin-bottom:6px}
.out .l{font-size:.92rem;color:var(--ink);font-weight:500;margin-bottom:8px}
.out .src{font-size:.72rem;color:#888;line-height:1.45}

.note-warn{margin-top:22px;padding:14px 18px;background:var(--warn-bg);border:1px solid #f1c97b;border-radius:8px;font-size:.86rem;color:var(--warn)}
.note-info{margin-top:22px;padding:14px 18px;background:#eaf4fb;border:1px solid #c5dff0;border-radius:8px;font-size:.88rem;color:#1f4d75}
.note-warn b,.note-info b{font-weight:700}

/* ---------- SAFETY (side effects) ---------- */
.safety{background:#fff}
.safety-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:28px}
.safety .item{padding:26px;background:var(--cyan-card);border-radius:18px;border:1px solid var(--cyan-border);border-left:4px solid var(--cyan);border-left-width:4px}
.safety .item h4{margin-bottom:8px}
.safety .item p{font-size:.92rem}

/* ---------- STORIES ---------- */
.story-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:32px}
.story{background:var(--cyan-card);border-radius:20px;overflow:hidden;border:1px solid var(--cyan-border)}
.story .pic{aspect-ratio:4/3;overflow:hidden;background:#e3e8f0}
.story .pic img{width:100%;height:100%;object-fit:cover}
.story .body{padding:22px}
.story h4{color:var(--navy);margin-bottom:4px}
.story .meta{font-size:.82rem;color:var(--ink-2);margin-bottom:12px}
.story blockquote{font-style:italic;color:var(--ink);font-size:.95rem;border-left:3px solid var(--amber);padding-left:14px;margin-top:10px}
.story-more{display:inline-block;margin-top:14px;color:var(--mint-deep);font-weight:600;font-size:.9rem;text-decoration:none}
.story-more:hover{text-decoration:underline}
.ind-more{display:inline-block;margin-top:12px;color:var(--mint-deep);font-weight:600;font-size:.88rem;text-decoration:none}
.ind-more:hover{text-decoration:underline}
.stories-all{margin-top:28px;text-align:center}

/* Side-by-side story card for condition pages */
.story-side{display:grid;grid-template-columns:200px 1fr;gap:24px;align-items:center;background:var(--cyan-card);border:1px solid var(--cyan-border);border-radius:20px;padding:24px;margin-top:24px}
.story-side .pic{width:200px;height:200px;border-radius:16px;overflow:hidden;background:#e3e8f0;flex:none}
.story-side .pic img{width:100%;height:100%;object-fit:cover;object-position:center top}
.story-side .body{padding:0}
.story-side h4{color:var(--navy);margin-bottom:4px}
.story-side .meta{font-size:.82rem;color:var(--ink-2);margin-bottom:12px}
.story-side blockquote{font-style:italic;color:var(--ink);font-size:.95rem;border-left:3px solid var(--amber);padding-left:14px;margin:10px 0}
@media (max-width:760px){
  .story-side{grid-template-columns:1fr;padding:18px}
  .story-side .pic{width:100%;max-width:240px;height:auto;aspect-ratio:1;margin:0 auto}
}

/* ---------- STORIES FULL PAGE ---------- */
.story-nav-section{padding:24px 0 8px;background:transparent}
.story-nav{display:flex;flex-wrap:wrap;gap:10px;justify-content:center}
.story-nav a{display:flex;flex-direction:column;background:var(--cyan-card);border:1px solid var(--cyan-border);border-radius:14px;padding:10px 14px;text-decoration:none;color:var(--ink);min-width:140px;transition:transform .12s ease, box-shadow .12s ease}
.story-nav a:hover{transform:translateY(-2px);box-shadow:0 6px 16px rgba(0,0,0,.08)}
.story-nav a b{color:var(--navy);font-size:.92rem;line-height:1.2;margin-bottom:4px}
.story-nav a span{color:var(--ink-2);font-size:.78rem;line-height:1.25}
.stories-full{padding:36px 0 64px}

.story-full{background:#fff;border:1px solid var(--cyan-border);border-radius:24px;padding:32px;margin-bottom:32px;scroll-margin-top:96px}
.story-full .story-head{display:grid;grid-template-columns:160px 1fr;gap:24px;align-items:center;margin-bottom:20px;padding-bottom:20px;border-bottom:1px solid var(--cyan-border)}
.story-full .story-photo{width:160px;height:160px;border-radius:18px;overflow:hidden;background:#e3e8f0}
.story-full .story-photo img{width:100%;height:100%;object-fit:cover}
.story-full h2{color:var(--navy);margin-bottom:6px}
.story-full .story-meta{color:var(--ink-2);font-size:.9rem}
.story-full .story-body p{margin-top:14px;line-height:1.65}
.story-full blockquote{border-left:3px solid var(--amber);padding:6px 0 6px 18px;margin:18px 0;font-style:italic;color:var(--ink)}

/* ---------- INTAKE FORM ---------- */
.intake{background:var(--soft);padding:64px 0 80px}
.intake .kicker{color:var(--mint-2);font-size:.78rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;margin-bottom:8px}
.intake h2{color:var(--navy);font-size:clamp(1.6rem,2.6vw,2.1rem);margin-bottom:10px}
.intake .intro{color:var(--ink-2);max-width:640px;margin-bottom:28px;line-height:1.55}
.form-card{background:#fff;border:1px solid var(--cyan-border);border-radius:22px;padding:32px;max-width:780px;box-shadow:0 14px 40px -20px rgba(14,42,71,.18)}
.form-card .progress{display:flex;gap:8px;margin-bottom:24px}
.form-card .progress > div{flex:1;height:6px;border-radius:6px;background:var(--soft);transition:background .25s ease}
.form-card .progress > div.active{background:var(--mint)}
.form-card .progress > div.done{background:var(--mint-2)}
.step-box{animation:stepFade .25s ease}
@keyframes stepFade{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}
.step-num{font-size:.78rem;color:var(--cyan-2);font-weight:700;letter-spacing:.08em;text-transform:uppercase;margin-bottom:10px}
.step-q{font-size:1.2rem;color:var(--navy);font-weight:700;margin-bottom:20px;line-height:1.35}
.opts{display:flex;flex-direction:column;gap:10px}
.opt{display:flex;align-items:center;gap:12px;padding:14px 18px;border:1.5px solid var(--line);border-radius:12px;cursor:pointer;transition:all .15s ease;background:#fff}
.opt:hover{border-color:var(--cyan);background:var(--cyan-soft)}
.opt input[type=radio]{accent-color:var(--mint-2);width:18px;height:18px;flex-shrink:0;margin:0}
.opt input[type=radio]:checked + span{color:var(--navy);font-weight:600}
.opt:has(input:checked){border-color:var(--mint);background:var(--mint-soft)}
.opt span{font-size:.95rem;color:var(--ink);line-height:1.4}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px}
.field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}
.field-row .field{margin-bottom:0}
.field label{font-size:.85rem;color:var(--ink);font-weight:600}
.field input,.field textarea{font-family:inherit;font-size:.95rem;padding:11px 14px;border:1.5px solid var(--line);border-radius:10px;background:#fff;color:var(--ink);transition:border-color .15s ease}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--cyan);box-shadow:0 0 0 3px rgba(65,195,218,.15)}
.field textarea{resize:vertical;min-height:80px}
.form-card .consent{margin-top:14px;font-size:.82rem;color:var(--ink-2);line-height:1.5}
.form-card .consent a{color:var(--cyan-2);text-decoration:underline}
.form-nav{display:flex;justify-content:space-between;align-items:center;gap:14px;margin-top:24px;padding-top:20px;border-top:1px solid var(--line)}
.form-nav .btn{padding:12px 26px;font-size:.95rem}
.form-success{text-align:center;padding:30px 10px}
.form-success .success-icon{width:64px;height:64px;border-radius:50%;background:var(--mint);color:#fff;font-size:2rem;font-weight:700;display:flex;align-items:center;justify-content:center;margin:0 auto 18px;box-shadow:0 8px 24px -8px rgba(65,218,164,.55)}
.form-success h3{color:var(--navy);font-size:1.4rem;margin-bottom:10px}
.form-success p{color:var(--ink-2);max-width:480px;margin:0 auto;line-height:1.55}
@media (max-width:680px){
  .form-card{padding:24px 18px}
  .field-row{grid-template-columns:1fr}
  .step-q{font-size:1.05rem}
  .opt{padding:12px 14px}
  .form-nav .btn{padding:10px 18px;font-size:.88rem}
}

/* ---------- WHY US (home) ---------- */
.why-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:32px}
.why-card{background:var(--cyan-card);border:1px solid var(--cyan-border);border-radius:18px;padding:26px 22px;transition:transform .15s ease, box-shadow .15s ease}
.why-card:hover{transform:translateY(-3px);box-shadow:0 12px 28px -14px rgba(65,195,218,.35);border-color:var(--cyan)}
.why-card .why-num{font-size:1.3rem;font-weight:800;color:var(--cyan-2);letter-spacing:.04em;margin-bottom:14px;display:inline-block;padding:6px 12px;border-radius:8px;background:var(--cyan-soft)}
.why-card h4{font-size:1.05rem;color:var(--navy);margin-bottom:8px;line-height:1.3}
.why-card p{font-size:.9rem;color:var(--ink-2);margin:0;line-height:1.55}
@media (max-width:980px){ .why-grid{grid-template-columns:repeat(2,1fr)} }
@media (max-width:560px){ .why-grid{grid-template-columns:1fr} }

/* ---------- COUNTRY COMPARISON BARS ---------- */
.compare-bars{display:flex;flex-direction:column;gap:14px;margin-top:32px;max-width:880px}
.compare-bar{display:grid;grid-template-columns:160px 1fr;gap:18px;align-items:center}
.compare-bar .country{font-size:.95rem;color:var(--navy);font-weight:600;line-height:1.3}
.compare-bar .bar-track{background:var(--soft);border-radius:8px;height:36px;position:relative;overflow:hidden;border:1px solid var(--line)}
.compare-bar .bar-fill{height:100%;border-radius:7px;display:flex;align-items:center;justify-content:flex-end;padding:0 14px;color:#fff;font-weight:700;font-size:.92rem;letter-spacing:.02em;min-width:60px;transition:width .6s cubic-bezier(.4,0,.2,1);box-shadow:inset 0 -2px 0 rgba(0,0,0,.1)}
.compare-bar .bar-fill.china{background:linear-gradient(90deg,var(--mint),var(--mint-2))}
.compare-bar .bar-fill.other{background:linear-gradient(90deg,#f4a261,#e76f51)}
.compare-bar .bar-fill.usa{background:linear-gradient(90deg,#e76f51,#c0392b)}
.compare-source{font-size:.78rem;color:var(--ink-2);margin-top:22px;line-height:1.55;max-width:880px}
@media (max-width:640px){
  .compare-bar{grid-template-columns:1fr;gap:6px}
  .compare-bar .country{font-size:.88rem}
  .compare-bar .bar-track{height:30px}
}

/* ---------- PRICING CARD ---------- */
.pricing-card{display:grid;grid-template-columns:280px 1fr 1fr;gap:32px;background:var(--cyan-card);border:1px solid var(--cyan-border);border-radius:22px;padding:34px;margin-top:28px;align-items:start}
.pricing-card .amount{text-align:left}
.pricing-card .amount .from{display:block;font-size:.8rem;color:var(--ink-2);text-transform:uppercase;letter-spacing:.08em;font-weight:700;margin-bottom:10px}
.pricing-card .amount > div:nth-child(2){font-size:1.85rem;font-weight:800;color:var(--navy);line-height:1.15}
.pricing-card .included h4,.pricing-card .excluded h4{font-size:.95rem;color:var(--navy);margin-bottom:12px}
.pricing-card .included ul,.pricing-card .excluded ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}
.pricing-card .included li,.pricing-card .excluded li{font-size:.88rem;color:var(--ink);padding-left:24px;position:relative;line-height:1.45}
.pricing-card .included li::before{content:"✓";position:absolute;left:0;color:var(--mint-2);font-weight:800}
.pricing-card .excluded li::before{content:"×";position:absolute;left:0;color:#c0392b;font-weight:800;font-size:1.1rem;line-height:1}
.pricing-card .included li b,.pricing-card .excluded li b{color:var(--navy);font-weight:600}
.pricing-card + p{margin-top:20px;font-size:.92rem;color:var(--ink-2);background:var(--mint-soft);border-left:3px solid var(--mint-2);padding:14px 18px;border-radius:0 10px 10px 0}
.pricing-card + p b{color:var(--mint-2)}
@media (max-width:960px){
  .pricing-card{grid-template-columns:1fr;gap:24px;padding:26px}
}

/* ---------- BROWSE-BY (home) ---------- */
.browse-by{margin-top:32px}
.browse-by > h3{font-size:1.05rem;color:var(--navy);margin-bottom:16px;font-weight:700}
.browse-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:12px}
.browse-card{background:var(--cyan-card);border:1px solid var(--cyan-border);border-radius:18px;padding:24px;transition:transform .15s ease, box-shadow .15s ease;text-decoration:none;color:inherit;display:flex;flex-direction:column;gap:10px}
.browse-card:hover{transform:translateY(-3px);box-shadow:0 14px 30px -16px rgba(65,195,218,.35);border-color:var(--cyan)}
.browse-icon{font-size:1.6rem;line-height:1}
.browse-card h4{font-size:1rem;color:var(--navy);margin:0}
.browse-card p{font-size:.86rem;color:var(--ink-2);margin:0;line-height:1.5;flex:1}
.browse-cta{font-size:.85rem;color:var(--mint-deep);font-weight:600;margin-top:6px}
.browse-card:hover .browse-cta{text-decoration:underline}
@media (max-width:880px){ .browse-grid{grid-template-columns:1fr} }

/* ---------- COORDINATOR (Marina) ---------- */
.coord{display:grid;grid-template-columns:120px 1fr 220px;gap:28px;align-items:center;background:var(--cyan-card);border:1px solid var(--cyan-border);border-radius:20px;padding:28px;margin-top:24px}
.coord .portrait{width:120px;height:120px;border-radius:50%;overflow:hidden;background:#e3e8f0;flex:none}
.coord .portrait img{width:100%;height:100%;object-fit:cover}
.coord .info h3{color:var(--navy);font-size:1.2rem;margin-bottom:4px}
.coord .info .role{font-size:.85rem;color:var(--cyan-2);font-weight:700;text-transform:uppercase;letter-spacing:.06em;margin-bottom:10px}
.coord .info p{font-size:.92rem;color:var(--ink-2);margin:0;line-height:1.55}
.coord .channels-vert{display:flex;flex-direction:column;gap:8px}
.coord .channels-vert a{display:inline-flex;align-items:center;gap:10px;padding:9px 14px;background:#fff;border:1px solid var(--line);border-radius:10px;color:var(--ink);font-size:.88rem;font-weight:600;text-decoration:none;transition:border-color .15s ease, transform .12s ease}
.coord .channels-vert a:hover{border-color:var(--cyan-2);transform:translateY(-1px);color:var(--navy)}
.coord .channels-vert a img{width:18px;height:18px;flex:none}
@media (max-width:780px){
  .coord{grid-template-columns:1fr;text-align:center;padding:22px}
  .coord .portrait{margin:0 auto}
  .coord .channels-vert{flex-direction:row;flex-wrap:wrap;justify-content:center}
}

/* ---------- FOOTER ---------- */
footer{background:var(--navy);color:#c8d3e2;padding:56px 0 24px}
footer h5{color:#fff;font-size:.9rem;text-transform:uppercase;letter-spacing:.08em;margin-bottom:14px;font-weight:700}
footer a{color:#c8d3e2;text-decoration:none;transition:color .12s ease}
footer a:hover{color:var(--mint)}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:36px;align-items:start;padding-bottom:36px;border-bottom:1px solid rgba(255,255,255,.08)}
.foot-brand img{max-height:38px;margin-bottom:14px;filter:brightness(0) invert(1)}
.foot-brand p{font-size:.86rem;color:#a5b6cb;line-height:1.6;margin-bottom:18px}
.foot-channels{display:flex;gap:10px;flex-wrap:wrap}
.foot-channels a{display:inline-flex;width:36px;height:36px;align-items:center;justify-content:center;background:rgba(255,255,255,.06);border-radius:50%;transition:background .15s ease}
.foot-channels a:hover{background:rgba(65,218,164,.18)}
.foot-channels img{width:16px;height:16px;filter:brightness(0) invert(1)}
footer ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}
footer ul li{font-size:.88rem;line-height:1.5}
.entity-block{font-size:.85rem;color:#a5b6cb;line-height:1.65}
.entity-block b{color:#fff}
.foot-bottom{padding-top:24px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px;font-size:.82rem;color:#7a8ca5}
.foot-langs{display:flex;gap:6px}
.foot-langs button{background:none;border:1px solid rgba(255,255,255,.18);color:#a5b6cb;font-size:.78rem;padding:5px 12px;border-radius:6px;cursor:pointer;font-family:inherit;letter-spacing:.04em;transition:all .15s ease}
.foot-langs button.active{background:rgba(65,218,164,.12);color:var(--mint);border-color:transparent}
.foot-langs button:hover:not(.active){color:#fff;border-color:rgba(255,255,255,.35)}
@media (max-width:960px){
  .foot-grid{grid-template-columns:repeat(2,1fr);gap:32px}
}
@media (max-width:560px){
  .foot-grid{grid-template-columns:1fr}
}

/* ---------- COMMON UTILITIES ---------- */
.muted{color:var(--ink-2);font-size:.85rem;line-height:1.5}
.placeholder{background:#eef1f5;color:var(--ink-2);display:flex;align-items:center;justify-content:center;font-size:.85rem;text-align:center;padding:14px}

/* ---------- CHECK-LIST (used on condition + product pages) ---------- */
.check-list{list-style:none;padding:0;margin:14px 0;display:flex;flex-direction:column;gap:8px}
.check-list li{padding-left:28px;position:relative;font-size:.92rem;color:var(--ink);line-height:1.5}
.check-list li::before{content:"✓";position:absolute;left:0;top:0;color:var(--mint-2);font-weight:800;font-size:1rem}
.check-list li b{color:var(--navy);font-weight:600}

/* ---------- ELIGIBILITY BLOCK (product sub-pages) ---------- */
.elig-block{background:var(--cyan-card);border:1px solid var(--cyan-border);border-radius:16px;padding:24px;margin:18px 0}
.elig-block h3{color:var(--navy);font-size:1.05rem;margin-bottom:10px}
.elig-block h4{color:var(--cyan-2);font-size:.92rem;margin-top:14px;margin-bottom:6px;text-transform:uppercase;letter-spacing:.06em;font-weight:700}
.elig-block p{font-size:.92rem;color:var(--ink);line-height:1.55;margin-top:6px}

/* ---------- PRODUCT FACTS GRID (product pages) ---------- */
.prod-facts{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin:24px 0 8px}
.prod-facts > div{background:var(--cyan-card);border:1px solid var(--cyan-border);border-radius:14px;padding:16px 18px}
.prod-facts > div .l,.prod-facts > div b:first-child{font-size:.72rem;color:var(--ink-2);text-transform:uppercase;letter-spacing:.06em;font-weight:700;display:block;margin-bottom:6px}
.prod-facts > div .v,.prod-facts > div > span{font-size:1rem;color:var(--navy);font-weight:600;line-height:1.3}
@media (max-width:880px){ .prod-facts{grid-template-columns:repeat(2,1fr)} }
@media (max-width:480px){ .prod-facts{grid-template-columns:1fr} }

/* ---------- FAQ ACCORDION ---------- */
.faq-cat{margin-bottom:32px}
.faq-cat h3{color:var(--navy);font-size:1.1rem;margin-bottom:14px;padding-bottom:10px;border-bottom:2px solid var(--cyan-border)}
.faq-list{display:flex;flex-direction:column;gap:8px}
.faq-item{background:#fff;border:1px solid var(--line);border-radius:12px;overflow:hidden;transition:border-color .12s ease}
.faq-item.open{border-color:var(--cyan)}
.faq-item .faq-q{width:100%;background:none;border:0;padding:16px 20px;font-family:inherit;font-size:.95rem;font-weight:600;color:var(--navy);text-align:left;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:14px}
.faq-item .faq-q .icon{flex:none;width:26px;height:26px;border-radius:50%;background:var(--cyan-soft);color:var(--cyan-2);display:inline-flex;align-items:center;justify-content:center;font-weight:700;font-size:1.1rem;transition:transform .2s ease, background .15s ease}
.faq-item.open .faq-q .icon{transform:rotate(45deg);background:var(--mint-soft);color:var(--mint-2)}
.faq-item .faq-a{max-height:0;overflow:hidden;transition:max-height .25s ease, padding .2s ease;padding:0 20px;font-size:.9rem;color:var(--ink);line-height:1.6}
.faq-item.open .faq-a{max-height:1200px;padding:0 20px 18px}
.faq-item .faq-a p{margin:8px 0}
.faq-item .faq-a a{color:var(--cyan-2);text-decoration:underline}

/* ---------- STORIES: diag + tags ---------- */
.story-full .diag{font-size:.82rem;color:var(--mint-2);background:var(--mint-soft);display:inline-block;padding:3px 10px;border-radius:999px;font-weight:700;margin-top:6px;letter-spacing:.02em}
.story-full .tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}
.story-full .tags span{font-size:.72rem;background:var(--cyan-soft);color:var(--cyan-2);padding:3px 10px;border-radius:999px;font-weight:600}
