/* ─────────────────────────────────────────────────────────────
   SYSTEEMS · Landing v2 styles
   New copy, new sections, two hero visual options.
   ───────────────────────────────────────────────────────────── */

/* ── HERO v2 — shared frame ──────────────────────────────── */
.heroV2-wrap {
  position: relative;
  padding: 80px 0 0;
  border-bottom: 1px solid var(--border-subtle);
  overflow: hidden;
}
.heroV2-wrap::before {
  content: '';
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse 900px 480px at 18% 12%, var(--green-wash), transparent 65%),
    radial-gradient(ellipse 600px 380px at 90% 75%, rgba(62,207,106,0.025), transparent 70%);
  pointer-events: none;
}
.heroV2-inner { position: relative; max-width: 1320px; margin: 0 auto; padding: 0 48px; }
.heroV2-head { max-width: 940px; margin: 0 auto; text-align: center; }

.heroV2-eyebrow {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: var(--font-mono);
  font-size: 11px; font-weight: 500;
  letter-spacing: 2px; text-transform: uppercase;
  color: var(--green);
  padding: 7px 14px;
  border: 1px solid var(--border-green);
  border-radius: var(--r-pill);
  background: rgba(62, 207, 106, 0.06);
  margin-bottom: 28px;
}
.heroV2-eyebrow .dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--green);
  box-shadow: 0 0 12px var(--green);
  animation: pulse-dot 2.2s ease-in-out infinite;
}
@keyframes pulse-dot {
  0%,100% { opacity: 1; }
  50% { opacity: 0.4; }
}

.heroV2-h1 {
  font-size: clamp(48px, 6.6vw, 92px);
  font-weight: 400;
  line-height: 0.98;
  letter-spacing: -0.03em;
  color: var(--fg);
  margin-bottom: 28px;
  text-wrap: balance;
}
.heroV2-h1 .accent { color: var(--green); }

.heroV2-sub {
  font-size: 20px;
  line-height: 1.5;
  color: var(--fg-2);
  max-width: 640px;
  margin: 0 auto 36px;
  text-wrap: pretty;
}

.heroV2-actions {
  display: flex; gap: 12px; justify-content: center; flex-wrap: wrap;
  margin-bottom: 80px;
}

/* ── HERO v2 · option A — Terminal ───────────────────────── */
.heroV2-term-wrap {
  max-width: 980px;
  margin: 0 auto;
  padding-bottom: 64px;
}

/* uses existing .term-window / .term-bar / .term-dots / .term-body / .term-line */

/* ── HERO v2 · option B — Multi-screen Ops Center ────────── */
.heroV2-screens {
  position: relative;
  max-width: 1320px;
  margin: 0 auto;
  padding-bottom: 0;
  height: 640px;
}

/* main window — sits center, tilted slightly */
.ops-win {
  position: absolute;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 12px;
  overflow: hidden;
  box-shadow:
    0 0 0 1px rgba(0,0,0,0.4),
    0 30px 60px -20px rgba(0,0,0,0.6),
    0 0 80px -20px rgba(62,207,106,0.12);
}
.ops-win .ops-win-bar {
  display: flex; align-items: center; gap: 12px;
  padding: 10px 14px;
  background: var(--surface-2);
  border-bottom: 1px solid var(--border);
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.05em;
  color: var(--fg-muted);
}
.ops-win .ops-win-bar .dots { display: flex; gap: 5px; }
.ops-win .ops-win-bar .dots span {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--border-strong);
}
.ops-win .ops-win-bar .dots span:first-child { background: #2ab558; }
.ops-win .ops-win-bar .title { color: var(--fg-2); }
.ops-win .ops-win-bar .title .accent { color: var(--green); }
.ops-win .ops-win-bar .right {
  margin-left: auto;
  display: inline-flex; align-items: center; gap: 6px;
  color: var(--green);
}
.ops-win .ops-win-bar .right .live-dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--green);
  box-shadow: 0 0 8px var(--green);
}

/* ── main dashboard window ── */
.ops-main {
  left: 50%; top: 0;
  transform: translateX(-50%);
  width: 880px;
  height: 540px;
  z-index: 2;
}
.ops-main .main-body {
  display: grid;
  grid-template-columns: 180px 1fr;
  height: calc(100% - 36px);
}
.ops-side {
  background: var(--bg-deep);
  border-right: 1px solid var(--border);
  padding: 16px 12px;
  font-family: var(--font-sans);
  font-size: 13px;
}
.ops-side .side-section {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--fg-muted);
  padding: 8px 10px 6px;
}
.ops-side .side-item {
  display: flex; align-items: center; gap: 10px;
  padding: 7px 10px;
  border-radius: 6px;
  color: var(--fg-2);
  cursor: default;
  transition: all 0.15s ease;
}
.ops-side .side-item .pip {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--border-strong);
}
.ops-side .side-item.on {
  background: rgba(62, 207, 106, 0.08);
  color: var(--fg);
}
.ops-side .side-item.on .pip {
  background: var(--green);
  box-shadow: 0 0 8px var(--green);
}
.ops-side .side-item .count {
  margin-left: auto;
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--fg-muted);
}
.ops-side .side-item.on .count { color: var(--green); }

.ops-main-content {
  padding: 22px 24px;
  display: flex; flex-direction: column;
  gap: 16px;
  overflow: hidden;
}
.ops-main-h {
  display: flex; align-items: baseline; justify-content: space-between;
  margin-bottom: 4px;
}
.ops-main-h h4 {
  font-size: 17px;
  font-weight: 500;
  color: var(--fg);
}
.ops-main-h .date {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--fg-muted);
  letter-spacing: 0.05em;
}

.ops-kpi-row {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
}
.ops-kpi-cell {
  background: var(--bg-deep);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 12px 14px;
}
.ops-kpi-cell .l {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--fg-muted);
  margin-bottom: 6px;
}
.ops-kpi-cell .v {
  font-size: 20px;
  font-weight: 500;
  color: var(--fg);
  letter-spacing: -0.01em;
  margin-bottom: 2px;
}
.ops-kpi-cell .d {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--green);
}
.ops-kpi-cell .d.flat { color: var(--fg-muted); }

/* pipeline table */
.ops-pipeline {
  flex: 1;
  background: var(--bg-deep);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 14px 16px;
  display: flex; flex-direction: column;
  min-height: 0;
}
.ops-pipeline .ph {
  display: flex; align-items: baseline; justify-content: space-between;
  margin-bottom: 10px;
}
.ops-pipeline .ph .nm {
  font-size: 13px;
  color: var(--fg);
}
.ops-pipeline .ph .src {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.08em;
  color: var(--fg-muted);
}
.ops-pipeline .pcol-h {
  display: grid;
  grid-template-columns: 1.7fr 1fr 0.9fr 0.7fr;
  gap: 10px;
  padding: 6px 4px;
  border-bottom: 1px solid var(--border-subtle);
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--fg-muted);
}
.ops-pipeline .prow {
  display: grid;
  grid-template-columns: 1.7fr 1fr 0.9fr 0.7fr;
  gap: 10px;
  padding: 9px 4px;
  align-items: center;
  border-bottom: 1px solid var(--border-subtle);
  font-size: 13px;
}
.ops-pipeline .prow:last-child { border-bottom: none; }
.ops-pipeline .prow .cli { color: var(--fg); }
.ops-pipeline .prow .own { color: var(--fg-2); font-size: 12px; }
.ops-pipeline .prow .amt {
  color: var(--fg);
  font-family: var(--font-mono);
  font-size: 12px;
}
.ops-pipeline .prow .st {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 2px 7px;
  border-radius: 4px;
  text-align: center;
  border: 1px solid var(--border);
  color: var(--fg-2);
}
.ops-pipeline .prow .st.flag {
  color: #f7b955;
  border-color: rgba(247,185,85,0.3);
  background: rgba(247,185,85,0.05);
}
.ops-pipeline .prow .st.ok {
  color: var(--green);
  border-color: var(--border-green);
  background: rgba(62,207,106,0.06);
}
.ops-pipeline .prow.flagged {
  background: rgba(247,185,85,0.025);
}

/* ── floating windows ── */
.ops-float {
  width: 320px;
  z-index: 3;
  animation: opsFloat 6s ease-in-out infinite;
}
@keyframes opsFloat {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-6px); }
}

/* top-left: Slack alert */
.ops-slack {
  left: -10px; top: 60px;
  animation-delay: -1s;
}
.ops-slack .slack-body {
  padding: 14px 16px;
  display: flex; flex-direction: column;
  gap: 10px;
}
.ops-slack .slack-msg {
  display: flex; gap: 10px;
  align-items: flex-start;
}
.ops-slack .slack-av {
  width: 32px; height: 32px;
  border-radius: 6px;
  background: var(--green-dim);
  border: 1px solid var(--border-green);
  display: grid; place-items: center;
  color: var(--green);
  font-family: var(--font-mono);
  font-size: 12px;
  font-weight: 500;
  flex-shrink: 0;
}
.ops-slack .slack-meta {
  display: flex; align-items: baseline; gap: 8px;
  font-size: 12px;
  margin-bottom: 4px;
}
.ops-slack .slack-meta .user { color: var(--fg); font-weight: 500; }
.ops-slack .slack-meta .time { color: var(--fg-muted); font-family: var(--font-mono); font-size: 10px; }
.ops-slack .slack-text {
  font-size: 13px;
  color: var(--fg-2);
  line-height: 1.45;
}
.ops-slack .slack-text .mention {
  color: var(--green);
  background: rgba(62,207,106,0.08);
  padding: 0 4px;
  border-radius: 3px;
}
.ops-slack .slack-text strong {
  color: var(--fg);
  font-weight: 500;
}
.ops-slack .slack-link {
  display: inline-flex; align-items: center; gap: 6px;
  margin-top: 6px;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--green);
}

/* top-right: invoice paid */
.ops-invoice {
  right: -10px; top: 30px;
  animation-delay: -3s;
}
.ops-invoice .inv-body {
  padding: 16px 18px;
}
.ops-invoice .inv-top {
  display: flex; align-items: center; gap: 10px;
  margin-bottom: 12px;
}
.ops-invoice .inv-icon {
  width: 28px; height: 28px;
  border-radius: 6px;
  background: rgba(62,207,106,0.1);
  border: 1px solid var(--border-green);
  display: grid; place-items: center;
  color: var(--green);
}
.ops-invoice .inv-label {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--green);
}
.ops-invoice .inv-amount {
  font-size: 32px;
  font-weight: 500;
  letter-spacing: -0.02em;
  color: var(--fg);
  margin-bottom: 4px;
}
.ops-invoice .inv-client {
  font-size: 13px;
  color: var(--fg-2);
  margin-bottom: 12px;
}
.ops-invoice .inv-meta {
  display: flex; justify-content: space-between;
  padding-top: 12px;
  border-top: 1px solid var(--border-subtle);
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.05em;
  color: var(--fg-muted);
}
.ops-invoice .inv-meta .ok { color: var(--green); }

/* bottom-right: forecast */
.ops-forecast {
  right: 30px; bottom: 20px;
  width: 280px;
  animation-delay: -2s;
}
.ops-forecast .fc-body {
  padding: 16px 18px;
}
.ops-forecast .fc-l {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--fg-muted);
  margin-bottom: 8px;
}
.ops-forecast .fc-v {
  font-size: 26px;
  font-weight: 500;
  letter-spacing: -0.02em;
  color: var(--fg);
}
.ops-forecast .fc-v .accent { color: var(--green); }
.ops-forecast .fc-spark {
  height: 36px;
  margin: 10px 0 6px;
}
.ops-forecast .fc-foot {
  display: flex; justify-content: space-between;
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--fg-muted);
}
.ops-forecast .fc-foot .up { color: var(--green); }

