@import url('https://fonts.googleapis.com/css2?family=Tenor+Sans&family=Fraunces:ital,opsz,wght@0,9..144,300;0,9..144,400;0,9..144,500;0,9..144,600;1,9..144,400&family=Hanken+Grotesk:wght@300;400;500;600&display=swap');

  :root{
    --bg:#0a1517;
    --bg-2:#0c1a1c;
    --panel:#10262a;
    --panel-2:#0e2125;
    --line:rgba(95,174,157,.16);
    --line-soft:rgba(95,174,157,.09);
    --teal:#5fae9d;
    --teal-d:#3f9e8b;
    --steel:#3a7d8c;
    --mint:#9fd4c4;
    --paper:#eef4f1;
    --paper-dim:#aec4bd;
    --paper-faint:#7e978f;
    --gold:#b8a06a;
    --ink:#173a32;
    --surface:#132d31;
    --maxw:1240px;
  }
  *{margin:0;padding:0;box-sizing:border-box;}
  html{scroll-behavior:smooth;}
  body{
    background:var(--bg);
    color:var(--paper);
    font-family:'Hanken Grotesk',sans-serif;
    font-weight:300;
    line-height:1.65;
    -webkit-font-smoothing:antialiased;
    overflow-x:hidden;
  }
  ::selection{background:rgba(95,174,157,.3);color:#fff;}

  /* grain + atmosphere */
  body::before{
    content:"";position:fixed;inset:0;z-index:0;pointer-events:none;opacity:.04;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  }

  .wrap{max-width:var(--maxw);margin:0 auto;padding:0 32px;position:relative;z-index:1;}
  @media(max-width:640px){.wrap{padding:0 20px;}}

  /* ---------- TYPE ---------- */
  .eyebrow{font-family:'Tenor Sans',sans-serif;text-transform:uppercase;letter-spacing:.36em;font-size:11px;color:var(--teal);display:inline-block;}
  h1,h2,h3{font-family:'Fraunces',serif;font-weight:300;line-height:1.06;letter-spacing:-.01em;}
  h2{font-size:clamp(30px,4.6vw,54px);}
  h3{font-size:clamp(22px,2.6vw,30px);font-weight:400;}
  .lead{font-size:clamp(16px,1.5vw,19px);color:var(--paper-dim);max-width:60ch;}
  .small{font-size:13.5px;color:var(--paper-faint);}
  em{font-style:normal;color:var(--teal);}
  .serif-accent{font-family:'Fraunces',serif;font-style:italic;font-weight:300;}

  /* ---------- LOGO ---------- */
  .logo{display:grid;grid-template-columns:auto 1fr;align-items:start;text-decoration:none;padding:4px 0;}
  .logo-row{display:contents;}
  .logo svg{grid-column:1;grid-row:1/span 2;display:block;flex-shrink:0;width:37px;height:30px;margin-top:1.5px;margin-left:-7px;margin-right:1px;}
  .logo-name{grid-column:2;grid-row:1;font-family:'Tenor Sans',sans-serif;text-transform:uppercase;font-size:21px;letter-spacing:.04em;color:var(--paper);-webkit-text-stroke:.5px var(--paper);line-height:1;margin-top:0;}
  .logo-health{grid-column:2;grid-row:2;font-family:'Tenor Sans',sans-serif;text-transform:uppercase;font-size:11px;letter-spacing:.32em;color:var(--teal);-webkit-text-stroke:.5px var(--teal);line-height:1;margin-top:1px;margin-left:0;}

  /* ---------- BUTTONS ---------- */
  .btn{font-family:'Tenor Sans',sans-serif;text-transform:uppercase;letter-spacing:.18em;font-size:12px;padding:15px 26px;border-radius:2px;display:inline-flex;align-items:center;gap:10px;text-decoration:none;cursor:pointer;border:1px solid transparent;transition:.35s cubic-bezier(.2,.8,.2,1);white-space:nowrap;}
  .btn-primary{background:var(--teal);color:#06100f;}
  .btn-primary:hover{background:var(--mint);transform:translateY(-2px);box-shadow:0 12px 30px -12px rgba(95,174,157,.6);}
  .btn-ghost{border-color:var(--line);color:var(--paper);background:transparent;}
  .btn-ghost:hover{border-color:var(--teal);color:var(--teal);background:rgba(95,174,157,.05);}
  .btn .arr{transition:transform .35s;}
  .btn:hover .arr{transform:translateX(4px);}

  /* ---------- NAV ---------- */
  nav{position:sticky;top:0;z-index:50;background:rgba(10,21,23,.82);backdrop-filter:blur(14px);border-bottom:1px solid var(--line-soft);}
  .nav-in{display:flex;align-items:center;justify-content:space-between;gap:24px;padding:16px 32px;max-width:var(--maxw);margin:0 auto;}
  .logo{flex-shrink:0;}
  .nav-right{display:flex;align-items:center;gap:14px;min-width:0;flex:1;justify-content:flex-end;}
  .nav-auth{margin-left:auto;}
  .nav-links{display:flex;gap:12px;align-items:center;}
  .nav-links a{font-family:'Tenor Sans',sans-serif;text-transform:uppercase;letter-spacing:.048em;font-size:11px;color:var(--paper-dim);text-decoration:none;transition:.25s;position:relative;padding:4px 0;white-space:nowrap;}
  .nav-links a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:1px;background:var(--teal);transition:width .3s;}
  .nav-links a:hover{color:var(--paper);}
  .nav-links a:hover::after{width:100%;}
  .nav-cta{flex-shrink:0;padding:10px 16px;font-size:10.5px;letter-spacing:.096em;gap:7px;}
  .nav-signin{flex-shrink:0;padding:10px 16px;font-size:10.5px;letter-spacing:.096em;border-color:transparent;color:var(--paper);font-weight:600;}
  .nav-signin:hover{border-color:var(--line);color:var(--paper);background:rgba(255,255,255,.02);}
  /* hamburger */
  .nav-toggle{display:none;flex-direction:column;justify-content:center;gap:5px;width:42px;height:42px;border:1px solid var(--line);border-radius:3px;background:transparent;cursor:pointer;flex-shrink:0;}
  .nav-toggle span{display:block;width:18px;height:1.5px;background:var(--paper);margin:0 auto;transition:.3s;}
  .nav-toggle.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg);}
  .nav-toggle.open span:nth-child(2){opacity:0;}
  .nav-toggle.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg);}
  /* mobile dropdown */
  .mobile-menu{display:none;flex-direction:column;background:rgba(9,19,21,.98);backdrop-filter:blur(14px);border-bottom:1px solid var(--line);overflow:hidden;max-height:0;transition:max-height .4s cubic-bezier(.2,.8,.2,1);}
  .mobile-menu.open{max-height:520px;}
  .mobile-menu a{font-family:'Tenor Sans',sans-serif;text-transform:uppercase;letter-spacing:.16em;font-size:13px;color:var(--paper-dim);text-decoration:none;padding:16px 32px;border-bottom:1px solid var(--line-soft);transition:.2s;}
  .mobile-menu a:hover,.mobile-menu a:active{color:var(--teal);background:rgba(95,174,157,.06);}
  .mobile-menu .btn{margin:18px 32px 24px;justify-content:center;}

  @media(max-width:1100px){
    .nav-links{display:none;}
    .nav-toggle{display:flex;width:36px;height:36px;gap:4px;}
    .nav-toggle span{width:15px;}
    .nav-toggle.open span:nth-child(1){transform:translateY(5.5px) rotate(45deg);}
    .nav-toggle.open span:nth-child(3){transform:translateY(-5.5px) rotate(-45deg);}
    .mobile-menu{display:flex;}
    
    /* Mobile Logo scale */
    .logo-name{font-size:18px;margin-top:0;}
    .logo-health{font-size:9px;margin-top:1px;margin-left:0;}
    .logo svg{width:31px;height:26px;margin-top:1px;margin-left:-5px;margin-right:2px;}
    .logo{padding:3px 0;}

    /* Mobile CTA configuration */
    .nav-main .nav-signin{display:none;}
    .nav-main .nav-cta{
      padding: 6px 10px !important;
      font-size: 9px !important;
      letter-spacing: .05em;
    }
  }
  @media(min-width:1101px){
    .mobile-menu{display:none !important;}
  }
  @media(max-width:640px){.nav-in{padding:14px 20px;gap:16px;}.mobile-menu a{padding:16px 20px;}.mobile-menu .btn{margin:18px 20px 24px;}}


  /* ---------- HERO ---------- */
  .hero{position:relative;padding:clamp(30px,4vh,56px) 0 clamp(12px,2vh,24px);overflow:hidden;}

  /* founding hero variant */
  .hero--founding{text-align:center;}
  .founding-hero{position:relative;z-index:1;max-width:780px;margin:0 auto;display:flex;flex-direction:column;align-items:center;}
  .founding-flag{display:inline-flex;align-items:center;gap:8px;font-family:'Tenor Sans',sans-serif;text-transform:uppercase;letter-spacing:.28em;font-size:10.5px;color:var(--teal);background:rgba(95,174,157,.1);border:1px solid rgba(95,174,157,.25);border-radius:2px;padding:7px 16px;margin-bottom:20px;}
  .hero--founding h1{font-size:clamp(38px,6.2vw,78px);margin:0 0 26px;}
  .hero--founding h1 .it{font-style:italic;color:var(--teal);}
  .hero--founding .lead{text-align:center;max-width:56ch;margin:0 auto;}
  .hero--founding .hero-ctas{justify-content:center;margin-top:24px;}

  /* ---------- HOW IT WORKS — static section ---------- */
  .hiw-lead{text-align:center;font-family:'Fraunces',Georgia,serif;font-style:italic;font-size:22px;color:rgba(159,212,196,.75);padding:0 0 8px;}
  #hp{max-width:900px;margin:0 auto;padding:20px 26px clamp(64px,9vh,120px);}
  #hp .row{display:flex;gap:12px;}
  #hp .col{flex:1;display:flex;flex-direction:column;align-items:center;text-align:center;opacity:.38;transition:opacity .45s ease;}
  #hp .col.on{opacity:1;}
  #hp .vis{height:148px;display:flex;align-items:center;justify-content:center;position:relative;margin-bottom:12px;}
  #hp .snum{font-family:'Fraunces',Georgia,serif;font-style:italic;font-size:12px;color:var(--teal);opacity:.6;transition:opacity .4s;}
  #hp .col.on .snum{opacity:1;}
  #hp .stit{font-family:'Fraunces',Georgia,serif;font-size:13px;color:rgba(238,244,241,.6);margin:4px 0 3px;line-height:1.12;transition:color .4s;}
  #hp .col.on .stit{color:#eef4f1;}
  #hp .sbl{font-size:9px;line-height:1.35;color:rgba(238,244,241,.4);max-width:104px;}
  #hp .acard{width:92px;background:#12292d;border:1px solid rgba(159,212,196,.12);border-radius:10px;padding:12px;}
  #hp .av2{width:22px;height:22px;border-radius:50%;border:1.4px solid #5fae9d;margin-bottom:9px;}
  #hp .ln2{height:5px;border-radius:3px;background:rgba(159,212,196,.16);margin:5px 0;}
  #hp .chip2{display:inline-block;margin-top:7px;font-family:'Tenor Sans',sans-serif;font-size:7px;letter-spacing:.12em;color:#b8a06a;border:1px solid rgba(184,160,106,.4);border-radius:4px;padding:3px 6px;opacity:0;transition:opacity .5s .25s;}
  #hp .col.on .chip2{opacity:1;}
  #hp .fcard{width:96px;background:#12292d;border:1px solid rgba(159,212,196,.12);border-radius:10px;padding:11px;}
  #hp .frow2{display:flex;align-items:center;gap:6px;margin:7px 0;}
  #hp .flab2{width:22px;height:5px;border-radius:3px;background:rgba(238,244,241,.2);flex:none;}
  #hp .fbar2{height:7px;border-radius:4px;background:rgba(95,174,157,.55);transform:scaleX(.12);transform-origin:left;transition:transform .7s cubic-bezier(.6,0,.3,1);}
  #hp .col.on .fbar2{transform:scaleX(1);}
  #hp .vcap{width:22px;height:6px;border:1.4px solid #5fae9d;border-radius:3px;margin:0 auto 2px;}
  #hp .vbody{position:relative;width:17px;height:58px;border:1.4px solid #5fae9d;border-radius:9px;overflow:hidden;margin:0 auto;}
  #hp .liq{position:absolute;left:0;right:0;bottom:0;height:0;background:rgba(208,93,73,.5);transition:height 1s ease .15s;}
  #hp .col.on .liq{height:30px;}
  #hp .vchip{margin-top:11px;font-family:'Tenor Sans',sans-serif;font-size:7px;letter-spacing:.1em;color:#9fd4c4;border:1px solid rgba(159,212,196,.3);border-radius:4px;padding:3px 6px;opacity:0;transition:opacity .5s .3s;}
  #hp .col.on .vchip{opacity:1;}
  #hp .field{position:relative;width:108px;height:140px;}
  #hp .dd{position:absolute;border-radius:50%;background:#5fae9d;transition:transform 1s cubic-bezier(.7,0,.2,1),opacity .7s ease;}
  #hp .vrb2{width:106px;}
  #hp .rlab2{font-family:'Tenor Sans',sans-serif;font-size:6.5px;letter-spacing:.1em;color:rgba(238,244,241,.42);margin-bottom:3px;text-align:left;}
  #hp .rb2{position:relative;height:8px;border-radius:5px;margin-bottom:14px;}
  #hp .rbo2{position:absolute;top:-3px;bottom:-3px;border-left:1.4px solid rgba(159,212,196,.5);border-right:1.4px solid rgba(159,212,196,.5);background:rgba(159,212,196,.06);}
  #hp .rbd2{position:absolute;top:50%;left:6%;width:11px;height:11px;border-radius:50%;transform:translate(-50%,-50%);border:2px solid #0a1517;transition:left 1s cubic-bezier(.6,0,.3,1) .1s;}
  #hp .col.on .rbd2{left:var(--t);}
  #hp .rxcard{width:96px;background:#12292d;border:1px solid rgba(159,212,196,.12);border-radius:10px;padding:11px 12px;}
  #hp .rx-head{font-family:'Fraunces',Georgia,serif;font-style:italic;font-size:16px;color:var(--teal);margin-bottom:8px;border-bottom:1px solid rgba(159,212,196,.15);padding-bottom:6px;}
  #hp .rx-row{display:flex;align-items:center;gap:6px;margin:6px 0;opacity:0;transform:translateX(-4px);transition:opacity .5s ease,transform .5s ease;}
  #hp .col.on .rx-row{opacity:1;transform:translateX(0);}
  #hp .col.on .rx-row:nth-child(2){transition-delay:.1s;}
  #hp .col.on .rx-row:nth-child(3){transition-delay:.2s;}
  #hp .col.on .rx-row:nth-child(4){transition-delay:.3s;}
  #hp .rx-dot{width:4px;height:4px;border-radius:50%;background:var(--teal);flex-shrink:0;}
  #hp .rx-name{font-family:'Tenor Sans',sans-serif;font-size:8px;letter-spacing:.06em;color:rgba(238,244,241,.75);}
  #hp .rail{position:relative;height:2px;background:rgba(159,212,196,.12);margin:6px 4px 0;}
  #hp .fill{position:absolute;left:0;top:0;height:2px;background:var(--teal);}

  /* Mobile: vertical stack */
  @media(max-width:899px){
    #hp{padding:0 20px 20px;}
    #hp .row{flex-direction:column;gap:40px;}
  }
  .hero-bg{position:absolute;inset:0;z-index:0;pointer-events:none;}
  .hero-bg .glow{position:absolute;border-radius:50%;filter:blur(90px);opacity:.5;}
  .hero-bg .g1{width:520px;height:520px;background:radial-gradient(circle,#15453d,transparent 70%);top:-120px;right:-80px;}
  .hero-bg .g2{width:420px;height:420px;background:radial-gradient(circle,#123244,transparent 70%);bottom:-100px;left:-120px;opacity:.4;}
  .hero-helix{position:absolute;right:2%;top:50%;transform:translateY(-50%);opacity:.16;z-index:0;}
  @media(max-width:900px){.hero-helix{display:none;}}
  .hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:48px;align-items:center;position:relative;z-index:1;}
  @media(max-width:900px){.hero-grid{grid-template-columns:1fr;}}
  .hero h1{font-size:clamp(40px,6.4vw,82px);margin:22px 0 24px;}
  .hero h1 .it{font-style:italic;color:var(--teal);}
  .hero-ctas{display:flex;gap:14px;margin-top:36px;flex-wrap:wrap;}
  .hero-meta{margin-top:40px;display:flex;gap:30px;flex-wrap:wrap;}
  .hero-meta .m{border-left:1px solid var(--line);padding-left:16px;}
  .hero-meta .m b{display:block;font-family:'Fraunces',serif;font-size:30px;font-weight:400;color:var(--paper);line-height:1;}
  .hero-meta .m span{font-family:'Tenor Sans',sans-serif;font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--paper-faint);}

  /* hero card */
  .hero-card{background:linear-gradient(160deg,var(--panel),var(--panel-2));border:1px solid var(--line);border-radius:6px;padding:30px;position:relative;overflow:hidden;}
  .hero-card::before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--teal),transparent);}
  .hero-card .eyebrow{margin-bottom:18px;}
  .hcrow{display:flex;justify-content:space-between;align-items:center;padding:13px 0;border-bottom:1px solid var(--line-soft);}
  .hcrow:last-child{border-bottom:none;}
  .hcrow .lbl{font-size:14px;color:var(--paper-dim);}
  .hcrow .val{font-family:'Tenor Sans',sans-serif;font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--teal);}
  .hcrow .val.val-high{color:#c96f6f;}
  .hcrow .val.val-low{color:var(--gold);}
  .hcrow .bar{flex:1;height:3px;background:rgba(255,255,255,.06);border-radius:2px;margin:0 16px;overflow:hidden;position:relative;}
  .hcrow .bar i{position:absolute;left:0;top:0;bottom:0;background:linear-gradient(90deg,var(--steel),var(--teal));border-radius:2px;width:0;transition:width 1.4s cubic-bezier(.2,.8,.2,1);}

  /* ---------- SECTION SCAFFOLD ---------- */
  section{position:relative;padding:clamp(64px,9vh,120px) 0;}
  .sec-head{max-width:760px;margin-bottom:54px;}
  .sec-head h2{margin:16px 0 18px;}
  .divider{height:1px;background:var(--line-soft);}

  /* stat strip */
  .stats{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:linear-gradient(90deg,#0b181a,#0d1f22,#0b181a);}
  .stats-in{display:grid;grid-template-columns:repeat(4,1fr);}
  @media(max-width:760px){.stats-in{grid-template-columns:repeat(2,1fr);}}
  .stat{padding:42px 28px;border-right:1px solid var(--line-soft);}
  .stat:last-child{border-right:none;}
  .stat b{font-family:'Fraunces',serif;font-weight:300;font-size:clamp(34px,4.4vw,52px);color:var(--paper);display:block;line-height:1;}
  .stat b em{color:var(--teal);font-style:normal;}
  .stat span{font-family:'Tenor Sans',sans-serif;font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--paper-faint);display:block;margin-top:12px;}

  /* ---------- COMPARISON ---------- */
  .cmp-wrap{display:grid;grid-template-columns:1fr 1fr;gap:24px;}
  @media(max-width:820px){.cmp-wrap{grid-template-columns:1fr;}}
  .cmp{border:1px solid var(--line);border-radius:6px;overflow:hidden;background:var(--panel-2);}
  .cmp.full{border-color:rgba(95,174,157,.4);box-shadow:0 24px 60px -40px rgba(95,174,157,.4);}
  .cmp-top{padding:26px 28px;border-bottom:1px solid var(--line-soft);}
  .cmp.full .cmp-top{background:linear-gradient(135deg,#143a34,#10262a);}
  .cmp-top .tag{font-family:'Tenor Sans',sans-serif;font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--paper-faint);}
  .cmp.full .cmp-top .tag{color:var(--teal);}
  .cmp-top h3{margin-top:8px;}
  .cmp-top .cnt{font-size:13px;color:var(--paper-dim);margin-top:6px;}
  .cmp ul{list-style:none;padding:14px 28px 26px;}
  .cmp li{display:flex;align-items:flex-start;gap:12px;padding:9px 0;font-size:14.5px;color:var(--paper-dim);border-bottom:1px solid rgba(255,255,255,.03);}
  .cmp li:last-child{border-bottom:none;}
  .cmp li .ic{flex-shrink:0;width:18px;height:18px;margin-top:2px;}
  .cmp li.no{color:var(--paper-faint);}
  .cmp li.no .lbltxt{opacity:.6;}
  .cmp li b{color:var(--paper);font-weight:500;}

  /* ---------- HOW IT WORKS ---------- */
  .steps{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line-soft);border:1px solid var(--line);border-radius:6px;overflow:hidden;}
  @media(max-width:900px){.steps{grid-template-columns:repeat(2,1fr);}}
  @media(max-width:540px){.steps{grid-template-columns:1fr;}}
  .step{background:var(--bg-2);padding:36px 28px;position:relative;transition:.4s;}
  .step:hover{background:var(--panel-2);}
  .step .no{font-family:'Fraunces',serif;font-style:italic;font-size:15px;color:var(--teal);}
  .step h3{font-size:21px;margin:16px 0 10px;}
  .step p{font-size:14px;color:var(--paper-dim);}
  .step .ic{margin-top:18px;color:var(--teal);opacity:.9;}

  /* ---------- OUTCOMES ---------- */
  .outcomes{display:grid;grid-template-columns:repeat(5,1fr);gap:18px;}
  @media(max-width:900px){.outcomes{grid-template-columns:repeat(3,1fr);}}
  @media(max-width:560px){.outcomes{grid-template-columns:repeat(2,1fr);}}
  .oc{border:1px solid var(--line-soft);border-radius:6px;padding:28px 22px;text-align:center;background:var(--panel-2);transition:.4s;}
  .oc:hover{transform:translateY(-4px);border-color:var(--teal);}
  .oc .ic{color:var(--teal);margin-bottom:16px;}
  .oc h3{font-size:18px;margin-bottom:6px;}
  .oc p{font-size:12.5px;color:var(--paper-faint);}

  /* ---------- PILLAR SECTIONS ---------- */
  .pillar-head{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:end;margin-bottom:50px;}
  @media(max-width:820px){.pillar-head{grid-template-columns:1fr;gap:24px;}}
  .card-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
  @media(max-width:900px){.card-grid{grid-template-columns:repeat(2,1fr);}}
  @media(max-width:560px){.card-grid{grid-template-columns:1fr;}}
  .card{border:1px solid var(--line);border-radius:6px;padding:28px;background:linear-gradient(160deg,var(--panel),var(--panel-2));transition:.4s;position:relative;overflow:hidden;}
  .card:hover{transform:translateY(-5px);border-color:rgba(95,174,157,.45);box-shadow:0 28px 60px -40px rgba(0,0,0,.7);}
  .card .ct{font-family:'Tenor Sans',sans-serif;font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--teal);}
  .card h3{font-size:22px;margin:10px 0 6px;}
  .card .sub{font-size:12px;color:var(--paper-faint);font-family:'Tenor Sans',sans-serif;letter-spacing:.08em;text-transform:uppercase;margin-bottom:14px;}
  .card p{font-size:13.5px;color:var(--paper-dim);}
  .card .meta{margin-top:18px;padding-top:16px;border-top:1px solid var(--line-soft);display:flex;flex-direction:column;gap:8px;}
  .card .meta .mr{display:flex;justify-content:space-between;font-size:12px;}
  .card .meta .mr span{color:var(--paper-faint);font-family:'Tenor Sans',sans-serif;letter-spacing:.06em;text-transform:uppercase;font-size:10px;}
  .card .meta .mr b{color:var(--paper);font-weight:500;}

  .info-2{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;margin-top:56px;}
  @media(max-width:820px){.info-2{grid-template-columns:1fr;gap:32px;}}
  .feature-list{list-style:none;}
  .feature-list li{display:flex;gap:14px;padding:16px 0;border-bottom:1px solid var(--line-soft);}
  .feature-list li:last-child{border-bottom:none;}
  .feature-list .ic{color:var(--teal);flex-shrink:0;margin-top:3px;}
  .feature-list h4{font-family:'Fraunces',serif;font-weight:400;font-size:18px;margin-bottom:3px;}
  .feature-list p{font-size:13.5px;color:var(--paper-dim);}

  /* ---------- CHART ---------- */
  .chart-card{border:1px solid var(--line);border-radius:6px;padding:34px;background:var(--panel-2);}
  .chart-card .eyebrow{margin-bottom:8px;}
  .chart-card h3{margin-bottom:30px;}
  .bars{display:flex;flex-direction:column;gap:22px;}
  .bar-row .bl{display:flex;justify-content:space-between;margin-bottom:8px;align-items:baseline;}
  .bar-row .bl .nm{font-size:13.5px;color:var(--paper);}
  .bar-row .bl .nm small{color:var(--paper-faint);font-size:11px;display:block;font-family:'Tenor Sans',sans-serif;letter-spacing:.06em;text-transform:uppercase;}
  .bar-row .bl .pct{font-family:'Fraunces',serif;font-size:24px;color:var(--teal);}
  .bar-track{height:12px;background:rgba(255,255,255,.05);border-radius:6px;overflow:hidden;}
  .bar-track i{display:block;height:100%;border-radius:6px;background:linear-gradient(90deg,var(--steel),var(--teal));width:0;transition:width 1.4s cubic-bezier(.2,.8,.2,1);}
  .bar-row.alt .bar-track i{background:linear-gradient(90deg,#2c5f6e,#4a8a99);}
  .bar-row.muted .bar-track i{background:rgba(255,255,255,.16);}
  .chart-note{font-size:11.5px;color:var(--paper-faint);margin-top:24px;line-height:1.5;}

  /* timing chart (peptides) */
  .timing{display:flex;align-items:flex-end;gap:14px;height:160px;padding:16px 0;border-bottom:1px solid var(--line);}
  .timing .t{flex:1;display:flex;flex-direction:column;align-items:center;gap:8px;height:100%;justify-content:flex-end;}
  .timing .t .col{width:70%;background:linear-gradient(180deg,var(--teal),var(--steel));border-radius:3px 3px 0 0;transition:height 1.2s cubic-bezier(.2,.8,.2,1);height:0;}
  .timing .t small{font-size:10px;color:var(--paper-faint);font-family:'Tenor Sans',sans-serif;letter-spacing:.05em;}

  /* ---------- RESEARCH ---------- */
  .ref-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;}
  @media(max-width:900px){.ref-grid{grid-template-columns:repeat(2,1fr);}}
  @media(max-width:560px){.ref-grid{grid-template-columns:1fr;}}
  .ref{border:1px solid var(--line-soft);border-radius:6px;padding:24px;background:var(--panel-2);text-decoration:none;display:block;transition:.35s;}
  .ref:hover{border-color:var(--teal);transform:translateY(-3px);}
  .ref .src{font-family:'Tenor Sans',sans-serif;font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--teal);}
  .ref h4{font-family:'Fraunces',serif;font-weight:400;font-size:16px;margin:10px 0 8px;color:var(--paper);line-height:1.3;}
  .ref p{font-size:12.5px;color:var(--paper-dim);}
  .ref .jr{margin-top:14px;font-size:11px;color:var(--paper-faint);font-family:'Tenor Sans',sans-serif;letter-spacing:.08em;text-transform:uppercase;}

  /* ---------- LOCATION ---------- */
  .loc-grid{display:grid;grid-template-columns:1fr 1fr;gap:0;border:1px solid var(--line);border-radius:6px;overflow:hidden;}
  @media(max-width:820px){.loc-grid{grid-template-columns:1fr;}}
  .loc-side{padding:44px;}
  .loc-side.map{background:linear-gradient(135deg,#0e2125,#0a1517);position:relative;min-height:360px;display:flex;flex-direction:column;justify-content:center;border-left:1px solid var(--line-soft);}
  @media(max-width:820px){.loc-side.map{border-left:none;border-top:1px solid var(--line-soft);}}
  .loc-side h3{margin:14px 0 18px;}
  .loc-detail{display:flex;gap:14px;padding:14px 0;border-bottom:1px solid var(--line-soft);}
  .loc-detail:last-child{border-bottom:none;}
  .loc-detail .ic{color:var(--teal);flex-shrink:0;margin-top:2px;}
  .loc-detail .lbl{font-family:'Tenor Sans',sans-serif;font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--paper-faint);}
  .loc-detail .v{font-size:15px;color:var(--paper);}
  .map-pin{display:flex;flex-direction:column;align-items:center;gap:16px;text-align:center;}
  .map-grid-lines{position:absolute;inset:0;background-image:linear-gradient(var(--line-soft) 1px,transparent 1px),linear-gradient(90deg,var(--line-soft) 1px,transparent 1px);background-size:40px 40px;opacity:.5;}
  .two-ways{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:46px;}
  @media(max-width:640px){.two-ways{grid-template-columns:1fr;}}
  .way{border:1px solid var(--line);border-radius:6px;padding:30px;background:var(--panel-2);position:relative;overflow:hidden;}
  .way::before{content:"";position:absolute;top:0;left:0;width:3px;height:100%;background:var(--teal);}
  .way .ic{color:var(--teal);margin-bottom:16px;}
  .way h3{font-size:22px;margin-bottom:10px;}
  .way p{font-size:14px;color:var(--paper-dim);margin-bottom:18px;}

  /* ---------- TEAM / NP ---------- */
  .np{display:grid;grid-template-columns:.8fr 1.2fr;gap:48px;align-items:center;border:1px solid var(--line);border-radius:6px;background:linear-gradient(160deg,var(--panel),var(--panel-2));overflow:hidden;}
  @media(max-width:760px){.np{grid-template-columns:1fr;}}
  .np-photo{min-height:360px;background:linear-gradient(160deg,#143a34,#0c1c1f);display:flex;align-items:center;justify-content:center;position:relative;}
  .np-photo .ring{width:150px;height:150px;border:1px solid var(--teal);border-radius:50%;display:flex;align-items:center;justify-content:center;opacity:.9;}
  .np-photo .ring .inner{font-family:'Fraunces',serif;font-size:54px;color:var(--teal);font-weight:300;}
  .np-body{padding:44px;}
  .np-body h3{margin:14px 0 16px;}
  .np-body p{font-size:14.5px;color:var(--paper-dim);margin-bottom:16px;}
  .creds{display:flex;gap:24px;flex-wrap:wrap;margin-top:22px;}
  .creds .c b{font-family:'Fraunces',serif;font-size:26px;color:var(--teal);font-weight:400;display:block;line-height:1;}
  .creds .c span{font-family:'Tenor Sans',sans-serif;font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--paper-faint);}

  /* ---------- CTA ---------- */
  .cta{background:linear-gradient(135deg,#10302a,#0c1f22);border-top:1px solid var(--line);border-bottom:1px solid var(--line);position:relative;overflow:hidden;}
  .cta .glow{position:absolute;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,#1a4d44,transparent 70%);filter:blur(80px);opacity:.4;top:50%;left:50%;transform:translate(-50%,-50%);}
  .cta-in{text-align:center;position:relative;z-index:1;max-width:740px;margin:0 auto;}
  .cta h2{margin:18px 0 22px;}
  .cta .hero-ctas{justify-content:center;}

  /* ---------- FOOTER ---------- */
  footer{background:var(--bg-2);border-top:1px solid var(--line);padding:70px 0 36px;}
  .foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:40px;margin-bottom:50px;}
  @media(max-width:820px){.foot-grid{grid-template-columns:1fr 1fr;gap:32px;}}
  @media(max-width:480px){.foot-grid{grid-template-columns:1fr;}}
  .foot-col h5{font-family:'Tenor Sans',sans-serif;font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--paper);margin-bottom:18px;}
  .foot-col a{display:block;color:var(--paper-faint);text-decoration:none;font-size:13.5px;padding:6px 0;transition:.25s;}
  .foot-col a:hover{color:var(--teal);}
  .foot-about .logo{display:grid;width:fit-content;}
  .foot-about p{font-size:13.5px;color:var(--paper-faint);margin-top:18px;max-width:34ch;}
  .disclaimer{border-top:1px solid var(--line-soft);padding-top:28px;font-size:11.5px;color:var(--paper-faint);line-height:1.7;}
  .disclaimer p{margin-bottom:12px;}
  .foot-bottom{display:flex;justify-content:space-between;align-items:center;margin-top:28px;flex-wrap:wrap;gap:16px;}
  .foot-bottom .cp{font-size:11.5px;color:var(--paper-faint);font-family:'Tenor Sans',sans-serif;letter-spacing:.08em;}

  /* reveal */
  .reveal{opacity:0;transform:translateY(26px);transition:opacity .9s cubic-bezier(.2,.8,.2,1),transform .9s cubic-bezier(.2,.8,.2,1);}
  .reveal.in{opacity:1;transform:none;}
  .stagger>*{opacity:0;transform:translateY(20px);transition:opacity .7s cubic-bezier(.2,.8,.2,1),transform .7s cubic-bezier(.2,.8,.2,1);}
  .stagger.in>*{opacity:1;transform:none;}
  .stagger.in>*:nth-child(2){transition-delay:.08s;}
  .stagger.in>*:nth-child(3){transition-delay:.16s;}
  .stagger.in>*:nth-child(4){transition-delay:.24s;}
  .stagger.in>*:nth-child(5){transition-delay:.32s;}
  .stagger.in>*:nth-child(6){transition-delay:.4s;}

  /* ---------- FORMS & INPUTS ---------- */
  .auth-wrap {
    display: none;
    min-height: 70vh;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 60px 20px;
    position: relative;
    z-index: 1;
  }
  .auth-wrap.visible {
    display: flex;
  }
  .auth-card {
    width: 100%;
    max-width: 440px;
    background: linear-gradient(160deg,var(--panel),var(--panel-2));
    border: 1px solid var(--line);
    border-radius: 6px;
    padding: 40px clamp(20px, 5vw, 36px);
    position: relative;
    overflow: hidden;
  }
  .auth-card::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 1px;
    background: linear-gradient(90deg,transparent,var(--teal),transparent);
  }
  .form-group {
    margin-bottom: 20px;
    position: relative;
  }
  .form-consent {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    font-family: 'Hanken Grotesk', sans-serif;
    font-size: 12.5px;
    font-weight: 300;
    line-height: 1.5;
    color: var(--paper-dim);
    cursor: pointer;
  }
  .form-consent input[type="checkbox"] {
    margin-top: 2px;
    flex-shrink: 0;
    accent-color: var(--teal);
  }
  .form-consent a {
    color: var(--teal);
    text-decoration: underline;
    text-underline-offset: 2px;
  }
  .form-consent a:hover {
    color: var(--paper);
  }
  .form-label {
    display: block;
    font-family: 'Tenor Sans', sans-serif;
    text-transform: uppercase;
    letter-spacing: .18em;
    font-size: 10px;
    color: var(--paper-dim);
    margin-bottom: 8px;
  }
  .form-control {
    width: 100%;
    background: var(--bg);
    border: 1px solid var(--line);
    border-radius: 2px;
    color: var(--paper);
    font-family: 'Hanken Grotesk', sans-serif;
    font-weight: 300;
    font-size: 14.5px;
    padding: 13px 16px;
    transition: border-color .3s, box-shadow .3s;
    outline: none;
  }
  .form-control:focus {
    border-color: var(--teal);
    box-shadow: 0 0 12px rgba(95,174,157,.12);
  }
  .form-control::placeholder {
    color: var(--paper-faint);
    opacity: 0.6;
  }
  .form-control:-webkit-autofill,
  .form-control:-webkit-autofill:hover,
  .form-control:-webkit-autofill:focus,
  select.form-control:-webkit-autofill {
    -webkit-text-fill-color: var(--paper);
    -webkit-box-shadow: 0 0 0 1000px var(--bg) inset;
    transition: background-color 5000s ease-in-out 0s;
    caret-color: var(--paper);
    font-family: 'Hanken Grotesk', sans-serif;
    font-size: 14.5px;
  }
  .form-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-top: -4px;
    margin-bottom: 20px;
  }
  .form-link {
    font-family: 'Tenor Sans', sans-serif;
    font-size: 10px;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: var(--teal);
    text-decoration: none;
    transition: color .25s;
  }
  .form-link:hover {
    color: var(--mint);
  }
  .btn-submit {
    width: 100%;
    justify-content: center;
    margin-top: 8px;
  }
  .google-btn {
    width: 100%;
    justify-content: center;
    margin-top: 16px;
    gap: 12px;
  }
  .google-icon {
    width: 16px;
    height: 16px;
    fill: currentColor;
  }
  .auth-switch {
    text-align: center;
    margin-top: 24px;
    font-size: 13.5px;
    color: var(--paper-dim);
  }
  .auth-switch a {
    color: var(--teal);
    text-decoration: none;
    font-family: 'Tenor Sans', sans-serif;
    text-transform: uppercase;
    font-size: 11px;
    letter-spacing: .08em;
    margin-left: 6px;
    transition: color .25s;
  }
  .auth-switch a:hover {
    color: var(--mint);
  }
  .password-strength-meter {
    height: 3px;
    background: rgba(255,255,255,.05);
    border-radius: 2px;
    margin-top: 8px;
    overflow: hidden;
    position: relative;
  }
  .password-strength-bar {
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 0;
    border-radius: 2px;
    transition: width 0.3s, background-color 0.3s;
  }
  .password-strength-text {
    font-size: 11px;
    color: var(--paper-faint);
    margin-top: 6px;
    display: block;
  }
  .pwd-toggle {
    position: absolute;
    right: 14px;
    bottom: 12px;
    background: none;
    border: none;
    color: var(--paper-faint);
    cursor: pointer;
    font-family: 'Tenor Sans', sans-serif;
    font-size: 10px;
    text-transform: uppercase;
    letter-spacing: .1em;
    padding: 4px;
    transition: color 0.2s;
  }
  .pwd-toggle:hover {
    color: var(--teal);
  }
  .auth-alert {
    background: rgba(209, 93, 101, 0.08);
    border: 1px solid #d15d65;
    color: var(--paper);
    padding: 14px 16px;
    border-radius: 2px;
    font-size: 13.5px;
    margin-bottom: 20px;
    display: none;
  }
  .auth-alert.success {
    background: rgba(95, 174, 157, 0.08);
    border: 1px solid var(--teal);
  }
  .auth-view {
    display: none;
  }
  .auth-view.active {
    display: block;
  }
  
  /* Dashboard layout overrides */
  .profile-header {
    display: flex;
    align-items: center;
    gap: 20px;
    margin-bottom: 30px;
    padding-bottom: 20px;
    border-bottom: 1px solid var(--line-soft);
  }
  .profile-avatar {
    width: 64px;
    height: 64px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--steel), var(--teal));
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: 'Fraunces', serif;
    font-size: 28px;
    color: var(--ink);
    font-weight: 400;
  }
  .profile-title h3 {
    font-size: 24px;
  }
  .profile-title p {
    font-size: 13.5px;
    color: var(--paper-dim);
  }
  .meta-list {
    margin-bottom: 30px;
  }

