/* ============================================================
   ZININ.AI · PARTNER PROGRAM — page-specific styles
   Builds on styles.css (tokens, page chrome).
============================================================ */

:root {
  --bar-h: 64px;
}

body.partners {
  background: var(--paper);
  color: var(--ink);
}
html, body { overflow-x: hidden; }
html { scroll-padding-top: 80px; }

/* ============================================================ TOP BAR */
.topbar {
  position: fixed; top: 0; left: 0; right: 0; z-index: 50;
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 24px;
  height: var(--bar-h);
  padding: 0 24px;
  background: var(--paper);
  color: var(--ink);
  border-bottom: var(--rule-w) solid var(--ink);
  transform: translateY(-100%);
  transition: transform 240ms ease;
}
.topbar.is-visible { transform: translateY(0); }
.topbar .brand { display: flex; align-items: center; gap: 18px; }
.topbar .brand .tag {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink);
  border-left: 1px solid var(--grey-20);
  padding-left: 18px;
  line-height: 1.4;
}
.topbar .brand .tag b { color: var(--red); font-weight: 700; }

.topnav {
  display: flex;
  gap: 22px;
  justify-content: center;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}
.topnav a { padding: 4px 0; border-bottom: 2px solid transparent; }
.topnav a:hover { border-color: var(--red); }

.topbar .actions { display: flex; align-items: center; gap: 14px; }

.lang-switch {
  display: inline-flex;
  border: 1.5px solid var(--ink);
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}
.lang-switch button {
  appearance: none;
  border: 0;
  background: transparent;
  color: var(--ink);
  padding: 6px 10px;
  cursor: pointer;
  border-right: 1px solid var(--ink);
  position: relative;
  line-height: 1;
}
.lang-switch button:last-child { border-right: 0; }
.lang-switch button[aria-pressed="true"] {
  background: var(--ink); color: var(--paper);
}
.lang-switch button[disabled] {
  color: var(--grey-40);
  cursor: not-allowed;
  background: repeating-linear-gradient(45deg, transparent 0 4px, var(--grey-10) 4px 5px);
}
.lang-switch button .soon {
  display: block;
  font-size: 8px;
  letter-spacing: 0.05em;
  color: var(--red);
  margin-top: 2px;
}

.cta-apply {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  background: var(--red);
  color: var(--paper);
  padding: 10px 16px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  font-weight: 700;
  line-height: 1;
}
.cta-apply::after { content: "→"; font-size: 14px; }
.cta-apply:hover { background: var(--ink); }

/* ============================================================ HERO */
.hero {
  position: relative;
  background: var(--red);
  color: var(--paper);
  padding: 56px 36px 48px;
  border-bottom: var(--rule-w) solid var(--ink);
  overflow: hidden;
  min-height: 100vh;
  display: grid;
  grid-template-rows: auto 1fr auto;
  gap: 32px;
}
.hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(to right, rgba(255,255,255,0.06) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(255,255,255,0.06) 1px, transparent 1px);
  background-size: calc(100% / 12) 100%, 100% 48px;
  pointer-events: none;
}
.hero > * { position: relative; z-index: 1; }

.hero-meta {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr 1fr 1fr;
  align-items: stretch;
  gap: 0;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  border-top: 2px solid var(--paper);
  border-bottom: 2px solid var(--paper);
}
.hero-meta .cell {
  padding: 14px 16px;
  border-right: 1px solid rgba(255,255,255,0.3);
  display: flex; flex-direction: column; gap: 6px;
}
.hero-meta .cell:last-child { border-right: 0; }
.hero-meta .cell .k { opacity: 0.7; font-size: 9px; letter-spacing: 0.18em; }
.hero-meta .cell .v { font-family: var(--font-display); font-size: 22px; line-height: 1; letter-spacing: -0.02em; text-transform: uppercase; }
.hero-meta .cell .v.live::before { content: ""; display: inline-block; width: 8px; height: 8px; background: var(--ink); margin-right: 8px; animation: blink 1.4s steps(2) infinite; vertical-align: middle; }
@keyframes blink { 50% { opacity: 0.25; } }

.hero-grid {
  display: grid;
  grid-template-columns: 8fr 4fr;
  gap: 36px;
  align-items: end;
}
.hero-wordmark {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: clamp(160px, 19vw, 300px);
  line-height: 0.78;
  letter-spacing: -0.055em;
  text-transform: uppercase;
  margin: 0;
  text-wrap: balance;
}
.hero-wordmark .dot { color: var(--paper); }
.hero-wordmark .tld { color: var(--paper); }

.hero-subline {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 18px;
  align-items: center;
  padding: 14px 0;
  margin: 8px 0 22px;
  border-top: 2px solid var(--paper);
  border-bottom: 2px solid var(--paper);
}
.hero-subline .ai-first {
  font-family: var(--font-display);
  font-size: clamp(40px, 4.5vw, 64px);
  line-height: 0.85;
  letter-spacing: -0.025em;
  text-transform: uppercase;
  color: var(--paper);
}
.hero-subline .ai-first .acc { color: var(--paper); }
.hero-subline .ai-first .slash { color: var(--paper); opacity: 0.5; }
.hero-subline .role {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  line-height: 1.5;
  border-left: 2px solid var(--paper);
  padding-left: 18px;
}
.hero-subline .role b { font-weight: 700; }

.hero-lede {
  font-family: var(--font-body);
  font-weight: 500;
  font-size: 18px;
  line-height: 1.5;
  margin: 0 0 24px;
  max-width: 46ch;
}

.hero-sig {
  display: flex;
  align-items: center;
  gap: 18px;
  margin: 0 0 26px;
  max-width: 520px;
}
.hero-sig-photo {
  width: 84px;
  height: 84px;
  flex: none;
  border-radius: 50% !important;
  object-fit: cover;
  object-position: center 22%;
  filter: grayscale(1) contrast(1.08);
}
.hero-sig-text {
  display: flex; flex-direction: column; gap: 6px;
  line-height: 1.3;
}
.hero-sig-quote {
  font-family: var(--font-display);
  font-size: 22px;
  line-height: 1.05;
  letter-spacing: -0.015em;
  text-transform: uppercase;
  margin: 0;
  text-wrap: balance;
}
.hero-sig-attrib {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  opacity: 0.85;
}
.hero-sig-attrib b { font-weight: 700; opacity: 1; }

/* persistent in-hero language switcher (top right) */
.hero-lang {
  position: absolute;
  top: 24px; right: 24px;
  z-index: 3;
  display: inline-flex;
  border: 1.5px solid var(--paper);
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  background: rgba(0,0,0,0.08);
}
.hero-lang button {
  appearance: none; border: 0;
  background: transparent;
  color: var(--paper);
  padding: 8px 12px;
  cursor: pointer;
  border-right: 1px solid rgba(255,255,255,0.4);
  line-height: 1;
  position: relative;
}
.hero-lang button:last-child { border-right: 0; }
.hero-lang button[aria-pressed="true"] {
  background: var(--paper); color: var(--red);
}
.hero-lang button[disabled] {
  opacity: 0.5;
  cursor: not-allowed;
}
.hero-lang button .soon {
  display: block;
  font-size: 7px;
  letter-spacing: 0.05em;
  margin-top: 1px;
}

/* ============================================================ PARTNERS */
.partners-wrap {
  margin-top: 56px;
}
.partners-eye {
  display: flex; justify-content: space-between; align-items: end;
  border-bottom: 2px solid currentColor;
  padding-bottom: 14px;
  margin-bottom: 24px;
}
.partners-eye h3 {
  font-family: var(--font-display);
  font-size: clamp(36px, 4vw, 56px);
  line-height: 0.9;
  letter-spacing: -0.025em;
  text-transform: uppercase;
  margin: 0;
  max-width: 22ch;
}
.partners-eye .legend {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  text-align: right;
  line-height: 1.5;
}