/* bottom-left: tasks */
.ops-tasks {
  left: 20px; bottom: 10px;
  width: 340px;
  animation-delay: -4s;
}
.ops-tasks .tk-body {
  padding: 14px 16px;
}
.ops-tasks .tk-head {
  display: flex; align-items: baseline; justify-content: space-between;
  margin-bottom: 10px;
}
.ops-tasks .tk-head h5 {
  font-size: 13px;
  font-weight: 500;
  color: var(--fg);
}
.ops-tasks .tk-head .count {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--fg-muted);
}
.ops-tasks .tk-row {
  display: flex; align-items: center; gap: 10px;
  padding: 7px 0;
  font-size: 12.5px;
  color: var(--fg-2);
  border-bottom: 1px solid var(--border-subtle);
}
.ops-tasks .tk-row:last-child { border-bottom: none; }
.ops-tasks .tk-check {
  width: 14px; height: 14px;
  border-radius: 3px;
  border: 1px solid var(--border-strong);
  flex-shrink: 0;
  display: grid; place-items: center;
}
.ops-tasks .tk-check.done {
  background: var(--green);
  border-color: var(--green);
  color: var(--bg-deep);
}
.ops-tasks .tk-row.done .nm { color: var(--fg-muted); text-decoration: line-through; }
.ops-tasks .tk-bar {
  flex: 1;
  height: 3px;
  background: var(--border);
  border-radius: 2px;
  overflow: hidden;
  position: relative;
}
.ops-tasks .tk-bar .fill {
  position: absolute; inset: 0;
  background: var(--green);
  border-radius: 2px;
  transform-origin: left;
}
.ops-tasks .tk-pct {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--fg-muted);
  width: 28px; text-align: right;
}

/* ── HERO v2 · option C — Tabbed Ops Center ─────────────── */
.heroV2-tabs-wrap {
  max-width: 1180px;
  margin: 0 auto;
  padding-bottom: 64px;
}
.heroV2-tabs-bar {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 8px;
  margin-bottom: 24px;
}
.heroV2-tab {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 9px 18px;
  border-radius: var(--r-pill);
  border: 1px solid var(--border);
  background: var(--surface);
  font-family: var(--font-sans);
  font-size: 13px;
  font-weight: 500;
  color: var(--fg-2);
  cursor: pointer;
  transition: all 0.18s ease;
  position: relative;
}
.heroV2-tab .num {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.1em;
  color: var(--fg-muted);
}
.heroV2-tab .pip {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--border-strong);
}
.heroV2-tab:hover {
  border-color: var(--border-strong);
  color: var(--fg);
}
.heroV2-tab.on {
  background: rgba(62,207,106,0.08);
  border-color: var(--border-green);
  color: var(--fg);
}
.heroV2-tab.on .num { color: var(--green); }
.heroV2-tab.on .pip {
  background: var(--green);
  box-shadow: 0 0 8px var(--green);
}
.heroV2-tabs-frame {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 14px;
  overflow: hidden;
  box-shadow:
    0 0 0 1px rgba(0,0,0,0.4),
    0 30px 60px -20px rgba(0,0,0,0.6),
    0 0 80px -20px rgba(62,207,106,0.12);
}
.heroV2-tabs-frame .frame-bar {
  display: flex; align-items: center; gap: 12px;
  padding: 11px 16px;
  background: var(--surface-2);
  border-bottom: 1px solid var(--border);
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.05em;
  color: var(--fg-muted);
}
.heroV2-tabs-frame .frame-bar .dots { display: flex; gap: 5px; }
.heroV2-tabs-frame .frame-bar .dots span {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--border-strong);
}
.heroV2-tabs-frame .frame-bar .dots span:first-child { background: #2ab558; }
.heroV2-tabs-frame .frame-bar .title { color: var(--fg-2); }
.heroV2-tabs-frame .frame-bar .title .accent { color: var(--green); }
.heroV2-tabs-frame .frame-bar .right {
  margin-left: auto;
  display: inline-flex; align-items: center; gap: 6px;
  color: var(--green);
}
.heroV2-tabs-frame .frame-bar .right .live-dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--green);
  box-shadow: 0 0 8px var(--green);
}
.heroV2-tabs-body {
  padding: 28px 32px;
  min-height: 460px;
  position: relative;
}
.heroV2-tabs-screen {
  animation: tabScreenIn 0.45s var(--ease-out);
}
@keyframes tabScreenIn {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}
.heroV2-tabs-screen .screen-h {
  display: flex; align-items: baseline; justify-content: space-between;
  margin-bottom: 18px;
  padding-bottom: 16px;
  border-bottom: 1px solid var(--border-subtle);
}
.heroV2-tabs-screen .screen-h h4 {
  font-size: 20px;
  font-weight: 500;
  color: var(--fg);
  letter-spacing: -0.01em;
}
.heroV2-tabs-screen .screen-h .meta {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.05em;
  color: var(--fg-muted);
  display: inline-flex; align-items: center; gap: 10px;
}
.heroV2-tabs-screen .screen-h .meta .src {
  padding: 2px 8px;
  border: 1px solid var(--border);
  border-radius: 4px;
}

/* KPI row */
.tab-kpi-row {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
  margin-bottom: 20px;
}
.tab-kpi {
  padding: 16px 18px;
  background: var(--bg-deep);
  border: 1px solid var(--border);
  border-radius: 8px;
}
.tab-kpi .l {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--fg-muted);
  margin-bottom: 8px;
}
.tab-kpi .v {
  font-size: 24px;
  font-weight: 500;
  color: var(--fg);
  letter-spacing: -0.015em;
  margin-bottom: 4px;
}
.tab-kpi .v .u { font-size: 14px; color: var(--fg-muted); margin-left: 2px; }
.tab-kpi .d {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--green);
}
.tab-kpi .d.flat { color: var(--fg-muted); }
.tab-kpi .d.warn { color: #f7b955; }

/* table */
.tab-table {
  border: 1px solid var(--border);
  border-radius: 8px;
  background: var(--bg-deep);
  overflow: hidden;
}
.tab-table .th, .tab-table .tr {
  display: grid;
  grid-template-columns: var(--cols, 2fr 1fr 1fr 1fr 0.8fr);
  gap: 12px;
  padding: 11px 18px;
  align-items: center;
}
.tab-table .th {
  background: var(--surface-2);
  border-bottom: 1px solid var(--border);
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--fg-muted);
}
.tab-table .tr {
  border-top: 1px solid var(--border-subtle);
  font-size: 13.5px;
  color: var(--fg-2);
}
.tab-table .tr:first-of-type { border-top: none; }
.tab-table .tr .pr {
  color: var(--fg);
}
.tab-table .tr .amt, .tab-table .tr .num {
  font-family: var(--font-mono);
  font-size: 12.5px;
  color: var(--fg);
}
.tab-table .tr .own { font-size: 12.5px; color: var(--fg-2); }
.tab-table .tr .st {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 3px 8px;
  border-radius: 4px;
  border: 1px solid var(--border);
  color: var(--fg-2);
  justify-self: start;
}
.tab-table .tr .st.ok {
  color: var(--green);
  border-color: var(--border-green);
  background: rgba(62,207,106,0.06);
}
.tab-table .tr .st.flag {
  color: #f7b955;
  border-color: rgba(247,185,85,0.3);
  background: rgba(247,185,85,0.05);
}
.tab-table .tr .st.warn {
  color: #f7b955;
  border-color: rgba(247,185,85,0.3);
}
.tab-table .tr .st.muted {
  color: var(--fg-muted);
}

/* generic 2-column split inside a tab screen */
.tab-split {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: 14px;
}
.tab-card {
  padding: 18px 20px;
  background: var(--bg-deep);
  border: 1px solid var(--border);
  border-radius: 8px;
}
.tab-card-h {
  display: flex; align-items: baseline; justify-content: space-between;
  margin-bottom: 12px;
}
.tab-card-h h5 {
  font-size: 13px;
  font-weight: 500;
  color: var(--fg);
}
.tab-card-h .src {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.05em;
  color: var(--fg-muted);
}

/* bar chart */
.tab-bars {
  display: flex;
  align-items: stretch;
  gap: 8px;
  height: 150px;
  padding-top: 8px;
}
.tab-bar {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  justify-content: flex-end;
  height: 100%;
  gap: 6px;
  min-width: 0;
}
.tab-bar .col {
  width: 100%;
  min-height: 4px;
  background: var(--green-dim);
  border-radius: 3px 3px 0 0;
  position: relative;
  transition: height 0.7s var(--ease-out);
}
.tab-bar .lbl {
  text-align: center;
}
.tab-bar.lit .col {
  background: var(--green);
  box-shadow: 0 0 12px rgba(62,207,106,0.4);
}
.tab-bar .lbl {
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--fg-muted);
}

/* finance breakdown */
.tab-fin-row {
  display: flex; align-items: center; gap: 12px;
  padding: 10px 0;
  border-top: 1px solid var(--border-subtle);
  font-size: 13px;
}
.tab-fin-row:first-of-type { border-top: none; }
.tab-fin-row .swatch {
  width: 10px; height: 10px;
  border-radius: 2px;
}
.tab-fin-row .nm { flex: 1; color: var(--fg-2); }
.tab-fin-row .amt {
  font-family: var(--font-mono);
  font-size: 12.5px;
  color: var(--fg);
}
.tab-fin-row .pct {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--fg-muted);
  width: 44px; text-align: right;
}

/* delivery list */
.tab-delivery-row {
  display: grid;
  grid-template-columns: 1.8fr 1fr 60px 80px;
  gap: 12px;
  align-items: center;
  padding: 11px 0;
  border-top: 1px solid var(--border-subtle);
  font-size: 13px;
}
.tab-delivery-row:first-of-type { border-top: none; }
.tab-delivery-row .nm { color: var(--fg); }
.tab-delivery-row .ph {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.05em;
  color: var(--fg-muted);
}
.tab-delivery-row .pbar {
  height: 4px;
  background: var(--border);
  border-radius: 2px;
  overflow: hidden;
  position: relative;
}
.tab-delivery-row .pbar .fill {
  position: absolute; left: 0; top: 0; bottom: 0;
  background: var(--green);
  transition: width 0.7s var(--ease-out);
}
.tab-delivery-row .pbar.warn .fill { background: #f7b955; }
.tab-delivery-row .pct {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--fg-muted);
  text-align: right;
}

/* team event log */
.tab-events .ev {
  display: grid;
  grid-template-columns: 80px 16px 1fr 100px;
  gap: 12px;
  align-items: center;
  padding: 10px 0;
  border-top: 1px solid var(--border-subtle);
  font-size: 13px;
}
.tab-events .ev:first-of-type { border-top: none; }
.tab-events .ev .t {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.05em;
  color: var(--fg-muted);
}
.tab-events .ev .ic {
  width: 16px; height: 16px;
  border-radius: 50%;
  border: 1px solid var(--border-strong);
  display: grid; place-items: center;
  font-size: 9px;
}
.tab-events .ev.ok .ic {
  background: rgba(62,207,106,0.08);
  border-color: var(--border-green);
  color: var(--green);
}
.tab-events .ev .nm { color: var(--fg-2); }
.tab-events .ev .nm strong { color: var(--fg); font-weight: 500; }
.tab-events .ev .src {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.05em;
  text-align: right;
  color: var(--fg-muted);
}

/* responsive */
@media (max-width: 820px) {
  .heroV2-tabs-body { padding: 20px 16px; }
  .tab-kpi-row { grid-template-columns: repeat(2, 1fr); }
  .tab-split { grid-template-columns: 1fr; }
  .tab-table .th, .tab-table .tr { padding: 10px 12px; font-size: 12px; }
  .tab-delivery-row { grid-template-columns: 1.4fr 60px 60px; }
  .tab-delivery-row .ph { display: none; }
  .tab-events .ev { grid-template-columns: 60px 16px 1fr; }
  .tab-events .ev .src { display: none; }
}

/* ── SECTION rhythm shared ─────────────────────────────── */
.secV2 {
  padding: 140px 0;
  border-top: 1px solid var(--border-subtle);
  position: relative;
}
/* Integrations is mostly visual — pull it closer to The Shift */
#integrations.secV2 {
  padding-top: 80px;
}

/* ── 4 · Integrations — refined hub + 3 variants ─────── */
#integrations .integ-wrap {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 56px 32px;
  overflow: hidden;
  position: relative;
}
#integrations .integ-grid {
  position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(62,207,106,0.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(62,207,106,0.06) 1px, transparent 1px);
  background-size: 40px 40px;
  -webkit-mask-image: radial-gradient(ellipse at center, black 12%, transparent 72%);
          mask-image: radial-gradient(ellipse at center, black 12%, transparent 72%);
  pointer-events: none;
}
#integrations .integ-canvas {
  position: relative;
  width: 100%;
  max-width: 1040px;
  height: 460px;
  margin: 0 auto;
}

