:root{--bg:#0c0e0d;--card:#191c1a;--card2:#1f2321;--bdr:#282c29;--bdr2:#353a37;--tx:#ddd9d0;--tx2:#8a8578;--tx3:#5a5650;--ac:#4ecdc4;--acd:rgba(78,205,196,.12);--warn:#f0a030;--warnd:rgba(240,160,48,.12);--dng:#e06050;--dngd:rgba(224,96,80,.10);--iver:#4ecdc4;--fenb:#f0a030;--meb:#c084fc;--sf:'Crimson Pro',Georgia,serif;--ss:'DM Sans',sans-serif;--sm:'IBM Plex Mono',monospace;--r:8px;--mw:1100px}
*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}
body{font-family:var(--ss);background:var(--bg);color:var(--tx);line-height:1.65;font-size:15px;min-height:100vh;min-height:100dvh;overflow-x:hidden}

/* ═══ PARASITE BACKGROUND — SVG worms, zero flash ═══ */
#parasiteBg{position:fixed;inset:0;z-index:0;pointer-events:none;overflow:hidden}
#parasiteBg svg{width:100%;height:100%;position:absolute;inset:0}

/* ═══ ONBOARDING ═══ */
#ob{position:fixed;inset:0;z-index:1000;display:flex;align-items:flex-start;justify-content:center;padding:24px 20px 40px;overflow-y:auto;-webkit-overflow-scrolling:touch}
#ob.gone{display:none}
#ob .obc{display:none}
#ob.unlocked .obc{display:block}
.obc{max-width:580px;width:100%;position:relative;z-index:1;animation:fu .5s ease}
.ob-hero{text-align:center;margin-bottom:10px;position:relative;display:flex;align-items:center;justify-content:center}
.ob-hero img{width:min(260px,68%);height:auto;opacity:1;position:relative;z-index:1;margin-bottom:2px}
/* Ticker: 6 text lines slide in/out below the logo. Continuous loop, 24s cycle, 4s per line. */
.ob-hero-sub{position:relative;width:100%;height:clamp(84px,12vw,124px);margin:0 auto 16px;overflow:hidden;pointer-events:none}
.ob-hero-line{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:var(--sf);font-size:clamp(1.2rem,4.2vw,2.1rem);font-weight:700;color:var(--tx);opacity:0;letter-spacing:.04em;line-height:1.25;text-align:center;max-width:90%;padding:0 10px;margin:0 auto;text-transform:uppercase;will-change:transform,opacity,filter;animation:obTickerLine 24s cubic-bezier(.25,.8,.25,1) infinite}
.ob-hero-line:nth-child(1){animation-delay:0s}
.ob-hero-line:nth-child(2){animation-delay:4s}
.ob-hero-line:nth-child(3){animation-delay:8s}
.ob-hero-line:nth-child(4){animation-delay:12s}
.ob-hero-line:nth-child(5){animation-delay:16s}
.ob-hero-line:nth-child(6){animation-delay:20s}
@keyframes obTickerLine{0%{opacity:0;transform:translateX(40px);filter:blur(3px)}2.5%{opacity:1;transform:translateX(0);filter:blur(0)}14%{opacity:1;transform:translateX(0);filter:blur(0)}16.67%{opacity:0;transform:translateX(-40px);filter:blur(3px)}100%{opacity:0;transform:translateX(-40px);filter:blur(3px)}}
@media (prefers-reduced-motion:reduce){.ob-hero-line{animation:none;opacity:1;transform:none;filter:none;position:relative}.ob-hero-line:not(:first-child){display:none}.ob-hero-sub{height:auto}}
/* Short-screen compression: keep the primary CTA (first decision card) above the fold on older iPhones and landscape tablets. */
@media (max-height:740px){
  .ob-hero{margin-bottom:6px}
  .ob-hero img{width:min(200px,58%)}
  .ob-hero-sub{height:clamp(72px,10vw,96px);margin-bottom:12px;font-size:.9em}
  .ob-hero-line{font-size:clamp(1rem,3.6vw,1.6rem)}
}
.ohs{display:flex;align-items:baseline;gap:4px}.ohs-n{font-family:var(--sm);font-size:1.1rem;font-weight:500;color:var(--ac)}.ohs-l{font-size:.65rem;color:var(--tx3);text-transform:uppercase;letter-spacing:1px}
.obs{display:none}.obs.on{display:block}
/* obs-q: 2x original 1.4rem = 2.8rem */
.obs-q{font-family:var(--sf);font-size:2.8rem;font-weight:400;line-height:1.2;margin-bottom:16px;text-align:center}
.ob-opts{display:grid;gap:10px}
.ob-act{background:var(--card);border:1px solid var(--bdr);border-radius:var(--r);padding:14px 18px 14px 16px;cursor:pointer;transition:.25s;display:flex;align-items:center;gap:12px}
.ob-act:hover{border-color:var(--bdr2);background:var(--card2);transform:translateX(4px)}
.ob-act:active{transform:translateX(2px)}
.ob-act-content{flex:1}
.ob-act-t{font-weight:600;font-size:.92rem;margin-bottom:1px}.ob-act-d{font-size:.73rem;color:var(--tx2);line-height:1.4}
.ob-act-arrow{color:var(--tx3);font-size:1.1rem;flex-shrink:0;transition:color .2s}
.ob-act:hover .ob-act-arrow{color:var(--ac)}
.ob-skip{display:block;text-align:center;margin-top:14px;background:none;border:none;color:var(--tx3);font-size:.74rem;cursor:pointer;padding:8px;width:100%}.ob-skip:hover{color:var(--tx2)}

/* Reviews widget on onboarding */
.ob-reviews{margin:20px 0 4px}
.ob-reviews iframe{border:none;min-height:280px}