.partner-tabs {
  display: flex;
  gap: 0;
  border: 2px solid currentColor;
  margin-bottom: 24px;
  overflow: hidden;
  flex-wrap: wrap;
}
.partner-tabs .tab {
  appearance: none; border: 0;
  background: transparent;
  color: inherit;
  padding: 12px 16px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  cursor: pointer;
  border-right: 1px solid currentColor;
  display: flex; align-items: center; gap: 8px;
  line-height: 1;
}
.partner-tabs .tab:last-child { border-right: 0; }
.partner-tabs .tab .count {
  font-family: var(--font-display);
  font-size: 13px;
  letter-spacing: 0;
  background: currentColor;
  padding: 2px 6px;
  line-height: 1;
}
.partner-tabs .tab .count::before {
  content: attr(data-n);
  color: var(--paper);
  mix-blend-mode: difference;
}
.partner-tabs .tab.active {
  background: var(--red);
  color: var(--paper);
  border-right-color: var(--ink);
}

.partner-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  border: 2px solid var(--ink);
}
.partner-card {
  position: relative;
  padding: 24px 22px 22px;
  border-right: 1px solid var(--ink);
  border-bottom: 1px solid var(--ink);
  background: var(--paper);
  color: var(--ink);
  display: flex; flex-direction: column; gap: 14px;
  min-height: 220px;
}
.partner-card:nth-child(3n) { border-right: 0; }
.partner-card.open {
  background: var(--paper);
  color: var(--ink);
  background-image:
    repeating-linear-gradient(45deg, transparent 0 9px, var(--grey-10) 9px 10px);
}
.partner-card.live { background: var(--red); color: var(--paper); }

.pc-head {
  display: flex; justify-content: space-between; align-items: start;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  border-bottom: 1px solid currentColor;
  padding-bottom: 10px;
}
.pc-head .where {
  display: flex; flex-direction: column; gap: 2px;
}
.pc-head .where .cc {
  font-family: var(--font-display);
  font-size: 22px;
  line-height: 0.9;
  letter-spacing: -0.02em;
}
.pc-head .where .city { font-size: 10px; letter-spacing: 0.18em; opacity: 0.7; }
.pc-head .status {
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.18em;
  background: var(--ink);
  color: var(--paper);
  padding: 4px 8px;
}
.partner-card.live .pc-head .status { background: var(--ink); }
.partner-card.open .pc-head .status { background: var(--grey-40); color: var(--paper); }

.pc-name {
  font-family: var(--font-display);
  font-size: 28px;
  line-height: 0.95;
  letter-spacing: -0.02em;
  text-transform: uppercase;
  margin: 0;
}
.pc-focus {
  font-family: var(--font-body);
  font-size: 14px;
  line-height: 1.5;
  margin: 0;
}
.pc-meta {
  margin-top: auto;
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 10px;
  align-items: end;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  padding-top: 12px;
  border-top: 1px solid currentColor;
}
.pc-meta .tier .k { opacity: 0.6; font-size: 9px; display: block; }
.pc-meta .tier .v { font-weight: 700; }
.pc-meta a.link {
  display: inline-flex; align-items: center; gap: 6px;
  font-weight: 700;
  border-bottom: 1px solid currentColor;
  padding-bottom: 1px;
}
.pc-meta a.link::after { content: "→"; }
.partner-card.open .pc-name { opacity: 0.55; }
.partner-card.open .pc-focus { opacity: 0.6; }

.hero-cta-row { display: flex; gap: 12px; flex-wrap: wrap; }
.hero-cta-row .btn {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 14px 20px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  font-weight: 700;
  background: var(--ink);
  color: var(--paper);
  line-height: 1;
}
.hero-cta-row .btn::after { content: "→"; font-size: 14px; }
.hero-cta-row .btn.ghost { background: transparent; color: var(--paper); border: 2px solid var(--paper); }
.hero-cta-row .btn:hover { background: var(--paper); color: var(--ink); border-color: var(--paper); }

.hero-side {
  border: 2px solid var(--paper);
  padding: 22px;
  background: rgba(0,0,0,0.18);
  display: flex; flex-direction: column; gap: 16px;
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.04em;
}
.hero-side h4 {
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  margin: 0;
  padding-bottom: 8px;
  border-bottom: 1px solid rgba(255,255,255,0.35);
}
.hero-side .row { display: flex; justify-content: space-between; gap: 16px; }
.hero-side .row .k { opacity: 0.7; text-transform: uppercase; letter-spacing: 0.1em; font-size: 10px; }
.hero-side .row .v { font-weight: 700; }
.hero-side .stamp {
  margin-top: 4px;
  border: 1px solid var(--paper);
  padding: 8px 10px;
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  text-align: center;
}

.hero-foot {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: end;
  gap: 24px;
  border-top: 1px solid rgba(255,255,255,0.3);
  padding-top: 16px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}
.hero-foot .center { text-align: center; }
.hero-foot .right  { text-align: right; }
.hero-foot .scroll {
  display: inline-flex; flex-direction: column; align-items: center; gap: 4px;
  font-size: 9px;
  letter-spacing: 0.2em;
}
.hero-foot .scroll::after {
  content: "";
  display: block;
  width: 1px;
  height: 22px;
  background: var(--paper);
  animation: dropline 1.8s ease-in-out infinite;
}
@keyframes dropline { 0% { transform: scaleY(0); transform-origin: top; } 50% { transform: scaleY(1); } 100% { transform: scaleY(0); transform-origin: bottom; } }

/* ============================================================ SECTION HEAD (slimmer than brandbook) */
.sec {
  padding: 96px 36px;
  border-bottom: var(--rule-w) solid currentColor;
  position: relative;
}
.sec.ink { background: var(--ink); color: var(--paper); }
.sec.red { background: var(--red); color: var(--paper); }
.sec.paper { background: var(--paper); color: var(--ink); }

.sec-tag {
  position: absolute; top: 24px; left: 36px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}
.sec-tag::before { content: ""; display: inline-block; width: 9px; height: 9px; background: var(--red); margin-right: 8px; vertical-align: middle; }
.sec.red .sec-tag::before, .sec.ink .sec-tag::before { background: var(--paper); }

.sec-num {
  position: absolute; top: 24px; right: 36px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.14em;
}

.sec-head {
  display: grid;
  grid-template-columns: 180px minmax(0, 1fr) 220px;
  gap: 32px;
  align-items: end;
  padding-bottom: 28px;
  border-bottom: var(--rule-w) solid currentColor;
  margin-bottom: 56px;
}
.sec-head .ix {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}
.sec-head .ix .big {
  display: block;
  font-family: var(--font-display);
  font-size: 56px;
  line-height: 0.85;
  color: var(--red);
  margin-bottom: 8px;
}
.sec.red .sec-head .ix .big,
.sec.ink .sec-head .ix .big { color: var(--paper); }
.sec-head h2 {
  font-family: var(--font-display);
  font-size: clamp(56px, 6.5vw, 92px);
  line-height: 0.88;
  letter-spacing: -0.03em;
  margin: 0;
  text-transform: uppercase;
  text-wrap: balance;
}
.sec-head h2 .acc { color: var(--red); }
.sec.red .sec-head h2 .acc,
.sec.ink .sec-head h2 .acc { background: var(--paper); color: var(--ink); padding: 0 6px; }
.sec-head .meta {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  text-align: right;
  line-height: 1.55;
}

.eyebrow {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  margin: 0 0 12px;
}
.eyebrow::before { content: "/ "; color: var(--red); }
.sec.red .eyebrow::before, .sec.ink .eyebrow::before { color: var(--paper); }

/* ============================================================ MANIFESTO */
.manifesto {
  display: grid;
  grid-template-columns: 7fr 5fr;
  gap: 48px;
  align-items: start;
}
.manifesto .stmt {
  font-family: var(--font-display);
  font-size: clamp(40px, 4.5vw, 64px);
  line-height: 0.95;
  letter-spacing: -0.025em;
  text-transform: uppercase;
  margin: 0 0 24px;
  text-wrap: balance;
}
.manifesto .stmt .acc { color: var(--red); }
.manifesto p { font-size: 16px; line-height: 1.6; max-width: 56ch; margin: 0 0 14px; }

.three-up {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin-top: 56px;
}
.three-up .tile {
  border: 2px solid var(--ink);
  padding: 28px;
  display: flex; flex-direction: column; gap: 12px;
  background: var(--paper); color: var(--ink);
}
.three-up .tile.red { background: var(--red); color: var(--paper); border-color: var(--red); }
.three-up .tile.ink { background: var(--ink); color: var(--paper); border-color: var(--ink); }
.three-up .tile .num {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}
.three-up .tile h3 {
  font-family: var(--font-display);
  font-size: 28px;
  line-height: 0.95;
  text-transform: uppercase;
  letter-spacing: -0.02em;
  margin: 0;
}
.three-up .tile p { font-size: 14px; line-height: 1.55; margin: 0; }

