:root {
  --bg: #FAFAFA;
  --surface: #FFFFFF;
  --ink: #0A0A0A;
  --ink-2: #2E2E2E;
  --ink-3: #6B6B6B;
  --ink-4: #9C9C9C;
  --line: rgba(0, 0, 0, 0.09);
  --line-2: rgba(0, 0, 0, 0.05);
  --hover: rgba(0, 0, 0, 0.035);
  --accent: #0A0A0A;
  --accent-ink: #0A0A0A;
  --accent-wash: rgba(0, 0, 0, 0.05);
  --highlight: rgba(0, 0, 0, 0.08);
  --ok: oklch(0.62 0.09 155);
  --warn: oklch(0.70 0.12 70);
  --alert: oklch(0.58 0.14 25);
  --idle: oklch(0.68 0.01 250);
}

* { box-sizing: border-box; }
html, body {
  margin: 0; padding: 0;
  font-family: 'Inter', -apple-system, system-ui, sans-serif;
  font-feature-settings: 'ss01', 'cv11';
  background: var(--bg);
  color: var(--ink);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  line-height: 1.5;
}

.mono { font-family: 'JetBrains Mono', ui-monospace, monospace; }

a { color: inherit; text-decoration: none; }
button { font-family: inherit; cursor: pointer; border: 0; background: none; padding: 0; color: inherit; }
input, textarea { font-family: inherit; }

.dot { display: inline-block; width: 6px; height: 6px; border-radius: 50%; flex-shrink: 0; }
.dot-active { background: var(--ok); }
.dot-ending { background: var(--warn); }
.dot-moveout { background: var(--alert); }
.dot-vacant { background: var(--idle); }

/* ========== Nav ========== */
.nav {
  position: sticky; top: 0; z-index: 50;
  background: rgba(250, 250, 250, 0.85);
  backdrop-filter: saturate(140%) blur(10px);
  border-bottom: 1px solid var(--line-2);
}
.nav-inner {
  max-width: 1100px;
  margin: 0 auto;
  padding: 16px 32px;
  display: flex; align-items: center; gap: 28px;
}
.brand {
  display: flex; align-items: center; gap: 10px;
  font-weight: 600; font-size: 15px;
  letter-spacing: -0.01em;
}
.brand-mark {
  width: 22px; height: 22px;
  background: var(--ink);
  border-radius: 6px;
  position: relative;
  flex-shrink: 0;
}
.brand-mark::after {
  content: '';
  position: absolute; inset: 5px;
  border-left: 2px solid var(--bg);
  border-bottom: 2px solid var(--bg);
}
.nav-links {
  display: flex; gap: 22px;
  font-size: 13.5px;
  color: var(--ink-3);
}
.nav-links a { transition: color 120ms ease; }
.nav-links a:hover { color: var(--ink); }
.nav-spacer { flex: 1; }
.nav-cta {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 7px 14px;
  font-size: 13px;
  font-weight: 500;
  background: var(--ink);
  color: var(--bg);
  border-radius: 7px;
  letter-spacing: -0.005em;
  transition: background 120ms ease;
}
.nav-cta:hover { background: var(--ink-2); }

/* ========== Sections ========== */
section { padding: 0 32px; }
.wrap {
  max-width: 1100px;
  margin: 0 auto;
}

/* ========== Hero ========== */
.hero {
  padding-top: 80px;
  padding-bottom: 72px;
}
.eyebrow {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 5px 11px 5px 8px;
  border: 1px solid var(--line);
  background: var(--surface);
  border-radius: 100px;
  font-size: 12px;
  font-weight: 500;
  color: var(--ink-2);
  letter-spacing: -0.005em;
  margin-bottom: 28px;
}
.eyebrow .dot-pulse {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--accent);
  box-shadow: 0 0 0 0 var(--accent);
  animation: pulse 2s infinite;
}
@keyframes pulse {
  0% { box-shadow: 0 0 0 0 rgba(10, 10, 10, 0.4); }
  70% { box-shadow: 0 0 0 8px rgba(10, 10, 10, 0); }
  100% { box-shadow: 0 0 0 0 rgba(10, 10, 10, 0); }
}

