/* CourtFlow marketing — landing page styles (tokens from colors_and_type.css) */
/* Satoshi Black (900) for the locked hero display treatment */
@import url('https://api.fontshare.com/v2/css?f[]=satoshi@900&display=swap');
*{box-sizing:border-box}
html{scroll-behavior:smooth}
html,body{margin:0}
body{background:var(--bg);color:var(--fg);font-family:var(--font-body);font-weight:500;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden}
body::before{content:"";position:fixed;inset:0;pointer-events:none;z-index:9999;
  background-image:url('assets/noise.svg');background-size:160px 160px;opacity:0.022;mix-blend-mode:multiply}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}
.mono{font-family:var(--font-mono);font-variant-numeric:tabular-nums}
.wrap{max-width:1120px;margin:0 auto;padding:0 32px}
/* offset anchor-scroll so targets clear the 64px sticky nav */
.section,.statbar{scroll-margin-top:80px}
.lab{font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--fg-faint)}

/* nav */
.nav{position:sticky;top:0;z-index:40;height:64px;display:flex;align-items:center;
  background:rgba(250,250,249,0.8);backdrop-filter:blur(10px);border-bottom:1px solid var(--border)}
.nav .wrap{display:flex;align-items:center;gap:28px;width:100%}
.nav-brand{display:flex;align-items:center;gap:9px}
.nav-brand img{width:30px;height:30px}
.nav-brand span{font-family:var(--font-display);font-weight:600;font-size:19px;letter-spacing:-0.01em}
.nav-links{display:flex;gap:24px;margin-left:8px}
.nav-links a{font-size:14px;color:var(--fg-muted);transition:color var(--motion-micro)}
.nav-links a:hover{color:var(--fg)}
.nav-right{margin-left:auto;display:flex;align-items:center;gap:14px}
.btn{display:inline-flex;align-items:center;gap:8px;border-radius:6px;font-weight:700;border:1px solid transparent;
  transition:background var(--motion-micro),transform var(--motion-micro)}