/* ============================================================ LADDER */
.ladder { display: flex; flex-direction: column; }

.tier {
  position: relative;
  border-bottom: var(--rule-w) solid var(--ink);
  padding: 56px 36px 64px;
  display: grid;
  grid-template-columns: 180px minmax(0, 1fr) 300px;
  gap: 36px;
  align-items: start;
  color: var(--ink);
  background: var(--paper);
  overflow: hidden;
}
.tier.ink   { background: var(--ink);   color: var(--paper); border-color: var(--paper); }
.tier.red   { background: var(--red);   color: var(--paper); border-color: var(--ink); }
.tier.paper { background: var(--paper); color: var(--ink); }

.tier .step-num {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: 140px;
  line-height: 0.8;
  letter-spacing: -0.05em;
  margin: 0;
  position: relative;
  z-index: 1;
}
.tier .step-num .dot { color: var(--red); }
.tier.red .step-num .dot { color: var(--ink); }
.tier.ink .step-num .dot { color: var(--red); }

.tier .step-body { min-width: 0; }
.tier .step-kicker {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  margin: 0 0 14px;
  padding-bottom: 10px;
  border-bottom: 1px solid currentColor;
  display: flex; justify-content: space-between; gap: 20px;
}
.tier .step-title {
  font-family: var(--font-display);
  font-size: clamp(40px, 4vw, 56px);
  line-height: 0.95;
  letter-spacing: -0.02em;
  text-transform: uppercase;
  margin: 0 0 16px;
  text-wrap: balance;
}
.tier .step-title .heng {
  display: block;
  font-size: 0.5em;
  font-family: var(--font-mono);
  font-weight: 400;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  margin-top: 8px;
  opacity: 0.7;
}
.tier .step-title .acc { color: var(--red); }
.tier.red .step-title .acc { color: var(--ink); }
.tier.ink .step-title .acc { color: var(--red); }
.tier .step-desc {
  font-family: var(--font-body);
  font-size: 16px;
  line-height: 1.55;
  margin: 0 0 20px;
  max-width: 52ch;
}

.tier .what-you-do, .tier .what-you-get {
  display: grid; grid-template-columns: 100px 1fr;
  gap: 12px;
  padding: 10px 0;
  border-top: 1px solid currentColor;
  font-size: 14px;
  line-height: 1.5;
}
.tier .what-you-do .l, .tier .what-you-get .l {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  padding-top: 3px;
  opacity: 0.7;
}

.tier .step-card {
  border: 2px solid currentColor;
  padding: 22px;
  display: flex; flex-direction: column; gap: 14px;
  font-family: var(--font-mono);
  font-size: 12px;
  line-height: 1.5;
  letter-spacing: 0.02em;
  position: sticky;
  top: calc(var(--bar-h) + 24px);
}
.tier.red .step-card { border-color: var(--paper); }
.tier.ink .step-card { border-color: var(--paper); }
.tier .step-card h4 {
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  margin: 0;
  padding-bottom: 8px;
  border-bottom: 1px solid currentColor;
}
.tier .step-card .row { display: flex; justify-content: space-between; gap: 16px; }
.tier .step-card .row .k { opacity: 0.7; text-transform: uppercase; letter-spacing: 0.1em; font-size: 10px; }
.tier .step-card .row .v { font-weight: 700; text-align: right; }
.tier .step-card .commission {
  background: var(--red); color: var(--paper);
  padding: 12px;
  display: flex; align-items: baseline; justify-content: space-between;
}
.tier.red .step-card .commission { background: var(--ink); }
.tier.ink .step-card .commission { background: var(--red); }
.tier .step-card .commission .big {
  font-family: var(--font-display);
  font-size: 36px;
  line-height: 0.9;
  letter-spacing: -0.02em;
}
.tier .step-card .commission .label {
  font-size: 9px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  text-align: right;
  max-width: 14ch;
}

.tier-progress {
  position: absolute;
  bottom: 0; left: 0;
  height: 6px;
  background: var(--red);
  z-index: 2;
}
.tier.red .tier-progress { background: var(--ink); }
.tier.ink .tier-progress { background: var(--red); }

/* ============================================================ COMPARATOR */
.compare {
  margin: 0 36px 24px;
}
.compare-eye {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  margin: 0 0 16px;
  display: flex; justify-content: space-between; align-items: end;
  border-bottom: 2px solid var(--ink);
  padding-bottom: 12px;
}
.compare-eye h3 {
  font-family: var(--font-display);
  font-size: 40px;
  line-height: 0.9;
  letter-spacing: -0.025em;
  text-transform: uppercase;
  margin: 0;
  max-width: 18ch;
}
.compare-eye .legend {
  letter-spacing: 0.14em;
  text-align: right;
  line-height: 1.5;
}

.compare-grid {
  border: 2px solid var(--ink);
  display: grid;
  grid-template-columns: 200px repeat(5, 1fr);
}
.compare-grid > div {
  border-right: 1px solid var(--ink);
  border-bottom: 1px solid var(--ink);
  padding: 14px 16px;
  font-family: var(--font-mono);
  font-size: 12px;
  line-height: 1.4;
  letter-spacing: 0.02em;
}
.compare-grid > div:nth-child(6n) { border-right: 0; }
.compare-grid > .row-label {
  background: var(--ink);
  color: var(--paper);
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  display: flex; align-items: center;
}
.compare-grid .col-head {
  background: var(--paper);
  display: flex; flex-direction: column; gap: 4px;
  min-height: 80px;
}
.compare-grid .col-head .ix {
  font-size: 10px;
  letter-spacing: 0.18em;
  color: var(--red);
}
.compare-grid .col-head .nm {
  font-family: var(--font-display);
  font-size: 22px;
  line-height: 0.95;
  text-transform: uppercase;
  letter-spacing: -0.02em;
}
.compare-grid .pct {
  background: var(--paper);
  display: flex; align-items: baseline; justify-content: space-between; gap: 6px;
}
.compare-grid .pct .big {
  font-family: var(--font-display);
  font-size: 32px;
  line-height: 0.85;
  letter-spacing: -0.02em;
  color: var(--red);
}
.compare-grid .pct .note {
  font-size: 9px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  opacity: 0.6;
  text-align: right;
  max-width: 12ch;
}
.compare-grid .bar-cell {
  padding: 18px 16px;
  display: flex; align-items: center;
}
.compare-grid .bar {
  position: relative;
  height: 12px;
  background: var(--grey-10);
  width: 100%;
}
.compare-grid .bar::before {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  width: var(--w, 0%);
  background: var(--red);
}
.compare-grid .bar .pct-num {
  position: absolute;
  top: -16px;
  left: var(--w, 0%);
  transform: translateX(-50%);
  font-size: 10px;
  letter-spacing: 0.1em;
  font-weight: 700;
}

.programs {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  border: var(--rule-w) solid currentColor;
}
.prog {
  position: relative;
  padding: 32px 28px 28px;
  display: flex;
  flex-direction: column;
  gap: 18px;
  border-right: 1px solid currentColor;
  background: var(--paper);
  color: var(--ink);
  min-height: 420px;
}
.prog:last-child { border-right: 0; }
.prog.accent { background: var(--red); color: var(--paper); }
.prog.ink    { background: var(--ink); color: var(--paper); }

.prog-head {
  display: flex; justify-content: space-between; align-items: baseline;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  padding-bottom: 14px;
  border-bottom: 2px solid currentColor;
}
.prog-head .n {
  font-family: var(--font-display);
  font-size: 56px;
  line-height: 0.85;
  letter-spacing: -0.03em;
}
.prog-head .kind { text-align: right; line-height: 1.4; }
.prog-head .kind strong {
  display: block;
  font-family: var(--font-display);
  font-size: 14px;
  letter-spacing: 0.04em;
  font-weight: 900;
}

