/* webtm.dev marketing landing — dark, terminal-native.
   Built entirely on the webterminal design tokens (--wt-*, Catppuccin Mocha,
   JetBrains Mono + Space Grotesk). Vendored via `flux assets sync webterminal`. */

* { box-sizing: border-box; margin: 0; padding: 0; }

:root { color-scheme: dark; }

html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }

body {
  font-family: var(--wt-font-mono);
  font-size: var(--wt-type-body);
  line-height: var(--wt-leading-normal);
  color: var(--wt-color-text);
  background: var(--wt-color-bg);
  background-image:
    radial-gradient(60rem 40rem at 78% -8%, rgba(137,180,250,0.10), transparent 60%),
    radial-gradient(50rem 36rem at 8% 6%, rgba(203,166,247,0.08), transparent 55%);
  -webkit-font-smoothing: antialiased;
  overflow-x: clip;
}

h1, h2, h3 { font-family: var(--wt-font-display); font-weight: var(--wt-weight-bold); line-height: var(--wt-leading-tight); }
a { color: var(--wt-color-accent); text-decoration: none; }
code { font-family: var(--wt-font-mono); }
.wrap { max-width: 1120px; margin: 0 auto; padding: 0 24px; }
.grad {
  background: linear-gradient(100deg, var(--wt-color-accent), var(--wt-color-accent-2) 60%, var(--wt-color-accent-alt));
  -webkit-background-clip: text; background-clip: text; color: transparent;
}
.kicker {
  display: inline-block; font-size: var(--wt-type-caption); text-transform: uppercase;
  letter-spacing: var(--wt-tracking-wide); color: var(--wt-color-accent-2);
  font-family: var(--wt-font-display); margin-bottom: 14px;
}

/* ---------- buttons ---------- */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  font-family: var(--wt-font-mono); font-weight: var(--wt-weight-medium); font-size: var(--wt-type-small);
  padding: 0.65em 1.2em; border-radius: var(--wt-radius-md); border: 1px solid transparent;
  background: var(--wt-color-accent); color: var(--wt-color-bg); cursor: pointer; white-space: nowrap;
  transition: background var(--wt-duration-fast) var(--wt-ease-out), transform var(--wt-duration-fast) var(--wt-ease-out);
}
.btn:hover { background: var(--wt-color-accent-hover); transform: translateY(-1px); }
.btn-sm { padding: 0.5em 0.95em; }
.btn-lg { font-size: var(--wt-type-body); padding: 0.8em 1.5em; }
.btn-ghost { background: transparent; color: var(--wt-color-text); border-color: var(--wt-color-surface-hover); }
.btn-ghost:hover { background: var(--wt-color-surface); transform: translateY(-1px); }

/* ---------- nav ---------- */
.nav {
  position: sticky; top: 0; z-index: 50;
  background: rgba(24,24,37,0.78); backdrop-filter: blur(14px);
  border-bottom: 1px solid var(--wt-color-surface);
}
.nav-inner { display: flex; align-items: center; gap: 24px; height: 60px; }
.brand { font-family: var(--wt-font-display); font-weight: var(--wt-weight-bold); font-size: 1.15rem; color: var(--wt-color-text); display: inline-flex; align-items: center; gap: 8px; }
.brand-mark { color: var(--wt-color-accent-2); font-family: var(--wt-font-mono); }
.nav-links { margin-left: auto; display: flex; align-items: center; gap: 22px; }
.nav-links a { color: var(--wt-color-text-soft); font-size: var(--wt-type-small); }
.nav-links a:hover { color: var(--wt-color-text); }
.nav-links a.btn { color: var(--wt-color-bg); }

