/* Ordentus marketing kit — recreation styles.
   Warm paper canvas, Inter, midnight bedtime gradient.
   Subset of landing.html's tokens — just what this kit needs. */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@200;300;400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap');

:root{
  --bg:#F7F5F1; --bg-pure:#FFFFFF; --bg-soft:#EFECE6; --bg-tint:#E8E4DC;
  --bg-deep:#1B1464; --bg-ink:#1F1A2E;
  --border:#E2DED5; --border-strong:#CFC9BD;
  --ink:#1D1D1F; --ink-2:#5C5A56; --ink-3:#8C8881; --ink-4:#B8B3AB;
  --accent:#007AFF; --accent-hover:#0056CC; --accent-tint:#E3F0FF;
  --red:#FF3B30; --pink:#FF2D55; --green:#34C759; --orange:#FF9500;
  --purple:#AF52DE; --indigo:#5E5CE6; --teal:#5AC8FA; --yellow:#FFCC00;
  --grad-bedtime: linear-gradient(135deg,#1B1464 0%, #2D1B69 100%);
  --shadow-sm: 0 1px 2px rgba(20,18,12,.05);
  --shadow-md: 0 4px 14px rgba(20,18,12,.07);
  --shadow-lg: 0 18px 50px -20px rgba(20,18,12,.18);
  --r-md:10px; --r-lg:14px; --r-xl:18px; --r-pill:999px;
  --font:'Inter',-apple-system,BlinkMacSystemFont,'SF Pro Display','Segoe UI',sans-serif;
  --font-product:-apple-system,BlinkMacSystemFont,'SF Pro Text','SF Pro Display','Helvetica Neue',sans-serif;
  --mono:'JetBrains Mono',ui-monospace,SFMono-Regular,Menlo,monospace;
}

*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }
html,body{ background:var(--bg); color:var(--ink); font-family:var(--font);
  -webkit-font-smoothing:antialiased; -moz-osx-font-smoothing:grayscale;
  font-feature-settings:"ss01","cv11"; line-height:1.5; }
img,svg{ display:block; max-width:100%; }
button{ font:inherit; cursor:pointer; border:none; background:none; color:inherit; }
a{ color:inherit; text-decoration:none; }
input{ font:inherit; }

.container{ max-width:1100px; margin:0 auto; padding:0 32px; }

.eyebrow{ font-size:12px; font-weight:600; text-transform:uppercase; letter-spacing:.9px; color:var(--ink-3); }
.h-display{ font-size:60px; font-weight:600; letter-spacing:-1.4px; line-height:1.04; text-wrap:balance; }
.h-section{ font-size:46px; font-weight:600; letter-spacing:-1.2px; line-height:1.06; text-wrap:balance; }
.h-feature{ font-size:30px; font-weight:600; letter-spacing:-.7px; line-height:1.12; }
.lede{ font-size:20px; font-weight:400; line-height:1.5; color:var(--ink-2); letter-spacing:-.1px; text-wrap:pretty; }
.body-l{ font-size:16px; line-height:1.6; color:var(--ink-2); }
.small{ font-size:13px; color:var(--ink-3); }
.micro{ font-size:11px; color:var(--ink-3); }
.mono{ font-family:var(--mono); }

.btn{ display:inline-flex; align-items:center; gap:8px; padding:12px 22px; border-radius:var(--r-pill);
  font-size:14px; font-weight:600; letter-spacing:-.1px; white-space:nowrap; transition:background .15s, color .15s, border-color .15s; }
