:root{
  --bg:        oklch(0.965 0.008 85);
  --bg-2:      oklch(0.945 0.012 85);
  --ink:       oklch(0.18 0.01 80);
  --ink-soft:  oklch(0.32 0.012 80);
  --ink-mute:  oklch(0.52 0.012 80);
  --rule:      oklch(0.86 0.012 85);
  --rule-soft: oklch(0.91 0.01 85);
  --accent:    oklch(0.60 0.16 38);
  --accent-2:  oklch(0.55 0.18 38);
  --green:     oklch(0.7 0.18 145);
  --green-text:oklch(0.62 0.16 145);
  --max:       1360px;
  --pad:       clamp(20px, 4vw, 56px);
  --grain:     0.04;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--ink)}
html{scroll-behavior:smooth}
body{
  font-family:'Geist', ui-sans-serif, system-ui, -apple-system, 'Helvetica Neue', Arial, sans-serif;
  font-feature-settings:"ss01","ss02","cv11";
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  line-height:1.45;
  overflow-x:hidden;
}

body::before{
  content:"";
  position:fixed; inset:0; pointer-events:none; z-index:60;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='180' height='180'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0  0 0 0 0 0  0 0 0 0 0  0 0 0 0.35 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
  opacity: var(--grain);
  mix-blend-mode: multiply;
}

a{color:inherit; text-decoration:none}
::selection{background:var(--accent); color:var(--bg)}

.sr-only{
  position:absolute; width:1px; height:1px;
  padding:0; margin:-1px; overflow:hidden;
  clip:rect(0,0,0,0); white-space:nowrap; border:0;
}

/* ============ Type scale ============ */
.mono{font-family:'Geist Mono', ui-monospace, SFMono-Regular, Menlo, monospace; letter-spacing:0.01em}
.eyebrow{
  font-family:'Geist Mono', monospace; font-size:11px; letter-spacing:0.18em;
  text-transform:uppercase; color:var(--ink-mute);
}
.serif{font-family:'Instrument Serif', 'Times New Roman', serif; font-style:italic; font-weight:400}

h1,h2,h3,h4{margin:0; font-weight:500; letter-spacing:-0.02em; line-height:1.02}
.display{
  /* Cap by both vw and vh so the 4-line title never overflows the
     viewport in either dimension. Floor low enough that the longest
     line ("on our own terms.") still fits at ~360px content widths. */
  font-size: clamp(36px, min(10vw, 13vh), 132px);
  letter-spacing:-0.035em;
  font-weight:500;
  line-height:0.95;
}
h2.section-title{
  font-size: clamp(34px, 5.6vw, 78px);
  letter-spacing:-0.025em;
  line-height:1.0;
  font-weight:500;
}
h3{font-size: clamp(22px, 2.4vw, 30px); letter-spacing:-0.02em; font-weight:500}

p{margin:0}
.lede{font-size: clamp(18px, 1.6vw, 22px); line-height:1.5; color:var(--ink-soft); max-width: 58ch}

/* ============ Layout ============ */
.shell{max-width:var(--max); margin:0 auto; padding-left:var(--pad); padding-right:var(--pad)}