.prog h4 {
  font-family: var(--font-display);
  font-size: clamp(28px, 2.4vw, 36px);
  line-height: 0.95;
  letter-spacing: -0.02em;
  text-transform: uppercase;
  margin: 0;
  text-wrap: balance;
}
.prog p {
  font-size: 14px;
  line-height: 1.55;
  margin: 0;
}
.prog ul {
  list-style: none;
  margin: 0; padding: 0;
  display: grid;
  gap: 6px;
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.02em;
  line-height: 1.4;
}
.prog ul li {
  position: relative;
  padding-left: 16px;
}
.prog ul li::before {
  content: "—";
  position: absolute;
  left: 0;
  top: 0;
  opacity: 0.6;
}

.prog-meta {
  margin-top: auto;
  padding-top: 14px;
  border-top: 1px solid currentColor;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}
.prog-meta .k { opacity: 0.65; font-size: 9px; display: block; margin-bottom: 4px; letter-spacing: 0.16em; }
.prog-meta .v {
  font-family: var(--font-display);
  font-size: 18px;
  line-height: 1;
  letter-spacing: -0.01em;
}

/* ============================================================ METHODOLOGY (legacy cycle grid kept for fallback) */
.cycle-wrap {
  display: grid;
  grid-template-columns: 5fr 7fr;
  gap: 48px;
  align-items: start;
}
.cycle-intro h3 {
  font-family: var(--font-display);
  font-size: 56px;
  line-height: 0.88;
  letter-spacing: -0.03em;
  text-transform: uppercase;
  margin: 0 0 22px;
}
.cycle-intro h3 .acc { color: var(--red); }
.cycle-intro p { font-size: 16px; line-height: 1.6; margin: 0 0 14px; max-width: 44ch; }

.cycle-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  border: var(--rule-w) solid currentColor;
}
.cycle-cell {
  padding: 28px 24px;
  border-right: 1px solid currentColor;
  border-bottom: 1px solid currentColor;
  position: relative;
  display: flex; flex-direction: column; gap: 14px;
  min-height: 240px;
  background: var(--paper);
  color: var(--ink);
}
.cycle-cell:nth-child(3n) { border-right: 0; }
.cycle-cell:nth-last-child(-n+3) { border-bottom: 0; }
.cycle-cell.accent { background: var(--red); color: var(--paper); }
.cycle-cell.ink    { background: var(--ink); color: var(--paper); }

.cycle-cell .step {
  display: flex; justify-content: space-between; align-items: baseline;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}
.cycle-cell .step .n {
  font-family: var(--font-display);
  font-size: 48px;
  line-height: 0.9;
}
.cycle-cell h4 {
  font-family: var(--font-display);
  font-size: 26px;
  line-height: 0.95;
  text-transform: uppercase;
  letter-spacing: -0.02em;
  margin: 0;
}
.cycle-cell p {
  font-size: 13px;
  line-height: 1.5;
  margin: 0;
}
.cycle-cell .dur {
  margin-top: auto;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  border-top: 1px solid currentColor;
  padding-top: 8px;
  display: flex; justify-content: space-between;
}

.principles {
  margin-top: 56px;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
}
.principle {
  border: 2px solid currentColor;
  padding: 18px;
  display: flex; flex-direction: column; gap: 8px;
}
.principle .l {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--red);
}
.sec.ink .principle .l, .sec.red .principle .l { color: var(--paper); }
.principle h5 {
  font-family: var(--font-display);
  font-size: 22px;
  line-height: 0.95;
  text-transform: uppercase;
  letter-spacing: -0.02em;
  margin: 0;
}
.principle p { font-size: 12px; line-height: 1.5; margin: 0; opacity: 0.85; }

/* ============================================================ GEOGRAPHY */
.geo {
  position: relative;
  border: var(--rule-w) solid currentColor;
  background: var(--ink);
  color: var(--paper);
  aspect-ratio: 2 / 1;
  overflow: hidden;
  width: 100%;
}
.geo .grid-bg {
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(to right, rgba(255,255,255,0.06) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(255,255,255,0.06) 1px, transparent 1px);
  background-size: calc(100% / 24) 100%, 100% calc(100% / 12);
}
.geo .axis-x, .geo .axis-y {
  position: absolute;
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.1em;
  color: rgba(255,255,255,0.45);
}
.geo .axis-x { top: 6px; left: 0; right: 0; display: flex; justify-content: space-between; padding: 0 12px; }
.geo .axis-y { left: 6px; top: 0; bottom: 0; display: flex; flex-direction: column; justify-content: space-between; padding: 12px 0; }
.geo .equator, .geo .meridian {
  position: absolute;
  background: rgba(255,255,255,0.18);
}
.geo .equator { top: 50%; left: 0; right: 0; height: 1px; }
.geo .meridian { top: 0; bottom: 0; left: 50%; width: 1px; }
.geo .corner {
  position: absolute;
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.6);
}
.geo .corner.tr { top: 14px; right: 14px; text-align: right; line-height: 1.4; }
.geo .corner.bl { bottom: 14px; left: 14px; }
.geo .corner.br { bottom: 14px; right: 14px; text-align: right; line-height: 1.4; }
.geo .corner.tl { top: 14px; left: 14px; }
.geo .corner b { color: var(--paper); }

.continents {
  position: absolute;
  inset: 0;
  pointer-events: none;
  background-image: url("world-map.svg");
  background-size: 100% 100%;
  background-repeat: no-repeat;
  opacity: 0.85;
}

.pin {
  position: absolute;
  transform: translate(-50%, -50%);
  z-index: 2;
  cursor: pointer;
}
.pin .marker {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 26px;
  height: 26px;
  background: var(--red);
  color: var(--paper);
  font-family: var(--font-display);
  font-size: 13px;
  line-height: 1;
  letter-spacing: -0.02em;
  border: 2px solid var(--paper);
  box-shadow: 0 0 0 2px var(--ink);
}
.pin.live .marker::after {
  content: "";
  position: absolute;
  inset: -10px;
  border: 1px solid var(--red);
  pointer-events: none;
  animation: ping 2.4s ease-out infinite;
}
.pin.open .marker { background: var(--ink); color: var(--paper); border-color: var(--paper); }
.pin.soon .marker { background: var(--paper); color: var(--ink); border-color: var(--ink); box-shadow: 0 0 0 2px var(--paper); }
.pin.hq .marker {
  background: var(--paper);
  color: var(--red);
  border-color: var(--red);
  width: 32px; height: 32px;
  font-size: 11px;
  font-family: var(--font-mono);
  letter-spacing: 0.1em;
}
.pin:hover { z-index: 10; }
.pin:hover .marker { transform: scale(1.25); }
@keyframes ping {
  0% { transform: scale(0.5); opacity: 0.9; }
  100% { transform: scale(1.6); opacity: 0; }
}
.pin .label b { color: var(--red); font-weight: 700; }
.pin.open .label b { color: var(--paper); }
.pin.soon .label { opacity: 0.65; }
.pin.soon .label b { color: var(--paper); opacity: 0.7; }

.geo-legend {
  margin-top: 18px;
  display: flex;
  gap: 24px;
  flex-wrap: wrap;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  padding: 14px 16px;
  border: 2px solid var(--ink);
}
.geo-legend .item { display: flex; align-items: center; gap: 10px; }
.geo-legend .swatch {
  width: 22px; height: 22px;
  display: grid; place-items: center;
  font-family: var(--font-display);
  font-size: 11px;
  color: var(--paper);
  border: 1.5px solid var(--ink);
}
.geo-legend .swatch.live { background: var(--red); }
.geo-legend .swatch.open { background: var(--ink); }
.geo-legend .swatch.soon { background: var(--paper); color: var(--ink); }
.geo-legend .swatch.hq   { background: var(--paper); color: var(--red); border-color: var(--red); font-family: var(--font-mono); font-size: 9px; letter-spacing: 0.04em; }