/* ============ NAV AVATAR DROPDOWN ============ */
.nav-avatar-wrap { position: relative; display: flex; align-items: center; }
.nav-avatar { width: 34px; height: 34px; border-radius: 50%; background: linear-gradient(135deg, var(--steel), var(--teal)); color: var(--ink); font-family: 'Fraunces', serif; font-size: 13px; display: flex; align-items: center; justify-content: center; cursor: pointer; user-select: none; border: 1px solid rgba(255,255,255,0.1); transition: transform 0.2s, box-shadow 0.2s; letter-spacing: 0.5px; }
.nav-avatar:hover { transform: translateY(-1px); box-shadow: 0 4px 12px rgba(95,174,157,0.3); }
.nav-dropdown { position: absolute; top: calc(100% + 12px); right: 0; width: 220px; background: rgba(10,21,23,0.97); backdrop-filter: blur(14px); border: 1px solid var(--line); border-radius: 8px; display: flex; flex-direction: column; overflow: hidden; opacity: 0; pointer-events: none; transform: translateY(-10px); transition: opacity 0.2s, transform 0.2s; box-shadow: 0 12px 30px rgba(0,0,0,0.5); z-index: 100; }
.nav-dropdown.open { opacity: 1; pointer-events: auto; transform: translateY(0); }
.nav-dropdown-header { padding: 14px 16px; border-bottom: 1px solid var(--line); }
.nav-dropdown-name { font-family: 'Fraunces', serif; font-size: 14px; color: var(--paper); font-weight: 500; line-height: 1.3; }
.nav-dropdown-email { font-family: 'Inter', sans-serif; font-size: 11px; color: var(--paper-dim); margin-top: 2px; line-height: 1.3; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.nav-dropdown a, .nav-dropdown button { width: 100%; text-align: left; padding: 11px 16px; background: transparent; border: none; font-family: 'Tenor Sans', sans-serif; font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--paper-dim); cursor: pointer; border-bottom: 1px solid var(--line-soft); transition: background 0.2s, color 0.2s; text-decoration: none; display: block; }
.nav-dropdown a:hover, .nav-dropdown button:hover { background: rgba(95,174,157,0.1); color: var(--paper); }
.nav-dropdown *:last-child { border-bottom: none; }