/* HUB — just the logo, no text */
/* HUB — rounded-corner logo card at the center */
.integ-hub-v2 {
  position: absolute;
  left: 50%; top: 50%;
  transform: translate(-50%, -50%);
  width: 116px; height: 116px;
  background: #0b1a10;
  border: 1px solid var(--border-green);
  border-radius: 24px;
  display: grid; place-items: center;
  z-index: 5;
  box-shadow:
    0 0 0 1px rgba(62,207,106,0.18),
    0 0 60px -8px rgba(62,207,106,0.45),
    inset 0 0 24px rgba(62,207,106,0.06);
}
.integ-hub-v2::before, .integ-hub-v2::after { display: none; }
@keyframes hubPulse {
  0%   { opacity: 0.7; transform: scale(0.7); }
  100% { opacity: 0; transform: scale(1.25); }
}

/* shared node card */
.integ-v2-node {
  position: absolute;
  display: inline-flex; align-items: center; gap: 10px;
  padding: 8px 12px 8px 8px;
  background: var(--bg-deep);
  border: 1px solid var(--border);
  border-radius: 10px;
  z-index: 4;
  transition: border-color 0.25s ease, transform 0.25s ease;
}
.integ-v2-node:hover {
  border-color: var(--border-green);
  transform: translateY(-1px);
}
.integ-v2-node .tile {
  width: 28px; height: 28px;
  border-radius: 7px;
  display: grid; place-items: center;
  font-family: var(--font-mono);
  font-size: 13px; font-weight: 600;
  color: #fff;
  flex-shrink: 0;
}
.integ-v2-node .txt { display: flex; flex-direction: column; gap: 1px; min-width: 0; }
.integ-v2-node .n { font-size: 13px; color: var(--fg); letter-spacing: -0.005em; }
.integ-v2-node .d {
  font-family: var(--font-mono);
  font-size: 9px; letter-spacing: 0.08em;
  text-transform: uppercase; color: var(--fg-muted);
}

.integ-v2-svg {
  position: absolute; inset: 0;
  pointer-events: none;
  width: 100%; height: 100%;
}
.integ-v2-svg .line {
  stroke: rgba(62,207,106,0.28);
  stroke-width: 1;
  fill: none;
}
.integ-v2-svg .packet {
  fill: var(--green);
  filter: drop-shadow(0 0 4px var(--green));
}

/* ── Variant A · CONSTELLATION (hexagonal layout, lines out from hub) ── */
.integ-v2.A .integ-v2-node.p0 { left: 4%;   top: 8%; }
.integ-v2.A .integ-v2-node.p1 { right: 4%;  top: 8%; }
.integ-v2.A .integ-v2-node.p2 { left: 0%;   top: 48%; transform: translateY(-50%); }
.integ-v2.A .integ-v2-node.p3 { right: 0%;  top: 48%; transform: translateY(-50%); }
.integ-v2.A .integ-v2-node.p4 { left: 4%;   bottom: 8%; }
.integ-v2.A .integ-v2-node.p5 { right: 4%;  bottom: 8%; }
.integ-v2.A .integ-v2-node:hover { transform: translateY(-1px); }
.integ-v2.A .integ-v2-node.p2:hover,
.integ-v2.A .integ-v2-node.p3:hover { transform: translateY(calc(-50% - 1px)); }

/* ── Variant B · ORBIT (clean rings + radial connectors) ── */
.integ-v2.B .integ-canvas { height: 540px; }
.integ-v2.B .orbit-rings {
  position: absolute; inset: 0;
  pointer-events: none;
}
.integ-v2.B .ring {
  position: absolute;
  border: 1px dashed rgba(62,207,106,0.20);
  border-radius: 50%;
  left: 50%; top: 50%;
  transform: translate(-50%, -50%);
}
.integ-v2.B .ring.r1 { width: 320px; height: 320px; }
.integ-v2.B .ring.r2 { width: 500px; height: 500px; }
.integ-v2.B .ring-tick {
  position: absolute;
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--green);
  box-shadow: 0 0 8px var(--green);
  transform: translate(-50%, -50%);
  z-index: 3;
}
.integ-v2.B .orbit-line {
  position: absolute;
  left: 50%; top: 50%;
  height: 1px;
  transform-origin: 0 50%;
  background: linear-gradient(90deg, rgba(62,207,106,0.55) 0%, rgba(62,207,106,0.15) 100%);
  z-index: 1;
}
.integ-v2.B .orbit-packet {
  position: absolute;
  left: 50%; top: 50%;
  width: 5px; height: 5px;
  border-radius: 50%;
  background: var(--green);
  box-shadow: 0 0 8px var(--green);
  transform-origin: 0 50%;
  animation: orbitPacket 2.6s linear infinite;
  z-index: 2;
}
@keyframes orbitPacket {
  0%   { transform: rotate(var(--ang)) translateX(var(--r)); opacity: 0; }
  15%  { opacity: 1; }
  85%  { opacity: 1; }
  100% { transform: rotate(var(--ang)) translateX(0); opacity: 0; }
}

/* ── Variant C · BUS (left/right with horizontal flow) ── */
.integ-v2.C .integ-canvas { height: 460px; position: relative; }
.integ-v2.C .bus-col {
  position: absolute;
  top: 0; bottom: 0;
  display: flex; flex-direction: column;
  justify-content: space-around;
  width: 220px;
  z-index: 4;
}
.integ-v2.C .bus-col.left  { left: 0;  align-items: flex-start; }
.integ-v2.C .bus-col.right { right: 0; align-items: flex-end; }
.integ-v2.C .integ-v2-node { position: relative; left: auto; right: auto; top: auto; bottom: auto; transform: none; }
.integ-v2.C .bus-line {
  position: absolute;
  height: 1px;
  transform-origin: 0 50%;
  z-index: 1;
}
.integ-v2.C .bus-line.from-left  { background: linear-gradient(90deg, rgba(62,207,106,0.45), rgba(62,207,106,0.15)); }
.integ-v2.C .bus-line.from-right { background: linear-gradient(90deg, rgba(62,207,106,0.15), rgba(62,207,106,0.45)); }
.integ-v2.C .bus-packet {
  position: absolute;
  width: 4px; height: 4px;
  border-radius: 50%;
  background: var(--green);
  box-shadow: 0 0 8px var(--green);
  z-index: 2;
}
.integ-v2.C .bus-label {
  position: absolute;
  left: 50%; transform: translateX(-50%);
  top: calc(50% - 90px);
  font-family: var(--font-mono);
  font-size: 10px; letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--green);
  display: inline-flex; align-items: center; gap: 8px;
}
.integ-v2.C .bus-label::before,
.integ-v2.C .bus-label::after {
  content: ''; width: 20px; height: 1px; background: var(--border-green);
}

/* variant switcher pills */
.integ-v2-switch {
  display: flex; justify-content: center; gap: 8px;
  margin: 0 0 24px;
}
.integ-v2-switch button {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.08em;
  padding: 7px 14px;
  border-radius: var(--r-pill);
  border: 1px solid var(--border);
  background: var(--surface);
  color: var(--fg-2);
  cursor: pointer;
  transition: all 0.18s ease;
}
.integ-v2-switch button.on {
  background: rgba(62,207,106,0.08);
  border-color: var(--border-green);
  color: var(--fg);
}

@media (max-width: 720px) {
  #integrations .integ-canvas { height: 560px; }
  .integ-v2.B .ring.r2 { width: 320px; height: 320px; }
  .integ-v2.B .ring.r1 { width: 200px; height: 200px; }
  .integ-v2.C .bus-col { width: 160px; }
}

.secV2-head {
  margin-bottom: 72px;
  max-width: 820px;
}
.secV2-eyebrow {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: var(--font-mono);
  font-size: 11px; font-weight: 500;
  letter-spacing: 2px; text-transform: uppercase;
  color: var(--green);
  margin-bottom: 24px;
}
.secV2-eyebrow::before {
  content:''; width: 24px; height: 1px; background: var(--green);
}
.secV2-h2 {
  font-size: clamp(38px, 4.4vw, 60px);
  font-weight: 400;
  line-height: 1.05;
  letter-spacing: -0.025em;
  color: var(--fg);
  margin-bottom: 24px;
  text-wrap: balance;
}
.secV2-h2 .accent { color: var(--green); }
.secV2-sub {
  font-size: 19px;
  line-height: 1.5;
  color: var(--fg-2);
  max-width: 680px;
  text-wrap: pretty;
}

/* ── 2 · Problem — typography accents ─────────────────── */
@import url('https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@500;600;700&display=swap');

/* override the eyebrow + numbers ONLY inside the problem section */
#problem .secV2-eyebrow,
#problem .prob-card-v2 .num,
#problem .prob-index-row .num,
#problem .prob-stack-row .num {
  font-family: 'JetBrains Mono', 'Source Code Pro', monospace;
  font-weight: 700;
  letter-spacing: 0.14em;
}
#problem .secV2-eyebrow { font-size: 12px; }

/* ── Problem · LAYOUT A · grid cards (default) ── */
.prob-grid-v2 {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 24px;
}
.prob-card-v2 {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: 36px 36px 40px;
  transition: border-color 0.25s ease;
}
.prob-card-v2:hover {
  border-color: var(--border-strong);
}
.prob-card-v2 .num {
  font-size: 12px;
  color: var(--green);
  margin-bottom: 28px;
}
.prob-card-v2 h4 {
  font-size: 22px;
  font-weight: 500;
  line-height: 1.25;
  color: var(--fg);
  margin-bottom: 14px;
  letter-spacing: -0.01em;
}
.prob-card-v2 p {
  font-size: 16px;
  line-height: 1.55;
  color: var(--fg-2);
}

/* ── Problem · LAYOUT B · numbered index rows ── */
.prob-index {
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}
.prob-index-row {
  display: grid;
  grid-template-columns: 120px 1fr 1.2fr;
  gap: 32px;
  padding: 36px 12px;
  border-top: 1px solid var(--border-subtle);
  align-items: baseline;
  transition: background 0.25s ease;
}
.prob-index-row:first-child { border-top: none; }
.prob-index-row:hover {
  background: rgba(62, 207, 106, 0.02);
}
.prob-index-row .num {
  font-size: clamp(40px, 4.2vw, 56px);
  font-weight: 700;
  color: var(--green);
  letter-spacing: -0.02em;
  line-height: 1;
}
.prob-index-row h4 {
  font-size: clamp(22px, 2.2vw, 28px);
  font-weight: 500;
  line-height: 1.2;
  color: var(--fg);
  letter-spacing: -0.015em;
}
.prob-index-row p {
  font-size: 16px;
  line-height: 1.6;
  color: var(--fg-2);
}

/* ── Problem · LAYOUT C · quoted stack (recognition scenes) ── */
.prob-stack {
  display: flex;
  flex-direction: column;
  gap: 24px;
  max-width: 980px;
}
.prob-stack-row {
  display: grid;
  grid-template-columns: 88px 1fr;
  gap: 28px;
  padding: 28px 32px 32px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-left: 2px solid var(--green-mid);
  border-radius: var(--r-lg);
  position: relative;
}
.prob-stack-row:nth-child(odd) {
  border-left-color: var(--green);
}
.prob-stack-row .num {
  font-size: 14px;
  color: var(--green);
  padding-top: 8px;
}
.prob-stack-row h4 {
  font-size: 20px;
  font-weight: 500;
  color: var(--fg);
  margin-bottom: 12px;
  letter-spacing: -0.01em;
}
.prob-stack-row p {
  font-size: 16px;
  line-height: 1.6;
  color: var(--fg-2);
}

@media (max-width: 820px) {
  .prob-index-row { grid-template-columns: 1fr; gap: 12px; padding: 28px 0; }
  .prob-stack-row { grid-template-columns: 1fr; gap: 12px; padding: 24px 22px 26px; }
}