/* ============ Nav ============ */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:50;
  backdrop-filter: blur(14px) saturate(140%);
  -webkit-backdrop-filter: blur(14px) saturate(140%);
  background: color-mix(in oklab, var(--bg) 78%, transparent);
  border-bottom: 1px solid color-mix(in oklab, var(--rule) 60%, transparent);
}
.nav-inner{
  display:flex; align-items:center; justify-content:space-between;
  height:62px;
}
.brand{display:flex; align-items:center; gap:10px; font-weight:500; letter-spacing:-0.01em}
.brand-mark{
  width:22px; height:22px; display:inline-grid; place-items:center;
  color:var(--accent);
}
.brand-mark svg{display:block}
.nav-links{display:flex; gap:26px; align-items:center}
.nav-links a{font-size:14px; color:var(--ink-soft)}
.nav-links a:hover{color:var(--ink)}
.nav-cta{
  display:inline-flex; align-items:center; gap:8px;
  height:34px; padding: 0 14px;
  border-radius: 999px;
  background: var(--ink); color:var(--bg) !important;
  font-size: 13px; letter-spacing:-0.005em;
  border:1px solid var(--ink);
  transition: transform .25s ease, background .25s ease, border-color .25s ease;
}
.nav-cta:hover{background:var(--accent-2); border-color:var(--accent-2); color:var(--bg) !important}
.nav-cta .dot{
  width:6px; height:6px; border-radius:50%;
  background:var(--accent);
  box-shadow:0 0 0 3px color-mix(in oklab, var(--accent) 30%, transparent);
}
@media (max-width: 720px){
  .nav-links a:not(.nav-cta){display:none}
}

/* ============ Hero ============ */
.hero{
  position:relative;
  /* Vertical spacing in vh (not vw) so short laptop viewports don't get
     padded as if they were tall. */
  padding-top: clamp(86px, 11vh, 130px);
  padding-bottom: clamp(40px, 7vh, 90px);
  min-height: 100svh;
  display:flex; flex-direction:column;
  isolation:isolate;
}
.hero-shell{
  position:relative; z-index:2;
  flex: 1;
  display:flex; flex-direction:column;
}
.hero-meta{
  display:grid; grid-template-columns: 1fr 1fr 1fr 1fr; gap:24px;
  margin-bottom: clamp(28px, 6vh, 96px);
  color:var(--ink-mute);
  font-size:12px;
}
.hero-meta > div{display:flex; flex-direction:column; gap:6px}
.hero-meta strong{color:var(--ink); font-weight:500; font-size:13px}
.status-dot{color:var(--green-text)}
@media (max-width:760px){
  .hero-meta{grid-template-columns: 1fr 1fr; gap:18px}
}

.hero-title{position:relative; z-index:2}
.hero-title .line{display:block; overflow:hidden}
.hero-title .word{
  display:inline-block;
  transform: translateY(110%);
  animation: rise 1.05s cubic-bezier(.2,.7,.2,1) forwards;
}
.hero-title .word.d2{animation-delay:.08s}
.hero-title .word.d3{animation-delay:.16s}
.hero-title .word.d4{animation-delay:.24s}
@keyframes rise{to{transform:translateY(0)}}

.hero-title .amp{
  color:var(--accent); font-style:italic;
  font-family:'Instrument Serif', serif; font-weight:400;
  letter-spacing:-0.02em;
}

.hero-foot{
  margin-top: auto;
  padding-top: clamp(32px, 5vh, 80px);
  display:grid; grid-template-columns: 1.4fr 1fr; gap:48px; align-items:end;
}
@media (max-width:880px){
  .hero-foot{grid-template-columns: 1fr; gap:36px}
}

.scroll-cue{
  display:inline-flex; align-items:center; gap:10px;
  font-size:12px; color:var(--ink-mute);
  font-family:'Geist Mono', monospace; letter-spacing:0.12em; text-transform:uppercase;
}
.scroll-cue .bar{
  width:42px; height:1px; background: var(--ink-mute);
  position:relative; overflow:hidden;
}
.scroll-cue .bar::after{
  content:""; position:absolute; inset:0;
  background: var(--ink);
  transform: translateX(-100%);
  animation: scan 2.4s ease-in-out infinite;
}
@keyframes scan{
  0%{transform:translateX(-100%)} 50%{transform:translateX(100%)} 100%{transform:translateX(100%)}
}

/* Kernel field background */
.kernels{
  position:absolute; inset: 0 0 0 0;
  z-index: 1;
  opacity: 0.95;
  pointer-events:auto;
  overflow: hidden;
}
.kernels canvas{width:100%; height:100%; display:block}