/* ============ CHAT UI ============ */
.intake-progress-container { margin-bottom: 30px; }
.intake-progress-text { font-family: 'Tenor Sans', sans-serif; font-size: 11px; text-transform: uppercase; letter-spacing: 0.1em; color: var(--paper-dim); margin-bottom: 8px; text-align: center; }
.intake-progress-track { height: 4px; background: rgba(255,255,255,0.05); border-radius: 2px; overflow: hidden; }
.intake-progress-fill { height: 100%; background: linear-gradient(90deg, var(--steel), var(--teal)); border-radius: 2px; transition: width 0.4s ease; }

.chat-history { display: flex; flex-direction: column; gap: 20px; padding-bottom: 40px; flex: 1; }
.message-row { display: flex; gap: 12px; align-items: flex-end; }
.message-row.app { justify-content: flex-start; }
.message-row.user { justify-content: flex-end; }

.message-avatar { width: 32px; height: 32px; border-radius: 50%; background: var(--teal); color: var(--bg); display: flex; align-items: center; justify-content: center; font-family: 'Fraunces', serif; font-size: 16px; flex-shrink: 0; }

.chat-bubble { max-width: 85%; padding: 14px 18px; border-radius: 12px; font-size: 15px; line-height: 1.5; position: relative; animation: popIn 0.3s cubic-bezier(0.2, 0.8, 0.2, 1); }
@keyframes popIn { from { opacity: 0; transform: translateY(10px) scale(0.98); } to { opacity: 1; transform: translateY(0) scale(1); } }

.chat-bubble.app { background: var(--panel-2); border: 1px solid var(--line); border-bottom-left-radius: 4px; color: var(--paper); }
.chat-bubble.user { background: var(--teal); color: var(--bg); border-bottom-right-radius: 4px; }

/* Chat Inputs */
.chat-input-area { background: var(--bg-2); border: 1px solid var(--line); border-radius: 8px; padding: 20px; margin-top: 20px; display: flex; flex-direction: column; gap: 16px; animation: popIn 0.3s ease; }
.chat-input-area.hidden { display: none; }
.chat-input-row { display: flex; gap: 12px; align-items: center; flex-wrap: wrap; }
.chat-pill { padding: 10px 18px; border: 1px solid var(--line); border-radius: 20px; background: transparent; color: var(--paper); font-size: 14px; cursor: pointer; transition: 0.2s; user-select: none; }
.chat-pill:hover { border-color: var(--teal); background: rgba(95,174,157,0.05); }
.chat-pill.selected { background: var(--teal); border-color: var(--teal); color: var(--bg); font-weight: 500; }

.chat-confirm-box { display: flex; flex-direction: column; gap: 12px; margin-top: 12px; padding-top: 12px; border-top: 1px solid rgba(255,255,255,0.05); }
.chat-confirm-btns { display: flex; gap: 10px; flex-wrap: wrap; }
.chat-confirm-btns .btn { padding: 8px 16px; font-size: 10.5px; }

/* Summary Screen */
.summary-card { background: var(--panel); border: 1px solid var(--line); border-radius: 8px; padding: 24px; display: flex; flex-direction: column; gap: 16px; margin-top: 10px; animation: popIn 0.3s ease; }
.summary-row { display: flex; justify-content: space-between; align-items: flex-start; padding-bottom: 16px; border-bottom: 1px solid var(--line-soft); }
.summary-row:last-child { border-bottom: none; padding-bottom: 0; }
.summary-content h4 { font-family: 'Tenor Sans', sans-serif; font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--paper-faint); margin-bottom: 6px; }
.summary-content p { font-size: 15px; color: var(--paper); }
.summary-edit { color: var(--teal); font-size: 11px; text-transform: uppercase; letter-spacing: 0.1em; cursor: pointer; border: none; background: transparent; font-family: 'Tenor Sans', sans-serif; }
.summary-edit:hover { text-decoration: underline; }

/* Step 4 Checklist UI */
.checklist-card {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 20px;
  margin-bottom: 16px;
  animation: popIn 0.3s ease;
}
.checklist-header {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 16px;
}
.checklist-icon {
  font-size: 24px;
}
.checklist-title h4 {
  margin: 0 0 4px 0;
  font-family: 'Tenor Sans', sans-serif;
  font-size: 14px;
  letter-spacing: 0.05em;
  color: var(--paper);
}
.checklist-title p {
  margin: 0;
  font-size: 12px;
  color: var(--paper-dim);
}
.checklist-row {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 10px 0;
  border-bottom: 1px solid var(--line-soft);
}
.checklist-row:last-child {
  border-bottom: none;
}
.checklist-row input[type="checkbox"] {
  appearance: none;
  -webkit-appearance: none;
  width: 18px;
  height: 18px;
  border: 1px solid var(--teal);
  border-radius: 4px;
  background: transparent;
  cursor: pointer;
  position: relative;
  flex-shrink: 0;
  margin-top: 2px;
  transition: all 0.2s ease;
}
.checklist-row input[type="checkbox"]:checked {
  background: var(--teal);
}
.checklist-row input[type="checkbox"]:checked::after {
  content: '✓';
  position: absolute;
  color: #000;
  font-size: 14px;
  font-weight: bold;
  left: 3px;
  top: -2px;
}
.checklist-row label {
  font-size: 14px;
  color: var(--paper);
  cursor: pointer;
  flex-grow: 1;
  line-height: 1.4;
}
.checklist-summary-bar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 12px 16px;
  background: rgba(95, 174, 157, 0.05);
  border: 1px solid rgba(95, 174, 157, 0.3);
  border-radius: 8px;
  margin-bottom: 12px;
  cursor: pointer;
  transition: all 0.2s ease;
}
.checklist-summary-bar:hover {
  background: rgba(95, 174, 157, 0.1);
}
.checklist-summary-title {
  font-size: 13px;
  color: var(--teal);
  font-weight: bold;
}
.checklist-summary-count {
  font-size: 12px;
  color: var(--paper-dim);
}

/* Animations */
.slide-wrap {
  overflow: hidden;
  position: relative;
  width: 100%;
}
.slide-enter-right {
  animation: slideRight 200ms ease-out forwards;
}
.slide-enter-left {
  animation: slideLeft 200ms ease-out forwards;
}
@keyframes slideRight {
  0% { transform: translateX(30px); opacity: 0; }
  100% { transform: translateX(0); opacity: 1; }
}
@keyframes slideLeft {
  0% { transform: translateX(-30px); opacity: 0; }
  100% { transform: translateX(0); opacity: 1; }
}