/* ── 3 · Insight ─── Prose & 3 before/after layouts ─── */
.insight-prose {
  max-width: 760px;
  margin: 0 0 72px;
}
.insight-prose p {
  font-size: 19px;
  line-height: 1.65;
  color: var(--fg-2);
  margin-bottom: 22px;
  text-wrap: pretty;
}
.insight-prose p:last-child { margin-bottom: 0; }
.insight-prose .hl { color: var(--fg); font-weight: 500; }

/* Variant A — clean split (refined) */
.insight-compare-split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  margin-bottom: 72px;
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  overflow: hidden;
}

/* Variant B — paired ledger rows */
.insight-ledger {
  margin-bottom: 72px;
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  background: var(--surface);
  overflow: hidden;
}
.insight-ledger-h {
  display: grid;
  grid-template-columns: 1fr 60px 1fr;
  gap: 24px;
  padding: 22px 28px;
  background: var(--surface-2);
  border-bottom: 1px solid var(--border);
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  font-weight: 600;
  align-items: center;
}
.insight-ledger-h .dim { color: var(--fg-muted); }
.insight-ledger-h .lit { color: var(--green); }
.insight-ledger-h .arrow { color: var(--green); text-align: center; font-size: 18px; }
.insight-ledger-row {
  display: grid;
  grid-template-columns: 1fr 60px 1fr;
  gap: 24px;
  padding: 20px 28px;
  border-top: 1px solid var(--border-subtle);
  align-items: center;
  font-size: 15.5px;
  line-height: 1.5;
}
.insight-ledger-row .dim {
  color: var(--fg-muted);
  display: flex; gap: 12px; align-items: baseline;
}
.insight-ledger-row .dim .x {
  color: var(--fg-dim);
  font-family: 'JetBrains Mono', monospace;
  flex-shrink: 0;
}
.insight-ledger-row .lit {
  color: var(--fg);
  display: flex; gap: 12px; align-items: baseline;
}
.insight-ledger-row .lit .ck {
  color: var(--green);
  flex-shrink: 0;
  font-weight: 600;
}
.insight-ledger-row .bridge {
  height: 1px;
  background: linear-gradient(90deg, var(--border) 0%, var(--green-mid) 50%, var(--green) 100%);
}

/* Variant C — flip cards with arrow */
.insight-flip {
  display: grid;
  grid-template-columns: 1fr 64px 1fr;
  gap: 0;
  align-items: stretch;
  margin-bottom: 72px;
}
.insight-flip-card {
  padding: 36px 36px 40px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  display: flex; flex-direction: column;
}
.insight-flip-card.dim { opacity: 0.78; }
.insight-flip-card.lit {
  background: var(--surface-2);
  border-color: var(--border-green);
  box-shadow: 0 0 0 1px var(--border-green), 0 0 60px -20px var(--green-glow);
}
.insight-flip-card .badge {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--fg-muted);
  margin-bottom: 16px;
}
.insight-flip-card.lit .badge { color: var(--green); }
.insight-flip-card h3 {
  font-size: 22px;
  font-weight: 500;
  color: var(--fg);
  letter-spacing: -0.01em;
  margin-bottom: 12px;
  line-height: 1.25;
}
.insight-flip-card > p {
  font-size: 15px;
  line-height: 1.55;
  color: var(--fg-2);
  margin-bottom: 24px;
}
.insight-flip-card .rule {
  height: 1px;
  background: var(--border);
  margin-bottom: 20px;
}
.insight-flip-card.lit .rule { background: var(--border-green); }
.insight-flip-card ul {
  list-style: none;
  display: flex; flex-direction: column; gap: 12px;
}
.insight-flip-card li {
  display: flex; gap: 12px; align-items: flex-start;
  font-size: 15px;
  line-height: 1.5;
  color: var(--fg-2);
}
.insight-flip-card li .dot {
  flex-shrink: 0;
  width: 5px; height: 5px;
  border-radius: 50%;
  background: var(--fg-dim);
  margin-top: 9px;
}
.insight-flip-card.lit li {
  color: var(--fg);
}
.insight-flip-card.lit li .dot {
  background: var(--green);
  box-shadow: 0 0 8px var(--green);
}
.insight-flip-arrow {
  display: flex; flex-direction: column; align-items: center;
  justify-content: center;
  gap: 12px;
  padding: 0 8px;
}
.insight-flip-arrow .line {
  flex: 1;
  width: 1px;
  background: linear-gradient(180deg, transparent, var(--border) 30%, var(--border-green) 70%, var(--green));
}
.insight-flip-arrow .head {
  font-size: 22px;
  color: var(--green);
  font-family: 'JetBrains Mono', monospace;
}

@media (max-width: 900px) {
  .insight-flip { grid-template-columns: 1fr; gap: 12px; }
  .insight-flip-arrow { flex-direction: row; padding: 8px 0; }
  .insight-flip-arrow .line { width: auto; height: 1px; flex: 1; background: linear-gradient(90deg, transparent, var(--border) 30%, var(--border-green) 70%, var(--green)); }
  .insight-flip-arrow .head { transform: rotate(90deg); }
  .insight-ledger-h, .insight-ledger-row { grid-template-columns: 1fr; gap: 8px; }
  .insight-ledger-h .arrow, .insight-ledger-row .bridge { display: none; }
}
.insight-col {
  padding: 36px 36px 40px;
  background: var(--surface);
}
.insight-col.lit {
  background: var(--surface-2);
  position: relative;
}
.insight-col.lit::before {
  content: '';
  position: absolute; left: 0; top: 0; bottom: 0;
  width: 2px;
  background: var(--green);
}
.insight-col + .insight-col { border-left: 1px solid var(--border); }
.insight-col .label {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--fg-muted);
  margin-bottom: 6px;
}
.insight-col.lit .label { color: var(--green); }
.insight-col h3 {
  font-size: 22px;
  font-weight: 500;
  color: var(--fg);
  margin-bottom: 24px;
  letter-spacing: -0.01em;
}
.insight-col .tag {
  font-size: 13px;
  color: var(--fg-muted);
  font-style: italic;
  margin-bottom: 24px;
  font-family: var(--font-sans);
}
.insight-col ul {
  list-style: none;
}
.insight-col li {
  display: flex; align-items: flex-start; gap: 12px;
  font-size: 15.5px;
  line-height: 1.5;
  color: var(--fg-2);
  padding: 10px 0;
  border-top: 1px solid var(--border-subtle);
}
.insight-col li:first-child { border-top: none; padding-top: 0; }
.insight-col li::before {
  content: '';
  flex-shrink: 0;
  width: 5px; height: 5px;
  border-radius: 50%;
  background: var(--fg-dim);
  margin-top: 9px;
}
.insight-col.lit li::before {
  background: var(--green);
}

.insight-closing {
  max-width: 880px;
  font-size: clamp(26px, 2.8vw, 38px);
  font-weight: 400;
  line-height: 1.25;
  letter-spacing: -0.02em;
  color: var(--fg);
  padding: 40px 0;
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  text-wrap: balance;
}
.insight-closing .accent { color: var(--green); }

/* ── 4 · Integrations reassurance lines ─────────────────── */
.integ-reassure {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 32px;
  margin-top: 72px;
  padding-top: 56px;
  border-top: 1px solid var(--border-subtle);
}
.integ-reassure .item {
  font-size: 15px;
  line-height: 1.55;
  color: var(--fg-2);
}
.integ-reassure .item strong {
  display: block;
  color: var(--fg);
  font-weight: 500;
  font-size: 17px;
  margin-bottom: 6px;
  letter-spacing: -0.005em;
}

#method .secV2-head { max-width: 1100px; }
#method .secV2-h2 { max-width: 22ch; }
#method .secV2-sub { max-width: 760px; }

/* ── 5b · Method (V2 variants) ─────────────────────────── */

/* shared closing */
.method-closing-v2 {
  margin-top: 40px;
  font-size: 16px;
  color: var(--fg-2);
  text-align: center;
  letter-spacing: -0.005em;
}
.method-closing-v2 .accent { color: var(--green); }

/* shared typography hooks (override only INSIDE method) */
#method .methV2 h4 {
  font-size: 20px;
  font-weight: 500;
  color: var(--fg);
  line-height: 1.25;
  letter-spacing: -0.01em;
  margin-bottom: 10px;
  text-wrap: balance;
}
#method .methV2 p {
  font-size: 15.5px;
  line-height: 1.55;
  color: var(--fg-2);
  text-wrap: pretty;
}

/* ─────── Variant A · TIMELINE RAIL ─────── */
.methV2-A .methV2-rail {
  position: relative;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  margin-bottom: 32px;
}
.methV2-A .methV2-rail-line {
  position: absolute;
  left: 6%; right: 6%;
  top: 22px;
  height: 1px;
  background: linear-gradient(90deg,
    var(--border-green) 0%,
    var(--green) 50%,
    var(--border-green) 100%);
}
.methV2-A .methV2-rail-step {
  position: relative;
  padding: 0 12px;
  text-align: center;
}
.methV2-A .methV2-rail-step .dot {
  width: 14px; height: 14px;
  border-radius: 50%;
  background: var(--bg-deep);
  border: 1px solid var(--green);
  box-shadow: 0 0 0 4px rgba(62,207,106,0.08), 0 0 16px var(--green);
  margin: 14px auto 18px;
  position: relative;
  z-index: 2;
}
.methV2-A .methV2-rail-step .head {
  display: flex; justify-content: center; align-items: baseline; gap: 10px;
  font-family: var(--font-mono);
  margin-bottom: 4px;
}
.methV2-A .methV2-rail-step .num {
  font-size: 11px;
  color: var(--green);
  letter-spacing: 0.1em;
}
.methV2-A .methV2-rail-step .ph {
  font-size: 16px;
  color: var(--fg);
  font-weight: 600;
  letter-spacing: 0.04em;
}
.methV2-A .methV2-rail-step .weeks {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--fg-muted);
}
.methV2-A .methV2-rail-bodies {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--border);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  overflow: hidden;
}
.methV2-A .methV2-rail-body {
  padding: 28px 26px 26px;
  background: var(--surface);
}
.methV2-A .methV2-rail-body .out {
  margin-top: 16px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.06em;
  color: var(--green);
  padding-top: 14px;
  border-top: 1px dashed var(--border-green);
  line-height: 1.4;
}

/* ─────── Variant B · NUMBERED LIST ─────── */
.methV2-B {
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}
.methV2-B .methV2-row {
  display: grid;
  grid-template-columns: 70px 180px 1fr 260px;
  gap: 28px;
  padding: 30px 4px;
  border-top: 1px solid var(--border-subtle);
  align-items: baseline;
}
.methV2-B .methV2-row:first-child { border-top: none; }
.methV2-B .methV2-row .num {
  font-family: var(--font-mono);
  font-size: 36px;
  font-weight: 600;
  color: var(--green);
  letter-spacing: -0.02em;
  line-height: 1;
}
.methV2-B .methV2-row .meta .phase {
  font-family: var(--font-mono);
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.12em;
  color: var(--fg);
  margin-bottom: 4px;
}
.methV2-B .methV2-row .meta .weeks {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.1em;
  color: var(--fg-muted);
}
.methV2-B .methV2-row .body p { margin-top: 2px; }
.methV2-B .methV2-row .out {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.04em;
  color: var(--green);
  padding-left: 18px;
  border-left: 2px solid var(--green);
  line-height: 1.45;
}

/* ─────── Variant C · STACKED PHASES ─────── */
.methV2-C {
  display: flex;
  flex-direction: column;
  gap: 0;
}
.methV2-C .methV2-stack-row {
  display: grid;
  grid-template-columns: 240px 1fr;
  gap: 48px;
  padding: 48px 0;
  border-top: 1px solid var(--border);
  align-items: start;
}
.methV2-C .methV2-stack-row:first-child { border-top: none; padding-top: 24px; }
.methV2-C .methV2-stack-row .left .big {
  font-family: var(--font-mono);
  font-size: clamp(72px, 8vw, 112px);
  font-weight: 700;
  color: var(--green);
  line-height: 0.9;
  letter-spacing: -0.04em;
  margin-bottom: 14px;
}
.methV2-C .methV2-stack-row .left .phase {
  font-family: var(--font-mono);
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.16em;
  color: var(--fg);
  margin-bottom: 4px;
}
.methV2-C .methV2-stack-row .left .weeks {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.12em;
  color: var(--fg-muted);
}
.methV2-C .methV2-stack-row .right h4 {
  font-size: 28px;
  margin-bottom: 14px;
  max-width: 24ch;
}
.methV2-C .methV2-stack-row .right p {
  font-size: 17px;
  margin-bottom: 22px;
  max-width: 60ch;
}
.methV2-C .methV2-stack-row .right .out {
  display: inline-flex; align-items: baseline; gap: 14px;
  padding: 12px 18px;
  background: rgba(62,207,106,0.04);
  border: 1px solid var(--border-green);
  border-radius: 8px;
  font-family: var(--font-mono);
  font-size: 13px;
  color: var(--fg);
}
.methV2-C .methV2-stack-row .right .out span {
  font-size: 10px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--green);
}

