@import url('https://fonts.googleapis.com/css2?family=Tenor+Sans&family=Fraunces:opsz,wght@9..144,300;9..144,400;9..144,500;9..144,600&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(70px,11vh,140px) 0 clamp(60px,8vh,100px);overflow:hidden;}
  .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 .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;}

  /* ---------- 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 {
    min-height: 70vh;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 60px 20px;
    position: relative;
    z-index: 1;
  }
  .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-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-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;
}