/* Profile Dashboard UI */
.prof-page { max-width: 800px; margin: 40px auto; padding: 0 20px; }
.prof-header { margin-bottom: 30px; display: flex; justify-content: space-between; align-items: flex-end; }
.prof-header h2 { font-family: 'Fraunces', serif; font-size: 28px; font-weight: 300; margin: 0; color: var(--paper); }
.prof-header p { margin: 4px 0 0 0; color: var(--paper-dim); font-size: 14px; }
.prof-card { background: var(--panel); border: 1px solid var(--line); border-radius: 12px; margin-bottom: 24px; overflow: hidden; }
.prof-card-head { padding: 16px 24px; border-bottom: 1px solid var(--line-soft); display: flex; justify-content: space-between; align-items: center; background: rgba(0,0,0,0.1); }
.prof-card-head h3 { margin: 0; font-family: 'Tenor Sans', sans-serif; font-size: 14px; text-transform: uppercase; letter-spacing: 0.1em; color: var(--paper); }
.prof-edit-btn { color: var(--teal); background: none; border: none; font-size: 12px; text-transform: uppercase; letter-spacing: 0.05em; cursor: pointer; display: flex; align-items: center; gap: 6px; }
.prof-edit-btn:hover { text-decoration: underline; }
.prof-card-body { padding: 24px; }
.prof-row { display: flex; padding-bottom: 16px; margin-bottom: 16px; border-bottom: 1px solid rgba(255,255,255,0.05); }
.prof-row:last-child { padding-bottom: 0; margin-bottom: 0; border-bottom: none; }
.prof-label { width: 140px; font-size: 13px; color: var(--paper-dim); flex-shrink: 0; }
.prof-val { font-size: 15px; color: var(--paper); flex-grow: 1; }
.prof-lock { color: var(--gold); margin-left: 6px; font-size: 12px; }
.prof-req-change { font-size: 11px; color: var(--gold); text-decoration: underline; cursor: pointer; margin-left: auto; background: none; border: none; padding: 0; }
.prof-req-change:hover { color: #fff; }
.prof-timestamp { font-size: 11px; color: var(--paper-dim); display: block; margin-top: 12px; text-align: right; font-style: italic; }

/* Inline Edit Forms */
.inline-form { display: none; background: rgba(0,0,0,0.2); padding: 20px; border-radius: 8px; border: 1px solid var(--line-soft); }
.inline-form.active { display: block; }
.prof-display.hidden { display: none; }
.inline-actions { display: flex; gap: 12px; justify-content: flex-end; margin-top: 16px; }

/* Change Request Form */
.cr-form { display: none; background: rgba(234, 179, 8, 0.05); border: 1px solid rgba(234, 179, 8, 0.3); padding: 16px; border-radius: 8px; margin-top: 12px; }
.cr-form.active { display: block; }

/* Secondary Portal Nav */
.portal-nav-bar {
  background: var(--surface);
  border-bottom: 1px solid rgba(255,255,255,0.05);
  position: sticky;
  top: 0;
  z-index: 100;
  box-shadow: 0 4px 20px rgba(0,0,0,0.1);
}
.portal-nav-inner {
  max-width: 1000px;
  margin: 0 auto;
  padding: 0 20px;
  display: flex;
  gap: 24px;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
}
.portal-nav-inner::-webkit-scrollbar { display: none; }

.portal-nav-item {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 16px 0;
  color: var(--paper-dim);
  text-decoration: none;
  font-size: 14px;
  border-bottom: 2px solid transparent;
  transition: all 0.2s ease;
  white-space: nowrap;
}
.portal-nav-item i {
  font-size: 18px;
  color: var(--teal);
  opacity: 0.7;
}
.portal-nav-item:hover {
  color: var(--paper);
}
.portal-nav-item:hover i {
  opacity: 1;
}
.portal-nav-item.active {
  color: var(--paper);
  border-bottom-color: var(--gold);
}
.portal-nav-item.active i {
  color: var(--gold);
  opacity: 1;
}

/* Biomarker Cards */
.bio-card {
  background: rgba(0,0,0,0.2);
  border: 1px solid rgba(255,255,255,0.05);
  border-radius: 8px;
  padding: 24px;
  margin-bottom: 16px;
}
.bio-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: 24px;
}
.bio-title {
  color: var(--teal);
  font-size: 16px;
  font-weight: 600;
  margin: 0 0 6px 0;
}
.bio-desc {
  color: var(--paper-dim);
  font-size: 13px;
  line-height: 1.5;
  margin: 0;
  max-width: 75%;
}
.bio-value-block {
  text-align: right;
}
.bio-value {
  font-size: 28px;
  color: var(--paper);
  font-weight: 500;
  font-family: 'Tenor Sans', sans-serif;
}
.bio-unit {
  font-size: 13px;
  color: var(--paper-dim);
  margin-left: 2px;
}
.bio-trend {
  font-size: 12px;
  font-weight: 500;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 4px;
  margin-top: 4px;
}
/* Visual Range Bar */
.bio-range-container {
  position: relative;
  height: 28px;
  margin-top: 12px;
}
.bio-range-bar {
  position: absolute;
  top: 12px;
  left: 0;
  right: 0;
  height: 4px;
  border-radius: 2px;
}
.bio-range-dot {
  position: absolute;
  top: 4px;
  width: 20px;
  height: 20px;
  background: #fff;
  border: 4px solid var(--surface);
  border-radius: 50%;
  transform: translateX(-50%);
  box-shadow: 0 2px 8px rgba(0,0,0,0.5);
  z-index: 2;
  transition: left 0.5s ease;
}
.bio-range-labels {
  display: flex;
  justify-content: space-between;
  margin-top: 8px;
  font-size: 11px;
  color: var(--paper-dim);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

/* ── Labs View ──────────────────────────────────────── */
.labs-timeline {
  display: flex;
  gap: 8px;
  overflow-x: auto;
  padding: 0 0 16px 0;
  margin-bottom: 24px;
  scrollbar-width: none;
}
.labs-timeline::-webkit-scrollbar { display: none; }

.labs-chip {
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 99px;
  color: var(--paper-dim);
  font-size: 13px;
  font-family: inherit;
  padding: 8px 18px;
  cursor: pointer;
  white-space: nowrap;
  transition: background 0.15s, border-color 0.15s, color 0.15s;
}
.labs-chip:hover {
  background: rgba(95,174,157,0.1);
  border-color: var(--teal);
  color: var(--teal);
}
.labs-chip.active {
  background: rgba(95,174,157,0.18);
  border-color: var(--teal);
  color: var(--teal);
  font-weight: 500;
}

.labs-summary-line {
  color: var(--paper-dim);
  font-size: 14px;
  margin: 4px 0 0 0;
}

.labs-status-bar {
  display: flex;
  gap: 24px;
  margin-bottom: 24px;
  padding: 16px 24px;
  background: rgba(0,0,0,0.2);
  border: 1px solid rgba(255,255,255,0.05);
  border-radius: 8px;
}

.labs-status-stat {
  display: flex;
  align-items: center;
  gap: 8px;
}
.labs-stat-count {
  font-size: 24px;
  font-weight: 500;
  font-family: 'Tenor Sans', sans-serif;
}
.labs-stat-label {
  font-size: 12px;
  color: var(--paper-dim);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}
.labs-stat-optimal .labs-stat-count { color: var(--teal); }
.labs-stat-range .labs-stat-count { color: #f59e0b; }
.labs-stat-out .labs-stat-count { color: #ef4444; }

@media (max-width: 640px) {
  .labs-status-bar {
    gap: 16px;
    padding: 12px 16px;
  }
  .labs-stat-count { font-size: 20px; }
}

/* ── Protocols View ─────────────────────────────────── */
.protocols-summary-line {
  color: var(--paper-dim);
  font-size: 14px;
  margin: 4px 0 0 0;
}
.protocols-filter {
  display: flex;
  gap: 8px;
  margin-bottom: 24px;
}

/* ── Goals View ─────────────────────────────────────── */
.goals-summary-line {
  color: var(--paper-dim);
  font-size: 14px;
  margin: 4px 0 0 0;
}
.goals-section-heading {
  color: var(--paper);
  font-family: 'Tenor Sans', sans-serif;
  font-size: 16px;
  font-weight: 400;
  letter-spacing: 0.03em;
  margin: 28px 0 12px 0;
}
.goals-section-heading:first-of-type {
  margin-top: 8px;
}

/* Goal Card Grid */
.goal-card-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
}
.goal-card {
  display: flex;
  gap: 14px;
  align-items: flex-start;
  padding: 18px;
  background: rgba(0,0,0,0.2);
  border: 1px solid rgba(255,255,255,0.05);
  border-radius: 8px;
  transition: border-color 0.15s;
}
.goal-card:hover {
  border-color: rgba(95,174,157,0.2);
}
.goal-card-icon {
  font-size: 22px;
  color: var(--teal);
  flex-shrink: 0;
  margin-top: 1px;
}
.goal-card-title {
  color: var(--paper);
  font-size: 14px;
  font-weight: 500;
  margin-bottom: 4px;
}
.goal-card-desc {
  color: var(--paper-dim);
  font-size: 13px;
  line-height: 1.45;
}
.goals-update-link {
  display: inline-block;
  margin-top: 12px;
  color: var(--paper-dim);
  font-size: 13px;
  text-decoration: none;
  transition: color 0.15s;
}
.goals-update-link:hover {
  color: var(--teal);
}

/* Goals Empty State */
.goals-empty-state {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  padding: 40px 24px;
  background: rgba(0,0,0,0.2);
  border: 1px solid rgba(255,255,255,0.05);
  border-radius: 8px;
}
.goals-empty-icon {
  font-size: 36px;
  color: var(--teal);
  margin-bottom: 14px;
  opacity: 0.7;
}
.goals-empty-heading {
  color: var(--paper);
  font-family: 'Tenor Sans', sans-serif;
  font-size: 17px;
  font-weight: 400;
  margin: 0 0 6px 0;
}
.goals-empty-desc {
  color: var(--paper-dim);
  font-size: 13px;
  line-height: 1.5;
  max-width: 340px;
  margin: 0 0 18px 0;
}
.goals-empty-cta {
  font-size: 14px;
}

/* Past Appointments */
.goals-past-toggle {
  display: flex;
  align-items: center;
  gap: 6px;
  background: none;
  border: none;
  color: var(--paper-dim);
  font-family: inherit;
  font-size: 13px;
  cursor: pointer;
  padding: 12px 0 8px 0;
  transition: color 0.15s;
}
.goals-past-toggle:hover {
  color: var(--teal);
}
.goals-past-chevron {
  font-size: 14px;
  transition: transform 0.2s;
}
.goals-past-chevron.expanded {
  transform: rotate(90deg);
}
.goals-past-list {
  overflow: hidden;
  transition: max-height 0.3s ease, opacity 0.2s ease;
  max-height: 2000px;
  opacity: 0.6;
}
.goals-past-list.collapsed {
  max-height: 0;
  opacity: 0;
}

@media (max-width: 640px) {
  .goal-card-grid {
    grid-template-columns: 1fr;
  }
  .goals-empty-state {
    padding: 32px 16px;
  }
}


/* ── Messages View ──────────────────────────────────── */
.messages-summary-line {
  color: var(--paper-dim);
  font-size: 14px;
  margin: 4px 0 0 0;
}
.messages-filter {
  display: flex;
  gap: 8px;
  margin-bottom: 24px;
}

/* ── Intake Form Utilities ─────────────────────────── */
.intake-col { display: flex; flex-direction: column; }
.intake-col-20 { display: flex; flex-direction: column; gap: 20px; }
.intake-col-16 { display: flex; flex-direction: column; gap: 16px; }
.intake-row { display: flex; gap: 12px; }
.intake-field-label {
  display: block;
  font-size: 12px;
  margin-bottom: 6px;
  color: var(--paper-dim);
}
.intake-max-200 { max-width: 200px; }
.intake-max-120 { max-width: 120px; }
.intake-self-start { align-self: flex-start; }
.intake-mt-16 { margin-top: 16px; }
.intake-grow { flex-grow: 1; }
.intake-id-card {
  background: rgba(0,0,0,0.2);
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 24px;
  text-align: center;
}
.intake-id-title {
  margin: 0 0 8px 0;
  color: var(--paper);
  font-size: 15px;
}
.intake-id-note {
  margin: 0;
  color: var(--gold);
  font-size: 13px;
}
.intake-counter {
  font-size: 12px;
  color: var(--teal);
  margin-bottom: 8px;
}
.intake-dyn-input { margin-top: 6px; }
.checklist-none-row {
  margin-top: 8px;
  padding-top: 16px;
  border-top: 1px solid rgba(255,255,255,0.1);
}
.intake-cancer-dropdown {
  margin-top: 16px;
  padding: 12px;
  background: rgba(255,255,255,0.05);
  border-radius: 8px;
}
.intake-upnext {
  font-size: 11px;
  color: var(--paper-dim);
  margin-bottom: 8px;
}
.intake-submit {
  justify-content: center;
  margin-top: 10px;
}
.intake-nav-auth {
  display: flex;
  align-items: center;
  gap: 5px;
  flex-shrink: 0;
}
.intake-hero-bg {
  position: fixed;
  inset: 0;
  z-index: 0;
  pointer-events: none;
}
.intake-glow-1 {
  position: absolute;
  border-radius: 50%;
  filter: blur(90px);
  opacity: .35;
  width: 520px;
  height: 520px;
  background: radial-gradient(circle, #15453d, transparent 70%);
  top: -120px;
  right: -80px;
}
.intake-glow-2 {
  position: absolute;
  border-radius: 50%;
  filter: blur(90px);
  opacity: .3;
  width: 420px;
  height: 420px;
  background: radial-gradient(circle, #123244, transparent 70%);
  bottom: -100px;
  left: -120px;
}
.intake-chat-wrap {
  position: relative;
  z-index: 1;
  max-width: 600px;
  margin: 40px auto;
  padding: 0 20px;
  min-height: 70vh;
  display: flex;
  flex-direction: column;
}

/* ── Profile History Form ──────────────────────────── */
.hist-cat-group {
  margin-bottom: 16px;
  padding: 16px;
  background: rgba(0,0,0,0.1);
  border-radius: 8px;
  border: 1px solid rgba(255,255,255,0.05);
}
.hist-cat-title {
  font-size: 14px;
  color: var(--teal);
}
.hist-item {
  margin-top: 10px;
}
.hist-item-label {
  display: flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
}
.hist-cb-input {
  width: 16px;
  height: 16px;
  accent-color: var(--teal);
}
.hist-item-text {
  font-size: 14px;
}
.hist-dyn-input {
  margin-top: 6px;
}
.hist-cancer-div {
  margin-top: 12px;
}

/* Daily Check-In Pills */
.checkin-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.checkin-pill {
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 99px;
  color: var(--paper-dim);
  font-size: 13px;
  font-family: inherit;
  padding: 7px 16px;
  cursor: pointer;
  transition: background 0.15s, border-color 0.15s, color 0.15s, transform 0.1s;
}
.checkin-pill:hover {
  background: rgba(95,174,157,0.1);
  border-color: var(--teal);
  color: var(--teal);
  transform: translateY(-1px);
}
.checkin-pill.selected {
  background: rgba(95,174,157,0.18);
  border-color: var(--teal);
  color: var(--teal);
  font-weight: 500;
}

/* ==========================================================================
   PORTAL TOGGLE SWITCHES
   ========================================================================== */
.switch {
  position: relative;
  display: inline-block;
  width: 44px;
  height: 24px;
  flex-shrink: 0;
}
.switch input {
  opacity: 0;
  width: 0;
  height: 0;
}
.slider {
  position: absolute;
  cursor: pointer;
  inset: 0;
  background-color: rgba(255,255,255,0.05);
  border: 1px solid var(--line);
  transition: .2s ease;
  border-radius: 24px;
}
.slider::before {
  position: absolute;
  content: "";
  height: 14px;
  width: 14px;
  left: 4px;
  bottom: 4px;
  background-color: var(--paper-dim);
  transition: .2s ease;
  border-radius: 50%;
}
input:checked + .slider {
  background-color: rgba(95, 174, 157, 0.15);
  border-color: var(--teal);
}
input:checked + .slider::before {
  transform: translateX(20px);
  background-color: var(--teal);
}

/* ========== WHAT WE OPTIMIZE — BIOMARKER GRID ========== */
#biomarkers { padding: 100px 0; }

.bio-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  margin-top: 48px;
}

.bio-card {
  background: rgba(16, 38, 42, .55);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border: 1px solid var(--line);
  border-radius: 16px;
  overflow: hidden;
  transition: transform .28s ease, box-shadow .28s ease, border-color .28s ease;
}
.bio-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 8px 32px rgba(0,0,0,.25);
  border-color: rgba(95,174,157,.3);
}

.bio-card-header {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 22px 24px;
  cursor: pointer;
  user-select: none;
}

.bio-card-icon {
  flex-shrink: 0;
  width: 44px;
  height: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 10px;
  background: rgba(95,174,157,.1);
  color: var(--teal);
}

.bio-card-title {
  flex: 1;
  min-width: 0;
}
.bio-card-title h3 {
  font-size: 18px;
  font-weight: 400;
  line-height: 1.3;
  margin: 0;
}
.bio-count {
  font-family: 'Tenor Sans', sans-serif;
  text-transform: uppercase;
  letter-spacing: .2em;
  font-size: 10px;
  color: var(--gold);
  margin-top: 2px;
  display: inline-block;
}

.bio-chevron {
  flex-shrink: 0;
  color: var(--paper-faint);
  transition: transform .3s ease;
}
.bio-card.expanded .bio-chevron {
  transform: rotate(180deg);
  color: var(--teal);
}

.bio-card-body {
  max-height: 0;
  overflow: hidden;
  transition: max-height .45s cubic-bezier(.25,.46,.45,.94), padding .35s ease;
  padding: 0 24px;
}
.bio-card.expanded .bio-card-body {
  max-height: 600px;
  padding: 0 24px 24px;
}

.bio-value-prop {
  font-style: italic;
  color: var(--paper-dim);
  font-size: 14.5px;
  line-height: 1.6;
  margin-bottom: 16px;
  padding-top: 4px;
  border-top: 1px solid var(--line-soft);
}

.bio-markers-list {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.bio-pill {
  display: inline-block;
  padding: 5px 12px;
  border-radius: 20px;
  background: var(--panel);
  border: 1px solid var(--line);
  color: var(--teal);
  font-size: 12.5px;
  font-weight: 400;
  letter-spacing: .02em;
  white-space: nowrap;
  transition: background .2s ease, border-color .2s ease;
}
.bio-pill:hover {
  background: rgba(95,174,157,.12);
  border-color: rgba(95,174,157,.35);
}

.bio-callout {
  text-align: center;
  margin-top: 56px;
  max-width: 640px;
  margin-left: auto;
  margin-right: auto;
}
.bio-callout p {
  font-size: clamp(16px, 1.5vw, 19px);
  color: var(--paper-dim);
  line-height: 1.65;
}

/* responsive */
@media (max-width: 900px) {
  .bio-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 640px) {
  .bio-grid { grid-template-columns: 1fr; }
  #biomarkers { padding: 72px 0; }
  .bio-card-header { padding: 18px 18px; }
  .bio-card-body { padding: 0 18px; }
  .bio-card.expanded .bio-card-body { padding: 0 18px 18px; }
  .bio-card-title h3 { font-size: 16px; }
}

/* ---------- LIFESTYLE PHOTO BANNER ---------- */
section.lifestyle-banner {
  padding: 0;
  height: 60vh;
  position: relative;
  width: 100%;
  display: flex;
  align-items: center;
  overflow: hidden;
  border-bottom: 1px solid var(--line);
}

.lifestyle-banner-media {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
}

.lifestyle-banner-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.lifestyle-banner-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(0, 0, 0, 0.5) 0%, rgba(0, 0, 0, 0.3) 25%, transparent 45%);
  z-index: 2;
}

.lifestyle-banner .wrap {
  width: 100%;
  z-index: 3;
  pointer-events: none;
}

.lifestyle-banner-content {
  max-width: 500px;
  pointer-events: auto;
}

.lifestyle-banner-content h2 {
  margin-top: 12px;
  color: var(--paper);
}

@media (max-width: 768px) {
  section.lifestyle-banner {
    flex-direction: column;
    height: auto;
    align-items: stretch;
  }

  .lifestyle-banner-media {
    position: relative;
    height: 40vh;
  }

  .lifestyle-banner-overlay {
    display: none;
  }

  .lifestyle-banner .wrap {
    pointer-events: auto;
  }

  .lifestyle-banner-content {
    max-width: 100%;
    padding: 40px 0;
  }
}

.lifestyle-banner--reverse .lifestyle-banner-overlay {
  background: linear-gradient(270deg, rgba(0, 0, 0, 0.5) 0%, rgba(0, 0, 0, 0.3) 25%, transparent 45%);
}

.lifestyle-banner--reverse .lifestyle-banner-content {
  margin-left: auto;
}

@media (max-width: 768px) {
  .lifestyle-banner--reverse .lifestyle-banner-content {
    margin-left: 0;
  }
}

/* ---------- INTAKE VALIDATION ---------- */
.intake-validation-error {
  color: #e28e75; /* Muted premium terracotta red */
  font-size: 13px;
  margin-top: 8px;
  margin-bottom: 12px;
  font-weight: 500;
  display: none;
  animation: fadeIn 0.2s ease-in-out;
}

@keyframes fadeIn {
  from { opacity: 0; transform: translateY(-4px); }
  to { opacity: 1; transform: translateY(0); }
}

/* ---------- SESSION TIMEOUT MODAL ---------- */
.timeout-modal-overlay {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0,0,0,0.8);
  z-index: 9999;
  align-items: center;
  justify-content: center;
}
.timeout-modal-overlay.visible {
  display: flex !important;
}
.timeout-modal-content {
  background: var(--surface);
  padding: 24px;
  border-radius: 8px;
  border: 1px solid var(--line);
  text-align: center;
  max-width: 400px;
  width: 90%;
}
.timeout-modal-title {
  color: var(--paper);
  margin-top: 0;
}
.timeout-modal-text {
  color: var(--paper-dim);
  margin-bottom: 24px;
}
.timeout-modal-btn {
  width: 100%;
}







