/* BowReady site — brand tokens mirror src/theme/tokens.ts */
:root{
  --paper:#F6F5F1; --surface:#FFFFFF; --mist:#EAEFEC; --line:#DCE3DF;
  --stone:#5E6B66; --ink:#0E211E; --spruce:#0C403B; --spruce-deep:#082D29;
  --teal:#0F766E; --teal-bright:#17A398; --teal-soft:#6CC6BE;
  --amber:#9B5E00; --amber-bg:#FBEFD6;
  --display:"Bricolage Grotesque", ui-sans-serif, system-ui, sans-serif;
  --body:"Hanken Grotesk", ui-sans-serif, system-ui, -apple-system, sans-serif;
  --mono:"JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, monospace;
  --maxw:1120px;
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%; scroll-behavior:smooth}
body{
  margin:0; background:var(--paper); color:var(--ink);
  font-family:var(--body); font-size:17px; line-height:1.6;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}
img{max-width:100%; display:block}
a{color:var(--teal); text-decoration:none}
a:hover{text-decoration:underline}
.wrap{max-width:var(--maxw); margin:0 auto; padding:0 24px}
.tl{color:var(--teal)}

/* ---------- Buttons ---------- */
.btn{display:inline-flex; align-items:center; justify-content:center; gap:9px;
  padding:14px 22px; border-radius:12px; font-family:var(--body); font-weight:600;
  font-size:16px; border:1px solid transparent; cursor:pointer; transition:.15s ease}