/* ─────── Variant D · PROCESS DIAGRAM ─────── */
.methV2-D .methV2-diagram {
  display: grid;
  grid-template-columns: 1fr 60px 1fr 60px 1fr;
  align-items: stretch;
  margin-bottom: 24px;
}
.methV2-D .methV2-stage {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: 24px 22px;
  display: flex; flex-direction: column;
  gap: 8px;
}
.methV2-D .methV2-stage .badge {
  display: inline-flex; align-items: baseline; gap: 8px;
  font-family: var(--font-mono);
  margin-bottom: 8px;
}
.methV2-D .methV2-stage .badge .n {
  font-size: 11px;
  letter-spacing: 0.1em;
  color: var(--green);
}
.methV2-D .methV2-stage .badge .ph {
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.12em;
  color: var(--fg);
}
.methV2-D .methV2-stage .weeks {
  margin-top: auto;
  padding-top: 14px;
  border-top: 1px dashed var(--border);
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--fg-muted);
}
.methV2-D .methV2-conn {
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  position: relative;
}
.methV2-D .methV2-conn .line {
  position: absolute; inset: 50% 0 auto 0;
  height: 1px;
  background: linear-gradient(90deg, var(--border) 0%, var(--green) 50%, var(--border) 100%);
}
.methV2-D .methV2-conn .arrow {
  position: relative;
  background: var(--bg);
  padding: 0 8px;
  font-family: var(--font-mono);
  font-size: 18px;
  color: var(--green);
}
.methV2-D .methV2-diagram-foot {
  display: grid;
  grid-template-columns: 1fr 60px 1fr 60px 1fr;
  gap: 0;
}
.methV2-D .methV2-diagram-foot .methV2-out-cell {
  grid-column: span 1;
  padding: 0 22px;
}
.methV2-D .methV2-diagram-foot .methV2-out-cell:nth-child(1) { grid-column: 1; }
.methV2-D .methV2-diagram-foot .methV2-out-cell:nth-child(2) { grid-column: 3; }
.methV2-D .methV2-diagram-foot .methV2-out-cell:nth-child(3) { grid-column: 5; }
.methV2-D .methV2-out-cell .t {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--green);
  margin-bottom: 6px;
}
.methV2-D .methV2-out-cell .v {
  font-size: 14px;
  color: var(--fg-2);
  line-height: 1.45;
}

@media (max-width: 980px) {
  .methV2-A .methV2-rail { grid-template-columns: 1fr; }
  .methV2-A .methV2-rail-line { display: none; }
  .methV2-A .methV2-rail-bodies { grid-template-columns: 1fr; }
  .methV2-B .methV2-row { grid-template-columns: 1fr; gap: 12px; padding: 24px 0; }
  .methV2-B .methV2-row .out { border-left: 2px solid var(--green); padding-left: 14px; }
  .methV2-C .methV2-stack-row { grid-template-columns: 1fr; gap: 18px; padding: 36px 0; }
  .methV2-C .methV2-stack-row .left .big { font-size: 64px; }
  .methV2-D .methV2-diagram { grid-template-columns: 1fr; gap: 0; }
  .methV2-D .methV2-diagram-foot { display: none; }
  .methV2-D .methV2-conn { padding: 8px 0; }
  .methV2-D .methV2-conn .line { display: none; }
  .methV2-D .methV2-conn .arrow { transform: rotate(90deg); }
}

/* ── 5 · Method (legacy) ─────────────────────────────────── */
.method-grid-v2 {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  overflow: hidden;
  background: var(--surface);
}
.method-col-v2 {
  padding: 40px 36px 40px;
  position: relative;
}
.method-col-v2 + .method-col-v2 { border-left: 1px solid var(--border); }
.method-col-v2.on::before {
  content: '';
  position: absolute; left: 0; top: 0; right: 0;
  height: 2px;
  background: var(--green);
}
.method-col-v2 .phase {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--fg-muted);
  margin-bottom: 6px;
}
.method-col-v2.on .phase { color: var(--green); }
.method-col-v2 .sub {
  font-family: var(--font-sans);
  font-size: 14px;
  color: var(--fg-muted);
  margin-bottom: 20px;
}
.method-col-v2 h3 {
  font-size: 24px;
  font-weight: 500;
  color: var(--fg);
  margin-bottom: 16px;
  letter-spacing: -0.01em;
}
.method-col-v2 p {
  font-size: 15.5px;
  line-height: 1.55;
  color: var(--fg-2);
  margin-bottom: 32px;
}
.method-col-v2 .commitment {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 14px 16px;
  background: var(--bg-deep);
  border: 1px solid var(--border-subtle);
  border-left: 2px solid var(--green-mid);
  border-radius: 6px;
  font-family: var(--font-sans);
  font-style: italic;
  font-size: 13.5px;
  color: var(--fg-2);
  line-height: 1.4;
}
.method-col-v2.on .commitment {
  border-left-color: var(--green);
  background: rgba(62,207,106,0.04);
  color: var(--fg);
}
.method-closing {
  margin-top: 32px;
  font-size: 17px;
  color: var(--fg-2);
  text-align: center;
}

/* ── 6b · Proof V2 variants (B/C) ────────────────────── */

/* ─── B · CASE DOSSIER ─── */
.proofV2-B .dossier {
  display: grid;
  grid-template-columns: 260px 1fr;
  gap: 0;
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  overflow: hidden;
  background: var(--surface);
  margin-bottom: 56px;
}
.proofV2-B .dossier-side {
  background: var(--bg-deep);
  border-right: 1px solid var(--border);
  padding: 32px 28px;
  display: flex; flex-direction: column; gap: 24px;
}
.proofV2-B .dossier-tag {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--green);
}
.proofV2-B .dossier-tag::before {
  content: ''; width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--green);
  box-shadow: 0 0 8px var(--green);
}
.proofV2-B .dossier-meta {
  display: flex; flex-direction: column; gap: 12px;
}
.proofV2-B .dossier-meta > div {
  display: flex; flex-direction: column; gap: 3px;
  padding-bottom: 10px;
  border-bottom: 1px dashed var(--border);
}
.proofV2-B .dossier-meta > div:last-child { border-bottom: none; }
.proofV2-B .dossier-meta span {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--fg-muted);
}
.proofV2-B .dossier-meta b {
  font-size: 14px;
  color: var(--fg);
  font-weight: 500;
}
.proofV2-B .dossier-meta b.ok { color: var(--green); }

.proofV2-B .dossier-body {
  padding: 40px 44px 36px;
}
.proofV2-B .dossier-body h3 {
  font-size: clamp(26px, 2.5vw, 34px);
  font-weight: 400;
  line-height: 1.15;
  letter-spacing: -0.02em;
  margin-bottom: 18px;
  text-wrap: balance;
}
.proofV2-B .dossier-body > p {
  font-size: 16px;
  line-height: 1.55;
  color: var(--fg-2);
  margin-bottom: 28px;
  max-width: 62ch;
}
.proofV2-B .dossier-timeline {
  display: flex; flex-direction: column;
  border-top: 1px dashed var(--border);
  margin-bottom: 32px;
}
.proofV2-B .dossier-timeline .row {
  display: grid;
  grid-template-columns: 96px 1fr;
  gap: 18px;
  padding: 12px 0;
  align-items: baseline;
  border-bottom: 1px dashed var(--border);
}
.proofV2-B .dossier-timeline .month {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.12em;
  color: var(--green);
}
.proofV2-B .dossier-timeline .ev {
  font-size: 14px;
  color: var(--fg-2);
}
.proofV2-B .dossier-kpis {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  background: var(--border);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  overflow: hidden;
  margin-bottom: 32px;
}
.proofV2-B .dossier-kpis .kpi {
  background: var(--bg-deep);
  padding: 20px 18px;
}
.proofV2-B .dossier-kpis .v {
  font-family: var(--font-sans);
  font-size: 30px;
  font-weight: 400;
  letter-spacing: -0.02em;
  color: var(--fg);
  margin-bottom: 8px;
}
.proofV2-B .dossier-kpis .v span {
  font-family: var(--font-mono);
  font-size: 0.42em;
  color: var(--green);
  margin-left: 4px;
  letter-spacing: 0;
}
.proofV2-B .dossier-kpis .l {
  font-size: 12px;
  line-height: 1.4;
  color: var(--fg-muted);
}
.proofV2-B .dossier-pull {
  margin: 0;
  padding: 22px 26px;
  background: rgba(62,207,106,0.04);
  border-left: 2px solid var(--green);
  border-radius: 0 var(--r-md) var(--r-md) 0;
  position: relative;
  font-size: 18px;
  line-height: 1.5;
  color: var(--fg);
  font-style: italic;
}
.proofV2-B .dossier-pull .mark {
  font-family: var(--font-mono);
  font-size: 32px;
  color: var(--green);
  margin-right: 6px;
  line-height: 0;
  position: relative; top: 4px;
}
.proofV2-B .dossier-pull footer {
  margin-top: 12px;
  font-family: var(--font-mono);
  font-size: 11px;
  font-style: normal;
  letter-spacing: 0.06em;
  color: var(--fg-muted);
}

/* ─── C · SPEC SHEET ─── */
.proofV2-C .spec-head {
  margin-bottom: 28px;
}
.proofV2-C .spec-meta {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  background: var(--border);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  overflow: hidden;
}
.proofV2-C .spec-meta > div {
  background: var(--bg-deep);
  padding: 14px 18px;
  display: flex; flex-direction: column; gap: 4px;
}
.proofV2-C .spec-meta span {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--fg-muted);
}
.proofV2-C .spec-meta b {
  font-size: 15px;
  color: var(--fg);
  font-weight: 500;
}
.proofV2-C .spec-meta b.accent { color: var(--green); }

.proofV2-C .spec-table {
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  overflow: hidden;
  background: var(--surface);
  margin-bottom: 32px;
}
.proofV2-C .spec-th,
.proofV2-C .spec-row {
  display: grid;
  grid-template-columns: 1.5fr 1fr 1fr 1.4fr;
  align-items: center;
  gap: 24px;
  padding: 14px 22px;
}
.proofV2-C .spec-th {
  background: var(--bg-deep);
  border-bottom: 1px solid var(--border);
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--fg-muted);
}
.proofV2-C .spec-row {
  border-bottom: 1px solid var(--border-subtle);
}
.proofV2-C .spec-row:last-child { border-bottom: none; }
.proofV2-C .spec-row .lab {
  font-size: 14px;
  color: var(--fg);
}
.proofV2-C .spec-row .bef {
  font-family: var(--font-mono);
  font-size: 13px;
  color: var(--fg-muted);
  text-decoration: line-through;
  text-decoration-color: rgba(193, 75, 75, 0.55);
}
.proofV2-C .spec-row .aft {
  font-family: var(--font-mono);
  font-size: 13px;
  color: var(--fg);
}
.proofV2-C .spec-row .del {
  display: flex; align-items: center; gap: 12px;
  font-family: var(--font-mono);
  font-size: 13px;
  font-weight: 600;
}
.proofV2-C .spec-row .del.good { color: var(--green); }
.proofV2-C .spec-row .del.flat { color: var(--fg-muted); }
.proofV2-C .spec-row .del .bar {
  flex: 1;
  display: block;
  height: 4px;
  background: var(--border);
  border-radius: 2px;
  overflow: hidden;
  max-width: 120px;
}
.proofV2-C .spec-row .del .bar i {
  display: block;
  height: 100%;
  background: var(--green);
  border-radius: 2px;
  box-shadow: 0 0 8px var(--green);
}
.proofV2-C .spec-row .del.flat .bar i { background: var(--border-strong); box-shadow: none; }