/* ---------- CSP INLINE STYLES MIGRATION ---------- */
.csp-style-1 { display: flex; align-items: center; gap: 5px; flex-shrink: 0; }
.csp-style-2 { padding: 8px 9px; }
.csp-style-3 { padding: 8px 11px; gap: 5px; }
.csp-style-4 { margin: 18px 20px 0; justify-content: center; }
.csp-style-5 { margin: 10px 20px 24px; justify-content: center; }
.csp-style-6 { position:fixed;inset:0;z-index:0;pointer-events:none; }
.csp-style-7 { position:absolute;border-radius:50%;filter:blur(90px);opacity:.35;width:520px;height:520px;background:radial-gradient(circle,#15453d,transparent 70%);top:-120px;right:-80px; }
.csp-style-8 { position:absolute;border-radius:50%;filter:blur(90px);opacity:.3;width:420px;height:420px;background:radial-gradient(circle,#123244,transparent 70%);bottom:-100px;left:-120px; }
.csp-style-9 { margin-bottom: 12px; }
.csp-style-10 { margin-bottom: 24px; }
.csp-style-11 { position: relative; }
.csp-style-12 { margin-bottom: 24px; color: var(--paper-dim); }
.csp-style-13 { margin-top: 24px; }
.csp-style-14 { color:var(--paper-dim); }
.csp-style-15 { position:relative; z-index:1; padding-top:40px; }
.csp-style-16 { display:none; background:rgba(234, 179, 8, 0.1); border: 1px solid rgba(234, 179, 8, 0.4); padding:16px 20px; border-radius:8px; margin-bottom:24px; align-items:center; gap:12px; }
.csp-style-17 { color:var(--gold); font-size:20px; }
.csp-style-18 { flex:1; }
.csp-style-19 { margin:0; color:var(--paper); font-size:14px; }
.csp-style-20 { padding:6px 12px; font-size:12px; background:var(--gold); color:#000; border:none; text-shadow:none; }
.csp-style-21 { margin-bottom:40px; display:flex; align-items:center; gap:20px; }
.csp-style-22 { width:64px; height:64px; border-radius:50%; background:var(--teal); color:#000; display:flex; align-items:center; justify-content:center; font-size:24px; font-family:'Tenor Sans', sans-serif; }
.csp-style-23 { font-family:'Tenor Sans', sans-serif; font-size:28px; font-weight:400; margin:0 0 4px 0; color:var(--paper); }
.csp-style-24 { margin:0; color:var(--paper-dim); font-size:13px; }
.csp-style-25 { color:var(--paper); margin-right:12px; }
.csp-style-26 { color:var(--paper); }
.csp-style-27 { margin-top: 20px; display:flex; justify-content:space-between; align-items:center; margin-bottom: 24px; }
.csp-style-28 { margin:0; font-family:'Tenor Sans', sans-serif; font-size:20px; color:var(--paper); }
.csp-style-29 { padding:8px 12px; font-size:12px; }
.csp-style-30 { color:var(--paper-dim); font-size:14px; margin:0; }
.csp-style-31 { margin-top:40px; }
.csp-style-32 { margin-top: 40px; display:flex; justify-content:space-between; align-items:center; margin-bottom: 24px; }
.csp-style-33 { margin-top: 40px; display:grid; grid-template-columns: 1fr 1fr; gap:24px; margin-bottom:40px; }
.csp-style-34 { margin:0; }
.csp-style-35 { background:rgba(0,0,0,0.2); }
.csp-style-36 { margin:0; font-size:16px; }
.csp-style-37 { padding:4px 8px; font-size:11px; }
.csp-style-38 { min-height:auto; padding:20px; }
.csp-style-39 { min-height:auto; padding:0; }
.csp-style-40 { padding:20px; }
.csp-style-41 { margin-bottom: 30px; }
.csp-style-42 { color:var(--teal); font-size:14px; }
.csp-style-43 { display:none; background:rgba(95, 174, 157, 0.1); border: 1px solid rgba(95, 174, 157, 0.4); color:var(--paper); padding:12px 16px; border-radius:8px; margin-bottom:24px; font-size:14px; align-items:center; gap:10px; }
.csp-style-44 { color:var(--teal); font-size:18px; }
.csp-style-45 { background:none; border:none; color:var(--paper-dim); cursor:pointer; font-size:18px; font-weight:bold; }
.csp-style-46 { display:none; position:relative; z-index:1; }
.csp-style-47 { display:flex; align-items:center; gap:20px; margin-bottom:24px; border-bottom:1px solid rgba(255,255,255,0.05); padding-bottom:20px; }
.csp-style-48 { width:64px; height:64px; border-radius:50%; background:var(--teal); color:#06100f; display:flex; align-items:center; justify-content:center; font-size:24px; font-family:'Tenor Sans', sans-serif; font-weight:bold; }
.csp-style-49 { margin:0 0 4px 0; font-family:'Tenor Sans', sans-serif; font-size:20px; color:var(--paper); font-weight:400; }
.csp-style-50 { margin:0; color:var(--paper-dim); font-size:14px; }
.csp-style-51 { margin: 40px 0 20px 0; }
.csp-style-52 { font-family:'Tenor Sans', sans-serif; font-size:18px; text-transform:uppercase; letter-spacing:0.1em; color:var(--teal); }
.csp-style-53 { margin:4px 0 0 0; color:var(--paper-dim); font-size:13px; }
.csp-style-54 { display:block; font-size:12px; margin-bottom:8px; color:var(--gold); }
.csp-style-55 { display:flex; gap:16px; }
.csp-style-56 { margin-top:16px; }
.csp-style-57 { display:flex; flex-wrap:wrap; gap:8px; }
.csp-style-58 { display:none; }
.csp-style-59 { display:flex; flex-direction:column; gap:16px; }
.csp-style-60 { display:flex; justify-content:space-between; align-items:center; border-bottom:1px solid rgba(255,255,255,0.05); padding-bottom:16px; }
.csp-style-61 { margin:0 0 4px 0; font-size:15px; color:var(--paper); font-weight:400; }
.csp-style-62 { margin:0; color:var(--paper-dim); font-size:12px; }
.csp-style-63 { padding: 10px 16px; font-size:11px; font-weight:600; }
.csp-style-64 { display:flex; justify-content:space-between; align-items:center; }
.csp-style-65 { padding: 10px 16px; font-size:11px; font-weight:600; border-color:rgba(239, 68, 68, 0.4); color:#ef4444; }
.csp-style-66 { color:var(--gold); font-size:12px; margin-bottom:20px; font-style:italic; }
.csp-style-67 { padding:60px 20px; text-align:center; }
.csp-style-68 { font-size:48px; color:var(--teal); opacity:0.5; margin-bottom:16px; }
.csp-style-69 { color:var(--paper); font-size:18px; margin-bottom:8px; }
.csp-style-70 { color:var(--paper-dim); font-size:14px; max-width:400px; margin:0 auto; }


/* ---------- CSP JS STYLES MIGRATION ---------- */
.csp-style-100 { margin-bottom:0; padding:24px; text-align:center; }
.csp-style-101 { color:var(--paper-dim); font-size:14px; margin:0; }
.csp-style-102 { background:rgba(245,158,11,0.1); color:#f59e0b; padding:4px 8px; border-radius:4px; font-size:11px; text-transform:uppercase; letter-spacing:0.05em; margin-left:12px; }
.csp-style-103 { background:rgba(255,255,255,0.1); color:var(--paper-dim); padding:4px 8px; border-radius:4px; font-size:11px; text-transform:uppercase; letter-spacing:0.05em; margin-left:12px; }
.csp-style-104 { padding:20px; }
.csp-style-105 { display:flex; justify-content:space-between; align-items:flex-start; }
.csp-style-106 { color:var(--teal); font-size:16px; display:inline-block; }
.csp-style-107 { color:var(--paper); font-size:13px; display:block; margin-top:4px; }
.csp-style-108 { text-align:right; }
.csp-style-109 { color:var(--paper-dim); font-size:12px; margin-bottom:6px; }
.csp-style-110 { width:100px; height:6px; background:rgba(255,255,255,0.1); border-radius:3px; overflow:hidden; }
.csp-style-111 { margin-top:16px; background:rgba(0,0,0,0.3); padding:12px; border-radius:6px; display:flex; align-items:center; gap:12px; }
.csp-style-112 { color:var(--paper-dim); font-size:18px; }
.csp-style-113 { color:var(--paper-dim); font-size:11px; display:block; text-transform:uppercase; }
.csp-style-114 { color:var(--gold); font-size:14px; }
.csp-style-115 { color:var(--gold); font-size:13px; margin:0; }
.csp-style-116 { text-align:center; padding:60px 20px; }
.csp-style-117 { font-size:48px; color:var(--teal); opacity:0.5; display:block; margin-bottom:16px; }
.csp-style-118 { color:var(--paper-dim); font-size:14px; margin:0 auto; max-width:400px; }
.csp-style-119 { flex:1; }
.csp-style-120 { display:flex; align-items:flex-start; gap:20px; }
.csp-style-121 { text-align:center; }
.csp-style-122 { display:block; }
.csp-style-123 { font-size:10px; color:var(--paper-dim); margin-top:2px; }
.csp-style-124 { display:block; overflow:visible; }
.csp-style-125 { font-size:10px; color:var(--paper-dim); margin-top:2px; white-space:nowrap; }
.csp-style-126 { margin-top:0; }
.csp-style-127 { background:rgba(0,0,0,0.2); }
.csp-style-128 { color:var(--teal); font-size:18px; }
.csp-style-129 { color:var(--teal); font-size:12px; margin:0 0 16px; text-transform:uppercase; letter-spacing:0.05em; }
.csp-style-130 { margin-top:16px; }
.csp-style-131 { color:var(--paper-dim); font-size:12px; text-transform:uppercase; letter-spacing:0.05em; display:block; margin-bottom:6px; }
.csp-style-132 { width:100%; background:rgba(0,0,0,0.3); border:1px solid rgba(255,255,255,0.08); border-radius:6px; padding:10px 12px; color:var(--paper); font-size:13px; font-family:inherit; resize:vertical; box-sizing:border-box; }
.csp-style-133 { margin-top:16px; display:flex; align-items:center; gap:12px; }
.csp-style-134 { padding:10px 24px; }
.csp-style-135 { font-size:13px; color:var(--teal); display:none; }
.csp-style-136 { color:var(--paper-dim); font-size:14px; margin:0; padding:20px; }
.csp-style-137 { display:flex; gap:16px; padding:16px 20px; border-bottom:1px solid rgba(255,255,255,0.05); }
.csp-style-138 { background:rgba(95,174,157,0.1); border-radius:8px; padding:8px; text-align:center; min-width:48px; }
.csp-style-139 { color:var(--teal); font-size:11px; font-weight:bold; letter-spacing:0.05em; }
.csp-style-140 { color:var(--paper); font-size:18px; font-weight:bold; }
.csp-style-141 { color:var(--paper); font-size:15px; display:block; margin-bottom:2px; }
.csp-style-142 { color:var(--paper-dim); font-size:13px; margin-bottom:4px; }
.csp-style-143 { display:inline-block; background:rgba(255,255,255,0.05); border:1px solid rgba(255,255,255,0.1); padding:2px 6px; border-radius:4px; font-size:11px; color:var(--paper-dim); text-transform:capitalize; }
.csp-style-144 { font-size:12px; vertical-align:text-bottom; margin-right:4px; }
.csp-style-145 { color:var(--gold); font-size:13px; margin:0; padding:20px; }
.csp-style-146 { width:8px; height:8px; border-radius:50%; background:var(--teal); margin-top:6px; }
.csp-style-147 { width:36px; height:36px; border-radius:50%; background:rgba(95,174,157,0.2); color:var(--teal); display:flex; align-items:center; justify-content:center; font-weight:bold; font-size:14px; flex-shrink:0; }
.csp-style-148 { flex:1; min-width:0; }
.csp-style-149 { display:flex; justify-content:space-between; align-items:baseline; margin-bottom:2px; }
.csp-style-150 { color:var(--paper); font-size:14px; }
.csp-style-151 { color:var(--paper-dim); font-size:11px; }

/* ---------- CSP DYNAMIC STYLES ---------- */
.csp-dyn-1 { margin-bottom: 16px; }
.csp-dyn-2 { height: 100%; background: var(--teal); border-radius: 3px; }
.csp-dyn-3 { display: flex; gap: 12px; padding: 16px 20px; text-decoration: none; transition: background 0.2s; }
.csp-dyn-4 { font-size: 13px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.msg-unread { color: var(--paper); font-weight: 600; }
.msg-read { color: var(--paper-dim); font-weight: 400; }
.csp-border-bottom { border-bottom: 1px solid rgba(255,255,255,0.05); }
.csp-style-104-pad { padding: 20px; }

.hidden { display: none !important; }

.portal-loading-container {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-height: 300px;
  color: var(--paper-dim);
  font-family: 'Tenor Sans', sans-serif;
  font-size: 14px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.portal-spinner {
  width: 32px;
  height: 32px;
  border: 2px solid rgba(95, 174, 157, 0.15);
  border-radius: 50%;
  border-top-color: var(--teal);
  animation: portal-spin 0.8s linear infinite;
  margin-bottom: 16px;
}

@keyframes portal-spin {
  to { transform: rotate(360deg); }
}

.portal-auth-blank {
  min-height: 100vh;
  background: var(--bg);
}
.portal-auth-loading {
  min-height: 100vh;
  background: var(--bg);
  display: flex;
  align-items: center;
  justify-content: center;
}
@keyframes portal-helix-pulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50% { opacity: 0.45; transform: scale(0.92); }
}
.portal-auth-helix {
  animation: portal-helix-pulse 1.6s ease-in-out infinite;
}
@keyframes portal-auth-fade-out {
  to { opacity: 0; }
}
.portal-auth-loading--out {
  animation: portal-auth-fade-out 0.3s ease-out forwards;
}

@keyframes portalFadeIn {
  from { opacity: 0; }
  to { opacity: 1; }
}

.portal-fade-in {
  animation: portalFadeIn 0.35s ease-out both;
}

/* ============ PRE-LAUNCH NOTICES ============ */
.pre-launch-banner {
  background: rgba(95, 174, 157, 0.08);
  border-bottom: 1px solid rgba(95, 174, 157, 0.25);
  color: var(--teal);
  text-align: center;
  padding: 12px 24px;
  font-size: 13.5px;
  font-weight: 500;
  letter-spacing: 0.02em;
  position: relative;
  z-index: 1000;
  width: 100%;
}
.intake-demo-notice {
  background: rgba(229, 115, 115, 0.1);
  border: 1px solid rgba(229, 115, 115, 0.3);
  color: #e57373;
  border-radius: 6px;
  padding: 14px 20px;
  margin: 20px auto 30px;
  font-size: 14px;
  max-width: 600px;
  text-align: left;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
}
.intake-demo-notice button {
  background: transparent;
  border: 1px solid rgba(229, 115, 115, 0.4);
  color: #e57373;
  padding: 6px 14px;
  border-radius: 4px;
  font-size: 12px;
  cursor: pointer;
  white-space: nowrap;
  font-family: 'Tenor Sans', sans-serif;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  transition: 0.2s;
}
.intake-demo-notice button:hover {
  background: rgba(229, 115, 115, 0.15);
}

/* ═══════════════════════════════════════════════════════
   FOUNDING 100 — 7-Step Onboarding Wizard
   ═══════════════════════════════════════════════════════ */

/* Wizard-mode widens the auth card for richer step content */
.auth-card.auth-card--wizard {
  max-width: 580px;
  transition: max-width .3s ease;
}
@media(max-width:640px){
  .auth-card.auth-card--wizard { max-width: 100%; }
}

/* Progress bar inside wizard */
.wizard-progress {
  margin-bottom: 28px;
}
.wizard-progress-text {
  font-family: 'Tenor Sans', sans-serif;
  text-transform: uppercase;
  letter-spacing: .22em;
  font-size: 10px;
  color: var(--paper-faint);
  margin-bottom: 8px;
}
.wizard-progress-track {
  height: 3px;
  background: var(--line);
  border-radius: 2px;
  overflow: hidden;
}
.wizard-progress-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--teal), var(--mint));
  border-radius: 2px;
  transition: width .4s ease;
  width: 0;
}

/* Step transitions */
.auth-view {
  transition: opacity .25s ease;
}
.auth-view.slide-out {
  opacity: 0;
}

/* Back button row */
.step-nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-top: 8px;
}
.step-nav .btn-back {
  background: none;
  border: none;
  color: var(--paper-faint);
  font-family: 'Tenor Sans', sans-serif;
  text-transform: uppercase;
  letter-spacing: .16em;
  font-size: 10.5px;
  cursor: pointer;
  padding: 8px 0;
  transition: color .2s;
}
.step-nav .btn-back:hover {
  color: var(--paper);
}

/* Two-column form row */
.form-row-2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}
@media(max-width:540px){
  .form-row-2 { grid-template-columns: 1fr; }
}
.form-row-3 {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 16px;
}
@media(max-width:540px){
  .form-row-3 { grid-template-columns: 1fr; }
}

/* Goal pills (multi-select) */
.goal-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-bottom: 20px;
}
.goal-pill {
  padding: 9px 18px;
  border-radius: 100px;
  border: 1px solid var(--line);
  background: var(--panel-2);
  color: var(--paper-dim);
  font-size: 13.5px;
  cursor: pointer;
  transition: all .2s;
  user-select: none;
}
.goal-pill:hover {
  border-color: var(--teal);
  color: var(--paper);
}
.goal-pill.selected {
  background: rgba(95,174,157,.15);
  border-color: var(--teal);
  color: var(--teal);
}

/* Safety flags row */
.safety-flags {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-top: 16px;
  padding: 16px;
  background: var(--panel-2);
  border: 1px solid var(--line-soft);
  border-radius: 4px;
}
.safety-flag {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 14px;
  color: var(--paper-dim);
}
.safety-flag input[type="checkbox"] {
  accent-color: var(--teal);
  width: 16px;
  height: 16px;
  flex-shrink: 0;
}

/* Consent blocks */
.consent-block {
  background: var(--panel-2);
  border: 1px solid var(--line-soft);
  border-radius: 4px;
  padding: 20px;
  margin-bottom: 16px;
}
.consent-block h4 {
  font-family: 'Fraunces', serif;
  font-weight: 400;
  font-size: 16px;
  color: var(--paper);
  margin-bottom: 10px;
}
.consent-block p {
  font-size: 13px;
  color: var(--paper-faint);
  line-height: 1.65;
  margin-bottom: 14px;
}
.consent-check {
  display: flex;
  align-items: flex-start;
  gap: 10px;
}
.consent-check input[type="checkbox"] {
  accent-color: var(--teal);
  width: 18px;
  height: 18px;
  flex-shrink: 0;
  margin-top: 2px;
}
.consent-check label {
  font-size: 14px;
  color: var(--paper-dim);
  cursor: pointer;
}

/* Schedule — date strip */
.schedule-dates {
  display: flex;
  gap: 6px;
  overflow-x: auto;
  padding: 4px 0 12px;
  scrollbar-width: thin;
  scrollbar-color: var(--line) transparent;
}
.schedule-date {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2px;
  min-width: 56px;
  padding: 10px 6px;
  border: 1px solid var(--line-soft);
  border-radius: 4px;
  background: var(--panel-2);
  cursor: pointer;
  transition: all .2s;
  flex-shrink: 0;
}
.schedule-date:hover {
  border-color: var(--teal);
}
.schedule-date.selected {
  background: rgba(95,174,157,.15);
  border-color: var(--teal);
}
.schedule-date .day-name {
  font-family: 'Tenor Sans', sans-serif;
  text-transform: uppercase;
  letter-spacing: .14em;
  font-size: 9px;
  color: var(--paper-faint);
}
.schedule-date .day-num {
  font-family: 'Fraunces', serif;
  font-size: 20px;
  color: var(--paper);
}
.schedule-date .day-month {
  font-size: 10px;
  color: var(--paper-faint);
}
.schedule-date.selected .day-name,
.schedule-date.selected .day-num,
.schedule-date.selected .day-month {
  color: var(--teal);
}

/* Walk-in option */
.walkin-option {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 18px;
  border: 1px solid var(--line-soft);
  border-radius: 4px;
  background: var(--panel-2);
  margin-top: 12px;
  cursor: pointer;
  transition: border-color .2s;
}
.walkin-option:hover {
  border-color: var(--teal);
}
.walkin-option.selected {
  border-color: var(--teal);
  background: rgba(95,174,157,.08);
}
.walkin-option input[type="radio"] {
  accent-color: var(--teal);
}

/* Panel tier cards */
.tier-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
  margin-bottom: 24px;
}
@media(max-width:640px){
  .tier-grid { grid-template-columns: 1fr; }
}
.tier-card {
  background: var(--panel-2);
  border: 1px solid var(--line-soft);
  border-radius: 5px;
  padding: 24px 20px;
  cursor: pointer;
  transition: all .25s;
  position: relative;
}
.tier-card:hover {
  border-color: var(--teal);
  transform: translateY(-2px);
}
.tier-card.selected {
  border-color: var(--teal);
  background: rgba(95,174,157,.08);
  box-shadow: 0 0 0 1px var(--teal);
}
.tier-card.featured {
  border-color: var(--gold);
}
.tier-card.featured.selected {
  border-color: var(--gold);
  background: rgba(184,160,106,.08);
  box-shadow: 0 0 0 1px var(--gold);
}
.tier-badge {
  position: absolute;
  top: -1px;
  right: 16px;
  font-family: 'Tenor Sans', sans-serif;
  text-transform: uppercase;
  letter-spacing: .16em;
  font-size: 9px;
  background: var(--gold);
  color: var(--ink);
  padding: 4px 10px;
  border-radius: 0 0 4px 4px;
}
.tier-name {
  font-family: 'Fraunces', serif;
  font-weight: 400;
  font-size: 19px;
  color: var(--paper);
  margin-bottom: 4px;
}
.tier-price {
  font-family: 'Tenor Sans', sans-serif;
  font-size: 13px;
  color: var(--teal);
  letter-spacing: .08em;
  margin-bottom: 14px;
}
.tier-card.featured .tier-price {
  color: var(--gold);
}
.tier-features {
  list-style: none;
  padding: 0;
  margin: 0;
}
.tier-features li {
  font-size: 13px;
  color: var(--paper-dim);
  padding: 5px 0;
  border-top: 1px solid var(--line-soft);
  display: flex;
  align-items: center;
  gap: 8px;
}
.tier-features li::before {
  content: '✓';
  color: var(--teal);
  font-size: 12px;
  flex-shrink: 0;
}
.tier-card.featured .tier-features li::before {
  color: var(--gold);
}

/* Payment stub */
.payment-stub {
  background: var(--panel-2);
  border: 1px solid rgba(184,160,106,.3);
  border-radius: 4px;
  padding: 20px;
  text-align: center;
  margin-bottom: 20px;
}
.payment-stub p {
  color: var(--paper-dim);
  font-size: 14px;
  margin-bottom: 0;
}
.payment-stub .payment-stub-icon {
  font-size: 28px;
  margin-bottom: 8px;
}

/* Waitlist card */
.waitlist-card {
  text-align: center;
  padding: 32px 20px 28px;
}
.waitlist-card .waitlist-icon {
  font-size: 36px;
  margin-bottom: 14px;
}
.waitlist-card h4 {
  font-family: 'Fraunces', serif;
  font-weight: 300;
  font-size: 18px;
  color: var(--paper);
  margin-bottom: 12px;
}
.waitlist-card p {
  color: var(--paper-dim);
  font-size: 14px;
  max-width: 40ch;
  margin: 0 auto 16px;
  line-height: 1.6;
}
.waitlist-card .waitlist-email {
  color: var(--paper-faint);
  font-size: 13px;
}
.waitlist-card .waitlist-email strong {
  color: var(--paper-dim);
  font-weight: 500;
}

/* Confirmed — status tracker */
.status-tracker {
  margin: 24px 0;
  padding: 0;
  list-style: none;
  position: relative;
}
.status-tracker::before {
  content: '';
  position: absolute;
  left: 11px;
  top: 12px;
  bottom: 12px;
  width: 1px;
  background: var(--line);
}
.tracker-step {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 10px 0;
  position: relative;
}
.tracker-dot {
  width: 23px;
  height: 23px;
  border-radius: 50%;
  border: 1px solid var(--line);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 10px;
  color: var(--paper-faint);
  background: var(--bg);
  flex-shrink: 0;
  z-index: 1;
}
.tracker-step.done .tracker-dot {
  border-color: var(--teal);
  color: var(--teal);
}
.tracker-step.current .tracker-dot {
  border-color: var(--gold);
  color: var(--gold);
  box-shadow: 0 0 0 3px rgba(184,160,106,.2);
}
.tracker-label {
  font-size: 14px;
  color: var(--paper-dim);
}
.tracker-step.done .tracker-label {
  color: var(--paper);
}
.tracker-step.current .tracker-label {
  color: var(--gold);
}

/* Cohort badge */
.cohort-badge {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  font-family: 'Tenor Sans', sans-serif;
  text-transform: uppercase;
  letter-spacing: .22em;
  font-size: 11px;
  color: var(--teal);
  border: 1px solid var(--line);
  border-radius: 100px;
  padding: 8px 18px;
  margin-bottom: 20px;
}
.cohort-badge .badge-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--teal);
  box-shadow: 0 0 0 3px rgba(95,174,157,.2);
}

/* Summary rows */
.confirm-summary {
  background: var(--panel-2);
  border: 1px solid var(--line-soft);
  border-radius: 4px;
  padding: 20px;
  margin-bottom: 20px;
}
.confirm-row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  padding: 7px 0;
  border-bottom: 1px solid var(--line-soft);
  font-size: 14px;
}
.confirm-row:last-child {
  border-bottom: none;
}
.confirm-row .confirm-label {
  color: var(--paper-faint);
  font-family: 'Tenor Sans', sans-serif;
  text-transform: uppercase;
  letter-spacing: .14em;
  font-size: 10.5px;
}
.confirm-row .confirm-value {
  color: var(--paper);
  text-align: right;
}

/* Medication toggle area */
.med-toggle-area {
  margin-top: 4px;
}

/* Section label inside a step */
.step-section-label {
  font-family: 'Tenor Sans', sans-serif;
  text-transform: uppercase;
  letter-spacing: .22em;
  font-size: 10px;
  color: var(--paper-faint);
  margin-bottom: 10px;
  margin-top: 24px;
}
.step-section-label:first-child {
  margin-top: 0;
}

/* ========== SIGNUP FLOW (Steps 2–7) — from signup-flow.html ========== */