.btn-primary{background:var(--spruce); color:#fff}
.btn-primary:hover{background:#0a352f; text-decoration:none; transform:translateY(-1px)}
.btn-ghost{background:var(--surface); color:var(--spruce); border-color:var(--line)}
.btn-ghost:hover{border-color:var(--teal); text-decoration:none}
.btn-sm{padding:10px 16px; font-size:15px}
/* Store badge buttons */
.store{display:inline-flex; align-items:center; gap:11px; padding:11px 20px 11px 18px;
  border-radius:13px; background:var(--ink); color:#fff; border:1px solid var(--ink)}
.store:hover{text-decoration:none; transform:translateY(-1px); background:#000}
.store svg{width:26px; height:26px; flex:none; fill:currentColor}
.store .lbl{display:flex; flex-direction:column; line-height:1.05; text-align:left}
.store .lbl small{font-size:11px; font-weight:500; opacity:.82; letter-spacing:.02em}
.store .lbl b{font-size:17px; font-weight:600; font-family:var(--display)}
.store.light{background:#fff; color:var(--ink); border-color:var(--line)}
.store.light:hover{background:#fff; border-color:var(--teal)}

/* ---------- Logo ---------- */
.logo{display:inline-flex; align-items:center; gap:10px}
.logo:hover{text-decoration:none}
.logo-mark{border-radius:9px; box-shadow:0 1px 3px rgba(12,64,59,.18)}
.logo-word{font-family:var(--display); font-weight:700; font-size:21px; letter-spacing:-.01em; color:var(--ink)}

/* ---------- Nav ---------- */
.nav{position:sticky; top:0; z-index:50; background:rgba(246,245,241,.82);
  backdrop-filter:saturate(180%) blur(12px); border-bottom:1px solid var(--line)}
.nav-inner{display:flex; align-items:center; gap:20px; height:66px}
.nav-links{display:flex; gap:26px; margin-left:auto}
.nav-links a{color:var(--ink); font-weight:500; font-size:15.5px}
.nav-links a:hover{color:var(--teal); text-decoration:none}
.nav-cta{margin-left:8px}

/* ---------- Hero ---------- */
.hero{position:relative; overflow:hidden; color:#fff;
  background:radial-gradient(120% 120% at 85% 0%, #12514A 0%, var(--spruce) 46%, var(--spruce-deep) 100%)}
.hero-inner{display:grid; grid-template-columns:1.05fr .95fr; gap:48px; align-items:center;
  padding:72px 0 84px}
.eyebrow{display:inline-flex; align-items:center; gap:8px; font-family:var(--mono);
  font-size:12.5px; letter-spacing:.04em; text-transform:uppercase; color:var(--teal-soft);
  background:rgba(108,198,190,.12); border:1px solid rgba(108,198,190,.25);
  padding:6px 13px; border-radius:999px; margin-bottom:22px}
.hero h1{font-family:var(--display); font-weight:700; letter-spacing:-.025em; line-height:1.04;
  font-size:clamp(38px,6.2vw,62px); margin:0 0 20px; color:#fff}
.hero h1 .accent{color:var(--teal-bright)}
.hero .lead{font-size:clamp(17px,2.2vw,20px); color:#D6E4E0; margin:0 0 30px; max-width:36ch}
.hero-cta{display:flex; flex-wrap:wrap; gap:14px; margin-bottom:24px}
.hero-meta{display:flex; align-items:center; gap:10px; flex-wrap:wrap;
  font-size:14px; color:#AEC6C0}
.hero-meta .chip{font-family:var(--mono); font-size:12px; color:#D6E4E0;
  background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.14);
  padding:4px 10px; border-radius:999px}

/* Floating phone (crops the marketing caption baked into the top of each shot) */
.phone{position:relative; justify-self:center; width:min(360px,80vw);
  aspect-ratio:82/146; overflow:hidden; border-radius:30px;
  box-shadow:0 30px 70px -20px rgba(0,0,0,.55), 0 0 0 1px rgba(255,255,255,.06);
  background:var(--spruce-deep)}
.phone img{width:100%; height:100%; object-fit:cover; object-position:center bottom}

/* ---------- Channels strip ---------- */
.channels{background:var(--surface); border-bottom:1px solid var(--line)}
.channels-inner{display:flex; align-items:center; justify-content:center; gap:14px 30px;
  flex-wrap:wrap; padding:22px 0; color:var(--stone); font-size:14.5px}
.channels b{color:var(--ink); font-weight:600}
.channels .src{display:inline-flex; align-items:center; gap:8px; font-weight:600; color:var(--ink)}
.channels .src::before{content:""; width:9px; height:9px; border-radius:999px; background:var(--dot,var(--teal))}

/* ---------- Sections ---------- */
.section{padding:84px 0}
.section.alt{background:var(--surface); border-block:1px solid var(--line)}
.section-head{max-width:640px; margin:0 auto 52px; text-align:center}
.kicker{font-family:var(--mono); font-size:12.5px; letter-spacing:.05em; text-transform:uppercase;
  color:var(--teal); margin:0 0 12px}
.section-head h2{font-family:var(--display); font-weight:700; letter-spacing:-.02em;
  font-size:clamp(28px,4vw,40px); color:var(--spruce); margin:0 0 12px; line-height:1.1}
.section-head p{font-size:18px; color:var(--stone); margin:0}

/* Features */
.features{display:grid; grid-template-columns:repeat(auto-fit,minmax(280px,1fr)); gap:20px}
.feature{background:var(--paper); border:1px solid var(--line); border-radius:18px; padding:26px 24px}
.section.alt .feature{background:var(--paper)}
.feature-ic{width:46px; height:46px; border-radius:12px; display:grid; place-items:center;
  background:var(--mist); color:var(--teal); margin-bottom:16px}
.feature-ic svg{width:24px; height:24px; stroke:currentColor; fill:none; stroke-width:1.9}
.feature h3{font-family:var(--display); font-weight:700; font-size:19px; color:var(--spruce); margin:0 0 7px}
.feature p{margin:0; color:var(--stone); font-size:15.5px}

/* Screenshot gallery */
.shots{display:flex; gap:22px; overflow-x:auto; scroll-snap-type:x mandatory;
  padding:6px 24px 22px; margin:0 -24px; -webkit-overflow-scrolling:touch}
.shots::-webkit-scrollbar{height:8px}
.shots::-webkit-scrollbar-thumb{background:var(--line); border-radius:999px}
.shot{flex:0 0 auto; width:clamp(230px,72vw,290px); scroll-snap-align:center}
.shot img{width:100%; border-radius:22px; box-shadow:0 18px 40px -18px rgba(12,64,59,.45)}

/* How it works */
.steps{display:grid; grid-template-columns:repeat(auto-fit,minmax(240px,1fr)); gap:24px; counter-reset:step}
.step{position:relative; padding:28px 22px; background:var(--paper); border:1px solid var(--line); border-radius:18px}
.step::before{counter-increment:step; content:counter(step); font-family:var(--display); font-weight:700;
  font-size:15px; width:32px; height:32px; border-radius:999px; background:var(--spruce); color:#fff;
  display:grid; place-items:center; margin-bottom:16px}
.step h3{font-family:var(--display); font-weight:700; font-size:18px; color:var(--spruce); margin:0 0 6px}
.step p{margin:0; color:var(--stone); font-size:15.5px}

/* CTA band */
.cta{background:radial-gradient(120% 140% at 15% 0%, #12514A 0%, var(--spruce) 55%, var(--spruce-deep) 100%);
  color:#fff; text-align:center; padding:76px 0}
.cta h2{font-family:var(--display); font-weight:700; letter-spacing:-.02em;
  font-size:clamp(28px,4.4vw,44px); margin:0 0 14px}
.cta p{color:#CFE0DC; font-size:19px; margin:0 0 30px}
.cta .hero-cta{justify-content:center}

/* ---------- Footer ---------- */
.footer{background:var(--spruce-deep); color:#B9CCC7; padding:56px 0 34px}
.footer a{color:#B9CCC7}
.footer a:hover{color:#fff}
.footer .logo-word{color:#fff}
.footer .logo-word .tl{color:var(--teal-bright)}
.footer-inner{display:flex; flex-wrap:wrap; gap:40px 64px; justify-content:space-between; margin-bottom:34px}
.footer-brand p{margin:14px 0 0; color:#8FA9A3; font-size:15px}
.footer-cols{display:flex; flex-wrap:wrap; gap:44px}
.footer-cols h4{font-family:var(--display); font-size:13px; text-transform:uppercase; letter-spacing:.06em;
  color:#7C948F; margin:0 0 14px}
.footer-cols a{display:block; margin-bottom:10px; font-size:15px}
.footer-base{border-top:1px solid rgba(255,255,255,.09); padding-top:22px; font-size:13.5px; color:#7C948F}

/* ---------- Legal / doc pages ---------- */
.doc{max-width:720px; margin:0 auto; padding:52px 0 20px}
.doc h1{font-family:var(--display); font-weight:700; letter-spacing:-.015em;
  font-size:clamp(28px,5vw,38px); color:var(--spruce); margin:0 0 6px}
.doc .updated{color:var(--stone); font-size:14px; margin:0 0 30px}
.doc h2{font-family:var(--display); font-weight:700; font-size:20px; color:var(--spruce); margin:34px 0 10px}
.doc h3{font-size:17px; font-weight:600; color:var(--ink); margin:22px 0 6px}
.doc p,.doc li{color:#26332F}
.doc ul{padding-left:22px; margin:10px 0}
.doc li{margin:6px 0}
.doc a{font-weight:600}
code,.mono{font-family:var(--mono); font-size:.92em; background:var(--mist);
  padding:2px 7px; border-radius:6px; color:var(--spruce)}

/* Connect (invite) page */
.connect{max-width:560px; margin:0 auto; padding:76px 24px; text-align:center}
.connect .badge{display:inline-block; font-family:var(--mono); font-size:12.5px; letter-spacing:.04em;
  text-transform:uppercase; color:var(--teal); background:var(--mist); padding:6px 13px; border-radius:999px; margin-bottom:22px}
.connect h1{font-family:var(--display); font-weight:700; font-size:clamp(28px,5vw,40px);
  color:var(--spruce); margin:0 0 14px; letter-spacing:-.015em}
.connect p{font-size:18px; color:var(--stone); margin:0 auto 12px; max-width:42ch}
.connect .hero-cta{justify-content:center; margin:26px 0 0}
.connect .fine{font-size:14px; color:var(--stone); margin-top:26px}

/* ---------- Responsive ---------- */
@media (max-width:900px){
  .hero-inner{grid-template-columns:1fr; gap:36px; padding:56px 0 64px; text-align:center}
  .hero .lead{margin-left:auto; margin-right:auto}
  .hero-cta,.hero-meta{justify-content:center}
  .eyebrow{margin-inline:auto}
}
@media (max-width:720px){
  .nav-links{display:none}
  .section{padding:60px 0}
  .cta{padding:60px 0}
  body{font-size:16px}
}
@media (max-width:420px){
  .wrap{padding:0 18px}
  .nav-cta{display:none}
}
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  .btn,.store{transition:none}
}