h1.display {
  font-weight: 700;
  font-size: clamp(44px, 6.4vw, 76px);
  line-height: 1.04;
  letter-spacing: -0.04em;
  margin: 0 0 22px;
  max-width: 880px;
  text-wrap: balance;
}
h1.display em {
  font-style: normal;
  font-weight: 700;
  color: var(--ink);
  background-image: linear-gradient(transparent 68%, var(--highlight) 68%);
  padding: 0 0.06em;
}
.hero-sub {
  font-size: 18px;
  line-height: 1.5;
  color: var(--ink-2);
  max-width: 560px;
  letter-spacing: -0.01em;
  margin: 0 0 32px;
}

/* Email form */
.email-form {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 6px 6px 16px;
  border: 1px solid var(--line);
  background: var(--surface);
  border-radius: 100px;
  width: 100%;
  max-width: 460px;
  transition: border-color 150ms ease, box-shadow 150ms ease;
}
.email-form:focus-within {
  border-color: var(--ink-3);
  box-shadow: 0 0 0 4px rgba(20, 20, 20, 0.03);
}
.email-form input {
  flex: 1;
  border: 0;
  outline: 0;
  font-size: 14.5px;
  color: var(--ink);
  background: transparent;
  padding: 10px 0;
  letter-spacing: -0.005em;
  min-width: 0;
}
.email-form input::placeholder { color: var(--ink-4); }
.email-form button {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 9px 18px;
  font-size: 13.5px;
  font-weight: 500;
  background: var(--ink);
  color: var(--bg);
  border-radius: 100px;
  letter-spacing: -0.005em;
  transition: background 120ms ease, transform 120ms ease;
  white-space: nowrap;
}
.email-form button:hover { background: var(--ink-2); }
.email-form button:active { transform: scale(0.98); }
.email-form svg { width: 13px; height: 13px; stroke-width: 2; }

/* Standalone CTA button (waitlist link) */
.cta-button {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 14px 24px;
  font-size: 14.5px;
  font-weight: 500;
  background: var(--ink);
  color: var(--bg);
  border-radius: 100px;
  letter-spacing: -0.005em;
  transition: background 120ms ease, transform 120ms ease;
  white-space: nowrap;
}
.cta-button:hover { background: var(--ink-2); }
.cta-button:active { transform: scale(0.98); }
.cta-button svg { width: 14px; height: 14px; stroke-width: 2; }

.hero-meta {
  margin-top: 14px;
  display: flex; align-items: center; gap: 14px;
  font-size: 12.5px;
  color: var(--ink-3);
  flex-wrap: wrap;
}
.hero-meta .sep {
  width: 1px; height: 10px; background: var(--line);
}
.hero-meta .count-num {
  font-family: 'JetBrains Mono', ui-monospace, monospace;
  color: var(--ink);
  font-weight: 500;
}

.success-state {
  display: flex; align-items: center; gap: 10px;
  padding: 12px 18px;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 100px;
  max-width: 460px;
  font-size: 14px;
  color: var(--ink);
  letter-spacing: -0.005em;
}
.success-state .check {
  width: 22px; height: 22px;
  border-radius: 50%;
  background: var(--ok);
  color: white;
  display: inline-flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}