/* ---------- hero ---------- */
.hero { padding: 76px 0 40px; }
.hero-inner { display: grid; grid-template-columns: 1.02fr 0.98fr; gap: 48px; align-items: center; }
.eyebrow {
  display: inline-block; font-size: var(--wt-type-caption); color: var(--wt-color-text-soft);
  background: var(--wt-color-panel); border: 1px solid var(--wt-color-surface);
  padding: 6px 13px; border-radius: var(--wt-radius-xl); margin-bottom: 22px; letter-spacing: var(--wt-tracking-wide);
}
.hero h1 { font-size: clamp(2.1rem, 4.6vw, 3.2rem); letter-spacing: var(--wt-tracking-tight); margin-bottom: 18px; }
.hero .lead { font-size: 1.05rem; color: var(--wt-color-text-soft); max-width: 560px; margin-bottom: 26px; }
.hero .lead strong { color: var(--wt-color-text); font-weight: var(--wt-weight-bold); }

.install {
  display: flex; align-items: center; gap: 10px; background: var(--wt-color-bg-deep);
  border: 1px solid var(--wt-color-surface); border-radius: var(--wt-radius-md);
  padding: 12px 12px 12px 16px; max-width: 540px; margin-bottom: 22px;
}
.install code { font-size: var(--wt-type-small); color: var(--wt-color-text); overflow-x: auto; white-space: nowrap; }
.install .muted { color: var(--wt-color-text-faint); }
.copy-btn {
  margin-left: auto; flex-shrink: 0; font-family: var(--wt-font-mono); font-size: var(--wt-type-caption);
  color: var(--wt-color-text-soft); background: var(--wt-color-surface); border: 0;
  border-radius: var(--wt-radius-sm); padding: 5px 10px; cursor: pointer; transition: color var(--wt-duration-fast) var(--wt-ease-out);
}
.copy-btn:hover { color: var(--wt-color-accent-2); }
.cta-row { display: flex; gap: 12px; flex-wrap: wrap; }
.cta-row.center { justify-content: center; margin-top: 36px; }
.hero-note { margin-top: 18px; font-size: var(--wt-type-small); color: var(--wt-color-text-faint); }

/* ---------- hero product window mockup ---------- */
.hero-shot { perspective: 1400px; }
.appwin {
  background: var(--wt-color-bg-deep); border: 1px solid var(--wt-color-surface);
  border-radius: var(--wt-radius-lg); overflow: hidden;
  box-shadow: var(--wt-shadow-lg), 0 40px 80px -40px rgba(137,180,250,0.40);
  transform: perspective(1400px) rotateY(-6deg) rotateX(2deg);
  transition: transform var(--wt-duration-slow) var(--wt-ease-out);
}
.appwin:hover { transform: perspective(1400px) rotateY(-2deg) rotateX(1deg); }
.win-bar { display: flex; align-items: center; gap: 7px; padding: 11px 14px; background: var(--wt-color-panel); border-bottom: 1px solid var(--wt-color-surface); }
.win-title { margin-left: 8px; font-size: var(--wt-type-caption); color: var(--wt-color-text-faint); }
.win-body { display: grid; grid-template-columns: 150px minmax(0, 1fr); min-height: 248px; }
.win-side { border-right: 1px solid var(--wt-color-surface); padding: 12px 10px; display: flex; flex-direction: column; gap: 4px; background: rgba(17,17,27,0.6); }
.side-sess { font-size: var(--wt-type-caption); color: var(--wt-color-text-soft); background: var(--wt-color-surface); border-radius: var(--wt-radius-sm); padding: 6px 9px; margin-bottom: 6px; }
.side-nav { display: flex; flex-direction: column; gap: 2px; }
.side-item { font-size: var(--wt-type-caption); color: var(--wt-color-text-soft); padding: 6px 9px; border-radius: var(--wt-radius-sm); display: flex; align-items: center; gap: 7px; }
.side-item i { font-style: normal; }
.side-item.on { color: var(--wt-color-accent-2); background: rgba(148,226,213,0.08); }
.side-foot { margin-top: auto; font-size: var(--wt-type-caption); color: var(--wt-color-text-faint); padding: 6px 9px; }
.win-main { padding: 4px 0; min-width: 0; overflow: hidden; }

