/* ===== Systo AI — design tokens ===== */
:root {
  --bg: #050608;
  --bg-2: #0a0d12;
  --bg-3: #0f1319;
  --ink: #e6f1ff;
  --ink-dim: #8a96a8;
  --ink-faint: #4a5568;
  --line: rgba(255,255,255,0.06);
  --line-2: rgba(255,255,255,0.12);
  --accent: #00E5FF;
  --accent-2: #FFB020;
  --accent-glow: rgba(0,229,255,0.35);
  --danger: #ff3b6b;
  --ok: #36e08c;
  --mono: 'JetBrains Mono', ui-monospace, SFMono-Regular, Menlo, monospace;
  --display: 'Geist', 'Inter', system-ui, sans-serif;
}
[data-theme="light"] {
  --bg: #f4f1ea;
  --bg-2: #ece8df;
  --bg-3: #e2ddd1;
  --ink: #0a0d12;
  --ink-dim: #4a5568;
  --ink-faint: #8a96a8;
  --line: rgba(0,0,0,0.08);
  --line-2: rgba(0,0,0,0.16);
  --accent-glow: rgba(0,150,200,0.25);
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html, body {
  background: var(--bg);
  color: var(--ink);
  font-family: var(--mono);
  font-size: 15px;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}
body { min-height: 100vh; cursor: none; }
::selection { background: var(--accent); color: #000; }

a { color: inherit; text-decoration: none; }
button { font: inherit; color: inherit; background: none; border: 0; cursor: none; }
input { cursor: text; }

/* Block image/video drag and select for casual save attempts */
img, video {
  -webkit-user-drag: none;
  user-select: none;
  -webkit-user-select: none;
  -webkit-touch-callout: none;
}

/* ===== Custom cursor ===== */
.cursor-dot, .cursor-ring {
  position: fixed; top: 0; left: 0; pointer-events: none; z-index: 9999;
  transform: translate(-50%, -50%);
  mix-blend-mode: difference;
}
.cursor-dot { width: 6px; height: 6px; background: var(--accent); border-radius: 50%; transition: width .2s, height .2s, background .2s; }
.cursor-ring {
  width: 36px; height: 36px; border: 1px solid var(--accent);
  border-radius: 50%;
  transition: width .25s ease, height .25s ease, border-color .25s, opacity .25s;
}
.cursor-dot.hot { width: 14px; height: 14px; }
.cursor-ring.hot { width: 64px; height: 64px; border-color: var(--accent-2); }

/* Cursor glow trail */
.cursor-glow {
  position: fixed; pointer-events: none; z-index: 1;
  width: 600px; height: 600px;
  background: radial-gradient(circle, var(--accent-glow) 0%, transparent 60%);
  mix-blend-mode: screen;
  transform: translate(-50%, -50%);
  opacity: 0.35;
  filter: blur(40px);
}

@media (hover: none) {
  body { cursor: auto; }
  button { cursor: pointer; }
  .cursor-dot, .cursor-ring, .cursor-glow { display: none; }
}

/* ===== Scroll progress ===== */
.scroll-progress {
  position: fixed; top: 0; left: 0; right: 0; height: 2px; z-index: 200;
  background: var(--accent);
  transform-origin: left;
  transform: scaleX(var(--p, 0));
  box-shadow: 0 0 8px var(--accent);
}

/* ===== Grid backdrop ===== */
.grid-backdrop {
  position: fixed; inset: 0; z-index: 0; pointer-events: none;
  background-image:
    linear-gradient(var(--line) 1px, transparent 1px),
    linear-gradient(90deg, var(--line) 1px, transparent 1px);
  background-size: 64px 64px;
  mask-image: radial-gradient(ellipse at center, #000 30%, transparent 80%);
  opacity: 0.6;
}

/* Scanline overlay */
.scanlines {
  position: fixed; inset: 0; z-index: 0; pointer-events: none;
  background: repeating-linear-gradient(180deg,
    transparent 0px, transparent 2px,
    rgba(0,229,255,0.012) 2px, rgba(0,229,255,0.012) 3px);
  opacity: 0.5;
}

/* ===== Live ticker (top) ===== */
.live-ticker {
  position: fixed; top: 0; left: 0; right: 0; z-index: 49;
  display: flex; align-items: center; gap: 24px;
  padding: 6px 28px;
  font-family: var(--mono); font-size: 10px;
  background: #000; border-bottom: 1px solid var(--accent);
  color: var(--accent); letter-spacing: 0.12em;
  overflow: hidden;
  white-space: nowrap;
}
.live-ticker__dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--ok); box-shadow: 0 0 8px var(--ok);
  animation: pulse 1.6s infinite;
  flex-shrink: 0;
}
.live-ticker__track {
  display: flex; gap: 36px; animation: tickerScroll 50s linear infinite;
  flex-shrink: 0;
}
@keyframes tickerScroll { to { transform: translateX(-50%); } }
.live-ticker__item { display: inline-flex; gap: 8px; }
.live-ticker__item .v { color: var(--ink); }

/* ===== Top nav ===== */
.nav {
  position: fixed; top: 28px; left: 0; right: 0; z-index: 50;
  display: flex; align-items: center; justify-content: space-between;
  padding: 18px 28px;
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: 0.04em;
  backdrop-filter: blur(12px);
  background: color-mix(in oklab, var(--bg) 70%, transparent);
  border-bottom: 1px solid var(--line);
}
.nav__brand { display: flex; align-items: center; gap: 12px; font-weight: 600; }
.nav__brand img { height: 22px; filter: invert(1); transition: filter .2s; }
[data-theme="light"] .nav__brand img { filter: none; }
.nav__brand .v { color: var(--ink-faint); margin-left: 4px; }
.nav__links { display: flex; gap: 22px; color: var(--ink-dim); }
.nav__links a { position: relative; transition: color .2s; }
.nav__links a:hover { color: var(--accent); }
.nav__links a::after {
  content: ''; position: absolute; left: 0; bottom: -4px; height: 1px;
  width: 0; background: var(--accent); transition: width .25s;
}
.nav__links a:hover::after { width: 100%; }
.nav__cta {
  border: 1px solid var(--accent);
  color: var(--accent);
  padding: 8px 14px;
  display: inline-flex; align-items: center; gap: 8px;
  transition: all .2s;
  position: relative; overflow: hidden;
}
.nav__cta::before {
  content: ''; position: absolute; inset: 0;
  background: var(--accent); transform: translateX(-101%);
  transition: transform .3s ease;
  z-index: -1;
}
.nav__cta:hover { color: #000; box-shadow: 0 0 24px var(--accent-glow); }
.nav__cta:hover::before { transform: translateX(0); }
.status-dot {
  width: 8px; height: 8px; border-radius: 50%; background: var(--ok);
  box-shadow: 0 0 8px var(--ok);
  animation: pulse 2s infinite;
}
@keyframes pulse { 50% { opacity: .4; } }

/* ===== Section base ===== */
section { position: relative; z-index: 1; padding: 120px 28px; }
.wrap { max-width: 1320px; margin: 0 auto; }

.eyebrow {
  font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--accent); display: inline-flex; align-items: center; gap: 10px;
  margin-bottom: 18px;
}
.eyebrow::before { content: ''; width: 24px; height: 1px; background: var(--accent); }

h1, h2, h3 { font-family: var(--display); font-weight: 500; letter-spacing: -0.02em; line-height: 1.05; }
h2.section-title { font-size: clamp(40px, 5vw, 72px); margin-bottom: 24px; }
h2.section-title .accent { color: var(--accent); font-style: italic; font-family: 'Instrument Serif', serif; font-weight: 400; }
.section-sub { color: var(--ink-dim); max-width: 640px; font-size: 15px; }

/* ===== Hero ===== */
.hero {
  min-height: 100vh; padding: 0;
  position: relative; overflow: hidden;
  display: flex; align-items: center; justify-content: center;
}
.hero__canvas { position: absolute; inset: 0; z-index: 1; }
.hero__overlay {
  position: relative; z-index: 2;
  display: flex; flex-direction: column; align-items: center;
  text-align: center; padding: 0 28px;
  pointer-events: none;
}
.hero__overlay > * { pointer-events: auto; }
.hero__chip {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 6px 14px; border: 1px solid var(--line-2);
  border-radius: 999px; font-size: 11px;
  background: color-mix(in oklab, var(--bg) 60%, transparent);
  margin-bottom: 32px;
  backdrop-filter: blur(8px);
}
.hero__title {
  font-size: clamp(56px, 9vw, 148px);
  font-family: var(--display); font-weight: 500;
  letter-spacing: -0.04em; line-height: 0.92;
  margin-bottom: 28px;
  animation: heroTitleFade .6s ease;
}
@keyframes heroTitleFade {
  from { opacity: 0; transform: translateY(20px); filter: blur(8px); }
  to { opacity: 1; transform: none; filter: none; }
}
.hero__title .ital { font-family: 'Instrument Serif', serif; font-style: italic; color: var(--accent); font-weight: 400; }
.hero__title .strike { position: relative; color: var(--ink-dim); }
.hero__title .strike::after {
  content: ''; position: absolute; left: -4%; right: -4%; top: 52%; height: 4px;
  background: var(--accent-2); transform: rotate(-2deg);
}
.hero__sub { color: var(--ink-dim); font-size: 16px; max-width: 560px; margin-bottom: 36px; }
.hero__cta-row { display: flex; gap: 14px; align-items: center; flex-wrap: wrap; justify-content: center; }
.btn {
  font-family: var(--mono); font-size: 13px; letter-spacing: 0.02em;
  padding: 14px 22px; display: inline-flex; align-items: center; gap: 10px;
  border: 1px solid var(--line-2); transition: all .25s cubic-bezier(.2,.7,.2,1);
  position: relative; overflow: hidden;
}
.btn--primary { background: var(--accent); color: #000; border-color: var(--accent); font-weight: 600; }
.btn--primary:hover { box-shadow: 0 0 32px var(--accent-glow); transform: translateY(-2px); }
.btn--ghost:hover { border-color: var(--accent); color: var(--accent); }
.btn .arrow { transition: transform .2s; }
.btn:hover .arrow { transform: translateX(4px); }
.btn::after {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(120deg, transparent 30%, rgba(255,255,255,.25) 50%, transparent 70%);
  transform: translateX(-100%);
  transition: transform .6s;
}
.btn:hover::after { transform: translateX(100%); }

.hero__scroll-hint {
  position: absolute; bottom: 32px; left: 50%; transform: translateX(-50%);
  z-index: 3; font-size: 11px; color: var(--ink-dim); letter-spacing: .14em;
  display: flex; flex-direction: column; align-items: center; gap: 10px;
}
.hero__scroll-hint .line {
  width: 1px; height: 40px; background: linear-gradient(180deg, var(--accent), transparent);
  animation: drop 2s infinite;
}
@keyframes drop {
  0% { transform: scaleY(0); transform-origin: top; }
  50% { transform: scaleY(1); transform-origin: top; }
  51% { transform: scaleY(1); transform-origin: bottom; }
  100% { transform: scaleY(0); transform-origin: bottom; }
}

/* Scene indicator on hero */
.scene-meter {
  position: absolute; right: 28px; top: 50%; transform: translateY(-50%);
  z-index: 3; display: flex; flex-direction: column; gap: 12px;
  font-family: var(--mono); font-size: 10px; color: var(--ink-dim); letter-spacing: .1em;
}
.scene-meter__row { display: flex; align-items: center; gap: 10px; opacity: .35; transition: all .3s; cursor: none; }
.scene-meter__row:hover { opacity: .8; }
.scene-meter__row.active { opacity: 1; color: var(--accent); transform: translateX(-6px); }
.scene-meter__row .dot { width: 6px; height: 6px; border-radius: 50%; background: currentColor; transition: box-shadow .3s; }
.scene-meter__row.active .dot { box-shadow: 0 0 12px currentColor; }
.scene-meter__row .num { width: 18px; }

/* HUD overlays during hero scenes */
.hud-corner {
  position: absolute; z-index: 3; font-family: var(--mono); font-size: 10px;
  color: var(--accent); letter-spacing: 0.1em; opacity: 0.6;
}
.hud-corner.tl { top: 100px; left: 28px; }
.hud-corner.tr { top: 100px; right: 28px; text-align: right; }
.hud-corner.bl { bottom: 80px; left: 28px; }
.hud-corner.br { bottom: 80px; right: 28px; text-align: right; }
.hud-corner .v { color: var(--ink); }

/* ===== Manifesto pull-quote ===== */
.manifesto { padding: 80px 28px 120px; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.manifesto__inner {
  max-width: 1100px; margin: 0 auto;
  display: grid; grid-template-columns: 120px 1fr; gap: 28px;
}
@media (max-width: 720px) {
  .manifesto__inner { grid-template-columns: 1fr; }
}
.manifesto__label { font-size: 11px; letter-spacing: .18em; color: var(--ink-dim); text-transform: uppercase; padding-top: 14px; }
.manifesto__quote {
  font-family: 'Instrument Serif', serif; font-weight: 400;
  font-size: clamp(28px, 3.5vw, 52px); line-height: 1.18; letter-spacing: -0.01em;
}
.manifesto__quote em { color: var(--accent); }
.manifesto__sig { font-family: var(--mono); font-size: 11px; color: var(--ink-dim); margin-top: 24px; letter-spacing: 0.12em; }

/* ===== What we build (capabilities grid) ===== */
.cap-grid {
  display: grid; grid-template-columns: repeat(12, 1fr); gap: 1px;
  background: var(--line); border: 1px solid var(--line);
  margin-top: 56px;
}
.cap {
  background: var(--bg); padding: 36px 28px; min-height: 280px;
  position: relative; overflow: hidden; cursor: none;
  transition: background .25s;
}
.cap:hover { background: var(--bg-2); }
.cap::after {
  content: ''; position: absolute; inset: 0;
  background: radial-gradient(circle at var(--mx, 50%) var(--my, 50%), var(--accent-glow), transparent 50%);
  opacity: 0; transition: opacity .3s; pointer-events: none;
}
.cap:hover::after { opacity: 0.15; }
.cap--lg { grid-column: span 6; }
.cap--md { grid-column: span 4; }
.cap--sm { grid-column: span 4; }
.cap__num, .cap__title, .cap__desc, .cap__tags { position: relative; z-index: 2; }
.cap__num { font-size: 11px; color: var(--ink-faint); letter-spacing: .12em; }
.cap__title { font-family: var(--display); font-size: clamp(24px, 2vw, 36px); margin: 16px 0 10px; letter-spacing: -0.02em; max-width: 60%; }
.cap__desc { color: var(--ink-dim); font-size: 13px; max-width: 60%; }
.cap__viz {
  position: absolute; right: 0; bottom: 0;
  width: 55%; height: 65%;
  pointer-events: none;
  opacity: 0.4;
  z-index: 1;
  -webkit-mask-image: linear-gradient(135deg, transparent 0%, #000 55%);
          mask-image: linear-gradient(135deg, transparent 0%, #000 55%);
}
.cap__viz--3d {
  width: 48%; height: 95%;
  top: 0; bottom: 0; right: 0;
  opacity: 1;
  -webkit-mask-image: linear-gradient(110deg, transparent 0%, #000 45%);
          mask-image: linear-gradient(110deg, transparent 0%, #000 45%);
}
.cap--md .cap__viz, .cap--sm .cap__viz {
  width: 50%; height: 55%;
  opacity: 0.35;
}
.cap--md .cap__viz--3d, .cap--sm .cap__viz--3d {
  width: 46%; height: 88%;
  top: 6%;
  opacity: 1;
  -webkit-mask-image: linear-gradient(110deg, transparent 0%, #000 50%);
          mask-image: linear-gradient(110deg, transparent 0%, #000 50%);
}
.cap__tags { margin-top: 18px; display: flex; flex-wrap: wrap; gap: 6px; max-width: 60%; }
.cap__tag { font-size: 10px; padding: 3px 8px; border: 1px solid var(--line-2); color: var(--ink-dim); transition: all .2s; background: color-mix(in oklab, var(--bg) 80%, transparent); backdrop-filter: blur(4px); }
.cap:hover .cap__tag { border-color: var(--accent); color: var(--accent); }

/* ===== How we work (terminal-style) ===== */
.how-grid { display: grid; grid-template-columns: 1fr 1.2fr; gap: 60px; margin-top: 56px; align-items: start; }
@media (max-width: 920px) { .how-grid { grid-template-columns: 1fr; } }
.how-steps { display: flex; flex-direction: column; gap: 4px; }
.how-step {
  border-left: 2px solid var(--line);
  padding: 18px 24px;
  cursor: none;
  transition: all .2s;
  position: relative;
}
.how-step.active { border-left-color: var(--accent); background: var(--bg-2); }
.how-step.active::before {
  content: ''; position: absolute; left: -2px; top: 0; bottom: 0;
  width: 2px; background: var(--accent);
  box-shadow: 0 0 12px var(--accent);
}
.how-step__num { font-size: 11px; color: var(--ink-faint); letter-spacing: .12em; }
.how-step__title { font-family: var(--display); font-size: 22px; margin: 6px 0 6px; }
.how-step__desc { color: var(--ink-dim); font-size: 13px; }

.terminal {
  background: #000; border: 1px solid var(--line-2);
  font-family: var(--mono); font-size: 13px;
  border-radius: 6px; overflow: hidden;
  box-shadow: 0 30px 80px rgba(0,0,0,0.5), 0 0 0 1px var(--line);
}
.terminal__bar {
  display: flex; align-items: center; gap: 8px;
  padding: 10px 14px; background: #0a0d12; border-bottom: 1px solid var(--line-2);
  font-size: 11px; color: var(--ink-dim);
}
.terminal__dot { width: 10px; height: 10px; border-radius: 50%; }
.terminal__body { padding: 20px; min-height: 360px; color: #c5e6f7; }
.t-line { white-space: pre-wrap; animation: termLineIn .25s ease; }
@keyframes termLineIn { from { opacity: 0; transform: translateX(-6px); } to { opacity: 1; transform: none; } }
.t-prompt { color: var(--accent); }
.t-cmd { color: #fff; }
.t-out { color: var(--ink-dim); }
.t-ok { color: var(--ok); }
.t-warn { color: var(--accent-2); }
.t-cursor::after {
  content: '▌'; color: var(--accent);
  animation: blink 1s steps(2) infinite;
}
@keyframes blink { 50% { opacity: 0; } }

/* ===== AI Agents section ===== */
.agents { padding: 120px 28px; position: relative; }
.agents::before {
  content: ''; position: absolute; inset: 0;
  background:
    radial-gradient(ellipse at 20% 30%, color-mix(in oklab, var(--accent) 8%, transparent), transparent 50%),
    radial-gradient(ellipse at 80% 70%, color-mix(in oklab, var(--accent) 6%, transparent), transparent 50%);
  pointer-events: none;
}
/* Isometric office diorama */
.iso-office-wrap {
  position: relative;
  margin: 56px auto 32px;
  max-width: 720px;
  border: 1px solid var(--line);
  background:
    linear-gradient(180deg, var(--bg-2), var(--bg-3));
  padding: 16px;
  box-shadow: 0 30px 80px rgba(0,0,0,0.4), inset 0 0 60px rgba(0,229,255,0.05);
}
.iso-office {
  display: block;
  width: 100%;
  height: auto;
  image-rendering: pixelated;
  image-rendering: crisp-edges;
}
.iso-office-caption {
  position: absolute; top: 12px; left: 16px;
  font-family: var(--mono); font-size: 10px;
  letter-spacing: 0.16em; color: var(--accent);
  text-transform: uppercase;
  display: flex; align-items: center; gap: 8px;
  padding: 4px 8px;
  background: color-mix(in oklab, var(--bg) 75%, transparent);
  border: 1px solid var(--accent);
  z-index: 2;
}
.iso-office-caption__dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--ok); box-shadow: 0 0 6px var(--ok);
  animation: pulse 1.6s infinite;
}

.agents-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px;
  background: var(--line); border: 1px solid var(--line);
  margin-top: 32px;
}
@media (max-width: 920px) { .agents-grid { grid-template-columns: 1fr; } }
.agent-card {
  background: var(--bg); padding: 36px 28px;
  display: flex; flex-direction: column; align-items: flex-start; gap: 12px;
  position: relative; overflow: hidden;
  transition: background .3s;
}
.agent-card:hover { background: var(--bg-2); }
.agent-card__sprite-wrap {
  position: relative;
  align-self: center;
  margin: 12px 0 18px;
}
.agent-card__sprite-bg {
  position: absolute; inset: -30%;
  pointer-events: none;
  filter: blur(8px);
  z-index: 0;
}
.pixel-sprite {
  position: relative; z-index: 1; display: block;
  animation: spriteBob 2.4s ease-in-out infinite;
  image-rendering: pixelated;
  -webkit-user-drag: none; user-select: none;
}
.agent-card:nth-child(2) .pixel-sprite { animation-delay: 0.4s; }
.agent-card:nth-child(3) .pixel-sprite { animation-delay: 0.8s; }
@keyframes spriteBob {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-6px); }
}
.agent-card__name {
  font-family: var(--display); font-size: 24px; letter-spacing: -0.01em;
  align-self: center;
}
.agent-card__role {
  font-family: var(--mono); font-size: 11px; letter-spacing: .14em;
  color: var(--ink-dim); text-transform: uppercase;
  align-self: center;
}
.agent-card__bio {
  color: var(--ink-dim); font-size: 13px; line-height: 1.55;
  margin-top: 8px;
}

/* ADAM — featured card */
.adam-card {
  margin-top: 24px;
  display: grid; grid-template-columns: minmax(260px, 320px) 1fr;
  gap: 36px; align-items: center;
  padding: 36px;
  background: var(--bg-2);
  border: 1px solid var(--accent);
  position: relative; overflow: hidden;
  box-shadow: 0 30px 80px rgba(0,0,0,0.5), 0 0 0 1px var(--accent);
}
@media (max-width: 920px) {
  .adam-card { grid-template-columns: 1fr; padding: 28px; gap: 24px; }
}
.adam-card::before {
  content: ''; position: absolute; inset: 0;
  background: radial-gradient(circle at 30% 50%, var(--accent-glow), transparent 50%);
  pointer-events: none; opacity: .4;
}
.adam-card__sprite-wrap {
  position: relative; display: flex; align-items: center; justify-content: center;
  height: 280px;
}
.adam-card__sprite-bg {
  position: absolute; inset: 0;
  pointer-events: none;
  filter: blur(20px);
}
.adam-card__rings {
  position: absolute; inset: 0; pointer-events: none;
  display: flex; align-items: center; justify-content: center;
}
.adam-card__rings span {
  position: absolute;
  width: 200px; height: 200px;
  border: 1px solid var(--accent);
  border-radius: 50%;
  opacity: 0;
  animation: adamRing 3s ease-out infinite;
}
.adam-card__rings span:nth-child(2) { animation-delay: 1s; }
.adam-card__rings span:nth-child(3) { animation-delay: 2s; }
@keyframes adamRing {
  0% { transform: scale(0.5); opacity: .6; }
  100% { transform: scale(1.4); opacity: 0; }
}
.adam-card__copy { position: relative; z-index: 1; }
.adam-card__badge {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--mono); font-size: 10px; letter-spacing: .14em;
  color: var(--accent);
  border: 1px solid var(--accent);
  padding: 4px 10px;
  background: color-mix(in oklab, var(--bg) 80%, transparent);
  margin-bottom: 16px;
}
.adam-card__name {
  font-family: var(--display); font-size: clamp(36px, 4vw, 56px);
  letter-spacing: -0.03em; margin: 0;
}
.adam-card__role {
  font-family: var(--mono); font-size: 11px; letter-spacing: .14em;
  color: var(--ink-dim); text-transform: uppercase; margin: 8px 0 14px;
}
.adam-card__bio {
  color: var(--ink); font-size: 15px; line-height: 1.6; margin-bottom: 20px;
  max-width: 600px;
}
.adam-card__meta {
  display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px 24px;
  font-family: var(--mono); font-size: 12px;
  margin-bottom: 20px;
}
@media (max-width: 720px) { .adam-card__meta { grid-template-columns: 1fr; } }
.adam-card__meta > div { display: flex; flex-direction: column; }
.adam-card__meta .k { color: var(--ink-faint); font-size: 10px; letter-spacing: .14em; text-transform: uppercase; }
.adam-card__meta .v { color: var(--ink); margin-top: 2px; }
.adam-card__quote {
  font-family: 'Instrument Serif', serif; font-style: italic;
  font-size: 18px; color: var(--ink-dim);
  border-left: 2px solid var(--accent); padding-left: 16px;
  max-width: 600px;
}

/* ===== Integrations / Automations diagram ===== */
.integrations { background: var(--bg-2); border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.int-canvas {
  position: relative; height: 540px; margin-top: 56px;
  border: 1px solid var(--line); background:
    radial-gradient(circle at 50% 50%, var(--bg-3), var(--bg));
  overflow: hidden;
}
.int-canvas svg, .int-canvas canvas { position: absolute; inset: 0; width: 100%; height: 100%; }
.node {
  position: absolute; transform: translate(-50%,-50%);
  background: var(--bg); border: 1px solid var(--line-2);
  padding: 12px 16px; font-size: 12px; font-family: var(--mono);
  display: flex; align-items: center; gap: 10px;
  cursor: none; transition: all .2s;
  white-space: nowrap;
  z-index: 2;
}
.node:hover { border-color: var(--accent); box-shadow: 0 0 24px var(--accent-glow); transform: translate(-50%,-50%) scale(1.08); }
.node.hub { background: var(--accent); color: #000; border-color: var(--accent); font-weight: 600; padding: 16px 22px; font-size: 13px; }
.node.hub::before {
  content: ''; position: absolute; inset: -8px;
  border: 1px solid var(--accent); opacity: 0.3;
  animation: hubPulse 2.5s ease-out infinite;
}
@keyframes hubPulse {
  0% { transform: scale(1); opacity: .4; }
  100% { transform: scale(1.5); opacity: 0; }
}
.node__ic {
  width: 18px; height: 18px; border: 1px solid currentColor; display: inline-block;
  position: relative;
}
.node__ic::after { content: ''; position: absolute; inset: 4px; background: currentColor; opacity: .6; }

/* ===== Tech stack marquee ===== */
.stack { padding: 80px 0; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); overflow: hidden; }
.marquee { display: flex; gap: 60px; animation: scroll 40s linear infinite; white-space: nowrap; }
.marquee__item {
  display: inline-flex; align-items: center; gap: 14px;
  font-family: var(--display); font-size: clamp(40px, 5vw, 80px); font-weight: 500;
  letter-spacing: -0.03em; color: var(--ink-dim);
  transition: color .25s;
}
.marquee__item::after { content: '*'; color: var(--accent); margin-left: 30px; }
.marquee__item:hover { color: var(--accent); }
@keyframes scroll { to { transform: translateX(-50%); } }

/* ===== Apps We Use marquee ===== */
.apps-marquee {
  margin-top: 56px; padding: 24px 0;
  position: relative; overflow: hidden;
  -webkit-mask-image: linear-gradient(90deg, transparent, #000 6%, #000 94%, transparent);
          mask-image: linear-gradient(90deg, transparent, #000 6%, #000 94%, transparent);
}
.apps-track {
  display: flex; gap: 20px; width: max-content;
  animation: appsScroll 60s linear infinite;
  padding: 0 28px;
}
.apps-marquee:hover .apps-track { animation-play-state: paused; }
@keyframes appsScroll { to { transform: translateX(-50%); } }
.app-card {
  flex: 0 0 280px; height: 320px;
  background: var(--bg-2);
  border: 1px solid var(--line);
  display: flex; flex-direction: column; align-items: center;
  padding: 22px 22px 24px;
  text-align: center;
  position: relative;
  transition: all .35s cubic-bezier(.2,.7,.2,1);
  cursor: none;
  overflow: hidden;
}
.app-card::before {
  content: ''; position: absolute; inset: 0;
  background: radial-gradient(circle at 50% 0%, var(--accent-glow), transparent 50%);
  opacity: 0; transition: opacity .35s; pointer-events: none;
}
.app-card:hover {
  border-color: var(--accent);
  transform: translateY(-6px);
  box-shadow: 0 30px 60px rgba(0,0,0,0.5), 0 0 0 1px var(--accent);
  background: var(--bg-3);
}
.app-card:hover::before { opacity: 0.35; }
.app-card__cat {
  font-size: 10px; letter-spacing: .14em; color: var(--accent);
  border: 1px solid var(--accent); padding: 4px 10px;
  text-transform: uppercase;
  background: color-mix(in oklab, var(--bg) 70%, transparent);
}
.app-card__logo {
  flex: 1; display: flex; align-items: center; justify-content: center;
  width: 100%; padding: 18px 0;
  filter: brightness(0.92);
  transition: filter .25s, transform .35s cubic-bezier(.2,.7,.2,1);
}
.app-card__logo img {
  max-height: 64px; max-width: 200px;
  object-fit: contain;
}
.app-card:hover .app-card__logo {
  filter: brightness(1.1) drop-shadow(0 0 12px var(--accent-glow));
  transform: scale(1.08);
}
.app-card__name {
  font-family: var(--display); font-size: 22px;
  letter-spacing: -0.01em; margin-bottom: 6px;
  position: relative;
}
.app-card__use {
  color: var(--ink-dim); font-size: 12px; line-height: 1.4;
  max-height: 0; opacity: 0; overflow: hidden;
  transition: max-height .35s, opacity .25s;
  position: relative;
}
.app-card:hover .app-card__use { max-height: 80px; opacity: 1; }

/* ===== Process timeline ===== */
.timeline { display: grid; grid-template-columns: repeat(5, 1fr); gap: 1px; background: var(--line); border: 1px solid var(--line); margin-top: 56px; }
.timeline__step { background: var(--bg); padding: 32px 24px; min-height: 220px; position: relative; transition: background .25s; }
.timeline__step:hover { background: var(--bg-2); }
.timeline__step::before {
  content: ''; position: absolute; top: 0; left: 0; height: 2px; width: 0;
  background: var(--accent); transition: width .8s; box-shadow: 0 0 8px var(--accent);
}
.timeline__step.in-view::before { width: 100%; }
.timeline__day { font-size: 11px; color: var(--accent); letter-spacing: .12em; }
.timeline__title { font-family: var(--display); font-size: 22px; margin: 12px 0 8px; }
.timeline__desc { color: var(--ink-dim); font-size: 12px; }
@media (max-width: 920px) { .timeline { grid-template-columns: 1fr; } }

/* ===== Pricing ===== */
.pricing-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--line); border: 1px solid var(--line); margin-top: 56px; }
@media (max-width: 920px) { .pricing-grid { grid-template-columns: 1fr; } }
.tier { background: var(--bg); padding: 36px 28px; display: flex; flex-direction: column; gap: 16px; min-height: 480px; transition: transform .3s, background .3s; }
.tier:hover { transform: translateY(-4px); background: var(--bg-2); }
.tier--featured { background: var(--bg-2); position: relative; }
.tier--featured::before {
  content: 'MOST PICKED'; position: absolute; top: 16px; right: 16px;
  font-size: 9px; padding: 4px 8px; background: var(--accent); color: #000; letter-spacing: .12em;
}
.tier__name { font-family: var(--display); font-size: 28px; }
.tier__price { font-family: var(--display); font-size: 48px; letter-spacing: -0.03em; }
.tier__price small { font-family: var(--mono); font-size: 13px; color: var(--ink-dim); margin-left: 6px; }
.tier__sub { color: var(--ink-dim); font-size: 13px; }
.tier__list { list-style: none; display: flex; flex-direction: column; gap: 10px; margin: 12px 0; flex: 1; }
.tier__list li { font-size: 13px; color: var(--ink); display: flex; gap: 10px; }
.tier__list li::before { content: '+'; color: var(--accent); }

/* ===== Portfolio horizontal ===== */
.portfolio { padding: 120px 0; overflow: hidden; }
.portfolio__head { padding: 0 28px; max-width: 1320px; margin: 0 auto 56px; }
.portfolio__track-wrap { padding-left: 28px; }
.portfolio__track { display: flex; gap: 24px; overflow-x: auto; padding: 24px 28px 60px 0; scroll-snap-type: x mandatory; scrollbar-width: thin; cursor: grab; }
.portfolio__track.dragging { cursor: grabbing; scroll-snap-type: none; }
.portfolio__track::-webkit-scrollbar { height: 6px; }
.portfolio__track::-webkit-scrollbar-thumb { background: var(--line-2); }
.portfolio__track::-webkit-scrollbar-thumb:hover { background: var(--accent); }
.proj-card {
  flex: 0 0 460px; height: 540px;
  background: var(--bg-2); border: 1px solid var(--line);
  scroll-snap-align: start;
  position: relative; overflow: hidden; cursor: none;
  transition: all .35s cubic-bezier(.2,.7,.2,1);
}
.proj-card:hover { border-color: var(--accent); transform: translateY(-6px); box-shadow: 0 30px 60px rgba(0,0,0,0.5), 0 0 0 1px var(--accent); }
.proj-card__viz {
  position: relative; height: 320px; overflow: hidden;
  border-bottom: 1px solid var(--line);
  background: var(--bg-3);
}
.proj-card__viz canvas { position: absolute; inset: 0; width: 100%; height: 100%; }
.proj-card__viz::after {
  content: ''; position: absolute; inset: 0; pointer-events: none;
  background: linear-gradient(180deg, transparent 60%, var(--bg-2));
}
.proj-card__meta { padding: 24px; position: relative; z-index: 2; }
.proj-card__num { font-size: 11px; color: var(--ink-faint); letter-spacing: .12em; }
.proj-card__name { font-family: var(--display); font-size: 28px; margin: 6px 0 8px; letter-spacing: -0.02em; }
.proj-card__desc { color: var(--ink-dim); font-size: 13px; }
.proj-card__tags { position: absolute; top: 16px; left: 16px; display: flex; gap: 6px; z-index: 2; }
.proj-card__tag { font-size: 10px; padding: 3px 8px; background: rgba(0,0,0,0.6); color: var(--accent); border: 1px solid var(--accent); backdrop-filter: blur(6px); }
.proj-card__open {
  position: absolute; right: 16px; top: 16px; z-index: 2;
  width: 36px; height: 36px; border: 1px solid var(--line-2); display: flex; align-items: center; justify-content: center;
  background: rgba(0,0,0,0.4); color: var(--ink); transition: all .2s;
}
.proj-card:hover .proj-card__open { background: var(--accent); color: #000; border-color: var(--accent); transform: rotate(45deg); }
.portfolio__hint { padding: 0 28px; max-width: 1320px; margin: 24px auto 0; color: var(--ink-dim); font-size: 11px; letter-spacing: .12em; display: flex; gap: 16px; align-items: center; }

/* ===== Testimonials ===== */
.testimonials { background: var(--bg-2); border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }

/* Video testimonials (featured row) */
.video-testi-grid {
  display: grid; grid-template-columns: repeat(2, 1fr); gap: 24px;
  margin: 56px auto 0;
  max-width: 784px;
}
@media (max-width: 720px) { .video-testi-grid { grid-template-columns: 1fr; } }
.video-testi {
  position: relative; aspect-ratio: 9 / 16;
  border: 1px solid var(--line); background: #000;
  overflow: hidden; cursor: none;
  transition: all .35s cubic-bezier(.2,.7,.2,1);
}
.video-testi:hover { border-color: var(--accent); transform: translateY(-4px); box-shadow: 0 30px 60px rgba(0,0,0,0.5), 0 0 0 1px var(--accent); }
.video-testi video {
  width: 100%; height: 100%; object-fit: cover; display: block;
  background: #000;
}
.video-testi__play {
  position: absolute; inset: 0; z-index: 2;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 16px;
  background: linear-gradient(0deg, rgba(0,0,0,0.65) 0%, rgba(0,0,0,0.25) 50%, rgba(0,0,0,0.45) 100%);
  color: #fff;
  cursor: none;
  transition: background .25s;
}
.video-testi:hover .video-testi__play { background: linear-gradient(0deg, rgba(0,0,0,0.55) 0%, rgba(0,0,0,0.15) 50%, rgba(0,0,0,0.35) 100%); }
.video-testi__play-icon {
  width: 80px; height: 80px;
  border: 2px solid var(--accent);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 28px; color: var(--accent);
  background: color-mix(in oklab, #000 40%, transparent);
  backdrop-filter: blur(6px);
  padding-left: 6px;
  transition: all .25s;
  box-shadow: 0 0 32px var(--accent-glow);
}
.video-testi:hover .video-testi__play-icon {
  background: var(--accent); color: #000;
  transform: scale(1.08);
  box-shadow: 0 0 48px var(--accent-glow);
}
.video-testi__play-label {
  font-family: var(--mono); font-size: 11px;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--accent);
  background: color-mix(in oklab, #000 60%, transparent);
  padding: 6px 12px; border: 1px solid var(--accent);
  backdrop-filter: blur(4px);
}
.video-testi__meta {
  position: absolute; left: 0; right: 0; bottom: 0; z-index: 1;
  display: flex; gap: 12px; align-items: center;
  padding: 16px 18px;
  background: linear-gradient(0deg, rgba(0,0,0,0.85), transparent);
  color: #fff;
  pointer-events: none;
}
.video-testi.is-playing .video-testi__meta { opacity: 0; transition: opacity .3s; }
.video-testi__avatar {
  width: 40px; height: 40px; border-radius: 50%;
  background: var(--accent); color: #000;
  display: flex; align-items: center; justify-content: center;
  font-weight: 600; flex-shrink: 0;
}
.video-testi__name { font-size: 14px; font-weight: 500; }
.video-testi__role { font-size: 11px; color: var(--ink-dim); margin-top: 2px; }
.video-testi__tag {
  font-family: var(--mono); font-size: 10px; letter-spacing: .1em;
  color: var(--accent); margin-top: 4px;
}

.testi-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; margin-top: 32px; }
@media (max-width: 920px) { .testi-grid { grid-template-columns: 1fr; } }
.testi { padding: 28px; border: 1px solid var(--line); background: var(--bg); transition: all .3s; }
.testi:hover { border-color: var(--accent); transform: translateY(-4px); }
.testi__quote { font-family: 'Instrument Serif', serif; font-size: 22px; line-height: 1.3; margin-bottom: 24px; }
.testi__who { display: flex; align-items: center; gap: 12px; }
.testi__avatar { width: 40px; height: 40px; border-radius: 50%; background: var(--accent); color: #000; display: flex; align-items: center; justify-content: center; font-weight: 600; }
.testi__name { font-size: 13px; }
.testi__role { font-size: 11px; color: var(--ink-dim); }

/* ===== FAQ ===== */
.faq-list { margin-top: 56px; border-top: 1px solid var(--line); }
.faq-item { border-bottom: 1px solid var(--line); }
.faq-item__head {
  width: 100%; text-align: left; padding: 24px 0;
  display: flex; justify-content: space-between; align-items: center;
  font-family: var(--display); font-size: 22px; letter-spacing: -0.01em;
  transition: color .25s;
}
.faq-item__head:hover { color: var(--accent); }
.faq-item__head .plus { color: var(--accent); transition: transform .3s; font-family: var(--mono); }
.faq-item.open .faq-item__head .plus { transform: rotate(45deg); }
.faq-item__body {
  max-height: 0; overflow: hidden;
  color: var(--ink-dim); font-size: 14px; padding-right: 60px;
  transition: max-height .4s ease, padding-bottom .4s ease;
}
.faq-item.open .faq-item__body { max-height: 1000px; padding-bottom: 24px; }

/* ===== Contact / final CTA ===== */
.contact { padding: 160px 28px; text-align: center; position: relative; overflow: hidden; }
.contact::before {
  content: ''; position: absolute; inset: 0;
  background: radial-gradient(ellipse at center bottom, var(--accent-glow), transparent 60%);
  opacity: 0.4; pointer-events: none;
}
.contact__big {
  font-family: var(--display); font-weight: 500;
  font-size: clamp(56px, 9vw, 140px); letter-spacing: -0.04em; line-height: 0.95;
  position: relative;
}
.contact__big .ital { font-family: 'Instrument Serif', serif; font-style: italic; color: var(--accent); }
.contact__sub { color: var(--ink-dim); margin: 24px auto 40px; max-width: 540px; position: relative; }
.contact__form { display: flex; gap: 0; max-width: 560px; margin: 0 auto; border: 1px solid var(--line-2); position: relative; transition: border-color .25s, box-shadow .25s; }
.contact__form:focus-within { border-color: var(--accent); box-shadow: 0 0 0 4px var(--accent-glow); }
.contact__form input { flex: 1; background: transparent; border: 0; color: var(--ink); padding: 18px 20px; font: inherit; }
.contact__form input:focus { outline: none; }
.contact__form button { padding: 18px 24px; background: var(--accent); color: #000; font-weight: 600; transition: background .25s; }
.contact__form button:hover { background: var(--accent-2); }

/* ===== Footer ===== */
.footer { padding: 60px 28px; border-top: 1px solid var(--line); background: var(--bg); font-size: 12px; color: var(--ink-dim); }
.footer__inner { max-width: 1320px; margin: 0 auto; display: flex; justify-content: space-between; flex-wrap: wrap; gap: 24px; }
.footer__cols { display: flex; gap: 60px; }
.footer__col { display: flex; flex-direction: column; gap: 8px; }
.footer__col strong { color: var(--ink); font-weight: 500; margin-bottom: 6px; font-family: var(--display); }
.footer a { transition: color .2s; }
.footer a:hover { color: var(--accent); }
.footer__brand { display: flex; align-items: center; gap: 10px; margin-bottom: 8px; }
.footer__brand img { height: 20px; filter: invert(1); }
[data-theme="light"] .footer__brand img { filter: none; }

/* ===== Lead Modal ===== */
.lead-modal {
  position: fixed; inset: 0; z-index: 200;
  background: color-mix(in oklab, #000 78%, transparent);
  backdrop-filter: blur(8px);
  display: flex; align-items: center; justify-content: center;
  padding: 24px;
  animation: lmFadeIn .25s ease;
}
@keyframes lmFadeIn { from { opacity: 0; } to { opacity: 1; } }
.lead-modal__card {
  background: var(--bg-2); border: 1px solid var(--accent);
  width: 100%; max-width: 760px; max-height: calc(100vh - 48px);
  overflow-y: auto;
  position: relative;
  padding: 32px;
  box-shadow: 0 40px 100px rgba(0,0,0,0.7), 0 0 0 1px var(--accent), 0 0 80px var(--accent-glow);
  animation: lmCardIn .3s cubic-bezier(.2,.7,.2,1);
}
@keyframes lmCardIn {
  from { opacity: 0; transform: translateY(20px) scale(0.98); }
  to { opacity: 1; transform: none; }
}
.lead-modal__close {
  position: absolute; top: 14px; right: 14px;
  width: 32px; height: 32px;
  display: flex; align-items: center; justify-content: center;
  font-size: 20px; color: var(--ink-dim);
  background: var(--bg);
  border: 1px solid var(--line-2);
  transition: all .2s; cursor: none;
  z-index: 5;
}
.lead-modal__close:hover { color: var(--accent); border-color: var(--accent); transform: rotate(90deg); }
.lead-modal__header {
  display: flex; align-items: center; justify-content: space-between;
  margin: 16px 56px 28px 0;
  padding-bottom: 18px;
  border-bottom: 1px solid var(--line);
}
.lead-modal__progress { display: flex; gap: 6px; }
.lm-pip {
  width: 28px; height: 4px;
  background: var(--line-2);
  transition: background .3s;
}
.lm-pip.on { background: var(--accent); box-shadow: 0 0 8px var(--accent); }
.lm-pip.done { background: var(--accent); opacity: 0.6; }
.lead-modal__step-label {
  font-family: var(--mono); font-size: 11px;
  letter-spacing: .14em; color: var(--ink-dim);
  text-transform: uppercase;
}

.lm-step { animation: lmStepIn .35s ease; }
@keyframes lmStepIn {
  from { opacity: 0; transform: translateX(8px); }
  to { opacity: 1; transform: none; }
}
.lm-step__title {
  font-family: var(--display); font-size: 28px;
  letter-spacing: -0.02em; margin-bottom: 6px;
}
.lm-step__sub {
  color: var(--ink-dim); font-size: 13px; margin-bottom: 24px;
}
.lm-fields { display: flex; flex-direction: column; gap: 16px; }
.lm-fields--2col {
  display: grid; grid-template-columns: 1fr 1fr; gap: 16px;
}
@media (max-width: 600px) { .lm-fields--2col { grid-template-columns: 1fr; } }
.lm-field { display: flex; flex-direction: column; gap: 6px; }
.lm-field--full { grid-column: 1 / -1; }
.lm-label {
  font-family: var(--mono); font-size: 11px;
  letter-spacing: .12em; color: var(--ink-dim);
  text-transform: uppercase;
  display: flex; gap: 6px; align-items: center;
}
.lm-label em { color: var(--accent); font-style: normal; }
.lm-label .opt { color: var(--ink-faint); }
.lm-field input, .lm-field select, .lm-field textarea {
  background: var(--bg);
  border: 1px solid var(--line-2);
  color: var(--ink);
  padding: 12px 14px;
  font: inherit;
  font-family: var(--mono);
  font-size: 13px;
  transition: all .2s;
}
.lm-field input:focus, .lm-field select:focus, .lm-field textarea:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-glow);
}
.lm-field textarea { resize: vertical; font-family: var(--mono); }
.lm-hp { position: absolute; left: -9999px; opacity: 0; pointer-events: none; height: 0; }

.lm-chips { display: flex; flex-wrap: wrap; gap: 8px; }
.lm-chip {
  font-family: var(--mono); font-size: 12px;
  padding: 8px 14px;
  border: 1px solid var(--line-2);
  background: var(--bg);
  color: var(--ink-dim);
  transition: all .2s;
  cursor: none;
}
.lm-chip:hover { color: var(--accent); border-color: var(--accent); }
.lm-chip.on { background: var(--accent); color: #000; border-color: var(--accent); font-weight: 500; }

.lm-err {
  margin-top: 16px; padding: 12px; font-size: 12px;
  border: 1px solid var(--danger); color: var(--danger);
  background: color-mix(in oklab, var(--danger) 10%, transparent);
}

.lead-modal__nav {
  display: flex; justify-content: space-between; gap: 12px;
  margin-top: 28px; padding-top: 20px;
  border-top: 1px solid var(--line);
}
.lead-modal__nav .btn:disabled { opacity: 0.4; cursor: not-allowed; }

/* ===== Calendar UI ===== */
.cal-wrap {
  display: grid; grid-template-columns: 1fr 1fr; gap: 24px;
  margin-top: 8px;
}
@media (max-width: 600px) { .cal-wrap { grid-template-columns: 1fr; } }
.cal-header {
  grid-column: 1 / -1;
  display: flex; align-items: center; justify-content: space-between;
  padding-bottom: 12px; border-bottom: 1px solid var(--line);
}
.cal-month {
  font-family: var(--display); font-size: 18px;
}
.cal-nav {
  width: 32px; height: 32px;
  display: flex; align-items: center; justify-content: center;
  border: 1px solid var(--line-2); color: var(--ink);
  font-size: 16px; transition: all .2s; cursor: none;
}
.cal-nav:hover:not(:disabled) { border-color: var(--accent); color: var(--accent); }
.cal-nav:disabled { opacity: 0.3; }
.cal-grid {
  display: grid; grid-template-columns: repeat(7, 1fr); gap: 4px;
}
.cal-dow {
  font-family: var(--mono); font-size: 10px;
  letter-spacing: .14em; color: var(--ink-faint);
  text-align: center; padding: 6px 0;
}
.cal-day {
  aspect-ratio: 1;
  display: flex; align-items: center; justify-content: center;
  font-family: var(--mono); font-size: 13px;
  border: 1px solid transparent;
  background: var(--bg);
  color: var(--ink);
  transition: all .2s; cursor: none;
}
.cal-day:not(:disabled):hover { border-color: var(--accent); color: var(--accent); }
.cal-day.is-past, .cal-day.is-weekend {
  color: var(--ink-faint); opacity: 0.4;
}
.cal-day.is-selected {
  background: var(--accent); color: #000; font-weight: 600;
  border-color: var(--accent);
  box-shadow: 0 0 16px var(--accent-glow);
}
.cal-day--empty { background: transparent; }

.cal-slots {
  border-left: 1px solid var(--line);
  padding-left: 24px;
  display: flex; flex-direction: column; gap: 12px;
  max-height: 320px; overflow-y: auto;
}
@media (max-width: 600px) {
  .cal-slots { border-left: 0; padding-left: 0; border-top: 1px solid var(--line); padding-top: 16px; }
}
.cal-slots__head {
  font-family: var(--mono); font-size: 11px;
  letter-spacing: .14em; color: var(--accent);
  text-transform: uppercase;
}
.cal-slots__grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 8px;
}
.cal-slot {
  padding: 10px;
  border: 1px solid var(--line-2);
  background: var(--bg);
  font-family: var(--mono); font-size: 13px;
  color: var(--ink);
  transition: all .2s; cursor: none;
}
.cal-slot:hover:not(:disabled) {
  border-color: var(--accent);
  color: var(--accent);
  background: color-mix(in oklab, var(--accent) 10%, transparent);
}
.cal-slot:disabled { opacity: 0.4; }
.cal-slot.is-booking {
  background: var(--accent); color: #000; border-color: var(--accent);
}
.cal-hint {
  color: var(--ink-dim); font-size: 12px; padding: 16px 0;
}
.cal-err {
  font-size: 11px; color: var(--danger);
  margin-top: 8px; padding: 8px;
  border: 1px solid var(--danger);
}

/* Slot confirmation panel */
.cal-confirm {
  display: flex; flex-direction: column; gap: 16px;
  padding: 18px;
  border: 1px solid var(--accent);
  background: color-mix(in oklab, var(--accent) 6%, var(--bg));
  animation: lmStepIn .25s ease;
}
.cal-confirm__head {
  font-family: var(--mono); font-size: 11px;
  letter-spacing: .14em; color: var(--accent);
  text-transform: uppercase;
}
.cal-confirm__time {
  font-family: var(--display); font-size: 18px;
  line-height: 1.4;
}
.cal-confirm__time strong {
  color: var(--accent); font-size: 28px;
  letter-spacing: -0.02em;
  display: inline-block; margin-top: 4px;
}
.cal-confirm__time small {
  font-family: var(--mono); font-size: 11px;
  color: var(--ink-dim); margin-left: 8px;
  letter-spacing: .12em;
}
.cal-confirm__buttons {
  display: flex; gap: 8px;
}
.cal-confirm__buttons .btn { flex: 1; justify-content: center; padding: 12px 14px; font-size: 12px; }

.lm-confirm {
  text-align: center; padding: 24px 0 12px;
}
.lm-confirm__icon {
  width: 72px; height: 72px;
  border-radius: 50%;
  background: var(--accent); color: #000;
  display: flex; align-items: center; justify-content: center;
  font-size: 36px; font-weight: 700;
  margin: 0 auto 24px;
  box-shadow: 0 0 32px var(--accent-glow);
  animation: confirmPop .4s cubic-bezier(.2,.9,.4,1.4);
}
@keyframes confirmPop {
  0% { transform: scale(0); }
  100% { transform: scale(1); }
}
.lm-confirm__time {
  font-family: var(--display); font-size: 22px;
  margin: 12px 0 16px;
}
.lm-confirm__time strong { color: var(--accent); }
.lm-confirm small { color: var(--ink-dim); font-family: var(--mono); font-size: 12px; }

/* ===== Tweaks panel ===== */
.tweaks-panel {
  position: fixed; bottom: 24px; right: 24px; z-index: 100;
  background: var(--bg-2); border: 1px solid var(--line-2);
  padding: 18px; min-width: 280px;
  font-family: var(--mono); font-size: 12px;
  display: none; flex-direction: column; gap: 14px;
  box-shadow: 0 30px 80px rgba(0,0,0,0.6);
}
.tweaks-panel.open { display: flex; }
.tweaks-panel__head { display: flex; justify-content: space-between; align-items: center; padding-bottom: 8px; border-bottom: 1px solid var(--line); }
.tweaks-panel__head .title { font-weight: 600; letter-spacing: .12em; font-size: 11px; color: var(--accent); }
.tweaks-row { display: flex; flex-direction: column; gap: 6px; }
.tweaks-row label { color: var(--ink-dim); font-size: 10px; letter-spacing: .12em; text-transform: uppercase; }
.tweaks-row .swatches { display: flex; gap: 8px; }
.swatch { width: 28px; height: 28px; border: 2px solid transparent; cursor: none; transition: transform .2s; }
.swatch:hover { transform: scale(1.1); }
.swatch.active { border-color: var(--ink); }
.tweaks-row select, .tweaks-row input[type=range] { background: var(--bg); color: var(--ink); border: 1px solid var(--line-2); padding: 6px 8px; font: inherit; cursor: none; }
.toggle-row { display: flex; gap: 6px; }
.toggle-row button { flex: 1; padding: 8px; border: 1px solid var(--line-2); transition: all .2s; }
.toggle-row button.active { background: var(--accent); color: #000; border-color: var(--accent); }

/* Tweaks toggle FAB */
.tweaks-fab {
  position: fixed; bottom: 24px; right: 24px; z-index: 99;
  width: 48px; height: 48px;
  background: var(--bg-2); border: 1px solid var(--accent); color: var(--accent);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--mono); font-size: 18px;
  transition: all .2s;
  cursor: none;
}
.tweaks-fab:hover { background: var(--accent); color: #000; box-shadow: 0 0 24px var(--accent-glow); }
.tweaks-fab.active { background: var(--accent); color: #000; }

/* utility */
.fade-in { opacity: 0; transform: translateY(20px); transition: opacity .8s, transform .8s; }
.fade-in.in-view { opacity: 1; transform: none; }

@media (max-width: 920px) {
  .cap-grid { grid-template-columns: 1fr; }
  .cap--lg, .cap--md, .cap--sm { grid-column: span 1; }
  .nav__links { display: none; }
  .scene-meter { display: none; }
  .hud-corner { font-size: 9px; }
}