.btn--primary{ background:var(--accent); color:#fff; }
.btn--primary:hover{ background:var(--accent-hover); }
.btn--ghost{ color:var(--ink); padding:12px 6px; }
.btn--ghost:hover{ color:var(--accent); }
.btn--outline{ border:1px solid var(--border-strong); color:var(--ink);
  padding:7px 16px; font-size:13px; font-weight:600; border-radius:var(--r-pill); background:transparent; }
.btn--outline:hover{ background:var(--ink); color:#fff; border-color:var(--ink); }

.wl-form{ display:flex; gap:8px; max-width:460px; background:var(--bg-pure);
  border:1px solid var(--border-strong); border-radius:var(--r-pill); padding:5px; align-items:center; }
.wl-form input{ flex:1; border:none; outline:none; padding:10px 16px; background:transparent;
  font-size:15px; color:var(--ink); }
.wl-form input::placeholder{ color:var(--ink-3); }
.wl-form .btn{ padding:10px 18px; font-size:13.5px; }

/* ──────── Nav ──────── */
.nav{ position:sticky; top:0; z-index:50;
  background:rgba(247,245,241,.82);
  -webkit-backdrop-filter:blur(20px) saturate(180%);
  backdrop-filter:blur(20px) saturate(180%);
  border-bottom:1px solid var(--border); }
.nav-inner{ display:flex; align-items:center; justify-content:space-between; height:52px; max-width:1100px; margin:0 auto; padding:0 32px; }
.brand{ display:flex; align-items:center; gap:10px; }
.brand-mark{ width:26px; height:26px; border-radius:7px; background:var(--accent); color:#fff;
  display:inline-flex; align-items:center; justify-content:center; }
.brand-mark svg{ width:16px; height:16px; }
.brand-name{ font-size:14.5px; font-weight:600; letter-spacing:-.2px; }
.nav-links{ display:flex; gap:26px; }
.nav-links a{ font-size:13.5px; font-weight:500; color:var(--ink-2); transition:color .15s; }
.nav-links a:hover{ color:var(--ink); }
.nav-right{ display:flex; align-items:center; gap:10px; }
.nav-cta{ background:var(--accent); color:#fff; font-size:13px; font-weight:600; white-space:nowrap;
  padding:7px 16px; border-radius:var(--r-pill); transition:background .15s; }
.nav-cta:hover{ background:var(--accent-hover); }

/* ──────── Section banding ──────── */
.section{ padding:80px 0; }
.section--soft{ background:var(--bg-soft); }
.section--ink{ background:var(--bg-ink); color:#F7F5F1; }
.section--ink .eyebrow{ color:rgba(247,245,241,.55); }
.section--ink .h-section{ color:#F7F5F1; }
.section--ink .body-l{ color:rgba(247,245,241,.72); }

/* ──────── Hero ──────── */
.hero{ padding:60px 0 48px; }
.hero-grid{ display:grid; grid-template-columns:0.85fr 1.15fr; gap:48px; align-items:center; }
.hero h1{ margin-top:18px; }
.hero .lede{ margin-top:22px; max-width:520px; }
.hero .wl-form{ margin-top:28px; }
.hero-microcopy{ margin-top:12px; max-width:460px; }
.hero-actions{ margin-top:18px; display:flex; align-items:center; gap:18px; }

/* Hero viz */
.viz{ position:relative; aspect-ratio:1.2/1; background:var(--bg-soft);
  border:1px solid var(--border); border-radius:22px; overflow:hidden;
  box-shadow:0 28px 56px -32px rgba(20,18,12,.22), 0 8px 28px rgba(20,18,12,.05); font-family:var(--font-product); }
.viz-cal{ position:absolute; left:22px; top:22px; bottom:22px; width:60%;
  background:var(--bg-pure); border:1px solid var(--border); border-radius:14px;
  box-shadow:var(--shadow-md); display:flex; flex-direction:column; overflow:hidden; }
.viz-cal-bar{ height:30px; background:var(--bg); border-bottom:1px solid var(--border);
  display:flex; align-items:center; gap:6px; padding:0 12px; flex-shrink:0; }
.viz-cal-bar .seg{ margin-left:auto; display:inline-flex; background:var(--bg-tint); border-radius:6px; padding:2px; }
.viz-cal-bar .seg span{ font-size:9px; font-weight:600; color:var(--ink-3); padding:3px 7px; border-radius:4px; }
.viz-cal-bar .seg span.on{ background:var(--bg-pure); color:var(--ink); box-shadow:var(--shadow-sm); }
.viz-cal-bar .ttl{ font-size:11px; font-weight:600; color:var(--ink); }
.viz-day-head{ display:grid; grid-template-columns:24px repeat(5,1fr);
  border-bottom:1px solid var(--border); background:var(--bg-pure); flex-shrink:0; }
.viz-day-head span{ font-size:9px; color:var(--ink-3); text-align:center; padding:6px 0;
  font-weight:500; border-left:1px solid var(--border); }
.viz-day-head span:first-child{ border-left:none; }
.viz-day-head span b{ display:block; font-size:13px; color:var(--ink); font-weight:600; margin-top:1px; }
.viz-day-head span.today b{ color:#fff; background:var(--red); width:20px; height:20px; border-radius:50%; line-height:20px; margin:0 auto; }
.viz-cal-grid{ flex:1; display:grid; grid-template-columns:24px repeat(5,1fr); position:relative; }
.viz-cal-hour-col{ display:flex; flex-direction:column; }
.viz-cal-hour{ flex:1; border-top:1px solid var(--border); font-size:8px; color:var(--ink-3); padding:2px 4px 0 0; text-align:right; }
.viz-cal-cell{ border-left:1px solid var(--border); position:relative; }
.viz-cal-cell::before{ content:""; position:absolute; left:0; right:0; top:50%; height:1px; background:var(--border); }
.viz-evt{ position:absolute; left:3px; right:3px; border-radius:4px; padding:3px 5px;
  font-size:8.5px; font-weight:600; line-height:1.2; color:#fff; overflow:hidden; }
.viz-evt small{ display:block; opacity:.85; font-size:7.5px; font-weight:500; margin-top:1px; }
.viz-evt.blue{ background:var(--accent); }
.viz-evt.red{ background:var(--red); }
.viz-evt.green{ background:var(--green); }
.viz-evt.purple{ background:var(--purple); }
.viz-evt.orange{ background:var(--orange); }
.viz-evt.teal{ background:var(--teal); color:#0a3a4d; }
.viz-evt.indigo{ background:var(--indigo); }

.viz-health{ position:absolute; right:22px; top:22px; bottom:22px; width:34%;
  display:flex; flex-direction:column; gap:14px; font-family:var(--font-product); }
.viz-bedtime{ background:var(--grad-bedtime); color:#fff; border-radius:14px; padding:16px; box-shadow:var(--shadow-md); }
.viz-bedtime .lbl{ font-size:9px; letter-spacing:.8px; font-weight:600; text-transform:uppercase; opacity:.7; }
.viz-bedtime .time{ font-size:40px; font-weight:200; letter-spacing:-1.6px; line-height:1; margin-top:8px; font-variant-numeric:tabular-nums; }
.viz-bedtime .time small{ font-size:14px; font-weight:300; opacity:.7; margin-left:2px; letter-spacing:0; }
.viz-bedtime .meta{ font-size:10px; color:rgba(255,255,255,.7); margin-top:8px; }
.viz-cog{ flex:1; background:var(--bg-pure); border:1px solid var(--border); border-radius:14px;
  box-shadow:var(--shadow-md); padding:14px; display:flex; flex-direction:column; align-items:center; justify-content:center; position:relative; }
.viz-cog .lbl{ position:absolute; top:11px; left:14px; font-size:9px; color:var(--ink-3); letter-spacing:.8px; font-weight:600; text-transform:uppercase; }
.viz-cog .pill{ position:absolute; top:9px; right:12px; font-size:9px; font-weight:600; padding:3px 8px; border-radius:999px; background:rgba(52,199,89,.14); color:#1F8B3D; }
.ring{ width:108px; height:108px; position:relative; margin-top:8px; }
.ring svg{ width:100%; height:100%; transform:rotate(-90deg); }
.ring .track{ fill:none; stroke:var(--bg-tint); }
.ring .arc{ fill:none; stroke:var(--green); stroke-linecap:round; }
.ring .pct{ position:absolute; inset:0; display:flex; flex-direction:column; align-items:center; justify-content:center; }
.ring .pct b{ font-size:34px; font-weight:200; letter-spacing:-1.2px; line-height:1; font-variant-numeric:tabular-nums; color:var(--ink); }
.ring .pct span{ font-size:8px; color:var(--ink-3); letter-spacing:.5px; text-transform:uppercase; font-weight:600; margin-top:2px; }
.domains{ width:100%; margin-top:12px; display:flex; flex-direction:column; gap:5px; }
.domains .row{ display:grid; grid-template-columns:48px 1fr 24px; align-items:center; gap:6px; font-size:9px; color:var(--ink-2); }
.domains .bar{ height:4px; background:var(--bg-tint); border-radius:2px; overflow:hidden; }
.domains .bar i{ display:block; height:100%; background:var(--green); border-radius:2px; }
.domains .row .v{ text-align:right; font-variant-numeric:tabular-nums; color:var(--ink); font-weight:600; }
.domains .row.warn .bar i{ background:var(--orange); }
.domains .row.warn .v{ color:var(--orange); }

/* ──────── Halves ──────── */
.halves-head{ text-align:center; max-width:780px; margin:0 auto 48px; }
.halves-head h2{ margin-top:12px; }
.halves-grid{ display:grid; grid-template-columns:1fr 1fr; gap:28px; align-items:stretch; }
.half{ background:var(--bg-pure); border:1px solid var(--border);
  border-radius:20px; padding:28px; display:flex; flex-direction:column; gap:18px; }
.half h3{ font-size:24px; font-weight:600; letter-spacing:-.4px; line-height:1.15; }
.half-caption{ margin-top:auto; padding-top:14px; border-top:1px solid var(--border);
  font-size:12px; color:var(--ink-2); display:flex; flex-wrap:wrap; gap:6px 14px; }
.half-caption span + span::before{ content:"·"; color:var(--ink-4); margin-right:14px; }

/* Mini cal in half */
.mini-cal{ border:1px solid var(--border); border-radius:12px; overflow:hidden; background:var(--bg-pure); font-family:var(--font-product); }
.mini-cal-bar{ display:flex; align-items:center; gap:10px; padding:8px 12px; background:var(--bg-soft); border-bottom:1px solid var(--border); font-size:11px; }
.mini-cal-bar .ttl{ font-weight:600; }
.mini-cal-bar .seg{ display:inline-flex; background:var(--bg-tint); border-radius:6px; padding:2px; }
.mini-cal-bar .seg span{ padding:2px 8px; font-size:10px; font-weight:600; color:var(--ink-3); border-radius:4px; }
.mini-cal-bar .seg span.on{ background:var(--bg-pure); color:var(--ink); box-shadow:var(--shadow-sm); }
.mini-cal-bar .sync{ margin-left:auto; font-size:10px; color:#1F8B3D; font-weight:600;
  background:rgba(52,199,89,.10); padding:2px 8px; border-radius:999px; display:inline-flex; align-items:center; gap:5px; }
.mini-cal-bar .sync::before{ content:""; width:5px; height:5px; border-radius:50%; background:var(--green); }
.mini-cal-grid{ display:grid; grid-template-columns:36px repeat(5,1fr); }
.mini-cal-grid .head{ font-size:9.5px; color:var(--ink-3); text-align:center; padding:6px 0;
  border-bottom:1px solid var(--border); border-left:1px solid var(--border); background:var(--bg-pure); }
.mini-cal-grid .head:first-child{ border-left:none; }
.mini-cal-grid .head b{ display:block; font-size:13px; font-weight:600; color:var(--ink); margin-top:1px; }
.mini-cal-grid .head.today b{ color:#fff; background:var(--red); width:20px; height:20px; border-radius:50%; line-height:20px; margin:0 auto; }
.mini-cal-body{ grid-column:1 / -1; position:relative; display:grid; grid-template-columns:36px repeat(5,1fr); height:200px; }
.mini-cal-hours{ display:flex; flex-direction:column; }
.mini-cal-hour{ flex:1; border-top:1px solid var(--border); font-size:9px; color:var(--ink-3); padding:1px 4px 0 0; text-align:right; }
.mini-cal-col{ border-left:1px solid var(--border); position:relative; }
.mini-evt{ position:absolute; left:3px; right:3px; border-radius:4px; padding:3px 5px; color:#fff;
  font-size:9px; font-weight:600; line-height:1.2; overflow:hidden; }
.mini-evt small{ display:block; font-size:8px; font-weight:500; opacity:.85; margin-top:1px; }
.mini-evt.blue{ background:var(--accent); }
.mini-evt.purple{ background:var(--purple); }
.mini-evt.green{ background:var(--green); }
.mini-evt.orange{ background:var(--orange); }
.mini-evt.teal{ background:var(--teal); color:#0a3a4d; }
.mini-evt.indigo{ background:var(--indigo); }
.now-line{ position:absolute; left:0; right:0; height:2px; background:var(--red); z-index:2; }
.now-line::before{ content:""; position:absolute; left:-3px; top:-3px; width:8px; height:8px; border-radius:50%; background:var(--red); }

/* Health mock in half */
.mock-health{ display:flex; flex-direction:column; gap:12px; font-family:var(--font-product); }
.h-bedtime{ background:var(--grad-bedtime); color:#fff; padding:20px; border-radius:14px;
  display:flex; align-items:flex-end; justify-content:space-between; gap:18px; }
.h-bedtime .lbl{ font-size:10px; font-weight:600; letter-spacing:.7px; text-transform:uppercase; opacity:.7; }
.h-bedtime .time{ font-size:46px; font-weight:200; letter-spacing:-1.6px; line-height:1; font-variant-numeric:tabular-nums; margin-top:8px; }
.h-bedtime .time small{ font-size:16px; font-weight:300; opacity:.7; margin-left:2px; letter-spacing:0; }
.h-bedtime .meta{ font-size:11px; color:rgba(255,255,255,.7); margin-top:6px; }
.h-bedtime .right{ text-align:right; font-size:10px; color:rgba(255,255,255,.7); align-self:flex-start; }
.h-bedtime .right b{ display:block; font-size:12px; color:#fff; font-weight:500; margin-top:2px; }
.h-card{ border:1px solid var(--border); border-radius:14px; padding:16px 18px; background:var(--bg-pure);
  display:flex; align-items:center; justify-content:space-between; gap:18px; }
.h-card .lbl{ font-size:10px; font-weight:600; letter-spacing:.7px; text-transform:uppercase; color:var(--ink-3); }
.h-card .num{ font-size:56px; font-weight:200; letter-spacing:-2px; line-height:1; font-variant-numeric:tabular-nums; color:var(--ink); margin-top:4px; }
.h-card .num small{ font-size:20px; font-weight:300; color:var(--ink-3); margin-left:2px; letter-spacing:0; }
.h-card .delta.warn{ margin-top:4px; font-size:11px; font-weight:600; color:var(--orange); }
.h-card .right{ text-align:right; font-size:10px; color:var(--ink-3); }
.h-card .right b{ display:block; font-size:16px; font-weight:500; color:var(--ink); font-variant-numeric:tabular-nums; margin-top:2px; }

/* ──────── How it works ──────── */
.how-head{ text-align:center; margin-bottom:48px; }
.how-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:32px; position:relative; }
.how-grid::before{ content:""; position:absolute; top:30px; left:7%; right:7%; height:1px;
  background:linear-gradient(to right, transparent, var(--border-strong), transparent); }
.step{ position:relative; }
.step .num{ font-size:42px; font-weight:200; letter-spacing:-1.4px; color:var(--ink-3); line-height:1;
  font-variant-numeric:tabular-nums; background:var(--bg-soft); padding-right:12px; display:inline-block; }
.section--soft .step .num{ background:var(--bg-soft); }
.step h4{ font-size:18px; font-weight:600; letter-spacing:-.3px; margin-top:18px; }
.step p{ font-size:14px; color:var(--ink-2); margin-top:8px; line-height:1.55; }

/* ──────── Privacy slab ──────── */
.privacy-head{ text-align:center; max-width:880px; margin:0 auto 36px; }
.privacy-head h2{ margin-top:14px; font-size:38px; font-weight:600; letter-spacing:-1px; line-height:1.15; color:#F7F5F1; }
.privacy-list{ max-width:880px; margin:0 auto; border-top:1px solid rgba(247,245,241,.14); }
.privacy-row{ display:grid; grid-template-columns:220px 1fr; gap:32px;
  padding:22px 0; border-bottom:1px solid rgba(247,245,241,.14); align-items:baseline; }
.privacy-row b{ font-size:16px; font-weight:600; color:#F7F5F1; }
.privacy-row p{ font-size:15px; line-height:1.55; color:rgba(247,245,241,.7); }
.privacy-receipt{ max-width:880px; margin:24px auto 0; padding:14px 22px;
  border:1px dashed rgba(247,245,241,.2); border-radius:10px; text-align:center;
  font-family:var(--mono); font-size:12px; color:rgba(247,245,241,.55); letter-spacing:.3px; }
.privacy-receipt span{ color:rgba(247,245,241,.85); }

/* ──────── Final CTA ──────── */
.offer{ max-width:520px; margin:0 auto; background:var(--bg-pure); border:1px solid var(--border);
  border-radius:18px; padding:30px 32px; box-shadow:var(--shadow-md); }
.offer h3{ margin-top:8px; font-size:26px; font-weight:600; letter-spacing:-.5px; line-height:1.1; }
.offer p{ margin-top:10px; font-size:15px; color:var(--ink-2); line-height:1.55; }
.offer .wl-form{ margin-top:18px; max-width:none; }
.offer .micro{ margin-top:12px; font-size:12px; color:var(--ink-3); line-height:1.5; }

/* ──────── Footer ──────── */
.foot{ background:var(--bg-ink); color:rgba(247,245,241,.72); padding:48px 0 24px; }
.foot-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:36px; }
.foot-brand .brand-mark{ background:#F7F5F1; color:var(--bg-ink); }
.foot-brand .brand-name{ display:block; margin-top:8px; color:#F7F5F1; font-size:14px; font-weight:600; }
.foot-brand .blurb{ margin-top:12px; font-size:13px; color:rgba(247,245,241,.55); max-width:320px; line-height:1.55; }
.foot-mini{ margin-top:18px; display:flex; gap:6px; max-width:340px;
  background:rgba(247,245,241,.06); border:1px solid rgba(247,245,241,.14); border-radius:var(--r-pill);
  padding:5px; align-items:center; }
.foot-mini input{ flex:1; border:none; outline:none; padding:8px 12px; background:transparent; font-size:13px; color:#F7F5F1; }
.foot-mini input::placeholder{ color:rgba(247,245,241,.4); }
.foot-mini button{ background:var(--accent); color:#fff; padding:8px 14px; border-radius:var(--r-pill); font-size:12px; font-weight:600; }
.foot-mini button:hover{ background:var(--accent-hover); }
.foot-col h6{ font-size:11px; font-weight:600; letter-spacing:.6px; text-transform:uppercase; color:rgba(247,245,241,.5); }
.foot-col ul{ margin-top:12px; list-style:none; display:flex; flex-direction:column; gap:8px; }
.foot-col a{ font-size:13.5px; color:rgba(247,245,241,.72); }
.foot-col a:hover{ color:#F7F5F1; }
.foot-rule{ margin-top:36px; padding-top:18px; border-top:1px solid rgba(247,245,241,.12);
  display:flex; justify-content:space-between; align-items:center; font-size:12px; color:rgba(247,245,241,.5); }
.foot-rule .ver{ font-family:var(--mono); }

@media (max-width: 980px){
  .section{ padding:56px 0; }
  .h-display{ font-size:42px; letter-spacing:-.9px; }
  .h-section{ font-size:32px; letter-spacing:-.8px; }
  .hero-grid{ grid-template-columns:1fr; gap:36px; }
  .halves-grid{ grid-template-columns:1fr; }
  .how-grid{ grid-template-columns:1fr; gap:24px; }
  .how-grid::before{ display:none; }
  .foot-grid{ grid-template-columns:1fr 1fr; gap:28px; }
  .privacy-row{ grid-template-columns:1fr; gap:6px; }
}