.su-shell{min-height:100vh;display:flex;flex-direction:column;align-items:center;padding:20px 20px 48px;position:relative;z-index:1;}
.su-top{display:flex;flex-direction:column;align-items:center;gap:18px;margin-bottom:16px;text-align:center;}
.su-signout-btn{background:none;border:none;cursor:pointer;color:var(--paper-dim);font-family:'Tenor Sans',sans-serif;font-size:10px;text-transform:uppercase;letter-spacing:.1em;transition:color .25s;}
.su-signout-btn:hover{color:var(--paper);}
.su-card{width:100%;max-width:720px;background:linear-gradient(160deg,var(--panel),var(--panel-2));border:1px solid var(--line);border-radius:6px;padding:26px clamp(22px,5vw,42px) 28px;position:relative;overflow:hidden;}
.su-card::before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--teal),transparent);}
.su-head{margin-bottom:18px;}
.su-head h1{font-size:clamp(26px,4vw,36px);margin:0 0 10px;}
.su-head h1 .it{font-style:italic;color:var(--teal);}
.su-head .lead{font-size:15px;max-width:none;}

/* error banner */
.su-error{display:none;width:100%;max-width:600px;background:rgba(209,93,101,.12);border:1px solid rgba(209,93,101,.35);border-radius:4px;padding:12px 16px;font-size:13px;color:#d15d65;margin-bottom:14px;text-align:center;}
.su-error.auth{border-color:rgba(184,160,106,.4);background:rgba(184,160,106,.08);color:var(--gold);}
.su-error a{color:inherit;text-decoration:underline;}

/* CSP-safe replacements for inline styles (style-src has no unsafe-inline) */
.su-shell{display:none;}
.su-shell.visible{display:flex;}
#pregRow{display:none;}
.pm-link-wrap{margin-top:12px;}
.pm-link-btn{background:none;border:none;cursor:pointer;color:var(--teal);font-size:13px;}
.su-sub.no-mt{margin-top:0;}
.payment-placeholder{font-size:13px;color:var(--paper-faint);padding:12px 0;}
#sumPanel{color:var(--teal);}
.results-cta{font-size:13.5px;color:var(--paper-dim);margin-bottom:14px;}
.results-cta b{color:var(--paper);font-weight:500;}
#npGrid{grid-template-columns:repeat(3,1fr);}

/* field-level validation errors */
.form-control.field-error{border-color:#d15d65;}
.pill-group.field-error{border:1px solid #d15d65;border-radius:3px;padding:6px 8px;margin:-6px -8px;}
.chip-grid.field-error{border:1px solid #d15d65;border-radius:4px;padding:6px;margin:-6px;}
.consent-card .chk-row.field-error{outline:1px solid #d15d65;border-radius:3px;}
.field-error-msg{font-size:12px;color:#d15d65;margin-top:4px;margin-bottom:8px;line-height:1.4;}

/* progress rail */
.su-progress{display:flex;align-items:flex-start;justify-content:space-between;width:100%;max-width:720px;margin:0 auto 18px;position:relative;}
.su-progress::before{content:"";position:absolute;top:13px;left:30px;right:30px;height:1px;background:var(--line);}
.sp-step{display:flex;flex-direction:column;align-items:center;gap:8px;position:relative;z-index:1;flex:1;}
.sp-dot{width:27px;height:27px;border-radius:50%;border:1px solid var(--line);background:var(--bg-2);color:var(--paper-faint);display:flex;align-items:center;justify-content:center;font-family:'Fraunces',serif;font-style:italic;font-size:12.5px;transition:.3s;}
.sp-step span{font-family:'Tenor Sans',sans-serif;text-transform:uppercase;letter-spacing:.12em;font-size:8.5px;color:var(--paper-faint);transition:.3s;}
.sp-step.current .sp-dot{border-color:var(--teal);color:var(--teal);box-shadow:0 0 14px rgba(95,174,157,.25);}
.sp-step.current span{color:var(--teal);}
.sp-step.done .sp-dot{background:var(--teal);border-color:var(--teal);color:var(--ink);}
.sp-step.done span{color:var(--paper-dim);}
@media(max-width:480px){.sp-step span{display:none;}.su-progress::before{left:24px;right:24px;}}

/* views */
.su-step{display:none;padding:0;}
.su-step.active{display:block;animation:suIn .45s cubic-bezier(.2,.8,.2,1);}
@keyframes suIn{from{opacity:0;transform:translateY(14px);}to{opacity:1;transform:none;}}
@media(prefers-reduced-motion:reduce){.su-step.active{animation:none;}}

/* founding spots counter */
.spots{display:inline-flex;align-items:center;gap:10px;font-family:'Tenor Sans',sans-serif;text-transform:uppercase;letter-spacing:.2em;font-size:10px;color:var(--gold);border:1px solid rgba(184,160,106,.35);background:rgba(184,160,106,.07);border-radius:2px;padding:6px 13px;}
.spots b{font-family:'Fraunces',serif;font-style:italic;font-size:14px;font-weight:400;letter-spacing:0;}

/* form extras */
.fg-split{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.fg-split-3{display:grid;grid-template-columns:2fr 1.4fr 1fr;gap:14px;}
@media(max-width:520px){.fg-split,.fg-split-3{grid-template-columns:1fr;gap:0;}}
.form-label .opt{color:var(--paper-faint);letter-spacing:.06em;text-transform:none;font-size:9.5px;margin-left:6px;}
.why{display:flex;gap:8px;align-items:flex-start;font-size:12px;color:var(--paper-faint);margin-top:7px;line-height:1.5;}
.why::before{content:"—";color:var(--teal);flex-shrink:0;}
select.form-control{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%237e978f' fill='none'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;}

/* checkbox rows */
.chk-row{display:flex;gap:13px;align-items:flex-start;cursor:pointer;padding:13px 15px;border:1px solid var(--line-soft);border-radius:3px;background:rgba(255,255,255,.012);transition:.25s;margin-bottom:12px;}
.chk-row:hover{border-color:var(--line);}
.chk-row input{position:absolute;opacity:0;pointer-events:none;}
.chk-box{width:17px;height:17px;flex-shrink:0;margin-top:2px;border:1px solid var(--paper-faint);border-radius:2px;display:flex;align-items:center;justify-content:center;transition:.2s;}
.chk-box svg{opacity:0;transition:.2s;}
.chk-row input:checked ~ .chk-box{background:var(--teal);border-color:var(--teal);}
.chk-row input:checked ~ .chk-box svg{opacity:1;}
.chk-row input:focus-visible ~ .chk-box{box-shadow:0 0 0 3px rgba(95,174,157,.3);}
.chk-text{font-size:13px;color:var(--paper-dim);line-height:1.55;}
.chk-text a{color:var(--teal);text-decoration:none;border-bottom:1px solid rgba(95,174,157,.35);}
.chk-text b{color:var(--paper);font-weight:500;}

/* pills (sex, yes/no) */
.pill-group{display:flex;gap:10px;flex-wrap:wrap;}
.pill{font-family:'Tenor Sans',sans-serif;text-transform:uppercase;letter-spacing:.14em;font-size:11px;color:var(--paper-dim);border:1px solid var(--line);border-radius:2px;background:transparent;padding:11px 22px;cursor:pointer;transition:.25s;}
.pill:hover{border-color:var(--teal);color:var(--teal);}
.pill.on{background:var(--teal);border-color:var(--teal);color:var(--ink);}
.flag-row{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:13px 15px;border:1px solid var(--line-soft);border-radius:3px;margin-bottom:12px;}
.flag-row p{font-size:13.5px;color:var(--paper-dim);}
.flag-row .pill{padding:8px 16px;font-size:10px;}

/* goal chips */
.chip-grid{display:grid;grid-template-columns:1fr 1fr;gap:11px;margin:6px 0 8px;}
@media(max-width:520px){.chip-grid{grid-template-columns:1fr;}}
.chip{font-family:'Hanken Grotesk',sans-serif;font-weight:300;font-size:13.5px;text-align:left;color:var(--paper-dim);border:1px solid var(--line);border-radius:3px;background:rgba(255,255,255,.012);padding:14px 16px;cursor:pointer;transition:.25s;position:relative;line-height:1.4;}
.chip:hover{border-color:var(--teal);transform:translateY(-1px);}
.chip.on{border-color:var(--teal);background:rgba(95,174,157,.1);color:var(--paper);}
.chip.on::after{content:"✓";position:absolute;top:9px;right:11px;color:var(--teal);font-size:12px;}

/* reveal block */
.toggle-reveal{display:none;margin-top:12px;}
.toggle-reveal.open{display:block;}

/* section divider inside a step */
.su-sub{font-family:'Tenor Sans',sans-serif;text-transform:uppercase;letter-spacing:.26em;font-size:10px;color:var(--teal);margin:30px 0 14px;display:flex;align-items:center;gap:14px;}
.su-sub::after{content:"";flex:1;height:1px;background:var(--line-soft);}

/* consent cards */
.consent-card{border:1px solid var(--line);border-radius:4px;padding:18px;margin-bottom:14px;background:rgba(255,255,255,.012);}
.consent-card h4{font-family:'Fraunces',serif;font-weight:400;font-size:16.5px;margin-bottom:6px;}
.consent-card p{font-size:13px;color:var(--paper-dim);line-height:1.6;margin-bottom:12px;}
.consent-card .chk-row{margin-bottom:0;border:none;padding:0;background:none;}

/* locations */
.loc-card{display:flex;align-items:center;justify-content:space-between;gap:14px;width:100%;text-align:left;border:1px solid var(--line);border-radius:4px;background:rgba(255,255,255,.012);padding:16px 18px;cursor:pointer;transition:.25s;margin-bottom:11px;}
.loc-card:hover{border-color:var(--teal);transform:translateY(-1px);}
.loc-card.on{border-color:var(--teal);background:rgba(95,174,157,.08);}
.loc-card .ln{font-family:'Fraunces',serif;font-size:16px;font-weight:400;color:var(--paper);margin-bottom:3px;}
.loc-card .ld{font-size:12px;color:var(--paper-faint);}
.loc-card .dist{font-family:'Tenor Sans',sans-serif;font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--teal);flex-shrink:0;text-align:right;}
.loc-badge{display:inline-block;font-family:'Tenor Sans',sans-serif;font-size:8.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink);background:var(--mint);border-radius:2px;padding:2px 7px;margin-left:8px;vertical-align:1px;}
.loc-left{display:flex;align-items:center;min-width:0;}
.loc-idx{display:inline-flex;align-items:center;justify-content:center;width:19px;height:19px;border-radius:50%;border:1px solid var(--line);color:var(--teal);font-family:'Fraunces',serif;font-style:italic;font-size:11px;margin-right:12px;flex-shrink:0;transition:.25s;}
.loc-card.on .loc-idx{background:var(--teal);border-color:var(--teal);color:var(--ink);}

/* wireframe map */
.map-wrap{border:1px solid var(--line);border-radius:4px;overflow:hidden;margin-bottom:14px;background:var(--bg);position:relative;}
.map-wrap svg{display:block;width:100%;height:auto;}
.map-pin{cursor:pointer;}
.map-pin circle.ring{fill:var(--bg-2);stroke:var(--line);transition:.25s;}
.map-pin text{fill:var(--paper-dim);font-family:'Tenor Sans',sans-serif;font-size:11px;transition:.25s;}
.map-pin:hover circle.ring{stroke:var(--teal);}
.map-pin.on circle.ring{fill:var(--teal);stroke:var(--teal);}
.map-pin.on text{fill:#06100f;}
.map-tag{position:absolute;top:10px;left:12px;font-family:'Tenor Sans',sans-serif;font-size:8.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--paper-faint);background:rgba(10,21,23,.78);border:1px solid var(--line-soft);border-radius:2px;padding:4px 9px;}

/* date strip */
.date-strip{display:flex;gap:8px;overflow-x:auto;padding:2px 2px 10px;margin:4px 0 14px;scrollbar-width:thin;scrollbar-color:var(--line) transparent;}
.date-strip::-webkit-scrollbar{height:5px;}
.date-strip::-webkit-scrollbar-thumb{background:var(--line);border-radius:3px;}
.date-card{flex:0 0 auto;width:58px;display:flex;flex-direction:column;align-items:center;gap:2px;border:1px solid var(--line);border-radius:3px;background:transparent;padding:9px 0 7px;cursor:pointer;transition:.25s;}
.date-card .dw{font-family:'Tenor Sans',sans-serif;font-size:8.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--paper-faint);}
.date-card .dn{font-family:'Fraunces',serif;font-size:19px;color:var(--paper-dim);line-height:1.1;}
.date-card .dm{font-size:9px;color:var(--paper-faint);text-transform:uppercase;letter-spacing:.1em;}
.date-card:hover{border-color:var(--teal);}
.date-card.on{background:var(--teal);border-color:var(--teal);}
.date-card.on .dw,.date-card.on .dn,.date-card.on .dm{color:var(--ink);}
.date-card.off{opacity:.28;pointer-events:none;}

/* slots */
.slot-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;}
@media(max-width:520px){.slot-grid{grid-template-columns:repeat(2,1fr);}}
.slot{font-family:'Tenor Sans',sans-serif;letter-spacing:.08em;font-size:12px;color:var(--paper-dim);border:1px solid var(--line);border-radius:2px;background:transparent;padding:12px 6px;cursor:pointer;transition:.25s;text-align:center;}
.slot:hover{border-color:var(--teal);color:var(--teal);}
.slot.on{background:var(--teal);border-color:var(--teal);color:var(--ink);}
.slot-note{font-size:12px;color:var(--paper-faint);margin-top:12px;display:flex;gap:8px;}
.slot-note::before{content:"☀";color:var(--gold);}

/* walk-in option */
.walkin-row{display:flex;gap:13px;align-items:flex-start;border:1px dashed var(--line);border-radius:3px;padding:14px 16px;margin-top:16px;cursor:pointer;transition:.25s;}
.walkin-row:hover{border-color:var(--teal);}
.walkin-row.on{border-style:solid;border-color:var(--teal);background:rgba(95,174,157,.08);}
.walkin-row .wi-t{font-size:13.5px;color:var(--paper);margin-bottom:2px;}
.walkin-row .wi-s{font-size:12px;color:var(--paper-faint);line-height:1.5;}
.dimmed{opacity:.35;pointer-events:none;transition:.3s;}

/* waitlist banner */
.waitlist-banner{display:none;border:1px solid rgba(184,160,106,.4);background:rgba(184,160,106,.07);border-radius:4px;padding:16px 18px;font-size:13.5px;color:var(--paper-dim);line-height:1.6;margin-bottom:18px;}
.waitlist-banner.show{display:block;}
.waitlist-banner b{color:var(--gold);font-weight:500;}

/* tiers & upsell */
.credit-sticker{display:flex;align-items:center;justify-content:center;gap:8px;border:1px solid rgba(184,160,106,.45);background:rgba(184,160,106,.08);border-radius:3px;padding:12px 16px;margin-bottom:22px;font-family:'Tenor Sans',sans-serif;text-transform:uppercase;letter-spacing:.16em;font-size:10px;color:var(--gold);text-align:center;}
.credit-sticker b{font-family:'Fraunces',serif;font-style:italic;font-size:17px;font-weight:400;letter-spacing:0;}
.tier-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:8px;}
@media(max-width:560px){.tier-grid{grid-template-columns:1fr;gap:16px;}}
.tier-card{position:relative;text-align:left;border:1px solid var(--line);border-radius:4px;background:rgba(255,255,255,.012);padding:22px 15px 14px;cursor:pointer;transition:.25s;display:flex;flex-direction:column;}
.tier-card:hover{border-color:var(--teal);transform:translateY(-2px);}
.tier-card.on{border-color:var(--teal);background:rgba(95,174,157,.07);box-shadow:0 0 18px rgba(95,174,157,.14);}
.tier-badge{position:absolute;top:-9px;left:13px;font-family:'Tenor Sans',sans-serif;font-size:8px;letter-spacing:.16em;text-transform:uppercase;border-radius:2px;padding:3px 8px;}
.tb-free{background:var(--teal);color:var(--ink);}
.tb-rec{background:var(--gold);color:#0a1517;}
.tier-name{font-family:'Fraunces',serif;font-size:17.5px;font-weight:400;margin-bottom:1px;}
.tier-bio{font-family:'Tenor Sans',sans-serif;font-size:9px;letter-spacing:.14em;text-transform:uppercase;color:var(--teal);margin-bottom:12px;}
.tp{display:flex;align-items:baseline;gap:8px;margin-bottom:12px;}
.tp-was{font-size:13px;color:var(--paper-faint);text-decoration:line-through;}
.tp-now{font-family:'Fraunces',serif;font-size:25px;color:var(--paper);}
.tp-now.free{color:var(--teal);font-style:italic;}
.tier-feat{list-style:none;margin:0;padding:0;flex:1;}
.tier-feat li{font-size:11.5px;color:var(--paper-dim);line-height:1.5;padding-left:14px;position:relative;margin-bottom:6px;}
.tier-feat li::before{content:"✓";position:absolute;left:0;top:1px;color:var(--teal);font-size:9px;}
.pay-block{display:none;margin-top:18px;border:1px solid var(--line);border-radius:4px;padding:18px 18px 6px;background:rgba(255,255,255,.012);}
.pay-block.open{display:block;}

/* tracker (confirmation) */
.tracker{margin:26px 0 8px;}
.trk{display:flex;gap:16px;position:relative;padding-bottom:26px;}
.trk:last-child{padding-bottom:0;}
.trk::before{content:"";position:absolute;left:13px;top:30px;bottom:2px;width:1px;background:var(--line);}
.trk:last-child::before{display:none;}
.trk-dot{width:27px;height:27px;flex-shrink:0;border-radius:50%;border:1px solid var(--line);background:var(--bg-2);display:flex;align-items:center;justify-content:center;color:var(--paper-faint);font-size:12px;}
.trk.done .trk-dot{background:var(--teal);border-color:var(--teal);color:var(--ink);}
.trk.next .trk-dot{border-color:var(--teal);color:var(--teal);}
.trk h5{font-family:'Fraunces',serif;font-weight:400;font-size:15.5px;color:var(--paper);margin-bottom:2px;}
.trk p{font-size:12.5px;color:var(--paper-faint);line-height:1.55;}

/* summary card */
.sum-card{border:1px solid var(--teal);border-radius:4px;background:rgba(95,174,157,.07);padding:20px;margin-bottom:8px;}
.sum-card .sc-lbl{font-family:'Tenor Sans',sans-serif;font-size:9.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--teal);margin-bottom:8px;}
.sum-card .sc-main{font-family:'Fraunces',serif;font-size:20px;font-weight:400;}
.sum-card .sc-sub{font-size:13px;color:var(--paper-dim);margin-top:4px;}

/* footer buttons */
.su-foot{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-top:22px;}
.su-back{font-family:'Tenor Sans',sans-serif;font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--paper-faint);background:none;border:none;cursor:pointer;padding:8px 0;transition:.25s;}
.su-back:hover{color:var(--paper);}
.su-foot .btn{flex-shrink:0;}

/* name row */
.fg-name{display:grid;grid-template-columns:1.5fr 1fr 1.5fr;gap:14px;}
@media(max-width:520px){.fg-name{grid-template-columns:1fr;gap:0;}}


/* Stepper — horizontal numbered dots */
.onboard-stepper{display:flex;align-items:center;justify-content:center;gap:0;padding:20px 16px 24px;}
.onboard-stepper-step{display:flex;align-items:center;gap:0;}
.onboard-stepper-dot{width:32px;height:32px;border-radius:50%;border:1.5px solid var(--line);background:var(--bg-2);display:flex;align-items:center;justify-content:center;font-family:'Tenor Sans',sans-serif;font-size:11px;color:var(--paper-faint);transition:all .35s cubic-bezier(.2,.8,.2,1);flex-shrink:0;}
.onboard-stepper-dot.active{border-color:var(--teal);color:var(--teal);background:rgba(95,174,157,.08);}
.onboard-stepper-dot.done{border-color:var(--teal);color:var(--ink);background:var(--teal);}
.onboard-stepper-label{font-family:'Tenor Sans',sans-serif;font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:var(--paper-faint);margin-top:6px;text-align:center;white-space:nowrap;}
.onboard-stepper-label.active{color:var(--teal);}
.onboard-stepper-line{width:28px;height:1px;background:var(--line);flex-shrink:0;}
.onboard-stepper-line.done{background:var(--teal);}
@media(max-width:640px){.onboard-stepper{gap:0;padding:16px 8px 20px;}
  .onboard-stepper-dot{width:26px;height:26px;font-size:10px;}
  .onboard-stepper-line{width:14px;}
  .onboard-stepper-label{font-size:0;/* hide on mobile */}}

/* Step card container */
.onboard-card{background:linear-gradient(160deg,var(--panel),var(--panel-2));border:1px solid var(--line);border-radius:6px;padding:36px 32px 32px;max-width:620px;margin:0 auto 24px;position:relative;}
.onboard-card::before{content:"";position:absolute;top:0;left:20%;right:20%;height:1px;background:linear-gradient(90deg,transparent,var(--teal),transparent);opacity:.5;}
@media(max-width:640px){.onboard-card{padding:28px 20px 24px;}}
.onboard-card h3{font-family:'Fraunces',serif;font-weight:300;font-size:clamp(22px,3vw,28px);color:var(--paper);margin-bottom:6px;line-height:1.15;}
.onboard-card .lead{color:var(--paper-dim);font-size:14.5px;margin-bottom:24px;max-width:50ch;}

/* Form rows inside onboard cards */
.onboard-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px;}
@media(max-width:540px){.onboard-row{grid-template-columns:1fr;}}
.onboard-field{margin-bottom:16px;}
.onboard-field label{display:block;font-family:'Tenor Sans',sans-serif;text-transform:uppercase;letter-spacing:.2em;font-size:10px;color:var(--paper-faint);margin-bottom:6px;}
.onboard-field .form-control{width:100%;}

/* Consent text block */
.onboard-consent{background:var(--bg-2);border:1px solid var(--line-soft);border-radius:4px;padding:20px 22px;margin-bottom:18px;}
.onboard-consent h4{font-family:'Fraunces',serif;font-weight:400;font-size:16px;color:var(--paper);margin-bottom:10px;}
.onboard-consent p{font-size:13px;color:var(--paper-dim);line-height:1.7;margin-bottom:12px;}
.onboard-consent label{display:flex;align-items:flex-start;gap:10px;font-size:14px;color:var(--paper);cursor:pointer;}
.onboard-consent label input[type="checkbox"]{margin-top:3px;accent-color:var(--teal);flex-shrink:0;}

/* Date strip — horizontal scrolling */
.onboard-date-strip{display:flex;gap:8px;overflow-x:auto;padding:4px 0 12px;-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:var(--line) transparent;}
.onboard-date-cell{flex:0 0 auto;width:64px;padding:12px 0;border:1px solid var(--line);border-radius:4px;text-align:center;cursor:pointer;background:var(--bg-2);transition:all .25s cubic-bezier(.2,.8,.2,1);}
.onboard-date-cell:hover{border-color:var(--teal);background:rgba(95,174,157,.06);}
.onboard-date-cell.selected{border-color:var(--teal);background:rgba(95,174,157,.12);}
.onboard-date-cell.disabled{opacity:.3;pointer-events:none;}
.onboard-date-day{font-family:'Tenor Sans',sans-serif;font-size:9px;letter-spacing:.16em;text-transform:uppercase;color:var(--paper-faint);}
.onboard-date-num{font-family:'Fraunces',serif;font-size:22px;color:var(--paper);margin-top:2px;}
.onboard-date-cell.selected .onboard-date-day,
.onboard-date-cell.selected .onboard-date-num{color:var(--teal);}

/* Location cards */
.onboard-locations{display:grid;grid-template-columns:1fr;gap:10px;margin-bottom:18px;}
.onboard-loc{display:flex;align-items:center;gap:16px;background:var(--bg-2);border:1px solid var(--line-soft);border-radius:4px;padding:16px 18px;cursor:pointer;transition:all .25s cubic-bezier(.2,.8,.2,1);}
.onboard-loc:hover{border-color:var(--teal);background:rgba(95,174,157,.04);}
.onboard-loc.selected{border-color:var(--teal);background:rgba(95,174,157,.08);}
.onboard-loc-icon{width:36px;height:36px;border-radius:50%;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0;}
.onboard-loc-info{flex:1;}
.onboard-loc-name{font-family:'Fraunces',serif;font-weight:400;font-size:15px;color:var(--paper);}
.onboard-loc-addr{font-size:12.5px;color:var(--paper-faint);margin-top:2px;}

/* Panel upsell cards */
.onboard-panels{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:24px;}
@media(max-width:760px){.onboard-panels{grid-template-columns:1fr;}}
.onboard-panel{background:var(--bg-2);border:1px solid var(--line);border-radius:6px;padding:28px 22px;text-align:center;cursor:pointer;transition:all .35s cubic-bezier(.2,.8,.2,1);position:relative;}
.onboard-panel:hover{border-color:var(--steel);transform:translateY(-2px);}
.onboard-panel.selected{border-color:var(--teal);background:rgba(95,174,157,.06);box-shadow:0 0 0 1px var(--teal);}
.onboard-panel.featured{border-color:var(--gold);}
.onboard-panel.featured::before{content:"Most popular";position:absolute;top:-10px;left:50%;transform:translateX(-50%);font-family:'Tenor Sans',sans-serif;font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);background:var(--bg);padding:2px 12px;border:1px solid rgba(184,160,106,.35);border-radius:100px;}
.onboard-panel-name{font-family:'Fraunces',serif;font-weight:400;font-size:18px;color:var(--paper);margin-bottom:6px;}
.onboard-panel-price{font-family:'Fraunces',serif;font-size:32px;color:var(--teal);margin-bottom:4px;}
.onboard-panel.featured .onboard-panel-price{color:var(--gold);}
.onboard-panel-period{font-size:12px;color:var(--paper-faint);margin-bottom:16px;}
.onboard-panel-features{list-style:none;text-align:left;}
.onboard-panel-features li{font-size:13px;color:var(--paper-dim);padding:5px 0;border-bottom:1px solid var(--line-soft);}
.onboard-panel-features li:last-child{border-bottom:none;}
.onboard-panel-features li::before{content:"✓ ";color:var(--teal);}