.proofV2-C .spec-foot {
  display: flex; align-items: center; justify-content: space-between;
  gap: 32px;
  padding: 28px 0 0;
  border-top: 1px dashed var(--border);
  flex-wrap: wrap;
}
.proofV2-C .spec-foot p {
  flex: 1;
  font-size: 16px;
  line-height: 1.55;
  color: var(--fg-2);
  max-width: 60ch;
}

@media (max-width: 980px) {
  .proofV2-B .dossier { grid-template-columns: 1fr; }
  .proofV2-B .dossier-side { border-right: none; border-bottom: 1px solid var(--border); }
  .proofV2-B .dossier-body { padding: 32px 26px; }
  .proofV2-B .dossier-kpis { grid-template-columns: repeat(2, 1fr); }
  .proofV2-C .spec-meta { grid-template-columns: repeat(2, 1fr); }
  .proofV2-C .spec-th { display: none; }
  .proofV2-C .spec-row {
    grid-template-columns: 1fr;
    gap: 6px;
    padding: 16px 18px;
  }
  .proofV2-C .spec-row .bef::before { content: 'Before · '; color: var(--fg-muted); }
  .proofV2-C .spec-row .aft::before { content: 'After · '; color: var(--fg-muted); }
  .proofV2-C .spec-row .del .bar { max-width: 100%; }
}

/* ── 6 · Proof (legacy A) ─────────────────────────── */
.proof-metrics {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  overflow: hidden;
  background: var(--surface);
  margin-bottom: 48px;
}
.proof-metric {
  padding: 44px 32px;
  text-align: left;
}
.proof-metric + .proof-metric { border-left: 1px solid var(--border); }
.proof-metric .v {
  font-size: clamp(36px, 3.6vw, 52px);
  font-weight: 400;
  letter-spacing: -0.03em;
  color: var(--fg);
  line-height: 1;
  margin-bottom: 14px;
}
.proof-metric .v .accent { color: var(--green); }
.proof-metric .l {
  font-size: 14px;
  line-height: 1.4;
  color: var(--fg-muted);
}

.proof-paragraph {
  max-width: 820px;
  font-size: 17px;
  line-height: 1.6;
  color: var(--fg-2);
  margin-bottom: 24px;
}
.proof-attribution {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.05em;
  color: var(--fg-muted);
  padding: 16px 0;
  border-top: 1px solid var(--border-subtle);
  border-bottom: 1px solid var(--border-subtle);
  margin-bottom: 64px;
  display: flex; align-items: center; gap: 10px;
}
.proof-attribution::before {
  content: '↳';
  color: var(--green);
}
.proof-demo {
  display: flex; align-items: center; justify-content: space-between;
  gap: 32px;
  padding: 40px 44px;
  background: var(--surface-2);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  flex-wrap: wrap;
}
.proof-demo h4 {
  font-size: 26px;
  font-weight: 500;
  letter-spacing: -0.01em;
  color: var(--fg);
  margin-bottom: 8px;
}
.proof-demo p {
  font-size: 15px;
  color: var(--fg-2);
  max-width: 520px;
}

/* ── 7b · Pricing (V2 variants) ─────────────────────────── */

.prV2 { max-width: 1100px; margin: 0 auto; }
.prV2-anchor {
  margin-top: 32px;
  max-width: 780px;
  font-size: 15px;
  line-height: 1.6;
  color: var(--fg-muted);
  text-align: center;
  margin-left: auto; margin-right: auto;
  text-wrap: pretty;
}

/* ── Variant A · TICKET STUB ── */
.prV2-A-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  overflow: hidden;
}
.prV2-A-top {
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: 32px;
  padding: 40px 44px 32px;
  align-items: end;
}
.prV2-A-top .kicker {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--green);
  margin-bottom: 10px;
}
.prV2-A-top .head {
  font-size: 28px;
  font-weight: 500;
  line-height: 1.2;
  color: var(--fg);
  letter-spacing: -0.01em;
  text-wrap: balance;
  max-width: 24ch;
}
.prV2-A-top .right { text-align: right; }
.prV2-A-top .amount {
  font-size: clamp(48px, 5vw, 64px);
  font-weight: 400;
  letter-spacing: -0.02em;
  color: var(--fg);
  line-height: 1;
}
.prV2-A-top .amount span {
  font-size: 18px;
  color: var(--fg-muted);
  margin-left: 6px;
  letter-spacing: 0;
}
.prV2-A-top .sub {
  margin-top: 8px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.06em;
  color: var(--fg-muted);
}
.prV2-A-perf {
  height: 1px;
  background-image: linear-gradient(90deg, var(--border) 50%, transparent 50%);
  background-size: 8px 1px;
}
.prV2-A-feats {
  padding: 28px 44px 32px;
}
.prV2-A-feats .t {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--green);
  margin-bottom: 14px;
}
.prV2-A-feats ul {
  list-style: none; padding: 0; margin: 0;
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 10px 32px;
}
.prV2-A-feats li {
  font-size: 14.5px;
  color: var(--fg-2);
  padding-left: 18px;
  position: relative;
  line-height: 1.4;
}
.prV2-A-feats li::before {
  content: '✓';
  position: absolute; left: 0; top: 0;
  color: var(--green);
  font-size: 12px;
}
.prV2-A-bot {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 24px;
  padding: 28px 44px 36px;
  align-items: center;
}
.prV2-A-bot .g .lbl {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--green);
  margin-bottom: 6px;
}
.prV2-A-bot .g .val {
  font-size: 15px;
  color: var(--fg);
  line-height: 1.45;
  max-width: 50ch;
}

/* ── Variant B · INVOICE LEDGER ── */
.prV2-B-doc {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: 48px;
}
.prV2-B-head {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 32px;
  padding-bottom: 28px;
  border-bottom: 1px solid var(--border);
  margin-bottom: 28px;
  align-items: start;
}
.prV2-B-head .meta { display: flex; flex-direction: column; gap: 8px; }
.prV2-B-head .meta .row {
  display: grid;
  grid-template-columns: 110px 1fr;
  gap: 16px;
  font-family: var(--font-mono);
  font-size: 12px;
  align-items: baseline;
}
.prV2-B-head .meta .row span {
  color: var(--fg-muted);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  font-size: 10px;
}
.prV2-B-head .meta .row b {
  color: var(--fg);
  font-weight: 500;
  letter-spacing: 0;
}
.prV2-B-head .num {
  font-family: var(--font-mono);
  font-size: 13px;
  color: var(--green);
  letter-spacing: 0.12em;
}
.prV2-B-table { margin-bottom: 36px; }
.prV2-B-row {
  display: grid;
  grid-template-columns: 1fr 80px 120px;
  gap: 16px;
  padding: 14px 0;
  border-bottom: 1px solid var(--border-subtle);
  font-size: 14.5px;
  color: var(--fg);
  align-items: baseline;
}
.prV2-B-row.prV2-B-tablehead {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--fg-muted);
  padding-bottom: 10px;
}
.prV2-B-row .qty { text-align: center; font-family: var(--font-mono); }
.prV2-B-row .amt { text-align: right; font-family: var(--font-mono); }
.prV2-B-row.prV2-B-total {
  border-bottom: none;
  border-top: 2px solid var(--green);
  margin-top: 4px;
  font-size: 16px;
  padding-top: 18px;
}
.prV2-B-row.prV2-B-total b {
  font-size: 22px;
  color: var(--green);
  font-weight: 500;
}
.prV2-B-grid {
  display: grid;
  grid-template-columns: 1.3fr 1fr;
  gap: 48px;
  padding-bottom: 32px;
  border-bottom: 1px solid var(--border);
  margin-bottom: 28px;
}
.prV2-B-grid .col .t {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--green);
  margin-bottom: 12px;
}
.prV2-B-grid .col ul {
  list-style: none; padding: 0; margin: 0;
  display: flex; flex-direction: column; gap: 8px;
}
.prV2-B-grid .col li {
  font-size: 14px; color: var(--fg-2);
  padding-left: 16px;
  position: relative;
  line-height: 1.4;
}
.prV2-B-grid .col li::before {
  content: '·';
  position: absolute; left: 4px; top: 0;
  color: var(--green);
  font-weight: 700;
}
.prV2-B-grid .col p { font-size: 14.5px; color: var(--fg-2); line-height: 1.55; }
.prV2-B-foot {
  display: grid; grid-template-columns: 1fr auto; gap: 32px; align-items: center;
}
.prV2-B-foot p { font-size: 14px; color: var(--fg-muted); line-height: 1.55; max-width: 56ch; }

/* ── Variant C · TWO-PANE FOCUS ── */
.prV2-C-grid {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  overflow: hidden;
}
.prV2-C-price {
  padding: 44px 40px;
  background: var(--bg-deep);
  border-right: 1px solid var(--border);
  display: flex; flex-direction: column;
}
.prV2-C-price .kicker {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--green);
  margin-bottom: 16px;
}
.prV2-C-price .amt {
  font-size: clamp(56px, 6vw, 80px);
  font-weight: 400;
  letter-spacing: -0.02em;
  color: var(--fg);
  line-height: 1;
  display: flex; align-items: baseline; gap: 2px;
  margin-bottom: 12px;
}
.prV2-C-price .amt .cur { font-size: 32px; color: var(--fg-muted); }
.prV2-C-price .amt .per { font-size: 18px; color: var(--fg-muted); margin-left: 8px; }
.prV2-C-price .terms {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.06em;
  color: var(--fg-muted);
  margin-bottom: 28px;
}
.prV2-C-months {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 8px;
  margin-bottom: 28px;
}
.prV2-C-months .m {
  padding: 12px 10px;
  border: 1px solid var(--border);
  border-radius: 6px;
  background: var(--surface);
}
.prV2-C-months .m .n {
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--fg-muted);
  margin-bottom: 4px;
}
.prV2-C-months .m .a {
  font-size: 16px;
  color: var(--fg);
  font-weight: 500;
}
.prV2-C-price .btn { margin-bottom: 18px; }
.prV2-C-after {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.06em;
  color: var(--fg-muted);
  line-height: 1.5;
}
.prV2-C-feats {
  padding: 44px 40px;
  display: flex; flex-direction: column;
}
.prV2-C-feathead { margin-bottom: 24px; }
.prV2-C-feathead .t {
  font-size: 22px;
  font-weight: 500;
  color: var(--fg);
  letter-spacing: -0.01em;
  margin-bottom: 6px;
}
.prV2-C-feathead .s {
  font-size: 13.5px;
  color: var(--fg-muted);
}
.prV2-C-cols {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px 28px;
  flex: 1;
  margin-bottom: 24px;
}
.prV2-C-cols ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 10px; }
.prV2-C-cols li {
  font-size: 14px; color: var(--fg-2);
  display: flex; gap: 10px;
  line-height: 1.4;
}
.prV2-C-cols .ck {
  color: var(--green);
  font-size: 11px;
  flex-shrink: 0;
  padding-top: 3px;
}
.prV2-C-guarantee {
  padding: 16px 18px;
  background: rgba(62,207,106,0.05);
  border: 1px solid var(--border-green);
  border-radius: 8px;
  font-size: 14px;
  color: var(--fg);
  line-height: 1.45;
}
.prV2-C-guarantee .lbl {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--green);
  margin-bottom: 4px;
}

@media (max-width: 980px) {
  .prV2-A-top { grid-template-columns: 1fr; gap: 20px; padding: 32px 28px 24px; }
  .prV2-A-top .right { text-align: left; }
  .prV2-A-feats { padding: 24px 28px; }
  .prV2-A-feats ul { grid-template-columns: 1fr; }
  .prV2-A-bot { grid-template-columns: 1fr; padding: 24px 28px 32px; }
  .prV2-B-doc { padding: 32px 24px; }
  .prV2-B-head { grid-template-columns: 1fr; }
  .prV2-B-grid { grid-template-columns: 1fr; gap: 28px; }
  .prV2-B-foot { grid-template-columns: 1fr; }
  .prV2-C-grid { grid-template-columns: 1fr; }
  .prV2-C-cols { grid-template-columns: 1fr; }
}