.geo-table {
  margin-top: 24px;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border: var(--rule-w) solid var(--ink);
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.04em;
}
.geo-table .geo-row {
  display: grid;
  grid-template-columns: 32px 50px 1fr auto;
  align-items: center;
  gap: 12px;
  padding: 12px 14px;
  border-right: 1px solid var(--ink);
  border-bottom: 1px solid var(--ink);
}
.geo-table .geo-row:nth-child(4n) { border-right: 0; }
.geo-table .geo-row .pin-n {
  display: grid; place-items: center;
  width: 24px; height: 24px;
  font-family: var(--font-display);
  font-size: 12px;
  background: var(--red);
  color: var(--paper);
  border: 1.5px solid var(--ink);
  letter-spacing: -0.02em;
}
.geo-table .geo-row[data-status="open"] .pin-n { background: var(--ink); color: var(--paper); border-color: var(--ink); }
.geo-table .geo-row[data-status="soon"] .pin-n { background: var(--paper); color: var(--ink); border-color: var(--ink); }
.geo-table .geo-row[data-status="hq"]   .pin-n { background: var(--paper); color: var(--red); border-color: var(--red); font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.06em; }
.geo-table .geo-row .cc {
  font-family: var(--font-display);
  font-size: 20px;
  line-height: 0.9;
}
.geo-table .geo-row .city { text-transform: uppercase; letter-spacing: 0.08em; font-size: 11px; font-weight: 700; }
.geo-table .geo-row .city small {
  display: block;
  font-weight: 400;
  letter-spacing: 0.06em;
  opacity: 0.6;
  margin-top: 2px;
  font-size: 10px;
}
.geo-table .geo-row .badge {
  font-size: 9px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  padding: 4px 6px;
  background: var(--red);
  color: var(--paper);
}
.geo-table .geo-row .badge.open { background: var(--ink); }
.geo-table .geo-row .badge.soon { background: var(--grey-20); color: var(--ink); }
.geo-table .geo-row .badge.hq   { background: var(--paper); color: var(--ink); border: 1px solid var(--ink); }

/* ============================================================ FOUNDER */
.founder {
  display: grid;
  grid-template-columns: 5fr 7fr;
  gap: 48px;
  align-items: start;
}
.founder .portrait {
  aspect-ratio: 3/4;
  background: var(--red);
  color: var(--paper);
  position: relative;
  border: var(--rule-w) solid var(--ink);
  overflow: hidden;
}
.founder .portrait .meta {
  position: absolute; top: 14px; left: 14px; right: 14px;
  display: flex; justify-content: space-between;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  z-index: 2;
}
.founder .portrait .name {
  position: absolute; bottom: 24px; left: 24px; right: 24px;
  font-family: var(--font-display);
  font-size: 48px;
  line-height: 0.9;
  letter-spacing: -0.02em;
  text-transform: uppercase;
  z-index: 2;
  text-shadow: 0 2px 12px rgba(0,0,0,0.4);
}
.founder .portrait .placeholder {
  position: absolute; inset: 30% 24%;
  border: 2px dashed rgba(255,255,255,0.5);
  display: grid; place-items: center;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  text-align: center;
}
.founder .portrait .portrait-photo {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 18%;
  filter: grayscale(1) contrast(1.05);
  mix-blend-mode: luminosity;
}
.founder .portrait::after {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    repeating-linear-gradient(0deg, transparent 0 3px, rgba(0,0,0,0.08) 3px 4px);
  pointer-events: none;
}

.founder h3 {
  font-family: var(--font-display);
  font-size: clamp(48px, 5.5vw, 80px);
  line-height: 0.88;
  letter-spacing: -0.03em;
  text-transform: uppercase;
  margin: 0 0 24px;
  text-wrap: balance;
}
.founder h3 .acc { color: var(--red); }
.founder p { font-size: 16px; line-height: 1.6; margin: 0 0 14px; max-width: 56ch; }

.pillars {
  margin-top: 30px;
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 12px;
}
.pillar {
  border: 2px solid var(--ink);
  padding: 18px;
}
.pillar .l {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--red);
  margin-bottom: 6px;
}
.pillar .t {
  font-family: var(--font-display);
  font-size: 26px;
  line-height: 0.95;
  text-transform: uppercase;
  letter-spacing: -0.02em;
}
.pillar p { font-size: 12px; line-height: 1.5; margin: 8px 0 0; }

.creds {
  margin-top: 24px;
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 12px;
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.04em;
}
.cred {
  display: grid; grid-template-columns: 32px 1fr;
  gap: 10px;
  padding: 10px 0;
  border-top: 1px solid var(--ink);
}
.cred .ic {
  display: grid; place-items: center;
  background: var(--ink); color: var(--paper);
  font-size: 10px; font-weight: 700;
  letter-spacing: 0.1em;
}

/* ============================================================ APPLY */
.apply-wrap {
  display: grid;
  grid-template-columns: 6fr 6fr;
  gap: 48px;
  align-items: start;
}
.apply-form {
  border: 2px solid var(--paper);
  padding: 28px;
  display: grid;
  gap: 14px;
  background: rgba(0,0,0,0.15);
}
.apply-form .field {
  display: flex; flex-direction: column; gap: 6px;
}
.apply-form .field label {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}
.apply-form .field input,
.apply-form .field textarea,
.apply-form .field select {
  appearance: none;
  font: inherit;
  font-family: var(--font-body);
  font-size: 15px;
  padding: 12px 14px;
  background: transparent;
  color: var(--paper);
  border: 1.5px solid var(--paper);
  outline: none;
}
.apply-form .field input::placeholder,
.apply-form .field textarea::placeholder { color: rgba(255,255,255,0.4); }
.apply-form .field input:focus,
.apply-form .field textarea:focus,
.apply-form .field select:focus { border-color: var(--ink); background: var(--paper); color: var(--ink); }
.apply-form .field textarea { min-height: 100px; resize: vertical; }
.apply-form .field select option { color: var(--ink); }
.apply-form .row2 { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.apply-form button {
  appearance: none; border: 0;
  background: var(--ink); color: var(--paper);
  padding: 16px 22px;
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  font-weight: 700;
  cursor: pointer;
  display: inline-flex; align-items: center; justify-content: space-between;
  gap: 14px;
}
.apply-form button:hover { background: var(--paper); color: var(--ink); }
.apply-form button::after { content: "→"; }
.apply-form .stamp {
  margin-top: 4px;
  border: 1px solid var(--paper);
  padding: 8px 10px;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  display: flex; justify-content: space-between;
}

.apply-aside {
  display: flex; flex-direction: column; gap: 22px;
}
.apply-aside h3 {
  font-family: var(--font-display);
  font-size: 56px;
  line-height: 0.88;
  letter-spacing: -0.03em;
  text-transform: uppercase;
  margin: 0;
}
.apply-aside .stmt {
  font-family: var(--font-display);
  font-size: 28px;
  line-height: 0.95;
  letter-spacing: -0.02em;
  text-transform: uppercase;
}
.apply-aside .stmt .acc { background: var(--paper); color: var(--red); padding: 0 6px; }
.apply-aside p { font-size: 15px; line-height: 1.6; margin: 0; max-width: 48ch; }

.contact-list {
  display: grid; gap: 1px;
  border: 2px solid var(--paper);
  background: var(--paper);
}
.contact-list .item {
  display: grid; grid-template-columns: 120px 1fr auto;
  gap: 14px;
  align-items: center;
  padding: 14px 18px;
  background: var(--red); color: var(--paper);
  font-family: var(--font-mono);
  font-size: 13px;
  letter-spacing: 0.04em;
}
.contact-list .item .k {
  font-size: 10px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  opacity: 0.85;
}
.contact-list .item .v { font-weight: 700; letter-spacing: 0.02em; }
.contact-list .item .arrow { font-size: 16px; }

/* ============================================================ FAQ */
.faq-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0;
  border: var(--rule-w) solid var(--ink);
}
.faq-q {
  padding: 24px 26px;
  border-right: 1px solid var(--ink);
  border-bottom: 1px solid var(--ink);
  display: flex; flex-direction: column; gap: 12px;
  background: var(--paper); color: var(--ink);
}
.faq-q:nth-child(2n) { border-right: 0; }
.faq-q:nth-last-child(-n+2) { border-bottom: 0; }
.faq-q .n {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--red);
}
.faq-q h4 {
  font-family: var(--font-display);
  font-size: 22px;
  line-height: 1;
  text-transform: uppercase;
  letter-spacing: -0.015em;
  margin: 0;
}
.faq-q p { font-size: 14px; line-height: 1.55; margin: 0; }