/* ========== Hero Product Preview ========== */
.hero-preview-wrap {
  margin-top: 64px;
  position: relative;
}
.preview-shell {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 14px;
  box-shadow: 0 30px 80px -30px rgba(20, 20, 20, 0.18), 0 2px 10px rgba(20,20,20,0.04);
  overflow: hidden;
  position: relative;
}
.preview-chrome {
  padding: 10px 14px;
  border-bottom: 1px solid var(--line);
  display: flex; align-items: center; gap: 10px;
}
.preview-chrome .traffic {
  display: flex; gap: 6px;
}
.preview-chrome .traffic span {
  width: 10px; height: 10px; border-radius: 50%;
  background: var(--line);
}
.preview-chrome .url {
  flex: 1;
  display: flex; justify-content: center;
  font-family: 'JetBrains Mono', ui-monospace, monospace;
  font-size: 11.5px;
  color: var(--ink-4);
}
.preview-body {
  display: grid;
  grid-template-columns: 170px 1fr;
  min-height: 420px;
}
.preview-sidebar {
  padding: 14px 10px;
  border-right: 1px solid var(--line);
  background: var(--bg);
  display: flex; flex-direction: column; gap: 1px;
}
.preview-sidebar .nav-item {
  display: flex; align-items: center; gap: 9px;
  padding: 6px 9px;
  border-radius: 6px;
  font-size: 12.5px;
  color: var(--ink-3);
}
.preview-sidebar .nav-item[data-active="true"] { color: var(--ink); background: var(--hover); font-weight: 500; }
.preview-sidebar .nav-item .ic {
  width: 12px; height: 12px;
  border: 1.3px solid currentColor;
  border-radius: 3px;
  opacity: 0.55;
}
.preview-main {
  padding: 22px 26px;
}
.preview-h {
  font-size: 18px;
  font-weight: 600;
  letter-spacing: -0.02em;
  margin-bottom: 3px;
}
.preview-sub {
  font-size: 12px; color: var(--ink-3);
  margin-bottom: 18px;
}
.preview-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
  margin-bottom: 10px;
}
.preview-card {
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 12px 14px;
  background: var(--surface);
  display: flex; flex-direction: column; gap: 8px;
}
.pc-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 8px; }
.pc-code { font-family: 'JetBrains Mono', ui-monospace, monospace; font-size: 10px; color: var(--ink-4); margin-bottom: 2px; }
.pc-name { font-size: 13px; font-weight: 600; letter-spacing: -0.01em; line-height: 1.25; }
.pc-pill {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 2px 7px 2px 6px;
  border-radius: 12px;
  font-size: 10px; font-weight: 500;
  background: var(--hover);
  color: var(--ink-2);
  white-space: nowrap;
}
.pc-tenant { font-size: 11.5px; color: var(--ink-2); padding-top: 8px; border-top: 1px solid var(--line-2); }
.pc-next { display: flex; justify-content: space-between; font-size: 11px; }
.pc-next .l { color: var(--ink-3); }
.pc-next .v { color: var(--ink); font-weight: 500; }
.pc-next .d { font-family: 'JetBrains Mono', ui-monospace, monospace; color: var(--ink-3); font-size: 10px; }
.pc-next .d.urgent { color: var(--alert); }
.pc-next .d.warn { color: var(--warn); }

/* ========== Callout / Problem ========== */
.problem {
  padding-top: 100px;
  padding-bottom: 40px;
}
.section-eyebrow {
  font-family: 'JetBrains Mono', ui-monospace, monospace;
  font-size: 11.5px;
  color: var(--ink-4);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  margin-bottom: 14px;
  font-weight: 500;
}
.section-eyebrow .num {
  color: var(--ink);
  margin-right: 10px;
}
h2.section-h {
  font-weight: 700;
  font-size: clamp(30px, 4vw, 44px);
  line-height: 1.1;
  letter-spacing: -0.03em;
  margin: 0 0 24px;
  max-width: 760px;
  text-wrap: balance;
}
h2.section-h em {
  font-style: normal;
  color: var(--ink);
  font-weight: 700;
  background-image: linear-gradient(transparent 68%, var(--highlight) 68%);
  padding: 0 0.06em;
}
.section-sub {
  font-size: 16px;
  line-height: 1.55;
  color: var(--ink-2);
  max-width: 620px;
  letter-spacing: -0.005em;
  margin: 0;
}

.chaos-card {
  margin-top: 40px;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: var(--surface);
  overflow: hidden;
  display: grid;
  grid-template-columns: 1fr 1fr;
}
.chaos-side {
  padding: 28px 32px;
  border-right: 1px solid var(--line);
}
.chaos-side:last-child { border-right: none; }
.chaos-label {
  font-family: 'JetBrains Mono', ui-monospace, monospace;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--ink-4);
  margin-bottom: 14px;
}
.chaos-label .tag {
  display: inline-block;
  padding: 2px 7px;
  border-radius: 4px;
  background: var(--hover);
  color: var(--ink-2);
  margin-right: 8px;
}
.chaos-item {
  display: flex; gap: 10px;
  padding: 10px 0;
  font-size: 13.5px;
  color: var(--ink-2);
  border-bottom: 1px solid var(--line-2);
  letter-spacing: -0.005em;
  line-height: 1.4;
}
.chaos-item:last-child { border: none; }
.chaos-item .src {
  font-family: 'JetBrains Mono', ui-monospace, monospace;
  font-size: 11px;
  color: var(--ink-4);
  min-width: 68px;
}
.chaos-item.missed { color: var(--ink-3); }
.chaos-item.missed .src { color: var(--alert); }
.chaos-item.missed .t { text-decoration: line-through; text-decoration-color: rgba(20,20,20,0.15); }

