/* ============================================================
   Qwota v2 — cinematic, product-led. Deliberately not a template.
   ============================================================ */

:root{
  --bg:#0c0c0d;            /* warm near-black, not tech blue-black */
  --bg-2:#141416;
  --panel:#16161a;
  --ink:#ededea;           /* warm off-white */
  --muted:#9a9a92;
  --faint:#6a6a64;
  --hair:rgba(255,255,255,.09);
  --hair-2:rgba(255,255,255,.14);
  --teal:#2EC4A7;          /* the app's brand teal — surgical accent only */
  --teal-deep:#1f8f7a;
  --teal-dim:rgba(46,196,167,.13);
  --paper:#f3f1ea;         /* the single inverted beat */
  --paper-ink:#15140f;

  --serif:'Fraunces',Georgia,'Times New Roman',serif;
  --sans:'Archivo',system-ui,-apple-system,sans-serif;
  --mono:'JetBrains Mono',ui-monospace,monospace;

  --wrap:1180px;
  --gut:clamp(20px,5vw,64px);
  --rhythm:clamp(84px,13vw,168px);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--bg);color:var(--ink);
  font-family:var(--sans);font-size:17px;line-height:1.6;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
::selection{background:var(--teal);color:#06120f}
a{color:inherit;text-decoration:none}
img,video{display:block;max-width:100%}
em{font-style:italic}

/* --- shared bits --- */
.eyebrow{
  font-family:var(--mono);font-size:12px;letter-spacing:.22em;
  text-transform:uppercase;color:var(--muted);
  display:flex;align-items:center;gap:.6em;margin-bottom:1.4rem;
}
.eyebrow .dot{width:7px;height:7px;border-radius:50%;background:var(--teal)}
.eyebrow .idx{color:var(--teal);font-weight:700}
.eyebrow .idx::after{content:"\00a0/\00a0";color:var(--faint);font-weight:400}
.accent-text{color:var(--teal)}
h1,h2,h3{font-family:var(--serif);font-weight:500;letter-spacing:-.015em;line-height:1.04}
h2{font-size:clamp(2.1rem,5.2vw,3.6rem);margin-bottom:1.2rem}
p{color:var(--muted)}
section p{max-width:46ch}

/* --- buttons --- */
.btn{display:inline-flex;align-items:center;justify-content:center;
  font-family:var(--sans);font-weight:600;font-size:15px;cursor:pointer;
  border-radius:999px;padding:.8em 1.5em;transition:.25s ease;border:1px solid transparent}
.btn--pill{background:var(--ink);color:#0c0c0d}
.btn--pill:hover{background:#fff;transform:translateY(-1px)}
.btn--solid{background:var(--teal);color:#06120f}
.btn--solid:hover{background:#43d8bb;transform:translateY(-1px)}
.btn--ghost{background:transparent;color:var(--ink);border-color:var(--hair-2)}
.btn--ghost:hover{border-color:var(--ink);background:rgba(255,255,255,.04)}
.appstore img{height:52px;transition:.25s}
.appstore:hover img{transform:translateY(-2px);filter:brightness(1.08)}

/* ============================== NAV ============================== */
.nav{position:fixed;top:0;left:0;right:0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;
  padding:18px var(--gut);transition:.3s ease;
  border-bottom:1px solid transparent}
.nav.is-stuck{background:rgba(12,12,13,.72);backdrop-filter:blur(14px);
  border-bottom-color:var(--hair);padding-top:13px;padding-bottom:13px}
.nav__brand{display:flex;align-items:center;gap:10px;font-weight:700;font-size:18px;letter-spacing:-.01em}
.nav__icon{border-radius:7px}
.nav__links{display:flex;gap:30px;font-size:14.5px;color:var(--muted)}
.nav__links a{transition:.2s}.nav__links a:hover{color:var(--ink)}
@media(max-width:820px){.nav__links{display:none}}

/* ============================== HERO ============================== */
.hero{max-width:var(--wrap);margin:0 auto;
  padding:clamp(130px,18vh,200px) var(--gut) var(--rhythm);
  display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(30px,5vw,70px);align-items:center}
.hero__title{font-size:clamp(3.4rem,9vw,6.2rem);font-weight:600;line-height:.95;margin-bottom:1.6rem}
.hero__title .accent{border-bottom:.12em solid var(--teal)}
.hero__sub{font-size:clamp(1.05rem,1.6vw,1.3rem);color:var(--muted);max-width:42ch;margin-bottom:2.4rem}
.hero__cta{display:flex;align-items:center;gap:22px;flex-wrap:wrap}
.hero__fine{font-family:var(--mono);font-size:11.5px;letter-spacing:.04em;color:var(--faint);max-width:30ch}

.hero__stage{position:relative;display:flex;justify-content:center}
.annot{position:absolute;font-family:var(--mono);font-size:12.5px;color:var(--muted);
  background:var(--panel);border:1px solid var(--hair);border-radius:10px;
  padding:9px 13px;white-space:nowrap;box-shadow:0 14px 34px rgba(0,0,0,.5)}
.annot b{color:var(--ink);font-weight:500}
.annot--1{top:12%;left:-6%}
.annot--2{top:46%;right:-10%}
.annot--3{bottom:11%;left:-2%}
.annot--3 b{color:var(--teal)}
@media(max-width:820px){
  .hero{grid-template-columns:1fr;text-align:left}
  .annot--1{left:0}.annot--2{right:0}
}

/* ============================== DEVICE FRAME ============================== */
.device{position:relative;width:clamp(248px,32vw,360px);aspect-ratio:1290/2796;
  background:linear-gradient(#202024,#0e0e10);border-radius:13% / 6%;
  padding:2.6%;border:1px solid var(--hair-2);
  box-shadow:0 40px 90px -20px rgba(0,0,0,.8),inset 0 0 0 1px rgba(0,0,0,.6)}
.device--sm{width:clamp(236px,28vw,330px)}
.device__screen{width:100%;height:100%;object-fit:cover;border-radius:10% / 4.6%;background:#000}
.device__notch{position:absolute;top:2.6%;left:50%;transform:translateX(-50%);
  width:30%;height:2.2%;min-height:13px;background:#000;border-radius:99px;z-index:2}

/* ============================== MANIFESTO ============================== */
.manifesto{max-width:980px;margin:0 auto;padding:var(--rhythm) var(--gut);
  font-family:var(--serif);font-weight:400;font-size:clamp(1.7rem,4.2vw,3rem);
  line-height:1.22;letter-spacing:-.01em;color:var(--faint)}
.manifesto em{color:var(--muted);font-style:italic}
.manifesto__turn{color:var(--ink);margin-top:.7em}

/* ============================== FEATURES ============================== */
.feature{max-width:var(--wrap);margin:0 auto;padding:var(--rhythm) var(--gut);
  display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,6vw,90px);align-items:center}
.feature--reverse .feature__media{order:2}
@media(min-width:821px){
  /* break the identical-rows rhythm — the coach beat is the differentiator, so it's larger */
  .feature--coach{grid-template-columns:1.18fr .82fr}
  .feature--coach .device--sm{width:clamp(280px,31vw,396px)}
}
.feature__media{display:flex;justify-content:center;position:relative}
.feature__copy h2{margin-top:.2rem}
.ticks{list-style:none;margin-top:1.8rem;display:flex;flex-direction:column;gap:.85rem}
.ticks li{position:relative;padding-left:1.7rem;color:var(--muted);font-size:15.5px;max-width:42ch}
.ticks li::before{content:"";position:absolute;left:0;top:.62em;width:14px;height:1.5px;
  background:var(--teal)}
.chips{display:flex;flex-wrap:wrap;gap:9px;margin-top:1.9rem;max-width:34ch}
.chips span{font-family:var(--mono);font-size:12.5px;color:var(--muted);
  border:1px solid var(--hair);border-radius:7px;padding:6px 11px}
@media(max-width:820px){
  .feature{grid-template-columns:1fr;gap:34px}
  .feature--reverse .feature__media{order:0}
}

/* coach mascot */
.bill{width:120px;height:auto}
.bill--coach{position:absolute;bottom:-22px;right:-2%;width:clamp(124px,15vw,178px);
  filter:drop-shadow(0 16px 28px rgba(0,0,0,.6))}

/* ============================== WATCH ============================== */
.watch{max-width:var(--wrap);margin:0 auto;padding:calc(var(--rhythm) * .6) var(--gut) var(--rhythm);text-align:center}
.watch__head{max-width:560px;margin:0 auto}
.watch__head p{margin:0 auto}
.watch__row{display:flex;justify-content:center;gap:clamp(18px,4vw,56px);margin-top:clamp(40px,6vw,70px);flex-wrap:wrap}
.watch__row figure{display:flex;flex-direction:column;align-items:center;gap:14px}
.watch__row img{width:clamp(150px,17vw,208px);border-radius:26px;
  border:1px solid var(--hair);box-shadow:0 26px 60px -18px rgba(0,0,0,.7)}
.watch__row figcaption{font-family:var(--mono);font-size:12px;letter-spacing:.12em;
  text-transform:uppercase;color:var(--faint)}

/* ============================== STATS (inverted beat) ============================== */
.stats{background:var(--paper);color:var(--paper-ink);margin-top:var(--rhythm);
  padding:clamp(70px,10vw,120px) var(--gut)}
.stats__grid{max-width:var(--wrap);margin:0 auto;display:grid;
  grid-template-columns:repeat(4,1fr);gap:clamp(24px,4vw,48px)}
.stats__num{font-family:var(--serif);font-size:clamp(3rem,7vw,5rem);font-weight:500;
  display:block;line-height:1;letter-spacing:-.02em}
.stats__label{display:block;margin-top:.6rem;font-size:14px;color:#5c5a50;max-width:18ch}
.stats__line{max-width:var(--wrap);margin:clamp(40px,6vw,64px) auto 0;
  font-family:var(--serif);font-size:clamp(1.3rem,2.6vw,1.9rem);color:var(--paper-ink);line-height:1.3}
@media(max-width:700px){.stats__grid{grid-template-columns:1fr 1fr;gap:34px}}

/* ============================== PRICING ============================== */
.pricing{max-width:var(--wrap);margin:0 auto;padding:var(--rhythm) var(--gut)}
.pricing__head{max-width:620px;margin-bottom:clamp(40px,5vw,64px)}
.plans{display:grid;grid-template-columns:1fr 1.12fr 1fr;gap:16px;align-items:start}
.plan{border:1px solid var(--hair);border-radius:16px;padding:28px 24px;
  display:flex;flex-direction:column;background:var(--bg-2);position:relative}
.plan--best{border-color:var(--teal);background:rgba(46,196,167,.05);padding:38px 28px}
.plan__flag{position:absolute;top:-11px;left:24px;font-family:var(--mono);font-size:11px;
  letter-spacing:.14em;text-transform:uppercase;background:var(--teal);color:#06120f;
  padding:4px 10px;border-radius:6px;font-weight:700}
.plan h3{font-family:var(--sans);font-weight:700;font-size:15px;letter-spacing:.04em;
  text-transform:uppercase;color:var(--muted);margin-bottom:1rem}
.plan__price{font-family:var(--serif);font-size:2.6rem;color:var(--ink);line-height:1}
.plan__price span{font-family:var(--sans);font-size:1rem;color:var(--muted);margin-left:.14em}
.plan__note{font-size:13.5px;color:var(--faint);margin:.5rem 0 1.4rem}
.plan ul{list-style:none;display:flex;flex-direction:column;gap:.7rem;margin-bottom:1.8rem;flex:1}
.plan li{font-size:14px;color:var(--muted);padding-left:1.3rem;position:relative}
.plan li::before{content:"+";position:absolute;left:0;color:var(--teal);font-weight:700}
.plan .btn{width:100%}
@media(max-width:820px){.plans{grid-template-columns:1fr;max-width:440px;margin:0 auto}}

/* ============================== CTA ============================== */
.cta{text-align:center;padding:var(--rhythm) var(--gut) clamp(90px,12vw,150px);position:relative}
.bill--cta{width:clamp(96px,12vw,140px);margin:0 auto 1.6rem;filter:drop-shadow(0 16px 30px rgba(0,0,0,.5))}
.cta h2{margin-bottom:2.2rem}
.cta .appstore{display:inline-block}
.cta .hero__fine{margin:1.4rem auto 0}

/* ============================== FOOTER ============================== */
.footer{border-top:1px solid var(--hair);max-width:var(--wrap);margin:0 auto;
  padding:46px var(--gut);display:flex;align-items:center;justify-content:space-between;
  flex-wrap:wrap;gap:24px}
.footer__brand{display:flex;align-items:center;gap:10px;font-weight:700}
.footer__brand img{border-radius:8px}
.footer__nav{display:flex;flex-wrap:wrap;gap:22px;font-size:14px;color:var(--muted)}
.footer__nav a:hover{color:var(--ink)}
.footer__fine{font-family:var(--mono);font-size:11.5px;color:var(--faint);width:100%}

/* ============================== REVEAL ============================== */
.reveal{opacity:0;transition:opacity .7s ease}   /* opacity-only — no Framer-default fade-up */
.reveal.is-in{opacity:1}
html.no-js .reveal{opacity:1}   /* content visible if JS never runs */
@media(prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  html{scroll-behavior:auto}
}