/* ── 7 · Pricing (legacy) ─────────────────────────────────── */
.pricing-layout {
  display: grid;
  grid-template-columns: 1.15fr 1fr;
  gap: 24px;
}
.price-card {
  padding: 44px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  position: relative;
}
.price-card .label {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--green);
  font-style: normal;
  margin-bottom: 16px;
}
.price-card .price-row {
  display: flex; align-items: baseline; gap: 12px;
  margin-bottom: 8px;
}
.price-card .big {
  font-size: clamp(56px, 5.8vw, 80px);
  font-weight: 400;
  letter-spacing: -0.03em;
  line-height: 1;
  color: var(--fg);
}
.price-card .unit {
  font-size: 18px;
  color: var(--fg-muted);
}
.price-card .terms {
  font-size: 15px;
  color: var(--fg-2);
  margin-bottom: 36px;
}
.price-months-v2 {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
  margin-bottom: 36px;
}
.price-months-v2 .pm {
  padding: 16px 18px;
  background: var(--bg-deep);
  border: 1px solid var(--border);
  border-radius: 8px;
}
.price-months-v2 .pm .n {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.12em;
  color: var(--fg-muted);
  margin-bottom: 6px;
}
.price-months-v2 .pm .a {
  font-size: 20px;
  font-weight: 500;
  color: var(--fg);
}

.feats-list {
  list-style: none;
  margin: 0 0 36px;
}
.feats-list li {
  display: flex; align-items: flex-start; gap: 12px;
  padding: 12px 0;
  border-top: 1px solid var(--border-subtle);
  font-size: 15px;
  line-height: 1.45;
  color: var(--fg-2);
}
.feats-list li:first-child { border-top: none; padding-top: 0; }
.feats-list li .ck {
  flex-shrink: 0;
  width: 16px; height: 16px;
  border-radius: 50%;
  border: 1px solid var(--border-green);
  background: rgba(62,207,106,0.08);
  color: var(--green);
  display: grid; place-items: center;
  font-size: 9px;
  margin-top: 3px;
}

.guarantee-v2 {
  padding: 36px 40px 40px;
  background: var(--surface-2);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  position: relative;
  overflow: hidden;
}
.guarantee-v2::before {
  content: '';
  position: absolute; left: 0; top: 0; bottom: 0;
  width: 2px;
  background: var(--green);
}
.guarantee-v2 .label {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--green);
  margin-bottom: 24px;
  display: inline-flex; align-items: center; gap: 10px;
}
.guarantee-v2 .label svg {
  width: 14px; height: 14px;
}
.guarantee-v2 h3 {
  font-size: 26px;
  font-weight: 500;
  color: var(--fg);
  letter-spacing: -0.015em;
  line-height: 1.2;
  margin-bottom: 16px;
}
.guarantee-v2 h3 .accent { color: var(--green); }
.guarantee-v2 p {
  font-size: 15px;
  line-height: 1.55;
  color: var(--fg-2);
}

.pricing-anchor {
  margin-top: 56px;
  padding: 32px 0 0;
  border-top: 1px solid var(--border-subtle);
  max-width: 820px;
  font-size: 16px;
  line-height: 1.6;
  color: var(--fg-2);
}
.pricing-after {
  margin-top: 16px;
  font-size: 14px;
  color: var(--fg-muted);
  max-width: 820px;
}
.pricing-cta {
  margin-top: 40px;
  display: flex; justify-content: center;
}

/* ── 8 · Who ─────────────────────────────────── */
.who-v2-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
}
.who-v2-col {
  padding: 40px 36px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
}
.who-v2-col.fit {
  background: var(--surface-2);
  position: relative;
}
.who-v2-col.fit::before {
  content: '';
  position: absolute; left: 0; top: 0; bottom: 0;
  width: 2px;
  background: var(--green);
}
.who-v2-col .label {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--fg-muted);
  margin-bottom: 8px;
}
.who-v2-col.fit .label { color: var(--green); }
.who-v2-col h4 {
  font-size: 22px;
  font-weight: 500;
  color: var(--fg);
  margin-bottom: 28px;
  letter-spacing: -0.01em;
}
.who-v2-col ul {
  list-style: none;
}
.who-v2-col li {
  display: flex; align-items: flex-start; gap: 14px;
  padding: 14px 0;
  font-size: 15.5px;
  line-height: 1.55;
  color: var(--fg-2);
  border-top: 1px solid var(--border-subtle);
}
.who-v2-col li:first-child { border-top: none; padding-top: 0; }
.who-v2-col li .marker {
  flex-shrink: 0;
  margin-top: 4px;
  width: 16px; height: 16px;
  border-radius: 50%;
  display: grid; place-items: center;
}
.who-v2-col.fit li .marker {
  border: 1px solid var(--border-green);
  background: rgba(62,207,106,0.08);
  color: var(--green);
  font-size: 9px;
}
.who-v2-col:not(.fit) li .marker {
  border: 1px solid var(--border);
  color: var(--fg-dim);
}
.who-v2-col:not(.fit) li .marker::before {
  content: '';
  width: 5px; height: 5px;
  background: var(--fg-dim);
  border-radius: 50%;
}

/* ── 9 · Closing — RESET base ────────────────────────── */
.closing-v2 {
  padding: 140px 0 120px;
  position: relative;
  border-top: 1px solid var(--border-subtle);
  background:
    radial-gradient(ellipse 900px 500px at 50% 60%, rgba(62,207,106,0.07), transparent 70%),
    var(--bg-deep);
  overflow: hidden;
}
.closing-v2::before {
  content: '';
  position: absolute; inset: 0;
  background-image:
    linear-gradient(var(--border-subtle) 1px, transparent 1px),
    linear-gradient(90deg, var(--border-subtle) 1px, transparent 1px);
  background-size: 64px 64px;
  background-position: center;
  mask-image: radial-gradient(ellipse 700px 380px at 50% 50%, black, transparent 70%);
  -webkit-mask-image: radial-gradient(ellipse 700px 380px at 50% 50%, black, transparent 70%);
  opacity: 0.5;
  pointer-events: none;
}
.closing-v2-inner {
  position: relative;
  max-width: 1180px;
  margin: 0 auto;
  padding: 0 48px;
}

/* shared closeV2 base */
.closeV2 h2 {
  font-size: clamp(38px, 4.4vw, 60px);
  font-weight: 400;
  line-height: 1.06;
  letter-spacing: -0.025em;
  color: var(--fg);
  text-wrap: balance;
}
.closeV2 h2 .accent { color: var(--green); }
.closeV2 p {
  font-size: 17px;
  line-height: 1.55;
  color: var(--fg-2);
  text-wrap: pretty;
}
.closeV2-eyebrow {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--green);
  margin-bottom: 28px;
}
.closeV2-eyebrow .dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--green); box-shadow: 0 0 10px var(--green);
}
.closeV2-eyebrow .rule {
  width: 28px; height: 1px; background: var(--border-green);
}

.btn-ghost-v2 {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 14px 22px;
  font-size: 14px;
  color: var(--fg-2);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  background: transparent;
  transition: all 0.18s ease;
}
.btn-ghost-v2:hover { color: var(--fg); border-color: var(--border-green); }

/* ─── A · MANIFESTO ─── */
.closeV2-A { text-align: center; max-width: 760px; margin: 0 auto; }
.closeV2-A .closeV2-eyebrow { justify-content: center; }
.closeV2-A h2 { margin-bottom: 26px; }
.closeV2-A p { max-width: 580px; margin: 0 auto 36px; }
.closeV2-A .closeV2-actions {
  display: inline-flex; align-items: center; gap: 16px;
  margin-bottom: 36px;
}
.closeV2-A .closeV2-foot {
  display: inline-flex; align-items: center; gap: 16px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.1em;
  color: var(--fg-muted);
}
.closeV2-A .closeV2-foot i {
  width: 4px; height: 4px; border-radius: 50%;
  background: var(--border-strong);
  display: inline-block;
}

/* ─── B · LETTER CARD ─── */
.closeV2-B { max-width: 780px; margin: 0 auto; }
.closeV2-B .closeV2-letter {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: 48px 52px 44px;
  box-shadow: 0 24px 60px rgba(0,0,0,0.4);
  position: relative;
}
.closeV2-B .letter-head {
  display: flex; justify-content: space-between; align-items: center;
  padding-bottom: 22px;
  margin-bottom: 28px;
  border-bottom: 1px dashed var(--border);
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}
.closeV2-B .letter-head .from { color: var(--green); }
.closeV2-B .letter-head .date { color: var(--fg-muted); }
.closeV2-B h2 { margin-bottom: 22px; }
.closeV2-B p { margin-bottom: 18px; max-width: 60ch; }
.closeV2-B .letter-foot {
  margin-top: 32px;
  padding-top: 28px;
  border-top: 1px dashed var(--border);
  display: flex; justify-content: space-between; align-items: center;
  gap: 24px;
  flex-wrap: wrap;
}
.closeV2-B .letter-meta {
  display: flex; flex-direction: column; gap: 4px;
  text-align: right;
}
.closeV2-B .letter-meta .row {
  display: flex; gap: 12px; align-items: baseline;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.06em;
}
.closeV2-B .letter-meta .row span { color: var(--fg-muted); }
.closeV2-B .letter-meta .row b {
  color: var(--fg); font-weight: 500;
}

/* ─── C · APPLY FORM PREVIEW ─── */
.closeV2-C {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: center;
}
.closeV2-C .closeV2-Cleft h2 { margin-bottom: 22px; }
.closeV2-C .closeV2-Cleft p { margin-bottom: 32px; max-width: 50ch; }
.closeV2-C .closeV2-Cstats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--border);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  overflow: hidden;
}
.closeV2-C .closeV2-Cstats > div {
  background: var(--bg-deep);
  padding: 18px 16px;
  display: flex; flex-direction: column; gap: 4px;
}
.closeV2-C .closeV2-Cstats b {
  font-family: var(--font-mono);
  font-size: 22px; font-weight: 600;
  color: var(--green);
  letter-spacing: -0.02em;
}
.closeV2-C .closeV2-Cstats span {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--fg-muted);
}

.closeV2-C .apply-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: 32px 30px 26px;
  box-shadow: 0 24px 60px rgba(0,0,0,0.4);
}
.closeV2-C .apply-row {
  display: flex; flex-direction: column; gap: 6px;
  margin-bottom: 16px;
}
.closeV2-C .apply-row label {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--fg-muted);
}
.closeV2-C .apply-input {
  background: var(--bg-deep);
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  padding: 12px 14px;
  font-size: 14px;
  color: var(--fg);
  font-family: var(--font-mono);
}
.closeV2-C .apply-input.ta {
  min-height: 70px;
  font-family: var(--font-sans);
  line-height: 1.5;
  color: var(--fg-2);
}
.closeV2-C .apply-cta { width: 100%; justify-content: center; margin-top: 8px; }
.closeV2-C .apply-foot {
  margin-top: 14px;
  text-align: center;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.06em;
  color: var(--fg-muted);
}

/* ─── D · SPOTLIGHT RAIL ─── */
.closeV2-D {
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: 80px;
  align-items: center;
}
.closeV2-D .closeV2-Dleft h2 { margin-bottom: 22px; }
.closeV2-D .closeV2-Dleft p { margin-bottom: 32px; max-width: 52ch; }
.closeV2-D .closeV2-Dactions {
  display: inline-flex; align-items: center; gap: 14px;
}
.closeV2-D .closeV2-Dright {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: 32px 36px;
}
.closeV2-D .closeV2-Dhead {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--green);
  margin-bottom: 24px;
  padding-bottom: 18px;
  border-bottom: 1px dashed var(--border);
}
.closeV2-D .closeV2-Dsteps {
  list-style: none; padding: 0; margin: 0;
  display: flex; flex-direction: column; gap: 22px;
}
.closeV2-D .closeV2-Dsteps li {
  display: grid;
  grid-template-columns: 42px 1fr;
  gap: 16px;
  align-items: baseline;
}
.closeV2-D .closeV2-Dsteps .n {
  font-family: var(--font-mono);
  font-size: 14px; font-weight: 600;
  color: var(--green);
  letter-spacing: 0.04em;
}
.closeV2-D .closeV2-Dsteps b {
  display: block;
  font-size: 15px; font-weight: 500;
  color: var(--fg);
  margin-bottom: 3px;
}
.closeV2-D .closeV2-Dsteps i {
  display: block;
  font-style: normal;
  font-size: 13px;
  color: var(--fg-muted);
}