.calm-item {
  display: flex; align-items: center; gap: 12px;
  padding: 10px 0;
  font-size: 13.5px;
  color: var(--ink);
  border-bottom: 1px solid var(--line-2);
  letter-spacing: -0.005em;
}
.calm-item:last-child { border: none; }
.calm-item .date {
  font-family: 'JetBrains Mono', ui-monospace, monospace;
  font-size: 11.5px;
  color: var(--ink-3);
  min-width: 52px;
}
.calm-item .check {
  width: 14px; height: 14px;
  border: 1.5px solid var(--ink-4);
  border-radius: 3px;
  flex-shrink: 0;
}
.calm-item[data-done="true"] .check {
  background: var(--ink);
  border-color: var(--ink);
  position: relative;
}
.calm-item[data-done="true"] .check::after {
  content: '';
  position: absolute;
  left: 3px; top: 1px;
  width: 4px; height: 7px;
  border: solid white;
  border-width: 0 1.5px 1.5px 0;
  transform: rotate(45deg);
}
.calm-item[data-done="true"] .t { color: var(--ink-3); text-decoration: line-through; text-decoration-color: rgba(20,20,20,0.2); }

/* ========== How it works ========== */
.how {
  padding-top: 100px;
  padding-bottom: 60px;
}
.how-steps {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  margin-top: 44px;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.how-step {
  padding: 28px 24px 28px 0;
  border-right: 1px solid var(--line);
  display: flex; flex-direction: column; gap: 10px;
}
.how-step:last-child { border-right: none; }
.how-step:not(:first-child) { padding-left: 24px; }
.how-num {
  font-family: 'JetBrains Mono', ui-monospace, monospace;
  font-size: 12px;
  color: var(--ink-4);
  letter-spacing: 0.02em;
}
.how-title {
  font-size: 17px;
  font-weight: 600;
  letter-spacing: -0.015em;
  margin-top: 4px;
}
.how-desc {
  font-size: 13.5px;
  color: var(--ink-3);
  line-height: 1.5;
  letter-spacing: -0.005em;
}

/* ========== Features ========== */
.features {
  padding-top: 80px;
  padding-bottom: 80px;
}
.feature-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
  margin-top: 44px;
}
.feature {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 28px 28px 0;
  display: flex; flex-direction: column;
  overflow: hidden;
  min-height: 340px;
}
.feature.wide { grid-column: span 2; }
.feature-title {
  font-size: 20px;
  font-weight: 600;
  letter-spacing: -0.02em;
  margin: 0 0 8px;
}
.feature-desc {
  font-size: 14px;
  color: var(--ink-3);
  line-height: 1.5;
  letter-spacing: -0.005em;
  max-width: 520px;
  margin: 0 0 24px;
}
.feature-art {
  margin-top: auto;
  min-height: 180px;
  position: relative;
}

/* Feature 1 art — auto timeline */
.f-timeline {
  display: flex; flex-direction: column; gap: 0;
  border: 1px solid var(--line);
  border-radius: 10px 10px 0 0;
  overflow: hidden;
  margin-bottom: -1px;
}
.f-timeline .r {
  display: grid;
  grid-template-columns: 24px 1fr 80px;
  gap: 10px;
  padding: 10px 14px;
  border-bottom: 1px solid var(--line-2);
  font-size: 12.5px;
  align-items: center;
}
.f-timeline .r:last-child { border-bottom: 0; }
.f-timeline .check {
  width: 14px; height: 14px;
  border: 1.5px solid var(--ink-4);
  border-radius: 3px;
}
.f-timeline .r[data-done="true"] .check {
  background: var(--ink); border-color: var(--ink); position: relative;
}
.f-timeline .r[data-done="true"] .check::after {
  content: ''; position: absolute; left: 3px; top: 1px;
  width: 4px; height: 7px; border: solid white; border-width: 0 1.5px 1.5px 0;
  transform: rotate(45deg);
}
.f-timeline .d { font-family: 'JetBrains Mono', ui-monospace, monospace; font-size: 11px; color: var(--ink-3); text-align: right; }
.f-timeline .r[data-done="true"] .t { color: var(--ink-3); text-decoration: line-through; text-decoration-color: rgba(20,20,20,0.2); }

/* Feature 2 art — status pills */
.f-status {
  display: flex; flex-direction: column; gap: 8px;
}
.f-status .row {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 14px;
  border: 1px solid var(--line);
  border-radius: 10px;
  font-size: 13px;
  background: var(--surface);
}
.f-status .row .n { flex: 1; font-weight: 500; letter-spacing: -0.01em; }
.f-status .row .m { font-family: 'JetBrains Mono', ui-monospace, monospace; font-size: 11px; color: var(--ink-3); }

