/* =========================================================================
   Refined Dark — shared design system (Phase 0)
   Consolidated from teaser_mockup.html + plan_unlocked_mockup.html.
   Every class from both mockups lives here; nothing dropped in the merge.
   Page-specific differences between the two mockups are reconciled under
   the `.page-teaser` scope near the bottom so each page stays pixel-faithful.
   ========================================================================= */

/* ---- Design tokens (union of both mockups) ---------------------------- */
:root{
  --bg:#16140F; --surface:#211E18; --surface2:#1B1813; --border:#2C2820;
  --text:#F2EDE4; --muted:#9B9488; --accent:#E0A458; --green:#8FB87A;
}

/* ---- Base ------------------------------------------------------------- */
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{background:var(--bg);color:var(--text);font-family:'Inter',sans-serif;line-height:1.65;padding:0 0 70px;}
.wrap{max-width:660px;margin:0 auto;padding:0 22px;}
.hidden{display:none !important;}
.loading{color:var(--muted);animation:pulse 1.4s ease-in-out infinite;}
@keyframes pulse{0%,100%{opacity:.45;}50%{opacity:.85;}}

/* ---- Loading skeletons (shimmer) — Refined Dark ---------------------- */
.skel-line{display:block;height:13px;border-radius:7px;background:var(--surface2);position:relative;overflow:hidden;margin:0 0 10px;}
.skel-line:last-child{margin-bottom:0;}
.skel-line::after{content:"";position:absolute;inset:0;transform:translateX(-100%);background:linear-gradient(90deg,transparent 0,rgba(224,164,88,.13) 50%,transparent 100%);animation:shimmer 1.5s ease-in-out infinite;}
.summary .skel-line{margin:11px 0;}
.skel-card{padding:16px 20px;}
@keyframes shimmer{100%{transform:translateX(100%);}}
@media(prefers-reduced-motion:reduce){.skel-line::after{animation:none;}.skel-line{opacity:.55;}}

/* ---- Shared hero / type (base = plan values) -------------------------- */
.hero{padding:50px 0 26px;scroll-margin-top:64px;}
.eyebrow{font-size:.74rem;letter-spacing:2.5px;text-transform:uppercase;color:var(--accent);font-weight:600;}
h1{font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:2.3rem;line-height:1.08;letter-spacing:-.5px;margin:12px 0 14px;}
.summary{color:#D8D2C7;font-size:1.02rem;max-width:560px;}
.summary b{color:var(--accent);font-weight:600;}
.chips{display:flex;gap:9px;flex-wrap:wrap;margin-top:20px;}
.chip{background:var(--surface);border:1px solid var(--border);border-radius:9px;padding:7px 14px;font-size:.82rem;}
.chip strong{color:var(--accent);font-weight:600;}

h2{font-family:'Space Grotesk',sans-serif;font-size:1.45rem;font-weight:600;margin:42px 0 8px;padding-bottom:10px;border-bottom:1px solid var(--border);scroll-margin-top:64px;}
.lead{color:var(--muted);font-size:.95rem;margin-bottom:18px;}

/* ---- Plan: sticky section nav ----------------------------------------- */
.nav{position:sticky;top:0;z-index:50;display:flex;gap:6px;flex-wrap:wrap;justify-content:center;padding:10px 8px;margin:0 -22px 4px;background:rgba(22,20,15,.93);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-bottom:1px solid var(--border);}
.nav a{color:var(--muted);text-decoration:none;font-size:.8rem;padding:5px 12px;border-radius:999px;white-space:nowrap;transition:.15s;}
.nav a:hover{color:var(--text);background:var(--surface);}

/* ---- Banner (callouts) ------------------------------------------------ */
.banner{display:flex;gap:14px;align-items:flex-start;background:rgba(224,164,88,.08);border:1px solid rgba(224,164,88,.25);border-radius:13px;padding:18px 20px;margin-top:20px;}
.banner .ic{color:var(--accent);flex:none;width:22px;height:22px;margin-top:2px;}
.banner .bt{font-family:'Space Grotesk',sans-serif;font-weight:600;margin-bottom:3px;}
.banner .bd{color:var(--muted);font-size:.9rem;}

/* ---- Day cards / exercises (shared) ----------------------------------- */
.day{background:var(--surface);border:1px solid var(--border);border-radius:14px;overflow:hidden;margin-bottom:12px;}
.day-head{display:flex;justify-content:space-between;align-items:center;padding:15px 20px;border-bottom:1px solid var(--border);}
.day-head .dt{font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:1rem;}
.day-head .dt .tag{color:var(--muted);font-weight:400;font-size:.82rem;}
.badge{background:rgba(224,164,88,.14);color:var(--accent);font-size:.72rem;font-weight:600;padding:4px 11px;border-radius:999px;letter-spacing:.4px;}
.badge.rest{background:rgba(155,148,136,.14);color:var(--muted);}
.ex{display:flex;justify-content:space-between;align-items:flex-start;gap:14px;padding:14px 20px;border-bottom:1px solid var(--border);}
.ex:last-child{border-bottom:none;}
.ex .name{font-weight:500;font-size:.96rem;}
.ex .note{display:block;font-size:.82rem;color:var(--muted);margin-top:3px;}
.ex .rx{font-family:'Space Grotesk',sans-serif;font-size:.86rem;color:var(--accent);font-weight:600;white-space:nowrap;text-align:right;}
.ex .rx small{display:block;color:var(--muted);font-weight:400;font-size:.74rem;margin-top:2px;}
.day-foot{padding:12px 20px;font-size:.82rem;color:var(--muted);background:var(--surface2);}
.day-foot b{color:var(--text);font-weight:500;}

/* ---- Plan: per-day session phases ------------------------------------- */
.phase{padding:11px 20px;border-bottom:1px solid var(--border);background:var(--surface2);}
.phase .ph{font-size:.7rem;text-transform:uppercase;letter-spacing:1.2px;color:var(--accent);font-weight:600;}
.phase .pc{font-size:.85rem;color:var(--muted);margin-top:2px;}
.worklabel{padding:10px 20px;font-size:.7rem;text-transform:uppercase;letter-spacing:1.2px;color:var(--text);font-weight:600;border-bottom:1px solid var(--border);}

/* ---- Plan: weekly schedule grid --------------------------------------- */
.weekgrid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;margin:6px 0 22px;}
.wd{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:11px 4px;text-align:center;}
.wd .d{font-size:.68rem;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);}
.wd .f{font-size:.8rem;font-weight:600;margin-top:4px;font-family:'Space Grotesk',sans-serif;}
.wd.train .f{color:var(--accent);}
.wd.rest{background:var(--surface2);}
.wd.rest .f{color:var(--muted);font-weight:400;}