/* Stage step */
.ob-stage-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.ob-stage-btn{background:var(--card);border:1px solid var(--bdr);border-radius:var(--r);padding:16px;cursor:pointer;text-align:center;transition:.25s}
.ob-stage-btn:hover{border-color:var(--bdr2);background:var(--card2)}
.ob-stage-num{font-family:var(--sm);font-size:1.4rem;font-weight:500;color:var(--ac);margin-bottom:2px}
.ob-stage-desc{font-size:.72rem;color:var(--tx2)}
.ob-back{display:block;text-align:center;margin-top:12px;background:none;border:none;color:var(--tx3);font-size:.76rem;cursor:pointer;padding:8px}.ob-back:hover{color:var(--tx2)}
/* Weight step */
.ob-wd{text-align:center;margin-bottom:14px}
.ob-wn{font-family:var(--sm);font-size:3rem;font-weight:500}.ob-wu{font-size:1rem;color:var(--tx3);margin-left:4px}
.ob-wk{font-family:var(--sm);font-size:1.1rem;color:var(--tx2);margin-top:2px}
.ob-sl{-webkit-appearance:none;appearance:none;width:100%;height:8px;border-radius:4px;background:var(--card);border:1px solid var(--bdr);outline:none;cursor:pointer}
.ob-sl::-webkit-slider-thumb{-webkit-appearance:none;width:28px;height:28px;border-radius:50%;background:var(--ac);border:3px solid var(--bg);box-shadow:0 0 0 2px var(--ac);cursor:grab}
.ob-sl::-webkit-slider-thumb:active{transform:scale(1.12);cursor:grabbing}
.ob-sl::-moz-range-thumb{width:28px;height:28px;border-radius:50%;background:var(--ac);border:3px solid var(--bg);cursor:grab}
.ob-sb{display:flex;justify-content:space-between;margin-top:5px;font-family:var(--sm);font-size:.65rem;color:var(--tx3)}
.ob-unit-row{display:flex;justify-content:center;margin-bottom:14px}
.ob-unit-toggle{display:flex;background:var(--card);border:1px solid var(--bdr);border-radius:6px;overflow:hidden}
.ob-unit-toggle button{background:none;border:none;color:var(--tx3);font-family:var(--sm);font-size:.78rem;padding:7px 16px;cursor:pointer;transition:.2s}
.ob-unit-toggle button.on{background:var(--ac);color:var(--bg)}
.ob-pri{display:block;width:100%;padding:14px;background:var(--ac);color:var(--bg);border:none;border-radius:6px;font-family:var(--ss);font-size:1rem;font-weight:700;cursor:pointer;margin-top:16px;transition:.2s}.ob-pri:hover{filter:brightness(1.1)}
/* weight-why lightbox */
.ob-why{background:var(--card);border:1px solid var(--bdr2);border-radius:var(--r);padding:14px 16px;margin-bottom:14px;font-size:.82rem;color:var(--tx2);line-height:1.7}
.ob-why strong{color:var(--tx)}
/* Results */
.ob-res{background:var(--card);border:1px solid var(--ac);border-radius:var(--r);padding:24px;margin-bottom:16px;position:relative;overflow:hidden}
.ob-res::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--iver),var(--fenb),var(--meb))}
.ob-rl{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--bdr);font-size:.88rem}.ob-rl:last-child{border-bottom:none}
.ob-rk{color:var(--tx2)}.ob-rv{font-family:var(--sm);font-weight:500}
.ob-gs{display:block;width:100%;padding:14px;background:var(--ac);color:var(--bg);border:none;border-radius:6px;font-family:var(--ss);font-size:1rem;font-weight:700;cursor:pointer;margin-top:16px;transition:.2s}.ob-gs:hover{filter:brightness(1.1)}
.ob-dis{margin-top:16px;background:var(--dngd);border:1px solid rgba(224,96,80,.2);border-radius:var(--r);padding:10px 14px;font-size:.7rem;color:var(--dng);line-height:1.5;text-align:center}

/* ═══ PILL NAV — truly floating, no bg, no border ═══ */
.pill-nav{position:fixed;top:12px;left:0;right:0;z-index:200;pointer-events:none;padding:0 16px}
.pill-inner{max-width:var(--mw);margin:0 auto;display:flex;align-items:center;justify-content:center;gap:8px;pointer-events:none}
.pill-bar{pointer-events:auto}
.pill-logo{flex-shrink:0;cursor:pointer;display:flex;align-items:center;padding:0 6px}.pill-logo img{height:36px;width:auto;opacity:.9}
.pill-bar{display:flex;gap:4px;align-items:center;background:rgba(25,28,26,.92);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-radius:28px;padding:6px 6px 6px 4px;overflow:visible;border:1px solid rgba(195,217,94,.25);box-shadow:0 6px 24px rgba(0,0,0,.5);touch-action:pan-y}
.pill{font-family:var(--ss);font-size:.72rem;font-weight:600;color:var(--tx2);background:none;border:none;padding:7px 13px;border-radius:20px;cursor:pointer;white-space:nowrap;transition:.2s;flex-shrink:0}
.pill:hover{color:var(--tx)}.pill.on{background:var(--ac);color:var(--bg)}
#app.v{padding-top:25px}
.sec{display:none;padding:20px 0 44px;animation:fu .4s ease}.sec.vis{display:block}

