/* ============================================================
   GR8MD design kit · components.css
   Layout + components. Load after tokens.css.
   Per-card colour is set with custom properties on the element:
     .fcard  --fb tile colour, --fi ink on tile, --fk light-mode mantra colour
     .fmini  --mc foundation colour (flip tile)
     .rcard  use .r-morning / .r-day / .r-evening
     .cal-day --cc day colour
     .pemblem --pe emblem colour
   ============================================================ */

/* ---- Base ---- */
*{box-sizing:border-box;margin:0;padding:0;}
[hidden]{display:none !important;}
html{scroll-behavior:smooth;}
body{font-family:var(--font);background:var(--bg);color:var(--fg);font-size:17px;line-height:1.5;
  -webkit-font-smoothing:antialiased;transition:background .35s ease,color .35s ease;}
a{color:inherit;text-decoration:none;}
img{display:block;}
.wrap{max-width:1060px;margin:0 auto;padding:0 28px;}
:focus-visible{outline:2px solid var(--accent);outline-offset:2px;}

/* ---- Skip link ---- */
.skip{position:absolute;left:-9999px;top:0;z-index:100;background:var(--fg);color:var(--bg);
  padding:10px 16px;border-radius:0 0 10px 0;font-weight:600;font-size:13px;}
.skip:focus{left:0;}

/* ---- Nav ---- */
.nav{position:sticky;top:0;z-index:50;background:var(--nav-bg);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);
  border-bottom:1px solid var(--line);}
.nav-inner{max-width:1180px;margin:0 auto;display:flex;align-items:center;gap:22px;padding:12px 28px;}
.logo{display:flex;align-items:center;}
.logo-stack{position:relative;display:inline-block;height:22px;}
.logo-letters{height:22px;width:auto;}
:root[data-theme="light"] .logo-dark{display:block;} :root[data-theme="light"] .logo-light{display:none;}
:root[data-theme="dark"] .logo-dark{display:none;} :root[data-theme="dark"] .logo-light{display:block;}
.logo-eight{position:absolute;left:-0.3%;top:-10.7%;width:100.3%;height:137%;background-color:var(--accent);transition:background-color .45s ease;
  -webkit-mask-repeat:no-repeat;mask-repeat:no-repeat;-webkit-mask-size:100% 100%;mask-size:100% 100%;-webkit-mask-position:center;mask-position:center;}
.logo-word{font-family:var(--font);font-weight:700;font-size:20px;letter-spacing:-.02em;color:var(--fg);display:inline-flex;align-items:center;line-height:1;transition:transform .28s cubic-bezier(.2,.7,.2,1);transform-origin:left center;}
.logo:hover .logo-word{transform:scale(1.08);}
.logo-helix{display:inline-flex;align-items:center;justify-content:center;width:.76em;height:1.4em;margin:0 .05em;}
.logo-helix svg{width:100%;height:100%;color:var(--accent);transition:color .45s ease;}
.nav-links{display:flex;gap:26px;font-size:13px;color:var(--muted);margin:0 auto;white-space:nowrap;}
.nav-links a:hover{color:var(--fg);}

/* ---- Segmented control (FOR HIM / FOR HER) ---- */
.seg{display:flex;gap:3px;background:var(--cell);border-radius:999px;padding:3px;position:relative;}
.seg button{font-family:var(--font);font-size:11.5px;font-weight:600;letter-spacing:.04em;border:0;background:none;
  color:var(--muted);padding:6px 13px;border-radius:999px;cursor:pointer;transition:color .25s ease,background .25s ease;}