/* Feature 3 art — wide, summary bar */
.f-summary {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  border: 1px solid var(--line);
  border-radius: 10px 10px 0 0;
  overflow: hidden;
  margin-bottom: -1px;
}
.f-summary .cell {
  padding: 18px 20px;
  border-right: 1px solid var(--line);
}
.f-summary .cell:last-child { border: none; }
.f-summary .l { font-size: 11.5px; color: var(--ink-3); margin-bottom: 7px; display: flex; align-items: center; gap: 6px; font-weight: 500; }
.f-summary .v { font-size: 26px; font-weight: 600; letter-spacing: -0.02em; }
.f-summary .s { font-size: 11px; color: var(--ink-4); margin-top: 3px; font-family: 'JetBrains Mono', ui-monospace, monospace; }

/* ========== Roadmap ========== */
.roadmap {
  padding-top: 60px;
  padding-bottom: 80px;
}
.roadmap-list {
  margin-top: 40px;
  border-top: 1px solid var(--line);
}
.roadmap-item {
  display: grid;
  grid-template-columns: 100px 140px 1fr 110px;
  gap: 24px;
  padding: 22px 0;
  border-bottom: 1px solid var(--line);
  align-items: baseline;
}
.rm-phase {
  font-family: 'JetBrains Mono', ui-monospace, monospace;
  font-size: 11.5px;
  color: var(--ink-4);
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.rm-title { font-size: 15px; font-weight: 600; letter-spacing: -0.015em; }
.rm-desc { font-size: 13.5px; color: var(--ink-3); line-height: 1.5; letter-spacing: -0.005em; }
.rm-state {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 3px 10px;
  font-size: 11.5px;
  font-weight: 500;
  border-radius: 100px;
  justify-self: end;
  background: var(--hover);
  color: var(--ink-2);
}
.rm-state.now { background: var(--ink); color: var(--bg); }
.rm-state.now .dot-pulse {
  background: var(--bg);
  animation: pulse-inv 2s infinite;
}
@keyframes pulse-inv {
  0% { box-shadow: 0 0 0 0 rgba(255, 255, 255, 0.55); }
  70% { box-shadow: 0 0 0 8px rgba(255, 255, 255, 0); }
  100% { box-shadow: 0 0 0 0 rgba(255, 255, 255, 0); }
}

/* ========== CTA / Signup ========== */
.cta {
  padding-top: 40px;
  padding-bottom: 100px;
}
.cta-card {
  padding: 64px 48px;
  border: 1px solid var(--line);
  border-radius: 18px;
  background: var(--surface);
  text-align: center;
  position: relative;
  overflow: hidden;
}
.cta-card::before {
  content: '';
  position: absolute; inset: 0;
  background: radial-gradient(ellipse at top, var(--accent-wash), transparent 60%);
  pointer-events: none;
}
.cta-card > * { position: relative; }
.cta-card h2 {
  font-weight: 700;
  font-size: clamp(28px, 3.6vw, 40px);
  line-height: 1.12;
  letter-spacing: -0.03em;
  margin: 0 0 14px;
  text-wrap: balance;
}
.cta-card h2 em {
  font-style: normal;
  color: var(--ink);
  font-weight: 700;
  background-image: linear-gradient(transparent 68%, var(--highlight) 68%);
  padding: 0 0.06em;
}
.cta-card p {
  font-size: 15px;
  color: var(--ink-2);
  max-width: 440px;
  margin: 0 auto 28px;
  line-height: 1.5;
}
.cta-card .email-form { margin: 0 auto; }

/* ========== Footer ========== */
footer {
  border-top: 1px solid var(--line);
  padding: 28px 32px;
  margin-top: 40px;
}
.foot-inner {
  max-width: 1100px;
  margin: 0 auto;
  display: flex; align-items: center; gap: 20px;
  font-size: 12.5px;
  color: var(--ink-3);
  flex-wrap: wrap;
}
.foot-inner .spacer { flex: 1; }
.foot-inner a { transition: color 120ms ease; }
.foot-inner a:hover { color: var(--ink); }

/* ========== Guide / Getting Started ========== */
.guide-hero {
  padding-top: 72px;
  padding-bottom: 48px;
}
.guide-hero h1 {
  font-weight: 700;
  font-size: clamp(38px, 5vw, 60px);
  line-height: 1.06;
  letter-spacing: -0.035em;
  margin: 0 0 20px;
  max-width: 820px;
  text-wrap: balance;
}
.guide-hero h1 em {
  font-style: normal;
  font-weight: 700;
  background-image: linear-gradient(transparent 68%, var(--highlight) 68%);
  padding: 0 0.06em;
}
.guide-hero p.lede {
  font-size: 17.5px;
  line-height: 1.55;
  color: var(--ink-2);
  max-width: 620px;
  letter-spacing: -0.005em;
  margin: 0 0 28px;
}
.guide-hero .guide-cta-row {
  display: flex; align-items: center; gap: 14px;
  flex-wrap: wrap;
}

.guide-toc {
  margin-top: 40px;
  padding: 22px 26px;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: var(--surface);
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 18px;
}
.guide-toc a {
  display: flex; flex-direction: column; gap: 4px;
  font-size: 13.5px;
  color: var(--ink);
  letter-spacing: -0.005em;
  transition: opacity 120ms ease;
}
.guide-toc a:hover { opacity: 0.65; }
.guide-toc .toc-num {
  font-family: 'JetBrains Mono', ui-monospace, monospace;
  font-size: 10.5px;
  color: var(--ink-4);
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

/* Step sections */
.guide-step {
  padding: 70px 32px;
  border-top: 1px solid var(--line-2);
}
.guide-step:first-of-type { border-top: 1px solid var(--line); }
.guide-step .wrap { display: grid; grid-template-columns: 1fr 1fr; gap: 56px; align-items: center; }
.guide-step.reverse .wrap > .step-copy { order: 2; }
.guide-step .step-num {
  font-family: 'JetBrains Mono', ui-monospace, monospace;
  font-size: 12px;
  color: var(--ink-4);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  margin-bottom: 12px;
  font-weight: 500;
}
.guide-step .step-num .num {
  color: var(--ink);
  margin-right: 10px;
}
.guide-step h2 {
  font-weight: 700;
  font-size: clamp(26px, 3vw, 34px);
  line-height: 1.12;
  letter-spacing: -0.025em;
  margin: 0 0 16px;
  text-wrap: balance;
}
.guide-step h2 em {
  font-style: normal;
  font-weight: 700;
  background-image: linear-gradient(transparent 68%, var(--highlight) 68%);
  padding: 0 0.06em;
}
.guide-step p {
  font-size: 15px;
  line-height: 1.6;
  color: var(--ink-2);
  letter-spacing: -0.005em;
  margin: 0 0 14px;
}
.guide-step ul.step-points {
  list-style: none;
  padding: 0;
  margin: 18px 0 0;
  display: flex; flex-direction: column; gap: 10px;
}
.guide-step ul.step-points li {
  display: flex; gap: 10px;
  font-size: 14px;
  color: var(--ink-2);
  letter-spacing: -0.005em;
}
.guide-step ul.step-points li::before {
  content: '';
  display: block;
  width: 4px; height: 4px; border-radius: 50%;
  background: var(--ink-3);
  margin-top: 9px;
  flex-shrink: 0;
}

/* Inline callouts inside steps */
.guide-callout {
  margin-top: 20px;
  padding: 14px 18px;
  border: 1px solid var(--line);
  border-left: 3px solid var(--ink);
  background: var(--surface);
  border-radius: 8px;
  font-size: 13.5px;
  color: var(--ink-2);
  line-height: 1.55;
  letter-spacing: -0.005em;
}
.guide-callout strong {
  display: block;
  font-weight: 600;
  color: var(--ink);
  margin-bottom: 4px;
  font-size: 12.5px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

/* Form-like mockup (used for unit / lease / event forms) */
.form-mockup {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 14px;
  box-shadow: 0 24px 60px -28px rgba(20, 20, 20, 0.16), 0 2px 8px rgba(20,20,20,0.03);
  overflow: hidden;
}
.form-mockup-chrome {
  padding: 10px 14px;
  border-bottom: 1px solid var(--line);
  display: flex; align-items: center; gap: 10px;
}
.form-mockup-chrome .traffic { display: flex; gap: 6px; }
.form-mockup-chrome .traffic span {
  width: 10px; height: 10px; border-radius: 50%;
  background: var(--line);
}
.form-mockup-chrome .url {
  flex: 1;
  display: flex; justify-content: center;
  font-family: 'JetBrains Mono', ui-monospace, monospace;
  font-size: 11.5px;
  color: var(--ink-4);
}
.form-mockup-body {
  padding: 26px 28px;
  display: flex; flex-direction: column; gap: 18px;
}
.form-mockup-title {
  font-size: 16px;
  font-weight: 600;
  letter-spacing: -0.015em;
  margin-bottom: 2px;
}
.form-mockup .mk-field {
  display: flex; flex-direction: column; gap: 6px;
}
.form-mockup .mk-field-row {
  display: grid; grid-template-columns: 1fr 1fr; gap: 12px;
}
.form-mockup .mk-label {
  font-size: 12px;
  font-weight: 500;
  color: var(--ink-2);
  letter-spacing: -0.005em;
}
.form-mockup .mk-input {
  padding: 9px 12px;
  border: 1px solid var(--line);
  border-radius: 7px;
  background: var(--bg);
  font-size: 13px;
  color: var(--ink-2);
  letter-spacing: -0.005em;
}
.form-mockup .mk-input.placeholder { color: var(--ink-4); }
.form-mockup .mk-input.filled { color: var(--ink); background: var(--surface); }
.form-mockup .mk-hint {
  font-size: 11.5px;
  color: var(--ink-4);
}
.form-mockup .mk-chips {
  display: flex; flex-wrap: wrap; gap: 6px;
  margin-top: 4px;
}
.form-mockup .mk-chip {
  padding: 4px 10px;
  border: 1px solid var(--line);
  border-radius: 100px;
  font-size: 11.5px;
  color: var(--ink-2);
  background: var(--surface);
  letter-spacing: -0.005em;
}
.form-mockup .mk-chip.active {
  background: var(--ink);
  color: var(--bg);
  border-color: var(--ink);
}
.form-mockup .mk-actions {
  display: flex; gap: 10px; justify-content: flex-end;
  margin-top: 4px;
}
.form-mockup .mk-btn {
  padding: 8px 14px;
  border-radius: 7px;
  font-size: 12.5px;
  font-weight: 500;
  background: var(--ink);
  color: var(--bg);
  letter-spacing: -0.005em;
}
.form-mockup .mk-btn.ghost {
  background: transparent;
  color: var(--ink-3);
}

/* Dashboard upcoming list mockup (Step 4) */
.upcoming-mockup {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 14px;
  overflow: hidden;
  box-shadow: 0 24px 60px -28px rgba(20, 20, 20, 0.16), 0 2px 8px rgba(20,20,20,0.03);
}
.upcoming-mockup .um-chrome {
  padding: 10px 14px;
  border-bottom: 1px solid var(--line);
  display: flex; align-items: center; gap: 10px;
}
.upcoming-mockup .um-chrome .traffic { display: flex; gap: 6px; }
.upcoming-mockup .um-chrome .traffic span {
  width: 10px; height: 10px; border-radius: 50%;
  background: var(--line);
}
.upcoming-mockup .um-chrome .url {
  flex: 1;
  display: flex; justify-content: center;
  font-family: 'JetBrains Mono', ui-monospace, monospace;
  font-size: 11.5px;
  color: var(--ink-4);
}
.upcoming-mockup .um-body { padding: 22px 26px; }
.upcoming-mockup .um-title {
  font-size: 14px;
  font-weight: 600;
  letter-spacing: -0.015em;
  margin-bottom: 14px;
}
.upcoming-mockup .um-row {
  display: grid;
  grid-template-columns: 22px 80px 1fr;
  gap: 12px;
  padding: 10px 0;
  border-top: 1px solid var(--line-2);
  align-items: center;
  font-size: 12.5px;
}
.upcoming-mockup .um-row:first-of-type { border-top: 0; }
.upcoming-mockup .um-check {
  width: 16px; height: 16px;
  border: 1.5px solid var(--ink-4);
  border-radius: 4px;
}
.upcoming-mockup .um-row[data-done="true"] .um-check {
  background: var(--ink);
  border-color: var(--ink);
  position: relative;
}
.upcoming-mockup .um-row[data-done="true"] .um-check::after {
  content: '';
  position: absolute;
  left: 3px; top: 1px;
  width: 4px; height: 8px;
  border: solid white;
  border-width: 0 1.5px 1.5px 0;
  transform: rotate(45deg);
}
.upcoming-mockup .um-date {
  font-family: 'JetBrains Mono', ui-monospace, monospace;
  font-size: 11px;
  color: var(--ink-3);
}
.upcoming-mockup .um-kind { color: var(--ink); font-weight: 500; letter-spacing: -0.005em; }
.upcoming-mockup .um-where { color: var(--ink-3); font-size: 11.5px; margin-top: 2px; letter-spacing: -0.005em; }
.upcoming-mockup .um-row[data-done="true"] .um-kind {
  color: var(--ink-3);
  text-decoration: line-through;
  text-decoration-color: rgba(20,20,20,0.2);
}

/* Dashboard preview (read-the-dashboard section) */
.dash-section {
  padding-top: 100px;
  padding-bottom: 60px;
}
.dash-section h2 {
  font-weight: 700;
  font-size: clamp(28px, 3.6vw, 38px);
  line-height: 1.1;
  letter-spacing: -0.03em;
  margin: 0 0 14px;
  text-wrap: balance;
}
.dash-section h2 em {
  font-style: normal;
  font-weight: 700;
  background-image: linear-gradient(transparent 68%, var(--highlight) 68%);
  padding: 0 0.06em;
}
.dash-section .section-sub { margin-bottom: 36px; }
.metric-legend {
  margin-top: 28px;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 14px 32px;
}
.metric-legend .item {
  display: flex; gap: 12px;
  padding: 14px 16px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: var(--surface);
}
.metric-legend .item .dot { margin-top: 7px; }
.metric-legend .item .name {
  font-size: 13.5px;
  font-weight: 600;
  letter-spacing: -0.01em;
}
.metric-legend .item .desc {
  font-size: 13px;
  color: var(--ink-3);
  line-height: 1.5;
  letter-spacing: -0.005em;
  margin-top: 3px;
}

/* Tips section */
.tips-section {
  padding-top: 40px;
  padding-bottom: 80px;
}
.tips-grid {
  margin-top: 36px;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
}
.tip-card {
  padding: 22px 24px;
  border: 1px solid var(--line);
  background: var(--surface);
  border-radius: 12px;
}
.tip-card .tip-tag {
  display: inline-block;
  font-family: 'JetBrains Mono', ui-monospace, monospace;
  font-size: 10.5px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--ink-4);
  margin-bottom: 10px;
  font-weight: 500;
}
.tip-card h3 {
  font-size: 15px;
  font-weight: 600;
  letter-spacing: -0.015em;
  margin: 0 0 8px;
}
.tip-card p {
  font-size: 13.5px;
  color: var(--ink-3);
  line-height: 1.55;
  letter-spacing: -0.005em;
  margin: 0;
}

/* FAQ */
.faq-section {
  padding-top: 60px;
  padding-bottom: 80px;
}
.faq-list {
  margin-top: 36px;
  border-top: 1px solid var(--line);
}
.faq-item {
  padding: 22px 0;
  border-bottom: 1px solid var(--line);
}
.faq-item h3 {
  font-size: 16px;
  font-weight: 600;
  letter-spacing: -0.015em;
  margin: 0 0 8px;
}
.faq-item p {
  font-size: 14px;
  color: var(--ink-3);
  line-height: 1.6;
  letter-spacing: -0.005em;
  margin: 0;
  max-width: 720px;
}

/* ========== Responsive ========== */
@media (max-width: 900px) {
  .nav-links { display: none; }
  .preview-body { grid-template-columns: 1fr; }
  .preview-sidebar { display: none; }
  .preview-grid { grid-template-columns: 1fr; }
  .chaos-card { grid-template-columns: 1fr; }
  .chaos-side { border-right: none; border-bottom: 1px solid var(--line); }
  .chaos-side:last-child { border-bottom: none; }
  .how-steps { grid-template-columns: 1fr; }
  .how-step { border-right: none; border-bottom: 1px solid var(--line); padding: 24px 0 !important; }
  .how-step:last-child { border-bottom: none; }
  .feature-grid { grid-template-columns: 1fr; }
  .feature.wide { grid-column: span 1; }
  .f-summary { grid-template-columns: repeat(2, 1fr); }
  .f-summary .cell:nth-child(2) { border-right: none; }
  .roadmap-item { grid-template-columns: 1fr; gap: 6px; }
  .rm-state { justify-self: start; }
  .hero { padding-top: 56px; padding-bottom: 48px; }
  h1.display { font-size: 42px; }
  .cta-card { padding: 44px 24px; }

  /* Guide responsive */
  .guide-toc { grid-template-columns: repeat(2, 1fr); }
  .guide-step { padding: 48px 32px; }
  .guide-step .wrap { grid-template-columns: 1fr; gap: 32px; }
  .guide-step.reverse .wrap > .step-copy { order: 0; }
  .tips-grid { grid-template-columns: 1fr; }
  .metric-legend { grid-template-columns: 1fr; }
  .form-mockup .mk-field-row { grid-template-columns: 1fr; }
}