/* ═══ SOCIAL LINKTREE — onboarding (25% brighter) ═══ */
/* 20px gap between socials and obs-q */
.ob-soc{display:flex;align-items:center;justify-content:center;text-decoration:none;color:#7a7872;transition:.2s;padding:4px;min-width:0;flex-shrink:0}
.ob-soc:hover{color:var(--ac);transform:translateY(-2px)}
.ob-soc svg{width:18px;height:18px;fill:currentColor}
.ob-soc span{display:none}
.ob-soc-circle{width:44px;height:44px;border-radius:50%;border:1px solid var(--bdr);display:flex;align-items:center;justify-content:center;transition:.2s}
.ob-soc:hover .ob-soc-circle{border-color:var(--ac);background:var(--acd)}

/* ═══ FOOTER SOCIAL ROW — matches starting page style ═══ */
.footer-socials{display:flex;gap:0;justify-content:center;flex-wrap:wrap;padding:20px 0 12px}

/* ═══ INFO BOX ═══ */
.info-box{background:var(--dngd);border:1px solid rgba(224,96,80,.2);border-radius:var(--r);padding:12px 16px;font-size:.74rem;color:var(--dng);line-height:1.6;margin-top:28px}
.info-box strong{color:rgba(230,120,100,1)}

/* ═══ RESEARCH STATS BAR ═══ */
.res-stats{display:flex;gap:0;justify-content:stretch;background:var(--card);border:1px solid var(--bdr);border-radius:var(--r);margin-bottom:16px;overflow:hidden}
.res-stats .ohs{flex:1;justify-content:center;flex-direction:row;align-items:baseline;gap:5px;padding:12px 8px;border-right:1px solid var(--bdr);text-align:center}
.res-stats .ohs:last-child{border-right:none}
.res-stats .ohs-n{font-size:1.2rem}
.res-stats .ohs-l{font-size:.6rem}

/* ═══ RESEARCH MIRACLE BLURB ═══ */
.res-blurb{background:var(--card2);border:1px solid var(--bdr);border-left:3px solid var(--ac);border-radius:var(--r);padding:16px 20px;margin-bottom:16px;font-size:.85rem;color:var(--tx2);line-height:1.75}
.res-blurb strong{color:var(--tx)}

/* ═══ YOUR DOSE INTRO ═══ */
.yd-intro{background:var(--card2);border:1px solid var(--bdr);border-radius:var(--r);padding:16px 20px;margin-bottom:20px;font-size:.85rem;color:var(--tx2);line-height:1.75}
.yd-intro strong{color:var(--tx)}

/* ═══ WEIGHT SLIDER ON YOUR DOSE PAGE ═══ */
.yd-weight{background:var(--card);border:1px solid var(--bdr);border-radius:var(--r);padding:12px 16px;margin-bottom:14px;display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.yd-weight-left{display:flex;align-items:baseline;gap:6px;flex:1}
.yd-weight-num{font-family:var(--sm);font-size:1.6rem;font-weight:500;color:var(--tx)}
.yd-weight-unit{font-size:.8rem;color:var(--tx3)}
.yd-weight-kg{font-family:var(--sm);font-size:.75rem;color:var(--tx3);margin-left:2px}
.yd-weight-edit{background:none;border:1px solid var(--bdr);border-radius:6px;color:var(--tx3);font-size:.72rem;padding:4px 8px;cursor:pointer;transition:.2s;white-space:nowrap}.yd-weight-edit:hover{border-color:var(--ac);color:var(--ac)}
.yd-weight-editor{display:none;width:100%;padding:10px 0 2px;border-top:1px solid var(--bdr);margin-top:4px;gap:10px;align-items:center;flex-wrap:wrap}
.yd-weight-editor.open{display:flex}
.yd-weight-input{background:var(--bg);border:1px solid var(--bdr);border-radius:6px;color:var(--tx);font-family:var(--sm);font-size:1rem;padding:7px 10px;width:90px;outline:none;transition:.2s}.yd-weight-input:focus{border-color:var(--ac)}
.unit-toggle{display:flex;background:var(--bg);border:1px solid var(--bdr);border-radius:6px;overflow:hidden}
.unit-toggle button{background:none;border:none;color:var(--tx3);font-family:var(--sm);font-size:.72rem;padding:6px 10px;cursor:pointer;transition:.2s}
.unit-toggle button.on{background:var(--ac);color:var(--bg)}
.yd-weight-apply{padding:7px 14px;background:var(--ac);color:var(--bg);border:none;border-radius:6px;font-family:var(--ss);font-size:.8rem;font-weight:600;cursor:pointer;transition:.2s}.yd-weight-apply:hover{filter:brightness(1.1)}

/* ═══ LAYOUT ═══ */
.ct{max-width:var(--mw);margin:0 auto;padding:0 20px;position:relative;z-index:1}
#app{display:none}#app.v{display:block}
.sec.vis{display:block}
.sh{margin-bottom:20px}.sl{font-family:var(--sm);font-size:.62rem;text-transform:uppercase;letter-spacing:2px;color:var(--tx3);margin-bottom:5px}
.st{font-family:var(--sf);font-size:1.5rem;font-weight:400;letter-spacing:-.5px}

/* ═══ YOUR DOSE ═══ */
.yd{background:var(--card);border:1px solid var(--ac);border-radius:var(--r);padding:24px;position:relative;overflow:hidden}
.yd::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--iver),var(--fenb),var(--meb))}
.yd-lb{font-family:var(--sm);font-size:.62rem;text-transform:uppercase;letter-spacing:2px;color:var(--ac);margin-bottom:5px}
.yd-tt{font-family:var(--sf);font-size:1.2rem;font-weight:500;margin-bottom:14px;display:flex;align-items:center;gap:8px}
.yd-g{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.yd-d{background:var(--bg);border:1px solid var(--bdr);border-radius:6px;padding:14px}
.yd-dn{font-family:var(--sm);font-size:.65rem;text-transform:uppercase;letter-spacing:1.5px;margin-bottom:8px;padding-bottom:7px;border-bottom:2px solid currentColor}
.yd-dn.ci{color:var(--iver);border-color:var(--iver)}.yd-dn.cf{color:var(--fenb);border-color:var(--fenb)}.yd-dn.cm{color:var(--meb);border-color:var(--meb)}
.yd-dv{font-family:var(--sm);font-size:1.2rem;font-weight:500;margin-bottom:3px}.yd-dd{font-size:.74rem;color:var(--tx2);line-height:1.5}
.yd-sc{margin-top:12px;padding:10px 12px;background:var(--bg);border:1px solid var(--bdr);border-radius:6px;font-size:.8rem;color:var(--tx2);line-height:1.6}.yd-sc strong{color:var(--tx)}
.yd-btns{margin-top:14px;display:flex;gap:8px;flex-wrap:wrap}
.yd-cta{padding:9px 20px;background:var(--ac);color:var(--bg);border:none;border-radius:6px;font-family:var(--ss);font-size:.85rem;font-weight:600;cursor:pointer;transition:.2s}.yd-cta:hover{filter:brightness(1.1)}
.yd-s{padding:7px 14px;background:var(--card);color:var(--tx2);border:1px solid var(--bdr);border-radius:6px;font-family:var(--ss);font-size:.8rem;cursor:pointer;transition:.2s}.yd-s:hover{color:var(--tx)}
.yd-warn{margin-top:16px;background:var(--dngd);border:1px solid rgba(224,96,80,.2);border-radius:var(--r);padding:10px 14px;font-size:.72rem;color:var(--dng);line-height:1.5}

/* ═══ NEWSLETTER — button-reveal iframe ═══ */
.nls{background:var(--card);border:1px solid var(--bdr);border-radius:var(--r);padding:24px;text-align:center;margin:28px 0 0;width:100%;box-sizing:border-box}
.nls h3{font-family:var(--sf);font-size:1.1rem;margin-bottom:3px}.nls p{font-size:.78rem;color:var(--tx2);margin-bottom:12px}
.nl-btn{display:inline-block;padding:10px 28px;background:var(--ac);color:var(--bg);border:none;border-radius:6px;font-family:var(--ss);font-size:.85rem;font-weight:700;cursor:pointer;transition:.2s}.nl-btn:hover{filter:brightness(1.1)}
.nl-iframe-wrap{display:none;margin-top:14px;border-radius:var(--r);overflow:hidden;min-height:729px}
.nl-iframe-wrap.open{display:block}
.nl-iframe-wrap iframe{width:100%;height:729px;border:none;border-radius:var(--r)}


/* ═══ BINDER MODAL ═══ */
.modal-overlay{position:fixed;inset:0;z-index:2000;background:rgba(0,0,0,.4);backdrop-filter:blur(3px);display:flex;align-items:flex-start;justify-content:center;padding:60px 20px 20px;overflow-y:auto;animation:fu .3s ease}
.modal-overlay.gone{display:none}
.modal-box{background:var(--card);border:1px solid var(--bdr);border-radius:var(--r);max-width:500px;width:100%;padding:28px 24px;position:relative;max-height:90vh;overflow-y:auto}
.modal-title{font-family:var(--sf);font-size:1.5rem;font-weight:500;margin-bottom:6px}
.modal-sub{font-size:.83rem;color:var(--tx2);line-height:1.7;margin-bottom:20px}
.modal-checks{display:grid;gap:12px;margin-bottom:22px}
.modal-check{display:flex;align-items:flex-start;gap:12px;background:var(--bg);border:1px solid var(--bdr);border-radius:6px;padding:12px 14px;cursor:pointer;transition:.2s}
.modal-check:hover{border-color:var(--bdr2)}
.modal-check.checked{border-color:var(--ac);background:var(--acd)}
.modal-check-box{width:20px;height:20px;border-radius:4px;border:2px solid var(--bdr2);flex-shrink:0;margin-top:1px;display:flex;align-items:center;justify-content:center;transition:.2s;font-size:.7rem}
.modal-check.checked .modal-check-box{background:var(--ac);border-color:var(--ac);color:var(--bg)}
.modal-check-box::after{content:'';display:none}
.modal-check.checked .modal-check-box::after{content:'\2713';display:block;font-size:.7rem;line-height:1;color:var(--bg)}
.modal-check-text{font-size:.84rem;line-height:1.5}
.modal-check-text strong{display:block;margin-bottom:1px}
.modal-check-text span{color:var(--tx2);font-size:.76rem}
.modal-btn{width:100%;padding:14px;background:var(--ac);color:var(--bg);border:none;border-radius:6px;font-family:var(--ss);font-size:1rem;font-weight:700;cursor:pointer;transition:.2s;opacity:.4;pointer-events:none}
.modal-btn.ready{opacity:1;pointer-events:auto}
.modal-btn.ready:hover{filter:brightness(1.1)}
.share-inp{width:100%;padding:10px 12px;background:var(--bg);border:1px solid var(--bdr);border-radius:6px;font-family:var(--ss);font-size:.9rem;color:var(--tx);box-sizing:border-box;transition:.15s}
.share-inp:focus{outline:none;border-color:var(--ac)}
.share-inp::placeholder{color:var(--tx3)}

/* ═══ CANCER TYPE SELECTOR (onboarding S1.5) ═══ */
.cancer-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:8px;margin-bottom:8px}
.cancer-btn{background:var(--card);border:1px solid var(--bdr);border-radius:var(--r);padding:10px 12px;cursor:pointer;text-align:left;transition:.2s;font-size:.82rem;font-weight:500;color:var(--tx)}
.cancer-btn:hover{border-color:var(--bdr2);background:var(--card2)}
.cancer-btn.sel{border-color:var(--ac);background:var(--acd);color:var(--ac)}
.cancer-skip{font-size:.73rem;color:var(--tx3);background:none;border:none;cursor:pointer;padding:6px;display:block;margin:0 auto}.cancer-skip:hover{color:var(--tx2)}