/* ---- Plan: numbered steps --------------------------------------------- */
.steps{list-style:none;counter-reset:s;margin-top:6px;}
.steps li{counter-increment:s;position:relative;padding:13px 16px 13px 50px;background:var(--surface);border:1px solid var(--border);border-radius:11px;margin-bottom:9px;}
.steps li::before{content:counter(s);position:absolute;left:14px;top:13px;width:24px;height:24px;background:var(--accent);color:#231a0c;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.78rem;font-family:'Space Grotesk',sans-serif;}
.steps li .st{font-weight:500;font-size:.92rem;}
.steps li .sd{font-size:.82rem;color:var(--muted);}

/* ---- Plan: cards / params / macros / meals ---------------------------- */
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:6px;}
.card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:16px 18px;}
.card .ct{font-weight:600;font-size:.94rem;}
.card .cdose{color:var(--accent);font-size:.82rem;font-weight:600;font-family:'Space Grotesk',sans-serif;margin:3px 0 6px;}
.card .cd{font-size:.84rem;color:var(--muted);line-height:1.5;}

.params{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:14px;}
.param{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:16px 18px;}
.param .pl{font-size:.7rem;text-transform:uppercase;letter-spacing:1.5px;color:var(--accent);font-weight:600;}
.param .pv{font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:1.05rem;margin:4px 0 6px;}
.param .pw{font-size:.83rem;color:var(--muted);line-height:1.5;}

.macros{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-top:6px;}
.macro{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:16px;text-align:center;}
.macro .mv{font-family:'Space Grotesk',sans-serif;font-size:1.5rem;font-weight:600;}
.macro.cal .mv{color:var(--accent);}
.macro .ml{font-size:.7rem;text-transform:uppercase;letter-spacing:1px;color:var(--muted);margin-top:2px;}

.meal{display:flex;gap:14px;padding:12px 0;border-bottom:1px solid var(--border);}
.meal:last-child{border-bottom:none;}
.meal .mt{font-size:.76rem;text-transform:uppercase;letter-spacing:.5px;color:var(--accent);font-weight:600;width:90px;flex:none;padding-top:2px;}
.meal .mc{font-size:.9rem;}
.meal .mc small{color:var(--muted);}

/* ---- Teaser: section label -------------------------------------------- */
.sec-label{font-family:'Space Grotesk',sans-serif;font-size:1.35rem;font-weight:600;margin:38px 0 16px;}

/* ---- Teaser: locked / blurred exercise rows --------------------------- */
.rx-lock{display:inline-flex;align-items:center;gap:6px;}
.blur{filter:blur(5px);user-select:none;font-family:'Space Grotesk',monospace;color:var(--accent);font-weight:600;font-size:.86rem;}
.lk{width:13px;height:13px;flex:none;color:var(--muted);}
.locked-day{position:relative;}
.locked-day .ex .name{filter:blur(5px);user-select:none;color:var(--muted);}
.lock-tag{display:flex;align-items:center;justify-content:center;gap:8px;padding:14px;color:var(--muted);font-size:.85rem;}
.lock-tag .lk{width:15px;height:15px;}