/* ============================================================ FOOTER */
.foot {
  background: var(--ink); color: var(--paper);
  padding: 64px 36px 24px;
  border-top: 4px solid var(--red);
}
.foot-top {
  display: grid; grid-template-columns: 1fr 1fr 1fr 1fr;
  gap: 32px;
  padding-bottom: 40px;
  border-bottom: 1px solid rgba(255,255,255,0.2);
}
.foot-top h5 {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--red);
  margin: 0 0 14px;
}
.foot-top ul { list-style: none; margin: 0; padding: 0; display: grid; gap: 8px; font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.04em; }
.foot-top li a:hover { color: var(--red); }

.foot-bot {
  display: grid; grid-template-columns: 1fr auto 1fr;
  gap: 24px;
  align-items: end;
  margin-top: 24px;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.7);
}
.foot-bot .center { text-align: center; }
.foot-bot .right { text-align: right; }

.foot-mark {
  display: flex; flex-direction: column; gap: 14px;
}
.foot-mark .punch {
  font-family: var(--font-display);
  font-size: clamp(72px, 12vw, 180px);
  line-height: 0.78;
  letter-spacing: -0.045em;
  text-transform: uppercase;
  margin: 24px 0 8px;
}
.foot-mark .punch .acc { color: var(--red); }

/* ============================================================ utilities */
.r-stripe {
  display: inline-block;
  background: var(--red);
  color: var(--paper);
  padding: 2px 8px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}
[hidden] { display: none !important; }

/* ============================================================ SALES FLOW */
.flow-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 0;
  border: var(--rule-w) solid var(--paper);
}
.flow-step {
  position: relative;
  padding: 28px 22px 24px;
  display: flex; flex-direction: column; gap: 14px;
  background: var(--ink);
  color: var(--paper);
  border-right: 1px solid var(--paper);
  min-height: 280px;
}
.flow-step:last-child { border-right: 0; }
.flow-step.accent { background: var(--red); }
.flow-step.red    { background: var(--paper); color: var(--ink); }

/* arrow connector between steps */
.flow-step::after {
  content: "";
  position: absolute;
  right: -10px; top: 50%;
  width: 20px; height: 20px;
  transform: translateY(-50%) rotate(45deg);
  background: inherit;
  border-top: 1px solid var(--paper);
  border-right: 1px solid var(--paper);
  z-index: 2;
}
.flow-step.red::after { border-color: var(--ink); }
.flow-step:last-child::after { display: none; }