/* ============ Section frame ============ */
section.block{
  position:relative;
  padding-top: clamp(72px, 10vw, 140px);
  padding-bottom: clamp(72px, 10vw, 140px);
  border-top: 1px solid var(--rule);
}
section.block-tight{padding-top: clamp(32px, 5vw, 60px)}

.section-head{
  display:grid; grid-template-columns: 200px 1fr; gap:32px;
  align-items: start;
  margin-bottom: clamp(40px, 6vw, 72px);
}
.section-head .idx{
  font-family:'Geist Mono', monospace; font-size:12px;
  color:var(--ink-mute); letter-spacing:0.16em; text-transform:uppercase;
  padding-top: 14px;
}
@media (max-width:760px){
  .section-head{grid-template-columns: 1fr; gap:14px}
  .section-head .idx{padding-top:0}
}

/* ============ Manifesto ============ */
.manifesto{
  font-size: clamp(26px, 3.6vw, 52px);
  line-height:1.18;
  letter-spacing:-0.02em;
  font-weight:400;
  max-width: 22ch;
}
.manifesto .muted{color: var(--ink-mute)}
.manifesto .pop{
  color: var(--accent);
  font-family:'Instrument Serif', serif;
  font-style:italic; font-weight:400;
}
.manifesto-grid{
  display:grid; grid-template-columns: 1.5fr 1fr; gap: clamp(40px, 6vw, 96px);
  align-items: end;
}
@media (max-width:880px){.manifesto-grid{grid-template-columns:1fr}}

.manifesto-side{
  display:flex; flex-direction:column; gap:18px;
  color: var(--ink-soft);
  font-size: 16px; line-height:1.6;
  max-width: 42ch;
}
.manifesto-side .label{
  font-family:'Geist Mono', monospace; font-size:11px;
  letter-spacing:0.16em; text-transform:uppercase; color:var(--ink-mute);
}

/* ============ Capabilities ============ */
.caps{
  display:grid; grid-template-columns: repeat(12, 1fr); gap: 0;
  border-top:1px solid var(--rule);
}
.cap{
  grid-column: span 4;
  padding: 32px 28px 36px;
  border-bottom: 1px solid var(--rule);
  border-right: 1px solid var(--rule);
  display:flex; flex-direction:column; gap:14px;
  min-height: 230px;
  position:relative;
  background: transparent;
  transition: background .35s ease;
}
.cap:hover{background: color-mix(in oklab, var(--bg-2) 60%, transparent)}
.cap:nth-child(3n){border-right:none}
.cap .num{
  font-family:'Geist Mono', monospace; font-size:11px;
  color:var(--ink-mute); letter-spacing:0.16em;
}
.cap h3{margin-top: 6px}
.cap p{color:var(--ink-soft); font-size:15px; line-height:1.55; margin-top:auto}
@media (max-width: 980px){
  .cap{grid-column: span 6}
  .cap:nth-child(3n){border-right:1px solid var(--rule)}
  .cap:nth-child(2n){border-right:none}
}
@media (max-width: 600px){
  .cap{grid-column: span 12; border-right:none !important}
}