.btn svg{width:16px;height:16px;stroke-width:2}
.btn-sm{height:36px;padding:0 14px;font-size:13px}
.btn-lg{height:48px;padding:0 22px;font-size:15px}
.btn-primary{background:var(--brand);color:#fff}
.btn-primary:hover{background:var(--brand-hover)}
.btn-accent{background:var(--accent);color:var(--brand)}
.btn-accent:hover{filter:brightness(0.96)}
.btn-ghost{background:transparent;border:none;color:var(--fg);font-weight:700;font-size:14px}
.btn-ghost:hover{color:var(--brand)}

/* hero */
.hero{padding:84px 0 56px;text-align:center}
.eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:12px;font-weight:700;
  color:var(--brand);background:#f0f2e4;border:1px solid #e0e6c8;padding:6px 14px;border-radius:20px;margin-bottom:24px}
.eyebrow .dot{width:7px;height:7px;border-radius:50%;background:var(--accent);border:1px solid #c3cc3f}
.hero h1{font-family:var(--hero-font, var(--font-display));font-weight:var(--hero-weight,600);
  font-size:var(--hero-size,66px);line-height:0.97;letter-spacing:var(--hero-track,-0.035em);
  margin:0 auto;max-width:840px;text-wrap:balance}
.hero h1 .l1{display:block;color:var(--fg)}
.hero h1 .l2{display:block;color:var(--brand)}
.hero p{font-size:19px;color:var(--fg-muted);max-width:560px;margin:22px auto 0;line-height:1.5}
.hero-cta{display:flex;gap:12px;justify-content:center;margin-top:32px}
.hero-note{margin-top:16px;font-size:13px;color:var(--fg-faint)}

/* product shot — parent keepsake report preview */
.shot{margin:52px auto 0;max-width:560px;border:1px solid var(--border);border-radius:16px;overflow:hidden;
  box-shadow:var(--shadow-lg);background:#fff;text-align:left}
.rep-head{padding:20px 22px;display:flex;align-items:center;gap:13px;border-bottom:1px solid var(--border-light)}
.rep-ava{width:42px;height:42px;border-radius:12px;background:var(--brand);color:var(--accent);flex:none;
  display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:600;font-size:17px}
.rep-head .rh-name{font-family:var(--font-display);font-weight:600;font-size:18px;letter-spacing:-0.01em;line-height:1.1}
.rep-head .rh-sub{font-family:var(--font-mono);font-size:11px;color:var(--fg-faint);margin-top:2px}
.rep-head .rh-tag{margin-left:auto;font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  color:var(--brand);background:#f0f2e4;border:1px solid #e0e6c8;padding:5px 10px;border-radius:20px}
.rep-body{padding:18px 22px 22px;display:flex;flex-direction:column;gap:16px}
.rep-note{background:var(--bg);border:1px solid var(--border-light);border-radius:9px;padding:13px 15px}
.rep-note .nl{font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--fg-faint);margin-bottom:6px}
.rep-note p{margin:0;font-size:14px;line-height:1.5;color:var(--fg)}
.rep-sec .sl{font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--fg-faint);margin-bottom:9px}
.chips{display:flex;flex-wrap:wrap;gap:7px}
.chip{font-size:12px;font-weight:700;padding:5px 11px;border-radius:20px}
.rep-mile{display:flex;align-items:center;gap:11px;padding:11px 14px;border-radius:9px;
  background:#f8f9e0;border:1px solid #eef0c4}
.rep-mile .mi{width:28px;height:28px;border-radius:8px;background:var(--accent);color:var(--brand);flex:none;
  display:flex;align-items:center;justify-content:center}
.rep-mile .mi svg{width:15px;height:15px;stroke-width:2}
.rep-mile .mt{font-weight:700;font-size:13px;color:var(--fg)}
.rep-mile .ms{font-size:12px;color:var(--fg-muted)}
.rep-next{display:flex;gap:10px;align-items:flex-start;border-top:1px solid var(--border-light);padding-top:15px}
.rep-next .nx{font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--brand);
  background:#f0f2e4;padding:4px 8px;border-radius:5px;flex:none}
.rep-next p{margin:0;font-size:13px;line-height:1.5;color:var(--fg-muted)}

/* four-dimensions band (replaces metric/quote bar) */
.statbar{border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:#fff}
.statbar .wrap{padding-top:52px;padding-bottom:52px;text-align:center}
.dims-lab{font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--fg-faint)}
.dims-title{font-family:var(--font-display);font-weight:600;font-size:30px;letter-spacing:-0.02em;
  line-height:1.1;margin:12px 0 36px;color:var(--fg)}
.dims{display:flex;justify-content:center;flex-wrap:wrap}
.dim{flex:1;min-width:170px;padding:6px 24px;border-left:1px solid var(--border);text-align:left}
.dim:first-child{border-left:none}
.dim .di{width:34px;height:34px;border-radius:9px;background:#f0f2e4;color:var(--brand);
  display:flex;align-items:center;justify-content:center;margin-bottom:13px}
.dim .di svg{width:18px;height:18px;stroke-width:1.5}
.dim .dn{font-family:var(--font-display);font-weight:600;font-size:18px;letter-spacing:-0.01em;color:var(--fg)}
.dim .dd{font-size:13px;color:var(--fg-muted);margin-top:5px;line-height:1.45}

/* sections */
.section{padding:88px 0}
.section-head{max-width:620px;margin-bottom:48px}
.section-head h2{font-family:var(--font-display);font-weight:600;font-size:42px;letter-spacing:-0.02em;line-height:1.08;margin:14px 0 0}
.section-head p{font-size:17px;color:var(--fg-muted);margin:16px 0 0;line-height:1.5}

.features{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.feat{background:#fff;border:1px solid var(--border);border-radius:10px;padding:24px;box-shadow:var(--shadow-xs);
  transition:box-shadow var(--motion-short),transform var(--motion-short)}
.feat:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}
.feat .ico{width:40px;height:40px;border-radius:8px;background:#f0f2e4;color:var(--brand);
  display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.feat .ico svg{width:20px;height:20px;stroke-width:1.5}
.feat h3{font-family:var(--font-body);font-weight:700;font-size:17px;margin:0 0 8px}
.feat p{font-size:14px;color:var(--fg-muted);margin:0;line-height:1.5}

/* how it works — steps */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.step{background:#fff;border:1px solid var(--border);border-radius:10px;padding:24px;box-shadow:var(--shadow-xs)}
.step .num{font-family:var(--font-mono);font-weight:500;font-size:13px;color:var(--brand);background:#f0f2e4;
  width:30px;height:30px;border-radius:8px;display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.step h3{font-family:var(--font-body);font-weight:700;font-size:17px;margin:0 0 8px}
.step p{font-size:14px;color:var(--fg-muted);margin:0;line-height:1.5}
.step .ws{display:inline-flex;align-items:center;gap:6px;margin-top:14px;font-family:var(--font-mono);
  font-size:11px;color:var(--fg-faint)}
.step .ws svg{width:13px;height:13px;stroke-width:1.5}

/* progression timeline */
.timeline{max-width:720px;margin:0 auto}
.tl-row{display:flex}
.tl-when{width:86px;flex:none;text-align:right;padding-right:20px;padding-top:1px}
.tl-when .m{font-family:var(--font-display);font-weight:600;font-size:19px;letter-spacing:-0.01em;line-height:1.1}
.tl-when .s{font-family:var(--font-mono);font-size:11px;color:var(--fg-faint);margin-top:4px}
.tl-rail{width:30px;flex:none;position:relative;display:flex;justify-content:center}
.tl-rail::before{content:"";position:absolute;top:7px;bottom:0;width:2px;background:var(--border)}
.tl-row:last-child .tl-rail::before{display:none}
.tl-node{position:relative;z-index:2;margin-top:3px;width:14px;height:14px;border-radius:50%;
  background:#fff;border:3px solid var(--border)}
.tl-node.on{border-color:var(--brand);background:var(--accent)}
.tl-body{flex:1;padding-bottom:30px}
.tl-row:last-child .tl-body{padding-bottom:0}
.tl-card{background:#fff;border:1px solid var(--border);border-radius:10px;padding:15px 17px;box-shadow:var(--shadow-xs)}
.tl-card .hl{margin:0;font-size:14px;line-height:1.5;color:var(--fg)}
.tl-card .chips{margin-top:12px}
.tl-mile{display:inline-flex;align-items:center;gap:7px;margin-top:13px;font-size:13px;font-weight:700;color:var(--brand)}
.tl-mile svg{width:14px;height:14px;stroke-width:2}

/* CTA */
.cta{text-align:center;padding:96px 0}
.cta h2{font-family:var(--font-display);font-weight:600;font-size:52px;letter-spacing:-0.02em;margin:0;line-height:1.05}
.cta p{font-size:18px;color:var(--fg-muted);margin:18px 0 32px}

/* footer */
.footer{border-top:1px solid var(--border);padding:40px 0;background:#fff}
.footer .wrap{display:flex;align-items:center;gap:16px}
.footer .nav-brand span{font-size:16px}
.foot-links{margin-left:auto;display:flex;gap:22px}
.foot-links a{font-size:13px;color:var(--fg-muted)}
.foot-links a:hover{color:var(--fg)}
.copy{font-family:var(--font-mono);font-size:11px;color:var(--fg-faint)}

/* ---- Tablet ---- */
@media(max-width:900px){
  .wrap{padding:0 24px}
  .hero{padding:64px 0 48px}
  .hero h1{font-size:46px}
  .section{padding:72px 0}
  .section-head h2{font-size:34px}
  .cta h2{font-size:40px}
  .features,.steps{grid-template-columns:1fr 1fr}
  .dim{border-left:none}
}

/* ---- Phone ---- */
@media(max-width:600px){
  .wrap{padding:0 20px}

  /* nav: collapse to brand + one compact CTA */
  .nav .wrap{gap:12px}
  .nav-links,.nav .btn-ghost{display:none}
  .nav .btn-primary{padding:0 12px;font-size:12px}

  /* hero: smaller display, stacked full-width CTAs */
  .hero{padding:44px 0 36px}
  .hero h1{font-size:37px}
  .hero p{font-size:17px;margin-top:18px}
  .hero-cta{flex-direction:column;align-items:stretch;margin-top:24px}
  .hero-cta .btn{width:100%;justify-content:center}
  .shot{margin-top:36px}

  /* sections: single column, tighter rhythm */
  .section{padding:56px 0}
  .section-head{margin-bottom:32px}
  .section-head h2{font-size:29px}
  .section-head p{font-size:16px}
  .features,.steps{grid-template-columns:1fr}
  .dims{flex-direction:column}

  /* four dimensions */
  .statbar .wrap{padding-top:40px;padding-bottom:40px}
  .dims-title{font-size:24px;margin-bottom:28px}
  .dim{flex:none;width:100%;min-width:0;padding:16px 0;border-top:1px solid var(--border)}
  .dim:first-child{border-top:none;padding-top:0}

  /* timeline: narrower month gutter */
  .tl-when{width:60px;padding-right:14px}
  .tl-when .m{font-size:16px}

  /* cta */
  .cta{padding:64px 0}
  .cta h2{font-size:33px}
  .cta p{font-size:16px}

  /* footer stacks */
  .footer .wrap{flex-direction:column;align-items:flex-start;gap:14px}
  .foot-links{margin-left:0;flex-wrap:wrap;gap:16px}
  .footer .copy{margin-left:0!important}
}

/* ---- Very small (≤360px): drop nav CTA, rely on hero/footer CTAs ---- */
@media(max-width:360px){
  .nav .btn-primary{display:none}
}
