/* Strive — marketing site */
:root{
  --ink:#1A1714; --body:#46403A; --muted:#857C6F;
  --line:#E9E3D8; --line-soft:#F1ECE2;
  --brand:#FF6A2C; --brand-deep:#E2581F; --brand-soft:#FFF3EC;
  --paper:#FAF8F3; --cream:#F4F1EA;
  --blue:#3B82F6; --violet:#7C5CFF; --green:#10B981; --amber:#F59E0B; --pink:#FB6F92;
  --ink-panel:#1E1A15;
  --shadow-sm:0 1px 2px rgba(20,17,12,.05);
  --shadow-md:0 12px 32px -12px rgba(20,17,12,.18);
  --shadow-lg:0 40px 90px -45px rgba(20,17,12,.45);
  --r:18px;
  --maxw:1180px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;background:var(--paper);color:var(--body);
  font-family:'Geist',system-ui,-apple-system,sans-serif;
  font-size:17px;line-height:1.6;-webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4{font-family:'Bricolage Grotesque',sans-serif;color:var(--ink);letter-spacing:-0.025em;text-wrap:balance;margin:0}
p{margin:0;text-wrap:pretty}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:13px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--brand-deep)}
.eyebrow .dot{width:7px;height:7px;border-radius:99px;background:var(--brand)}

/* ── Buttons ── */
.btn{display:inline-flex;align-items:center;gap:9px;font-family:inherit;font-weight:700;font-size:15px;
  padding:13px 22px;border-radius:14px;cursor:pointer;border:0;transition:transform .12s ease,box-shadow .2s ease;white-space:nowrap}