/* ═══ DOSE CARD — product amount headline ═══ */
.yd-dose-headline{font-family:var(--sm);font-size:1.6rem;font-weight:500;line-height:1.2;margin-bottom:3px}
.yd-dose-mg{font-size:.75rem;color:var(--tx3);margin-bottom:4px}
.yd-dose-note{font-size:.68rem;color:var(--tx3);line-height:1.4;margin-top:4px}

/* ═══ PROTOCOL TRACKER ═══ */
.tracker{background:var(--card);border:1px solid var(--bdr);border-radius:var(--r);padding:16px 18px;margin-bottom:14px;display:none}
.tracker.vis{display:block}
.tracker-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.tracker-title{font-family:var(--sm);font-size:.6rem;text-transform:uppercase;letter-spacing:2px;color:var(--ac)}
.tracker-edit{font-size:.7rem;color:var(--tx3);background:none;border:none;cursor:pointer;padding:2px 6px}.tracker-edit:hover{color:var(--tx2)}
.tracker-row{display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.tracker-big{font-family:var(--sm);font-size:1.8rem;font-weight:500;color:var(--tx)}
.tracker-label{font-size:.78rem;color:var(--tx2);line-height:1.4}
.tracker-ring{flex-shrink:0}
.tracker-day-status{display:inline-block;padding:3px 10px;border-radius:12px;font-family:var(--sm);font-size:.65rem;margin-top:6px}
.tracker-day-status.on{background:rgba(78,205,196,.15);color:var(--ac)}
.tracker-day-status.off{background:var(--bg);color:var(--tx3);border:1px solid var(--bdr)}
.trk-head{display:flex;align-items:baseline;gap:8px;margin-bottom:8px;flex-wrap:wrap}
.trk-week{font-family:var(--sm);font-size:1rem;font-weight:600;color:var(--tx)}
.trk-daycount{font-family:var(--sm);font-size:.85rem;color:var(--tx2)}
.trk-started{font-size:.72rem;color:var(--tx3);margin-left:auto}
.trk-today-label{font-size:.65rem;font-weight:700;letter-spacing:1.5px;margin-bottom:8px}
.trk-status-on{color:var(--ac)}
.trk-status-off{color:var(--tx3)}
.trk-row{display:flex;align-items:center;gap:10px;padding:5px 0;border-bottom:1px solid rgba(255,255,255,.04)}
.trk-row:last-of-type{border-bottom:none}
.trk-icon{font-size:.85rem;width:14px;text-align:center;flex-shrink:0}
.trk-row.trk-on .trk-icon{color:var(--ac)}
.trk-row.trk-off .trk-icon{color:var(--tx3)}
.trk-name{font-family:var(--sm);font-size:.82rem;color:var(--tx);flex:1}
.trk-row.trk-off .trk-name{color:var(--tx3)}
.trk-dose{font-family:var(--sm);font-size:.82rem;font-weight:500;color:var(--ac)}
.trk-row.trk-off .trk-dose{color:var(--tx3);font-style:italic}
.trk-tomorrow{font-size:.7rem;color:var(--tx3);margin-top:8px;padding-top:6px;border-top:1px solid var(--bdr)}
.tracker-setup{font-size:.82rem;color:var(--tx2)}
.tracker-date-input{background:var(--bg);border:1px solid var(--bdr);border-radius:6px;color:var(--tx);font-family:var(--sm);font-size:.8rem;padding:6px 10px;margin-top:8px;width:100%}
.tracker-date-input:focus{outline:none;border-color:var(--ac)}
.tracker-set-btn{margin-top:8px;padding:8px 16px;background:var(--ac);color:var(--bg);border:none;border-radius:6px;font-family:var(--ss);font-size:.8rem;font-weight:600;cursor:pointer}

/* ═══ CANCER TYPE CALLOUT on Your Dose ═══ */
.cancer-callout{background:var(--card2);border:1px solid var(--bdr);border-left:3px solid var(--ac);border-radius:var(--r);padding:12px 16px;margin-bottom:14px;font-size:.82rem;color:var(--tx2);line-height:1.65}
.cancer-callout strong{color:var(--tx);display:block;margin-bottom:2px}

/* ═══ HERX TRIAGE ═══ */
.herx-triage{background:var(--card);border:1px solid var(--bdr);border-radius:var(--r);margin-top:14px;overflow:hidden}
.herx-triage-btn{width:100%;background:none;border:none;padding:14px 16px;display:flex;align-items:center;gap:10px;cursor:pointer;color:var(--tx);text-align:left}
.herx-triage-btn:hover{background:var(--card2)}
.herx-triage-icon{font-size:1rem;flex-shrink:0}
.herx-triage-label{font-size:.86rem;font-weight:600;flex:1}
.herx-triage-chevron{color:var(--tx3);font-size:.8rem;transition:transform .2s}
.herx-triage-btn.open .herx-triage-chevron{transform:rotate(90deg)}
.herx-triage-body{display:none;padding:0 16px 16px;border-top:1px solid var(--bdr)}
.herx-triage-body.open{display:block}
.triage-row{padding:10px 0;border-bottom:1px solid var(--bdr)}
.triage-row:last-child{border-bottom:none}
.triage-sx{font-weight:600;font-size:.83rem;margin-bottom:3px}
.triage-action{font-size:.78rem;color:var(--tx2);line-height:1.55}
.triage-ok{color:var(--ac)}.triage-warn{color:var(--warn)}.triage-stop{color:var(--dng)}
.triage-check-row{display:flex;align-items:flex-start;gap:10px;cursor:pointer;margin-bottom:3px}
.triage-cb{flex-shrink:0;width:16px;height:16px;border:2px solid var(--bdr);border-radius:3px;display:inline-flex;align-items:center;justify-content:center;margin-top:2px;transition:.15s;cursor:pointer}
.triage-cb.checked{border-color:var(--ac);background:var(--ac)}
.triage-cb.checked::after{content:'\2714';font-size:.7rem;color:var(--bg);line-height:1}
.triage-cb-warn.checked{border-color:var(--warn);background:var(--warn)}

/* ═══ PRINT ═══ */
.print-btn{display:flex;align-items:center;gap:6px;font-size:.75rem;color:var(--tx3);background:none;border:1px solid var(--bdr);border-radius:6px;padding:6px 12px;cursor:pointer;transition:.2s;margin-top:10px}
.print-btn:hover{color:var(--tx);border-color:var(--bdr2)}
@media print{
  #parasiteBg,.pill-nav,.yd-btns,.herx-triage,.tracker-edit,.print-btn,footer,.modal-overlay,.ver-stamp{display:none!important}
  body{background:#fff;color:#000;font-size:12pt}
  .sec{display:block!important;padding:0}
  #sec-research,#sec-community,#sec-buy{display:none!important}
  .yd-d{break-inside:avoid}
}
.ob-form-grid{display:grid;gap:10px;margin-bottom:4px}
.ob-form-btn{background:var(--card);border:1px solid var(--bdr);border-radius:var(--r);padding:14px 16px;cursor:pointer;transition:.25s;text-align:left;width:100%}
.ob-form-btn:hover{border-color:var(--bdr2);background:var(--card2)}
.ob-form-btn.sel{border-color:var(--ac);background:var(--acd)}
.ob-form-name{font-weight:600;font-size:.9rem;margin-bottom:2px;color:var(--tx)}
.ob-form-conc{font-family:var(--sm);font-size:.75rem;color:var(--ac);margin-bottom:3px}
.ob-form-desc{font-size:.72rem;color:var(--tx2);line-height:1.4}
.ob-form-note{display:none}
#s3 .ob-pri{display:none}

/* ═══ COMPOUND ACCORDION ═══ */
.comp-btn{width:100%;background:var(--card);border:1px solid var(--bdr);border-radius:var(--r);padding:16px 18px;cursor:pointer;display:flex;align-items:center;gap:12px;text-align:left;transition:.2s;margin-bottom:8px}
.comp-btn:hover{border-color:var(--bdr2);background:var(--card2)}
.comp-btn.open{border-color:var(--ac);background:var(--card2);border-bottom-left-radius:0;border-bottom-right-radius:0;margin-bottom:0}
.comp-btn-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.comp-btn-info{flex:1}
.comp-btn-name{font-weight:700;font-size:.95rem;margin-bottom:2px;color:var(--tx)}
.comp-btn-sub{font-size:.73rem;color:var(--tx2)}
.comp-btn-chevron{color:var(--tx3);font-size:.85rem;transition:transform .2s;flex-shrink:0}
.comp-btn.open .comp-btn-chevron{transform:rotate(90deg);color:var(--ac)}
.comp-reveal{display:none;border:1px solid var(--ac);border-top:none;border-radius:0 0 var(--r) var(--r);padding:4px 0 12px;margin-bottom:16px;background:var(--card2)}
.comp-reveal.open{display:block}

/* ═══ SUPPLIERS — pill buttons ═══ */
.sup-pills{display:flex;flex-direction:column;gap:10px;margin-bottom:24px}
.sup-pill{display:flex;align-items:center;background:var(--card);border:1px solid var(--bdr);border-radius:var(--r);padding:14px 16px;text-decoration:none;color:var(--tx);transition:.2s;gap:12px}
.sup-pill:hover{border-color:var(--ac);background:var(--card2);transform:translateX(3px)}
.sup-pill-info{flex:1;min-width:0}
.sup-pill-name{font-weight:700;font-size:.95rem;margin-bottom:2px}
.sup-pill-tag{font-family:var(--sm);font-size:.62rem;text-transform:uppercase;letter-spacing:1px;margin-bottom:4px}
.sup-pill-tag.tf{color:var(--fenb)}.sup-pill-tag.ta{color:var(--ac)}.sup-pill-tag.tb{color:var(--meb)}
.sup-pill-desc{font-size:.75rem;color:var(--tx2);line-height:1.4}
.sup-pill-arrow{color:var(--ac);font-size:1.2rem;flex-shrink:0;opacity:.6;transition:.2s}
.sup-pill:hover .sup-pill-arrow{opacity:1}
.sup-w{margin-top:4px;background:var(--warnd);border:1px solid rgba(240,160,48,.2);border-radius:var(--r);padding:10px 14px;font-size:.74rem;color:var(--warn);line-height:1.6}

/* ═══ BINDERS ═══ */
.binders-box{background:var(--card);border:1px solid var(--bdr);border-left:3px solid var(--meb);border-radius:var(--r);padding:20px;margin-bottom:24px}
.binders-box h3{font-family:var(--sf);font-size:1.1rem;font-weight:500;margin-bottom:6px}
.binders-sub{font-size:.83rem;color:var(--tx2);line-height:1.75;margin-bottom:14px}
.binders-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.binder-c{background:var(--bg);border:1px solid var(--bdr);border-radius:6px;padding:10px 12px}
.binder-n{font-weight:600;font-size:.84rem;margin-bottom:2px}
.binder-d{font-family:var(--sm);font-size:.72rem;color:var(--meb);margin-bottom:3px}
.binder-w{font-size:.7rem;color:var(--tx2);line-height:1.4}
@media(max-width:480px){.binders-grid{grid-template-columns:1fr}}

/* Herx callout */
.herx-callout{background:var(--warnd);border:1px solid rgba(240,160,48,.25);border-radius:var(--r);padding:14px 16px;margin-bottom:16px;font-size:.83rem;color:var(--tx2);line-height:1.7}
.herx-callout strong{color:var(--warn)}

/* Featured product pill */

.buy-div{margin:32px 0 16px;padding-bottom:8px;border-bottom:1px solid var(--bdr)}
.buy-div h3{font-family:var(--sf);font-size:1.15rem;font-weight:400;margin-bottom:3px}.buy-div p{font-size:.78rem;color:var(--tx2)}
.spg{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:8px}
.spc{background:var(--card);border:1px solid var(--bdr);border-radius:6px;padding:12px 14px;display:flex;flex-direction:column;gap:3px}
.spn{font-weight:600;font-size:.85rem}.spd{font-family:var(--sm);font-size:.8rem;color:var(--ac)}.spx{font-size:.7rem;color:var(--tx3)}
.sp-lnk{margin-top:6px;display:inline-block;font-family:var(--sm);font-size:.68rem;color:var(--ac);text-decoration:none;padding:4px 10px;border:1px solid var(--ac);border-radius:4px;align-self:flex-start;transition:.2s}.sp-lnk:hover{background:var(--acd)}

/* ═══ RESEARCH INLINE TABS ═══ */
.rtabs{display:flex;gap:4px;margin-bottom:20px;border-bottom:1px solid var(--bdr);justify-content:center}
.rt{font-family:var(--ss);font-size:.78rem;font-weight:600;color:var(--tx2);background:none;border:none;padding:8px 14px;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:.2s}
.rt:hover{color:var(--tx)}.rt.on{color:var(--ac);border-bottom-color:var(--ac)}
.rp{display:none}.rp.on{display:block}

/* ═══ STUDIES ═══ */
.sb{position:relative;margin-bottom:12px}.sb input{width:100%;padding:10px 14px 10px 36px;background:var(--bg);border:1px solid var(--bdr);border-radius:6px;color:var(--tx);font-family:var(--ss);font-size:.85rem;outline:none}.sb input:focus{border-color:var(--ac)}.sb input::placeholder{color:var(--tx3)}
.si{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--tx3);font-size:.82rem}
.rf{display:flex;gap:5px;flex-wrap:wrap;margin-bottom:14px}
.fb{font-family:var(--ss);font-size:.7rem;font-weight:600;padding:4px 11px;border-radius:16px;border:1px solid var(--bdr);background:var(--card);color:var(--tx2);cursor:pointer;transition:.2s}.fb:hover{border-color:var(--bdr2);color:var(--tx)}.fb.on{background:var(--acd);border-color:var(--ac);color:var(--ac)}
.sc{background:var(--card);border:1px solid var(--bdr);border-radius:var(--r);padding:16px 18px;margin-bottom:8px;cursor:pointer;transition:.2s}.sc:hover{border-color:var(--bdr2)}.sc.ex{border-color:var(--ac);background:var(--card2)}
.sc-top{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}
.sc-t{font-family:var(--sf);font-size:.92rem;font-weight:500;line-height:1.4;flex:1}
.sc-b{display:flex;gap:4px;flex-shrink:0;flex-wrap:wrap;justify-content:flex-end}
.bg{font-family:var(--sm);font-size:.58rem;font-weight:500;padding:2px 6px;border-radius:3px;text-transform:uppercase;letter-spacing:.4px;white-space:nowrap}
.bg-iv{background:rgba(78,205,196,.15);color:var(--iver)}.bg-fe{background:rgba(240,160,48,.15);color:var(--fenb)}.bg-me{background:rgba(192,132,252,.15);color:var(--meb)}
.bg-nc{background:rgba(255,120,180,.15);color:#e880b0}.bg-al{background:rgba(130,180,220,.15);color:#7aaecd}.bg-pz{background:rgba(200,180,100,.15);color:#c0a860}.bg-nz{background:rgba(180,130,220,.15);color:#b094d6}.bg-ox{background:rgba(150,200,130,.15);color:#8fb87f}
.bg-cl{background:rgba(78,205,196,.2);color:#6ee7de}.bg-vo{background:rgba(240,160,48,.12);color:#d4a04a}.bg-vi{background:rgba(140,140,130,.12);color:#9a9688}
.bg-rv{background:rgba(192,132,252,.12);color:#b89aec}.bg-cs{background:rgba(224,96,80,.12);color:#e08070}.bg-rt{background:rgba(224,40,40,.2);color:#f06060}
.bg-t1{background:rgba(78,222,128,.18);color:#6edf90;letter-spacing:.5px}
.bg-t2{background:rgba(120,210,255,.15);color:#88c8ea;letter-spacing:.5px}
.bg-t3{background:rgba(240,200,80,.15);color:#e0c060;letter-spacing:.5px}
.bg-t4{background:rgba(240,150,60,.12);color:#d09550;letter-spacing:.5px}
.bg-t5{background:rgba(140,140,140,.12);color:#8a8a8a;letter-spacing:.5px}
.sc-m{display:flex;gap:12px;margin-top:5px;font-size:.7rem;color:var(--tx3);flex-wrap:wrap;align-items:baseline}
.sc-j{font-style:italic;color:var(--tx3);font-size:.7rem}
.sc-n{font-family:var(--sm);font-size:.65rem;color:var(--tx2)}
.sc-d{display:none;margin-top:12px;padding-top:12px;border-top:1px solid var(--bdr)}.sc.ex .sc-d{display:block}
.sc-f{font-size:.83rem;color:var(--tx2);line-height:1.7}
.sc-combo{font-size:.75rem;color:var(--tx2);margin-top:8px;font-family:var(--sm)}
.sc-mech{display:flex;gap:4px;flex-wrap:wrap;margin-top:8px}
.sc-mt{font-family:var(--sm);font-size:.6rem;padding:2px 7px;background:var(--bg2,rgba(255,255,255,.04));border:1px solid var(--bdr);border-radius:3px;color:var(--tx3);text-transform:lowercase;letter-spacing:.3px}
.sc-ids{font-family:var(--sm);font-size:.63rem;color:var(--tx3);margin-top:8px;word-break:break-all;opacity:.7}
.sc-a{display:inline-block;margin-top:8px;font-family:var(--sm);font-size:.7rem;color:var(--ac);text-decoration:none;border-bottom:1px solid var(--acd);transition:.2s}.sc-a:hover{border-color:var(--ac)}
.fb-strong{border-color:rgba(78,222,128,.4)!important}.fb-strong.on{background:rgba(78,222,128,.18)!important;color:#6edf90!important}

/* ═══ MECHANISMS ═══ */
.mg{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.mc h4{font-family:var(--sm);font-size:.68rem;text-transform:uppercase;letter-spacing:1.5px;margin-bottom:10px;padding-bottom:6px;border-bottom:2px solid}
.mc.i h4{color:var(--iver);border-color:var(--iver)}.mc.f h4{color:var(--fenb);border-color:var(--fenb)}
.mi{font-size:.8rem;color:var(--tx2);padding:4px 0;display:flex;gap:8px}.mn{font-family:var(--sm);font-size:.66rem;color:var(--tx3);width:18px;flex-shrink:0}

/* ═══ TIMELINE ═══ */
.tli{display:flex;gap:16px;padding:14px 18px;border-bottom:1px solid var(--bdr);background:rgba(25,28,26,.88);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}
.tli:first-of-type{border-top-left-radius:var(--r);border-top-right-radius:var(--r);border-top:1px solid var(--bdr);margin-top:8px}
.tli:last-of-type{border-bottom-left-radius:var(--r);border-bottom-right-radius:var(--r);border-bottom:1px solid var(--bdr);margin-bottom:8px}
.tly{font-family:var(--sm);font-size:.8rem;color:var(--ac);flex-shrink:0;width:60px}.tlc{font-size:.83rem;color:var(--tx2);line-height:1.6}.tlc strong{color:var(--tx);font-weight:500}
@media(prefers-color-scheme:light){:root:not(.dark-mode) .tli{background:rgba(255,255,255,.92)}}
.light-mode .tli{background:rgba(255,255,255,.92)}

/* ═══ SAFETY ═══ */
.sfc{background:var(--card);border:1px solid var(--bdr);border-radius:var(--r);padding:20px;margin-bottom:12px}.sfc.cr{border-left:3px solid var(--dng)}
.sfc h3{font-family:var(--sf);font-size:1.05rem;font-weight:500;margin-bottom:5px}
.sfi{padding:8px 10px;background:var(--bg);border-radius:6px;font-size:.8rem;margin-top:7px}

/* ═══ COMMUNITY ═══ */
.cs{text-align:center;padding:60px 20px}
.cs-icon{font-size:2.5rem;margin-bottom:12px;opacity:.4}
.cs-title{font-family:var(--sf);font-size:1.6rem;font-weight:400;margin-bottom:6px;color:var(--tx2)}
.cs-sub{font-size:.85rem;color:var(--tx3);max-width:380px;margin:0 auto}

/* ═══ VERSION STAMP ═══ */
.ver-stamp{position:fixed;bottom:12px;right:14px;font-family:var(--sm);font-size:.6rem;color:var(--tx2);z-index:9999;pointer-events:none;letter-spacing:.5px;opacity:1}

footer{padding:0;position:relative;z-index:1}
.footer-inner{max-width:var(--mw);margin:0 auto;padding:0 20px 24px}

/* ═══ RESPONSIVE ═══ */
@media(max-width:480px){
  .ob-hero-stats{grid-template-columns:1fr 1fr;max-width:260px}
  .ohs-n{font-size:1rem}.ohs-l{font-size:.6rem}
  .ob-soc span{font-size:.42rem}
  
  .pill{font-size:.65rem;padding:6px 9px}
}
@media(max-width:768px){
  .yd-g{grid-template-columns:1fr}.mg{grid-template-columns:1fr}
  .sc-top{flex-direction:column}.sc-b{justify-content:flex-start}
  .sup-c{flex:0 0 200px}
  .ob-hero img{width:85%}.ob-stage-grid{grid-template-columns:1fr 1fr}
  .spg{grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}
}
@media(min-width:769px){
  .ob-hero-stats{grid-template-columns:repeat(4,auto);max-width:none;justify-items:start}
}
@media(min-width:769px) and (max-width:1024px){
  .yd-g{grid-template-columns:1fr 1fr}
  .spg{grid-template-columns:repeat(auto-fill,minmax(190px,1fr))}
}
@media(min-width:1025px){
  .ct{padding:0 24px}
}
@keyframes fu{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}

/* ═══ WHO FORK ═══ */
.who-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:16px}
.who-card{background:var(--card);border:1px solid var(--bdr);border-radius:var(--r);padding:28px 16px;cursor:pointer;text-align:center;transition:.25s}
.who-card:hover{border-color:var(--ac);background:var(--card2);transform:translateY(-3px)}
.who-card-icon{font-size:2.8rem;margin-bottom:10px;line-height:1}
.who-card-label{font-weight:700;font-size:1rem;margin-bottom:4px}
.who-card-desc{font-size:.74rem;color:var(--tx2);line-height:1.4}

/* ═══ PET SPECIES TILES ═══ */
.pet-species-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:8px}
.pet-species-btn{background:var(--card);border:1px solid var(--bdr);border-radius:var(--r);padding:20px 8px 16px;cursor:pointer;text-align:center;transition:.25s;display:flex;flex-direction:column;align-items:center;gap:8px}
.pet-species-btn:hover{border-color:var(--ac);background:var(--card2);transform:translateY(-2px)}
.pet-species-btn.sel{border-color:var(--ac);background:var(--acd)}
.pet-species-icon{font-size:2.4rem;line-height:1;display:block}
.pet-species-name{font-size:.85rem;font-weight:700;color:var(--tx)}

/* ═══ PET OTHER ELEMENTS ═══ */
.pet-name-input{width:100%;background:var(--card);border:1px solid var(--bdr);border-radius:var(--r);padding:12px 14px;color:var(--tx);font-family:var(--ss);font-size:1rem;margin-bottom:14px;outline:none;transition:.2s}
.pet-name-input:focus{border-color:var(--ac)}
.pet-name-input::placeholder{color:var(--tx3)}
.mdr1-stop{background:var(--dngd);border:2px solid var(--dng);border-radius:var(--r);padding:24px;text-align:center;margin-bottom:16px}
.mdr1-stop-title{font-family:var(--sf);font-size:1.4rem;color:var(--dng);margin-bottom:10px}
.mdr1-stop-body{font-size:.85rem;color:var(--tx2);line-height:1.75;margin-bottom:14px}
.mdr1-stop-btn{display:inline-block;padding:10px 22px;background:var(--fenb);color:var(--bg);border:none;border-radius:6px;font-weight:700;cursor:pointer;font-family:var(--ss)}
.pet-mode-badge{display:inline-flex;align-items:center;gap:5px;font-family:var(--sm);font-size:.58rem;text-transform:uppercase;letter-spacing:1.5px;color:var(--fenb);background:rgba(240,160,48,.12);border-radius:12px;padding:3px 10px;margin-bottom:8px}
@media(max-width:400px){.pet-species-grid{grid-template-columns:repeat(2,1fr)}}


/* ═══ APP INSTALL BANNER ═══ */

/* ═══ INSTALL BUTTONS (legacy) ═══ */
.install-row{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;margin:14px 0 4px}
.install-btn{display:inline-flex;align-items:center;gap:7px;padding:10px 16px;background:var(--card);border:1px solid var(--bdr2);border-radius:8px;color:var(--tx);font-family:var(--ss);font-size:.78rem;font-weight:600;text-decoration:none;cursor:pointer;transition:.2s}
.install-btn:hover{border-color:var(--ac);color:var(--ac);background:var(--acd)}
.install-btn svg{width:15px;height:15px;flex-shrink:0}

/* ═══ PWA TOAST ═══ */
.pwa-toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);background:var(--card);border:1px solid var(--ac);border-radius:var(--r);padding:14px 18px;z-index:3000;display:flex;align-items:flex-start;gap:12px;box-shadow:0 8px 32px rgba(0,0,0,.5);max-width:340px;width:calc(100% - 32px);animation:pwaToastSlideUp .55s cubic-bezier(.2,.9,.3,1.05)}
@keyframes pwaToastSlideUp{from{opacity:0;transform:translate(-50%,90px)}to{opacity:1;transform:translate(-50%,0)}}
.pwa-toast.gone{display:none}
.pwa-toast-icon{font-size:1.5rem;flex-shrink:0;line-height:1;margin-top:2px}
.pwa-toast-body{flex:1;min-width:0}
.pwa-toast-title{font-weight:700;font-size:.86rem;margin-bottom:3px;color:var(--tx)}
.pwa-toast-sub{font-size:.76rem;color:var(--tx2);line-height:1.5;margin-bottom:10px}
.pwa-toast-btns{display:flex;gap:8px;align-items:center}
.pwa-toast-install{padding:6px 14px;background:var(--ac);color:var(--bg);border:none;border-radius:6px;font-family:var(--ss);font-size:.78rem;font-weight:700;cursor:pointer;white-space:nowrap;transition:.2s}.pwa-toast-install:hover{filter:brightness(1.1)}
.pwa-toast-dismiss{background:none;border:none;color:var(--tx3);font-size:.72rem;cursor:pointer;padding:2px}.pwa-toast-dismiss:hover{color:var(--tx2)}
.sup-pill--soon{opacity:.5;cursor:default;border-style:dashed;pointer-events:none}
/* ── Push notification UI ── */
.push-container{margin-top:10px;padding-top:8px;border-top:1px solid var(--bdr)}
.push-setup{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.push-bell{font-size:.9rem}
.push-label{font-size:.75rem;color:var(--tx2)}
.push-time{background:var(--bg);border:1px solid var(--bdr);border-radius:6px;color:var(--tx);font-size:.75rem;padding:4px 6px;cursor:pointer;outline:none;color-scheme:dark;font-family:var(--ss)}
.push-time:focus{border-color:var(--ac)}
.push-btn{padding:4px 12px;background:var(--ac);color:var(--bg);border:none;border-radius:6px;font-family:var(--ss);font-size:.72rem;font-weight:600;cursor:pointer;transition:.2s;white-space:nowrap}
.push-btn:hover{filter:brightness(1.1)}
.push-active{display:flex;align-items:center;gap:8px;font-size:.75rem;color:var(--tx2);flex-wrap:wrap}
.push-active strong{color:var(--tx)}
.push-cancel{background:none;border:1px solid var(--bdr);border-radius:6px;color:var(--tx3);font-size:.68rem;padding:3px 8px;cursor:pointer;margin-left:auto;transition:.2s}
.push-cancel:hover{border-color:var(--dng);color:var(--dng)}
.push-blocked{background:rgba(240,160,48,.08);border:1px solid rgba(240,160,48,.3);border-radius:var(--r);padding:12px 14px;font-size:.76rem;color:var(--tx2);line-height:1.5}
.push-blocked-title{font-weight:700;color:var(--warn);margin-bottom:6px;display:flex;align-items:center;gap:6px;font-size:.82rem}
.push-blocked-body{margin-bottom:10px}
.push-blocked-body strong{color:var(--tx)}
.push-blocked .push-btn{width:100%;display:block;text-align:center;padding:8px 14px}

/* ═══ LIGHT MODE ═══ */
:root.light-mode{
  --bg:#f8f7f5;--card:#ffffff;--card2:#f0efec;--bdr:#e2e0db;--bdr2:#d0cec8;
  --tx:#1a1d1b;--tx2:#6b6660;--tx3:#9a958e;
  --ac:#2ba89e;--acd:rgba(43,168,158,.10);
  --warn:#c88520;--warnd:rgba(200,133,32,.10);
  --dng:#c84840;--dngd:rgba(200,72,64,.08);
  --iver:#2ba89e;--fenb:#c88520;--meb:#9656e0
}
@media(prefers-color-scheme:light){
  :root:not(.dark-mode){
    --bg:#f8f7f5;--card:#ffffff;--card2:#f0efec;--bdr:#e2e0db;--bdr2:#d0cec8;
    --tx:#1a1d1b;--tx2:#6b6660;--tx3:#9a958e;
    --ac:#2ba89e;--acd:rgba(43,168,158,.10);
    --warn:#c88520;--warnd:rgba(200,133,32,.10);
    --dng:#c84840;--dngd:rgba(200,72,64,.08);
    --iver:#2ba89e;--fenb:#c88520;--meb:#9656e0
  }
}

/* Light mode overrides — .light-mode for manual, @media for auto */
.light-mode #parasiteBg,.light-mode #parasiteBg svg{opacity:.55;filter:brightness(.7) saturate(.8)}
.light-mode .pill-bar{background:rgba(160,160,155,.45);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-color:rgba(43,168,158,.3);box-shadow:0 4px 20px rgba(0,0,0,.08)}
.light-mode .pill{color:var(--tx2)}.light-mode .pill:hover{color:var(--tx)}.light-mode .pill.on{background:var(--ac);color:#fff}
.light-mode .modal-overlay{background:rgba(0,0,0,.45)}
.light-mode .ob-hero img,.light-mode .pill-logo img{filter:none}
.light-mode .ob-soc{color:var(--ac)}.light-mode .footer-socials a{color:var(--ac)}
@media(prefers-color-scheme:light){
  :root:not(.dark-mode) #parasiteBg,:root:not(.dark-mode) #parasiteBg svg{opacity:.55;filter:brightness(.7) saturate(.8)}
  :root:not(.dark-mode) .pill-bar{background:rgba(160,160,155,.45);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-color:rgba(43,168,158,.3);box-shadow:0 4px 20px rgba(0,0,0,.08)}
  :root:not(.dark-mode) .pill{color:var(--tx2)}
  :root:not(.dark-mode) .pill:hover{color:var(--tx)}
  :root:not(.dark-mode) .pill.on{background:var(--ac);color:#fff}
  :root:not(.dark-mode) .modal-overlay{background:rgba(0,0,0,.45)}
  :root:not(.dark-mode) .ob-hero img,:root:not(.dark-mode) .pill-logo img{filter:none}
  :root:not(.dark-mode) .ob-soc{color:var(--ac)}
  :root:not(.dark-mode) .footer-socials a{color:var(--ac)}
}

/* Print keeps light regardless */
@media print{:root{--bg:#fff;--card:#fff;--card2:#f5f5f5;--tx:#000;--tx2:#444;--bdr:#ddd}}

/* Settings gear + panel */
.theme-toggle{background:none;border:1px solid var(--bdr);border-radius:50%;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--tx3);font-size:.9rem;transition:.2s;flex-shrink:0;padding:0;line-height:1}
.theme-toggle:hover{border-color:var(--ac);color:var(--ac)}
#aiqSettingsPop{font-family:var(--ss)}
.aiq-settings-section{margin-bottom:12px}
.aiq-settings-section:last-child{margin-bottom:0}
.aiq-settings-label{font-family:var(--sm);font-size:.55rem;text-transform:uppercase;letter-spacing:1.5px;color:var(--tx3);margin-bottom:6px}
.aiq-settings-row{display:flex;gap:4px;flex-wrap:wrap}
.aiq-opt{background:var(--bg);border:1px solid var(--bdr);border-radius:6px;color:var(--tx2);font-family:var(--ss);font-size:.72rem;padding:5px 10px;cursor:pointer;text-align:center;transition:.15s;flex:1;min-width:0;white-space:nowrap}
.aiq-opt:hover{border-color:var(--ac);color:var(--tx)}
.aiq-opt.sel{border-color:var(--ac);background:var(--acd);color:var(--ac);font-weight:600}

/* ── Bug report button + modal ── */