/* terminal mock body (shared) */
.term-body { padding: 18px; font-size: var(--wt-type-small); line-height: 1.7; color: var(--wt-color-text-soft); white-space: pre-wrap; word-break: break-word; }
.c-mut { color: var(--wt-color-text-faint); }
.c-ok  { color: var(--wt-color-success); }
.c-acc { color: var(--wt-color-accent); }
.c-acc2{ color: var(--wt-color-accent-2); }
.c-alt { color: var(--wt-color-accent-alt); }
.cursor { color: var(--wt-color-accent-2); animation: blink 1.1s steps(1) infinite; }
@keyframes blink { 50% { opacity: 0; } }

/* ---------- capability ticker ---------- */
.ticker {
  margin-top: 44px; display: flex; flex-wrap: wrap; gap: 10px; justify-content: center;
  border-top: 1px solid var(--wt-color-surface); padding-top: 28px;
}
.ticker span {
  font-size: var(--wt-type-caption); color: var(--wt-color-text-soft); letter-spacing: var(--wt-tracking-wide);
  background: var(--wt-color-panel); border: 1px solid var(--wt-color-surface);
  padding: 7px 14px; border-radius: var(--wt-radius-xl); text-transform: uppercase;
}

/* ---------- sections ---------- */
section { padding: 64px 0; }
.section-head { max-width: 680px; margin: 0 auto 44px; text-align: center; }
.section-head h2 { font-size: clamp(1.65rem, 3vw, 2.3rem); margin-bottom: 12px; }
.section-head p { color: var(--wt-color-text-soft); font-size: 1.02rem; }
.section-head code { color: var(--wt-color-accent-2); background: var(--wt-color-bg-deep); padding: 1px 6px; border-radius: var(--wt-radius-sm); font-size: 0.92em; }
.grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.grid-4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; }

/* pillars */
.pillars { padding-top: 8px; }
.pillar { background: var(--wt-color-panel); border: 1px solid var(--wt-color-surface); border-radius: var(--wt-radius-lg); padding: 24px; transition: transform var(--wt-duration-base) var(--wt-ease-out), border-color var(--wt-duration-base) var(--wt-ease-out); }
.pillar:hover { transform: translateY(-4px); border-color: var(--wt-color-accent); }
.p-ico { font-size: 1.5rem; margin-bottom: 12px; }
.pillar h3 { font-size: var(--wt-type-h3); color: var(--wt-color-text); margin-bottom: 8px; }
.pillar p { color: var(--wt-color-text-soft); font-size: var(--wt-type-small); }
.pillar code, .card code, .step code, .diag-card code, .mobile code { color: var(--wt-color-accent-2); background: var(--wt-color-bg-deep); padding: 1px 5px; border-radius: var(--wt-radius-sm); font-size: 0.92em; }

/* ---------- diagnostics suite ---------- */
.diag { background: linear-gradient(180deg, transparent, rgba(203,166,247,0.04) 40%, transparent); }
.diag-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 18px; }
.diag-card { background: var(--wt-color-panel); border: 1px solid var(--wt-color-surface); border-radius: var(--wt-radius-lg); padding: 22px; transition: border-color var(--wt-duration-base) var(--wt-ease-out); }
.diag-card:hover { border-color: var(--wt-color-accent-2); }
.diag-card header { display: flex; align-items: center; gap: 10px; margin-bottom: 8px; flex-wrap: wrap; }
.diag-card h3 { font-size: var(--wt-type-h3); color: var(--wt-color-text); }
.diag-card > p { color: var(--wt-color-text-soft); font-size: var(--wt-type-small); margin-bottom: 16px; }
.tag { font-family: var(--wt-font-display); text-transform: uppercase; font-size: 0.62rem; letter-spacing: var(--wt-tracking-wide); padding: 2px 7px; border-radius: var(--wt-radius-sm); white-space: nowrap; }
.tag.pro { color: var(--wt-color-accent); border: 1px solid var(--wt-color-accent); }
.tag.ultra { color: var(--wt-color-accent-alt); border: 1px solid var(--wt-color-accent-alt); }
.tag.t1 { color: var(--wt-color-accent); border: 1px solid var(--wt-color-accent); }
.tag.t2 { color: var(--wt-color-accent-2); border: 1px solid var(--wt-color-accent-2); }
.tag.t3 { color: var(--wt-color-warning); border: 1px solid var(--wt-color-warning); }

