/* Hallmark · macrostructure: Marquee Hero · nav: N5 floating pill · footer: Ft5 statement
 * tone: technical-atmospheric · theme: Midnight · anchor hue: violet→cyan (cool)
 * Hallmark · pre-emit critique: P5 H5 E4 S4 R5 V4
 */
@import url("tokens.css");

* { box-sizing: border-box; }
html, body { overflow-x: clip; }
html { scroll-behavior: smooth; }

body {
  margin: 0;
  background: var(--color-paper);
  color: var(--color-ink);
  font-family: var(--font-body);
  font-size: var(--text-base);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  background-image:
    radial-gradient(60rem 40rem at 78% -10%, oklch(70% 0.19 292 / 0.16), transparent 60%),
    radial-gradient(48rem 36rem at 8% 8%, oklch(74% 0.15 232 / 0.12), transparent 62%);
  background-attachment: fixed;
}

h1, h2, h3 {
  font-family: var(--font-display);
  font-weight: 600;
  letter-spacing: -0.02em;
  line-height: 1.04;
  overflow-wrap: anywhere;
  min-width: 0;
}

a { color: inherit; }
img, video { max-width: 100%; display: block; }

.wrap { width: min(72rem, 92vw); margin-inline: auto; }
.eyebrow {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.22em;
  color: var(--color-ink-mute);
}

/* ---- nav: N5 floating pill ---- */
.nav-shell { position: sticky; top: var(--space-md); z-index: 50; padding-inline: var(--space-md); }
.nav {
  width: min(64rem, 94vw); margin-inline: auto;
  display: flex; align-items: center; justify-content: space-between;
  gap: var(--space-md);
  padding: var(--space-xs) var(--space-xs) var(--space-xs) var(--space-lg);
  background: oklch(19% 0.03 280 / 0.72);
  backdrop-filter: blur(14px);
  border: var(--rule-hair);
  border-radius: var(--radius-pill);
}
.brand { font-family: var(--font-display); font-weight: 600; letter-spacing: -0.01em; font-size: var(--text-lg); }
.brand span { color: var(--color-accent); }
.nav-right { display: flex; align-items: center; gap: var(--space-sm); }
.nav-link { font-size: var(--text-sm); color: var(--color-ink-2); text-decoration: none; padding: var(--space-xs) var(--space-sm); border-radius: var(--radius-pill); transition: color var(--dur-fast) var(--ease-out); }
.nav-link:hover { color: var(--color-ink); }

/* ---- buttons ---- */
.btn {
  display: inline-flex; align-items: center; gap: var(--space-xs);
  font-family: var(--font-body); font-weight: 600; font-size: var(--text-sm);
  text-decoration: none; cursor: pointer; border: 0;
  padding: var(--space-sm) var(--space-lg);
  border-radius: var(--radius-pill);
  transition: transform var(--dur-fast) var(--ease-out), box-shadow var(--dur-mid) var(--ease-out), background var(--dur-fast) var(--ease-out);
}
.btn-primary {
  color: var(--color-accent-ink);
  background: linear-gradient(120deg, var(--color-accent), var(--color-accent-2));
  box-shadow: 0 8px 30px oklch(70% 0.19 292 / 0.28);
}
.btn-primary:hover { transform: translateY(-2px); box-shadow: 0 12px 40px oklch(70% 0.19 292 / 0.4); }
.btn-primary:active { transform: translateY(0); }
.btn-ghost { color: var(--color-ink); background: transparent; border: var(--rule-hair); }
.btn-ghost:hover { background: var(--color-paper-3); }
.btn:focus-visible, .nav-link:focus-visible { outline: 2px solid var(--color-focus); outline-offset: 3px; }

/* ---- hero (marquee) ---- */
.hero { padding: var(--space-3xl) 0 var(--space-2xl); text-align: center; }
.badge {
  display: inline-flex; align-items: center; gap: var(--space-xs);
  font-family: var(--font-mono); font-size: var(--text-xs); letter-spacing: 0.04em;
  padding: var(--space-2xs) var(--space-sm); margin-bottom: var(--space-lg);
  border: var(--rule-hair); border-radius: var(--radius-pill); color: var(--color-ink-2);
}
.badge b { color: var(--color-good); }
.hero h1 { font-size: var(--text-display); margin: 0 auto var(--space-lg); max-width: 16ch; }
.hero h1 em { font-style: normal; background: linear-gradient(120deg, var(--color-accent), var(--color-accent-2)); -webkit-background-clip: text; background-clip: text; color: transparent; }
.hero .lede { font-size: var(--text-lg); color: var(--color-ink-2); max-width: 52ch; margin: 0 auto var(--space-xl); }
.cta-row { display: flex; gap: var(--space-sm); justify-content: center; flex-wrap: wrap; margin-bottom: var(--space-2xs); }
.cta-note { font-size: var(--text-xs); color: var(--color-ink-mute); margin-top: var(--space-md); }