/* Payment area */
.onboard-payment{background:var(--bg-2);border:1px solid var(--line-soft);border-radius:4px;padding:22px;margin-bottom:20px;}
.onboard-payment.hidden{display:none;}
.onboard-payment h4{font-family:'Fraunces',serif;font-weight:400;font-size:15px;color:var(--paper);margin-bottom:14px;}
.onboard-payment-mount{min-height:44px;background:var(--surface);border:1px solid var(--line);border-radius:3px;padding:12px;}

/* Status tracker (Step 7) */
.onboard-tracker{padding:0 0 0 28px;position:relative;margin-bottom:24px;}
.onboard-tracker::before{content:"";position:absolute;left:11px;top:8px;bottom:8px;width:1px;background:linear-gradient(to bottom,var(--teal),var(--line));}
.onboard-tracker-step{position:relative;padding:10px 0 10px 22px;}
.onboard-tracker-node{position:absolute;left:-22px;top:12px;width:20px;height:20px;border-radius:50%;border:1.5px solid var(--line);background:var(--bg);display:flex;align-items:center;justify-content:center;font-size:11px;}
.onboard-tracker-node.done{border-color:var(--teal);background:var(--teal);color:var(--ink);}
.onboard-tracker-node.current{border-color:var(--teal);color:var(--teal);box-shadow:0 0 0 4px rgba(95,174,157,.15);}
.onboard-tracker-title{font-size:14px;color:var(--paper);}
.onboard-tracker-step.upcoming .onboard-tracker-title{color:var(--paper-faint);}
.onboard-tracker-sub{font-size:12px;color:var(--paper-faint);margin-top:2px;}

/* Summary rows (Step 7) */
.onboard-summary{margin-bottom:24px;}
.onboard-summary-row{display:flex;justify-content:space-between;align-items:baseline;padding:10px 0;border-bottom:1px solid var(--line-soft);}
.onboard-summary-row:last-child{border-bottom:none;}
.onboard-summary-label{font-family:'Tenor Sans',sans-serif;font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--paper-faint);}
.onboard-summary-value{font-size:14px;color:var(--paper);text-align:right;}

/* Waitlist card */
.onboard-waitlist{text-align:center;padding:40px 24px 36px;}
.onboard-waitlist-icon{font-size:40px;margin-bottom:16px;}
.onboard-waitlist h3{font-family:'Fraunces',serif;font-weight:300;font-size:22px;color:var(--paper);margin-bottom:14px;}
.onboard-waitlist p{color:var(--paper-dim);font-size:14px;max-width:42ch;margin:0 auto 14px;line-height:1.65;}
.onboard-waitlist .onboard-waitlist-email{color:var(--paper-faint);font-size:13px;}
.onboard-waitlist .onboard-waitlist-email strong{color:var(--paper-dim);font-weight:500;}

/* Walk-in toggle */
.onboard-walkin{display:flex;align-items:center;gap:12px;padding:14px 18px;background:var(--bg-2);border:1px solid var(--line-soft);border-radius:4px;margin-bottom:18px;cursor:pointer;transition:border-color .25s;}
.onboard-walkin:hover{border-color:var(--teal);}
.onboard-walkin input[type="checkbox"]{accent-color:var(--teal);}
.onboard-walkin-text{font-size:14px;color:var(--paper);}
.onboard-walkin-sub{font-size:12px;color:var(--paper-faint);}

/* Completed step summary bars (resume) */
.onboard-done-bar{display:flex;justify-content:space-between;align-items:center;padding:12px 18px;background:var(--bg-2);border:1px solid var(--line-soft);border-radius:4px;margin-bottom:8px;cursor:pointer;transition:border-color .25s;}
.onboard-done-bar:hover{border-color:var(--steel);}
.onboard-done-bar-title{font-size:13px;color:var(--paper-dim);}
.onboard-done-bar-title strong{color:var(--paper);font-weight:500;}
.onboard-done-bar-edit{font-family:'Tenor Sans',sans-serif;font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--teal);}

/* Safety flags */
.onboard-flags{display:flex;flex-direction:column;gap:10px;margin-top:16px;padding-top:16px;border-top:1px solid var(--line-soft);}
.onboard-flag{display:flex;align-items:flex-start;gap:10px;font-size:14px;color:var(--paper);}
.onboard-flag input[type="checkbox"]{margin-top:3px;accent-color:var(--gold);}
.onboard-flag-warn{font-size:12px;color:var(--gold);margin-top:2px;}

/* Error display inside onboard cards */
.onboard-error{color:var(--gold);font-size:13px;margin-bottom:14px;display:none;}
.onboard-error.visible{display:block;}

/* Cohort badge (Step 7) */
.onboard-badge{display:inline-flex;align-items:center;gap:8px;font-family:'Tenor Sans',sans-serif;text-transform:uppercase;letter-spacing:.24em;font-size:10.5px;color:var(--teal);background:rgba(95,174,157,.08);border:1px solid rgba(95,174,157,.2);border-radius:100px;padding:8px 18px;}
.onboard-badge .dot{width:6px;height:6px;border-radius:50%;background:var(--teal);box-shadow:0 0 0 3px rgba(95,174,157,.18);}

/* demo banner */
.demo-banner { position: sticky; top: 0; width: 100%; background: rgba(95,174,157,0.18); border-top: 1px solid rgba(95,174,157,0.4); border-bottom: 1px solid rgba(95,174,157,0.4); color: #9fd4c4; font-size: 13.5px; text-align: center; padding: 10px 16px; z-index: 9999; font-weight: 500; font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif; }


/* ========== LEGAL PAGES ========== */
.legal-page{max-width:720px;margin:0 auto;padding:60px 24px 80px;position:relative;z-index:1;}
.legal-page h1{font-family:'Fraunces',serif;font-weight:400;font-size:clamp(28px,4vw,38px);color:var(--paper);margin:0 0 8px;line-height:1.25;}
.legal-page .legal-version{font-family:'Tenor Sans',sans-serif;font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--teal);margin-bottom:32px;display:block;}
.legal-page h2{font-family:'Fraunces',serif;font-weight:400;font-size:clamp(20px,2.5vw,24px);color:var(--paper);margin:40px 0 14px;padding-top:20px;border-top:1px solid var(--line-soft);}
.legal-page h3{font-family:'Fraunces',serif;font-weight:500;font-size:17px;color:var(--mint);margin:28px 0 10px;}
.legal-page h4{font-family:'Tenor Sans',sans-serif;font-size:13px;letter-spacing:.1em;text-transform:uppercase;color:var(--teal);margin:24px 0 8px;}
.legal-page p,.legal-page li{font-size:15px;line-height:1.75;color:var(--paper-dim);margin-bottom:12px;}
.legal-page ul,.legal-page ol{padding-left:24px;margin-bottom:16px;}
.legal-page li{margin-bottom:6px;}
.legal-page a{color:var(--teal);text-decoration:underline;text-underline-offset:3px;}
.legal-page a:hover{color:var(--mint);}
.legal-page strong{color:var(--paper);font-weight:500;}
.legal-page em{font-style:italic;color:var(--paper);}
.legal-page hr{border:none;border-top:1px solid var(--line);margin:32px 0;}
.legal-page blockquote{border-left:3px solid var(--gold);background:rgba(184,160,106,.08);padding:16px 20px;margin:20px 0;border-radius:0 4px 4px 0;font-size:14px;line-height:1.65;color:var(--gold);}
.legal-page blockquote strong{color:var(--gold);}
.legal-page blockquote p{color:var(--gold);margin-bottom:6px;}
.legal-page blockquote p:last-child{margin-bottom:0;}
.legal-page table{width:100%;border-collapse:collapse;margin:16px 0;font-size:14px;}
.legal-page th{text-align:left;font-family:'Tenor Sans',sans-serif;font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--teal);border-bottom:1px solid var(--line);padding:10px 12px;}
.legal-page td{border-bottom:1px solid var(--line-soft);padding:10px 12px;color:var(--paper-dim);}
.legal-nav{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:36px;padding-bottom:20px;border-bottom:1px solid var(--line-soft);}
.legal-nav a{font-family:'Tenor Sans',sans-serif;font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--paper-faint);text-decoration:none;padding:6px 12px;border:1px solid var(--line);border-radius:2px;transition:.25s;}
.legal-nav a:hover{border-color:var(--teal);color:var(--teal);}
.legal-nav a.active{border-color:var(--teal);color:var(--teal);background:rgba(95,174,157,.08);}
@media(max-width:600px){.legal-page{padding:40px 16px 60px;}.legal-page h1{font-size:24px;}.legal-nav{gap:6px;}.legal-nav a{font-size:10px;padding:5px 8px;}}
@media print{.legal-page{color:#222;max-width:none;}.legal-page blockquote{border-color:#b8a06a;background:#fff8e1;}.nav-main,.demo-banner,footer,.legal-nav{display:none;}}

/* Skip-to-content link (accessibility) */
.skip-link{position:absolute;top:-100px;left:16px;background:var(--teal);color:var(--bg);padding:8px 16px;font-size:13px;font-family:'Tenor Sans',sans-serif;z-index:10000;border-radius:0 0 4px 4px;transition:top .2s;}
.skip-link:focus{top:0;}

/* Footer legal links */
.foot-bottom a{color:var(--paper-faint);text-decoration:none;transition:color .2s;}
.foot-bottom a:hover{color:var(--teal);}

/* Legal page atmosphere */
.legal-bg{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:0;}

/* Disclaimer label (CSP-safe replacement for inline style) */
.disclaimer-label{color:var(--paper-dim);}

/* Nav auth layout for legal pages (no inline styles — CSP) */
.nav-auth-legal{display:flex;align-items:center;gap:5px;flex-shrink:0;}

/* ── Homepage CSP-compliant inline-style replacements ──────────── */
.csp-home-nav-auth{display:flex;align-items:center;gap:5px;flex-shrink:0;}
.csp-home-signin-btn{padding:8px 9px;}
.csp-home-cta-btn{padding:8px 11px;gap:5px;}
.csp-home-mobile-signin{margin:18px 20px 0;justify-content:center;}
.csp-home-mobile-cta{margin:10px 20px 24px;justify-content:center;}
.csp-home-panel-cta{margin-top:28px;}
.csp-home-section-h3{margin:14px 0 18px;}
.csp-home-lead-sm{font-size:16px;}
.csp-home-lead-sm-mb{font-size:16px;margin-bottom:18px;}
.csp-home-info2-top{margin-top:60px;}
.csp-home-info2-flush{margin-top:0;}
.csp-home-pct-faint{color:var(--paper-faint);}
.csp-home-col-stack{display:flex;flex-direction:column;gap:16px;margin-top:20px;}
.csp-home-card-padded{padding:24px;}
.csp-home-card-title{font-size:20px;}
.csp-home-feature-list-mt{margin-top:8px;}
.csp-home-book-cta{margin-top:26px;}
.csp-home-location-name{font-family:'Fraunces',serif;font-size:22px;color:var(--paper);}
.csp-home-lead-center{margin:0 auto;}
.csp-home-disclaimer{color:var(--paper-dim);}

/* ═══════════════════════════════════════════════════════════════
   LABS DASHBOARD — Biomarker results page
   Added: 2026-06-14
   ═══════════════════════════════════════════════════════════════ */

/* ── Status colour variables ────────────────────────────────── */
:root{
  --opt:#9fd4c4;  --opt-bg:rgba(159,212,196,.12);  --opt-ln:rgba(159,212,196,.30);
  --low:#d2b85c;  --low-bg:rgba(210,184,92,.13);   --low-ln:rgba(210,184,92,.30);
  --high:#dd8b4e; --high-bg:rgba(221,139,78,.14);   --high-ln:rgba(221,139,78,.32);
  --attn:#d05d49; --attn-bg:rgba(208,93,73,.14);    --attn-ln:rgba(208,93,73,.34);
}

/* ── Labs page header ───────────────────────────────────────── */
.labs-head{padding:38px 0 26px;border-bottom:1px solid var(--line-soft);}
.labs-head h1{font-size:clamp(30px,4.4vw,46px);margin:14px 0 0;font-family:'Fraunces',serif;font-weight:300;line-height:1.08;letter-spacing:-.01em;}
.labs-head h1 .it{font-style:italic;color:var(--teal);}

/* ── Head meta / patient tags ───────────────────────────────── */
.head-meta{display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap;margin-top:18px;}
.ptags{display:flex;gap:18px;flex-wrap:wrap;margin-top:0;align-items:center;}
.ptag{font-size:12.5px;color:var(--paper-faint);}
.ptag b{color:var(--paper-dim);font-weight:400;}
.tuned{display:inline-flex;align-items:center;gap:8px;font-family:'Tenor Sans',sans-serif;text-transform:uppercase;letter-spacing:.1em;font-size:10px;color:var(--teal);background:var(--opt-bg);border:1px solid var(--line);border-radius:2px;padding:6px 12px;}
.tuned .car{opacity:.6;}
.review-badge{display:inline-flex;align-items:center;gap:9px;font-family:'Tenor Sans',sans-serif;text-transform:uppercase;letter-spacing:.14em;font-size:10px;color:var(--mint);background:var(--opt-bg);border:1px solid rgba(159,212,196,.28);border-radius:2px;padding:8px 14px;}
.review-badge .dot{width:6px;height:6px;border-radius:50%;background:var(--mint);box-shadow:0 0 8px var(--mint);}

/* ── Tabs / view switcher ───────────────────────────────────── */
.tabs{display:inline-flex;gap:4px;background:var(--panel-2);border:1px solid var(--line);border-radius:4px;padding:4px;margin-top:30px;}
.tab{font-family:'Tenor Sans',sans-serif;text-transform:uppercase;letter-spacing:.12em;font-size:11px;color:var(--paper-dim);background:transparent;border:none;border-radius:2px;padding:11px 22px;cursor:pointer;transition:.25s;}
.tab:hover{color:var(--paper);}
.tab.active{background:var(--teal);color:#06100f;}
.tab:focus-visible{outline:2px solid var(--mint);outline-offset:2px;}
.view{display:none;animation:fade .5s ease;}
.view.active{display:block;}
@keyframes fade{from{opacity:0;transform:translateY(8px);}to{opacity:1;transform:none;}}

/* ── Section headings ───────────────────────────────────────── */
#labs-scaffold .sec-head{display:flex;align-items:baseline;gap:14px;margin-bottom:8px;}
#labs-scaffold .sec-head .ttl{font-family:'Fraunces',serif;font-size:24px;font-weight:400;}
#labs-scaffold .sec-head .ttl.attn{color:var(--attn);}
#labs-scaffold .sec-head .ttl.watch{color:var(--low);}
#labs-scaffold .sec-head .ttl.love{color:var(--opt);}
#labs-scaffold .sec-head .count{font-family:'Tenor Sans',sans-serif;font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--paper-faint);}
.sec-sub{font-size:13.5px;color:var(--paper-dim);margin-bottom:20px;max-width:66ch;}

/* ── Typography helpers ─────────────────────────────────────── */
.lead{font-size:clamp(15px,1.5vw,18px);color:var(--paper-dim);max-width:62ch;}
.small{font-size:13px;color:var(--paper-faint);}

/* ── Snapshot card ──────────────────────────────────────────── */
.snapshot{background:linear-gradient(160deg,var(--panel),var(--panel-2));border:1px solid var(--line);border-radius:8px;padding:30px 34px;margin-top:34px;position:relative;overflow:hidden;}
.snapshot::before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--teal),transparent);}
.snap-grid{display:grid;grid-template-columns:0.95fr 1.15fr 1.05fr;gap:34px;align-items:stretch;}
.snap-z{display:flex;flex-direction:column;justify-content:flex-start;}
.snap-z+.snap-z{border-left:1px solid var(--line-soft);padding-left:34px;}
.bioage{display:flex;align-items:flex-end;gap:18px;margin:14px 0 6px;}
.bioage .num{font-family:'Fraunces',serif;font-size:64px;font-weight:300;line-height:.9;color:var(--paper);}
.bioage .vs{font-size:13px;color:var(--paper-faint);padding-bottom:9px;}
.bioage .vs b{color:var(--teal);font-weight:500;display:block;font-size:14px;}
.snap-note{font-size:13px;color:var(--paper-dim);margin-top:4px;}
.snap-tag{font-family:'Tenor Sans',sans-serif;font-size:9px;letter-spacing:.16em;text-transform:uppercase;color:var(--paper-faint);margin-top:16px;display:block;}