/* mock panels */
.mock { background: var(--wt-color-bg-deep); border: 1px solid var(--wt-color-surface); border-radius: var(--wt-radius-md); padding: 12px; font-size: var(--wt-type-caption); overflow: hidden; }
.mock .hex { font-variant-ligatures: none; letter-spacing: 0.02em; }

/* CAN monitor */
.mock-can .mc-head, .mock-can .mc-row { display: grid; grid-template-columns: 1.2fr 0.7fr 0.4fr 2fr; gap: 8px; padding: 4px 2px; align-items: center; }
.mock-can .mc-head { color: var(--wt-color-text-faint); border-bottom: 1px solid var(--wt-color-surface); margin-bottom: 4px; }
.mock-can .mc-row { color: var(--wt-color-text-soft); }
.mock-can .mc-row .hl { color: var(--wt-color-accent); }
.mock-can .mc-row .hex { color: var(--wt-color-text); }
.mock-can .mc-row.dim { color: var(--wt-color-text-faint); }
.mock-can .mc-row.dim .hl { color: var(--wt-color-text-faint); }
.mock-can .mc-row.dim .hex { color: var(--wt-color-text-faint); }
.mock-can .mc-row:last-child { animation: rowin 2.6s var(--wt-ease-out) infinite; }
@keyframes rowin { 0%,70% { opacity: 0.35; } 80%,100% { opacity: 1; } }

/* UDS log */
.mock-uds .mu-line { display: flex; align-items: baseline; gap: 12px; padding: 5px 2px; }
.mock-uds .tx { color: var(--wt-color-accent); min-width: 96px; }
.mock-uds .rx { color: var(--wt-color-accent-2); min-width: 96px; }
.mock-uds .lbl { color: var(--wt-color-text-soft); }

/* XCP DAQ */
.mock-xcp .mx-row { display: grid; grid-template-columns: 1.4fr 0.6fr 1.2fr; gap: 10px; align-items: center; padding: 6px 2px; }
.mock-xcp .mx-name { color: var(--wt-color-text-soft); }
.mock-xcp .mx-val { color: var(--wt-color-warning); text-align: right; font-weight: var(--wt-weight-bold); }
.spark { display: inline-flex; align-items: flex-end; gap: 2px; height: 18px; }
.spark i { width: 4px; background: var(--wt-color-accent-2); border-radius: 1px; opacity: 0.8; }

/* Embed channels */
.mock-embed .me-row { display: flex; align-items: center; gap: 10px; padding: 5px 2px; color: var(--wt-color-text-soft); }
.mock-embed .ch { font-family: var(--wt-font-display); font-size: 0.6rem; padding: 2px 7px; border-radius: var(--wt-radius-sm); text-transform: uppercase; }
.mock-embed .ch0 { color: var(--wt-color-accent); border: 1px solid var(--wt-color-accent); }
.mock-embed .ch1 { color: var(--wt-color-accent-2); border: 1px solid var(--wt-color-accent-2); }
.mock-embed .ch2 { color: var(--wt-color-warning); border: 1px solid var(--wt-color-warning); }

/* transport URI block */
.uri-block { margin-top: 24px; display: grid; grid-template-columns: 0.7fr 1.3fr; gap: 24px; align-items: center; background: var(--wt-color-panel); border: 1px solid var(--wt-color-surface); border-radius: var(--wt-radius-lg); padding: 28px; }
.uri-head .kicker { margin-bottom: 8px; }
.uri-head p { color: var(--wt-color-text-soft); font-size: var(--wt-type-small); }
.uri-head code { color: var(--wt-color-accent-2); }
.uri-pre { background: var(--wt-color-bg-deep); border: 1px solid var(--wt-color-surface); border-radius: var(--wt-radius-md); padding: 16px 18px; font-size: var(--wt-type-caption); line-height: 1.85; color: var(--wt-color-text); overflow-x: auto; }