/* ============ Contact ============ */
.contact{
  background: var(--ink);
  color: var(--bg);
  border-radius: 24px;
  padding: clamp(48px, 7vw, 96px) clamp(28px, 5vw, 72px);
  display:grid; grid-template-columns: 1.4fr 1fr; gap: 48px; align-items:end;
  position:relative; overflow:hidden;
  margin-bottom: 72px;
}
.contact::before{
  content:""; position:absolute; inset:0;
  background:
    radial-gradient(60% 80% at 100% 100%, color-mix(in oklab, var(--accent) 45%, transparent), transparent 60%),
    radial-gradient(40% 60% at 0% 0%, color-mix(in oklab, var(--accent) 18%, transparent), transparent 60%);
  pointer-events:none;
}
.contact > *{position:relative; z-index:1}
.contact h2{
  font-size: clamp(40px, 7vw, 100px);
  line-height: 0.96; letter-spacing:-0.03em;
  font-weight:500;
}
.contact h2 .it{
  font-family:'Instrument Serif', serif;
  font-style:italic;
  color: color-mix(in oklab, var(--accent) 65%, white);
  font-weight:400;
}
.contact .side{
  color: color-mix(in oklab, var(--bg) 65%, transparent);
  font-size:15px; line-height:1.6;
}
.contact .side .label{
  font-family:'Geist Mono', monospace; font-size:11px;
  letter-spacing:0.16em; text-transform:uppercase;
  color: color-mix(in oklab, var(--bg) 60%, transparent);
  display:block; margin-bottom:10px;
}
.contact .side .side-p2{margin-top:14px}

.big-cta{
  display:inline-flex; align-items:center; gap:14px;
  margin-top: 28px;
  padding: 18px 26px 18px 28px;
  background: var(--bg);
  color: var(--ink);
  border-radius: 999px;
  font-size: 17px; letter-spacing:-0.01em;
  font-weight: 500;
  transition: transform .35s cubic-bezier(.2,.7,.2,1), background .3s, color .3s;
}
.big-cta:hover{background: var(--accent); color:var(--bg); transform: translateY(-2px)}
.big-cta .arrow{
  width:34px; height:34px; border-radius:50%;
  display:grid; place-items:center;
  background: var(--ink); color: var(--bg);
  transition: transform .35s, background .3s, color .3s;
}
.big-cta:hover .arrow{background:var(--bg); color: var(--accent); transform: rotate(-45deg)}
.big-cta .arrow svg{display:block}

@media (max-width: 880px){
  .contact{grid-template-columns:1fr; gap: 28px}
}

/* ============ Footer ============ */
footer{
  padding-top: 32px;
  padding-bottom: 36px;
  border-top:1px solid var(--rule);
  color: var(--ink-mute);
  font-size: 12px;
  font-family:'Geist Mono', monospace;
  letter-spacing: 0.06em;
}
.foot-row{display:flex; justify-content:space-between; align-items:center; gap: 20px; flex-wrap:wrap}
.foot-row .dot{
  width:6px; height:6px; border-radius:50%;
  background: var(--green);
  display:inline-block; margin-right:6px;
  box-shadow:0 0 0 3px color-mix(in oklab, var(--green) 25%, transparent);
}

/* ============ Reveal on scroll ============ */
.reveal{
  opacity:0; transform: translateY(18px);
  transition: opacity .9s cubic-bezier(.2,.7,.2,1), transform .9s cubic-bezier(.2,.7,.2,1);
}
.reveal.in{opacity:1; transform:none}

/* ============ Marquee ============ */
.marquee{
  border-top:1px solid var(--rule);
  border-bottom:1px solid var(--rule);
  padding: 18px 0;
  overflow:hidden;
  background: var(--bg-2);
}
.marquee-track{
  display:flex; gap: 56px;
  white-space:nowrap;
  animation: scrollx 38s linear infinite;
  font-family:'Geist Mono', monospace;
  font-size: 13px; letter-spacing:0.12em; text-transform:uppercase;
  color: var(--ink-soft);
}
.marquee-track span{display:inline-flex; align-items:center; gap: 18px}
.marquee-track .star{color:var(--accent)}
@keyframes scrollx{
  from{transform:translateX(0)} to{transform:translateX(-50%)}
}

/* ============ Reduced motion ============ */
@media (prefers-reduced-motion: reduce){
  *, *::before, *::after{
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.001ms !important;
  }
  html{scroll-behavior:auto}
  .hero-title .word{transform:none}
  .marquee-track{animation: none}
  .scroll-cue .bar::after{animation: none}
  .reveal{opacity:1; transform:none}
}