/* ---- Teaser: nutrition hook ------------------------------------------- */
.nut{display:flex;align-items:center;justify-content:space-between;gap:16px;background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:18px 22px;flex-wrap:wrap;}
.nut .cal .n{font-family:'Space Grotesk',sans-serif;font-size:1.8rem;font-weight:600;color:var(--accent);}
.nut .cal .l{font-size:.74rem;text-transform:uppercase;letter-spacing:1px;color:var(--muted);}
.nut .more{display:flex;align-items:center;gap:8px;color:var(--muted);font-size:.88rem;}

/* ---- Teaser: unlock list ---------------------------------------------- */
.unlock-list{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:8px 4px;}
.ul-row{display:flex;align-items:center;gap:12px;padding:11px 18px;font-size:.94rem;}
.ul-row + .ul-row{border-top:1px solid var(--border);}
.ul-row .lk{width:16px;height:16px;color:var(--accent);}
.ul-row .tag{margin-left:auto;font-size:.7rem;text-transform:uppercase;letter-spacing:.8px;color:var(--muted);}

/* ---- Teaser: CTA + buttons -------------------------------------------- */
.cta{background:var(--surface2);border:1px solid var(--border);border-radius:16px;padding:30px 26px;text-align:center;margin-top:34px;}
.cta h3{font-family:'Space Grotesk',sans-serif;font-size:1.4rem;font-weight:600;}
.cta .price{font-family:'Space Grotesk',sans-serif;font-size:2.6rem;font-weight:700;margin:14px 0 2px;}
.cta .price small{font-size:1rem;color:var(--muted);font-weight:500;}
.cta .reassure{color:var(--muted);font-size:.85rem;margin-bottom:20px;}
.btn{display:inline-block;width:100%;max-width:340px;background:var(--accent);color:#231a0c;font-weight:600;font-size:1.02rem;font-family:'Space Grotesk',sans-serif;border:none;border-radius:11px;padding:15px 24px;cursor:pointer;text-decoration:none;text-align:center;}
.btn:hover{filter:brightness(1.06);}
.btn:disabled,.btn.disabled{opacity:.4;cursor:not-allowed;filter:none;}
.fine{color:var(--muted);font-size:.78rem;margin-top:14px;}

/* =======================================================================
   Page-scoped reconciliation — teaser mockup used slightly different
   values for a few shared elements. Restore them only on the teaser page
   so it stays pixel-identical to teaser_mockup.html.
   ======================================================================= */
.page-teaser{line-height:1.6;}
.page-teaser .wrap{max-width:640px;}
.page-teaser .hero{padding:52px 0 30px;}
.page-teaser h1{font-size:2.4rem;}
.page-teaser .summary{font-size:1.04rem;max-width:540px;}
.page-teaser .chips{margin-top:22px;}
.page-teaser .ex{align-items:center;gap:0;padding:13px 20px;}

/* =======================================================================
   Landing + quiz (Phase 0 front-end, index.html / quiz.js)
   New classes — not from the mockups, but built in the same Refined Dark
   language (surface bg, 1px border, 14px radius, amber accent).
   ======================================================================= */

/* ---- Brand wordmark --------------------------------------------------- */
.brand{display:inline-block;font-family:'Space Grotesk',sans-serif;font-weight:700;letter-spacing:-.5px;color:var(--text);text-decoration:none;}
.brand .dot{color:var(--accent);}
.brandbar{padding:22px 0 0;}
.brandbar .brand{font-size:1.4rem;}
.brand-sm{font-size:1.05rem;}

/* ---- Landing ---------------------------------------------------------- */
.landing-sub{color:var(--muted);font-size:1rem;margin-top:14px;max-width:520px;}
.landing-cta{margin-top:30px;}
.sample{margin-top:36px;}
.sample .sample-cap{font-size:.72rem;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);font-weight:600;margin-bottom:10px;}

/* ---- Quiz progress (sticky) ------------------------------------------- */
.progress{position:sticky;top:0;z-index:50;background:rgba(22,20,15,.93);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-bottom:1px solid var(--border);margin:0 -22px;padding:12px 22px;}
.progress .bar{height:6px;background:var(--surface);border-radius:999px;overflow:hidden;}
.progress .fill{height:100%;width:0;background:var(--accent);border-radius:999px;transition:width .25s ease;}
.progress .lbl{display:flex;justify-content:space-between;font-size:.76rem;color:var(--muted);margin-top:7px;}
.progress .lbl b{color:var(--text);font-weight:600;}