.btn:active{transform:scale(.97)}
.btn-primary{background:linear-gradient(135deg,var(--brand),var(--brand-deep));color:#fff;box-shadow:0 10px 24px -8px rgba(226,88,31,.6)}
.btn-primary:hover{box-shadow:0 14px 30px -8px rgba(226,88,31,.7)}
.btn-ghost{background:#fff;color:var(--ink);border:1px solid var(--line);box-shadow:var(--shadow-sm)}
.btn-ghost:hover{border-color:#d9d2c5}
.btn-dark{background:var(--ink-panel);color:#fff}

/* Google Play badge */
.gp{display:inline-flex;align-items:center;gap:11px;background:#000;color:#fff;border-radius:14px;padding:10px 20px 10px 18px;cursor:pointer;transition:transform .12s ease}
.gp:active{transform:scale(.97)}
.gp svg{width:24px;height:24px;flex-shrink:0}
.gp>span{display:flex;flex-direction:column;justify-content:center;gap:1px}
.gp .l1{font-size:10px;letter-spacing:.04em;opacity:.85;line-height:1}
.gp .l2{font-family:'Bricolage Grotesque',sans-serif;font-size:19px;font-weight:600;letter-spacing:-.01em;line-height:1.15}

/* ── Header ── */
header.nav{position:sticky;top:0;z-index:50;background:rgba(250,248,243,.82);backdrop-filter:blur(14px);border-bottom:1px solid transparent;transition:border-color .2s,background .2s}
header.nav.scrolled{border-color:var(--line)}
.nav-in{display:flex;align-items:center;justify-content:space-between;height:70px}
.brand{display:flex;align-items:center;gap:11px}
.brand .logo{width:38px;height:38px;border-radius:11px;background:#fff;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-sm)}
.brand .logo img{width:24px;height:24px}
.brand .name{font-family:'Bricolage Grotesque',sans-serif;font-weight:700;font-size:22px;letter-spacing:-.03em;color:var(--ink)}
.nav-links{display:flex;align-items:center;gap:34px}
.nav-links a{font-size:15px;font-weight:600;color:var(--body);transition:color .15s}
.nav-links a:hover{color:var(--brand-deep)}
.nav-cta{display:flex;align-items:center;gap:14px}

/* ── Hero ── */
.hero{position:relative;overflow:hidden;padding:78px 0 90px}
.hero::before{content:'';position:absolute;inset:0;z-index:0;
  background:radial-gradient(900px 520px at 12% -5%,rgba(255,106,44,.12),transparent 60%),
             radial-gradient(700px 600px at 95% 30%,rgba(124,92,255,.08),transparent 60%)}
.hero-in{position:relative;z-index:1;display:grid;grid-template-columns:1.05fr .95fr;gap:40px;align-items:center}
.hero h1{font-size:62px;line-height:1.0;margin:20px 0 0}
.hero h1 .accent{color:var(--brand)}
.hero .sub{font-size:19px;color:var(--body);margin-top:22px;max-width:30ch}
.hero .cta-row{display:flex;align-items:center;gap:14px;margin-top:30px;flex-wrap:wrap}
.hero .chips{display:flex;gap:8px;margin-top:26px;flex-wrap:wrap}
.chip{display:inline-flex;align-items:center;gap:7px;padding:8px 14px;border-radius:99px;background:#fff;border:1px solid var(--line);font-size:13.5px;font-weight:600;color:var(--body);box-shadow:var(--shadow-sm)}
.chip svg{width:15px;height:15px}
.hero-art{position:relative;display:flex;justify-content:center;align-items:center}
.hero-glow{position:absolute;width:340px;height:340px;border-radius:50%;background:radial-gradient(circle,rgba(255,106,44,.28),transparent 65%);filter:blur(20px);z-index:0}

/* ── Phone mockup ── */
.device{position:relative;z-index:2;width:300px;border-radius:42px;background:#14110C;padding:10px;
  box-shadow:0 0 0 2px rgba(255,255,255,.06) inset,var(--shadow-lg)}
.device img{display:block;width:100%;border-radius:32px}
.device.tilt{transform:rotate(2deg)}
.phone{position:relative;z-index:2;width:300px;border-radius:42px;background:#14110C;padding:11px;box-shadow:0 0 0 2px rgba(255,255,255,.06) inset,var(--shadow-lg)}
.phone.tilt{transform:rotate(2deg)}
.screen{position:relative;border-radius:32px;overflow:hidden;background:var(--cream);height:600px}
.notch{position:absolute;top:0;left:50%;transform:translateX(-50%);width:120px;height:26px;background:#14110C;border-radius:0 0 16px 16px;z-index:5}
.s-status{display:flex;justify-content:space-between;align-items:center;padding:13px 20px 4px;font-size:12px;font-weight:600;color:var(--ink)}
.s-status .r{display:flex;gap:5px;align-items:center}
.s-pad{padding:6px 16px 16px}
.s-greet{font-size:12px;color:var(--muted);font-weight:600;margin-top:6px}
.s-h{font-family:'Bricolage Grotesque',sans-serif;font-weight:700;font-size:23px;letter-spacing:-.02em;color:var(--ink);line-height:1.1;margin-top:2px}

/* streak card in mockup */
.m-streak{margin-top:14px;border-radius:18px;padding:15px 16px;color:#fff;position:relative;overflow:hidden;
  background:linear-gradient(150deg,var(--brand),#ff8a4f)}
.m-streak .lab{font-size:9.5px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;opacity:.92}
.m-streak .big{font-family:'Bricolage Grotesque',sans-serif;font-size:34px;font-weight:700;line-height:1;margin:3px 0 12px}
.m-streak .big span{font-size:14px;opacity:.9;margin-left:5px}
.m-flame{position:absolute;right:-8px;top:-10px;font-size:90px;opacity:.16;line-height:1}
.dots{display:flex;gap:7px}
.dots i{width:22px;height:22px;border-radius:99px;background:rgba(255,255,255,.22);display:flex;align-items:center;justify-content:center;font-size:11px;color:#fff;font-style:normal}
.dots i.on{background:#fff;color:var(--brand)}
.dots i.tdy{border:2px solid #fff}

/* quest card */
.m-card{margin-top:12px;background:#fff;border-radius:16px;padding:14px;box-shadow:var(--shadow-sm);border:1px solid var(--line-soft)}
.m-card .top{display:flex;justify-content:space-between;align-items:center;margin-bottom:7px}
.m-tag{font-size:9px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:var(--brand-deep)}
.m-tag.blue{color:var(--blue)}
.m-pri{font-size:9px;font-weight:800;color:#EF4444;display:flex;align-items:center;gap:3px}
.m-card .ttl{font-family:'Bricolage Grotesque',sans-serif;font-weight:700;font-size:15px;color:var(--ink);letter-spacing:-.01em}
.m-meta{display:flex;justify-content:space-between;align-items:center;margin-top:9px}
.m-due{font-size:10px;font-weight:700;color:var(--brand-deep);background:var(--brand-soft);padding:3px 8px;border-radius:99px}
.m-open{font-size:11px;font-weight:700;color:var(--brand-deep);display:flex;align-items:center;gap:3px}
.m-row{display:flex;align-items:center;gap:11px;margin-top:11px}
.m-ring{width:42px;height:42px;flex-shrink:0}
.m-row .info .t{font-family:'Bricolage Grotesque',sans-serif;font-weight:700;font-size:14px;color:var(--ink)}
.m-row .info .s{font-size:10.5px;color:var(--muted);margin-top:1px}
.m-section{font-size:11px;font-weight:700;color:var(--muted);display:flex;justify-content:space-between;margin:16px 2px 0}

/* ── Section shells ── */
section{position:relative}
.sec{padding:96px 0}
.sec-head{max-width:680px;margin:0 auto;text-align:center}
.sec-head h2{font-size:42px;line-height:1.08;margin-top:14px}
.sec-head p{font-size:18px;color:var(--body);margin-top:16px}

/* ── Features grid ── */
.feat-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-top:56px}
.feat{background:#fff;border:1px solid var(--line);border-radius:22px;padding:30px;box-shadow:var(--shadow-sm);transition:transform .18s,box-shadow .18s}
.feat:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}
.feat .ic{width:52px;height:52px;border-radius:15px;display:flex;align-items:center;justify-content:center;margin-bottom:18px}
.feat .ic svg{width:26px;height:26px;stroke-width:2}
.feat h3{font-size:21px;margin-bottom:8px}
.feat p{font-size:15.5px;color:var(--body)}
.ic.o{background:var(--brand-soft);color:var(--brand-deep)}
.ic.b{background:#EAF2FE;color:var(--blue)}
.ic.v{background:#F0ECFF;color:var(--violet)}
.ic.g{background:#E7F7F0;color:var(--green)}

/* ── How it works ── */
.how{background:var(--cream)}
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;margin-top:56px}
.step{position:relative;padding-top:8px}
.step .n{font-family:'Bricolage Grotesque',sans-serif;font-weight:700;font-size:15px;width:38px;height:38px;border-radius:12px;background:#fff;border:1px solid var(--line);color:var(--brand-deep);display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-sm)}
.step h3{font-size:20px;margin:18px 0 8px}
.step p{font-size:15.5px;color:var(--body)}

/* ── Showcase ── */
.showcase{display:flex;justify-content:center;gap:26px;margin-top:60px;flex-wrap:wrap}
.showcase .phone,.showcase .device{width:256px}
.showcase .screen{height:512px}
.cap{text-align:center;margin-top:18px;font-size:14px;font-weight:600;color:var(--muted)}

/* trail mockup */
.trail{position:relative;padding-left:6px;margin-top:12px}
.trail::before{content:'';position:absolute;left:21px;top:14px;bottom:24px;width:2px;background:rgba(20,17,12,.07)}
.trail .node-row{display:flex;gap:11px;align-items:flex-start;padding:5px 0;position:relative}
.tn{width:32px;height:32px;border-radius:10px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-family:'Bricolage Grotesque',sans-serif;font-weight:700;font-size:13px;background:#fff;border:2px solid;z-index:1}
.tn.done{background:var(--blue);border-color:var(--blue);color:#fff}
.tn.prog{border-color:var(--blue);color:var(--blue)}
.tn.pend{border-color:rgba(59,130,246,.35);color:var(--blue);border-style:solid}
.tbody{flex:1;background:#fff;border:1px solid var(--line-soft);border-radius:11px;padding:9px 11px}
.tbody .t{font-size:12.5px;font-weight:600;color:var(--ink);line-height:1.3}
.tbody.done .t{text-decoration:line-through;opacity:.6}
.tbody .st{font-size:8.5px;font-weight:800;letter-spacing:.05em;text-transform:uppercase;margin-top:5px;color:var(--blue)}
.tbody .st.pend{color:var(--muted)}

/* trophies mockup */
.badge-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:9px;margin-top:12px}
.badge{border-radius:13px;padding:13px 6px;text-align:center;border:1px solid var(--line-soft)}
.badge .bc{width:38px;height:38px;border-radius:50%;margin:0 auto 7px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:18px}
.badge .bt{font-size:10px;font-weight:700;color:var(--ink)}
.badge.lock{opacity:.5}.badge.lock .bc{background:#d8d2c6 !important}
.m-banner{margin-top:12px;border-radius:16px;padding:16px;color:#fff;background:linear-gradient(150deg,var(--brand),#ff8a4f);display:flex;justify-content:space-between;align-items:center}
.m-banner .num{font-family:'Bricolage Grotesque',sans-serif;font-size:30px;font-weight:700;line-height:1}
.m-banner .l{font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;opacity:.9;margin-top:3px}

/* ── Stats band ── */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:0}
.stat{text-align:center}
.stat .v{font-family:'Bricolage Grotesque',sans-serif;font-weight:700;font-size:46px;color:var(--ink);letter-spacing:-.03em;line-height:1}
.stat .v .u{color:var(--brand);font-size:30px}
.stat .l{font-size:14.5px;color:var(--muted);font-weight:600;margin-top:8px}

/* ── FAQ ── */
.faq-wrap{max-width:760px;margin:50px auto 0}
.faq{border-bottom:1px solid var(--line)}
.faq summary{list-style:none;cursor:pointer;padding:22px 4px;display:flex;justify-content:space-between;align-items:center;gap:20px;
  font-family:'Bricolage Grotesque',sans-serif;font-weight:700;font-size:19px;color:var(--ink);letter-spacing:-.01em}
.faq summary::-webkit-details-marker{display:none}
.faq summary .pm{flex-shrink:0;width:28px;height:28px;border-radius:8px;background:var(--brand-soft);color:var(--brand-deep);display:flex;align-items:center;justify-content:center;font-size:20px;transition:transform .2s}
.faq[open] summary .pm{transform:rotate(45deg)}
.faq .ans{padding:0 4px 22px;font-size:16px;color:var(--body);max-width:64ch}

/* ── CTA band ── */
.cta-band{background:var(--ink-panel);color:#F4EEE4;border-radius:32px;margin:0 28px;padding:72px 40px;text-align:center;position:relative;overflow:hidden}
.cta-band::before{content:'';position:absolute;inset:0;background:radial-gradient(600px 360px at 50% -20%,rgba(255,106,44,.32),transparent 60%)}
.cta-band .in{position:relative;z-index:1;max-width:620px;margin:0 auto}
.cta-band h2{color:#fff;font-size:44px;line-height:1.05}
.cta-band p{color:#C9BFAF;font-size:18px;margin-top:18px}
.cta-band .row{display:flex;gap:14px;justify-content:center;margin-top:32px;flex-wrap:wrap}

/* ── Footer ── */
footer.site{background:var(--cream);margin-top:96px;padding:64px 0 36px;border-top:1px solid var(--line)}
.foot-top{display:flex;justify-content:space-between;gap:40px;flex-wrap:wrap}
.foot-brand{max-width:300px}
.foot-brand p{font-size:14.5px;color:var(--muted);margin-top:14px}
.foot-cols{display:flex;gap:64px;flex-wrap:wrap}
.foot-col h4{font-size:12px;text-transform:uppercase;letter-spacing:.07em;color:var(--muted);font-family:'Geist',sans-serif;font-weight:700;margin-bottom:14px}
.foot-col a{display:block;font-size:15px;color:var(--body);font-weight:500;margin-bottom:11px;transition:color .15s}
.foot-col a:hover{color:var(--brand-deep)}
.foot-bot{display:flex;justify-content:space-between;align-items:center;margin-top:48px;padding-top:24px;border-top:1px solid var(--line);font-size:13.5px;color:var(--muted);flex-wrap:wrap;gap:12px}

@media(max-width:900px){
  .hero-in{grid-template-columns:1fr;gap:20px}
  .hero h1{font-size:48px}.hero-art{order:-1}
  .feat-grid{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr}
  .stats{grid-template-columns:repeat(2,1fr);gap:32px}
  .nav-links{display:none}
  .sec{padding:64px 0}
}
@media(max-width:560px){
  .hero h1{font-size:38px}.sec-head h2{font-size:32px}
  .cta-band h2{font-size:32px}.cta-band{padding:52px 24px;margin:0 14px}
  .stats{grid-template-columns:repeat(2,1fr)}
  .wrap{padding:0 18px}
}