.flow-head {
  display: flex; justify-content: space-between; align-items: baseline;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  border-bottom: 1px solid currentColor;
  padding-bottom: 10px;
}
.flow-head .who {
  background: var(--red);
  color: var(--paper);
  padding: 3px 7px;
}
.flow-step.accent .flow-head .who { background: var(--ink); }
.flow-step.red    .flow-head .who { background: var(--red); }
.flow-head .num {
  font-family: var(--font-display);
  font-size: 36px;
  line-height: 0.85;
  letter-spacing: -0.03em;
}
.flow-step h4 {
  font-family: var(--font-display);
  font-size: 22px;
  line-height: 1;
  letter-spacing: -0.02em;
  text-transform: uppercase;
  margin: 0;
}
.flow-step p {
  font-size: 13px;
  line-height: 1.5;
  margin: 0;
}
.flow-meta {
  margin-top: auto;
  padding-top: 12px;
  border-top: 1px solid currentColor;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.flow-step { transition: transform 200ms ease, box-shadow 200ms ease, z-index 0ms; }
.flow-step:hover { transform: scale(1.04); z-index: 3; box-shadow: 0 0 0 3px var(--red); }
.flow-step.accent:hover { box-shadow: 0 0 0 3px var(--ink); }

/* ============================================================ LANG MENU (dropdown — scales to N languages) */
.lang-menu {
  position: relative;
}
.lang-menu summary {
  list-style: none;
  cursor: pointer;
  display: inline-flex; align-items: center; gap: 8px;
  padding: 8px 12px;
  border: 1.5px solid currentColor;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  font-weight: 700;
  user-select: none;
}
.lang-menu summary::-webkit-details-marker { display: none; }
.lang-menu summary::after {
  content: "▾";
  display: inline-block;
  font-size: 9px;
  transition: transform 180ms ease;
}
.lang-menu[open] summary::after { transform: rotate(180deg); }
.lang-menu summary .cur-name {
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.1em;
  opacity: 0.7;
  text-transform: none;
}
.lang-menu .lang-pop {
  position: absolute;
  top: calc(100% + 6px);
  right: 0;
  z-index: 60;
  width: 240px;
  max-height: 360px;
  overflow: auto;
  background: var(--paper);
  color: var(--ink);
  border: 2px solid var(--ink);
  box-shadow: 6px 6px 0 0 var(--ink);
  padding: 6px 0;
  display: grid;
  gap: 0;
}
.hero .lang-menu .lang-pop { background: var(--ink); color: var(--paper); border-color: var(--paper); }

.lang-menu .lang-item {
  appearance: none; border: 0;
  background: transparent;
  color: inherit;
  text-align: left;
  padding: 10px 14px;
  cursor: pointer;
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.04em;
  display: grid;
  grid-template-columns: 32px 1fr auto;
  align-items: baseline;
  gap: 10px;
  border-bottom: 1px solid currentColor;
  transition: background 120ms ease;
}
.lang-menu .lang-item:last-child { border-bottom: 0; }
.lang-menu .lang-item:hover { background: var(--red); color: var(--paper); }
.lang-menu .lang-item .code {
  font-family: var(--font-display);
  font-size: 14px;
  letter-spacing: -0.01em;
}
.lang-menu .lang-item .name {
  text-transform: none;
  font-size: 13px;
  letter-spacing: 0.02em;
}
.lang-menu .lang-item[aria-pressed="true"] {
  background: var(--red);
  color: var(--paper);
  font-weight: 700;
}
.lang-menu .lang-item[aria-pressed="true"]:hover { background: var(--red); }
.lang-menu .lang-item[disabled] {
  opacity: 0.5;
  cursor: not-allowed;
  background-image: repeating-linear-gradient(45deg, transparent 0 4px, rgba(0,0,0,0.05) 4px 5px);
}
.lang-menu .lang-item[disabled]:hover { background: transparent; color: inherit; }
.lang-menu .lang-item .badge {
  font-size: 9px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  background: var(--red);
  color: var(--paper);
  padding: 2px 6px;
}
.lang-menu .lang-item[disabled] .badge { background: var(--grey-40); }
.lang-menu .lang-header {
  padding: 8px 14px 4px;
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  opacity: 0.6;
}

/* ============================================================ RESPONSIVE — site stretches gracefully */
@media (max-width: 1200px) {
  body.partners { min-width: 0; }
  .topnav { gap: 14px; font-size: 10px; }
  .sec-head { grid-template-columns: 120px 1fr 180px; gap: 24px; }
  .sec-head h2 { font-size: clamp(48px, 6vw, 80px); }
  .hero-wordmark { font-size: clamp(120px, 16vw, 240px); }
  .hero-grid { grid-template-columns: 7fr 5fr; gap: 28px; }
  .tier { grid-template-columns: 140px 1fr 280px; gap: 28px; }
  .tier .step-num { font-size: 120px; }
}

@media (max-width: 960px) {
  .hero { padding: 40px 24px 36px; }
  .hero-grid { grid-template-columns: 1fr; }
  .hero-side { max-width: 520px; }
  .topnav { display: none; }
  .topbar { grid-template-columns: auto 1fr auto; }

  .sec { padding: 64px 24px; }
  .sec-head {
    grid-template-columns: 1fr;
    gap: 12px;
  }
  .sec-head .meta { text-align: left; }

  .manifesto { grid-template-columns: 1fr; gap: 24px; }
  .three-up { grid-template-columns: 1fr; }
  .compare-grid { grid-template-columns: 80px repeat(5, 1fr); font-size: 10px; }

  .tier {
    grid-template-columns: 1fr;
    padding: 36px 24px 44px;
    gap: 20px;
  }
  .tier .step-num { font-size: 96px; }
  .tier .step-card { position: static; }

  .flow-grid { grid-template-columns: repeat(2, 1fr); }
  .flow-step:nth-child(2)::after { display: none; }
  .flow-step:nth-child(4)::after { display: none; }
  .flow-step { min-height: 220px; }

  .programs { grid-template-columns: 1fr; }
  .cycle-wrap { grid-template-columns: 1fr; }
  .principles { grid-template-columns: repeat(2, 1fr); }

  .founder { grid-template-columns: 1fr; }
  .apply-wrap { grid-template-columns: 1fr; gap: 28px; }
  .faq-grid { grid-template-columns: 1fr; }
  .partner-grid { grid-template-columns: 1fr 1fr; }
  .partner-card:nth-child(3n) { border-right: 1px solid var(--ink); }
  .partner-card:nth-child(2n) { border-right: 0; }
  .geo-table { grid-template-columns: 1fr 1fr; }
  .geo-table .geo-row:nth-child(4n) { border-right: 1px solid var(--ink); }
  .geo-table .geo-row:nth-child(2n) { border-right: 0; }

  .foot-top { grid-template-columns: 1fr 1fr; }
  .foot-bot { grid-template-columns: 1fr; gap: 14px; }
  .foot-bot .center, .foot-bot .right { text-align: left; }
}

@media (max-width: 640px) {
  .hero { padding: 32px 18px 28px; min-height: auto; }
  .hero-wordmark { font-size: clamp(80px, 22vw, 130px); line-height: 0.85; }
  .hero-subline { grid-template-columns: 1fr; gap: 10px; padding: 12px 0; }
  .hero-subline .role { border-left: 0; padding-left: 0; border-top: 1px solid rgba(255,255,255,0.4); padding-top: 10px; }
  .hero-subline .ai-first { font-size: 32px; }
  .hero-lede { font-size: 16px; }
  .hero-sig { gap: 14px; }
  .hero-sig-photo { width: 64px; height: 64px; }
  .hero-sig-quote { font-size: 18px; }
  .hero-foot { grid-template-columns: 1fr; text-align: left; gap: 8px; }
  .hero-foot .center, .hero-foot .right { text-align: left; }
  .hero-lang { top: 14px; right: 14px; }

  .sec { padding: 48px 18px; }
  .sec-head h2 { font-size: clamp(32px, 9vw, 56px); }
  .sec-tag, .sec-num { font-size: 9px; }

  .tier { padding: 28px 18px 36px; }
  .tier .step-num { font-size: 72px; }
  .tier .step-title { font-size: 32px; }
  .tier .step-desc { font-size: 14px; }

  .compare-grid { grid-template-columns: 1fr; }
  .compare-grid .row-label { display: none; }
  .compare-grid > div { font-size: 11px; }
  .compare-grid .col-head .nm { font-size: 18px; }

  .flow-grid { grid-template-columns: 1fr; }
  .flow-step::after { display: none; }
  .flow-step { min-height: 0; }

  .principles { grid-template-columns: 1fr; }
  .partner-grid { grid-template-columns: 1fr; }
  .partner-card { border-right: 0 !important; }
  .geo-table { grid-template-columns: 1fr; }
  .geo-table .geo-row { border-right: 0 !important; }
  .geo { aspect-ratio: 4 / 3; }

  .pillars { grid-template-columns: 1fr; }
  .creds { grid-template-columns: 1fr; }
  .three-up .tile h3 { font-size: 22px; }

  .foot-top { grid-template-columns: 1fr; }
  .foot-mark .punch { font-size: 56px; }
}

/* form fields: visible focus state */
.apply-form .field input,
.apply-form .field textarea,
.apply-form .field select {
  transition: background 180ms ease, color 180ms ease, border-color 180ms ease, transform 120ms ease;
}
.apply-form .field input:hover,
.apply-form .field textarea:hover,
.apply-form .field select:hover {
  border-color: var(--ink);
}
.apply-form .field input:focus,
.apply-form .field textarea:focus,
.apply-form .field select:focus {
  background: var(--paper);
  color: var(--ink);
  border-color: var(--ink);
  outline: 3px solid var(--ink);
  outline-offset: 0;
  box-shadow: 6px 6px 0 0 var(--ink);
  transform: translate(-2px, -2px);
}
.apply-form .field input:focus::placeholder,
.apply-form .field textarea:focus::placeholder { color: var(--grey-40); }
.apply-form .field:has(input:focus) label,
.apply-form .field:has(textarea:focus) label,
.apply-form .field:has(select:focus) label { color: var(--ink); background: var(--paper); padding: 2px 6px; align-self: flex-start; }

.apply-form button {
  transition: background 160ms ease, color 160ms ease, transform 120ms ease, box-shadow 160ms ease;
}
.apply-form button:hover {
  transform: translate(-2px, -2px);
  box-shadow: 6px 6px 0 0 var(--ink);
}
.apply-form button:active { transform: translate(0, 0); box-shadow: 2px 2px 0 0 var(--ink); }

/* FAQ blocks: hover lifts + accent corner */
.faq-q { transition: background 200ms ease, color 200ms ease; position: relative; cursor: default; }
.faq-q::after {
  content: "";
  position: absolute;
  inset: auto 0 0 auto;
  width: 0; height: 0;
  border-style: solid;
  border-width: 0 0 14px 14px;
  border-color: transparent transparent var(--red) transparent;
  opacity: 0;
  transition: opacity 200ms ease;
}
.faq-q:hover { background: var(--ink); color: var(--paper); }
.faq-q:hover .n { color: var(--red); }
.faq-q:hover::after { opacity: 1; }

/* PRINCIPLE blocks (methodology): hover red border */
.principle {
  transition: background 200ms ease, color 200ms ease, border-color 200ms ease, transform 160ms ease;
}
.principle:hover {
  background: var(--red);
  color: var(--paper);
  border-color: var(--red);
  transform: translate(-3px, -3px);
}
.principle:hover .l { color: var(--paper); }

/* PROGRAM cards: hover pulse */
.prog {
  transition: transform 200ms ease, box-shadow 200ms ease, z-index 0ms;
}
.prog:hover {
  transform: scale(1.02);
  z-index: 2;
  box-shadow: 0 0 0 3px var(--red);
}

/* THREE-UP tiles (manifesto) */
.three-up .tile {
  transition: transform 200ms ease, box-shadow 200ms ease;
}
.three-up .tile:hover {
  transform: translate(-3px, -3px);
  box-shadow: 6px 6px 0 0 var(--ink);
}
.three-up .tile.ink:hover { box-shadow: 6px 6px 0 0 var(--red); }
.three-up .tile.red:hover { box-shadow: 6px 6px 0 0 var(--ink); }

/* TIER rows: subtle highlight + commission emphasis */
.tier { transition: background 220ms ease, color 220ms ease; cursor: default; }
.tier .step-card { transition: transform 220ms ease; }
.tier:hover .step-card { transform: translateX(-4px); }
.tier:hover .commission { animation: comm-pulse 1.6s ease-in-out infinite; }
@keyframes comm-pulse {
  0%, 100% { transform: scale(1); }
  50% { transform: scale(1.04); }
}

/* COMPARATOR rows: hover highlights column */
.compare-grid .col-head,
.compare-grid .bar-cell,
.compare-grid > div:not(.row-label) {
  transition: background 160ms ease;
}
.compare-grid > div:not(.row-label):hover {
  background: var(--paper-2, #F4F4F2);
}
.compare-grid .bar {
  transition: transform 160ms ease;
}
.compare-grid .bar-cell:hover .bar { transform: scaleY(1.5); transform-origin: bottom; }

/* PARTNER CARDS: hover lift + reveal CTA */
.partner-card {
  transition: transform 220ms cubic-bezier(.2,.7,.2,1), box-shadow 220ms ease;
  cursor: default;
}
.partner-card:hover {
  transform: translate(-4px, -4px);
  box-shadow: 8px 8px 0 0 var(--ink);
  z-index: 3;
}
.partner-card.live:hover { box-shadow: 8px 8px 0 0 var(--ink); }
.partner-card.open:hover {
  background: var(--ink);
  color: var(--paper);
  background-image: none;
}
.partner-card.open:hover .pc-name { opacity: 1; }
.partner-card.open:hover .pc-focus { opacity: 1; }
.partner-card.open:hover .pc-head .status { background: var(--red); color: var(--paper); }
.partner-card a.link {
  transition: gap 160ms ease, color 160ms ease;
}
.partner-card:hover a.link { gap: 12px; color: var(--red); }
.partner-card.live:hover a.link { color: var(--paper); }

/* PARTNER TABS: animated active indicator */
.partner-tabs .tab {
  transition: background 180ms ease, color 180ms ease, padding 180ms ease;
}
.partner-tabs .tab:hover { background: var(--grey-10); }
.partner-tabs .tab.active:hover { background: var(--red); }

/* MAP PINS: numbered markers pulse + scale */
.pin { transition: transform 180ms ease; }
.pin .marker {
  transition: transform 200ms cubic-bezier(.2,.7,.2,1), background 200ms ease, color 200ms ease, box-shadow 200ms ease;
  cursor: pointer;
}
.pin:hover { z-index: 20; }
.pin:hover .marker {
  transform: scale(1.6);
  box-shadow: 0 0 0 4px var(--ink), 0 0 0 6px var(--red);
}
.pin.open:hover .marker { background: var(--red); border-color: var(--paper); }
.pin.soon:hover .marker { background: var(--red); color: var(--paper); border-color: var(--ink); }

/* GEO TABLE rows: hover highlight matching pin (by data-status) */
.geo-table .geo-row {
  transition: background 180ms ease, color 180ms ease, transform 160ms ease;
  cursor: default;
}
.geo-table .geo-row:hover {
  background: var(--ink);
  color: var(--paper);
  transform: translateX(-3px);
}
.geo-table .geo-row:hover .pin-n { background: var(--red); color: var(--paper); border-color: var(--paper); }

/* HERO LANG SWITCHER: hover */
.hero-lang button:not([disabled]):hover {
  background: var(--paper);
  color: var(--red);
}
.hero-lang button[aria-pressed="true"]:hover { background: var(--paper); }

/* TOPBAR LANG SWITCHER: same */
.lang-switch button:not([disabled]):hover {
  background: var(--ink);
  color: var(--paper);
}

/* BUTTONS (CTA): consistent hover with offset shadow */
.cta-apply, .hero-cta-row .btn {
  transition: transform 160ms ease, box-shadow 160ms ease, background 160ms ease, color 160ms ease;
}
.cta-apply:hover, .hero-cta-row .btn:hover {
  transform: translate(-2px, -2px);
  box-shadow: 4px 4px 0 0 currentColor;
}

/* NAV LINKS: animated underline */
.topnav a {
  position: relative;
  transition: color 160ms ease;
}
.topnav a::before {
  content: "";
  position: absolute;
  bottom: -4px; left: 0;
  width: 100%; height: 2px;
  background: var(--red);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 220ms cubic-bezier(.2,.7,.2,1);
}
.topnav a:hover::before { transform: scaleX(1); }
.topnav a:hover { color: var(--red); border-bottom-color: transparent; }

/* CONTACT ITEMS in apply: hover slide arrow */
.contact-list .item { transition: background 180ms ease; cursor: pointer; }
.contact-list .item:hover { background: var(--ink); }
.contact-list .item .arrow { transition: transform 200ms ease; display: inline-block; }
.contact-list .item:hover .arrow { transform: translateX(6px); }

/* PILLAR (founder section) hover */
.pillar { transition: background 200ms ease, color 200ms ease, transform 160ms ease; }
.pillar:hover {
  background: var(--ink);
  color: var(--paper);
  border-color: var(--ink);
  transform: translate(-3px, -3px);
}
.pillar:hover .l { color: var(--red); }

/* SCROLL-IN reveal — applied via IntersectionObserver, see partners-i18n.js */
.reveal {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 600ms ease, transform 600ms cubic-bezier(.2,.7,.2,1);
}
.reveal.in {
  opacity: 1;
  transform: translateY(0);
}

/* TYPING CARET for hero quote — optional flourish */
.hero-sig-quote { position: relative; }
.hero-sig-quote::after {
  content: "_";
  display: inline-block;
  margin-left: 4px;
  color: var(--paper);
  animation: caret 1s steps(2) infinite;
}
@keyframes caret { 50% { opacity: 0; } }

/* ============================================================
   v1.1 — RESPONSIVE & OVERFLOW FIXES
   Тим report 28 мая: «партнёры» наезжает на «AI-FIRST» + horiz scroll.
============================================================ */

/* 1. Long Russian compound words must break, not stretch grid items.
   ВАЖНО: .hero-wordmark (ZININ.AI) исключён — должен быть в 1 строку. */
h2, h3, h4, h5,
.sec-head h2,
.prog h4,
.tier .step-title,
.partner-card h4,
.geo-row .where,
.faq-card h4,
.founder h3,
.cycle-intro h3,
.three-up .tile h3 {
  overflow-wrap: break-word;
  hyphens: auto;
}
.hero-wordmark, .hero-subline .ai-first {
  overflow-wrap: normal;
  word-break: keep-all;
  hyphens: none;
}
/* Hero side card задушивается grid'ом 8fr 4fr на средних desktop'ах —
   сделаем layout 1col уже с 1100px, не ждём mobile breakpoint 960 */
@media (max-width: 1100px) {
  .hero-grid { grid-template-columns: 1fr; gap: 28px; }
  .hero-side { max-width: 560px; }
}
@media (max-width: 380px) {
  .hero-wordmark { overflow-wrap: anywhere; }
}

/* 2. Grid/flex items must not push parent wider than its column */
.prog,
.partner-card,
.geo-row,
.tier .step-body,
.tier .step-card,
.three-up .tile,
.programs,
.cycle-wrap,
.manifesto,
.hero-side,
.flow-step,
.partner-grid,
.geo-table,
.faq-grid {
  min-width: 0;
}

/* 3. Lang dropdown clamp к viewport на узких экранах */
.lang-menu .lang-pop {
  max-width: calc(100vw - 32px);
}

/* 4. Hero side card на узких vw — не должна торчать */
.hero-side { max-width: 100%; box-sizing: border-box; }
.hero-side .stamp { white-space: normal; }

/* 5. Topbar на mobile — тенюшка-разделитель + компактный CTA */
@media (max-width: 960px) {
  .topbar {
    box-shadow: 0 2px 0 0 rgba(0,0,0,0.06);
    padding: 0 18px;
    gap: 12px;
  }
  .topbar .brand .tag {
    font-size: 9px;
    padding-left: 12px;
    line-height: 1.3;
  }
  .topbar .actions { gap: 8px; }
  .cta-apply { padding: 6px 10px; font-size: 10px; }
  .topbar .lang-menu summary { font-size: 10px; padding: 6px 8px; }
  .topbar .lang-menu .cur-name { display: none; }
}

/* 6. Section headings — clamp font-size глобально, чтобы h2 не пересекался с topbar */
.sec-head h2 {
  font-size: clamp(28px, 7vw, 92px);
  line-height: 0.95;
}

/* 7. Apply form inputs — не должны выйти за форму */
.form-grid input,
.form-grid select,
.form-grid textarea {
  max-width: 100%;
  box-sizing: border-box;
}

/* 8. На mobile sticky topbar imeет высокий contrast — добавляем небольшой backdrop */
@media (max-width: 640px) {
  .sec { padding: 56px 18px 48px; }
  .hero-side { padding: 18px; }
  .hero-mini { gap: 8px; }
  .hero-mini .num { font-size: 10px; }
  .prog { padding: 24px 20px; min-height: auto; }
  .prog h4 { font-size: 22px; }
  .prog ul { font-size: 11px; }
  .compare-grid { padding: 0; }
  .form-grid { gap: 12px; }
  .form-row-two { grid-template-columns: 1fr; }
  /* Топбар на самом узком — только бренд + язык, CTA скрываем */
  .cta-apply { display: none; }
  .topbar .brand .tag { display: none; }
  .topbar { grid-template-columns: auto 1fr auto; padding: 0 14px; }
}

/* 9. Геометрия секций — пин-карта не должна вылезать */
#geography .map-canvas { max-width: 100%; overflow: hidden; }

/* 10. Footer AI-FIRST лого тоже должно ужиматься */
.foot-mark { overflow-wrap: anywhere; }

/* 11. Hero wordmark — на mobile clamp агрессивнее, чтобы ZININ.AI не торчал */
@media (max-width: 480px) {
  .hero-wordmark { font-size: clamp(68px, 18vw, 110px) !important; }
  .hero-subline .ai-first { font-size: clamp(22px, 7vw, 32px) !important; }
}