/* ---- Quiz question blocks --------------------------------------------- */
.q{margin:34px 0;scroll-margin-top:80px;}
.q-num{font-size:.72rem;letter-spacing:1.5px;text-transform:uppercase;color:var(--accent);font-weight:600;}
.q-title{font-family:'Space Grotesk',sans-serif;font-size:1.3rem;font-weight:600;margin:6px 0 4px;line-height:1.2;}
.q-sub{color:var(--muted);font-size:.9rem;margin:8px 0 16px;}
.q-micro{color:var(--muted);font-size:.9rem;margin:8px 0 16px;}
.subhead{font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:.95rem;margin:18px 0 10px;}
.subhead .opt-hint{color:var(--muted);font-weight:400;font-size:.82rem;}

/* ---- Selectable options ----------------------------------------------- */
.opts{display:flex;flex-direction:column;gap:10px;}
.opts.cols2{display:grid;grid-template-columns:1fr 1fr;}
.opt{display:flex;gap:13px;align-items:flex-start;background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:14px 16px;cursor:pointer;transition:.15s;text-align:left;width:100%;color:var(--text);}
.opt:hover{border-color:rgba(224,164,88,.45);}
.opt.selected{border-color:var(--accent);background:rgba(224,164,88,.09);}
.opt.disabled{opacity:.4;pointer-events:none;}
.opt .oemoji{font-size:1.35rem;line-height:1.2;flex:none;}
.opt .obody{flex:1;}
.opt .ot{display:block;font-weight:600;font-size:.98rem;line-height:1.3;}
.opt .os{display:block;color:var(--muted);font-size:.85rem;margin-top:4px;line-height:1.4;}
.opt .oe{display:block;color:var(--muted);font-size:.78rem;margin-top:6px;font-style:italic;line-height:1.4;}
.opt .otick{flex:none;width:20px;height:20px;border-radius:50%;border:1.5px solid var(--border);display:flex;align-items:center;justify-content:center;color:#231a0c;font-size:.7rem;font-weight:700;}
.opt.selected .otick{background:var(--accent);border-color:var(--accent);}

/* ---- Day picker (Q6) -------------------------------------------------- */
.daypick{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;}
.daycell{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:14px 4px;text-align:center;cursor:pointer;font-size:.82rem;font-weight:600;font-family:'Space Grotesk',sans-serif;transition:.15s;color:var(--muted);}
.daycell:hover{border-color:rgba(224,164,88,.45);}
.daycell.selected{border-color:var(--accent);background:rgba(224,164,88,.12);color:var(--accent);}

/* ---- Inputs ----------------------------------------------------------- */
.field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px;}
.field label{font-size:.85rem;color:var(--muted);font-weight:500;}
input[type=number],input[type=text],textarea{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:12px 14px;color:var(--text);font-family:'Inter',sans-serif;font-size:.95rem;width:100%;}
input[type=number]:focus,input[type=text]:focus,textarea:focus{outline:none;border-color:var(--accent);}
textarea{resize:vertical;min-height:70px;line-height:1.5;}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
.suffix{position:relative;}
.suffix .u{position:absolute;right:14px;top:50%;transform:translateY(-50%);color:var(--muted);font-size:.85rem;pointer-events:none;}
.suffix input{padding-right:48px;}

/* ---- Unit toggle ------------------------------------------------------ */
.toggle{display:inline-flex;background:var(--surface);border:1px solid var(--border);border-radius:999px;padding:3px;margin-bottom:14px;}
.toggle button{background:none;border:none;color:var(--muted);font-family:'Inter',sans-serif;font-size:.85rem;font-weight:600;padding:7px 16px;border-radius:999px;cursor:pointer;}
.toggle button.active{background:var(--accent);color:#231a0c;}

/* ---- Safety gates ----------------------------------------------------- */
.gate{display:flex;gap:12px;align-items:flex-start;background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:14px 16px;cursor:pointer;margin-bottom:10px;}
.gate input{margin-top:3px;width:18px;height:18px;flex:none;accent-color:var(--accent);cursor:pointer;}
.gate .gt{font-size:.88rem;}

/* ---- Validation ------------------------------------------------------- */
.err{color:#e07a7a;font-size:.82rem;margin-top:8px;display:none;}
.q.invalid .err{display:block;}
.q.invalid .q-title{color:#e07a7a;}

.submit-wrap{text-align:center;margin-top:40px;}
.submit-note{color:var(--muted);font-size:.8rem;margin-top:12px;}

@media(max-width:600px){
  .weekgrid{grid-template-columns:repeat(4,1fr);}
  .grid2,.macros{grid-template-columns:1fr 1fr;}
  .opts.cols2{grid-template-columns:1fr;}
}
