/** Shopify CDN: Minification failed

Line 640:2 Unexpected "@media"

**/
:root{
  --federal:#121656;--federal-deep:#06091e;--tiffany:#7ED6D0;--tiffany-soft:#E8F7F5;
  --purple:#4F1A6D;--purple-soft:#F4EDF8;--steel:#214C6D;--ink:#1A1D2E;--slate:#5A607A;
  --line:#E6E8F0;--paper:#FFFFFF;--paper-warm:#FBFBFD;
  --good:#2E9E6B;--good-soft:#EAF6F0;--amber:#E8A33D;--danger:#D64545;
  --star:#F4B740;--star-off:#D9DEE8;
  --font:"Public Sans",sans-serif;--maxw:1200px;
  --shadow-sm:0 1px 3px rgba(18,22,86,.06);
  --shadow-md:0 12px 30px -12px rgba(18,22,86,.18);
  --shadow-lg:0 28px 60px -20px rgba(18,22,86,.30);
  --ease:cubic-bezier(.2,.7,.3,1);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--font);color:var(--ink);background:var(--paper);line-height:1.6;-webkit-font-smoothing:antialiased;font-variant-numeric:tabular-nums}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}
@media(min-width:1025px){.wrap{padding:0 40px}}
h1,h2,h3,h4{color:var(--federal);font-weight:700;letter-spacing:-0.02em;line-height:1.12}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:inherit;font-weight:600;font-size:16px;border-radius:10px;padding:14px 26px;cursor:pointer;border:1.5px solid transparent;transition:all 180ms var(--ease);min-height:44px}
.btn-primary{background:var(--tiffany);color:var(--federal)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);background:#92ddd8}
.btn-dark{background:var(--federal);color:#fff}
.btn-dark:hover{transform:translateY(-2px);background:#1b2070}
.btn-ghost{background:transparent;color:var(--federal);border-color:var(--line)}
.btn-ghost:hover{border-color:var(--federal);background:var(--tiffany-soft)}
.btn:focus-visible{outline:3px solid var(--tiffany);outline-offset:2px}
.btn-lg{padding:18px 32px;font-size:17px}
.btn:disabled{opacity:.5;cursor:not-allowed}

/* shared header */
.announce{background:var(--federal-deep);color:#cdd2ea;font-size:13px;text-align:center;padding:9px 16px}
.announce strong{color:var(--tiffany);font-weight:600}
header{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.92);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:76px}
.logo img{height:54px;display:block}
.nav-links{display:none;gap:30px;align-items:center}
.nav-links a{font-size:15px;font-weight:500;color:var(--ink);position:relative;padding:4px 0}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:2px;background:var(--tiffany);transition:width .22s var(--ease)}
.nav-links a:hover::after{width:100%}
.nav-links .has-drop{position:relative}
.nav-links .has-drop > a::after{display:none}
.nav-links .drop{position:absolute;top:calc(100% + 14px);left:50%;transform:translateX(-50%) translateY(8px);background:#fff;border:1px solid var(--line);border-radius:14px;padding:10px;min-width:200px;box-shadow:var(--shadow-md);opacity:0;visibility:hidden;transition:all .22s var(--ease)}
.nav-links .has-drop:hover .drop,.nav-links .has-drop:focus-within .drop{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.nav-links .drop a{display:block;padding:9px 12px;border-radius:8px;font-size:14px;color:var(--ink)}
.nav-links .drop a:hover{background:var(--paper-warm);color:var(--federal)}
.nav-links .drop a::after{display:none}
.nav-links .drop a.active{background:var(--tiffany-soft);color:var(--federal)}
.nav-right{display:flex;align-items:center;gap:14px}
.icon-btn{width:42px;height:42px;border-radius:10px;display:flex;align-items:center;justify-content:center;color:var(--federal)}
.icon-btn:hover{background:var(--tiffany-soft)}
.nav-cta{display:none}
.burger{display:flex;flex-direction:column;gap:4px;width:42px;height:42px;align-items:center;justify-content:center;border-radius:10px;background:none;border:none;cursor:pointer}
.burger span{width:20px;height:2px;background:var(--federal);border-radius:2px}
@media(min-width:1025px){.nav-links{display:flex}.nav-cta{display:inline-flex}.burger{display:none}}

/* common section */
section.block{padding:56px 0}
@media(min-width:1025px){section.block{padding:80px 0}}
.warm{background:var(--paper-warm)}
.sec-head{max-width:680px;margin:0 auto 36px;text-align:center}
.sec-head .kick{font-size:13px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--tiffany);display:block;margin-bottom:10px}
.sec-head .kick span{color:var(--steel)}
.sec-head h2{font-size:28px;margin-bottom:10px}
.sec-head p{color:var(--slate);font-size:15px}
@media(min-width:1025px){.sec-head h2{font-size:36px}}

/* simple hero (used by most secondary pages) */
.page-hero{background:linear-gradient(180deg,#fff,var(--tiffany-soft));padding:40px 0 32px;position:relative;overflow:hidden}
.page-hero::before{content:"";position:absolute;top:-120px;right:-90px;width:400px;height:400px;border-radius:50%;background:radial-gradient(circle,rgba(126,214,208,.22),transparent 70%);pointer-events:none}
.crumb{font-size:13px;color:var(--slate);margin-bottom:14px;position:relative}
.crumb a{color:var(--slate)}.crumb .sep{margin:0 8px;color:#c5c9da}.crumb .curr{color:var(--federal);font-weight:600}
.page-hero h1{font-size:32px;margin-bottom:10px;line-height:1.1;position:relative}
.page-hero p.lead{color:var(--slate);font-size:16px;max-width:60ch;position:relative}
@media(min-width:1025px){.page-hero{padding:64px 0 56px}.page-hero h1{font-size:44px}}

/* footer */
footer{background:var(--federal-deep);color:#aeb4d6;padding:48px 0 28px}
footer .foot-grid{display:grid;gap:32px;margin-bottom:36px}
@media(min-width:700px){footer .foot-grid{grid-template-columns:1.4fr 1fr 1fr 1fr}}
footer .brand{max-width:340px}
footer .brand img{height:54px;margin-bottom:14px}
footer .brand p{font-size:13px;color:#8b91b8;line-height:1.6}
footer h5{color:#fff;font-size:13px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;margin-bottom:14px}
footer ul{list-style:none}
footer li{margin-bottom:9px}
footer li a{font-size:13px;color:#aeb4d6;transition:color .2s}
footer li a:hover{color:var(--tiffany)}
footer .foot-bottom{border-top:1px solid rgba(255,255,255,.08);padding-top:22px;display:flex;flex-direction:column;gap:14px;align-items:center;text-align:center}
footer .pay-row{display:flex;gap:6px;flex-wrap:wrap;justify-content:center}
footer .pay{background:rgba(255,255,255,.08);border-radius:6px;padding:5px 9px;font-size:11px;color:#cdd2ea;font-weight:600}
footer .foot-bottom p{font-size:11px;color:#7a82a8;max-width:60ch}
.partner-login{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:var(--tiffany);margin-top:14px;padding:7px 12px;border:1px solid rgba(126,214,208,.3);border-radius:8px}

/* mobile drawer */
.m-drawer{position:fixed;inset:0;z-index:200;display:none}
.m-drawer[hidden]{display:none!important}
.m-drawer.open{display:block}
.m-drawer-backdrop{position:absolute;inset:0;background:rgba(6,9,30,.55);backdrop-filter:blur(4px);animation:fadeIn .25s ease-out}
.m-drawer-panel{position:absolute;top:0;right:0;bottom:0;width:min(360px,86vw);background:#fff;box-shadow:-12px 0 40px rgba(6,9,30,.3);display:flex;flex-direction:column;animation:slideIn .3s cubic-bezier(.2,.7,.3,1)}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes slideIn{from{transform:translateX(100%)}to{transform:translateX(0)}}
.m-drawer-head{padding:16px 20px;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between}
.m-drawer-close{width:42px;height:42px;border:none;background:var(--paper-warm);border-radius:10px;cursor:pointer;color:var(--federal);display:flex;align-items:center;justify-content:center}
.m-drawer-body{flex:1;overflow-y:auto;padding:20px}
.m-cta{display:block;background:var(--tiffany);color:var(--federal);text-align:center;font-weight:700;padding:14px;border-radius:10px;margin-bottom:24px;font-size:15px}
.m-section{margin-bottom:22px}
.m-section-label{font-size:11px;font-weight:700;color:var(--steel);text-transform:uppercase;letter-spacing:.08em;margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid var(--line)}
.m-section a{display:block;padding:11px 4px;font-size:15px;color:var(--ink);font-weight:500}
.m-section a:hover{color:var(--federal)}
.m-partner-login{display:inline-flex!important;align-items:center;gap:6px;color:var(--steel)!important;font-size:13px!important;margin-top:6px;padding:8px 12px!important;border:1px solid var(--line);border-radius:8px}
body.drawer-open{overflow:hidden}

@media(prefers-reduced-motion:no-preference){
  .reveal{opacity:0;transform:translateY(16px);transition:opacity .55s var(--ease),transform .55s var(--ease)}
  .reveal.in{opacity:1;transform:none}
}

/* ============================================================
   Additional component styles
   ============================================================ */

/* Skip to content (a11y) */
.skip-to-content{position:absolute;top:-50px;left:0;background:var(--federal);color:#fff;padding:10px 16px;text-decoration:none;border-radius:0 0 6px 0;z-index:999;font-size:13px;font-weight:600}
.skip-to-content:focus{top:0}

/* Generic cards & badges */
.card-badge{position:absolute;top:14px;left:14px;font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;padding:5px 10px;border-radius:6px;color:#fff;z-index:2}
.badge-champion{background:var(--purple);color:#fff}
.badge-popular{background:var(--tiffany);color:var(--federal)}
.badge-flagship{background:var(--federal);color:#fff}
.badge-perf{background:var(--steel);color:#fff}
.badge-longev{background:var(--tiffany);color:var(--federal)}
.badge-hormones{background:var(--purple);color:#fff}
.badge-essentials{background:var(--slate);color:#fff}

/* Vitall Point + Insight callouts (used in PDP, article, portal tour) */
.vc-point{background:var(--tiffany-soft);border:1px solid #c0e9e5;border-left:4px solid var(--tiffany);border-radius:10px;padding:16px 20px;margin:24px 0}
.vc-point b{display:flex;align-items:center;gap:7px;color:var(--steel);font-size:12px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;margin-bottom:6px}
.vc-point p{font-size:15px;color:var(--ink);margin:0;line-height:1.55}
.vc-insight{background:var(--purple-soft);border:1px solid #e2cfee;border-left:4px solid var(--purple);border-radius:10px;padding:16px 20px;margin:24px 0}
.vc-insight b{display:flex;align-items:center;gap:7px;color:var(--purple);font-size:12px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;margin-bottom:6px}
.vc-insight p{font-size:15px;color:var(--ink);margin:0;line-height:1.55}

/* Accordion (used on PDP biomarkers, FAQs, article) */
.acc{background:#fff;border:1px solid var(--line);border-radius:12px;margin-bottom:10px;overflow:hidden}
.acc-head{padding:18px 22px;display:flex;align-items:center;justify-content:space-between;cursor:pointer;font-weight:600;color:var(--federal);font-size:15px;gap:14px;background:#fff}
.acc-head:hover{background:var(--paper-warm)}
.acc-head .chev{color:var(--slate);transition:transform .25s var(--ease)}
.acc.open .acc-head{background:var(--tiffany-soft)}
.acc.open .acc-head .chev{transform:rotate(180deg);color:var(--federal)}
.acc-body{display:none;padding:4px 22px 22px;color:var(--ink);font-size:14px;line-height:1.65;border-top:1px solid var(--line);background:#fff}
.acc.open .acc-body{display:block}

/* Form fields (used on cart, activate, contact, partners) */
.field{margin-bottom:16px}
.field label{display:block;font-size:13px;font-weight:600;color:var(--federal);margin-bottom:6px}
.field label .req{color:var(--danger);margin-left:2px}
.field input,.field select,.field textarea{width:100%;font-family:inherit;font-size:15px;color:var(--ink);background:#fff;border:1.5px solid var(--line);border-radius:10px;padding:12px 14px;transition:border-color .2s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--federal)}
.field .help{font-size:11px;color:var(--slate);margin-top:5px}
.field .err{display:none;font-size:11px;color:var(--danger);margin-top:5px;font-weight:600}
.field.error .err{display:block}
.field.error input,.field.error select,.field.error textarea{border-color:var(--danger);background:#fff4f4}
.row-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media(max-width:600px){.row-2{grid-template-columns:1fr}}

/* Sex selection pills */
.sex-pills{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.sex-pill{border:1.5px solid var(--line);background:#fff;border-radius:10px;padding:14px;cursor:pointer;text-align:center;font-weight:600;font-size:14px;color:var(--ink);transition:all .2s;display:flex;align-items:center;justify-content:center;gap:7px;font-family:inherit}
.sex-pill:hover{border-color:var(--steel)}
.sex-pill.active{border-color:var(--federal);background:var(--tiffany-soft);color:var(--federal)}

/* Important / Important banner */
.important-banner{background:var(--amber);color:var(--federal-deep);border-radius:12px;padding:14px 18px;margin:14px 0;display:flex;gap:10px;align-items:flex-start;font-size:13px;font-weight:600;line-height:1.5}
.important-banner svg{flex-shrink:0;margin-top:2px}

/* Trust strip (used on PDP, cart, partner landing) */
.trust-strip{display:flex;flex-wrap:wrap;justify-content:center;gap:14px;margin-top:18px}
.trust-strip span{font-size:11px;color:var(--slate);display:inline-flex;align-items:center;gap:5px}
.trust-strip svg{color:var(--tiffany)}

/* Phone frame styles - now defined in homepage section CSS below */


  :root{
    --federal:#121656;--federal-deep:#06091e;--tiffany:#7ED6D0;--tiffany-soft:#E8F7F5;
    --purple:#4F1A6D;--purple-soft:#F4EDF8;--steel:#214C6D;--ink:#1A1D2E;--slate:#5A607A;
    --line:#E6E8F0;--paper:#FFFFFF;--paper-warm:#FBFBFD;
    --danger:#D64545;--danger-soft:#FCEEEE;--good:#2E9E6B;--good-soft:#EAF6F0;--amber:#E8A33D;--amber-soft:#FDF6E9;
    --font:"Public Sans",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
    --maxw:1200px;
    --shadow-sm:0 1px 3px rgba(18,22,86,.06),0 1px 2px rgba(18,22,86,.04);
    --shadow-md:0 12px 30px -12px rgba(18,22,86,.18);
    --shadow-lg:0 28px 60px -20px rgba(18,22,86,.30);
    --ease:cubic-bezier(.2,.7,.3,1);
  }
  *{margin:0;padding:0;box-sizing:border-box}
  html{scroll-behavior:smooth}
  body{font-family:var(--font);color:var(--ink);background:var(--paper);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden;font-variant-numeric:tabular-nums}
  a{text-decoration:none;color:inherit}
  img{max-width:100%;display:block}
  .wrap{max-width:var(--maxw);margin:0 auto;padding:0 20px}
  @media(min-width:1025px){.wrap{padding:0 40px}}
  h1,h2,h3,h4{color:var(--federal);font-weight:700;letter-spacing:-0.02em;line-height:1.16}
  .btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:inherit;font-weight:600;font-size:16px;border-radius:10px;padding:16px 28px;cursor:pointer;border:1.5px solid transparent;transition:all 180ms var(--ease);min-height:44px}
  .btn-primary{background:var(--tiffany);color:var(--federal)}
  .btn-primary:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);background:#92ddd8}
  .btn-primary:active{transform:translateY(0);box-shadow:var(--shadow-sm)}
  .btn-secondary{background:transparent;color:var(--federal);border-color:var(--steel)}
  .btn-secondary:hover{transform:translateY(-2px);background:var(--tiffany-soft);border-color:var(--federal)}
  .btn-dark{background:var(--federal);color:#fff}
  .btn-dark:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);background:#1b2070}
  .btn:focus-visible{outline:3px solid var(--tiffany);outline-offset:2px}
  .btn-lg{padding:18px 34px;font-size:17px}
  .announce{background:var(--federal-deep);color:#cdd2ea;font-size:13px;text-align:center;padding:9px 16px}
  .announce strong{color:var(--tiffany);font-weight:600}
  header{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.9);backdrop-filter:blur(12px);border-bottom:1px solid var(--line);transition:box-shadow .3s}
  header.scrolled{box-shadow:var(--shadow-sm)}
  .nav{display:flex;align-items:center;justify-content:space-between;height:76px}
  .logo{display:flex;align-items:center;gap:9px}
  .logo img{height:54px;width:auto;display:block}
  footer .logo img{height:58px}
  .nav-links{display:none;gap:30px;align-items:center}
  .nav-links a{font-size:15px;font-weight:500;color:var(--ink);position:relative;padding:4px 0}
  .nav-links a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:2px;background:var(--tiffany);transition:width .22s var(--ease)}
  .nav-links a:hover::after{width:100%}
  .nav-links .has-drop{position:relative}
  .nav-links .has-drop > a::after{display:none}
  .nav-links .drop{position:absolute;top:calc(100% + 14px);left:50%;transform:translateX(-50%) translateY(8px);background:#fff;border:1px solid var(--line);border-radius:14px;padding:10px;min-width:200px;box-shadow:var(--shadow-md);opacity:0;visibility:hidden;transition:all .22s var(--ease)}
  .nav-links .has-drop:hover .drop,.nav-links .has-drop:focus-within .drop{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
  .nav-links .drop a{display:block;padding:9px 12px;border-radius:8px;font-size:14px;font-weight:500;color:var(--ink)}
  .nav-links .drop a:hover{background:var(--paper-warm);color:var(--federal)}
  .nav-links .drop a::after{display:none}
  .nav-right{display:flex;align-items:center;gap:14px}
  .icon-btn{width:42px;height:42px;border-radius:10px;display:flex;align-items:center;justify-content:center;color:var(--federal);transition:background .2s}
  .icon-btn:hover{background:var(--tiffany-soft)}
  .nav-cta{display:none}
  .burger{display:flex;flex-direction:column;gap:4px;width:42px;height:42px;align-items:center;justify-content:center;border-radius:10px}
  .burger span{width:20px;height:2px;background:var(--federal);border-radius:2px}
  @media(min-width:1025px){.nav-links{display:flex}.nav-cta{display:inline-flex}.burger{display:none}}

  /* HERO */
  .hero{position:relative;background:radial-gradient(120% 90% at 80% 0%,var(--tiffany-soft),#fff 60%);overflow:hidden;padding:44px 0 56px}
  .hero::before{content:"";position:absolute;top:-160px;right:-120px;width:480px;height:480px;border-radius:50%;background:radial-gradient(circle,rgba(126,214,208,.28),transparent 70%);pointer-events:none}
  .hero::after{content:"";position:absolute;bottom:-180px;left:-120px;width:420px;height:420px;border-radius:50%;background:radial-gradient(circle,rgba(79,26,109,.08),transparent 70%);pointer-events:none}
  .hero-grid{display:grid;gap:36px;position:relative;z-index:2;align-items:center}
  .eyebrow{display:inline-flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--line);border-radius:100px;padding:7px 14px;font-size:13px;font-weight:600;color:var(--steel);box-shadow:var(--shadow-sm);margin-bottom:20px}
  .eyebrow .dot{width:7px;height:7px;border-radius:50%;background:var(--tiffany);box-shadow:0 0 8px var(--tiffany)}
  .hero h1{font-size:34px;line-height:1.06;margin-bottom:18px}
  .hero h1 .hl{color:var(--steel);position:relative;white-space:nowrap}
  .hero h1 .hl::after{content:"";position:absolute;left:0;bottom:2px;width:100%;height:10px;background:var(--tiffany);opacity:.45;z-index:-1;border-radius:3px}
  .hero p.lead{font-size:17px;color:var(--slate);max-width:36ch;margin-bottom:26px}
  .hero-cta{display:flex;flex-direction:column;gap:12px;margin-bottom:26px}
  .hero-cta .btn{width:100%}
  .trust-strip{display:flex;flex-wrap:wrap;justify-content:center;gap:14px 18px;align-items:center;padding-top:22px;border-top:1px solid rgba(18,22,86,.10)}
  @media(min-width:1025px){.trust-strip{justify-content:flex-start}}
  .trust-item{display:flex;align-items:center;gap:9px}
  .stars{color:var(--star);font-size:15px;letter-spacing:1px}
  .trust-item .ts-num{font-weight:700;color:var(--federal);font-size:15px}
  .trust-item .ts-sub{font-size:12px;color:var(--slate);line-height:1.3}
  .badge-pill{display:inline-flex;align-items:center;gap:7px;font-size:12px;font-weight:600;color:var(--steel);background:#fff;border:1px solid var(--line);border-radius:8px;padding:7px 11px}
  .badge-pill svg{color:var(--tiffany)}

  /* phone — holds real portal screenshot (true modern phone ratio ~19.5:9) */
  .phone{position:relative;margin:0 auto;width:100%;max-width:260px}
  .phone-frame{background:#0e1230;border-radius:34px;padding:7px;box-shadow:var(--shadow-lg);position:relative;aspect-ratio:9/18}
  .phone-screen{background:#0e1230;border-radius:28px;overflow:hidden;width:100%;height:100%;position:relative;display:block}
  .phone-screen img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:top;display:block}
  .phone-screen > div{width:100%;height:100%;position:absolute;inset:0}
  .marker{border-radius:12px;border:1px solid var(--line);border-left:4px solid var(--danger);padding:12px 13px;margin-bottom:10px;background:#fff;box-shadow:var(--shadow-sm)}
  .marker.ok{border-left-color:var(--good)}
  .marker-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:9px}
  .marker-top b{font-size:14px;color:var(--ink)}
  .rng-pill{font-size:9px;font-weight:800;letter-spacing:.04em;padding:4px 8px;border-radius:20px;text-transform:uppercase}
  .rng-out{background:var(--danger-soft);color:var(--danger)}
  .rng-in{background:var(--good-soft);color:var(--good)}
  .marker-data{display:flex;gap:18px}
  .md-col .lbl{font-size:9px;letter-spacing:.06em;color:var(--slate);text-transform:uppercase}
  .md-col .res{font-size:17px;font-weight:800;color:var(--danger)}
  .md-col.ok .res{color:var(--good)}
  .md-col .ref{font-size:12px;color:var(--slate)}
  .vpoint{border-radius:10px;padding:11px 12px;font-size:11px;line-height:1.5;margin-top:10px;border-left:3px solid var(--tiffany);background:var(--tiffany-soft)}
  .vpoint b{color:var(--steel)}
  .vinsight{border-left-color:var(--purple);background:var(--purple-soft)}
  .vinsight b{color:var(--purple)}
  .float-mini{position:absolute;top:-14px;right:-10px;background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow-lg);padding:11px 13px;display:flex;align-items:center;gap:9px;z-index:5}
  .float-mini .ring{width:34px;height:34px;border-radius:50%;background:conic-gradient(var(--tiffany) 0% 72%,var(--line) 72% 100%);display:flex;align-items:center;justify-content:center}
  .float-mini .ring i{width:25px;height:25px;border-radius:50%;background:#fff;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:800;color:var(--federal);font-style:normal}
  .float-mini .mt{font-size:10px;color:var(--slate);line-height:1.2}
  .float-mini .mt b{display:block;color:var(--federal);font-size:12px}
  @media(min-width:1025px){.hero{padding:70px 0 86px}.hero-grid{grid-template-columns:1.08fr .92fr;gap:50px}.hero h1{font-size:50px}.hero p.lead{font-size:19px}.hero-cta{flex-direction:row}.hero-cta .btn{width:auto}}

  section.block{padding:60px 0}
  @media(min-width:1025px){section.block{padding:90px 0}}
  .warm{background:var(--paper-warm)}
  .dark{background:var(--federal);color:#fff}
  .sec-head{text-align:center;max-width:660px;margin:0 auto 44px}
  .sec-head .kick{font-size:13px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--tiffany);display:block;margin-bottom:12px}
  .sec-head .kick span{color:var(--steel)}
  .sec-head.on-dark .kick span{color:#aeb4d6}
  .sec-head h2{font-size:28px;margin-bottom:14px}
  .sec-head.on-dark h2{color:#fff}
  .sec-head p{color:var(--slate);font-size:16px}
  .sec-head.on-dark p{color:#c3c8e6}
  @media(min-width:1025px){.sec-head h2{font-size:34px}}

  .logos{padding:22px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:#fff}
  .logos .wrap{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:14px 28px}
  .trust-sig{display:inline-flex;align-items:center;gap:9px;font-size:14px;color:var(--slate)}
  .trust-sig b{color:var(--federal);font-weight:700}
  .trust-sig svg{color:var(--tiffany)}
  .trust-sig .stars{color:var(--star);font-size:14px}
  .trust-sig .tsm{font-size:11px;color:#aab0c4}
  .trust-div{width:1px;height:20px;background:var(--line)}
  @media(max-width:680px){.trust-div{display:none}}

  .steps{display:grid;gap:20px}
  .step{background:#fff;border:1px solid var(--line);border-radius:18px;overflow:hidden;transition:all .25s var(--ease);display:flex;flex-direction:column}
  .step:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
  .step-img{aspect-ratio:16/10;overflow:hidden;position:relative;background:linear-gradient(140deg,var(--tiffany-soft),#eef5f8);display:flex;align-items:center;justify-content:center}
  .step-graphic{width:84px;height:84px;border-radius:20px;background:#fff;box-shadow:var(--shadow-sm);display:flex;align-items:center;justify-content:center;color:var(--steel)}
  .step-graphic svg{width:42px;height:42px}
  .step-img::after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 70% 20%,rgba(126,214,208,.25),transparent 60%)}
  .step:nth-child(2) .step-img{background:linear-gradient(140deg,#eef1f8,var(--tiffany-soft))}
  .step:nth-child(3) .step-img{background:linear-gradient(140deg,var(--purple-soft),var(--tiffany-soft))}
  .step:nth-child(3) .step-graphic{color:var(--purple)}
  .step-num{position:absolute;top:12px;left:12px;width:30px;height:30px;border-radius:8px;background:var(--federal);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:15px}
  .step-body{padding:22px 24px}
  .step h3{font-size:19px;margin-bottom:8px}
  .step p{color:var(--slate);font-size:15px}
  @media(min-width:700px){.steps{grid-template-columns:repeat(3,1fr)}}

  /* SEE YOUR RESULTS band */
  .results-grid{display:grid;gap:36px;align-items:center}
  .rc-copy h2{font-size:28px;margin-bottom:16px}
  .rc-copy>p{color:var(--slate);font-size:16px;margin-bottom:22px}
  .rc-feats{display:grid;gap:14px;margin-bottom:24px}
  .rc-feat{display:flex;gap:13px;align-items:flex-start}
  .rc-feat .ic{flex-shrink:0;width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center}
  .rc-feat.t .ic{background:var(--tiffany-soft);color:var(--steel)}
  .rc-feat.p .ic{background:var(--purple-soft);color:var(--purple)}
  .rc-feat.g .ic{background:var(--good-soft);color:var(--good)}
  .rc-feat h4{font-size:15px;margin-bottom:2px}
  .rc-feat p{font-size:13px;color:var(--slate)}
  .rc-card{background:#fff;border:1px solid var(--line);border-radius:20px;box-shadow:var(--shadow-lg);overflow:hidden}
  .rc-card .rc-head{background:var(--federal);color:#fff;padding:16px 20px;display:flex;align-items:center;justify-content:space-between}
  .rc-card .rc-head .t{display:flex;align-items:center;gap:10px}
  .rc-card .rc-head .badge{width:28px;height:28px;border-radius:7px;background:rgba(255,255,255,.14);color:#fff;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:800}
  .rc-card .rc-head h4{color:#fff;margin:0;font-size:16px}
  .rc-card .rc-head .ai{font-size:11px;color:var(--tiffany);font-weight:700;display:flex;align-items:center;gap:5px}
  .rc-card-body{padding:20px}
  .rc-card-body .marker{margin-bottom:12px}
  @media(min-width:1025px){.results-grid{grid-template-columns:1fr 1fr}.rc-copy h2{font-size:34px}}

  .kits{display:grid;gap:20px}
  .kit{background:#fff;border:1px solid var(--line);border-radius:18px;overflow:hidden;transition:all .25s var(--ease);display:flex;flex-direction:column}
  .kit:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
  .kit-img{aspect-ratio:16/11;position:relative;overflow:hidden}
  .kit-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s var(--ease)}
  .kit:hover .kit-img img{transform:scale(1.05)}
  .kit-tag{position:absolute;top:12px;left:12px;font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:#fff;background:var(--purple);padding:5px 10px;border-radius:6px;z-index:2}
  .kit-tag.popular{background:var(--tiffany);color:var(--federal)}
  .kit-tag.flagship{background:var(--federal);color:#fff}
  .kit-body{padding:22px;display:flex;flex-direction:column;flex:1}
  .kit h3{font-size:18px;margin-bottom:6px}
  .kit .kit-desc{font-size:14px;color:var(--slate);margin-bottom:16px;flex:1}
  .kit-specs{display:flex;gap:16px;margin-bottom:16px;padding:12px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
  .kit-spec{flex:1}
  .kit-spec .n{font-size:20px;font-weight:800;color:var(--federal)}
  .kit-spec .l{font-size:11px;color:var(--slate);text-transform:uppercase;letter-spacing:.04em}
  .kit-foot{display:flex;align-items:center;justify-content:space-between;gap:12px}
  .kit-price{font-size:23px;font-weight:800;color:var(--federal)}
  .kit-price span{font-size:13px;font-weight:500;color:var(--slate)}
  @media(min-width:700px){.kits{grid-template-columns:repeat(2,1fr)}}
  @media(min-width:1100px){.kits{grid-template-columns:repeat(4,1fr)}}

  /* comparison strip */
  .compare{background:#fff;border:1px solid var(--line);border-radius:18px;overflow:hidden;box-shadow:var(--shadow-sm)}
  .compare{overflow-x:auto;-webkit-overflow-scrolling:touch}
  .ctable{width:100%;border-collapse:collapse;min-width:560px}
  .ctable th,.ctable td{padding:16px 14px;text-align:left;font-size:14px;border-bottom:1px solid var(--line)}
  .ctable thead th{background:var(--paper-warm);font-size:12px;text-transform:uppercase;letter-spacing:.04em;color:var(--slate);font-weight:700}
  .ctable thead th.us{background:var(--federal);color:#fff;border-radius:0}
  .ctable td.us{background:rgba(126,214,208,.10);font-weight:600;color:var(--federal)}
  .ctable .feat{font-weight:600;color:var(--ink)}
  .ctable .tick{color:var(--good);font-weight:800}
  .ctable .cross{color:var(--danger);font-weight:800}
  .ctable .limited{color:var(--amber);font-weight:700}
  .ctable .neutral{color:var(--slate)}
  .ctable tbody tr:last-child td{border-bottom:none}
  @media(max-width:680px){.compare{margin:0 -20px;border-radius:0;border-left:none;border-right:none}}

  /* testimonials */
  .tcards{display:grid;gap:20px}
  .tcard{background:#fff;border:1px solid var(--line);border-radius:16px;padding:24px;transition:all .25s var(--ease)}
  .tcard:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}
  .tcard .stars{margin-bottom:12px}
  .tcard p{font-size:15px;color:var(--ink);line-height:1.55;margin-bottom:16px}
  .tcard .who{display:flex;align-items:center;gap:11px}
  .tcard .who img{width:42px;height:42px;border-radius:50%;object-fit:cover}
  .tcard .who .nm{font-size:14px;font-weight:700;color:var(--federal)}
  .tcard .who .vf{font-size:11px;color:var(--good);font-weight:600}
  @media(min-width:700px){.tcards{grid-template-columns:repeat(3,1fr)}}

  /* ambassador */
  .amb-card{background:linear-gradient(120deg,#fff,#faf7fc);border:1px solid var(--line);border-radius:22px;overflow:hidden;display:grid}
  .amb-photo{position:relative;min-height:340px;overflow:hidden}
  .amb-photo img{width:100%;height:100%;object-fit:cover;object-position:center top;position:absolute;inset:0}
  .amb-photo .grad{position:absolute;inset:0;background:linear-gradient(120deg,rgba(79,26,109,.30),transparent 60%)}
  .amb-body{padding:32px 26px}
  .amb-cred{display:inline-flex;align-items:center;gap:8px;background:rgba(79,26,109,.08);color:var(--purple);font-size:12px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;padding:7px 13px;border-radius:8px;margin-bottom:18px}
  .amb-body h2{font-size:25px;margin-bottom:14px}
  .amb-quote{font-size:18px;color:var(--ink);line-height:1.5;font-style:italic;margin-bottom:18px;border-left:3px solid var(--tiffany);padding-left:16px}
  .amb-name{font-weight:700;color:var(--federal);font-size:15px}
  .amb-role{font-size:13px;color:var(--slate);margin-bottom:22px}
  .amb-kits{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:18px}
  .amb-kit-chip{font-size:13px;font-weight:600;color:var(--steel);background:#fff;border:1px solid var(--line);border-radius:9px;padding:9px 14px;transition:all .2s}
  .amb-kit-chip:hover{border-color:var(--purple);color:var(--purple);transform:translateY(-2px)}
  .amb-disclosure{font-size:11px;color:var(--slate);background:var(--paper-warm);border:1px dashed var(--line);border-radius:8px;padding:9px 12px}
  @media(min-width:850px){.amb-card{grid-template-columns:.85fr 1.15fr}.amb-body{padding:44px 40px}}

  .accred{display:grid;gap:16px}
  .acc-item{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.12);border-radius:16px;padding:24px;text-align:center;transition:all .25s var(--ease)}
  .acc-item:hover{transform:translateY(-3px);background:rgba(255,255,255,.08)}
  .acc-ico{width:48px;height:48px;border-radius:12px;background:rgba(126,214,208,.16);display:flex;align-items:center;justify-content:center;color:var(--tiffany);margin:0 auto 14px}
  .acc-item h4{font-size:16px;margin-bottom:6px;color:#fff}
  .acc-item p{font-size:13px;color:#aeb4d6}
  @media(min-width:700px){.accred{grid-template-columns:repeat(4,1fr)}}

  .hub{display:grid;gap:20px}
  .article{background:#fff;border:1px solid var(--line);border-radius:16px;overflow:hidden;transition:all .25s var(--ease)}
  .article:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
  .article-img{aspect-ratio:16/9;overflow:hidden}
  .article-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s var(--ease)}
  .article:hover .article-img img{transform:scale(1.05)}
  .article-body{padding:20px}
  .article .cat{font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--tiffany);display:block;margin-bottom:8px}
  .article .cat span{color:var(--steel)}
  .article h3{font-size:17px;margin-bottom:8px;line-height:1.3}
  .article p{font-size:14px;color:var(--slate)}
  @media(min-width:700px){.hub{grid-template-columns:repeat(3,1fr)}}

  .cta-band{background:linear-gradient(120deg,var(--federal),var(--purple));border-radius:24px;padding:44px 28px;text-align:center;position:relative;overflow:hidden}
  .cta-band::before{content:"";position:absolute;top:-80px;right:-60px;width:300px;height:300px;border-radius:50%;background:radial-gradient(circle,rgba(126,214,208,.22),transparent 70%)}
  .cta-band h2{color:#fff;font-size:27px;margin-bottom:12px;position:relative}
  .cta-band p{color:#d3d7ee;font-size:16px;margin-bottom:24px;position:relative}
  .cta-band .btn{position:relative}
  @media(min-width:1025px){.cta-band{padding:60px 40px}.cta-band h2{font-size:34px}}

  footer{background:var(--federal-deep);color:#aeb4d6;padding:56px 0 28px}
  .foot-grid{display:grid;gap:34px;margin-bottom:36px}
  .foot-brand .logo{color:#fff;margin-bottom:14px}
  .foot-brand p{font-size:13px;color:#8b91b8;max-width:30ch;margin-bottom:14px}
  .foot-col h5{color:#fff;font-size:14px;font-weight:600;margin-bottom:14px}
  .foot-col a{display:block;font-size:13px;color:#aeb4d6;padding:5px 0;transition:color .2s}
  .foot-col a:hover{color:var(--tiffany)}
  .pay-row{display:flex;gap:8px;flex-wrap:wrap}
  .pay{background:rgba(255,255,255,.08);border-radius:6px;padding:6px 10px;font-size:11px;color:#cdd2ea;font-weight:600}
  .disclaimer{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:18px;font-size:12px;color:#8b91b8;line-height:1.6;margin-bottom:24px}
  .foot-bot{border-top:1px solid rgba(255,255,255,.10);padding-top:22px;display:flex;flex-direction:column;gap:12px;font-size:12px;color:#7980a8}
  .foot-bot .badges{display:flex;gap:10px;flex-wrap:wrap}
  @media(min-width:700px){.foot-grid{grid-template-columns:2fr 1fr 1fr 1fr}.foot-bot{flex-direction:row;justify-content:space-between;align-items:center}}

  @media(prefers-reduced-motion:no-preference){
    .reveal{opacity:0;transform:translateY(18px);transition:opacity .6s var(--ease),transform .6s var(--ease)}
    .reveal.in{opacity:1;transform:none}
    .reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}
    .hero .eyebrow,.hero h1,.hero .lead,.hero-cta,.trust-strip{opacity:0;transform:translateY(14px);animation:rise .6s var(--ease) forwards}
    .hero h1{animation-delay:.08s}.hero .lead{animation-delay:.16s}.hero-cta{animation-delay:.24s}.trust-strip{animation-delay:.32s}
    .phone{opacity:0;transform:translateY(22px) scale(.97);animation:rise .8s var(--ease) .2s forwards}
    @keyframes rise{to{opacity:1;transform:none}}
  }

/* =========================================
   LOGO FIXES (prevent squishing)
   ========================================= */
.logo{display:flex;align-items:center;height:auto}
.logo img,.logo-img{
  height:54px !important;
  width:auto !important;
  max-width:200px;
  object-fit:contain;
  display:block;
}
.m-drawer-head .logo img{height:44px !important}
footer .brand img{height:54px;width:auto;max-width:200px;object-fit:contain}


/* === PDP-specific CSS from mockup === */

  
  
  html{scroll-behavior:smooth}
  a{text-decoration:none;color:inherit}
  img{max-width:100%;display:block}
  .wrap{max-width:var(--maxw);margin:0 auto;padding:0 20px}
  @media(min-width:1025px){.wrap{padding:0 40px}}
  h1,h2,h3,h4{color:var(--federal);font-weight:700;letter-spacing:-0.02em;line-height:1.16}
  .btn-primary:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);background:#92ddd8}
  .btn-secondary:hover{transform:translateY(-2px);background:var(--tiffany-soft);border-color:var(--federal)}
  .btn-dark{background:var(--federal);color:#fff}
  .btn-dark:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);background:#1b2070}
  .btn:focus-visible{outline:3px solid var(--tiffany);outline-offset:2px}
  .btn-lg{padding:18px 34px;font-size:17px}

  /* announce + header (matches homepage) */
  .announce{background:var(--federal-deep);color:#cdd2ea;font-size:13px;text-align:center;padding:9px 16px}
  .announce strong{color:var(--tiffany);font-weight:600}
  header{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.9);backdrop-filter:blur(12px);border-bottom:1px solid var(--line);transition:box-shadow .3s}
  header.scrolled{box-shadow:var(--shadow-sm)}
  .nav{display:flex;align-items:center;justify-content:space-between;height:76px}
  .logo{display:flex;align-items:center;gap:9px}
  .logo img{height:54px;width:auto;display:block}
  .nav-links{display:none;gap:30px;align-items:center}
  .nav-links a{font-size:15px;font-weight:500;color:var(--ink);position:relative;padding:4px 0}
  .nav-links a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:2px;background:var(--tiffany);transition:width .22s var(--ease)}
  .nav-links a:hover::after{width:100%}
  .nav-links .has-drop{position:relative}
  .nav-links .has-drop > a::after{display:none}
  .nav-links .drop{position:absolute;top:calc(100% + 14px);left:50%;transform:translateX(-50%) translateY(8px);background:#fff;border:1px solid var(--line);border-radius:14px;padding:10px;min-width:200px;box-shadow:var(--shadow-md);opacity:0;visibility:hidden;transition:all .22s var(--ease)}
  .nav-links .has-drop:hover .drop,.nav-links .has-drop:focus-within .drop{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
  .nav-links .drop a{display:block;padding:9px 12px;border-radius:8px;font-size:14px;font-weight:500;color:var(--ink)}
  .nav-links .drop a:hover{background:var(--paper-warm);color:var(--federal)}
  .nav-links .drop a::after{display:none}
  .nav-right{display:flex;align-items:center;gap:14px}
  .icon-btn{width:42px;height:42px;border-radius:10px;display:flex;align-items:center;justify-content:center;color:var(--federal);transition:background .2s}
  .icon-btn:hover{background:var(--tiffany-soft)}
  .nav-cta{display:none}
  .burger{display:flex;flex-direction:column;gap:4px;width:42px;height:42px;align-items:center;justify-content:center;border-radius:10px}
  .burger span{width:20px;height:2px;background:var(--federal);border-radius:2px}
  @media(min-width:1025px){.nav-links{display:flex}.nav-cta{display:inline-flex}.burger{display:none}}

  /* breadcrumb */
  .crumb{padding:18px 0;font-size:13px;color:var(--slate);border-bottom:1px solid var(--line)}
  .crumb a{color:var(--slate);transition:color .2s}
  .crumb a:hover{color:var(--federal)}
  .crumb .sep{margin:0 8px;color:#c5c9da}
  .crumb .curr{color:var(--federal);font-weight:600}

  /* PDP main grid */
  .pdp{padding:32px 0 56px}
  .pdp-grid{display:grid;gap:32px}
  @media(min-width:1025px){.pdp-grid{grid-template-columns:1.1fr .9fr;gap:56px}.pdp{padding:48px 0 80px}}

  /* gallery */
  .gallery-main{aspect-ratio:4/3;background:linear-gradient(140deg,var(--tiffany-soft),#eef5f8);border-radius:20px;overflow:hidden;position:relative;display:flex;align-items:center;justify-content:center}
  .gallery-main img{width:100%;height:100%;object-fit:cover}
  .gallery-badges{position:absolute;top:14px;left:14px;display:flex;flex-direction:column;align-items:flex-start;gap:6px;z-index:3}
  .gallery-badges .badge{display:inline-block;width:auto}
  .badge{font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;padding:6px 11px;border-radius:6px;color:#fff;background:var(--federal)}
  .badge.popular{background:var(--tiffany);color:var(--federal)}
  .badge.champion{background:var(--purple)}
  .badge.flagship{background:var(--federal)}
  .badge.goal-perf{background:var(--steel)}
  .badge.goal-longev{background:var(--tiffany);color:var(--federal)}
  .badge.goal-hormone{background:var(--purple)}
  .badge.goal-essentials{background:var(--slate);color:#fff}
  .gallery-thumbs{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-top:12px}
  .thumb{aspect-ratio:1;background:var(--paper-warm);border:1.5px solid var(--line);border-radius:10px;cursor:pointer;transition:all .2s;overflow:hidden}
  .thumb.active{border-color:var(--federal)}
  .thumb:hover{border-color:var(--steel)}

  /* buy box */
  .buy h1{font-size:28px;line-height:1.15;margin-bottom:12px}
  @media(min-width:1025px){.buy h1{font-size:36px}}
  .review-row{display:flex;align-items:center;gap:10px;margin-bottom:16px;font-size:14px;color:var(--slate)}
  .review-row .stars{color:var(--star);font-size:19px;letter-spacing:2px;line-height:1}
  .review-row a{color:var(--steel);text-decoration:underline}
  .rev-summary{display:flex;gap:28px;align-items:center;flex-wrap:wrap;background:#fff;border:1px solid var(--line);border-radius:14px;padding:24px 28px;margin-top:8px}
  .rev-summary-score{text-align:center;flex-shrink:0}
  .rev-summary-score .big{font-size:44px;font-weight:800;color:var(--federal);line-height:1}
  .rev-summary-score .stars{color:var(--star);font-size:20px;letter-spacing:2px;margin:6px 0}
  .rev-summary-score .ct{font-size:13px;color:var(--slate)}
  .rev-summary-note{flex:1;min-width:200px}
  .rev-summary-note p{font-size:14px;color:var(--slate);line-height:1.6;margin:0}
  .lead{font-size:16px;color:var(--slate);margin-bottom:22px;max-width:50ch}
  .price-row{display:flex;align-items:baseline;gap:12px;margin-bottom:22px;padding-bottom:22px;border-bottom:1px solid var(--line)}
  .price{font-size:34px;font-weight:800;color:var(--federal)}
  .price-sub{font-size:13px;color:var(--slate)}
  .price-klarna{display:inline-block;font-size:12px;color:var(--slate);background:var(--paper-warm);border:1px solid var(--line);padding:5px 10px;border-radius:6px;margin-top:6px}

  /* collection method selector */
  .collect-label{font-size:13px;font-weight:700;color:var(--federal);text-transform:uppercase;letter-spacing:.06em;margin-bottom:10px}
  .collect-opts{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:24px}
  .collect-opt{border:1.5px solid var(--line);border-radius:14px;padding:14px;cursor:pointer;transition:all .2s;position:relative;background:#fff}
  .collect-opt:hover{border-color:var(--steel)}
  .collect-opt.active{border-color:var(--federal);background:var(--tiffany-soft)}
  .collect-opt .ic{width:28px;height:28px;border-radius:8px;background:var(--tiffany-soft);display:flex;align-items:center;justify-content:center;color:var(--steel);margin-bottom:8px}
  .collect-opt.active .ic{background:#fff}
  .collect-opt h4{font-size:14px;margin-bottom:2px}
  .collect-opt p{font-size:12px;color:var(--slate);line-height:1.4}
  .collect-opt .check{position:absolute;top:12px;right:12px;width:18px;height:18px;border-radius:50%;border:1.5px solid var(--line);transition:all .2s}
  .collect-opt.active .check{background:var(--federal);border-color:var(--federal)}
  .collect-opt.active .check::after{content:"";position:absolute;top:4px;left:4px;width:6px;height:6px;border-radius:50%;background:var(--tiffany)}

  /* clinic postcode check */
  .clinic-check{display:none;margin:-12px 0 24px;background:var(--tiffany-soft);border:1px solid var(--line);border-radius:12px;padding:14px}
  .clinic-check.show{display:block}
  .clinic-check label{display:block;font-size:12px;font-weight:700;color:var(--federal);text-transform:uppercase;letter-spacing:.05em;margin-bottom:7px}
  .clinic-check .row{display:flex;gap:8px}
  .clinic-check input{flex:1;font-family:inherit;font-size:15px;color:var(--federal);background:#fff;border:1.5px solid var(--line);border-radius:8px;padding:10px 12px;text-transform:uppercase}
  .clinic-check input:focus{outline:none;border-color:var(--federal)}
  .clinic-check button{font-family:inherit;font-weight:600;font-size:14px;background:var(--federal);color:#fff;border:none;border-radius:8px;padding:10px 16px;cursor:pointer}
  .clinic-result{margin-top:10px;font-size:13px;display:none;align-items:flex-start;gap:8px;padding:10px;border-radius:8px;background:#fff}
  .clinic-result.show{display:flex}
  .clinic-result.ok{color:var(--good)}.clinic-result.ok .ic{color:var(--good)}
  .clinic-result.warn{color:#a06b15}.clinic-result.warn .ic{color:var(--amber)}
  .clinic-result.no{color:var(--danger)}.clinic-result.no .ic{color:var(--danger)}
  .clinic-result .ic{flex-shrink:0;margin-top:1px}
  .clinic-result b{display:block;color:var(--federal);margin-bottom:2px}
  .cta-wrap{display:flex;gap:10px;margin-bottom:18px}
  .cta-wrap
  .heart{width:54px;min-height:54px;background:#fff;border:1.5px solid var(--line);border-radius:10px;display:flex;align-items:center;justify-content:center;color:var(--steel);cursor:pointer;transition:all .2s}
  .heart:hover{border-color:var(--federal);color:var(--federal)}
  .trust-pills{display:flex;flex-wrap:wrap;justify-content:center;gap:10px;margin-bottom:24px}
  @media(min-width:1025px){.trust-pills{justify-content:flex-start}}
  .pill{display:inline-flex;align-items:center;gap:7px;font-size:12px;font-weight:600;color:var(--steel);background:#fff;border:1px solid var(--line);border-radius:8px;padding:7px 11px}
  .pill svg{color:var(--tiffany)}

  /* "what's measured" sneak peek */
  .peek{background:var(--paper-warm);border:1px solid var(--line);border-radius:14px;padding:18px 20px;margin-bottom:8px}
  .peek h4{font-size:14px;margin-bottom:8px;display:flex;align-items:center;gap:8px}
  .peek h4 svg{color:var(--tiffany)}
  .peek p{font-size:13px;color:var(--slate)}
  .peek strong{color:var(--federal);font-weight:700}

  /* sticky mobile cta */
  .sticky-mobile{position:fixed;bottom:0;left:0;right:0;background:#fff;border-top:1px solid var(--line);padding:12px 20px;display:flex;gap:10px;z-index:50;box-shadow:0 -8px 30px -10px rgba(18,22,86,.10)}
  .sticky-mobile .price-sm{display:flex;flex-direction:column;justify-content:center}
  .sticky-mobile .price-sm .p{font-size:18px;font-weight:800;color:var(--federal);line-height:1}
  .sticky-mobile .price-sm .s{font-size:11px;color:var(--slate)}
  .sticky-mobile
  @media(min-width:1025px){.sticky-mobile{display:none}}

  /* section base */
  section.block{padding:48px 0}
  @media(min-width:1025px){section.block{padding:72px 0}}
  .warm{background:var(--paper-warm)}
  .sec-head{max-width:680px;margin-bottom:32px}
  .sec-head .kick{font-size:13px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--tiffany);display:block;margin-bottom:10px}
  .sec-head .kick span{color:var(--steel)}
  .sec-head h2{font-size:26px;margin-bottom:10px}
  .sec-head p{color:var(--slate);font-size:15px}
  @media(min-width:1025px){.sec-head h2{font-size:32px}}

  /* biomarkers section */
  .bm-tabs{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:22px}
  .bm-tab{font-size:13px;font-weight:600;color:var(--steel);background:#fff;border:1.5px solid var(--line);border-radius:100px;padding:8px 14px;cursor:pointer;transition:all .2s}
  .bm-tab:hover{border-color:var(--federal)}
  .bm-tab.active{background:var(--federal);color:#fff;border-color:var(--federal)}
  .bm-tab .ct{font-size:11px;background:rgba(255,255,255,.18);color:#fff;padding:2px 7px;border-radius:100px;margin-left:5px}
  .bm-tab:not(.active) .ct{background:var(--tiffany-soft);color:var(--steel)}
  .bm-groups{display:grid;gap:14px}
  .bm-group{background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden;transition:box-shadow .25s}
  .bm-group:hover{box-shadow:var(--shadow-sm)}
  .bm-head{display:flex;align-items:center;gap:13px;padding:18px 20px;cursor:pointer;background:#fff;transition:background .2s}
  .bm-head:hover{background:var(--paper-warm)}
  .bm-head .gi{width:38px;height:38px;border-radius:10px;background:var(--tiffany-soft);display:flex;align-items:center;justify-content:center;color:var(--steel);flex-shrink:0}
  .bm-head .gt{flex:1;min-width:0}
  .bm-head h3{font-size:16px;margin-bottom:3px}
  .bm-head .gd{font-size:13px;color:var(--slate);line-height:1.4}
  .bm-head .gc{font-size:12px;font-weight:700;color:var(--steel);background:var(--tiffany-soft);padding:4px 10px;border-radius:100px;flex-shrink:0;white-space:nowrap}
  .bm-head .toggle{display:none;font-size:12px;font-weight:600;color:var(--steel);flex-shrink:0;align-items:center;gap:5px}
  @media(min-width:700px){.bm-head .toggle{display:inline-flex}}
  .bm-head .chev{color:var(--slate);transition:transform .25s;flex-shrink:0}
  .bm-group.open .bm-head .chev{transform:rotate(180deg)}
  .bm-group.open .bm-head .toggle .lbl::before{content:"Hide"}
  .bm-head .toggle .lbl::before{content:"Show"}
  .bm-
  .bm-group.open .bm-
  .bm-list{display:grid;gap:10px;padding-top:16px}
  .bm-item{display:flex;align-items:flex-start;gap:12px;padding:10px 0}
  .bm-item .dot{width:7px;height:7px;border-radius:50%;background:var(--tiffany);margin-top:8px;flex-shrink:0}
  .bm-item b{font-size:14px;color:var(--ink);display:block;margin-bottom:1px}
  .bm-item p{font-size:13px;color:var(--slate)}

  /* process section */
  .process{display:grid;gap:18px}
  .proc{display:flex;gap:16px;align-items:flex-start}
  .proc-num{flex-shrink:0;width:42px;height:42px;border-radius:12px;background:var(--tiffany-soft);color:var(--federal);font-weight:800;font-size:18px;display:flex;align-items:center;justify-content:center}
  .proc h4{font-size:16px;margin-bottom:4px}
  .proc p{font-size:14px;color:var(--slate)}
  @media(min-width:700px){.process{grid-template-columns:repeat(2,1fr);gap:24px}}
  @media(min-width:1025px){.process{grid-template-columns:repeat(4,1fr)}}

  /* prep + AI plan + faqs share accordion style */
  .acc{background:#fff;border:1px solid var(--line);border-radius:12px;margin-bottom:10px;overflow:hidden}
  .acc-head{padding:18px 20px;display:flex;align-items:center;justify-content:space-between;cursor:pointer;font-weight:600;color:var(--federal);font-size:15px;transition:background .2s}
  .acc-head:hover{background:var(--paper-warm)}
  .acc-head .chev{color:var(--slate);transition:transform .25s}
  .acc.open .acc-head .chev{transform:rotate(180deg)}
  .acc-
  .acc-body p{margin-bottom:10px}
  .acc-body ul{padding-left:18px}
  .acc-body li{margin-bottom:6px}
  .acc.open .acc-

  /* prep highlights */
  .prep{display:grid;gap:12px}
  .prep-item{display:flex;align-items:flex-start;gap:12px;background:#fff;border:1px solid var(--line);border-radius:12px;padding:14px 16px}
  .prep-item .ic{width:36px;height:36px;border-radius:9px;background:var(--tiffany-soft);color:var(--steel);display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:2px}
  .prep-item b{font-size:14px;color:var(--ink);display:block;line-height:1.3;margin-bottom:2px}
  .prep-item span{font-size:12px;color:var(--slate);line-height:1.45;display:block}
  @media(min-width:700px){.prep{grid-template-columns:repeat(2,1fr)}}
  @media(min-width:1100px){.prep{grid-template-columns:repeat(4,1fr)}}

  /* portal-preview band */
  .portal-grid{display:grid;gap:36px;align-items:center}
  .portal-copy h2{font-size:26px;margin-bottom:14px}
  .portal-copy p{color:var(--slate);font-size:15px;margin-bottom:18px}
  .portal-feats{display:grid;gap:12px;margin-bottom:20px}
  .pf{display:flex;gap:11px;align-items:flex-start}
  .pf .ic{width:30px;height:30px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
  .pf.t .ic{background:var(--tiffany-soft);color:var(--steel)}
  .pf.p .ic{background:var(--purple-soft);color:var(--purple)}
  .pf b{font-size:14px;color:var(--federal);display:block}
  .pf span{font-size:13px;color:var(--slate)}
  .portal-phone{position:relative;margin:0 auto;width:100%;max-width:280px}
  .portal-phone .frame{background:#0e1230;border-radius:38px;padding:8px;box-shadow:var(--shadow-lg)}
  .portal-phone .scr{background:#0e1230;border-radius:30px;overflow:hidden}
  .portal-phone .scr img{width:100%;height:auto;display:block}
  @media(min-width:1025px){.portal-grid{grid-template-columns:1.1fr .9fr}.portal-copy h2{font-size:32px}}

  /* reviews summary */
  .rev-summary{background:#fff;border:1px solid var(--line);border-radius:16px;padding:24px;display:grid;gap:20px;align-items:center}
  .rev-score{text-align:center;padding-right:20px}
  .rev-score .big{font-size:48px;font-weight:800;color:var(--federal);line-height:1}
  .rev-score .stars{color:var(--star);font-size:18px;letter-spacing:2px;margin:8px 0}
  .rev-score .ct{font-size:12px;color:var(--slate)}
  .rev-bars{display:grid;gap:6px}
  .rev-bar{display:grid;grid-template-columns:30px 1fr 30px;align-items:center;gap:10px;font-size:12px;color:var(--slate)}
  .rev-bar .b{height:7px;background:var(--line);border-radius:100px;overflow:hidden}
  .rev-bar .f{height:100%;background:var(--star);border-radius:100px}
  @media(min-width:700px){.rev-summary{grid-template-columns:auto 1fr;padding:32px}}

  /* cross-sells */
  .xsell{display:grid;gap:16px}
  .xs-card{background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden;transition:all .25s var(--ease);display:flex;flex-direction:column}
  .xs-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}
  .xs-img{aspect-ratio:16/10;background:linear-gradient(135deg,var(--tiffany-soft),#eef5f8);position:relative;overflow:hidden}
  .xs-img img{width:100%;height:100%;object-fit:cover}
  .xs-tag{position:absolute;top:10px;left:10px;font-size:10px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:#fff;background:var(--purple);padding:4px 8px;border-radius:5px}
  .xs-tag.popular{background:var(--tiffany);color:var(--federal)}
  .xs-
  .xs-body h3{font-size:15px;margin-bottom:6px}
  .xs-meta{font-size:12px;color:var(--slate);margin-bottom:12px;flex:1}
  .xs-foot{display:flex;align-items:center;justify-content:space-between;gap:10px}
  .xs-price{font-size:18px;font-weight:800;color:var(--federal)}
  @media(min-width:700px){.xsell{grid-template-columns:repeat(3,1fr)}}

  /* disclaimer / footer base (kept light) */
  .pdp-disclaimer{font-size:12px;color:var(--slate);background:var(--paper-warm);border:1px dashed var(--line);border-radius:10px;padding:14px 16px;margin-top:24px;line-height:1.55}
  footer{background:var(--federal-deep);color:#aeb4d6;padding:40px 0 28px;margin-top:0}
  footer .wrap{display:flex;flex-direction:column;gap:18px;align-items:center;text-align:center}
  footer .logo{display:block}
  footer .logo img{height:54px;width:auto;display:block;margin:0 auto}
  footer p{font-size:12px;color:#8b91b8;max-width:48ch;line-height:1.6}
  footer .pay{background:rgba(255,255,255,.08);border-radius:6px;padding:5px 9px;font-size:11px;color:#cdd2ea;font-weight:600}
  footer .pay-row{display:flex;gap:6px;flex-wrap:wrap;justify-content:center}

  /* reveal */
  @media(prefers-reduced-motion:no-preference){
    .reveal{opacity:0;transform:translateY(16px);transition:opacity .5s var(--ease),transform .5s var(--ease)}
    .reveal.in{opacity:1;transform:none}
  }


/* === Category CSS from mockup === */

  
  
  html{scroll-behavior:smooth}
  a{text-decoration:none;color:inherit}
  img{max-width:100%;display:block}
  @media(min-width:1025px){}
  h1,h2,h3,h4{color:var(--federal);font-weight:700;letter-spacing:-0.02em;line-height:1.16}
  .btn-primary:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);background:#92ddd8}
  .btn-secondary{background:transparent;color:var(--federal);border-color:var(--steel)}
  .btn-secondary:hover{background:var(--tiffany-soft);border-color:var(--federal)}
  .btn-dark{background:var(--federal);color:#fff}
  .btn-dark:hover{background:#1b2070}
  .btn:focus-visible{outline:3px solid var(--tiffany);outline-offset:2px}

  .announce{background:var(--federal-deep);color:#cdd2ea;font-size:13px;text-align:center;padding:9px 16px}
  .announce strong{color:var(--tiffany);font-weight:600}
  header{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.9);backdrop-filter:blur(12px);border-bottom:1px solid var(--line);transition:box-shadow .3s}
  header.scrolled{box-shadow:var(--shadow-sm)}
  .nav{display:flex;align-items:center;justify-content:space-between;height:76px}
  .logo{display:flex;align-items:center;gap:9px}
  .logo img{height:54px;width:auto;display:block}
  .nav-links{display:none;gap:30px;align-items:center}
  .nav-links a{font-size:15px;font-weight:500;color:var(--ink);position:relative;padding:4px 0}
  .nav-links a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:2px;background:var(--tiffany);transition:width .22s var(--ease)}
  .nav-links a:hover::after{width:100%}
  .nav-links .has-drop{position:relative}
  .nav-links .has-drop > a::after{display:none}
  .nav-links .drop{position:absolute;top:calc(100% + 14px);left:50%;transform:translateX(-50%) translateY(8px);background:#fff;border:1px solid var(--line);border-radius:14px;padding:10px;min-width:200px;box-shadow:var(--shadow-md);opacity:0;visibility:hidden;transition:all .22s var(--ease)}
  .nav-links .has-drop:hover .drop,.nav-links .has-drop:focus-within .drop{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
  .nav-links .drop a{display:block;padding:9px 12px;border-radius:8px;font-size:14px;font-weight:500;color:var(--ink)}
  .nav-links .drop a:hover{background:var(--paper-warm);color:var(--federal)}
  .nav-links .drop a::after{display:none}
  .nav-right{display:flex;align-items:center;gap:14px}
  .icon-btn{width:42px;height:42px;border-radius:10px;display:flex;align-items:center;justify-content:center;color:var(--federal);transition:background .2s}
  .icon-btn:hover{background:var(--tiffany-soft)}
  .nav-cta{display:none}
  .burger{display:flex;flex-direction:column;gap:4px;width:42px;height:42px;align-items:center;justify-content:center;border-radius:10px}
  .burger span{width:20px;height:2px;background:var(--federal);border-radius:2px}
  @media(min-width:1025px){.nav-links{display:flex}.nav-cta{display:inline-flex}.burger{display:none}}

  /* hero */
  .cat-hero{background:linear-gradient(180deg,#fff,var(--tiffany-soft));padding:36px 0 40px;position:relative;overflow:hidden}
  .cat-hero::before{content:"";position:absolute;top:-100px;right:-80px;width:340px;height:340px;border-radius:50%;background:radial-gradient(circle,rgba(126,214,208,.22),transparent 70%);pointer-events:none}
  .crumb{font-size:13px;color:var(--slate);margin-bottom:14px}
  .crumb a{color:var(--slate)}.crumb .sep{margin:0 8px;color:#c5c9da}.crumb .curr{color:var(--federal);font-weight:600}
  .cat-hero h1{font-size:32px;line-height:1.1;margin-bottom:10px}
  .cat-hero p{color:var(--slate);font-size:16px;max-width:60ch;margin-bottom:18px}
  .cat-quick{display:flex;flex-wrap:wrap;gap:8px}
  .cat-quick a{font-size:13px;font-weight:600;color:var(--steel);background:#fff;border:1px solid var(--line);border-radius:100px;padding:8px 14px;transition:all .2s}
  .cat-quick a:hover{border-color:var(--federal);transform:translateY(-1px)}
  .cat-quick a.active{background:var(--federal);color:#fff;border-color:var(--federal)}
  @media(min-width:1025px){.cat-hero{padding:56px 0 64px}.cat-hero h1{font-size:42px}}

  /* toolbar */
  .toolbar{position:sticky;top:76px;z-index:40;background:#fff;border-bottom:1px solid var(--line);padding:14px 0}
  .toolbar-row{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
  .filter-btn{display:inline-flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:var(--federal);background:#fff;border:1.5px solid var(--line);border-radius:10px;padding:9px 14px;cursor:pointer;transition:all .2s}
  .filter-btn:hover{border-color:var(--federal)}
  .filter-btn .ct{background:var(--federal);color:#fff;font-size:11px;padding:2px 7px;border-radius:100px}
  .result-count{font-size:13px;color:var(--slate)}
  .sort-wrap{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--slate)}
  .sort-wrap select{font-family:inherit;font-size:13px;font-weight:600;color:var(--federal);background:#fff;border:1.5px solid var(--line);border-radius:10px;padding:8px 12px;cursor:pointer}

  /* layout: filters left, grid right (desktop) */
  .main{padding:24px 0 64px}
  .main-grid{display:grid;gap:24px}
  @media(min-width:1025px){.main-grid{grid-template-columns:260px 1fr;gap:32px}}

  /* filters */
  .filters{background:#fff;border:1px solid var(--line);border-radius:14px;padding:20px;height:max-content;display:none}
  .filters.open{display:block}
  @media(min-width:1025px){.filters{display:block;position:sticky;top:160px}}
  .filter-group{padding:14px 0;border-bottom:1px solid var(--line)}
  .filter-group:last-child{border-bottom:none}
  .filter-group:first-child{padding-top:0}
  .filter-group h4{font-size:13px;text-transform:uppercase;letter-spacing:.06em;margin-bottom:12px;color:var(--steel)}
  .check-list{display:grid;gap:8px}
  .check-item{display:flex;align-items:center;gap:10px;font-size:14px;color:var(--ink);cursor:pointer}
  .check-item input{width:16px;height:16px;accent-color:var(--federal);cursor:pointer}
  .check-item .ct{margin-left:auto;font-size:12px;color:var(--slate)}
  .range-row{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--slate)}
  .range-row input[type=number]{width:80px;padding:7px 10px;border:1.5px solid var(--line);border-radius:8px;font-family:inherit}
  .clear{font-size:13px;font-weight:600;color:var(--steel);text-decoration:underline;cursor:pointer;background:none;border:none;padding:8px 0}

  /* product grid */
  .grid{display:grid;gap:20px}
  @media(min-width:700px){.grid{grid-template-columns:repeat(2,1fr)}}
  @media(min-width:1100px){.grid{grid-template-columns:repeat(3,1fr)}}
  .card{background:#fff;border:1px solid var(--line);border-radius:16px;overflow:hidden;transition:all .25s var(--ease);display:flex;flex-direction:column;position:relative}
  .card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
  .card-img{aspect-ratio:16/11;position:relative;overflow:hidden;background:linear-gradient(135deg,var(--tiffany-soft),#eef5f8)}
  .card-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s var(--ease)}
  .card:hover .card-img img{transform:scale(1.05)}
  .card-badge{position:absolute;top:12px;left:12px;font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:#fff;padding:5px 10px;border-radius:6px;z-index:2}
  .badge.champion,.card-badge.champion{background:var(--purple)}
  .badge.popular,.card-badge.popular{background:var(--tiffany);color:var(--federal)}
  .badge.flagship,.card-badge.flagship{background:var(--federal)}
  .card-badge.perf{background:var(--steel)}
  .card-badge.longev{background:var(--tiffany);color:var(--federal)}
  .card-badge.hormone{background:var(--purple)}
  .card-badge.essentials{background:var(--slate)}
  .compare-toggle{position:absolute;top:12px;right:12px;background:rgba(255,255,255,.95);border:1px solid var(--line);border-radius:8px;padding:5px 10px;font-size:11px;font-weight:600;color:var(--steel);cursor:pointer;z-index:2;display:flex;align-items:center;gap:5px;transition:all .2s}
  .compare-toggle:hover{border-color:var(--federal);color:var(--federal)}
  .compare-toggle input{width:13px;height:13px;accent-color:var(--federal);cursor:pointer}
  .card-
  .card h3{font-size:17px;margin-bottom:6px;line-height:1.25}
  .card .desc{font-size:13px;color:var(--slate);margin-bottom:14px;flex:1}
  .card .specs{display:flex;gap:14px;padding:12px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);margin-bottom:14px}
  .card .spec{flex:1}
  .card .spec .n{font-size:18px;font-weight:800;color:var(--federal);line-height:1}
  .card .spec .l{font-size:10px;color:var(--slate);text-transform:uppercase;letter-spacing:.05em;margin-top:2px}
  .card .foot{display:flex;align-items:center;justify-content:space-between;gap:10px}
  .card .price{font-size:20px;font-weight:800;color:var(--federal)}
  .card .price span{font-size:12px;color:var(--slate);font-weight:500}

  /* compare bar (sticky bottom) */
  .compare-bar{position:fixed;bottom:0;left:0;right:0;background:var(--federal);color:#fff;padding:14px 20px;display:none;align-items:center;justify-content:space-between;gap:16px;z-index:80;box-shadow:0 -8px 30px -10px rgba(18,22,86,.30)}
  .compare-bar.show{display:flex}
  .compare-bar .info{font-size:13px}
  .compare-bar .info b{color:var(--tiffany)}
  .compare-bar .actions{display:flex;gap:10px;align-items:center}
  .compare-bar button{font-family:inherit;font-weight:600;font-size:13px;border-radius:8px;padding:10px 16px;cursor:pointer;border:none}
  .compare-bar .clear-c{background:transparent;color:#fff;border:1px solid rgba(255,255,255,.3)}
  .compare-bar .go{background:var(--tiffany);color:var(--federal)}

  /* educational footer */
  .edu{background:var(--paper-warm);padding:48px 0;border-top:1px solid var(--line)}
  .edu-grid{display:grid;gap:24px}
  .edu h2{font-size:24px;margin-bottom:10px}
  .edu p{color:var(--slate);font-size:15px;margin-bottom:18px}
  .edu-articles{display:grid;gap:14px}
  .edu-art{display:flex;gap:14px;background:#fff;border:1px solid var(--line);border-radius:12px;padding:16px;transition:all .25s var(--ease)}
  .edu-art:hover{transform:translateY(-2px);box-shadow:var(--shadow-sm)}
  .edu-art .ic{width:42px;height:42px;border-radius:10px;background:var(--tiffany-soft);color:var(--steel);display:flex;align-items:center;justify-content:center;flex-shrink:0}
  .edu-art b{font-size:14px;color:var(--federal);display:block;margin-bottom:3px}
  .edu-art span{font-size:12px;color:var(--slate)}
  @media(min-width:900px){.edu-grid{grid-template-columns:1fr 1fr;gap:48px;align-items:center}}

  /* footer */
  footer{background:var(--federal-deep);color:#aeb4d6;padding:40px 0 28px}
  footer
  footer .logo img{height:50px}
  footer p{font-size:12px;color:#8b91b8;max-width:48ch;line-height:1.6}
  footer .pay{background:rgba(255,255,255,.08);border-radius:6px;padding:5px 9px;font-size:11px;color:#cdd2ea;font-weight:600}
  footer .pay-row{display:flex;gap:6px;flex-wrap:wrap;justify-content:center}

  @media(prefers-reduced-motion:no-preference){
    .reveal{opacity:0;transform:translateY(14px);transition:opacity .5s var(--ease),transform .5s var(--ease)}
    .reveal.in{opacity:1;transform:none}
  }


/* === Clinic Finder CSS === */



html{scroll-behavior:smooth}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
@media(min-width:1025px){}
h1,h2,h3,h4{color:var(--federal);font-weight:700;letter-spacing:-0.02em;line-height:1.12}
.btn-primary:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);background:#92ddd8}
.btn-dark{background:var(--federal);color:#fff}
.btn-dark:hover{transform:translateY(-2px);background:#1b2070}
.btn-ghost{background:transparent;color:var(--federal);border-color:var(--line)}
.btn-ghost:hover{border-color:var(--federal);background:var(--tiffany-soft)}
.btn:focus-visible{outline:3px solid var(--tiffany);outline-offset:2px}
.btn-lg{padding:18px 32px;font-size:17px}
.btn:disabled{opacity:.5;cursor:not-allowed}

/* shared header */
.announce{background:var(--federal-deep);color:#cdd2ea;font-size:13px;text-align:center;padding:9px 16px}
.announce strong{color:var(--tiffany);font-weight:600}
header{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.92);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:76px}
.logo img{height:54px;display:block}
.nav-links{display:none;gap:30px;align-items:center}
.nav-links a{font-size:15px;font-weight:500;color:var(--ink);position:relative;padding:4px 0}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:2px;background:var(--tiffany);transition:width .22s var(--ease)}
.nav-links a:hover::after{width:100%}
.nav-links .has-drop{position:relative}
.nav-links .has-drop > a::after{display:none}
.nav-links .drop{position:absolute;top:calc(100% + 14px);left:50%;transform:translateX(-50%) translateY(8px);background:#fff;border:1px solid var(--line);border-radius:14px;padding:10px;min-width:200px;box-shadow:var(--shadow-md);opacity:0;visibility:hidden;transition:all .22s var(--ease)}
.nav-links .has-drop:hover .drop,.nav-links .has-drop:focus-within .drop{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.nav-links .drop a{display:block;padding:9px 12px;border-radius:8px;font-size:14px;color:var(--ink)}
.nav-links .drop a:hover{background:var(--paper-warm);color:var(--federal)}
.nav-links .drop a::after{display:none}
.nav-links .drop a.active{background:var(--tiffany-soft);color:var(--federal)}
.nav-right{display:flex;align-items:center;gap:14px}
.icon-btn{width:42px;height:42px;border-radius:10px;display:flex;align-items:center;justify-content:center;color:var(--federal)}
.icon-btn:hover{background:var(--tiffany-soft)}
.nav-cta{display:none}
.burger{display:flex;flex-direction:column;gap:4px;width:42px;height:42px;align-items:center;justify-content:center;border-radius:10px;background:none;border:none;cursor:pointer}
.burger span{width:20px;height:2px;background:var(--federal);border-radius:2px}
@media(min-width:1025px){.nav-links{display:flex}.nav-cta{display:inline-flex}.burger{display:none}}

/* common section */
section.block{padding:56px 0}
@media(min-width:1025px){section.block{padding:80px 0}}
.warm{background:var(--paper-warm)}
.sec-head{max-width:680px;margin:0 auto 36px;text-align:center}
.sec-head .kick{font-size:13px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--tiffany);display:block;margin-bottom:10px}
.sec-head .kick span{color:var(--steel)}
.sec-head h2{font-size:28px;margin-bottom:10px}
.sec-head p{color:var(--slate);font-size:15px}
@media(min-width:1025px){.sec-head h2{font-size:36px}}

/* simple hero (used by most secondary pages) */
.page-hero{background:linear-gradient(180deg,#fff,var(--tiffany-soft));padding:40px 0 32px;position:relative;overflow:hidden}
.page-hero::before{content:"";position:absolute;top:-120px;right:-90px;width:400px;height:400px;border-radius:50%;background:radial-gradient(circle,rgba(126,214,208,.22),transparent 70%);pointer-events:none}
.page-hero h1{font-size:32px;margin-bottom:10px;line-height:1.1;position:relative}
.page-hero p.lead{color:var(--slate);font-size:16px;max-width:60ch;position:relative}
@media(min-width:1025px){.page-hero{padding:64px 0 56px}.page-hero h1{font-size:44px}}

/* footer */
footer{background:var(--federal-deep);color:#aeb4d6;padding:48px 0 28px}
footer .foot-grid{display:grid;gap:32px;margin-bottom:36px}
@media(min-width:700px){footer .foot-grid{grid-template-columns:1.4fr 1fr 1fr 1fr}}
footer .brand{max-width:340px}
footer .brand img{height:54px;margin-bottom:14px}
footer .brand p{font-size:13px;color:#8b91b8;line-height:1.6}
footer h5{color:#fff;font-size:13px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;margin-bottom:14px}
footer ul{list-style:none}
footer li{margin-bottom:9px}
footer li a{font-size:13px;color:#aeb4d6;transition:color .2s}
footer li a:hover{color:var(--tiffany)}
footer .foot-bottom{border-top:1px solid rgba(255,255,255,.08);padding-top:22px;display:flex;flex-direction:column;gap:14px;align-items:center;text-align:center}
footer .pay-row{display:flex;gap:6px;flex-wrap:wrap;justify-content:center}
footer .pay{background:rgba(255,255,255,.08);border-radius:6px;padding:5px 9px;font-size:11px;color:#cdd2ea;font-weight:600}
footer .foot-bottom p{font-size:11px;color:#7a82a8;max-width:60ch}
.partner-login{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:var(--tiffany);margin-top:14px;padding:7px 12px;border:1px solid rgba(126,214,208,.3);border-radius:8px}

/* mobile drawer */
.m-drawer{position:fixed;inset:0;z-index:200;display:none}
.m-drawer[hidden]{display:none!important}
.m-drawer.open{display:block}
.m-drawer-backdrop{position:absolute;inset:0;background:rgba(6,9,30,.55);backdrop-filter:blur(4px);animation:fadeIn .25s ease-out}
.m-drawer-panel{position:absolute;top:0;right:0;bottom:0;width:min(360px,86vw);background:#fff;box-shadow:-12px 0 40px rgba(6,9,30,.3);display:flex;flex-direction:column;animation:slideIn .3s cubic-bezier(.2,.7,.3,1)}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes slideIn{from{transform:translateX(100%)}to{transform:translateX(0)}}
.m-drawer-head{padding:16px 20px;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between}
.m-drawer-close{width:42px;height:42px;border:none;background:var(--paper-warm);border-radius:10px;cursor:pointer;color:var(--federal);display:flex;align-items:center;justify-content:center}
.m-drawer-
.m-cta{display:block;background:var(--tiffany);color:var(--federal);text-align:center;font-weight:700;padding:14px;border-radius:10px;margin-bottom:24px;font-size:15px}
.m-section{margin-bottom:22px}
.m-section-label{font-size:11px;font-weight:700;color:var(--steel);text-transform:uppercase;letter-spacing:.08em;margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid var(--line)}
.m-section a{display:block;padding:11px 4px;font-size:15px;color:var(--ink);font-weight:500}
.m-section a:hover{color:var(--federal)}
.m-partner-login{display:inline-flex!important;align-items:center;gap:6px;color:var(--steel)!important;font-size:13px!important;margin-top:6px;padding:8px 12px!important;border:1px solid var(--line);border-radius:8px}
body.drawer-open{overflow:hidden}

@media(prefers-reduced-motion:no-preference){
  .reveal{opacity:0;transform:translateY(16px);transition:opacity .55s var(--ease),transform .55s var(--ease)}
  .reveal.in{opacity:1;transform:none}
}



/* === /tmp/article_css.txt === */

  a{text-decoration:none;color:inherit}
  img{max-width:100%;display:block}
  @media(min-width:700px){}
  @media(min-width:1025px){}
  h1,h2,h3,h4{color:var(--federal);font-weight:700;letter-spacing:-0.02em;line-height:1.16}
  .btn-primary:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);background:#92ddd8}
  .btn-dark{background:var(--federal);color:#fff}

  /* shared header */
  .announce{background:var(--federal-deep);color:#cdd2ea;font-size:13px;text-align:center;padding:9px 16px}
  .announce strong{color:var(--tiffany);font-weight:600}
  header{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.92);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
  .nav{display:flex;align-items:center;justify-content:space-between;height:76px}
  .logo img{height:54px;display:block}
  .nav-links{display:none;gap:30px;align-items:center}
  .nav-links a{font-size:15px;font-weight:500;color:var(--ink)}
  .nav-links .has-drop{position:relative}
  .nav-links .drop{position:absolute;top:calc(100% + 14px);left:50%;transform:translateX(-50%) translateY(8px);background:#fff;border:1px solid var(--line);border-radius:14px;padding:10px;min-width:200px;box-shadow:var(--shadow-md);opacity:0;visibility:hidden;transition:all .22s var(--ease)}
  .nav-links .has-drop:hover .drop{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
  .nav-links .drop a{display:block;padding:9px 12px;border-radius:8px;font-size:14px;color:var(--ink)}
  .nav-links .drop a:hover{background:var(--paper-warm);color:var(--federal)}
  .nav-links .drop a.active{background:var(--tiffany-soft);color:var(--federal)}
  .nav-right{display:flex;align-items:center;gap:14px}
  .icon-btn{width:42px;height:42px;border-radius:10px;display:flex;align-items:center;justify-content:center;color:var(--federal)}
  .icon-btn:hover{background:var(--tiffany-soft)}
  .nav-cta{display:none}
  .burger{display:flex;flex-direction:column;gap:4px;width:42px;height:42px;align-items:center;justify-content:center;border-radius:10px;background:none;border:none;cursor:pointer}
  .burger span{width:20px;height:2px;background:var(--federal);border-radius:2px}
  @media(min-width:1025px){.nav-links{display:flex}.nav-cta{display:inline-flex}.burger{display:none}}

  /* article hero */
  .art-hero{padding:32px 0 24px;border-bottom:1px solid var(--line)}
  .art-cat{display:inline-flex;align-items:center;gap:6px;background:var(--tiffany-soft);color:var(--federal);font-size:11px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;padding:6px 12px;border-radius:100px;margin-bottom:14px}
  .art-hero h1{font-size:28px;line-height:1.18;margin-bottom:14px;max-width:760px;letter-spacing:-0.015em}
  .art-meta{display:flex;flex-wrap:wrap;gap:14px;font-size:13px;color:var(--slate);margin-bottom:6px}
  .art-meta span{display:inline-flex;align-items:center;gap:5px}
  .art-meta svg{color:var(--steel)}
  @media(min-width:700px){.art-hero h1{font-size:34px;line-height:1.15}}
  @media(min-width:1025px){.art-hero h1{font-size:42px;line-height:1.1}}

  /* layout: article + TOC sidebar */
  .art-layout{display:grid;gap:36px;padding:40px 0 64px}
  @media(min-width:1025px){.art-layout{grid-template-columns:1fr 240px;gap:64px}}

  /* article body */
  .article{max-width:760px;padding:0 4px}
  @media(min-width:700px){.article{padding:0}}
  .article p{font-size:17px;color:var(--ink);margin-bottom:18px;line-height:1.7}
  .article h2{font-size:24px;margin:36px 0 14px;line-height:1.25}
  .article h3{font-size:19px;margin:24px 0 10px}
  .article ul,.article ol{margin:0 0 18px 22px;font-size:17px;color:var(--ink)}
  .article li{margin-bottom:8px;line-height:1.6}
  .article strong{color:var(--federal);font-weight:700}
  .article a{color:var(--steel);text-decoration:underline;font-weight:500}

  /* lead paragraph */
  .lead{font-size:19px !important;color:var(--slate) !important;line-height:1.55 !important;font-weight:500;border-left:3px solid var(--tiffany);padding:4px 0 4px 20px;margin-bottom:28px !important}

  /* Vitall Point / Insight inline callouts (same DNA as in-product) */
  .vc-point{background:var(--tiffany-soft);border:1px solid #c0e9e5;border-left:4px solid var(--tiffany);border-radius:10px;padding:16px 20px;margin:24px 0}
  .vc-point b{display:flex;align-items:center;gap:7px;color:var(--steel);font-size:12px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;margin-bottom:6px}
  .vc-point p{font-size:15px !important;color:var(--ink) !important;margin:0 !important}

  .vc-insight{background:var(--purple-soft);border:1px solid #e2cfee;border-left:4px solid var(--purple);border-radius:10px;padding:16px 20px;margin:24px 0}
  .vc-insight b{display:flex;align-items:center;gap:7px;color:var(--purple);font-size:12px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;margin-bottom:6px}
  .vc-insight p{font-size:15px !important;color:var(--ink) !important;margin:0 !important}

  /* Key takeaways box */
  .takeaways{background:var(--paper-warm);border:1px solid var(--line);border-radius:14px;padding:22px;margin:30px 0}
  .takeaways h4{font-size:14px;font-weight:700;color:var(--federal);text-transform:uppercase;letter-spacing:.05em;margin-bottom:12px;display:flex;align-items:center;gap:7px}
  .takeaways ul{margin-bottom:0}
  .takeaways li{font-size:15px;color:var(--ink)}

  /* TOC sidebar */
  .toc{display:none}
  @media(min-width:1025px){
    .toc{display:block;position:sticky;top:96px;align-self:start;background:#fff;border:1px solid var(--line);border-radius:14px;padding:20px}
  }
  .toc h4{font-size:13px;font-weight:700;color:var(--steel);text-transform:uppercase;letter-spacing:.05em;margin-bottom:12px}
  .toc ul{list-style:none}
  .toc li{margin-bottom:8px}
  .toc a{font-size:13px;color:var(--slate);transition:color .2s;display:block;padding:5px 0;border-left:2px solid transparent;padding-left:10px;margin-left:-10px}
  .toc a:hover,.toc a.active{color:var(--federal);border-left-color:var(--tiffany)}

  /* related kits CTA inside article */
  .related-cta{background:linear-gradient(135deg,var(--federal),var(--purple));color:#fff;border-radius:18px;padding:28px;margin:32px 0;display:grid;gap:14px}
  .related-cta h3{color:#fff;font-size:20px}
  .related-cta p{font-size:14px;color:#cdd2ea;margin:0 !important}
  .related-cta .kits{display:grid;gap:10px}
  .rk-chip{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);border-radius:10px;padding:14px;display:flex;align-items:center;gap:12px;color:#fff;transition:all .2s}
  .rk-chip:hover{background:rgba(255,255,255,.14)}
  .rk-chip b{display:block;font-size:14px;color:#fff}
  .rk-chip span{font-size:12px;color:#9ea4cc;display:block}
  .rk-chip .arr{margin-left:auto;color:var(--tiffany)}

  /* author + reviewed */
  .author{display:flex;align-items:center;gap:14px;padding:24px;background:var(--paper-warm);border-radius:14px;margin-top:36px}
  .author-avatar{width:54px;height:54px;border-radius:50%;background:var(--tiffany-soft);display:flex;align-items:center;justify-content:center;color:var(--federal);font-weight:800;flex-shrink:0}
  .author-info b{display:block;font-size:14px;color:var(--federal)}
  .author-info span{font-size:12px;color:var(--slate)}

  /* FAQs */
  .faqs{margin-top:36px}
  .faqs h2{margin-bottom:18px}
  .acc{background:#fff;border:1px solid var(--line);border-radius:12px;margin-bottom:10px;overflow:hidden}
  .acc-head{padding:16px 18px;display:flex;align-items:center;justify-content:space-between;cursor:pointer;font-weight:600;color:var(--federal);font-size:15px}
  .acc-head:hover{background:var(--paper-warm)}
  .acc-head .chev{color:var(--slate);transition:transform .2s}
  .acc.open .acc-head .chev{transform:rotate(180deg)}
  .acc-
  .acc.open .acc-

  /* disclaimer */
  .disclaimer{font-size:12px;color:var(--slate);background:var(--paper-warm);border:1px dashed var(--line);border-radius:10px;padding:14px 16px;margin:28px 0 0;line-height:1.55}
  .disclaimer b{color:var(--federal)}

  /* related articles */
  .related{background:var(--paper-warm);padding:48px 0}
  .related h3{font-size:22px;margin-bottom:20px;text-align:center}
  .rel-grid{display:grid;gap:16px;max-width:900px;margin:0 auto}
  @media(min-width:700px){.rel-grid{grid-template-columns:repeat(3,1fr)}}
  .rel-card{background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden;transition:all .25s var(--ease)}
  .rel-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}
  .rel-card .ri{aspect-ratio:16/10;background:var(--tiffany-soft);overflow:hidden}
  .rel-card .ri img{width:100%;height:100%;object-fit:cover}
  .rel-card .rb{padding:16px}
  .rel-card h4{font-size:15px;margin-bottom:4px;line-height:1.3}
  .rel-card span{font-size:12px;color:var(--slate)}

  /* footer */
  footer{background:var(--federal-deep);color:#aeb4d6;padding:48px 0 28px}
  footer .foot-grid{display:grid;gap:32px;margin-bottom:36px}
  @media(min-width:700px){footer .foot-grid{grid-template-columns:1.4fr 1fr 1fr 1fr}}
  footer .brand{max-width:340px}
  footer .brand img{height:54px;margin-bottom:14px}
  footer .brand p{font-size:13px;color:#8b91b8;line-height:1.6}
  footer h5{color:#fff;font-size:13px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;margin-bottom:14px}
  footer ul{list-style:none}
  footer li{margin-bottom:9px}
  footer li a{font-size:13px;color:#aeb4d6}
  footer li a:hover{color:var(--tiffany)}
  footer .foot-bottom{border-top:1px solid rgba(255,255,255,.08);padding-top:22px;display:flex;flex-direction:column;gap:14px;align-items:center;text-align:center}
  footer .pay-row{display:flex;gap:6px;flex-wrap:wrap;justify-content:center}
  footer .pay{background:rgba(255,255,255,.08);border-radius:6px;padding:5px 9px;font-size:11px;color:#cdd2ea;font-weight:600}
  footer .foot-bottom p{font-size:11px;color:#7a82a8;max-width:60ch}
  .partner-login{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:var(--tiffany);margin-top:14px;padding:7px 12px;border:1px solid rgba(126,214,208,.3);border-radius:8px}


/* === /tmp/healthhub_css.txt === */

  a{text-decoration:none;color:inherit}
  img{max-width:100%;display:block}
  @media(min-width:1025px){}
  h1,h2,h3,h4{color:var(--federal);font-weight:700;letter-spacing:-0.02em;line-height:1.16}
  .btn-primary:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);background:#92ddd8}
  .btn-dark{background:var(--federal);color:#fff}
  .btn-dark:hover{transform:translateY(-2px);background:#1b2070}

  .announce{background:var(--federal-deep);color:#cdd2ea;font-size:13px;text-align:center;padding:9px 16px}
  .announce strong{color:var(--tiffany);font-weight:600}
  header{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.92);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
  .nav{display:flex;align-items:center;justify-content:space-between;height:76px}
  .logo img{height:54px;display:block}
  .nav-links{display:none;gap:30px;align-items:center}
  .nav-links a{font-size:15px;font-weight:500;color:var(--ink)}
  .nav-links .has-drop{position:relative}
  .nav-links .drop{position:absolute;top:calc(100% + 14px);left:50%;transform:translateX(-50%) translateY(8px);background:#fff;border:1px solid var(--line);border-radius:14px;padding:10px;min-width:200px;box-shadow:var(--shadow-md);opacity:0;visibility:hidden;transition:all .22s var(--ease)}
  .nav-links .has-drop:hover .drop{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
  .nav-links .drop a{display:block;padding:9px 12px;border-radius:8px;font-size:14px;color:var(--ink)}
  .nav-links .drop a:hover{background:var(--paper-warm);color:var(--federal)}
  .nav-links .drop a.active{background:var(--tiffany-soft);color:var(--federal)}
  .nav-right{display:flex;align-items:center;gap:14px}
  .icon-btn{width:42px;height:42px;border-radius:10px;display:flex;align-items:center;justify-content:center;color:var(--federal)}
  .icon-btn:hover{background:var(--tiffany-soft)}
  .nav-cta{display:none}
  .burger{display:flex;flex-direction:column;gap:4px;width:42px;height:42px;align-items:center;justify-content:center;border-radius:10px;background:none;border:none;cursor:pointer}
  .burger span{width:20px;height:2px;background:var(--federal);border-radius:2px}
  @media(min-width:1025px){.nav-links{display:flex}.nav-cta{display:inline-flex}.burger{display:none}}

  /* HERO */
  .hh-hero{background:linear-gradient(180deg,#fff,var(--tiffany-soft));padding:48px 0 36px;position:relative;overflow:hidden}
  .hh-hero::before{content:"";position:absolute;top:-120px;right:-90px;width:400px;height:400px;border-radius:50%;background:radial-gradient(circle,rgba(126,214,208,.22),transparent 70%);pointer-events:none}
  .hh-hero h1{font-size:34px;margin-bottom:10px}
  .hh-hero p{color:var(--slate);font-size:16px;max-width:60ch;margin-bottom:18px}
  .topic-pills{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:20px}
  .topic-pills a{font-size:13px;font-weight:600;color:var(--steel);background:#fff;border:1px solid var(--line);border-radius:100px;padding:8px 14px;transition:all .2s}
  .topic-pills a.active{background:var(--federal);color:#fff;border-color:var(--federal)}
  .topic-pills a:hover{border-color:var(--federal)}
  .search-bar{display:flex;gap:8px;max-width:480px}
  .search-bar input{flex:1;font-family:inherit;font-size:15px;border:1.5px solid var(--line);border-radius:10px;padding:12px 16px;background:#fff}
  .search-bar input:focus{outline:none;border-color:var(--federal)}
  .search-bar button{font-family:inherit;font-weight:600;border:none;border-radius:10px;background:var(--federal);color:#fff;padding:12px 18px;cursor:pointer}
  @media(min-width:1025px){.hh-hero{padding:64px 0 56px}.hh-hero h1{font-size:42px}}

  /* FEATURED */
  .featured{padding:48px 0 24px}
  .feat-card{background:#fff;border:1px solid var(--line);border-radius:20px;overflow:hidden;display:grid;gap:0;transition:all .25s var(--ease)}
  .feat-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}
  .feat-img{aspect-ratio:16/10;background:linear-gradient(135deg,var(--tiffany-soft),var(--purple-soft));overflow:hidden}
  .feat-img img{width:100%;height:100%;object-fit:cover}
  .feat-
  .article-meta{display:flex;align-items:center;gap:10px;font-size:12px;color:var(--slate);margin-bottom:12px}
  .article-cat{font-weight:700;color:var(--steel);text-transform:uppercase;letter-spacing:.05em}
  .feat-body h2{font-size:24px;margin-bottom:10px;line-height:1.2}
  .feat-body p{color:var(--slate);font-size:15px;margin-bottom:16px}
  .feat-body .read{font-weight:600;color:var(--steel)}
  @media(min-width:1025px){.feat-card{grid-template-columns:1.2fr 1fr}.feat-body h2{font-size:32px}}

  /* ARTICLE GRID */
  .articles{padding:32px 0 56px}
  .ar-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}
  .ar-head h3{font-size:22px}
  .ar-head .sort{font-size:13px;color:var(--slate)}
  .ar-head select{font-family:inherit;font-size:13px;color:var(--federal);background:#fff;border:1.5px solid var(--line);border-radius:8px;padding:7px 10px}
  .grid{display:grid;gap:24px}
  @media(min-width:700px){.grid{grid-template-columns:repeat(2,1fr)}}
  @media(min-width:1100px){.grid{grid-template-columns:repeat(3,1fr)}}
  .art-card{background:#fff;border:1px solid var(--line);border-radius:16px;overflow:hidden;transition:all .25s var(--ease);display:flex;flex-direction:column}
  .art-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}
  .art-img{aspect-ratio:16/10;background:linear-gradient(135deg,var(--tiffany-soft),#eef5f8);overflow:hidden}
  .art-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s var(--ease)}
  .art-card:hover .art-img img{transform:scale(1.05)}
  .art-
  .art-body h3{font-size:17px;margin-bottom:8px;line-height:1.25}
  .art-body p{font-size:13px;color:var(--slate);margin-bottom:14px;flex:1}
  .art-body .read{font-size:13px;font-weight:600;color:var(--steel)}

  /* CTA at end */
  .hub-cta{background:linear-gradient(135deg,var(--federal) 0%,var(--purple) 100%);color:#fff;border-radius:24px;padding:40px 32px;text-align:center;margin:32px 0}
  .hub-cta h3{color:#fff;font-size:24px;margin-bottom:8px}
  .hub-cta p{color:#cdd2ea;font-size:14px;margin-bottom:18px;max-width:46ch;margin-left:auto;margin-right:auto}

  /* footer */
  footer{background:var(--federal-deep);color:#aeb4d6;padding:48px 0 28px}
  footer .foot-grid{display:grid;gap:32px;margin-bottom:36px}
  @media(min-width:700px){footer .foot-grid{grid-template-columns:1.4fr 1fr 1fr 1fr}}
  footer .brand{max-width:340px}
  footer .brand img{height:54px;margin-bottom:14px}
  footer .brand p{font-size:13px;color:#8b91b8;line-height:1.6}
  footer h5{color:#fff;font-size:13px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;margin-bottom:14px}
  footer ul{list-style:none}
  footer li{margin-bottom:9px}
  footer li a{font-size:13px;color:#aeb4d6}
  footer li a:hover{color:var(--tiffany)}
  footer .foot-bottom{border-top:1px solid rgba(255,255,255,.08);padding-top:22px;display:flex;flex-direction:column;gap:14px;align-items:center;text-align:center}
  footer .pay-row{display:flex;gap:6px;flex-wrap:wrap;justify-content:center}
  footer .pay{background:rgba(255,255,255,.08);border-radius:6px;padding:5px 9px;font-size:11px;color:#cdd2ea;font-weight:600}
  footer .foot-bottom p{font-size:11px;color:#7a82a8;max-width:60ch}
  .partner-login{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:var(--tiffany);margin-top:14px;padding:7px 12px;border:1px solid rgba(126,214,208,.3);border-radius:8px}

  @media(prefers-reduced-motion:no-preference){
    .reveal{opacity:0;transform:translateY(16px);transition:opacity .5s var(--ease),transform .5s var(--ease)}
    .reveal.in{opacity:1;transform:none}
  }


/* === Clinic Finder PAGE-SPECIFIC CSS === */

  .finder{display:grid;gap:32px;padding:20px 0 64px}
  @media(min-width:1025px){.finder{grid-template-columns:1fr 1.3fr;gap:48px;align-items:start}}

  /* search side */
  .search-panel{background:#fff;border:1px solid var(--line);border-radius:18px;padding:24px;position:sticky;top:96px;z-index:5;align-self:start}
  @media(max-width:1024px){.search-panel{position:relative;top:0}}
  .search-panel h2{font-size:22px;margin-bottom:6px}
  .search-panel p{font-size:13px;color:var(--slate);margin-bottom:18px}
  .pc-row{display:flex;gap:8px;margin-bottom:14px}
  .pc-row input{flex:1;font-family:inherit;font-size:16px;color:var(--federal);background:#fff;border:1.5px solid var(--line);border-radius:10px;padding:13px 14px;text-transform:uppercase}
  .pc-row input:focus{outline:none;border-color:var(--federal)}
  .pc-row button{font-family:inherit;font-weight:600;font-size:14px;background:var(--federal);color:#fff;border:none;border-radius:10px;padding:13px 20px;cursor:pointer}
  .pc-row button:hover{background:#1b2070}
  .filter-block{padding-top:14px;border-top:1px solid var(--line);margin-top:14px}
  .filter-block h4{font-size:12px;text-transform:uppercase;letter-spacing:.06em;color:var(--steel);margin-bottom:10px}
  .check-list{display:grid;gap:8px}
  .check-list label{display:flex;align-items:center;gap:10px;font-size:14px;cursor:pointer}
  .check-list input{width:16px;height:16px;accent-color:var(--federal);cursor:pointer}
  .request-card{background:var(--tiffany-soft);border:1px solid #c0e9e5;border-radius:12px;padding:16px;margin-top:20px;font-size:13px;color:var(--ink);line-height:1.5}
  .request-card b{color:var(--federal)}
  .request-card a{color:var(--steel);text-decoration:underline;font-weight:600}

  /* results side */
  .results-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px;font-size:14px;color:var(--slate)}
  .results-head b{color:var(--federal)}
  .results-empty{background:var(--paper-warm);border:1px dashed var(--line);border-radius:14px;padding:36px 24px;text-align:center;color:var(--slate)}
  .clinic-card{background:#fff;border:1px solid var(--line);border-radius:14px;padding:20px;margin-bottom:12px;display:grid;gap:14px;align-items:start;transition:all .2s}
  .clinic-card:hover{border-color:var(--federal);box-shadow:var(--shadow-sm)}
  @media(min-width:600px){.clinic-card{grid-template-columns:48px 1fr auto;align-items:center}}
  .clinic-icon{width:48px;height:48px;border-radius:12px;background:var(--tiffany-soft);color:var(--federal);display:flex;align-items:center;justify-content:center;flex-shrink:0}
  .clinic-card h3{font-size:16px;margin-bottom:3px;line-height:1.2}
  .clinic-card .addr{font-size:13px;color:var(--slate);line-height:1.4;margin-bottom:6px}
  .clinic-card .meta{display:flex;gap:10px;flex-wrap:wrap;font-size:12px;color:var(--steel);font-weight:600}
  .clinic-card .meta span{display:inline-flex;align-items:center;gap:4px;background:var(--paper-warm);padding:3px 8px;border-radius:100px}
  .clinic-card .dist{font-size:14px;font-weight:700;color:var(--federal);white-space:nowrap}
  .clinic-card .dist small{font-size:11px;color:var(--slate);font-weight:500;display:block}
  .clinic-card .book{font-size:13px;font-weight:600;color:var(--steel);text-decoration:underline;white-space:nowrap}

  /* status banner */
  .status-banner{padding:14px 18px;border-radius:12px;margin-bottom:18px;display:flex;gap:10px;align-items:flex-start;font-size:14px;line-height:1.5}
  .status-banner.ok{background:var(--good-soft);color:var(--good);border:1px solid #b9e0ca}
  .status-banner.warn{background:#fdf6e9;color:#a06b15;border:1px solid #f0d693}
  .status-banner.no{background:#fce9e9;color:var(--danger);border:1px solid #f0bdbd}
  .status-banner svg{flex-shrink:0;margin-top:1px}
  .status-banner b{display:block;margin-bottom:2px}


/* === cart page CSS === */

  .m-drawer{position:fixed;inset:0;z-index:200;display:none}
  .m-drawer[hidden]{display:none!important}
  .m-drawer.open{display:block}
  .m-drawer-backdrop{position:absolute;inset:0;background:rgba(6,9,30,.55);backdrop-filter:blur(4px);animation:fadeIn .25s ease-out}
  .m-drawer-panel{position:absolute;top:0;right:0;bottom:0;width:min(360px,86vw);background:#fff;box-shadow:-12px 0 40px rgba(6,9,30,.3);display:flex;flex-direction:column;animation:slideIn .3s cubic-bezier(.2,.7,.3,1)}
  @keyframes fadeIn{from{opacity:0}to{opacity:1}}
  @keyframes slideIn{from{transform:translateX(100%)}to{transform:translateX(0)}}
  .m-drawer-head{padding:16px 20px;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between}
  .m-drawer-close{width:42px;height:42px;border:none;background:var(--paper-warm);border-radius:10px;cursor:pointer;color:var(--federal);display:flex;align-items:center;justify-content:center}
  .m-drawer-body{flex:1;overflow-y:auto;padding:20px}
  .m-cta{display:block;background:var(--tiffany);color:var(--federal);text-align:center;font-weight:700;padding:14px;border-radius:10px;margin-bottom:24px;font-size:15px}
  .m-section{margin-bottom:22px}
  .m-section-label{font-size:11px;font-weight:700;color:var(--steel);text-transform:uppercase;letter-spacing:.08em;margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid var(--line)}
  .m-section a{display:block;padding:11px 4px;font-size:15px;color:var(--ink);font-weight:500}
  .m-section a:hover{color:var(--federal)}
  .m-partner-login{display:inline-flex!important;align-items:center;gap:6px;color:var(--steel)!important;font-size:13px!important;margin-top:6px;padding:8px 12px!important;border:1px solid var(--line);border-radius:8px}
  body.drawer-open{overflow:hidden}


/* === how-it-works page CSS === */

  .steps-large{display:grid;gap:36px;max-width:920px;margin:0 auto}
  .step-row{display:grid;gap:24px;align-items:center}
  @media(min-width:900px){.step-row{grid-template-columns:1fr 1.3fr;gap:48px}.step-row.alt{grid-template-columns:1.3fr 1fr}.step-row.alt .step-visual{order:2}}
  .step-visual{aspect-ratio:4/3;background:linear-gradient(135deg,var(--tiffany-soft),var(--purple-soft));border-radius:18px;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}
  .step-visual svg{width:38%;color:var(--steel)}
  .step-num{position:absolute;top:18px;left:18px;width:42px;height:42px;border-radius:12px;background:#fff;color:var(--federal);font-weight:800;font-size:18px;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-sm)}
  .step-copy h3{font-size:24px;margin-bottom:10px}
  .step-copy p{font-size:15px;color:var(--slate);margin-bottom:14px;line-height:1.65}
  .step-copy .points{list-style:none;display:grid;gap:8px}
  .step-copy .points li{display:flex;align-items:flex-start;gap:9px;font-size:14px;color:var(--ink)}
  .step-copy .points svg{flex-shrink:0;color:var(--good);margin-top:3px}
  .important{background:var(--amber);color:var(--federal-deep);border-radius:12px;padding:14px 18px;margin-top:14px;display:flex;gap:10px;align-items:flex-start;font-size:13px;font-weight:600;line-height:1.5}
  .important svg{flex-shrink:0;margin-top:2px}

  .feature-grid{display:grid;gap:18px;max-width:920px;margin:32px auto 0}
  @media(min-width:700px){.feature-grid{grid-template-columns:repeat(3,1fr)}}
  .feature{background:#fff;border:1px solid var(--line);border-radius:14px;padding:22px;text-align:center}
  .feature .ic{width:48px;height:48px;border-radius:12px;background:var(--tiffany-soft);color:var(--federal);display:flex;align-items:center;justify-content:center;margin:0 auto 14px}
  .feature h4{font-size:16px;margin-bottom:6px}
  .feature p{font-size:13px;color:var(--slate)}

  .cta-band{background:linear-gradient(135deg,var(--federal),var(--purple));color:#fff;border-radius:24px;padding:48px 32px;text-align:center;max-width:920px;margin:48px auto 0}
  .cta-band h3{color:#fff;font-size:26px;margin-bottom:10px}
  .cta-band p{color:#cdd2ea;font-size:15px;margin-bottom:22px;max-width:46ch;margin-left:auto;margin-right:auto}


/* === stephen page CSS === */

  .m-drawer{position:fixed;inset:0;z-index:200;display:none}
  .m-drawer[hidden]{display:none!important}
  .m-drawer.open{display:block}
  .m-drawer-backdrop{position:absolute;inset:0;background:rgba(6,9,30,.55);backdrop-filter:blur(4px);animation:fadeIn .25s ease-out}
  .m-drawer-panel{position:absolute;top:0;right:0;bottom:0;width:min(360px,86vw);background:#fff;box-shadow:-12px 0 40px rgba(6,9,30,.3);display:flex;flex-direction:column;animation:slideIn .3s cubic-bezier(.2,.7,.3,1)}
  @keyframes fadeIn{from{opacity:0}to{opacity:1}}
  @keyframes slideIn{from{transform:translateX(100%)}to{transform:translateX(0)}}
  .m-drawer-head{padding:16px 20px;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between}
  .m-drawer-close{width:42px;height:42px;border:none;background:var(--paper-warm);border-radius:10px;cursor:pointer;color:var(--federal);display:flex;align-items:center;justify-content:center}
  .m-drawer-body{flex:1;overflow-y:auto;padding:20px}
  .m-cta{display:block;background:var(--tiffany);color:var(--federal);text-align:center;font-weight:700;padding:14px;border-radius:10px;margin-bottom:24px;font-size:15px}
  .m-section{margin-bottom:22px}
  .m-section-label{font-size:11px;font-weight:700;color:var(--steel);text-transform:uppercase;letter-spacing:.08em;margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid var(--line)}
  .m-section a{display:block;padding:11px 4px;font-size:15px;color:var(--ink);font-weight:500}
  .m-section a:hover{color:var(--federal)}
  .m-partner-login{display:inline-flex!important;align-items:center;gap:6px;color:var(--steel)!important;font-size:13px!important;margin-top:6px;padding:8px 12px!important;border:1px solid var(--line);border-radius:8px}
  body.drawer-open{overflow:hidden}


/* === partners page CSS === */

  .m-drawer{position:fixed;inset:0;z-index:200;display:none}
  .m-drawer[hidden]{display:none!important}
  .m-drawer.open{display:block}
  .m-drawer-backdrop{position:absolute;inset:0;background:rgba(6,9,30,.55);backdrop-filter:blur(4px);animation:fadeIn .25s ease-out}
  .m-drawer-panel{position:absolute;top:0;right:0;bottom:0;width:min(360px,86vw);background:#fff;box-shadow:-12px 0 40px rgba(6,9,30,.3);display:flex;flex-direction:column;animation:slideIn .3s cubic-bezier(.2,.7,.3,1)}
  @keyframes fadeIn{from{opacity:0}to{opacity:1}}
  @keyframes slideIn{from{transform:translateX(100%)}to{transform:translateX(0)}}
  .m-drawer-head{padding:16px 20px;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between}
  .m-drawer-close{width:42px;height:42px;border:none;background:var(--paper-warm);border-radius:10px;cursor:pointer;color:var(--federal);display:flex;align-items:center;justify-content:center}
  .m-drawer-body{flex:1;overflow-y:auto;padding:20px}
  .m-cta{display:block;background:var(--tiffany);color:var(--federal);text-align:center;font-weight:700;padding:14px;border-radius:10px;margin-bottom:24px;font-size:15px}
  .m-section{margin-bottom:22px}
  .m-section-label{font-size:11px;font-weight:700;color:var(--steel);text-transform:uppercase;letter-spacing:.08em;margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid var(--line)}
  .m-section a{display:block;padding:11px 4px;font-size:15px;color:var(--ink);font-weight:500}
  .m-section a:hover{color:var(--federal)}
  .m-partner-login{display:inline-flex!important;align-items:center;gap:6px;color:var(--steel)!important;font-size:13px!important;margin-top:6px;padding:8px 12px!important;border:1px solid var(--line);border-radius:8px}
  body.drawer-open{overflow:hidden}


/* === partner-landing page CSS === */

  .m-drawer{position:fixed;inset:0;z-index:200;display:none}
  .m-drawer[hidden]{display:none!important}
  .m-drawer.open{display:block}
  .m-drawer-backdrop{position:absolute;inset:0;background:rgba(6,9,30,.55);backdrop-filter:blur(4px);animation:fadeIn .25s ease-out}
  .m-drawer-panel{position:absolute;top:0;right:0;bottom:0;width:min(360px,86vw);background:#fff;box-shadow:-12px 0 40px rgba(6,9,30,.3);display:flex;flex-direction:column;animation:slideIn .3s cubic-bezier(.2,.7,.3,1)}
  @keyframes fadeIn{from{opacity:0}to{opacity:1}}
  @keyframes slideIn{from{transform:translateX(100%)}to{transform:translateX(0)}}
  .m-drawer-head{padding:16px 20px;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between}
  .m-drawer-close{width:42px;height:42px;border:none;background:var(--paper-warm);border-radius:10px;cursor:pointer;color:var(--federal);display:flex;align-items:center;justify-content:center}
  .m-drawer-body{flex:1;overflow-y:auto;padding:20px}
  .m-cta{display:block;background:var(--tiffany);color:var(--federal);text-align:center;font-weight:700;padding:14px;border-radius:10px;margin-bottom:24px;font-size:15px}
  .m-section{margin-bottom:22px}
  .m-section-label{font-size:11px;font-weight:700;color:var(--steel);text-transform:uppercase;letter-spacing:.08em;margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid var(--line)}
  .m-section a{display:block;padding:11px 4px;font-size:15px;color:var(--ink);font-weight:500}
  .m-section a:hover{color:var(--federal)}
  .m-partner-login{display:inline-flex!important;align-items:center;gap:6px;color:var(--steel)!important;font-size:13px!important;margin-top:6px;padding:8px 12px!important;border:1px solid var(--line);border-radius:8px}
  body.drawer-open{overflow:hidden}


/* === activate page CSS === */

  .m-drawer{position:fixed;inset:0;z-index:200;display:none}
  .m-drawer[hidden]{display:none!important}
  .m-drawer.open{display:block}
  .m-drawer-backdrop{position:absolute;inset:0;background:rgba(6,9,30,.55);backdrop-filter:blur(4px);animation:fadeIn .25s ease-out}
  .m-drawer-panel{position:absolute;top:0;right:0;bottom:0;width:min(360px,86vw);background:#fff;box-shadow:-12px 0 40px rgba(6,9,30,.3);display:flex;flex-direction:column;animation:slideIn .3s cubic-bezier(.2,.7,.3,1)}
  @keyframes fadeIn{from{opacity:0}to{opacity:1}}
  @keyframes slideIn{from{transform:translateX(100%)}to{transform:translateX(0)}}
  .m-drawer-head{padding:16px 20px;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between}
  .m-drawer-close{width:42px;height:42px;border:none;background:var(--paper-warm);border-radius:10px;cursor:pointer;color:var(--federal);display:flex;align-items:center;justify-content:center}
  .m-drawer-body{flex:1;overflow-y:auto;padding:20px}
  .m-cta{display:block;background:var(--tiffany);color:var(--federal);text-align:center;font-weight:700;padding:14px;border-radius:10px;margin-bottom:24px;font-size:15px}
  .m-section{margin-bottom:22px}
  .m-section-label{font-size:11px;font-weight:700;color:var(--steel);text-transform:uppercase;letter-spacing:.08em;margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid var(--line)}
  .m-section a{display:block;padding:11px 4px;font-size:15px;color:var(--ink);font-weight:500}
  .m-section a:hover{color:var(--federal)}
  .m-partner-login{display:inline-flex!important;align-items:center;gap:6px;color:var(--steel)!important;font-size:13px!important;margin-top:6px;padding:8px 12px!important;border:1px solid var(--line);border-radius:8px}
  body.drawer-open{overflow:hidden}


/* === quiz page CSS === */

  .quiz-shell{min-height:calc(100vh - 76px - 40px);display:flex;align-items:center;padding:48px 0;background:linear-gradient(180deg,#fff,var(--tiffany-soft) 80%)}
  .quiz-card{max-width:680px;margin:0 auto;background:#fff;border:1px solid var(--line);border-radius:24px;box-shadow:var(--shadow-md);padding:32px;width:100%}
  @media(min-width:700px){.quiz-card{padding:48px}}

  .progress-row{display:flex;align-items:center;gap:10px;margin-bottom:28px;font-size:13px;color:var(--slate)}
  .progress-bar{flex:1;height:6px;background:var(--line);border-radius:100px;overflow:hidden;position:relative}
  .progress-fill{height:100%;background:linear-gradient(90deg,var(--tiffany),var(--federal));border-radius:100px;width:0;transition:width .4s var(--ease)}
  .progress-row b{color:var(--federal);font-weight:700}

  .q-step{display:none}
  .q-step.active{display:block;animation:slideUp .3s var(--ease)}
  @keyframes slideUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}

  .q-title{font-size:24px;margin-bottom:6px;line-height:1.2}
  @media(min-width:700px){.q-title{font-size:28px}}
  .q-sub{color:var(--slate);font-size:15px;margin-bottom:24px}

  .q-options{display:grid;gap:10px;margin-bottom:24px}
  .q-opt{display:flex;align-items:center;gap:14px;padding:18px;background:#fff;border:1.5px solid var(--line);border-radius:14px;cursor:pointer;transition:all .2s;text-align:left;font-family:inherit;width:100%}
  .q-opt:hover{border-color:var(--steel);background:var(--paper-warm)}
  .q-opt.selected{border-color:var(--federal);background:var(--tiffany-soft)}
  .q-opt .ic{width:42px;height:42px;border-radius:11px;background:var(--tiffany-soft);color:var(--federal);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .2s}
  .q-opt.selected .ic{background:var(--federal);color:#fff}
  .q-opt .lbl{flex:1}
  .q-opt .lbl b{display:block;font-size:15px;color:var(--federal);font-weight:600;margin-bottom:2px}
  .q-opt .lbl span{font-size:13px;color:var(--slate);line-height:1.4}
  .q-opt .chk{width:22px;height:22px;border-radius:50%;border:2px solid var(--line);flex-shrink:0;position:relative;transition:all .2s}
  .q-opt.selected .chk{border-color:var(--federal);background:var(--federal)}
  .q-opt.selected .chk::after{content:"";position:absolute;inset:5px;border-radius:50%;background:#fff}

  .q-actions{display:flex;gap:10px;justify-content:space-between;align-items:center;margin-top:8px}
  .q-back{font-family:inherit;background:none;border:none;color:var(--slate);font-size:14px;cursor:pointer;font-weight:600;display:inline-flex;align-items:center;gap:5px}
  .q-back:hover{color:var(--federal)}
  .q-back:disabled{opacity:.4;cursor:not-allowed}

  /* RESULT SCREEN */
  .result-card{display:none}
  .result-card.show{display:block;animation:slideUp .4s var(--ease)}
  .result-eyebrow{display:inline-flex;align-items:center;gap:6px;background:var(--good-soft);color:var(--good);font-size:12px;font-weight:700;letter-spacing:.05em;padding:6px 12px;border-radius:100px;margin-bottom:14px;text-transform:uppercase}
  .result-heading{font-size:24px;margin-bottom:8px;line-height:1.2}
  .result-sub{color:var(--slate);font-size:15px;margin-bottom:24px}
  .recommended-kit{background:linear-gradient(135deg,var(--tiffany-soft),var(--purple-soft));border:1px solid var(--line);border-radius:18px;padding:24px;margin-bottom:18px;display:grid;gap:14px;align-items:center}
  @media(min-width:600px){.recommended-kit{grid-template-columns:96px 1fr auto}}
  .rk-img{width:96px;height:96px;border-radius:14px;background:#fff;overflow:hidden;display:flex;align-items:center;justify-content:center;border:1px solid rgba(255,255,255,.5)}
  .rk-img img{width:100%;height:100%;object-fit:cover}
  .rk-body h3{font-size:20px;margin-bottom:6px;line-height:1.2}
  .rk-body p{font-size:13px;color:var(--slate);margin-bottom:10px;line-height:1.5}
  .rk-meta{display:flex;gap:10px;font-size:12px;color:var(--steel);font-weight:600}
  .rk-meta span{background:#fff;padding:3px 9px;border-radius:6px;border:1px solid var(--line)}
  .rk-price{font-size:22px;font-weight:800;color:var(--federal);text-align:right;line-height:1.2}
  .rk-price small{display:block;font-size:11px;color:var(--slate);font-weight:500;text-transform:uppercase;letter-spacing:.05em}

  .alt-text{font-size:13px;color:var(--slate);text-align:center;margin-top:14px}
  .alt-text a{color:var(--steel);text-decoration:underline;font-weight:600}

  .restart{font-family:inherit;background:none;border:none;color:var(--slate);font-size:13px;cursor:pointer;font-weight:600;text-decoration:underline;margin-top:18px;display:block;margin-left:auto;margin-right:auto}


/* === about page CSS === */

  .doc-body{max-width:760px;margin:0 auto;padding:48px 0 64px}
  .doc-body h2{font-size:22px;margin:36px 0 12px;line-height:1.2}
  .doc-body h2:first-child{margin-top:0}
  .doc-body h3{font-size:17px;margin:24px 0 8px}
  .doc-body p{font-size:16px;color:var(--ink);margin-bottom:14px;line-height:1.7}
  .doc-body ul,.doc-body ol{margin:0 0 18px 22px}
  .doc-body li{font-size:16px;color:var(--ink);margin-bottom:8px;line-height:1.6}
  .doc-body strong{color:var(--federal);font-weight:700}
  .doc-body a{color:var(--steel);text-decoration:underline}
  .info-card{background:var(--tiffany-soft);border:1px solid #c0e9e5;border-radius:12px;padding:16px 20px;margin:18px 0;font-size:15px;line-height:1.55}
  .info-card b{color:var(--federal)}
  .important-card{background:#fdf6e9;border:1px solid #f0d693;border-radius:12px;padding:16px 20px;margin:18px 0;font-size:15px;line-height:1.55}
  .important-card b{color:#a06b15}
  .meta-row{font-size:13px;color:var(--slate);padding-bottom:18px;margin-bottom:26px;border-bottom:1px solid var(--line)}


/* === contact page CSS === */

  .doc-body{max-width:760px;margin:0 auto;padding:48px 0 64px}
  .doc-body h2{font-size:22px;margin:36px 0 12px;line-height:1.2}
  .doc-body h2:first-child{margin-top:0}
  .doc-body h3{font-size:17px;margin:24px 0 8px}
  .doc-body p{font-size:16px;color:var(--ink);margin-bottom:14px;line-height:1.7}
  .doc-body ul,.doc-body ol{margin:0 0 18px 22px}
  .doc-body li{font-size:16px;color:var(--ink);margin-bottom:8px;line-height:1.6}
  .doc-body strong{color:var(--federal);font-weight:700}
  .doc-body a{color:var(--steel);text-decoration:underline}
  .info-card{background:var(--tiffany-soft);border:1px solid #c0e9e5;border-radius:12px;padding:16px 20px;margin:18px 0;font-size:15px;line-height:1.55}
  .info-card b{color:var(--federal)}
  .important-card{background:#fdf6e9;border:1px solid #f0d693;border-radius:12px;padding:16px 20px;margin:18px 0;font-size:15px;line-height:1.55}
  .important-card b{color:#a06b15}
  .meta-row{font-size:13px;color:var(--slate);padding-bottom:18px;margin-bottom:26px;border-bottom:1px solid var(--line)}


/* === medical-disclaimer page CSS === */

  .doc-body{max-width:760px;margin:0 auto;padding:48px 0 64px}
  .doc-body h2{font-size:22px;margin:36px 0 12px;line-height:1.2}
  .doc-body h2:first-child{margin-top:0}
  .doc-body h3{font-size:17px;margin:24px 0 8px}
  .doc-body p{font-size:16px;color:var(--ink);margin-bottom:14px;line-height:1.7}
  .doc-body ul,.doc-body ol{margin:0 0 18px 22px}
  .doc-body li{font-size:16px;color:var(--ink);margin-bottom:8px;line-height:1.6}
  .doc-body strong{color:var(--federal);font-weight:700}
  .doc-body a{color:var(--steel);text-decoration:underline}
  .info-card{background:var(--tiffany-soft);border:1px solid #c0e9e5;border-radius:12px;padding:16px 20px;margin:18px 0;font-size:15px;line-height:1.55}
  .info-card b{color:var(--federal)}
  .important-card{background:#fdf6e9;border:1px solid #f0d693;border-radius:12px;padding:16px 20px;margin:18px 0;font-size:15px;line-height:1.55}
  .important-card b{color:#a06b15}
  .meta-row{font-size:13px;color:var(--slate);padding-bottom:18px;margin-bottom:26px;border-bottom:1px solid var(--line)}


/* === shipping page CSS === */

  .doc-body{max-width:760px;margin:0 auto;padding:48px 0 64px}
  .doc-body h2{font-size:22px;margin:36px 0 12px;line-height:1.2}
  .doc-body h2:first-child{margin-top:0}
  .doc-body h3{font-size:17px;margin:24px 0 8px}
  .doc-body p{font-size:16px;color:var(--ink);margin-bottom:14px;line-height:1.7}
  .doc-body ul,.doc-body ol{margin:0 0 18px 22px}
  .doc-body li{font-size:16px;color:var(--ink);margin-bottom:8px;line-height:1.6}
  .doc-body strong{color:var(--federal);font-weight:700}
  .doc-body a{color:var(--steel);text-decoration:underline}
  .info-card{background:var(--tiffany-soft);border:1px solid #c0e9e5;border-radius:12px;padding:16px 20px;margin:18px 0;font-size:15px;line-height:1.55}
  .info-card b{color:var(--federal)}
  .important-card{background:#fdf6e9;border:1px solid #f0d693;border-radius:12px;padding:16px 20px;margin:18px 0;font-size:15px;line-height:1.55}
  .important-card b{color:#a06b15}
  .meta-row{font-size:13px;color:var(--slate);padding-bottom:18px;margin-bottom:26px;border-bottom:1px solid var(--line)}


/* === privacy page CSS === */

  .doc-body{max-width:760px;margin:0 auto;padding:48px 0 64px}
  .doc-body h2{font-size:22px;margin:36px 0 12px;line-height:1.2}
  .doc-body h2:first-child{margin-top:0}
  .doc-body h3{font-size:17px;margin:24px 0 8px}
  .doc-body p{font-size:16px;color:var(--ink);margin-bottom:14px;line-height:1.7}
  .doc-body ul,.doc-body ol{margin:0 0 18px 22px}
  .doc-body li{font-size:16px;color:var(--ink);margin-bottom:8px;line-height:1.6}
  .doc-body strong{color:var(--federal);font-weight:700}
  .doc-body a{color:var(--steel);text-decoration:underline}
  .info-card{background:var(--tiffany-soft);border:1px solid #c0e9e5;border-radius:12px;padding:16px 20px;margin:18px 0;font-size:15px;line-height:1.55}
  .info-card b{color:var(--federal)}
  .important-card{background:#fdf6e9;border:1px solid #f0d693;border-radius:12px;padding:16px 20px;margin:18px 0;font-size:15px;line-height:1.55}
  .important-card b{color:#a06b15}
  .meta-row{font-size:13px;color:var(--slate);padding-bottom:18px;margin-bottom:26px;border-bottom:1px solid var(--line)}


/* === PAGE-SPECIFIC CSS (dedup append) === */

/* --- from cart mockup --- */
.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--shadow-md);background:#92ddd8}
.btn-primary:disabled{opacity:.55;cursor:not-allowed}
.nav-back{font-size:14px;font-weight:600;color:var(--steel);display:inline-flex;align-items:center;gap:7px}
.nav-back:hover{color:var(--federal)}
.page{padding:32px 0 64px}
.page h1{font-size:30px;margin-bottom:8px}
.page .sub{color:var(--slate);font-size:15px;margin-bottom:28px}
.layout{display:grid;gap:24px}
.items{background:#fff;border:1px solid var(--line);border-radius:16px;padding:8px 20px}
.item{display:grid;grid-template-columns:80px 1fr auto;gap:16px;padding:20px 0;border-bottom:1px solid var(--line);align-items:center}
.item:last-child{border-bottom:none}
.item-img{aspect-ratio:1;border-radius:10px;background:linear-gradient(135deg,var(--tiffany-soft),#eef5f8);overflow:hidden}
.item-img img{width:100%;height:100%;object-fit:cover}
.item-title{font-size:15px;font-weight:700;color:var(--federal);margin-bottom:4px;line-height:1.2}
.item-meta{font-size:12px;color:var(--slate);line-height:1.4}
.item-meta span{display:inline-block;background:var(--paper-warm);border:1px solid var(--line);padding:2px 8px;border-radius:6px;margin-right:4px;margin-top:3px;font-weight:500;color:var(--steel)}
.item-meta a{color:var(--steel);text-decoration:underline;font-weight:600;font-size:11px}
.item-right{text-align:right}
.item-price{font-size:17px;font-weight:800;color:var(--federal);margin-bottom:8px;display:block}
.qty{display:inline-flex;align-items:center;border:1px solid var(--line);border-radius:8px;overflow:hidden}
.qty button{width:30px;height:30px;background:#fff;border:none;color:var(--federal);font-size:16px;cursor:pointer}
.qty button:hover{background:var(--paper-warm)}
.qty span{width:32px;text-align:center;font-weight:600;font-size:14px;color:var(--federal)}
.item-remove{display:block;font-size:11px;color:var(--slate);background:none;border:none;cursor:pointer;margin-top:5px;text-decoration:underline}
.item-remove:hover{color:var(--danger)}
.side{display:grid;gap:20px;position:sticky;top:96px}
.panel{background:#fff;border:1px solid var(--line);border-radius:16px;padding:22px}
.panel h3{font-size:17px;margin-bottom:6px}
.panel .panel-sub{font-size:13px;color:var(--slate);margin-bottom:18px}
.why{background:var(--tiffany-soft);border:1px solid #c0e9e5;color:var(--federal);font-size:12px;border-radius:10px;padding:10px 12px;margin-bottom:18px;display:flex;gap:8px;align-items:flex-start}
.why svg{flex-shrink:0;color:var(--steel);margin-top:1px}
.field input:invalid:not(:placeholder-shown){border-color:var(--danger)}
.sex-pill svg{color:var(--steel)}
.sex-pill.active svg{color:var(--federal)}
.sum-row{display:flex;justify-content:space-between;font-size:14px;color:var(--slate);margin-bottom:10px}
.sum-row.total{font-size:17px;font-weight:800;color:var(--federal);padding-top:14px;margin-top:6px;border-top:1px solid var(--line)}
.sum-row .free{color:var(--good);font-weight:600}
.discount{display:flex;gap:8px;margin-bottom:14px;padding-bottom:14px;border-bottom:1px solid var(--line)}
.discount input{flex:1;font-family:inherit;font-size:14px;border:1.5px solid var(--line);border-radius:8px;padding:10px 12px}
.discount button{font-family:inherit;font-weight:600;font-size:13px;background:#fff;color:var(--steel);border:1.5px solid var(--line);border-radius:8px;padding:10px 14px;cursor:pointer}
.discount button:hover{border-color:var(--federal);color:var(--federal)}
.dev-note{font-size:11px;color:#a8adc1;font-style:italic;text-align:center;margin-top:10px;padding:8px;background:var(--paper-warm);border-radius:6px;border:1px dashed var(--line)}
.empty{text-align:center;padding:60px 20px;background:#fff;border:1px solid var(--line);border-radius:16px}
.empty svg{color:var(--slate);margin-bottom:14px;opacity:.5}
.empty h2{font-size:22px;margin-bottom:8px}
.empty p{color:var(--slate);font-size:14px;margin-bottom:20px}

/* --- from portal-tour mockup --- */
.tour-hero{background:linear-gradient(135deg,var(--federal-deep) 0%,var(--purple) 100%);color:#fff;padding:56px 0 80px;position:relative;overflow:hidden}
.tour-hero::before{content:"";position:absolute;top:-200px;right:-150px;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(126,214,208,.18),transparent 70%);pointer-events:none}
.tour-hero .crumb{font-size:13px;color:#cdd2ea;margin-bottom:18px;position:relative}
.tour-hero .crumb a{color:#cdd2ea}
.tour-hero .crumb .sep{margin:0 8px;color:rgba(255,255,255,.3)}
.tour-hero .crumb .curr{color:#fff;font-weight:600}
.tour-eyebrow{display:inline-flex;align-items:center;gap:7px;background:rgba(126,214,208,.13);border:1px solid rgba(126,214,208,.4);color:var(--tiffany);font-size:12px;font-weight:700;letter-spacing:.08em;padding:7px 14px;border-radius:100px;margin-bottom:18px;text-transform:uppercase;position:relative}
.tour-eyebrow .dot{width:6px;height:6px;border-radius:50%;background:var(--tiffany);box-shadow:0 0 0 4px rgba(126,214,208,.2)}
.tour-hero h1{color:#fff;font-size:38px;line-height:1.05;letter-spacing:-0.03em;margin-bottom:14px;max-width:740px;position:relative}
.tour-hero h1 .accent{color:var(--tiffany)}
.tour-hero p.lead{color:#cdd2ea;font-size:17px;line-height:1.55;max-width:54ch;margin-bottom:24px;position:relative}
.tour-hero .cta-row{display:flex;flex-wrap:wrap;gap:10px;position:relative}
.phone::before{content:"";position:absolute;top:18px;left:50%;transform:translateX(-50%);width:88px;height:24px;background:#000;border-radius:14px;z-index:3}
.step-section{padding:64px 0;background:#fff;border-bottom:1px solid var(--line)}
.step-section:nth-child(even){background:var(--paper-warm)}
.step-grid{display:grid;gap:36px;align-items:center;max-width:1080px;margin:0 auto}
.step-grid.reverse .phone-col{order:-1}
.step-section h2{font-size:30px;margin-bottom:14px;line-height:1.15;letter-spacing:-0.02em}
.step-section .copy-col p{font-size:16px;color:var(--slate);line-height:1.65;margin-bottom:14px}
.step-section .copy-col p strong{color:var(--federal)}
.feat-list{list-style:none;margin:18px 0 0;display:grid;gap:10px}
.feat-list li{display:flex;align-items:flex-start;gap:10px;font-size:14px;color:var(--ink);line-height:1.55}
.feat-list li svg{flex-shrink:0;color:var(--good);margin-top:3px}
.step-callout{background:var(--tiffany-soft);border:1px solid #c0e9e5;border-left:4px solid var(--tiffany);border-radius:10px;padding:16px 20px;margin:20px 0 0;font-size:14px;line-height:1.55;color:var(--ink)}
.step-callout b{color:var(--steel);font-size:12px;text-transform:uppercase;letter-spacing:.05em;display:flex;align-items:center;gap:6px;margin-bottom:6px;font-weight:700}
.step-callout.purple{background:var(--purple-soft);border-color:#e2cfee;border-left-color:var(--purple)}
.step-callout.purple b{color:var(--purple)}
.phone-col{position:relative;display:flex;justify-content:center;padding:24px 0}
.float-card{position:absolute;background:#fff;border-radius:14px;padding:14px 16px;box-shadow:var(--shadow-lg);font-size:13px;display:flex;align-items:center;gap:10px;z-index:2;max-width:240px}
.float-card .fic{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.float-card .fic.good{background:var(--tiffany-soft);color:var(--good)}
.float-card .fic.alert{background:#fdf6e9;color:var(--amber)}
.float-card .fic.brain{background:var(--purple-soft);color:var(--purple)}
.float-card b{display:block;color:var(--federal);font-size:13px;font-weight:700;margin-bottom:2px}
.float-card span{color:var(--slate);font-size:11px}
.features-section{background:var(--federal-deep);color:#fff;padding:72px 0;position:relative;overflow:hidden}
.features-section::before{content:"";position:absolute;top:-150px;left:-100px;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(126,214,208,.15),transparent 70%);pointer-events:none}
.features-section .sec-head{text-align:center;max-width:680px;margin:0 auto 44px;position:relative}
.features-section .sec-head .kick{font-size:13px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--tiffany);display:block;margin-bottom:10px}
.features-section .sec-head h2{color:#fff;font-size:34px;line-height:1.1;margin-bottom:10px}
.features-section .sec-head p{color:#cdd2ea;font-size:16px}
.feat-grid{display:grid;gap:20px;position:relative}
.feat-card .ic{width:48px;height:48px;border-radius:12px;background:rgba(126,214,208,.15);color:var(--tiffany);display:flex;align-items:center;justify-content:center;margin-bottom:14px}
.feat-card h3{color:#fff;font-size:17px;margin-bottom:8px}
.feat-card p{color:#cdd2ea;font-size:14px;line-height:1.55}
.tour-cta{padding:72px 0;background:linear-gradient(180deg,#fff,var(--tiffany-soft))}
.tour-cta .cta-card{max-width:760px;margin:0 auto;background:#fff;border:1px solid var(--line);border-radius:24px;padding:48px 32px;text-align:center;box-shadow:var(--shadow-lg);position:relative;overflow:hidden}
.tour-cta .cta-card::before{content:"";position:absolute;top:-150px;left:50%;transform:translateX(-50%);width:400px;height:400px;border-radius:50%;background:radial-gradient(circle,rgba(126,214,208,.25),transparent 70%);pointer-events:none}
.tour-cta h2{font-size:30px;margin-bottom:10px;position:relative}
.tour-cta p{color:var(--slate);font-size:16px;margin-bottom:24px;max-width:48ch;margin-left:auto;margin-right:auto;position:relative}
.tour-cta .cta-row{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;position:relative}

/* --- from stephen mockup --- */
.magazine-hero{background:var(--federal-deep);color:#fff;position:relative;overflow:hidden}
.magazine-hero::before{content:"";position:absolute;top:-200px;right:-100px;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(79,26,109,.4),transparent 70%);pointer-events:none}
.mh-grid{display:grid;gap:0;position:relative}
.mh-photo{aspect-ratio:1/1;background:#000;overflow:hidden;position:relative}
.mh-photo img{width:100%;height:100%;object-fit:cover}
.mh-photo::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 0%,transparent 70%,rgba(6,9,30,.7) 100%);pointer-events:none}
.mh-copy{padding:36px 22px;display:flex;flex-direction:column;justify-content:center;position:relative}
.mh-label{display:inline-flex;align-items:center;gap:7px;background:rgba(126,214,208,.13);border:1px solid rgba(126,214,208,.4);color:var(--tiffany);font-size:11px;font-weight:700;letter-spacing:.1em;padding:7px 14px;border-radius:100px;margin-bottom:20px;width:max-content;text-transform:uppercase}
.mh-label .dot{width:6px;height:6px;border-radius:50%;background:var(--tiffany);box-shadow:0 0 0 4px rgba(126,214,208,.2)}
.magazine-hero h1{color:#fff;font-size:40px;line-height:1.02;letter-spacing:-0.03em;margin-bottom:12px}
.magazine-hero .subtitle{font-size:13px;color:var(--tiffany);font-weight:600;text-transform:uppercase;letter-spacing:.15em;margin-bottom:20px}
.magazine-hero .lede{font-size:18px;color:#cdd2ea;line-height:1.55;margin-bottom:28px;max-width:42ch}
.mh-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;padding-top:24px;border-top:1px solid rgba(255,255,255,.08)}
.mh-stat b{display:block;font-size:30px;color:#fff;font-weight:800;line-height:1;letter-spacing:-0.03em;margin-bottom:4px}
.mh-stat span{font-size:11px;color:#9ea4cc;text-transform:uppercase;letter-spacing:.07em;line-height:1.3;display:block}
.hero-video{margin:32px auto 0;max-width:920px;padding:0 22px;position:relative;z-index:2}
.video-frame{position:relative;background:#000;border-radius:18px;overflow:hidden;box-shadow:var(--shadow-lg);aspect-ratio:16/9}
.video-frame video{width:100%;height:100%;object-fit:cover;display:block}
.play-overlay{position:absolute;inset:0;background:linear-gradient(180deg,transparent 0%,rgba(0,0,0,.4) 100%);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:opacity .25s var(--ease)}
.video-frame.playing .play-overlay{opacity:0;pointer-events:none}
.play-btn{width:80px;height:80px;border-radius:50%;background:rgba(255,255,255,.95);display:flex;align-items:center;justify-content:center;color:var(--federal);transition:all .2s;box-shadow:0 8px 30px rgba(0,0,0,.3);border:none;cursor:pointer}
.play-btn:hover{transform:scale(1.08);background:#fff}
.video-caption{position:absolute;bottom:18px;left:18px;right:18px;display:flex;align-items:center;gap:10px;transition:opacity .25s}
.video-frame.playing .video-caption{opacity:0;pointer-events:none}
.video-caption .tag{font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;background:rgba(126,214,208,.95);color:var(--federal);padding:5px 10px;border-radius:100px}
.video-caption .ttl{font-size:14px;font-weight:600;color:#fff;text-shadow:0 1px 4px rgba(0,0,0,.7)}
.story{max-width:720px;margin:0 auto}
.story p{font-size:18px;color:var(--ink);margin-bottom:20px;line-height:1.7}
.story p:first-child::first-letter{font-size:64px;font-weight:800;color:var(--federal);float:left;line-height:.85;margin:8px 12px 0 0;letter-spacing:-0.04em}
.pull-quote{font-size:24px;font-weight:600;color:var(--federal);border-left:4px solid var(--tiffany);padding:8px 0 8px 24px;margin:36px 0;line-height:1.35;font-style:italic}
.photo-strip{display:grid;gap:14px;margin:48px 0}
.ps-main{aspect-ratio:4/3;background:#000;overflow:hidden;border-radius:14px}
.ps-main img{width:100%;height:100%;object-fit:cover}
.ps-side{display:grid;gap:14px}
.ps-side > div{aspect-ratio:4/3;background:#000;overflow:hidden;border-radius:14px}
.ps-side img{width:100%;height:100%;object-fit:cover}
.reel{display:grid;gap:18px;max-width:1080px;margin:0 auto}
.reel-row{display:grid;gap:18px}
.reel-row.two{grid-template-columns:1fr}
.his-kits{display:grid;gap:20px;margin-top:32px}
.kit-card{background:#fff;border:1.5px solid var(--purple);border-radius:18px;overflow:hidden;transition:all .25s var(--ease);position:relative}
.kit-card::before{content:"";position:absolute;top:0;left:0;right:0;height:5px;background:linear-gradient(90deg,var(--purple),var(--tiffany));z-index:1}
.kit-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.kit-body h3{font-size:20px;margin-bottom:8px}
.kit-body .why{background:var(--purple-soft);border:1px solid #e2cfee;border-radius:10px;padding:12px 14px;margin:12px 0 16px}
.kit-body .why b{color:var(--purple);font-size:12px;font-weight:700;display:flex;align-items:center;gap:6px;margin-bottom:4px;text-transform:uppercase;letter-spacing:.05em}
.kit-body .why p{font-size:13px;color:var(--ink);line-height:1.5;font-style:italic}
.kit-specs .spec b{display:block;font-size:18px;color:var(--federal);font-weight:800}
.kit-specs .spec span{font-size:11px;color:var(--slate);text-transform:uppercase;letter-spacing:.05em}
.partner-spot{background:#fff;border:1px solid var(--line);border-radius:18px;overflow:hidden;display:grid;gap:0;align-items:stretch}
.partner-spot-photo{aspect-ratio:4/5;background:#000;overflow:hidden}
.partner-spot-photo img{width:100%;height:100%;object-fit:cover;object-position:center}
.partner-spot-body{padding:28px}
.partner-spot-body .kick{font-size:12px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--tiffany);margin-bottom:10px;display:block}
.partner-spot-body h3{font-size:22px;margin-bottom:10px;line-height:1.2}
.partner-spot-body p{font-size:15px;color:var(--slate);margin-bottom:18px;line-height:1.6}
.disclosure{background:var(--paper-warm);border:1px dashed var(--line);border-radius:12px;padding:18px 22px;font-size:13px;color:var(--slate);max-width:760px;margin:48px auto 0;line-height:1.55}
.disclosure b{color:var(--federal);font-weight:700}

/* --- from partners mockup --- */
.ph-hero{background:linear-gradient(135deg,var(--federal) 0%,var(--purple) 100%);color:#fff;padding:64px 0 80px;position:relative;overflow:hidden}
.ph-hero::before{content:"";position:absolute;top:-200px;right:-100px;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(126,214,208,.18),transparent 70%);pointer-events:none}
.ph-hero .wrap{position:relative}
.ph-hero .grid{display:grid;gap:36px;align-items:center}
.ph-hero .eyebrow{display:inline-flex;align-items:center;gap:6px;background:rgba(126,214,208,.15);border:1px solid rgba(126,214,208,.4);color:var(--tiffany);font-size:12px;font-weight:700;letter-spacing:.05em;padding:7px 13px;border-radius:100px;margin-bottom:18px}
.ph-hero h1{color:#fff;font-size:36px;margin-bottom:12px;line-height:1.05}
.ph-hero p{color:#cdd2ea;font-size:17px;margin-bottom:24px;max-width:50ch;line-height:1.5}
.ph-hero .cta-row{display:flex;flex-wrap:wrap;gap:10px}
.hero-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.hs{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.10);border-radius:14px;padding:18px}
.hs b{display:block;font-size:28px;color:#fff;font-weight:800;line-height:1;margin-bottom:5px;letter-spacing:-0.02em}
.hs span{font-size:12px;color:#9ea4cc}
.ptypes{display:grid;gap:18px}
.ptype{background:#fff;border:1px solid var(--line);border-radius:18px;padding:26px;text-align:center;transition:all .25s var(--ease)}
.ptype:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--tiffany)}
.ptype .ic{width:56px;height:56px;border-radius:14px;background:var(--tiffany-soft);color:var(--federal);display:flex;align-items:center;justify-content:center;margin:0 auto 16px}
.ptype h3{font-size:18px;margin-bottom:8px}
.ptype p{font-size:13px;color:var(--slate);line-height:1.5}
.bens{display:grid;gap:18px}
.ben{background:#fff;border:1px solid var(--line);border-radius:16px;padding:24px}
.ben .ic{width:44px;height:44px;border-radius:12px;background:linear-gradient(135deg,var(--tiffany-soft),var(--purple-soft));color:var(--federal);display:flex;align-items:center;justify-content:center;margin-bottom:14px}
.ben h4{font-size:17px;margin-bottom:8px}
.ben p{font-size:14px;color:var(--slate);line-height:1.55}
.comm{display:inline-flex;align-items:center;gap:7px;background:var(--good);color:#fff;font-size:11px;font-weight:700;padding:4px 10px;border-radius:100px;letter-spacing:.04em;text-transform:uppercase;margin-bottom:6px}
.form-section{background:linear-gradient(180deg,var(--paper-warm),#fff);padding:64px 0}
.form-wrap{max-width:640px;margin:0 auto;background:#fff;border:1px solid var(--line);border-radius:20px;padding:32px;box-shadow:var(--shadow-md)}
.form-wrap h2{font-size:26px;margin-bottom:8px;text-align:center}
.form-wrap > p{color:var(--slate);font-size:14px;text-align:center;margin-bottom:24px}
.field textarea{min-height:80px;resize:vertical;font-family:inherit}
.ep-banner{background:var(--federal);color:#fff;border-radius:18px;padding:28px 32px;display:grid;gap:18px;align-items:center;margin-top:32px}
.ep-banner h3{color:#fff;font-size:20px;margin-bottom:4px}
.ep-banner p{color:#cdd2ea;font-size:14px}

/* --- from activate mockup --- */
.help-link{font-size:14px;font-weight:600;color:var(--steel)}
.step-dots{display:inline-flex;gap:6px;margin-bottom:18px;font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--steel);background:#fff;padding:7px 14px;border-radius:100px;border:1px solid var(--line)}
.step-dots .dot{width:7px;height:7px;border-radius:50%;background:var(--tiffany)}
.hero p{color:var(--slate);font-size:15px;max-width:50ch;margin:0 auto 12px;position:relative}
.panel h2{font-size:20px;margin-bottom:6px}
.panel .sub{color:var(--slate);font-size:14px;margin-bottom:20px}
.field input.kit-code{font-family:'Courier New',monospace;letter-spacing:.15em;text-transform:uppercase;font-weight:700;text-align:center;font-size:18px}
.checkbox-row{display:flex;align-items:flex-start;gap:10px;margin-bottom:16px;padding:12px;background:var(--paper-warm);border-radius:10px;cursor:pointer}
.checkbox-row input{width:18px;height:18px;accent-color:var(--federal);margin-top:2px;cursor:pointer;flex-shrink:0}
.checkbox-row label{font-size:13px;color:var(--slate);line-height:1.45;cursor:pointer}
.checkbox-row label b{color:var(--federal)}
.req{color:var(--danger);margin-left:2px}
.step .num{flex-shrink:0;width:36px;height:36px;border-radius:10px;background:var(--tiffany-soft);color:var(--federal);font-weight:800;display:flex;align-items:center;justify-content:center;font-size:16px}
.step h4{font-size:15px;margin-bottom:3px}
.success{display:none;text-align:center;background:#fff;border:1px solid var(--line);border-radius:16px;padding:40px 24px}
.success.show{display:block}
.success-ring{width:80px;height:80px;border-radius:50%;background:var(--good);color:#fff;display:flex;align-items:center;justify-content:center;margin:0 auto 18px}
.success h2{font-size:24px;margin-bottom:10px}
.success p{color:var(--slate);font-size:15px;margin-bottom:24px;max-width:46ch;margin-left:auto;margin-right:auto}
.success .ref{display:inline-block;font-family:'Courier New',monospace;background:var(--paper-warm);border:1px dashed var(--line);padding:8px 14px;border-radius:8px;font-size:13px;font-weight:700;color:var(--federal);letter-spacing:.1em;margin-bottom:24px}

/* --- from faqs mockup --- */
.faq-hero{background:linear-gradient(180deg,#fff,var(--tiffany-soft));padding:48px 0 36px;position:relative;overflow:hidden;text-align:center}
.faq-hero::before{content:"";position:absolute;top:-150px;left:50%;transform:translateX(-50%);width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(126,214,208,.22),transparent 70%);pointer-events:none}
.faq-hero h1{font-size:34px;line-height:1.1;margin-bottom:10px;position:relative}
.faq-hero p.lead{color:var(--slate);font-size:16px;max-width:54ch;margin:0 auto 28px;position:relative}
.faq-search{position:relative;max-width:560px;margin:0 auto}
.faq-search input{width:100%;font-family:inherit;font-size:16px;color:var(--federal);background:#fff;border:1.5px solid var(--line);border-radius:14px;padding:18px 22px 18px 56px;box-shadow:var(--shadow-md)}
.faq-search input:focus{outline:none;border-color:var(--federal)}
.faq-search .search-ic{position:absolute;left:20px;top:50%;transform:translateY(-50%);color:var(--slate)}
.faq-search .clear-search{position:absolute;right:14px;top:50%;transform:translateY(-50%);color:var(--slate);background:var(--paper-warm);border:none;border-radius:50%;width:28px;height:28px;cursor:pointer;display:none;align-items:center;justify-content:center;font-size:14px}
.faq-search .clear-search.show{display:flex}
.cat-tiles-section{padding:40px 0;background:#fff}
.section-label{font-size:13px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--steel);margin-bottom:14px;text-align:center}
.cat-tiles{display:grid;gap:14px;grid-template-columns:1fr 1fr}
.cat-tile{background:#fff;border:1.5px solid var(--line);border-radius:18px;padding:24px 18px;text-align:center;cursor:pointer;transition:all .25s var(--ease);position:relative;text-decoration:none}
.cat-tile:hover{border-color:var(--tiffany);transform:translateY(-3px);box-shadow:var(--shadow-md)}
.cat-tile.active{border-color:var(--federal);background:var(--tiffany-soft);box-shadow:var(--shadow-md)}
.cat-tile .ic{width:48px;height:48px;border-radius:12px;background:var(--tiffany-soft);color:var(--federal);display:flex;align-items:center;justify-content:center;margin:0 auto 12px;transition:all .2s}
.cat-tile.active .ic{background:var(--federal);color:var(--tiffany)}
.cat-tile h3{font-size:15px;font-weight:700;color:var(--federal);margin-bottom:4px;line-height:1.2}
.cat-tile .ct{font-size:12px;color:var(--slate);font-weight:500}
.faq-body{padding:32px 0 64px;background:var(--paper-warm)}
.faq-section{margin-bottom:32px}
.faq-section-head{display:flex;align-items:center;gap:12px;margin-bottom:16px;padding-bottom:14px;border-bottom:2px solid var(--tiffany)}
.faq-section-head .ic{width:36px;height:36px;border-radius:10px;background:var(--federal);color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.faq-section-head h2{font-size:20px;line-height:1.2}
.faq-section-head .ct{margin-left:auto;font-size:12px;color:var(--slate);background:#fff;padding:4px 10px;border-radius:100px;border:1px solid var(--line);font-weight:600}
.acc-list{max-width:760px}
.acc:hover{box-shadow:var(--shadow-sm)}
.acc-body p{margin-bottom:10px}
.acc-body p:last-child{margin-bottom:0}
.acc-body strong{color:var(--federal)}
.acc-body a{color:var(--steel);text-decoration:underline;font-weight:600}
.acc.hidden{display:none}
.faq-section.empty{display:none}
.no-results{display:none;text-align:center;padding:60px 20px;background:#fff;border:1px solid var(--line);border-radius:14px}
.no-results.show{display:block}
.no-results svg{color:var(--slate);opacity:.4;margin-bottom:14px}
.no-results h3{font-size:18px;margin-bottom:6px}
.no-results p{font-size:14px;color:var(--slate)}
.help-cta{background:linear-gradient(135deg,var(--federal),var(--purple));color:#fff;border-radius:24px;padding:40px 32px;text-align:center;max-width:760px;margin:36px auto 0;position:relative;overflow:hidden}
.help-cta::before{content:"";position:absolute;top:-100px;right:-50px;width:300px;height:300px;border-radius:50%;background:radial-gradient(circle,rgba(126,214,208,.22),transparent 70%);pointer-events:none}
.help-cta h3{color:#fff;font-size:22px;margin-bottom:8px;position:relative}
.help-cta p{color:#cdd2ea;font-size:14px;margin-bottom:20px;max-width:46ch;margin-left:auto;margin-right:auto;position:relative}

/* --- from sampling-guide mockup --- */
.guide-hero{background:linear-gradient(180deg,#fff,var(--tiffany-soft));padding:48px 0 36px;position:relative;overflow:hidden}
.guide-hero::before{content:"";position:absolute;top:-150px;right:-100px;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(126,214,208,.22),transparent 70%);pointer-events:none}
.guide-eyebrow{display:inline-flex;align-items:center;gap:6px;background:#fff;border:1px solid var(--line);color:var(--federal);font-size:12px;font-weight:700;letter-spacing:.05em;padding:7px 13px;border-radius:100px;margin-bottom:18px;text-transform:uppercase;position:relative}
.guide-hero h1{font-size:34px;line-height:1.1;margin-bottom:14px;max-width:680px;position:relative}
.guide-hero p.lead{color:var(--slate);font-size:16px;max-width:60ch;margin-bottom:22px;position:relative}
.reading-time{display:inline-flex;align-items:center;gap:6px;font-size:13px;color:var(--slate);font-weight:500;position:relative}
.reading-time svg{color:var(--steel)}
.what-needed{padding:48px 0;background:#fff}
.checklist{max-width:760px;margin:0 auto;background:var(--paper-warm);border:1px solid var(--line);border-radius:16px;padding:24px}
.checklist h3{font-size:17px;margin-bottom:16px}
.check-grid{display:grid;gap:10px}
.check-item svg{flex-shrink:0;color:var(--good)}
.check-item.amber svg{color:var(--amber)}
.steps-section{padding:48px 0 64px;background:var(--paper-warm)}
.step-stack{max-width:860px;margin:0 auto;display:grid;gap:24px}
.step-card{background:#fff;border:1px solid var(--line);border-radius:18px;overflow:hidden;transition:box-shadow .25s var(--ease)}
.step-card:hover{box-shadow:var(--shadow-md)}
.step-time{display:inline-block;font-size:11px;font-weight:700;color:var(--steel);background:var(--tiffany-soft);padding:4px 10px;border-radius:100px;margin-bottom:10px;text-transform:uppercase;letter-spacing:.05em}
.step-body h3{font-size:20px;margin-bottom:10px;line-height:1.2}
.step-body p{font-size:15px;color:var(--slate);line-height:1.6;margin-bottom:12px}
.step-body p strong{color:var(--federal)}
.step-body ul{list-style:none;margin-top:12px;display:grid;gap:8px}
.step-body ul li{display:flex;align-items:flex-start;gap:9px;font-size:14px;color:var(--ink);line-height:1.55}
.step-body ul li svg{flex-shrink:0;color:var(--good);margin-top:3px}
.step-tip{background:var(--tiffany-soft);border-left:3px solid var(--tiffany);border-radius:8px;padding:12px 14px;margin-top:14px;font-size:13px;color:var(--ink);line-height:1.55}
.step-tip b{color:var(--steel);display:block;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;margin-bottom:4px}
.step-warn{background:#fdf6e9;border-left:3px solid var(--amber);border-radius:8px;padding:12px 14px;margin-top:14px;font-size:13px;color:var(--ink);line-height:1.55}
.step-warn b{color:#a06b15;display:block;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;margin-bottom:4px}
.troubleshoot{padding:48px 0;background:#fff}
.ts-grid{display:grid;gap:18px;max-width:920px;margin:0 auto}
.ts-card{background:#fff;border:1px solid var(--line);border-radius:14px;padding:22px}
.ts-card .ic{width:40px;height:40px;border-radius:10px;background:#fdf6e9;color:var(--amber);display:flex;align-items:center;justify-content:center;margin-bottom:12px}
.ts-card h4{font-size:16px;margin-bottom:8px}
.ts-card p{font-size:14px;color:var(--slate);line-height:1.55}
.guide-cta{padding:56px 0;background:var(--paper-warm)}
.guide-cta-card{max-width:760px;margin:0 auto;background:linear-gradient(135deg,var(--federal),var(--purple));color:#fff;border-radius:24px;padding:40px 32px;text-align:center;position:relative;overflow:hidden}
.guide-cta-card::before{content:"";position:absolute;top:-100px;right:-50px;width:300px;height:300px;border-radius:50%;background:radial-gradient(circle,rgba(126,214,208,.22),transparent 70%);pointer-events:none}
.guide-cta-card h3{color:#fff;font-size:24px;margin-bottom:10px;position:relative}
.guide-cta-card p{color:#cdd2ea;font-size:15px;margin-bottom:22px;max-width:48ch;margin-left:auto;margin-right:auto;position:relative}
.guide-cta-card .cta-row{display:flex;flex-wrap:wrap;justify-content:center;gap:10px;position:relative}

/* --- from partner-landing mockup --- */
.lockup{display:flex;align-items:center;gap:14px}
.lockup .logo img{height:48px;display:block}
.lockup .x{color:var(--slate);font-weight:600;font-size:16px;letter-spacing:.05em}
.lockup .partner-logo{height:42px;width:auto;display:block;border-left:1px solid var(--line);padding-left:14px}
.lockup .partner-text{padding-left:14px;border-left:1px solid var(--line);font-size:13px;color:var(--federal);font-weight:700;line-height:1.2}
.lockup .partner-text small{display:block;font-size:11px;color:var(--slate);font-weight:500;text-transform:uppercase;letter-spacing:.05em;margin-bottom:2px}
.partner-eyebrow{display:inline-flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--line);color:var(--federal);font-size:12px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;padding:7px 14px;border-radius:100px;margin-bottom:18px;width:max-content;max-width:100%}
.partner-eyebrow .dot{width:7px;height:7px;border-radius:50%;background:var(--good);box-shadow:0 0 0 4px rgba(46,158,107,.18)}
.ph-hero .lead{color:var(--ink);font-size:17px;margin-bottom:22px;max-width:46ch;line-height:1.55}
.ph-hero .discount-card{background:#fff;border:1.5px solid var(--purple);border-radius:18px;padding:22px;margin-bottom:22px;box-shadow:var(--shadow-md);position:relative;overflow:hidden}
.ph-hero .discount-card::before{content:"";position:absolute;top:0;left:0;right:0;height:5px;background:linear-gradient(90deg,var(--purple),var(--tiffany))}
.discount-card .label{font-size:11px;font-weight:700;color:var(--purple);text-transform:uppercase;letter-spacing:.08em;margin-bottom:6px}
.discount-card .pct{display:flex;align-items:baseline;gap:6px;margin-bottom:6px}
.discount-card .pct b{font-size:42px;font-weight:800;color:var(--federal);line-height:1;letter-spacing:-0.03em}
.discount-card .pct span{font-size:14px;color:var(--slate)}
.discount-card .auto{display:inline-flex;align-items:center;gap:5px;font-size:12px;color:var(--good);font-weight:600;background:var(--good-soft, #e8f5ee);padding:4px 10px;border-radius:100px;margin-top:8px}
.partner-card{background:#fff;border-radius:24px;overflow:hidden;box-shadow:var(--shadow-lg);max-width:420px;margin:0 auto}
.partner-card-photo{aspect-ratio:4/5;background:linear-gradient(135deg,var(--tiffany-soft),var(--purple-soft));overflow:hidden}
.partner-card-photo img{width:100%;height:100%;object-fit:cover}
.partner-card-body{padding:24px;text-align:center}
.partner-card-body h3{font-size:20px;margin-bottom:4px}
.partner-card-body .role{color:var(--slate);font-size:13px;margin-bottom:12px}
.partner-card-body .creds{display:flex;flex-wrap:wrap;gap:6px;justify-content:center}
.creds .c{font-size:11px;font-weight:600;color:var(--steel);background:var(--paper-warm);border:1px solid var(--line);padding:4px 9px;border-radius:6px}
.quote-block{max-width:760px;margin:0 auto;text-align:center}
.quote-block .q{font-size:22px;font-weight:500;color:var(--federal);line-height:1.4;margin-bottom:18px}
.quote-block .q::before{content:"\201C";color:var(--tiffany);font-size:54px;line-height:0;vertical-align:-20px;margin-right:6px;font-family:serif}
.quote-block .q::after{content:"\201D";color:var(--tiffany);font-size:54px;line-height:0;vertical-align:-20px;margin-left:2px;font-family:serif}
.quote-block .a{font-size:14px;color:var(--slate);font-weight:600}
.kits-grid{display:grid;gap:18px}
.kit-card:hover .kit-img img{transform:scale(1.05)}
.partner-pick{position:absolute;top:12px;right:12px;background:#fff;border:1.5px solid var(--purple);color:var(--purple);font-size:10px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;padding:4px 9px;border-radius:6px;z-index:2;display:flex;align-items:center;gap:4px}
.kit-body .desc{font-size:13px;color:var(--slate);margin-bottom:14px;flex:1}
.kit-specs .spec{flex:1}
.kit-specs .n{font-size:18px;font-weight:800;color:var(--federal);line-height:1}
.kit-specs .l{font-size:10px;color:var(--slate);text-transform:uppercase;letter-spacing:.05em;margin-top:2px}
.price-wrap{display:flex;flex-direction:column}
.price-was{font-size:12px;color:var(--slate);text-decoration:line-through;line-height:1}
.price-now{font-size:20px;font-weight:800;color:var(--purple);line-height:1.2}
.mini-steps{display:grid;gap:16px;max-width:880px;margin:0 auto}
.ms{text-align:center}
.ms .n{width:44px;height:44px;border-radius:12px;background:var(--tiffany-soft);color:var(--federal);font-weight:800;display:flex;align-items:center;justify-content:center;margin:0 auto 12px;font-size:18px}
.ms h4{font-size:15px;margin-bottom:4px}
.ms p{font-size:13px;color:var(--slate)}
.trust-row{background:var(--federal);color:#fff;padding:28px 0;text-align:center}
.trust-row .strip{display:flex;flex-wrap:wrap;gap:18px 28px;justify-content:center;align-items:center}
.trust-row .strip span{display:inline-flex;align-items:center;gap:7px;font-size:13px;color:#cdd2ea}
.trust-row .strip svg{color:var(--tiffany)}
.trust-row .strip b{color:#fff;font-weight:700}
.final-cta{background:linear-gradient(135deg,var(--federal) 0%,var(--purple) 100%);color:#fff;border-radius:28px;padding:48px 32px;text-align:center;max-width:920px;margin:0 auto;position:relative;overflow:hidden}
.final-cta::before{content:"";position:absolute;top:-150px;right:-100px;width:400px;height:400px;border-radius:50%;background:radial-gradient(circle,rgba(126,214,208,.22),transparent 70%);pointer-events:none}
.final-cta h2{color:#fff;font-size:30px;margin-bottom:10px;position:relative}
.final-cta p{color:#cdd2ea;font-size:16px;margin-bottom:24px;max-width:50ch;margin-left:auto;margin-right:auto;position:relative}
.final-cta .btn{position:relative}
.partner-disclosure{background:var(--paper-warm);border:1px dashed var(--line);border-radius:12px;padding:18px 22px;font-size:13px;color:var(--slate);max-width:760px;margin:48px auto 0;line-height:1.55}
.partner-disclosure b{color:var(--federal);font-weight:700}

/* --- from mens mockup --- */
.cat-hero .wrap{position:relative}
.cat-hero .crumb{font-size:13px;color:#cdd2ea;margin-bottom:14px}
.cat-hero .crumb a{color:#cdd2ea}
.cat-hero .crumb .sep{margin:0 8px;color:rgba(255,255,255,.3)}
.cat-hero .crumb .curr{color:#fff;font-weight:600}
.cat-eyebrow{display:inline-flex;align-items:center;gap:6px;background:rgba(126,214,208,.13);border:1px solid rgba(126,214,208,.35);color:var(--tiffany);font-size:12px;font-weight:700;letter-spacing:.05em;padding:7px 14px;border-radius:100px;margin-bottom:18px;text-transform:uppercase}
.cat-hero p.lead{color:#cdd2ea;font-size:17px;line-height:1.55;max-width:60ch;margin-bottom:24px}
.cat-hero .cta-row{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:24px}
.hero-pills{display:flex;flex-wrap:wrap;gap:8px}
.hero-pills span{display:inline-flex;align-items:center;gap:6px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);color:#cdd2ea;font-size:12px;font-weight:600;padding:7px 13px;border-radius:100px}
.hero-pills svg{color:var(--tiffany)}
.why-test{padding:56px 0;background:var(--paper-warm)}
.why-grid{display:grid;gap:18px;max-width:920px;margin:0 auto}
.why-card{background:#fff;border:1px solid var(--line);border-radius:16px;padding:24px;transition:all .25s var(--ease)}
.why-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}
.why-card .ic{width:48px;height:48px;border-radius:12px;background:var(--tiffany-soft);color:var(--federal);display:flex;align-items:center;justify-content:center;margin-bottom:14px}
.why-card h3{font-size:17px;margin-bottom:8px}
.why-card p{font-size:14px;color:var(--slate);line-height:1.55}
.kits-section{padding:56px 0}
.tag-champion{background:var(--purple)}
.tag-popular{background:var(--tiffany);color:var(--federal)}
.tag-flagship{background:var(--federal)}
.tag-perf{background:var(--steel)}
.tag-longev{background:var(--tiffany);color:var(--federal)}
.tag-hormone{background:var(--purple)}
.tag-essentials{background:var(--slate)}
.guide-band{background:var(--federal-deep);color:#fff;padding:64px 0;position:relative;overflow:hidden}
.guide-band::before{content:"";position:absolute;top:-100px;right:-100px;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(79,26,109,.3),transparent 70%);pointer-events:none}
.guide-grid{display:grid;gap:28px;align-items:center;position:relative}
.guide-photo{aspect-ratio:1/1;background:#000;border-radius:18px;overflow:hidden;max-width:360px}
.guide-photo img{width:100%;height:100%;object-fit:cover}
.guide-band h2{color:#fff;font-size:28px;line-height:1.15;margin-bottom:14px;letter-spacing:-0.02em}
.guide-band p{color:#cdd2ea;font-size:16px;margin-bottom:18px;line-height:1.55}
.guide-band .q{font-size:18px;font-style:italic;font-weight:500;color:#fff;border-left:3px solid var(--tiffany);padding:6px 0 6px 18px;margin-bottom:18px}
.cat-faq{padding:64px 0;background:var(--paper-warm)}
.cat-faq h2{text-align:center;font-size:28px;margin-bottom:32px}
.final-cta-band{background:linear-gradient(135deg,var(--federal),var(--purple));color:#fff;border-radius:24px;padding:48px 32px;text-align:center;max-width:920px;margin:0 auto;position:relative;overflow:hidden}
.final-cta-band::before{content:"";position:absolute;top:-100px;right:-50px;width:300px;height:300px;border-radius:50%;background:radial-gradient(circle,rgba(126,214,208,.22),transparent 70%);pointer-events:none}
.final-cta-band h3{color:#fff;font-size:26px;margin-bottom:10px;position:relative}
.final-cta-band p{color:#cdd2ea;font-size:15px;margin-bottom:22px;max-width:46ch;margin-left:auto;margin-right:auto;position:relative}
/* === MOBILE CART OVERFLOW FIXES === */
.cart-section{overflow-x:hidden}
.cart-section .wrap{overflow-x:hidden;max-width:100%}
.cart-items, .cart-summary-box{max-width:100%;box-sizing:border-box}
.cart-line{min-width:0}
.cart-line-body{min-width:0;overflow:hidden}
.cart-line-body h3, .cart-line-body p{overflow-wrap:anywhere;word-wrap:break-word}
.cart-line-price{flex-shrink:0;white-space:nowrap}
.cart-line-img{flex-shrink:0}
@media(max-width:600px){
  .cart-line{grid-template-columns:72px 1fr;gap:10px}
  .cart-line-img{width:72px}
  .cart-line-price{grid-column:2;text-align:left;margin-top:6px}
  .cart-line-price b{font-size:14px}
  .intake-block{padding:14px}
  .intake-block h4{font-size:13px}
  .field input, .field select, .field textarea{font-size:14px;padding:9px 10px}
  .sex-pill{padding:10px 14px;font-size:13px}
}

/* === STICKY COLLECTION TOOLBAR (sits below header, full-width white bar) === */
.toolbar{
  position: sticky;
  top: 64px;                    /* sits flush under the sticky header */
  z-index: 50;
  background: #fff;
  border-bottom: 1px solid var(--line);
  padding: 12px 0;
  margin: 0 0 24px;             /* visual breathing room below */
}
.toolbar-row{display:flex;justify-content:space-between;align-items:center;gap:14px;flex-wrap:wrap}
/* Mobile: toolbar still sticky but offset accounts for potentially shorter header */
@media(max-width:768px){
  .toolbar{top:56px;padding:10px 0;margin-bottom:18px}
}
/* When announcement bar is visible at top of page (not scrolled), header is offset by ~36px.
   We want toolbar still to sit flush against header. Browser handles this via CSS sticky. */

/* === ARTICLE BODY PADDING FIX (prevents touching screen edge) === */
.article{
  padding: 28px 22px !important;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 16px;
  margin: 0;
}
@media(min-width:700px){
  .article{padding: 40px 36px !important}
}
@media(min-width:1025px){
  .article{padding: 56px 56px !important}
}
/* Full-bleed cover image inside article uses negative margin to escape padding */
.article > .art-cover{
  margin-left: -22px;
  margin-right: -22px;
  margin-top: -28px;
  margin-bottom: 28px;
  border-radius: 0;
}
@media(min-width:700px){
  .article > .art-cover{margin-left:-36px;margin-right:-36px;margin-top:-40px}
}
@media(min-width:1025px){
  .article > .art-cover{margin-left:-56px;margin-right:-56px;margin-top:-56px}
}
/* art-layout also needs its own breathing room — kill the 4px inner padding */
.art-layout{padding-left: 0; padding-right: 0}

/* === ARTICLE PADDING - HIGHER SPECIFICITY OVERRIDE === */
.art-layout article.article,
.wrap.art-layout article.article,
section .article{
  padding: 28px 22px !important;
  background: #fff !important;
  border: 1px solid var(--line) !important;
  border-radius: 16px !important;
  box-sizing: border-box !important;
  max-width: 100% !important;
}
@media(min-width:700px){
  .art-layout article.article,
  .wrap.art-layout article.article,
  section .article{padding: 40px 36px !important}
}
@media(min-width:1025px){
  .art-layout article.article,
  .wrap.art-layout article.article,
  section .article{padding: 56px 56px !important}
}
/* TOC links basic styling */
.toc ul{list-style:none;padding:0;margin:0}
.toc ul li{margin:0;padding:0}
.toc ul li a{display:block;padding:8px 0;font-size:13px;color:var(--slate);text-decoration:none;border-bottom:1px solid var(--line);line-height:1.4}
.toc ul li a:hover{color:var(--federal)}
.toc ul li:last-child a{border-bottom:0}

/* === PDP BIOMARKER SECTION (rebuilt) === */
.bm-pills{display:flex;flex-wrap:wrap;gap:8px;margin:24px 0 28px;justify-content:center}
.bm-pill{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;border-radius:100px;background:#fff;border:1.5px solid var(--line);font:inherit;font-size:13px;font-weight:600;color:var(--ink);cursor:pointer;transition:all .2s}
.bm-pill:hover{border-color:var(--steel)}
.bm-pill.active{background:var(--federal);border-color:var(--federal);color:#fff}
.bm-pill .ct{display:inline-flex;align-items:center;justify-content:center;min-width:24px;height:20px;padding:0 6px;border-radius:100px;background:var(--tiffany-soft);color:var(--steel);font-size:11px;font-weight:700}
.bm-pill.active .ct{background:rgba(255,255,255,.18);color:#fff}
.bm-cards{display:flex;flex-direction:column;gap:10px}
.bm-card{background:#fff;border:1.5px solid var(--line);border-radius:14px;overflow:hidden;transition:border-color .2s}
.bm-card.open{border-color:var(--federal)}
.bm-card-head{width:100%;display:grid;grid-template-columns:auto 1fr auto;gap:16px;align-items:center;padding:18px 22px;background:none;border:0;font:inherit;text-align:left;cursor:pointer;color:inherit}
.bm-card-head:hover{background:var(--paper-warm)}
.bm-card-ic{width:42px;height:42px;border-radius:12px;background:var(--tiffany-soft);color:var(--steel);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.bm-card-text h3{font-size:15px;margin:0 0 3px;line-height:1.3;color:var(--federal)}
.bm-card-text p{font-size:13px;color:var(--slate);line-height:1.5;margin:0}
.bm-card-right{display:flex;align-items:center;gap:12px;flex-shrink:0}
.bm-card-count{display:inline-flex;align-items:center;justify-content:center;padding:4px 10px;border-radius:100px;background:var(--tiffany-soft);color:var(--steel);font-size:12px;font-weight:700;white-space:nowrap}
.bm-card-toggle{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:var(--steel);white-space:nowrap}
.bm-card-toggle .lbl-show{display:inline}
.bm-card-toggle .lbl-hide{display:none}
.bm-card.open .bm-card-toggle .lbl-show{display:none}
.bm-card.open .bm-card-toggle .lbl-hide{display:inline}
.bm-card-toggle .chev{transition:transform .25s ease}
.bm-card.open .bm-card-toggle .chev{transform:rotate(180deg)}
.bm-card-body{max-height:0;overflow:hidden;transition:max-height .35s ease}
.bm-card.open .bm-card-body{max-height:3000px}
.bm-list{list-style:none;padding:0 22px 22px;margin:0;display:grid;gap:14px}
.bm-item{display:grid;grid-template-columns:auto 1fr;gap:10px;padding-top:14px;border-top:1px solid var(--line)}
.bm-item:first-child{border-top:0;padding-top:8px}
.bm-item .dot{width:7px;height:7px;border-radius:50%;background:var(--tiffany);margin-top:9px;flex-shrink:0}
.bm-item b{display:block;font-size:14px;color:var(--federal);font-weight:700;margin-bottom:4px}
.bm-item p{font-size:13px;color:var(--slate);line-height:1.6;margin:0}
@media(max-width:680px){
  .bm-card-head{grid-template-columns:auto 1fr;gap:12px;padding:14px 16px}
  .bm-card-right{grid-column:1/-1;justify-content:space-between;margin-top:6px}
  .bm-card-toggle{font-size:12px}
  .bm-list{padding:0 16px 18px}
}

/* === PRODUCT CARD PADDING + ALIGNMENT FIXES === */
.card{padding:0;display:flex;flex-direction:column}
.card .card-body, .card .kit-body, .card-content{padding:16px 18px 18px !important}
/* Inner stats row (biomarker count + 48h results) needs alignment + side padding */
.card .kit-stats, .card .stats-row, .card .stat-row{
  display:grid !important;
  grid-template-columns:1fr 1fr;
  gap:12px;
  padding:14px 18px;
  margin:0;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  align-items:center;
}
.card .stat-num, .card .kit-n{font-size:22px;font-weight:800;color:var(--federal);line-height:1;letter-spacing:-0.01em}
.card .stat-lbl, .card .kit-l{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--slate);margin-top:3px;display:block}
/* Price + View row needs side padding too */
.card .kit-foot, .card .card-foot, .card .price-row{
  display:flex !important;
  justify-content:space-between;
  align-items:center;
  padding:14px 18px 16px !important;
  gap:12px;
}
.card .kit-foot .price, .card .card-foot .price{font-size:18px;font-weight:800;color:var(--federal)}
.card .kit-foot .btn, .card .card-foot .btn{padding:8px 18px;font-size:13px}

/* === BADGE SIZE CONSISTENCY (don't stretch to match adjacent) === */
.card-badge, .badge-pill, .pill-badge{
  display:inline-flex !important;
  align-self:flex-start !important;
  width:auto !important;
  max-width:fit-content !important;
  white-space:nowrap !important;
  padding:5px 11px !important;
  font-size:11px !important;
  font-weight:700 !important;
  letter-spacing:.03em !important;
  border-radius:6px !important;
  line-height:1.3 !important;
}
/* If multiple badges stacked, prevent the container from stretching them */
.card-badges, .badge-row{
  display:flex !important;
  flex-wrap:wrap !important;
  gap:6px !important;
  align-items:flex-start !important;
  justify-content:flex-start !important;
}

/* === STICKY TOOLBAR — properly at top under header, all viewports === */
.toolbar{
  position: sticky !important;
  top: 0 !important;
  z-index: 50 !important;
  background: #fff !important;
  border-bottom: 1px solid var(--line) !important;
  padding: 14px 0 !important;
  margin: 0 0 24px !important;
  width: 100% !important;
}
/* If your header is also sticky, the toolbar needs to sit below it.
   The .header sticky should set its own z-index higher than toolbar.
   We achieve "below header" by using top:0 with the header set to position:sticky too,
   stacked in document order — browser handles offset automatically when both are sticky. */
header.header, .header{position:sticky;top:0;z-index:100;background:#fff}

/* === POPUP CLINIC FEATURED EVENT === */
.pe-featured{transition:all .2s}
.pe-featured:hover{box-shadow:0 16px 40px -16px rgba(18,22,86,.4)}
.pe-feat-actions{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.pe-feat-actions .btn{margin:0}
#peLocationBar{margin:24px 0 8px}

/* === MOBILE COLLAPSIBLE TOC === */
.toc-mobile{
  display:none;
  margin:0 0 18px;
  background:var(--paper-warm);
  border:1px solid var(--line);
  border-radius:12px;
  overflow:hidden;
}
.toc-mobile summary{
  list-style:none;
  display:flex;
  align-items:center;
  gap:10px;
  padding:14px 18px;
  font-size:14px;
  font-weight:700;
  color:var(--federal);
  cursor:pointer;
  user-select:none;
}
.toc-mobile summary::-webkit-details-marker{display:none}
.toc-mobile summary span{flex:1}
.toc-mobile summary .chev{transition:transform .25s}
.toc-mobile[open] summary .chev{transform:rotate(180deg)}
.toc-mobile ul{list-style:none;padding:4px 18px 16px;margin:0;border-top:1px solid var(--line)}
.toc-mobile ul li{margin:0}
.toc-mobile ul li a{display:block;padding:10px 0;font-size:13px;color:var(--slate);text-decoration:none;border-bottom:1px solid var(--line);line-height:1.4}
.toc-mobile ul li:last-child a{border-bottom:0}
.toc-mobile ul li a:hover{color:var(--federal)}
/* Show mobile TOC below 900px (where desktop sidebar hides) */
@media(max-width:900px){
  .toc-mobile{display:block}
  .toc{display:none}
}

/* === COMPARE — checkbox on cards + sticky bottom bar === */
.compare-toggle{
  position:absolute;
  top:12px;
  right:12px;
  z-index:5;
  display:inline-flex;
  align-items:center;
  gap:5px;
  background:#fff;
  border:1.5px solid var(--line);
  border-radius:100px;
  padding:5px 11px;
  font-size:11px;
  font-weight:700;
  color:var(--slate);
  cursor:pointer;
  transition:all .2s;
  user-select:none;
}
.compare-toggle:hover{border-color:var(--steel);color:var(--federal)}
.compare-toggle input{accent-color:var(--federal);margin:0;width:13px;height:13px}
.compare-toggle:has(input:checked){background:var(--federal);color:#fff;border-color:var(--federal)}
.compare-toggle:has(input:checked) input{accent-color:#fff}
/* Sticky compare bar at bottom */
.compare-bar{
  position:fixed;
  bottom:0;left:0;right:0;
  background:#fff;
  border-top:1.5px solid var(--federal);
  box-shadow:0 -8px 24px -8px rgba(18,22,86,.18);
  z-index:80;
  padding:14px 0;
  animation:slideUp .25s ease;
}
@keyframes slideUp{from{transform:translateY(100%)}to{transform:translateY(0)}}
.compare-bar-inner{display:flex;justify-content:space-between;align-items:center;gap:18px;flex-wrap:wrap}
.compare-items{display:flex;gap:8px;flex-wrap:wrap;align-items:center;flex:1}
.compare-chip{
  display:inline-flex;
  align-items:center;
  gap:8px;
  background:var(--paper-warm);
  border:1px solid var(--line);
  border-radius:100px;
  padding:5px 10px 5px 5px;
  font-size:12px;
  font-weight:600;
}
.compare-chip img{width:24px;height:24px;object-fit:contain;border-radius:50%;background:#fff}
.compare-chip .x{background:none;border:0;color:var(--slate);font-size:14px;cursor:pointer;padding:0 4px}
.compare-chip .x:hover{color:var(--danger)}
.compare-actions{display:flex;gap:8px;align-items:center}
@media(max-width:600px){
  .compare-bar{padding:10px 0}
  .compare-bar-inner{gap:10px}
  .compare-chip span{display:none}
  .compare-chip{padding:5px}
}

/* === POPUP DETAIL: PANELS GRID === */
.pe-panels{margin:18px 0 22px;padding:18px 20px;background:var(--paper-warm);border-radius:12px;border:1px solid var(--line)}
.pe-panels h4{font-size:13px;text-transform:uppercase;letter-spacing:.06em;color:var(--steel);margin-bottom:14px;font-weight:700}
.pe-panel-grid{display:grid;gap:12px}
.pe-panel{display:flex;flex-direction:column;padding:14px;background:#fff;border:1px solid var(--line);border-radius:10px}
.pe-panel-head{display:grid;grid-template-columns:auto 1fr auto;gap:14px;align-items:center}
.pe-panel-ic{width:48px;height:48px;border-radius:12px;object-fit:contain;background:linear-gradient(135deg,var(--tiffany-soft),#fff);padding:6px;flex-shrink:0}
.pe-panel-ic-fallback{display:flex;align-items:center;justify-content:center;color:var(--steel);background:var(--tiffany-soft);padding:0}
.pe-panel-info b{display:block;font-size:14px;color:var(--federal);margin-bottom:2px}
.pe-panel-count{display:inline-block;background:var(--tiffany-soft);color:var(--steel);padding:2px 8px;border-radius:6px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;margin-bottom:4px}
.pe-panel-toggle{display:inline-flex;align-items:center;gap:5px;background:var(--tiffany-soft);color:var(--steel);padding:3px 9px;border-radius:6px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;margin-bottom:4px;border:none;cursor:pointer;transition:background .15s}
.pe-panel-toggle:hover{background:var(--steel);color:#fff}
.pe-panel-toggle svg{transition:transform .2s}
.pe-panel-toggle.is-open svg{transform:rotate(180deg)}
.pe-panel-info p{font-size:12px;color:var(--slate);line-height:1.5;margin:0}
.pe-panel-meta{text-align:right;flex-shrink:0}
.pe-panel-bios{display:flex;flex-wrap:wrap;gap:6px;margin-top:12px;padding-top:12px;border-top:1px dashed var(--line)}
.pe-bio-chip{display:inline-block;background:var(--paper-warm);color:var(--ink);border:1px solid var(--line);padding:3px 10px;border-radius:20px;font-size:12px;line-height:1.4}
.pe-panel-price{font-size:18px;font-weight:800;color:var(--federal);line-height:1}
.pe-panel-extras{font-size:11px;color:var(--slate);margin-top:4px}
.pe-card-panels-hint{display:inline-block;background:var(--purple-soft);color:var(--purple);font-size:11px;font-weight:700;padding:3px 8px;border-radius:6px;margin-bottom:10px;text-transform:uppercase;letter-spacing:.04em}
@media(max-width:600px){
  .pe-panel{grid-template-columns:auto 1fr;gap:10px;padding:12px}
  .pe-panel-meta{grid-column:1/-1;text-align:left;padding-top:8px;border-top:1px solid var(--line);margin-top:8px}
}

/* === POPUP CLINICS: NOTIFY ME SIGNUP === */
.popup-notify{background:linear-gradient(135deg,var(--federal),var(--purple));color:#fff;border-radius:18px;padding:36px;margin:32px 0;position:relative;overflow:hidden}
.popup-notify::before{content:'';position:absolute;top:-50px;right:-50px;width:200px;height:200px;background:var(--tiffany);opacity:.08;border-radius:50%;pointer-events:none}
.popup-notify-grid{display:grid;gap:28px;position:relative}
@media(min-width:800px){.popup-notify-grid{grid-template-columns:1fr 1.1fr;gap:48px;align-items:center}}
.popup-notify-tag{display:inline-block;background:var(--tiffany);color:var(--federal);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;padding:5px 12px;border-radius:100px;margin-bottom:12px}
.popup-notify h2{color:#fff;font-size:24px;line-height:1.2;margin-bottom:10px}
.popup-notify p{color:#cdd2ea;font-size:15px;line-height:1.5}
.popup-notify-form{background:#fff;border-radius:14px;padding:20px;color:var(--ink)}
.popup-notify-row{display:flex;gap:10px;margin-bottom:10px;flex-wrap:wrap}
.popup-notify-row input[type="email"],
.popup-notify-row input[type="text"]{flex:1;min-width:140px;border:1.5px solid var(--line);border-radius:10px;padding:11px 14px;font-family:inherit;font-size:14px;background:#fff;color:var(--ink)}
.popup-notify-row input:focus{outline:none;border-color:var(--federal)}
.popup-notify-chk{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--slate);cursor:pointer;line-height:1.4}
.popup-notify-chk input{accent-color:var(--federal);margin:0;width:14px;height:14px}
.popup-notify-form .btn{width:100%;padding:13px;font-size:14px;margin-top:6px}
.popup-notify-fine{font-size:11px;color:var(--slate);margin-top:10px;text-align:center}

/* === BADGE CSS FIX — missing class variants (hormones, essentials, longev) === */
.card-badge.hormones{background:var(--purple);color:#fff}
.card-badge.essentials{background:var(--slate);color:#fff}
.card-badge.longev{background:var(--tiffany);color:var(--federal)}
.card-badge.perf{background:var(--steel);color:#fff}
.card-badge.champion{background:var(--purple);color:#fff}
.card-badge.popular{background:var(--tiffany);color:var(--federal)}
.card-badge.flagship{background:var(--federal);color:#fff}
/* Ensure the card has position:relative so badge anchors correctly */
.card.kit-card, .kit-card.card, a.kit-card, a.card{position:relative !important}



/* === SQUARE IMAGES FOR POPUP CARDS === */
.pe-card-img{aspect-ratio: 1/1 !important}
.pe-feat-img{aspect-ratio: 1/1 !important}


/* The pre-book button on hero - solid mint */
.pe-featured .btn-primary{
  background: var(--tiffany) !important;
  color: var(--federal) !important;
  border: 1.5px solid var(--tiffany) !important;
}
.pe-featured .btn-primary:hover{
  background: #fff !important;
  border-color: #fff !important;
}

/* === MODAL OVERLAY — proper Baymard/NN design === */
/* Backdrop wraps the modal */
.modal-overlay{
  position: fixed;
  inset: 0;
  z-index: 9999;
  background: rgba(6,9,30,0.55);
  backdrop-filter: blur(2px);
  -webkit-backdrop-filter: blur(2px);
  display: none;
  align-items: center;
  justify-content: center;
  padding: 24px;
  animation: modalFadeIn .2s ease;
}
.modal-overlay.is-open{display:flex}
@keyframes modalFadeIn{from{opacity:0}to{opacity:1}}
.modal-overlay .modal-content{
  background: #fff;
  border-radius: 18px;
  box-shadow: 0 24px 64px -16px rgba(0,0,0,0.4);
  width: 100%;
  max-width: 720px;
  max-height: calc(100vh - 48px);
  overflow-y: auto;
  position: relative;
  animation: modalSlideUp .25s cubic-bezier(.16,1,.3,1);
}
@keyframes modalSlideUp{from{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}
.modal-overlay .modal-close{
  position: absolute;
  top: 16px;
  right: 16px;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: #fff;
  border: 1.5px solid var(--line);
  color: var(--federal);
  font-size: 22px;
  font-weight: 600;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 10;
  transition: all .15s;
  padding: 0;
  line-height: 1;
}
.modal-overlay .modal-close:hover{
  background: var(--paper-warm);
  border-color: var(--steel);
  transform: scale(1.05);
}
.modal-overlay .modal-body{
  padding: 36px 36px 28px;
}
.modal-overlay .modal-body h3{font-size:24px;line-height:1.2;margin:0 0 8px;color:var(--federal);padding-right:48px}
.modal-overlay .modal-body .modal-addr{color:var(--slate);font-size:14px;line-height:1.5;margin-bottom:14px}
.modal-overlay .modal-body .modal-tags{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:18px}
.modal-overlay .modal-body .modal-desc{color:var(--ink);line-height:1.6;margin-bottom:22px;font-size:15px}
.modal-overlay .modal-grid{display:grid;gap:20px;grid-template-columns:1fr;margin-bottom:20px}
@media(min-width:640px){.modal-overlay .modal-grid{grid-template-columns:1fr 1fr}}
.modal-overlay .modal-info b{display:block;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--steel);margin-bottom:10px}
.modal-overlay .modal-info ul{list-style:none;padding:0;margin:0}
.modal-overlay .modal-info ul li{padding:8px 0;border-bottom:1px solid var(--line);color:var(--ink);font-size:14px;line-height:1.5}
.modal-overlay .modal-info ul li:last-child{border-bottom:0}
.modal-overlay .modal-map{border-radius:10px;overflow:hidden;border:1px solid var(--line);aspect-ratio:1/1;min-height:200px}
.modal-overlay .modal-map iframe{width:100%;height:100%;border:0;display:block}
.modal-overlay .modal-actions{display:flex;gap:10px;padding:0 36px 36px;flex-wrap:wrap;margin-top:8px}
.modal-overlay .modal-actions .btn{flex:1;min-width:140px;padding:13px 20px;font-size:14px;font-weight:700}
@media(max-width:520px){
  .modal-overlay{padding:0;align-items:stretch}
  .modal-overlay .modal-content{max-height:100vh;border-radius:0;max-width:none}
  .modal-overlay .modal-body{padding:28px 22px 16px}
  .modal-overlay .modal-body h3{font-size:20px}
  .modal-overlay .modal-actions{padding:0 22px 24px;flex-direction:column}
}
body.modal-open{overflow:hidden}

/* Featured event button contrast (popup clinics hero) */
.pe-featured .btn-ghost,
.pe-feat-actions .btn-ghost{
  background: rgba(255,255,255,0.18) !important;
  border: 1.5px solid rgba(255,255,255,0.55) !important;
  color: #fff !important;
}
.pe-featured .btn-ghost:hover,
.pe-feat-actions .btn-ghost:hover{
  background: rgba(255,255,255,0.32) !important;
  border-color: #fff !important;
}
.pe-featured .btn-primary{
  background: var(--tiffany) !important;
  color: var(--federal) !important;
  border: 1.5px solid var(--tiffany) !important;
}

/* === MODAL GRID SINGLE-COLUMN (no embed map) === */
.modal-overlay .modal-grid.modal-grid-single{grid-template-columns:1fr !important}

/* === COMPARE CHIP TEXT CONTRAST === */
.compare-chip{
  background:var(--paper-warm) !important;
  border:1.5px solid var(--line) !important;
  color:var(--federal) !important;
  font-weight:700 !important;
}
.compare-chip span{color:var(--federal) !important}
.compare-chip .x{color:var(--slate) !important;font-size:18px !important;background:none;border:0;cursor:pointer;padding:0 4px}
.compare-chip .x:hover{color:var(--danger) !important}

/* === LOCATION FILTER INPUT STYLING === */
#peLocationInput, #peLocationInput[type="text"]{
  width:100%;
  border:1.5px solid var(--line);
  border-radius:10px;
  padding:14px 14px 14px 44px;
  font-family:inherit;
  font-size:14px;
  font-weight:500;
  background:#fff;
  color:var(--ink);
  transition:border-color .2s;
}
#peLocationInput:focus{outline:none;border-color:var(--federal)}
#peLocationBar{display:flex;gap:12px;align-items:stretch;margin:24px 0 8px;flex-wrap:wrap}
#peLocationBar .cf-search-input-wrap{position:relative;flex:1;min-width:240px}
#peLocationBar .cf-search-input-wrap svg{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--slate)}
#peLocationClear{padding:13px 18px;font-size:14px;font-weight:600}

/* === STATIC MAP PLACEHOLDER (replaces blocked iframe) === */
.modal-map-static{
  background:var(--paper-warm);
  border:1px solid var(--line);
  border-radius:10px;
  padding:24px 18px;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  text-align:center;
  gap:8px;
  min-height:180px;
  color:var(--steel);
}
.modal-map-static svg{color:var(--federal);opacity:.5}
.modal-map-static span{font-size:12px;font-weight:600;color:var(--slate);text-transform:uppercase;letter-spacing:.04em}
.modal-map-static .btn-link{
  display:inline-flex;
  align-items:center;
  gap:6px;
  font-size:14px;
  color:var(--federal);
  font-weight:700;
  text-decoration:underline;
  margin-top:6px;
}
.modal-map-static .btn-link:hover{color:var(--steel)}

/* === COMPARE CHIP TEXT CONTRAST === */
.compare-chip{
  background: var(--federal) !important;
  color: #fff !important;
  border-color: var(--federal) !important;
}
.compare-chip span{color:#fff !important}
.compare-chip .x{color:rgba(255,255,255,0.7) !important}
.compare-chip .x:hover{color:#fff !important}

/* === LOCATION FILTER STYLING === */
.cf-search-bar#peLocationBar{
  background: #fff;
  border: 1.5px solid var(--line);
  border-radius: 12px;
  padding: 12px 16px;
  margin: 24px 0 16px;
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}
.cf-search-bar#peLocationBar .cf-search-input-wrap{
  flex: 1;
  min-width: 200px;
  position: relative;
  display: flex;
  align-items: center;
  gap: 10px;
}
.cf-search-bar#peLocationBar .cf-search-input-wrap svg{
  color: var(--steel);
  flex-shrink: 0;
}
#peLocationInput{
  flex: 1;
  border: 1.5px solid var(--line);
  border-radius: 10px;
  padding: 11px 14px;
  font-family: inherit;
  font-size: 14px;
  font-weight: 500;
  background: var(--paper-warm);
  color: var(--ink);
  width: 100%;
}
#peLocationInput:focus{
  outline: none;
  border-color: var(--federal);
  background: #fff;
}
#peLocationClear{
  padding: 11px 18px;
  font-size: 13px;
  white-space: nowrap;
}

/* Filter bar */
.pe-filterbar{
  background: #fff;
  border: 1.5px solid var(--line);
  border-radius: 12px;
  padding: 14px 18px;
  margin-bottom: 24px;
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 18px;
}
.pe-filterbar label{
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  color: var(--slate);
}
.pe-filterbar label > span:first-child{font-weight: 700; color: var(--federal); font-size: 12px; text-transform: uppercase; letter-spacing: .04em}
.pe-filterbar select{
  flex: 1;
  border: 1.5px solid var(--line);
  border-radius: 8px;
  padding: 8px 12px;
  font-family: inherit;
  font-size: 13px;
  background: #fff;
  color: var(--ink);
  cursor: pointer;
}
.pe-filterbar select:focus{outline: none; border-color: var(--federal)}
@media(max-width:680px){
  .pe-filterbar{grid-template-columns: 1fr; gap: 10px}
  .pe-filterbar label{flex-direction: column; align-items: flex-start; gap: 4px}
}

/* === LEARN MENU DROPDOWN — fix "all selected" appearance === */
/* Each menu item should only show focus/hover on actual hover */
.hdr-menu a, .hdr-mega a, .mega-menu a, nav.menu a, header nav a {
  background: transparent !important;
}
.hdr-menu a:hover, .hdr-mega a:hover, .mega-menu a:hover, nav.menu a:hover {
  background: var(--paper-warm) !important;
  color: var(--federal) !important;
}
/* If submenu items have an active/current class showing teal background, only apply to truly current page */
.submenu-item, .dropdown-item, .menu-item-dropdown {
  background: transparent !important;
}
.submenu-item:hover, .dropdown-item:hover {
  background: var(--paper-warm) !important;
}

/* === ARTICLE PROSE: quote styling + spacing === */
.article.rte blockquote,
.article blockquote{
  margin: 32px 0;
  padding: 24px 28px;
  background: linear-gradient(135deg, var(--tiffany-soft), #fff);
  border-left: 4px solid var(--tiffany);
  border-radius: 0 14px 14px 0;
  font-size: 19px;
  line-height: 1.55;
  color: var(--federal);
  font-weight: 500;
  font-style: italic;
  position: relative;
}
.article.rte blockquote::before,
.article blockquote::before{
  content: '\201C';
  position: absolute;
  top: 4px;
  left: 16px;
  font-size: 56px;
  line-height: 1;
  color: var(--tiffany);
  opacity: .4;
  font-family: Georgia, serif;
  font-style: normal;
}
.article.rte blockquote p,
.article blockquote p{ margin: 0; padding-left: 36px; }
.article.rte blockquote p + p,
.article blockquote p + p{ margin-top: 12px; }
.article.rte blockquote cite,
.article blockquote cite{
  display: block;
  margin-top: 12px;
  padding-left: 36px;
  font-size: 13px;
  font-style: normal;
  color: var(--slate);
  font-weight: 600;
}
.article.rte blockquote cite::before,
.article blockquote cite::before{ content: '\2014 '; }

/* General article content spacing */
.article.rte, .article{ font-size: 17px; line-height: 1.75; color: var(--ink); }
.article.rte h2, .article h2{ font-size: 28px; line-height: 1.2; margin: 48px 0 16px; color: var(--federal); letter-spacing: -0.01em; }
.article.rte h3, .article h3{ font-size: 21px; line-height: 1.3; margin: 32px 0 12px; color: var(--federal); }
.article.rte p, .article p{ margin: 0 0 20px; }
.article.rte ul, .article.rte ol, .article ul, .article ol{ margin: 0 0 20px; padding-left: 24px; }
.article.rte li, .article li{ margin-bottom: 8px; line-height: 1.65; }
.article.rte img, .article img{ max-width: 100%; height: auto; border-radius: 12px; margin: 24px 0; }
.article.rte a, .article a{ color: var(--federal); font-weight: 600; text-decoration: underline; text-decoration-color: var(--tiffany); text-decoration-thickness: 2px; text-underline-offset: 3px; }
.article.rte a:hover, .article a:hover{ color: var(--steel); }
.article.rte hr, .article hr{ border: 0; border-top: 1px solid var(--line); margin: 40px 0; }
.article.rte strong, .article strong{ color: var(--federal); font-weight: 700; }
.article.rte code, .article code{ background: var(--paper-warm); padding: 2px 6px; border-radius: 4px; font-size: 0.92em; }

/* === BADGE CONTAINER: stack badges cleanly without stretching === */
.card-img .card-badges,
.kit-img .card-badges{
  position: absolute !important;
  top: 12px !important;
  left: 12px !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 6px !important;
  align-items: flex-start !important;
  z-index: 3 !important;
  max-width: calc(100% - 24px);
}
.card-img .card-badges .card-badge,
.kit-img .card-badges .kit-tag,
.card-img .card-badges .kit-tag{
  position: static !important;
  top: auto !important;
  left: auto !important;
  display: inline-flex !important;
  align-self: flex-start !important;
  width: auto !important;
  max-width: fit-content !important;
  white-space: nowrap !important;
  padding: 5px 10px !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: .03em !important;
  border-radius: 6px !important;
  line-height: 1.3 !important;
  text-transform: uppercase !important;
  box-shadow: 0 2px 6px rgba(18,22,86,.12) !important;
}

/* === BADGE FALLBACK BACKGROUND (so badges are never invisible) === */
.card-badge, .kit-tag{
  background: var(--federal) !important;
  color: #fff !important;
}

/* Type-specific overrides (with plural-tolerant aliases) */
.card-badge.champion, .card-badge.champions,
.kit-tag.champion, .kit-tag.champions{
  background: var(--purple) !important; color: #fff !important;
}
.card-badge.popular, .kit-tag.popular{
  background: var(--tiffany) !important; color: var(--federal) !important;
}
.card-badge.flagship, .kit-tag.flagship{
  background: var(--federal) !important; color: #fff !important;
}
.card-badge.perf, .card-badge.performance,
.kit-tag.perf, .kit-tag.performance{
  background: var(--steel) !important; color: #fff !important;
}
.card-badge.longev, .card-badge.longevity,
.kit-tag.longev, .kit-tag.longevity{
  background: var(--tiffany) !important; color: var(--federal) !important;
}
.card-badge.hormone, .card-badge.hormones,
.kit-tag.hormone, .kit-tag.hormones{
  background: var(--purple) !important; color: #fff !important;
}
.card-badge.essentials, .card-badge.essential,
.kit-tag.essentials, .kit-tag.essential{
  background: var(--slate) !important; color: #fff !important;
}
.card-badge.new, .kit-tag.new{
  background: var(--good) !important; color: #fff !important;
}
.card-badge.limited, .kit-tag.limited{
  background: var(--amber) !important; color: #fff !important;
}

/* Goal badge (second pill) — soft tiffany, federal text, lighter weight */
.card-badges .card-badge:nth-child(2),
.card-badges .kit-tag:nth-child(2),
.card-badge.goal, .kit-tag.goal, .badge.goal{
  background: var(--tiffany-soft) !important;
  color: var(--federal) !important;
  font-weight: 600 !important;
}

/* === COMPARE TABLE: clearer yes/no visuals === */
.cmp-yes{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:24px; height:24px;
  border-radius:50%;
  background: var(--good-soft);
  color: var(--good);
  font-size:13px;
  font-weight:800;
}
.cmp-no{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:24px; height:24px;
  border-radius:50%;
  background: #FCEAEA;
  color: var(--danger);
  font-size:11px;
  font-weight:800;
  opacity:0.85;
}

/* ============================================
   JUDGE.ME WRITTEN-REVIEWS — THEMED OVERRIDES
   Restyle the app's widget to match the site.
   Native stars + summary handled in Liquid above.
   ============================================ */

/* Hide Judge.me's own preview badge / star summary
   if the app injects one — we render our own. */
.jdgm-rev-widg__summary,
.jdgm-widget .jdgm-rev-widg__header,
.jdgm-all-reviews-rating,
.jdgm-rev-widg__sort-wrapper select { font-family: inherit; }

/* Overall widget container */
.vc-reviews,
.jdgm-rev-widg {
  font-family: inherit !important;
  color: var(--ink);
}

/* "Write a review" button — match theme dark button */
.jdgm-write-rev-link,
.jdgm-widget .jdgm-write-rev-link {
  background: var(--federal) !important;
  color: #fff !important;
  border: 0 !important;
  border-radius: 100px !important;
  padding: 10px 20px !important;
  font-weight: 600 !important;
  font-size: 14px !important;
  text-transform: none !important;
  transition: all .2s var(--ease);
}
.jdgm-write-rev-link:hover { background: var(--federal-deep) !important; }

/* Individual review cards */
.jdgm-rev {
  border: 1px solid var(--line) !important;
  border-radius: 14px !important;
  background: #fff !important;
  padding: 20px 22px !important;
  margin-bottom: 14px !important;
}
.jdgm-rev__header,
.jdgm-rev__timestamp { color: var(--slate) !important; }
.jdgm-rev__author { color: var(--federal) !important; font-weight: 700 !important; }
.jdgm-rev__title { color: var(--ink) !important; font-weight: 700 !important; }
.jdgm-rev__body { color: var(--slate) !important; line-height: 1.6 !important; }

/* Stars inside the widget — match our amber */
.jdgm-star { color: var(--star) !important; }
.jdgm-star.jdgm--off { color: var(--star-off) !important; }

/* Paging controls (1, 2, 3, More) — themed */
.jdgm-paginate__page,
.jdgm-paginate__prev,
.jdgm-paginate__next {
  border: 1px solid var(--line) !important;
  border-radius: 8px !important;
  color: var(--steel) !important;
  background: #fff !important;
  font-weight: 600 !important;
  min-width: 34px;
  height: 34px;
  line-height: 32px;
  margin: 0 3px !important;
  transition: all .2s var(--ease);
}
.jdgm-paginate__page:hover,
.jdgm-paginate__prev:hover,
.jdgm-paginate__next:hover { border-color: var(--steel) !important; }
.jdgm-paginate__page.jdgm-curt {
  background: var(--federal) !important;
  color: #fff !important;
  border-color: var(--federal) !important;
}

/* Histogram bars (if shown) — amber on light track */
.jdgm-histogram__bar-content { background: var(--star) !important; }

/* Empty state — keep it quiet, not a big ugly prompt */
.jdgm-no-reviews-text {
  color: var(--slate) !important;
  font-size: 14px !important;
}

/* Reconcile rev-summary: the inline buy-box / section summary.
   Single source of truth so the unused histogram variant
   further up the file can't override it. */
.rev-summary {
  display: flex !important;
  gap: 28px;
  align-items: center;
  flex-wrap: wrap;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 16px;
  padding: 28px 32px;
  margin-top: 8px;
  grid-template-columns: none !important;
}
.rev-summary-score { text-align: center; flex-shrink: 0; }
.rev-summary-score .big { font-size: 46px; font-weight: 800; color: var(--federal); line-height: 1; }
.rev-summary-score .stars { color: var(--star); font-size: 20px; letter-spacing: 2px; margin: 6px 0; }
.rev-summary-score .ct { font-size: 13px; color: var(--slate); }
.rev-summary-note { flex: 1; min-width: 200px; }
.rev-summary-note p { font-size: 14px; color: var(--slate); line-height: 1.6; margin: 0; }

/* ============================================
   VC STAR RATING — precise fractional stars
   On-brand gold fill over soft line-grey base.
   Used in the title review-row and rev-summary.
   ============================================ */
.vc-stars{
  position:relative;
  display:inline-block;
  font-size:19px;
  line-height:1;
  letter-spacing:3px;
  white-space:nowrap;
  vertical-align:middle;
  font-family:Arial,sans-serif; /* consistent star glyph metrics */
}
.vc-stars-off{ color:var(--star-off); }
.vc-stars-on{
  position:absolute;
  top:0; left:0;
  color:var(--star);
  overflow:hidden;
  white-space:nowrap;
  display:inline-block;
}
.vc-stars-lg{ font-size:26px; letter-spacing:4px; margin:8px 0; }
.vc-stars-sm{ font-size:14px; letter-spacing:1.5px; }
.vc-card-rating{ display:flex; align-items:center; gap:6px; margin:2px 0 10px; }
.vc-card-rating__count{ font-size:12px; color:var(--slate); font-weight:600; }

/* ============================================================
   UNIFIED PRODUCT BADGE SYSTEM (research-backed, brand-locked)
   badge_type → colour. Works across .card-badge / .kit-tag / .badge
   on collection, PDP, homepage and Stephen pages.
   All colours are brand tokens — no off-brand values possible.
   ============================================================ */
.card-badge, .kit-tag, .badge{
  font-weight:700;letter-spacing:.04em;text-transform:uppercase;
}
/* champion — deep purple (Stephen / flagship endorsement) */
.card-badge.champion,.kit-tag.champion,.badge.champion{background:var(--purple) !important;color:#fff !important}
/* flagship — federal navy (most comprehensive) */
.card-badge.flagship,.kit-tag.flagship,.badge.flagship{background:var(--federal) !important;color:#fff !important}
/* popular — tiffany */
.card-badge.popular,.kit-tag.popular,.badge.popular{background:var(--tiffany) !important;color:var(--federal) !important}
/* hormones — soft purple (light, distinct from champion) */
.card-badge.hormones,.kit-tag.hormones,.badge.hormones{background:var(--purple-soft) !important;color:var(--purple) !important}
/* longev — steel blue (distinct from popular tiffany) */
.card-badge.longev,.kit-tag.longev,.badge.longev{background:var(--steel) !important;color:#fff !important}
/* perf — amber (warm, athletic; distinct from steel) */
.card-badge.perf,.kit-tag.perf,.badge.perf{background:var(--amber) !important;color:#fff !important}
/* essentials — slate grey */
.card-badge.essentials,.kit-tag.essentials,.badge.essentials{background:var(--slate) !important;color:#fff !important}
/* goal pill — always tiffany-soft, federal text, lighter weight (secondary signal) */
.card-badge.goal,.kit-tag.goal,.badge.goal,.card-badge.popular.goal{
  background:var(--tiffany-soft);color:var(--federal);font-weight:600;
}