/* ---------- feature cards ---------- */
.cards .card { background: var(--wt-color-panel); border: 1px solid var(--wt-color-surface); border-radius: var(--wt-radius-lg); padding: 24px; transition: transform var(--wt-duration-base) var(--wt-ease-out), border-color var(--wt-duration-base) var(--wt-ease-out); }
.cards .card:hover { transform: translateY(-4px); border-color: var(--wt-color-accent); }
.card h3 { font-size: var(--wt-type-h3); color: var(--wt-color-text); margin-bottom: 8px; display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.card p { color: var(--wt-color-text-soft); font-size: var(--wt-type-small); }

/* ---------- AI workflow ---------- */
.flow { display: flex; align-items: stretch; gap: 10px; flex-wrap: wrap; justify-content: center; }
.flow-step { flex: 1 1 180px; min-width: 0; max-width: 230px; background: var(--wt-color-panel); border: 1px solid var(--wt-color-surface); border-radius: var(--wt-radius-lg); padding: 22px; }
.flow-step .fn { display: inline-grid; place-items: center; width: 28px; height: 28px; border-radius: 999px; background: var(--wt-color-bg-deep); border: 1px solid var(--wt-color-accent-alt); color: var(--wt-color-accent-alt); font-family: var(--wt-font-display); font-weight: var(--wt-weight-bold); margin-bottom: 12px; }
.flow-step h3 { font-size: var(--wt-type-h3); color: var(--wt-color-text); margin-bottom: 8px; }
.flow-step p { color: var(--wt-color-text-soft); font-size: var(--wt-type-small); }
.flow-arrow { flex: 0 0 auto; display: flex; align-items: center; color: var(--wt-color-text-faint); font-size: 1.2rem; }

/* ---------- compare table ---------- */
.table-wrap { overflow-x: auto; border: 1px solid var(--wt-color-surface); border-radius: var(--wt-radius-lg); }
.cmp { width: 100%; border-collapse: collapse; min-width: 560px; }
.cmp th, .cmp td { padding: 13px 16px; text-align: center; border-bottom: 1px solid var(--wt-color-surface); font-size: var(--wt-type-small); }
.cmp thead th { font-family: var(--wt-font-display); color: var(--wt-color-text-soft); background: var(--wt-color-panel); }
.cmp thead th small { font-weight: var(--wt-weight-regular); color: var(--wt-color-text-faint); font-family: var(--wt-font-mono); }
.cmp tbody td:first-child, .cmp thead th:first-child { text-align: left; color: var(--wt-color-text); }
.cmp td.no { color: var(--wt-color-text-faint); }
.cmp .me { color: var(--wt-color-accent-2); font-weight: var(--wt-weight-bold); background: rgba(148,226,213,0.06); }
.cmp tbody tr:last-child td { border-bottom: 0; }

/* ---------- mobile / iPad ---------- */
.mobile-inner { display: grid; grid-template-columns: 1.1fr 0.9fr; gap: 48px; align-items: center; }
.mobile-copy h2 { font-size: clamp(1.5rem, 3vw, 2.1rem); color: var(--wt-color-text); margin-bottom: 14px; }
.mobile-copy > p { color: var(--wt-color-text-soft); font-size: 1rem; margin-bottom: 22px; }
.phone { display: flex; justify-content: center; }
.phone-screen {
  width: 280px; background: var(--wt-color-bg-deep); border: 1px solid var(--wt-color-surface);
  border-radius: 26px; padding: 14px 12px 16px; box-shadow: var(--wt-shadow-lg), inset 0 0 0 6px rgba(49,50,68,0.4);
}
.ph-bar { display: flex; align-items: center; gap: 8px; font-family: var(--wt-font-display); font-weight: var(--wt-weight-bold); color: var(--wt-color-text); padding: 6px 6px 12px; border-bottom: 1px solid var(--wt-color-surface); }
.ph-bar .ph-x { margin-left: auto; color: var(--wt-color-text-faint); font-weight: var(--wt-weight-regular); }
.ph-sect { font-size: 0.6rem; letter-spacing: var(--wt-tracking-wide); color: var(--wt-color-text-faint); text-transform: uppercase; margin: 12px 6px 4px; }
.ph-item { font-size: var(--wt-type-caption); color: var(--wt-color-text-soft); padding: 8px 9px; border-radius: var(--wt-radius-sm); }
.ph-item.on { color: var(--wt-color-accent-2); background: rgba(148,226,213,0.08); }
.ph-item.live { color: var(--wt-color-success); }
.ph-item.live::before { content: "● "; font-size: 0.7em; }
.ph-keys { display: flex; gap: 5px; margin-top: 16px; flex-wrap: wrap; }
.ph-keys span { flex: 1; min-width: 30px; text-align: center; font-size: 0.62rem; color: var(--wt-color-text-soft); background: var(--wt-color-surface); border-radius: var(--wt-radius-sm); padding: 8px 0; }

/* ---------- security band ---------- */
.band-wrap { padding: 24px 0 64px; }
.band {
  text-align: center; background: linear-gradient(135deg, var(--wt-color-panel), var(--wt-color-bg-deep));
  border: 1px solid var(--wt-color-surface); border-radius: var(--wt-radius-xl); padding: 52px 36px;
}
.band h2 { font-size: clamp(1.6rem, 3vw, 2.1rem); color: var(--wt-color-text); margin-bottom: 14px; }
.band p { color: var(--wt-color-text-soft); max-width: 720px; margin: 0 auto; font-size: 1rem; }
.band code { color: var(--wt-color-accent-2); }
.band-pills { display: flex; gap: 10px; justify-content: center; flex-wrap: wrap; margin-top: 24px; }
.pill { font-size: var(--wt-type-caption); color: var(--wt-color-text-soft); background: var(--wt-color-bg-deep); border: 1px solid var(--wt-color-surface); padding: 7px 13px; border-radius: var(--wt-radius-xl); }
.mobile-copy .band-pills { justify-content: flex-start; margin-top: 0; }

/* ---------- pricing ---------- */
.plans .plan { background: var(--wt-color-panel); border: 1px solid var(--wt-color-surface); border-radius: var(--wt-radius-lg); padding: 28px; display: flex; flex-direction: column; }
.plans .plan.feat { border-color: var(--wt-color-accent); box-shadow: 0 0 0 1px var(--wt-color-accent), var(--wt-shadow-md); }
.plan h3 { font-size: var(--wt-type-h3); color: var(--wt-color-text-soft); margin-bottom: 8px; }
.plan .price { font-family: var(--wt-font-display); font-size: 2rem; color: var(--wt-color-text); letter-spacing: var(--wt-tracking-tight); }
.plan .price small { font-size: 0.9rem; color: var(--wt-color-text-faint); font-family: var(--wt-font-mono); }
.plan-sub { font-size: var(--wt-type-small); color: var(--wt-color-text-faint); margin: 4px 0 18px; }
.plan ul { list-style: none; margin-bottom: 22px; flex: 1; }
.plan li { font-size: var(--wt-type-small); color: var(--wt-color-text-soft); padding: 7px 0 7px 22px; position: relative; border-top: 1px solid var(--wt-color-surface); }
.plan li:first-child { border-top: 0; }
.plan li::before { content: "✓"; position: absolute; left: 0; color: var(--wt-color-accent-2); }
.pricing-note { text-align: center; margin-top: 26px; font-size: var(--wt-type-small); color: var(--wt-color-text-faint); }

/* full feature matrix (details) */
.matrix { margin-top: 24px; border: 1px solid var(--wt-color-surface); border-radius: var(--wt-radius-lg); overflow: hidden; }
.matrix > summary { cursor: pointer; padding: 16px 20px; font-family: var(--wt-font-display); color: var(--wt-color-text); list-style: none; user-select: none; background: var(--wt-color-panel); }
.matrix > summary::-webkit-details-marker { display: none; }
.matrix > summary::before { content: "▸ "; color: var(--wt-color-accent-2); }
.matrix[open] > summary::before { content: "▾ "; }
.matrix .table-wrap { border: 0; border-top: 1px solid var(--wt-color-surface); border-radius: 0; }
.matrix .cmp { min-width: 480px; }

/* ---------- steps ---------- */
.steps .step { background: var(--wt-color-panel); border: 1px solid var(--wt-color-surface); border-radius: var(--wt-radius-lg); padding: 24px; transition: transform var(--wt-duration-base) var(--wt-ease-out), border-color var(--wt-duration-base) var(--wt-ease-out); }
.steps .step:hover { transform: translateY(-4px); border-color: var(--wt-color-accent); }
.step-n { display: inline-grid; place-items: center; width: 30px; height: 30px; border-radius: 999px; background: var(--wt-color-bg-deep); border: 1px solid var(--wt-color-accent); color: var(--wt-color-accent); font-family: var(--wt-font-display); font-weight: var(--wt-weight-bold); margin-bottom: 14px; }
.step h3 { font-size: var(--wt-type-h3); color: var(--wt-color-text); margin-bottom: 10px; }
.snip { background: var(--wt-color-bg-deep); border: 1px solid var(--wt-color-surface); border-radius: var(--wt-radius-sm); padding: 10px 12px; font-size: var(--wt-type-caption); color: var(--wt-color-accent-2); overflow-x: auto; margin-bottom: 10px; }
.step p { color: var(--wt-color-text-soft); font-size: var(--wt-type-small); }

/* ---------- footer ---------- */
.footer { border-top: 1px solid var(--wt-color-surface); padding: 48px 0 28px; margin-top: 24px; }
.footer-inner { display: flex; justify-content: space-between; gap: 28px; flex-wrap: wrap; align-items: start; }
.foot-brand .brand { font-size: 1.1rem; }
.foot-brand p { color: var(--wt-color-text-faint); font-size: var(--wt-type-small); margin-top: 8px; max-width: 320px; }
.foot-links { display: flex; gap: 22px; flex-wrap: wrap; }
.foot-links a { color: var(--wt-color-text-soft); font-size: var(--wt-type-small); }
.foot-links a:hover { color: var(--wt-color-text); }
.foot-biz { margin-top: 28px; padding-top: 18px; border-top: 1px solid var(--wt-color-surface); color: var(--wt-color-text-faint); font-size: var(--wt-type-caption); line-height: 1.6; }
.foot-legal { display: flex; justify-content: space-between; gap: 16px; flex-wrap: wrap; margin-top: 12px; color: var(--wt-color-text-faint); font-size: var(--wt-type-caption); }

/* ---------- responsive ---------- */
@media (max-width: 980px) {
  .grid-4 { grid-template-columns: repeat(2, 1fr); }
  .uri-block { grid-template-columns: 1fr; gap: 16px; }
}
@media (max-width: 860px) {
  .hero-inner { grid-template-columns: 1fr; gap: 36px; }
  .hero-shot { order: 2; }
  .appwin { transform: none; }
  .mobile-inner { grid-template-columns: 1fr; gap: 32px; }
  .grid-3, .diag-grid { grid-template-columns: 1fr; }
  .nav-links a:not(.btn) { display: none; }
  .hero h1 { font-size: 2rem; }
  .flow-arrow { transform: rotate(90deg); }
}
@media (max-width: 520px) {
  .grid-4 { grid-template-columns: 1fr; }
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  .cursor, .mock-can .mc-row:last-child { animation: none; }
  .appwin, .appwin:hover { transition: none; }
  .pillar:hover, .cards .card:hover, .steps .step:hover, .diag-card:hover { transform: none; }
}