.seg button[aria-pressed="true"]{background:var(--accent);color:#fff;}

/* ---- Icon button + account ---- */
.icon-btn{width:34px;height:34px;border-radius:50%;border:0;background:var(--cell);color:var(--fg);cursor:pointer;
  display:inline-flex;align-items:center;justify-content:center;}
.icon-btn svg{width:16px;height:16px;}
.acct-btn{position:relative;}
.acct-btn:hover{color:var(--accent);}
.acct-btn .ic-her{display:none;}
:root[data-path="her"] .acct-btn .ic-him{display:none;}
:root[data-path="her"] .acct-btn .ic-her{display:block;}
.acct-btn.has-acct::after{content:'';position:absolute;top:0;right:0;width:9px;height:9px;border-radius:50%;background:var(--accent);border:2px solid var(--bg);}

/* ---- Theme toggle — accent knob with a single centred icon ---- */
#themeToggle{position:relative;width:54px;height:28px;border-radius:999px;background:var(--cell);border:1px solid var(--line);padding:0;cursor:pointer;flex:none;display:block;transition:border-color .2s ease;}
#themeToggle:hover{border-color:var(--muted);}
#themeToggle::after{content:'';position:absolute;top:50%;left:3px;width:22px;height:22px;border-radius:50%;transform:translate(0,-50%);background:var(--accent);box-shadow:0 2px 6px rgba(0,0,0,.2);transition:transform .32s cubic-bezier(.2,.7,.2,1),background .3s ease;z-index:0;}
:root[data-theme="dark"] #themeToggle::after{transform:translate(26px,-50%);}
#themeToggle svg{position:absolute;top:50%;left:14px;width:12px;height:12px;transform:translate(-50%,-50%);color:#fff;z-index:1;transition:left .32s cubic-bezier(.2,.7,.2,1);}
:root[data-theme="dark"] #themeToggle svg{left:40px;}
:root[data-theme="light"] #themeToggle #iconMoon{display:none;}
:root[data-theme="dark"] #themeToggle #iconSun{display:none;}

/* ---- Buttons ---- */
.btn{display:inline-block;font-family:var(--font);font-size:13px;font-weight:500;color:#fff;background:var(--accent);
  border:0;border-radius:999px;padding:8px 18px;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease,background .3s ease;}
.btn:hover{transform:translateY(-1px);box-shadow:0 8px 20px color-mix(in srgb,var(--accent) 40%,transparent);}
.btn-lg{font-size:16px;padding:13px 28px;}
/* inverted nav CTA: accent text on page bg, accent border + soft glow pulse */
.nav .btn{background:var(--bg);color:var(--accent);border:1.5px solid var(--accent);animation:navGlow 2.8s ease-in-out infinite;}
.nav .btn:hover{background:var(--accent);color:#fff;transform:translateY(-1px);animation-play-state:paused;}
.tlink{font-size:16px;color:var(--accent);font-weight:400;}
.tlink:hover{text-decoration:underline;}

/* ---- Hero ---- */
.hero{padding:96px 28px 72px;text-align:center;}
.hero .eyebrow{font-size:14px;font-weight:600;color:var(--muted);}
.hero h1{font-weight:700;font-size:clamp(44px,8vw,80px);letter-spacing:-.028em;line-height:1.02;margin-top:12px;
  background:var(--hero-grad);-webkit-background-clip:text;background-clip:text;color:transparent;background-size:220% auto;}
.hero .sub{font-size:clamp(17px,2.3vw,20px);line-height:1.5;color:var(--muted);max-width:46ch;margin:18px auto 0;text-wrap:pretty;}
.hero .cta-row{display:flex;align-items:center;justify-content:center;gap:26px;margin-top:26px;flex-wrap:wrap;}
.hero .fine{font-size:12.5px;color:var(--faint);margin-top:16px;}

/* ---- Sections ---- */
.sec{padding:56px 0;}
.sec-head{text-align:center;max-width:62ch;margin:0 auto 36px;}
.sec-head h2{font-weight:700;font-size:clamp(30px,4.4vw,40px);letter-spacing:-.022em;line-height:1.1;}
.sec-head p{font-size:17px;color:var(--muted);margin-top:10px;text-wrap:pretty;}

/* ---- Bento ---- */
.bento{display:grid;grid-template-columns:repeat(6,1fr);gap:14px;}
.cell{background:var(--cell);border-radius:24px;padding:30px 32px;transition:background .35s ease,transform .3s ease,box-shadow .3s ease;}
@media (hover:hover){.cell:hover{transform:translateY(-5px) scale(1.035);box-shadow:var(--shadow);position:relative;z-index:3;}}
.cell .k{font-size:12px;font-weight:600;letter-spacing:.08em;color:var(--muted);}
.cell h3{font-weight:700;font-size:26px;letter-spacing:-.02em;margin-top:6px;}
.span4{grid-column:span 4;} .span3{grid-column:span 3;} .span2{grid-column:span 2;} .span6{grid-column:span 6;}
.bignum{font-weight:700;font-size:62px;letter-spacing:-.03em;line-height:1;
  background:var(--warm-grad);-webkit-background-clip:text;background-clip:text;color:transparent;}
.cell .cap{font-size:13px;color:var(--muted);margin-top:6px;line-height:1.5;}
.cell .cap b{color:var(--fg);font-weight:600;}

/* flip tile — front shows icon, back shows mantra (set --mc) */
.fmini{aspect-ratio:1;border-radius:11px;display:block;perspective:560px;}
.fmini-in{display:block;position:relative;width:100%;height:100%;transition:transform .5s cubic-bezier(.4,.1,.2,1);transform-style:preserve-3d;}
@media (hover:hover){.fmini:hover .fmini-in{transform:rotateY(180deg);}}
.fmini-f,.fmini-b{position:absolute;inset:0;border-radius:11px;display:flex;align-items:center;justify-content:center;
  backface-visibility:hidden;-webkit-backface-visibility:hidden;
  background:color-mix(in srgb,var(--mc) 26%,var(--cell-2));box-shadow:inset 0 0 0 1.5px color-mix(in srgb,var(--mc) 48%,transparent);}
.fmini-f{font-size:17px;line-height:1;}
.fmini-f img{width:64%;height:64%;object-fit:contain;display:block;}
.fmini-b{transform:rotateY(180deg);color:var(--fg);font-size:12.5px;font-weight:700;letter-spacing:-.02em;line-height:1.05;text-align:center;padding:2px;
  background:color-mix(in srgb,var(--mc) 40%,var(--cell-2));}

.spectrum{display:flex;height:10px;border-radius:5px;overflow:hidden;margin-top:16px;}
.spectrum div{flex:1;}
.phase-row{display:flex;align-items:flex-start;gap:10px;margin-top:13px;}
.phase-row .pd{width:9px;height:9px;border-radius:50%;flex:none;margin-top:6px;}
.phase-row .pt{font-size:14.5px;line-height:1.45;}
.phase-row .pt b{font-weight:650;}
.cell-paths{background:var(--paths-grad);color:#fff;display:flex;flex-direction:column;justify-content:center;}
.cell-paths .k{color:rgba(255,255,255,.65);}
.cell-paths h3{color:#fff;font-size:23px;line-height:1.2;}
.cell-paths .cap{color:rgba(255,255,255,.72);}

/* journey loop (milestone dots; pulse keyframes in motion.css) */
.journey-track{display:flex;align-items:center;margin-top:22px;}
.journey-track .jdot{width:11px;height:11px;border-radius:50%;background:var(--dot-idle);flex:none;
  animation:jdot 9.6s linear infinite;animation-delay:calc(var(--i)*1.6s);}
.journey-track .jseg{flex:1;height:2px;background:var(--track);}
.journey-labels{display:flex;justify-content:space-between;margin-top:12px;font-size:12px;color:var(--muted);gap:6px;}
.journey-labels b{color:var(--fg);font-weight:600;}

/* ---- Foundations grid ---- */
.fgrid{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;}
.fcard{background:var(--cell);border-radius:20px;padding:22px 18px;text-align:center;position:relative;
  transition:transform .3s ease,box-shadow .3s ease,background .35s ease;}
.fcard.fclick{cursor:pointer;}
.fchap{position:absolute;top:11px;right:13px;font-size:10.5px;font-weight:700;letter-spacing:.06em;color:var(--muted);opacity:.6;}
.fcard.fclick .fread{font-size:11.5px;font-weight:700;color:var(--accent-strong);margin-top:10px;opacity:0;transition:opacity .25s ease;}
:root[data-theme="dark"] .fcard.fclick .fread{color:var(--fb);}
@media (hover:hover){.fcard.fclick:hover .fread{opacity:1;}}
@media (hover:hover){.fcard:hover{transform:translateY(-6px) scale(1.07);box-shadow:0 22px 44px color-mix(in srgb,var(--fb) 42%,transparent);position:relative;z-index:3;}}
.fcard .icn{width:58px;height:58px;border-radius:17px;margin:0 auto;display:flex;align-items:center;justify-content:center;
  font-weight:700;font-size:28px;line-height:1;background:var(--fb);color:var(--fi);box-shadow:0 6px 16px color-mix(in srgb,var(--fb) 40%,transparent);}
.fcard .fn{font-weight:650;font-size:15.5px;margin-top:12px;}
.fcard .fm{font-size:12.5px;color:var(--accent-strong);font-weight:550;margin-top:2px;}
:root[data-theme="dark"] .fcard .fm{color:var(--fb);}
:root[data-theme="light"] .fcard .fm{color:var(--fk,var(--fi));}
.fcard .fd{font-size:12.5px;color:var(--muted);line-height:1.45;margin-top:8px;}
.fnote{text-align:center;font-size:14px;color:var(--muted);margin-top:24px;}

/* ---- Routines (time-of-day cards) ---- */
.routines{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;}
.rcard{background:var(--cell);border-radius:24px;padding:30px 28px;text-align:center;position:relative;overflow:hidden;
  transition:transform .3s ease,box-shadow .3s ease;}
.rcard::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:var(--t);}
@media (hover:hover){.rcard:hover{transform:translateY(-6px) scale(1.06);box-shadow:0 22px 44px color-mix(in srgb,var(--t) 35%,transparent);position:relative;z-index:3;}}
.rcard .rgo{font-size:12.5px;font-weight:650;color:var(--t-ink,var(--accent-strong));margin-top:12px;transition:transform .25s ease;}
:root[data-theme="dark"] .rcard .rgo{color:var(--t);}
@media (hover:hover){.rcard:hover .rgo{transform:translateX(3px);}}
.rcard .ric{width:48px;height:48px;border-radius:50%;margin:0 auto;display:flex;align-items:center;justify-content:center;
  background:color-mix(in srgb,var(--t) 38%,transparent);font-size:24px;line-height:1;}
.rcard .ric svg{width:22px;height:22px;color:var(--ti);}
:root[data-theme="dark"] .rcard .ric svg{color:var(--t);}
.rcard .rt{font-weight:650;font-size:18px;margin-top:14px;}
.rcard .rd{font-size:14px;color:var(--muted);margin-top:5px;line-height:1.5;}
.r-morning{--t:var(--t-morning);--ti:var(--t-morning-ink);}
.r-day{--t:var(--t-day);--ti:var(--t-day-ink);}
.r-evening{--t:var(--t-evening);--ti:var(--t-evening-ink);}

/* ---- Weekly calendar ---- */
.cal{display:grid;grid-template-columns:repeat(7,1fr);gap:10px;}
.cal-day{display:flex;flex-direction:column;gap:8px;text-decoration:none;color:inherit;}
.cal-dow{font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);text-align:center;}
.cal-cell{flex:1;background:var(--cell);border:1px solid transparent;border-radius:18px;min-height:158px;padding:16px 12px;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;text-align:center;
  transition:transform .25s ease,box-shadow .25s ease,background .25s ease;}
.cal-cell.rest{background:color-mix(in srgb,var(--cell) 55%,transparent);border:1px solid var(--line);color:var(--muted);font-size:14px;font-weight:600;letter-spacing:-.01em;gap:9px;}
.cal-cell.rest::before{content:'';width:8px;height:8px;border-radius:50%;background:color-mix(in srgb,var(--accent) 50%,var(--line));}
.cal-day.active .cal-cell{background:color-mix(in srgb,var(--cc) 14%,var(--cell));border-color:color-mix(in srgb,var(--cc) 38%,transparent);}
.cal-tag{font-size:10.5px;font-weight:700;letter-spacing:.08em;color:#fff;background:var(--cc);border-radius:999px;padding:4px 11px;}
.cal-t{font-weight:700;font-size:15.5px;letter-spacing:-.01em;margin-top:4px;}
.cal-m{font-size:11.5px;color:var(--muted);}
.cal-go{font-size:11px;font-weight:700;color:var(--cc);margin-top:6px;opacity:0;transform:translateY(2px);transition:opacity .25s ease,transform .25s ease;}
@media (hover:hover){
  .cal-day.active:hover .cal-cell{transform:translateY(-5px);box-shadow:0 16px 32px color-mix(in srgb,var(--cc) 30%,transparent);background:color-mix(in srgb,var(--cc) 22%,var(--cell));}
  .cal-day.active:hover .cal-go{opacity:1;transform:none;}
}
.weeknote{text-align:center;font-size:14px;color:var(--muted);margin-top:24px;}
@media (max-width:760px){
  .cal{grid-template-columns:repeat(7,minmax(118px,1fr));overflow-x:auto;scrollbar-width:none;padding-bottom:6px;}
  .cal::-webkit-scrollbar{display:none;}
}

/* ---- Marquee (overlays) ---- */
.ov-marquee{overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent);}
.ov-track{display:flex;width:max-content;animation:ovScroll 42s linear infinite;}
.ov-marquee:hover .ov-track,.ov-marquee:focus-within .ov-track{animation-play-state:paused;}
.ov-set{display:flex;gap:14px;padding-right:14px;flex:none;}
.ovc{width:240px;flex:none;background:var(--cell);border-radius:20px;padding:24px;transition:background .3s ease,transform .3s ease,box-shadow .3s ease;}
@media (hover:hover){.ovc:hover{transform:scale(1.07);box-shadow:var(--shadow);position:relative;z-index:3;}}
.ovc svg{width:24px;height:24px;color:var(--accent);}
.ovc .ovi{font-size:26px;line-height:1;display:inline-block;}
a.ovc{display:block;color:inherit;cursor:pointer;}
.ovc .on{font-weight:650;font-size:17px;margin-top:12px;}
.ovc .og{font-size:13.5px;color:var(--muted);margin-top:3px;line-height:1.45;}
.ovnote{text-align:center;font-size:14px;color:var(--muted);margin-top:22px;}

/* ---- Path cards (horizontal scroll) ---- */
.pgrid{display:flex;gap:14px;overflow-x:auto;scroll-snap-type:x proximity;padding:8px 4px 16px;max-width:none;margin:0;
  scrollbar-width:none;-webkit-overflow-scrolling:touch;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 2.5%,#000 97.5%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 2.5%,#000 97.5%,transparent);}
.pgrid::-webkit-scrollbar{display:none;}
:root[data-path="him"] .pcol-her{display:none;}
:root[data-path="her"] .pcol-him{display:none;}
.pcard{flex:0 0 214px;scroll-snap-align:center;border-radius:24px;padding:24px 22px;min-height:202px;
  display:flex;flex-direction:column;text-align:left;position:relative;overflow:hidden;
  transition:transform .3s ease,box-shadow .3s ease;}
@media (hover:hover){.pcard:hover{transform:translateY(-6px) scale(1.04);box-shadow:0 22px 44px rgba(0,0,0,.22);position:relative;z-index:3;}}
.pcard .pemoji{font-size:38px;line-height:1;}
.pcard .ptext{margin-top:auto;}
.pcard .pn{font-weight:700;font-size:22px;letter-spacing:-.01em;}
.pcard .pw{font-size:13px;margin-top:5px;opacity:.85;line-height:1.4;}
.pcard .pgo{font-size:12.5px;font-weight:700;margin-top:12px;opacity:.95;display:inline-flex;gap:5px;align-items:center;transition:gap .25s ease;}
@media (hover:hover){.pcard:hover .pgo{gap:9px;}}
.pathnote{text-align:center;font-size:13.5px;color:var(--muted);margin-top:20px;max-width:60ch;margin-left:auto;margin-right:auto;}

/* ---- Pricing ---- */
.pricing{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;align-items:start;}
.ptier{background:var(--cell);border:1px solid var(--line);border-radius:24px;padding:30px 28px;position:relative;display:flex;flex-direction:column;
  transition:transform .3s ease,box-shadow .3s ease;}
@media (hover:hover){.ptier:hover{transform:translateY(-4px);box-shadow:var(--shadow);}}
.ptier.feature{border-color:color-mix(in srgb,var(--accent) 55%,transparent);box-shadow:0 18px 44px color-mix(in srgb,var(--accent) 16%,transparent);}
.pbadge{position:absolute;top:-11px;left:28px;font-size:10.5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#fff;background:var(--accent);border-radius:999px;padding:5px 12px;}
.pbadge.quiet{background:var(--cell-2);color:var(--muted);border:1px solid var(--line);padding:4px 12px;}
.pbadge.gold{background:var(--f-movement);color:#2E2509;}
.ptier .pname{font-weight:700;font-size:22px;letter-spacing:-.01em;}
.ptier .pdesc{font-size:14px;color:var(--muted);margin-top:6px;line-height:1.45;min-height:40px;}
.phead{display:flex;align-items:center;gap:14px;}
.phead .pdesc{min-height:0;}
.pemblem{width:54px;height:54px;border-radius:16px;flex:none;display:flex;align-items:center;justify-content:center;
  font-size:27px;line-height:1;background:color-mix(in srgb,var(--pe) 28%,var(--cell));
  box-shadow:inset 0 0 0 1.5px color-mix(in srgb,var(--pe) 50%,transparent);}
.pprice{display:flex;align-items:baseline;gap:8px;margin-top:18px;}
.pprice .amt{font-weight:700;font-size:40px;letter-spacing:-.02em;}
.pprice .per{font-size:13px;color:var(--muted);}
.pmo{font-size:13px;color:var(--muted);margin-top:8px;min-height:18px;}
.pfeat{list-style:none;display:flex;flex-direction:column;gap:11px;margin:22px 0 24px;}
.pfeat li{display:flex;gap:10px;align-items:flex-start;font-size:14px;line-height:1.45;color:var(--fg);}
.pf-ic{width:18px;height:18px;flex:none;margin-top:1px;color:var(--accent-strong);}
:root[data-theme="dark"] .pf-ic{color:var(--accent);}
.pfeat li b{font-weight:700;}
.pfeat li.off{color:var(--faint);}
.pfeat li.off .pf-ic{color:var(--faint);}
.ptier .btn{margin-top:auto;width:100%;text-align:center;justify-content:center;}
.ptier .btn-ghost{background:transparent;color:var(--fg);border:1px solid var(--line);}
.ptier .btn-ghost:hover{border-color:var(--accent);color:var(--accent);background:transparent;box-shadow:none;}
.pricing-note{text-align:center;font-size:13.5px;color:var(--muted);margin-top:24px;}
.pricing-note b{color:var(--fg);}
.bill-seg{display:flex;justify-content:center;margin:0 0 26px;}
.bill-seg .inner{display:inline-flex;gap:3px;background:var(--cell);border:1px solid var(--line);border-radius:999px;padding:4px;}
.bill-seg button{font-family:var(--font);font-size:13px;font-weight:600;letter-spacing:.02em;border:0;background:none;
  color:var(--muted);padding:8px 26px;border-radius:999px;cursor:pointer;transition:color .25s ease,background .25s ease;}
.bill-seg button[aria-pressed="true"]{background:var(--accent);color:#fff;}

/* ---- Waitlist / CTA panel ---- */
.waitlist{background:var(--cell);border-radius:28px;padding:64px 32px;text-align:center;}
.waitlist h2{font-weight:700;font-size:clamp(28px,4vw,36px);letter-spacing:-.02em;}
.waitlist .sub{font-size:16px;color:var(--muted);margin-top:8px;}
.waitlist .statement{font-size:14px;font-weight:600;color:var(--accent-strong);margin-top:4px;}
:root[data-theme="dark"] .waitlist .statement{color:var(--accent);}
.form-row{display:flex;gap:10px;justify-content:center;margin-top:24px;flex-wrap:wrap;}
.input{font-family:var(--font);font-size:15px;padding:13px 18px;width:300px;max-width:100%;
  border-radius:12px;border:1px solid var(--input-line);background:var(--input-bg);color:var(--fg);}
.input::placeholder{color:var(--faint);}
.input:focus-visible{outline:2px solid var(--accent);outline-offset:1px;}
.btn-join{border-radius:12px;font-size:15px;padding:13px 26px;}
.waitlist .fine{font-size:12.5px;color:var(--faint);margin-top:14px;}

/* ---- FAQ ---- */
.faq{max-width:720px;margin:0 auto;}
.faq details{border-bottom:1px solid var(--line);}
.faq summary{cursor:pointer;font-weight:600;font-size:16.5px;padding:18px 0;list-style:none;
  display:flex;justify-content:space-between;align-items:center;gap:14px;}
.faq summary::-webkit-details-marker{display:none;}
.faq summary::after{content:'+';font-size:21px;line-height:1;color:var(--faint);flex:none;transition:transform .25s ease;}
.faq details[open] summary{color:var(--accent-strong);}
:root[data-theme="dark"] .faq details[open] summary{color:var(--accent);}
.faq details[open] summary::after{transform:rotate(45deg);}
.faq .a{color:var(--muted);font-size:15px;line-height:1.6;padding:0 0 18px;max-width:62ch;}

/* ---- Footer ---- */
.footer{border-top:1px solid var(--line);margin-top:64px;padding:40px 0 28px;}
.footer .statement{font-size:17px;font-weight:600;text-align:center;}
.footer .links{display:flex;gap:10px 24px;flex-wrap:wrap;justify-content:center;margin:20px 0 14px;font-size:13px;color:var(--muted);}
.footer .links a:hover,.footer button.linklike:hover{color:var(--fg);text-decoration:underline;}
.footer button.linklike{background:none;border:0;color:var(--muted);font-family:var(--font);font-size:13px;padding:0;cursor:pointer;}
.footer .legal{text-align:center;font-size:12px;color:var(--faint);line-height:1.6;max-width:62ch;margin:0 auto;}
.footer .fine{display:flex;justify-content:space-between;gap:10px;flex-wrap:wrap;color:var(--faint);font-size:11.5px;margin-top:22px;}

/* ---- Sticky mobile CTA ---- */
.sticky-cta{display:none;}

/* ---- Responsive ---- */
@media (max-width:920px){
  .nav-links{display:none;}
  .bento{grid-template-columns:repeat(2,1fr);}
  .span4,.span3,.span2,.span6{grid-column:span 2;}
  .fgrid{grid-template-columns:repeat(2,1fr);}
  .routines,.week{grid-template-columns:1fr;}
  .routines{grid-template-columns:repeat(3,1fr);gap:10px;}
  .rcard{padding:22px 14px;}
  .journey-labels span:nth-child(2),.journey-labels span:nth-child(5){display:none;}
  .pricing{grid-template-columns:1fr;}
}
@media (max-width:640px){
  .hero{padding:64px 20px 48px;}
  .nav-inner{flex-wrap:wrap;row-gap:8px;padding:10px 16px;}
  .seg{order:5;}
  .bento{grid-template-columns:1fr;}
  .span4,.span3,.span2,.span6{grid-column:span 1;}
  .sticky-cta{display:block;position:fixed;left:0;right:0;bottom:0;z-index:40;
    padding:10px 16px calc(10px + env(safe-area-inset-bottom,0px));
    background:var(--nav-bg);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border-top:1px solid var(--line);}
  .sticky-cta .btn{width:100%;text-align:center;font-size:15px;padding:13px;}
  body.has-sticky-cta{padding-bottom:74px;}
  body.has-sticky-cta .nav .btn{display:none;} /* sticky bottom CTA carries it on mobile */
}