@media (max-width: 980px) {
  .closeV2-C, .closeV2-D { grid-template-columns: 1fr; gap: 40px; }
  .closing-v2 { padding: 96px 0 80px; }
  .closing-v2-inner { padding: 0 24px; }
  .closeV2-B .closeV2-letter { padding: 32px 26px; }
}

/* ── 9 · Closing (legacy h2/p shims — preserved for safety) ── */

/* ── Tweak panel — hero visual switch ─────────────────── */
.tweak-panel-v2 {
  position: fixed;
  bottom: 24px; right: 24px;
  z-index: 999;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: 14px;
  width: 280px;
  max-height: calc(100vh - 48px);
  overflow-y: auto;
  overscroll-behavior: contain;
  box-shadow: 0 12px 32px rgba(0,0,0,0.5);
  opacity: 0;
  visibility: hidden;
  transform: translateY(8px);
  transition: opacity 0.25s ease, transform 0.25s ease, visibility 0.25s ease;
  scrollbar-width: thin;
  scrollbar-color: var(--border-strong) transparent;
}
.tweak-panel-v2::-webkit-scrollbar { width: 8px; }
.tweak-panel-v2::-webkit-scrollbar-track { background: transparent; }
.tweak-panel-v2::-webkit-scrollbar-thumb {
  background: var(--border-strong);
  border-radius: 4px;
  border: 2px solid var(--surface);
}
.tweak-panel-v2.on {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}
.tweak-panel-v2 h5 {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--green);
  margin-bottom: 8px;
  display: flex; align-items: center; gap: 8px;
  position: sticky;
  top: -14px;
  background: var(--surface);
  padding: 8px 0 4px;
  z-index: 2;
}
.tweak-panel-v2 h5::before {
  content: '';
  width: 6px; height: 6px;
  background: var(--green);
  border-radius: 50%;
  box-shadow: 0 0 8px var(--green);
}
.tweak-row-v2 {
  display: flex; align-items: center;
  padding: 8px 10px;
  border-radius: 8px;
  cursor: pointer;
  margin-bottom: 3px;
  border: 1px solid transparent;
  transition: all 0.15s ease;
}
.tweak-row-v2:hover {
  background: var(--bg-deep);
}
.tweak-row-v2.on {
  background: rgba(62,207,106,0.06);
  border-color: var(--border-green);
}
.tweak-row-v2 .lab {
  flex: 1;
  display: flex; flex-direction: column; gap: 2px;
}
.tweak-row-v2 .lab b {
  font-size: 13px;
  font-weight: 500;
  color: var(--fg);
}
.tweak-row-v2 .lab small {
  font-size: 11px;
  color: var(--fg-muted);
}
.tweak-row-v2 .v {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--fg-muted);
  letter-spacing: 0.08em;
}
.tweak-row-v2.on .v { color: var(--green); }

/* ── Reveal ─────────────────────────────────── */
[data-reveal] {
  opacity: 0;
  transform: translateY(16px);
  transition: opacity 0.6s ease, transform 0.6s ease;
}
[data-reveal].in {
  opacity: 1;
  transform: translateY(0);
}
[data-reveal-delay="1"] { transition-delay: 0.08s; }
[data-reveal-delay="2"] { transition-delay: 0.16s; }
[data-reveal-delay="3"] { transition-delay: 0.24s; }

/* ── Responsive ─────────────────────────────────── */
@media (max-width: 1100px) {
  .heroV2-screens { height: auto; padding-bottom: 60px; }
  .ops-main { position: static; width: 100%; max-width: 880px; margin: 0 auto; transform: none; }
  .ops-float { position: static; width: 100%; max-width: 880px; margin: 16px auto 0; animation: none; }
  .insight-body { grid-template-columns: 1fr; gap: 16px; }
  .insight-compare { grid-template-columns: 1fr; }
  .insight-col + .insight-col { border-left: none; border-top: 1px solid var(--border); }
  .method-grid-v2 { grid-template-columns: 1fr; }
  .method-col-v2 + .method-col-v2 { border-left: none; border-top: 1px solid var(--border); }
  .proof-metrics { grid-template-columns: repeat(2, 1fr); }
  .proof-metric:nth-child(3) { border-left: none; border-top: 1px solid var(--border); }
  .proof-metric:nth-child(4) { border-top: 1px solid var(--border); }
  .pricing-layout { grid-template-columns: 1fr; }
  .who-v2-grid { grid-template-columns: 1fr; }
  .prob-grid-v2 { grid-template-columns: 1fr; }
  .integ-reassure { grid-template-columns: 1fr; gap: 24px; }
}
@media (max-width: 720px) {
  .secV2 { padding: 96px 0; }
  .heroV2-inner { padding: 0 24px; }
  .price-card, .guarantee-v2, .who-v2-col, .prob-card-v2, .insight-col, .method-col-v2 {
    padding: 28px 24px;
  }
  .price-months-v2 { grid-template-columns: 1fr; }
  .proof-metrics { grid-template-columns: 1fr; }
  .proof-metric { border-left: none !important; border-top: 1px solid var(--border); }
  .proof-metric:first-child { border-top: none; }
}

/* ── 10 · Apply (embedded form) ─────────────────────── */
.apply-section {
  padding: 96px 0 120px;
  border-top: 1px solid var(--border-subtle);
  background:
    radial-gradient(ellipse at center top, rgba(62,207,106,0.05) 0%, transparent 60%),
    var(--bg);
}
.apply-shell {
  max-width: 760px;
  margin: 0 auto;
  padding: 0 32px;
}
.apply-head {
  text-align: center;
  margin-bottom: 56px;
}
.apply-eyebrow {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: var(--font-mono);
  font-size: 11px; font-weight: 500;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--green);
  margin-bottom: 24px;
}
.apply-eyebrow .dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--green);
  box-shadow: 0 0 8px var(--green);
}
.apply-title {
  font-size: clamp(32px, 4vw, 48px);
  font-weight: 400;
  line-height: 1.1;
  letter-spacing: -0.02em;
  color: var(--fg);
  margin-bottom: 14px;
}
.apply-sub {
  font-size: 17px;
  line-height: 1.55;
  color: var(--fg-2);
  max-width: 560px;
  margin: 0 auto 32px;
}
.apply-progress {
  max-width: 480px; margin: 0 auto;
}
.apply-progress-meta {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--fg-muted);
  margin-bottom: 10px;
}
.apply-progress-track {
  height: 2px;
  background: var(--border);
  border-radius: 1px;
  overflow: hidden;
}
.apply-progress-fill {
  height: 100%;
  background: var(--green);
  border-radius: 1px;
  transition: width 420ms cubic-bezier(.2,.8,.2,1);
  box-shadow: 0 0 12px rgba(62,207,106,0.4);
}

.apply-body {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 48px 48px;
  min-height: 460px;
  display: flex;
  flex-direction: column;
}
.apply-screen {
  animation: applyFadeIn 320ms cubic-bezier(.2,.8,.2,1) both;
}
@keyframes applyFadeIn {
  from { opacity: 0; transform: translateY(10px); }
  to   { opacity: 1; transform: translateY(0); }
}
.apply-q-eyebrow {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--font-mono);
  font-size: 11px; font-weight: 500;
  letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--green);
  margin-bottom: 18px;
}
.apply-q-eyebrow .dot {
  width: 5px; height: 5px; border-radius: 50%;
  background: var(--green);
}
.apply-q-title {
  font-size: 26px;
  font-weight: 500;
  line-height: 1.25;
  letter-spacing: -0.018em;
  color: var(--fg);
  margin-bottom: 12px;
}
.apply-q-helper {
  color: var(--fg-muted);
  font-size: 14.5px;
  line-height: 1.55;
  max-width: 560px;
  margin-bottom: 28px;
}

/* Options */
.apply-options {
  display: flex; flex-direction: column;
  gap: 10px;
  margin-bottom: 28px;
}
.apply-option {
  display: flex; align-items: center; gap: 12px;
  padding: 16px 20px;
  background: var(--bg-deep);
  border: 1px solid var(--border);
  border-radius: 10px;
  cursor: pointer;
  text-align: left;
  font-family: inherit;
  font-size: 14.5px;
  line-height: 1.4;
  color: var(--fg);
  transition: border-color 180ms ease, background 180ms ease;
}
.apply-option:hover {
  border-color: var(--border-green);
  background: rgba(62,207,106,0.04);
}
.apply-option.selected {
  border-color: var(--green);
  background: rgba(62,207,106,0.08);
}
.apply-option-marker {
  width: 18px; height: 18px;
  border: 1px solid var(--border-strong);
  border-radius: 50%;
  flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  transition: border-color 180ms ease, background 180ms ease;
}
.apply-option.selected .apply-option-marker {
  border-color: var(--green);
  background: var(--green);
}
.apply-option.selected .apply-option-marker::after {
  content: '';
  width: 6px; height: 6px;
  background: var(--bg-deep);
  border-radius: 50%;
}

/* Inputs */
.apply-input-wrap {
  margin-bottom: 28px;
}
.apply-input {
  width: 100%;
  background: var(--bg-deep);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 16px 20px;
  color: var(--fg);
  font-family: inherit;
  font-size: 15px;
  line-height: 1.4;
  transition: border-color 180ms ease, background 180ms ease;
}
.apply-input:focus {
  outline: none;
  border-color: var(--green);
  background: rgba(62,207,106,0.04);
}
.apply-input.error {
  border-color: #ff6b6b;
}
.apply-textarea {
  resize: vertical;
  min-height: 120px;
}
.apply-err {
  color: #ff6b6b;
  font-size: 13px;
  margin-top: 10px;
}

/* Nav row */
.apply-nav {
  display: flex; align-items: center; gap: 14px;
  margin-top: auto;
  flex-wrap: wrap;
}
.apply-back {
  background: transparent;
  border: none;
  color: var(--fg-muted);
  font-family: inherit;
  font-size: 14px;
  font-weight: 500;
  padding: 12px 4px;
  cursor: pointer;
  transition: color 160ms ease;
}
.apply-back:hover { color: var(--fg); }
.apply-back:disabled { opacity: 0.5; cursor: not-allowed; }
.apply-cta {
  margin-left: auto;
}
.apply-cta:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.apply-hint {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--fg-muted);
  margin-top: 14px;
  letter-spacing: 0.04em;
}
.apply-hint kbd {
  background: var(--bg-deep);
  border: 1px solid var(--border);
  border-radius: 4px;
  padding: 2px 7px;
  font-family: inherit;
  font-size: 10px;
}
.apply-submit-err {
  margin-top: 16px;
  padding: 12px 16px;
  background: rgba(255,107,107,0.08);
  border: 1px solid rgba(255,107,107,0.3);
  border-radius: 8px;
  color: #ff6b6b;
  font-size: 13px;
}

/* Success */
.apply-success {
  text-align: center;
  padding: 24px 0;
  margin: auto 0;
}
.apply-success-eyebrow {
  color: var(--green);
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  margin-bottom: 20px;
}
.apply-success h3 {
  font-size: 28px;
  font-weight: 500;
  line-height: 1.2;
  letter-spacing: -0.02em;
  color: var(--fg);
  margin-bottom: 12px;
}
.apply-success p {
  color: var(--fg-2);
  font-size: 15px;
  line-height: 1.55;
}

@media (max-width: 720px) {
  .apply-section { padding: 72px 0 88px; }
  .apply-shell { padding: 0 20px; }
  .apply-body { padding: 32px 24px; min-height: 420px; }
  .apply-q-title { font-size: 22px; }
  .apply-q-helper { font-size: 14px; }
  .apply-option { padding: 14px 16px; font-size: 14px; }
  .apply-input { font-size: 14.5px; padding: 14px 16px; }
}