/* ── Percentile track ───────────────────────────────────────── */
.pctile .eyebrow{margin-bottom:14px;}
.pctile .ph{display:flex;align-items:flex-end;gap:10px;margin-bottom:6px;}
.pctile .ph .pn{font-family:'Fraunces',serif;font-size:50px;font-weight:300;line-height:.9;color:var(--mint);}
.pctile .ph .pord{font-family:'Tenor Sans',sans-serif;text-transform:uppercase;letter-spacing:.08em;font-size:13px;color:var(--mint);padding-bottom:9px;}
.pctile .pcap{font-size:13px;color:var(--paper-dim);margin-bottom:22px;}
.pctile .pcap b{color:var(--paper);font-weight:500;}
.ptrack{position:relative;height:10px;border-radius:6px;background:linear-gradient(90deg,rgba(208,93,73,.25),rgba(210,184,92,.28) 45%,rgba(95,174,157,.4) 78%,rgba(159,212,196,.6));margin:6px 0 8px;}
.ptrack .you{position:absolute;top:50%;width:15px;height:15px;border-radius:50%;background:var(--mint);transform:translate(-50%,-50%);border:2.5px solid var(--bg);box-shadow:0 0 10px rgba(159,212,196,.6);z-index:2;}
.ptrack .goal{position:absolute;top:-5px;bottom:-5px;width:2px;background:var(--paper);opacity:.5;}
.pscale{display:flex;justify-content:space-between;font-family:'Tenor Sans',sans-serif;font-size:9.5px;letter-spacing:.05em;color:var(--paper-faint);}
.pgoal-note{font-size:12px;color:var(--paper-faint);margin-top:16px;line-height:1.5;}
.pgoal-note b{color:var(--mint);}

/* ── Counts row ─────────────────────────────────────────────── */
.counts-row{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:18px;}
.cnt{display:flex;align-items:center;gap:16px;border:1px solid var(--line-soft);border-radius:8px;padding:18px 22px;background:var(--panel-2);}
.cnt .big{font-family:'Fraunces',serif;font-size:38px;font-weight:300;line-height:1;min-width:46px;}
.cnt .lbl{font-family:'Tenor Sans',sans-serif;text-transform:uppercase;letter-spacing:.1em;font-size:11px;}
.cnt .sub{font-size:12px;color:var(--paper-faint);margin-top:2px;}
.cnt.opt .big{color:var(--opt);}
.cnt.opt{border-color:var(--opt-ln);}
.cnt.watch .big{color:var(--low);}
.cnt.watch{border-color:var(--low-ln);}
.cnt.attn .big{color:var(--attn);}
.cnt.attn{border-color:var(--attn-ln);}

/* ── Marker card ────────────────────────────────────────────── */
.mk{border:1px solid var(--line);border-radius:8px;background:linear-gradient(160deg,var(--panel),var(--panel-2));margin-bottom:12px;transition:.25s;overflow:hidden;}
.mk:hover{border-color:rgba(95,174,157,.32);}
.mk.lite{background:var(--panel-2);}
.mk-top{display:grid;grid-template-columns:1.5fr 1.6fr auto;gap:22px;align-items:center;padding:22px 24px;}
.mk.lite .mk-top{padding:16px 22px;}
.mk-id .nm{font-size:16px;color:var(--paper);font-weight:400;}
.mk-id .sys{font-family:'Tenor Sans',sans-serif;font-size:9.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--paper-faint);margin-top:3px;}
.mk-val{display:flex;align-items:baseline;gap:7px;}
.mk-val .v{font-family:'Fraunces',serif;font-size:30px;font-weight:300;line-height:1;}
.mk-val .u{font-size:11px;color:var(--paper-faint);}
.mk-val .chev{font-size:13px;margin-left:3px;font-weight:600;}
.mk-val .v-opt{color:var(--opt);}
.mk-val .v-low{color:var(--low);}
.mk-val .v-high{color:var(--high);}
.mk-val .v-attn{color:var(--attn);}

/* ── Range bar track + marker dot ───────────────────────────── */
.rb-track{position:relative;height:9px;border-radius:5px;margin:9px 0 7px;box-shadow:inset 0 0 0 1px rgba(255,255,255,.03);}
.rb-marker{position:absolute;top:50%;width:15px;height:15px;border-radius:50%;transform:translate(-50%,-50%);border:2.5px solid var(--bg);z-index:2;box-shadow:0 0 0 1px rgba(0,0,0,.35);}
.rb-marker.opt{background:var(--opt);}
.rb-marker.low{background:var(--low);}
.rb-marker.high{background:var(--high);}
.rb-marker.attn-low{background:var(--attn);}
.rb-marker.attn-high{background:var(--attn);}
.rb-scale{display:flex;justify-content:space-between;font-size:10.5px;color:var(--paper-faint);font-family:'Tenor Sans',sans-serif;letter-spacing:.02em;}
.rb-scale .opt-lbl{color:var(--teal);}

/* ── Marker status pill ─────────────────────────────────────── */
.mk-stat{text-align:right;white-space:nowrap;}
.pill{font-family:'Tenor Sans',sans-serif;font-size:9.5px;letter-spacing:.13em;text-transform:uppercase;padding:6px 12px;border-radius:2px;display:inline-flex;align-items:center;gap:6px;}
.p-opt{background:var(--opt-bg);color:var(--opt);}
.p-low{background:var(--low-bg);color:var(--low);}
.p-high{background:var(--high-bg);color:var(--high);}
.p-attn{background:var(--attn-bg);color:var(--attn);}

/* ── Expandable marker details ──────────────────────────────── */
details.mk-more{border-top:1px solid var(--line-soft);}
details.mk-more summary{list-style:none;cursor:pointer;padding:13px 24px;display:flex;align-items:center;gap:9px;font-family:'Tenor Sans',sans-serif;font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--teal);transition:.2s;user-select:none;}
details.mk-more summary::-webkit-details-marker{display:none;}
details.mk-more summary:hover{color:var(--mint);background:rgba(95,174,157,.04);}
details.mk-more summary .car{transition:transform .25s;font-size:9px;}
details.mk-more[open] summary .car{transform:rotate(180deg);}
details.mk-more summary:focus-visible{outline:2px solid var(--mint);outline-offset:-2px;}
.mk-body{padding:4px 24px 22px;}
.blk{margin-top:16px;}
.blk:first-child{margin-top:4px;}
.blk-lbl{font-family:'Tenor Sans',sans-serif;font-size:9px;letter-spacing:.16em;text-transform:uppercase;color:var(--paper-faint);margin-bottom:6px;display:flex;align-items:center;gap:7px;}
.blk-lbl .ic{width:5px;height:5px;border-radius:50%;background:var(--teal);}
.blk-lbl.life .ic{background:var(--mint);}
.blk-lbl.np .ic{background:var(--teal);}
.blk p{font-size:13.5px;color:var(--paper-dim);line-height:1.64;}
.blk p .lead{color:var(--paper);font-weight:400;}

/* ── Next-steps box ─────────────────────────────────────────── */
.np-box{background:rgba(95,174,157,.05);border:1px solid var(--line-soft);border-radius:6px;padding:14px 16px;margin-top:8px;}
.np-box p{font-size:13px;}

/* ── Divider + system heads ─────────────────────────────────── */
.divider{display:flex;align-items:center;gap:20px;margin:46px 0 6px;}
.divider .ln{flex:1;height:1px;background:var(--line);}
.divider .dt{font-family:'Tenor Sans',sans-serif;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--paper-faint);}
.sys-head{margin:34px 0 16px;}
.sys-head .pt{font-family:'Tenor Sans',sans-serif;font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--teal);}
.sys-head h3{font-size:22px;margin-top:5px;}
.sys-head .desc{font-size:12.5px;color:var(--paper-faint);margin-top:4px;max-width:58ch;}

/* ── Trends intro + date chips ──────────────────────────────── */
.trend-intro{display:grid;grid-template-columns:1.3fr 1fr;gap:24px;align-items:center;margin:32px 0 8px;}
.dateline{display:flex;gap:10px;flex-wrap:wrap;}
.dchip{flex:1;min-width:118px;border:1px solid var(--line);border-radius:8px;padding:16px 18px;background:var(--panel-2);cursor:pointer;transition:.25s;text-align:left;}
.dchip:hover{border-color:rgba(95,174,157,.4);}
.dchip.active{border-color:var(--teal);background:linear-gradient(160deg,var(--panel),var(--panel-2));}
.dchip .dl{font-family:'Tenor Sans',sans-serif;font-size:9.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--paper-faint);}
.dchip.active .dl{color:var(--teal);}
.dchip .dd{font-family:'Fraunces',serif;font-size:19px;color:var(--paper);margin-top:5px;}
.dchip .ds{font-size:11px;color:var(--paper-faint);margin-top:2px;}
.dchip:focus-visible{outline:2px solid var(--mint);outline-offset:2px;}

/* ── Trend rows ─────────────────────────────────────────────── */
.trow{border:1px solid var(--line);border-radius:8px;background:linear-gradient(160deg,var(--panel),var(--panel-2));margin-bottom:14px;display:grid;grid-template-columns:260px 1fr;gap:0;overflow:hidden;transition:.25s;}
.trow:hover{border-color:rgba(95,174,157,.32);}
.trow-info{padding:24px;border-right:1px solid var(--line-soft);}
.trow-info .tn{font-size:16px;color:var(--paper);}
.trow-info .tu{font-family:'Tenor Sans',sans-serif;font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--paper-faint);margin-top:3px;}
.trow-cur{display:flex;align-items:baseline;gap:9px;margin:16px 0 4px;}
.trow-cur .v{font-family:'Fraunces',serif;font-size:38px;font-weight:300;line-height:1;color:var(--paper);}
.trow-cur .dl{font-size:12px;font-family:'Tenor Sans',sans-serif;letter-spacing:.03em;}
.trow-cur .dl.good{color:var(--opt);}
.trow-cur .dl.watch{color:var(--low);}
.pos-tag{display:inline-flex;align-items:center;gap:7px;font-family:'Tenor Sans',sans-serif;font-size:9.5px;letter-spacing:.12em;text-transform:uppercase;padding:6px 11px;border-radius:2px;margin-top:8px;}
.pos-tag .pd{width:6px;height:6px;border-radius:50%;}
.pos-opt{background:var(--opt-bg);color:var(--opt);}
.pos-opt .pd{background:var(--opt);}
.pos-low{background:var(--low-bg);color:var(--low);}
.pos-low .pd{background:var(--low);}
.pos-high{background:var(--high-bg);color:var(--high);}
.pos-high .pd{background:var(--high);}
.pos-attn{background:var(--attn-bg);color:var(--attn);}
.pos-attn .pd{background:var(--attn);}
.trow-journey{font-size:12.5px;color:var(--paper-dim);line-height:1.55;margin-top:14px;}

/* ── Trend chart area ───────────────────────────────────────── */
.trow-chart{padding:18px 22px 14px;display:flex;align-items:center;}
.trow-chart svg{width:100%;height:auto;display:block;}
.ch-band-lbl{font-family:'Tenor Sans',sans-serif;font-size:9px;letter-spacing:.06em;}
.ch-axis{font-family:'Tenor Sans',sans-serif;font-size:9.5px;fill:var(--paper-faint);}
.ch-date{font-family:'Tenor Sans',sans-serif;font-size:10px;fill:var(--paper-faint);letter-spacing:.02em;}
.ch-date.hot{fill:var(--paper);}
.ch-val{font-family:'Hanken Grotesk',sans-serif;font-size:11px;font-weight:500;fill:var(--paper-dim);}
.ch-val.hot{fill:var(--paper);font-weight:600;}

/* ── Footer note ────────────────────────────────────────────── */
.foot-note{font-size:12px;color:var(--paper-faint);max-width:82ch;line-height:1.6;}
.foot-note b{color:var(--paper-dim);font-weight:400;}

/* ── Labs empty state ───────────────────────────────────────── */
.labs-empty-state{text-align:center;padding:80px 28px;max-width:520px;margin:0 auto;}
.labs-empty-state .eyebrow{margin-bottom:18px;}
.labs-empty-state h2{font-family:'Fraunces',serif;font-size:clamp(24px,3vw,32px);font-weight:300;margin-bottom:14px;color:var(--paper);}
.labs-empty-state p{font-size:14px;color:var(--paper-dim);line-height:1.6;max-width:44ch;margin:0 auto;}

/* ── Labs loading skeleton ──────────────────────────────────── */
.labs-skeleton{display:flex;flex-direction:column;gap:16px;padding:34px 0;}
.labs-skeleton-card{height:120px;border-radius:8px;background:linear-gradient(90deg,var(--panel-2) 25%,var(--surface) 50%,var(--panel-2) 75%);background-size:200% 100%;animation:shimmer 1.6s ease-in-out infinite;}
@keyframes shimmer{0%{background-position:200% 0;}100%{background-position:-200% 0;}}

/* ── Optimal-range note ─────────────────────────────────────── */
.labs-opt-note{font-size:12px;color:var(--paper-faint);font-style:italic;margin-top:6px;}

/* ── Responsive: snap-grid collapses ────────────────────────── */
@media(max-width:960px){
  .snap-grid{grid-template-columns:1fr;gap:0;}
  .snap-z+.snap-z{border-left:none;padding-left:0;border-top:1px solid var(--line-soft);padding-top:26px;margin-top:26px;}
}

/* ── Responsive: marker card single-col ─────────────────────── */
@media(max-width:720px){
  .mk-top{grid-template-columns:1fr;gap:14px;}
  .mk-stat{text-align:left;}
}

/* ── Responsive: wrap padding ───────────────────────────────── */
@media(max-width:640px){
  .labs-head{padding:28px 0 20px;}
}

/* ── Responsive: trend rows ─────────────────────────────────── */
@media(max-width:760px){
  .trow{grid-template-columns:1fr;}
  .trow-info{border-right:none;border-bottom:1px solid var(--line-soft);}
}

/* ── Responsive: counts row ─────────────────────────────────── */
@media(max-width:620px){
  .counts-row{grid-template-columns:1fr;}
}

/* ── Responsive: trend intro ────────────────────────────────── */
@media(max-width:880px){
  .trend-intro{grid-template-columns:1fr;}
}

/* ── Reduced motion ─────────────────────────────────────────── */
@media(prefers-reduced-motion:reduce){
  .view{animation:none;}
  .mk{transition:none;}
  .tab{transition:none;}
  .dchip{transition:none;}
  .trow{transition:none;}
  details.mk-more summary{transition:none;}
  details.mk-more summary .car{transition:none;}
  .labs-skeleton-card{animation:none;}
}

/* ── CSP-safe utility classes (replace inline styles) ──────── */
.labs-hidden{display:none;}
.labs-color-low{color:var(--low);}
.labs-color-high{color:var(--high);}
.labs-color-opt{color:var(--opt);}
.labs-color-attn{color:var(--attn);}
.labs-color-paper-dim{color:var(--paper-dim);}
.labs-mt-10{margin-top:10px;}
.labs-mt-12{margin-top:12px;}
.labs-mt-14{margin-top:14px;}
.labs-pt-18{padding-top:18px;}
.labs-empty-card{flex-direction:column;text-align:center;padding:48px 32px;border-color:var(--line);}
.labs-empty-icon{margin-bottom:18px;opacity:.6;}
.labs-empty-title{color:var(--paper-dim);margin-bottom:8px;}
.labs-empty-desc{max-width:38ch;margin:0 auto;}
.cnt .lbl.lbl-opt{color:var(--opt);}
.cnt .lbl.lbl-low{color:var(--low);}
.cnt .lbl.lbl-attn{color:var(--attn);}

/* ── NP consult scheduler (step 7) ────────────────────────────── */
#npSchedBlock{margin-top:8px;}
.np-sched-label{margin-bottom:4px;}