.marquee { margin-top: var(--space-2xl); }
.frame {
  margin: 0; border: var(--rule-hair); border-radius: var(--radius-lg); overflow: hidden;
  background: var(--color-paper-2);
  box-shadow: 0 30px 80px oklch(8% 0.02 280 / 0.6);
}
.frame video, .frame img { width: 100%; height: auto; display: block; }
figcaption { font-size: var(--text-sm); color: var(--color-ink-mute); text-align: center; padding-top: var(--space-md); }

/* ---- generic section ---- */
section { padding-block: var(--space-3xl); }
.sec-head { max-width: 40ch; margin-bottom: var(--space-2xl); }
.sec-head h2 { font-size: var(--text-2xl); margin: var(--space-sm) 0 0; }
.sec-head p { color: var(--color-ink-2); font-size: var(--text-lg); margin: var(--space-sm) 0 0; }

/* ---- steps ---- */
.steps { display: grid; grid-template-columns: repeat(auto-fit, minmax(min(15rem, 100%), 1fr)); gap: var(--space-lg); }
.step { padding: var(--space-lg); border: var(--rule-hair); border-radius: var(--radius-md); background: oklch(19% 0.03 280 / 0.5); }
.step .n { font-family: var(--font-mono); font-size: var(--text-sm); color: var(--color-accent); }
.step h3 { font-size: var(--text-lg); margin: var(--space-sm) 0 var(--space-xs); }
.step p { color: var(--color-ink-2); font-size: var(--text-sm); margin: 0; }

/* ---- under the hood ---- */
.stack { display: grid; grid-template-columns: repeat(auto-fit, minmax(min(16rem, 100%), 1fr)); gap: var(--space-md); }
.chip { padding: var(--space-lg); border: var(--rule-hair); border-radius: var(--radius-md); }
.chip .k { font-family: var(--font-mono); font-size: var(--text-xs); letter-spacing: 0.08em; color: var(--color-accent-2); text-transform: uppercase; }
.chip h3 { font-size: var(--text-lg); margin: var(--space-xs) 0; }
.chip p { color: var(--color-ink-2); font-size: var(--text-sm); margin: 0; }

/* ---- pricing ---- */
.price-band { border: var(--rule-hair); border-radius: var(--radius-lg); padding: var(--space-2xl); background: oklch(19% 0.03 280 / 0.55); text-align: center; }
.price-band h2 { font-size: var(--text-2xl); margin: 0 0 var(--space-md); }
.price-cols { display: grid; grid-template-columns: repeat(auto-fit, minmax(min(13rem, 100%), 1fr)); gap: var(--space-lg); margin-top: var(--space-xl); text-align: left; }
.price-cols .c { padding: var(--space-lg); border-radius: var(--radius-md); border: var(--rule-hair); }
.price-cols .big { font-family: var(--font-display); font-size: var(--text-2xl); }
.price-cols .c p { color: var(--color-ink-2); font-size: var(--text-sm); }

/* ---- footer: Ft5 statement ---- */
footer { border-top: var(--rule-hair); padding-block: var(--space-3xl) var(--space-xl); }
.statement { font-family: var(--font-display); font-size: var(--text-2xl); letter-spacing: -0.02em; max-width: 18ch; margin: 0 0 var(--space-2xl); }
.statement em { font-style: normal; color: var(--color-accent); }
.foot-row { display: flex; flex-wrap: wrap; gap: var(--space-lg); justify-content: space-between; align-items: center; color: var(--color-ink-mute); font-size: var(--text-sm); }
.foot-links { display: flex; gap: var(--space-lg); flex-wrap: wrap; }
.foot-links a { text-decoration: none; color: var(--color-ink-2); }
.foot-links a:hover { color: var(--color-ink); }

/* ---- motion (reduced-motion aware) ---- */
@media (prefers-reduced-motion: no-preference) {
  .reveal { opacity: 0; transform: translateY(16px); animation: rise 0.7s var(--ease-out) forwards; }
  .reveal.d1 { animation-delay: 0.08s; }
  .reveal.d2 { animation-delay: 0.16s; }
  @keyframes rise { to { opacity: 1; transform: none; } }
}
