/* ==========================================================
   OMNIX// — home.css  (FILE 00 — THE NETWORK)
   Homepage sections. Mobile-first; enhancements in min-width.
   ========================================================== */

/* ========== COVER / HERO ========== */
.hero {
  position: relative;
  min-height: 100svh;
  display: flex;
  align-items: flex-end;
  padding: calc(var(--nav-h) + 40px) var(--pad-x) clamp(40px, 8vh, 88px);
  overflow: hidden;
}
#cover-canvas {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  z-index: 0;
  opacity: 0.55;
}
.hero::after {
  content: '';
  position: absolute;
  inset: 0;
  z-index: 1;
  background: linear-gradient(180deg, rgba(11,11,12,0.35) 0%, rgba(11,11,12,0.05) 38%, rgba(11,11,12,0.8) 100%);
  pointer-events: none;
}
.hero__inner { position: relative; z-index: 2; width: 100%; max-width: var(--container); margin-inline: auto; }
.hero__file { margin-bottom: clamp(20px, 4vh, 40px); }
.hero__headline { margin: 0; }
.hero__headline .line { display: block; }
.hero__headline .stop { color: var(--spot); }

.hero__foot {
  display: flex;
  flex-direction: column;
  gap: clamp(28px, 5vh, 48px);
  align-items: flex-start;
  margin-top: clamp(32px, 6vh, 56px);
}
.hero__chip { display: flex; flex-direction: column; gap: 6px; }
.hero__fig {
  font-family: var(--serif);
  font-variation-settings: 'opsz' 144, 'wght' 900;
  font-size: clamp(2.5rem, 6vw, 4.5rem);
  line-height: 0.9;
  letter-spacing: -0.02em;
  color: var(--paper);
}
.hero__cap {
  font-family: var(--mono);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.2em;
  color: var(--mist);
}
.hero__cap .slash { color: var(--spot); }

@media (min-width: 860px) {
  .hero__foot { flex-direction: row; align-items: flex-end; justify-content: space-between; gap: var(--s-7); }
  .hero__chip { text-align: right; align-items: flex-end; }
}

/* ========== THE TAPE ========== */
.tape { border-block: 1px solid var(--line); overflow: hidden; padding-block: 14px; background: var(--ink-2); }
.tape__track { display: flex; width: max-content; animation: tape 42s linear infinite; }
.tape__set {
  display: flex;
  align-items: center;
  list-style: none;
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--bone);
  white-space: nowrap;
}
.tape__set li { position: relative; padding: 0 clamp(20px, 3vw, 40px); }
.tape__set li::after {
  content: '';
  position: absolute;
  right: -3px; top: 50%;
  width: 5px; height: 5px;
  background: var(--spot);
  transform: translateY(-50%) rotate(45deg);
}
@keyframes tape { to { transform: translateX(-50%); } }
@media (prefers-reduced-motion: reduce) {
  .tape__track { animation: none; }
  .tape { overflow-x: auto; }
}
.tape:hover .tape__track { animation-play-state: paused; }

/* ========== TWO PARTIES ========== */
.parties {
  max-width: var(--content);
  margin-inline: auto;
  padding: clamp(72px, 12vw, 150px) var(--pad-x);
}
.parties__frame {
  font-family: var(--mono);
  text-transform: uppercase;
  letter-spacing: 0.24em;
  font-size: var(--fs-label);
  color: var(--mist);
  margin-bottom: var(--s-7);
}
.parties__cols { display: grid; gap: var(--s-7); }
.party__tag {
  display: block;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--spot);
  margin-bottom: var(--s-3);
}
.party__line {
  font-family: var(--serif);
  font-variation-settings: 'opsz' 40, 'wght' 400;
  font-size: clamp(1.55rem, 3.4vw, 2.6rem);
  line-height: 1.15;
  letter-spacing: -0.01em;
  color: var(--paper);
}
.parties__close {
  margin-top: var(--s-7);
  font-size: clamp(1.05rem, 1.6vw, 1.3rem);
  font-weight: 500;
  color: var(--bone);
}
@media (min-width: 760px) {
  .parties__cols { grid-template-columns: 1fr 1fr; gap: 0; }
  .party { padding-inline: clamp(24px, 3vw, 48px); }
  .party:first-child { padding-left: 0; border-right: 1px solid var(--line); }
  .party:last-child { padding-right: 0; }
}

/* ========== DOCTRINE / 01 ========== */
.doctrine {
  max-width: var(--container);
  margin-inline: auto;
  padding: clamp(64px, 10vw, 140px) var(--pad-x);
  border-top: 1px solid var(--line);
}
.doctrine__text {
  font-family: var(--serif);
  font-variation-settings: 'opsz' 144, 'wght' 300;
  font-size: clamp(2rem, 4.6vw, 3.5rem);
  line-height: 1.24;
  letter-spacing: -0.01em;
  color: var(--paper);
  max-width: 20em;
}

/* ========== VERTICALS WE RUN / 02 (contents table) ========== */
.fields {
  max-width: var(--container);
  margin-inline: auto;
  padding: clamp(64px, 10vw, 140px) var(--pad-x);
  border-top: 1px solid var(--line);
}
.fields__head { margin-bottom: var(--s-8); }
.fields__head .file-label { margin-bottom: var(--s-5); }
.fields__list { list-style: none; border-top: 1px solid var(--line-2); }
.field-row {
  display: grid;
  grid-template-columns: auto 1fr;
  grid-template-areas: "num name" "desc desc" "fig fig";
  gap: var(--s-3) var(--s-4);
  align-items: baseline;
  padding-block: var(--s-6);
  border-bottom: 1px solid var(--line);
  position: relative;
  transition: background var(--dur-fast) var(--ease), padding-inline var(--dur-fast) var(--ease);
}
.field-row__num { grid-area: num; font-family: var(--mono); font-size: 12px; color: var(--spot); letter-spacing: 0.16em; }
.field-row__name {
  grid-area: name;
  font-family: var(--serif);
  font-variation-settings: 'opsz' 40, 'wght' 400;
  font-size: clamp(1.4rem, 2.6vw, 2.1rem);
  letter-spacing: -0.01em;
  line-height: 1;
  color: var(--paper);
}
.field-row__desc { grid-area: desc; font-size: 0.95rem; line-height: 1.55; color: var(--mist); max-width: 56ch; }
.field-row__fig { grid-area: fig; font-family: var(--mono); }
.field-row__fig b { color: var(--bone); font-weight: 700; transition: color var(--dur-fast) var(--ease); }
.field-row__fig .alt { color: var(--mist); font-size: 12px; }

.field-row::before {
  content: '';
  position: absolute;
  left: calc(var(--pad-x) * -1);
  top: 0; bottom: 0;
  width: 2px;
  background: var(--spot);
  transform: scaleY(0);
  transform-origin: top;
  transition: transform var(--dur-fast) var(--ease);
}
.field-row:hover, .field-row:focus-visible { background: var(--ink-2); }
.field-row:hover::before, .field-row:focus-visible::before { transform: scaleY(1); }
.field-row:hover .field-row__fig b, .field-row:focus-visible .field-row__fig b { color: var(--spot); }

@media (min-width: 880px) {
  .fields__head { display: flex; align-items: flex-end; justify-content: space-between; gap: var(--s-6); }
  .fields__head .file-label { margin-bottom: 0; }
  .field-row {
    grid-template-columns: 3.5rem minmax(11rem, 1.1fr) minmax(0, 2fr) minmax(9rem, auto);
    grid-template-areas: "num name desc fig";
    align-items: center;
    gap: var(--s-6);
    padding-inline: var(--s-5);
  }
  .field-row__fig { text-align: right; }
  .field-row__fig .alt { display: block; }
}

/* ========== BY THE NUMBERS (asymmetric data plate) ========== */
.numbers {
  max-width: var(--container);
  margin-inline: auto;
  padding: clamp(64px, 10vw, 140px) var(--pad-x);
  border-top: 1px solid var(--line);
}
.numbers__h { margin-bottom: var(--s-8); }
.numbers__grid { display: grid; gap: var(--s-7); }
.stat__label {
  display: block;
  font-family: var(--mono);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.2em;
  color: var(--spot);
  margin-bottom: var(--s-3);
}
.stat__val { display: block; font-family: var(--mono); font-weight: 700; font-size: clamp(2.5rem, 7vw, 3.75rem); line-height: 0.9; color: var(--paper); }
.stat__sub { margin-top: var(--s-3); font-size: 0.9rem; line-height: 1.5; color: var(--mist); max-width: 34ch; }
.stat--hero .stat__val {
  font-family: var(--serif);
  font-variation-settings: 'opsz' 144, 'wght' 900;
  font-size: clamp(4.5rem, 16vw, 11rem);
  letter-spacing: -0.03em;
}
@media (min-width: 820px) {
  .numbers__grid {
    grid-template-columns: 1.05fr 0.95fr;
    column-gap: clamp(48px, 8vw, 120px);
    row-gap: 0;
  }
  .stat--hero { grid-column: 1; grid-row: 1 / span 3; align-self: start; }
  .stat:not(.stat--hero) { grid-column: 2; padding-block: var(--s-6); border-top: 1px solid var(--line); }
  .stat:not(.stat--hero):first-of-type { border-top: 0; }
}

/* ========== THE ROSTER / 04 (redacted register) ========== */
.register {
  position: relative;
  padding: clamp(80px, 13vw, 170px) var(--pad-x);
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  overflow: hidden;
  background: var(--ink);
}
.register__veil {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: clamp(10px, 2.4vw, 22px);
  padding-inline: var(--pad-x);
  font-family: var(--mono);
  font-size: clamp(13px, 2.2vw, 20px);
  letter-spacing: 0.12em;
  color: var(--bone);
  opacity: 0.1;
  filter: blur(3px);
  pointer-events: none;
  user-select: none;
  white-space: nowrap;
  overflow: hidden;
}
.register::after {
  content: '';
  position: absolute;
  inset: 0;
  z-index: 1;
  background: radial-gradient(ellipse 70% 65% at 50% 50%, rgba(11,11,12,0.92) 32%, rgba(11,11,12,0.55) 100%);
  pointer-events: none;
}
.register__card { position: relative; z-index: 2; max-width: 600px; margin-inline: auto; text-align: center; }
.register__card .file-label { justify-content: center; margin-bottom: var(--s-5); }
.register__stamp {
  display: inline-block;
  font-family: var(--mono);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.26em;
  color: var(--spot);
  border: 1px solid var(--spot);
  padding: 7px 14px;
  border-radius: 3px;
  margin-bottom: var(--s-6);
}
.register__card h2 { margin-bottom: var(--s-5); }
.register__body { margin: 0 auto var(--s-7); color: var(--bone); }

/* ========== THE PACT / 05 (timeline) ========== */
.pact {
  max-width: var(--content);
  margin-inline: auto;
  padding: clamp(64px, 10vw, 140px) var(--pad-x);
}
.pact__head { margin-bottom: var(--s-8); }
.pact__head .file-label { margin-bottom: var(--s-5); }
.pact__list { list-style: none; position: relative; }
.pact__list::before {
  content: '';
  position: absolute;
  left: 13px; top: 8px; bottom: 8px;
  width: 1px;
  background: var(--line-2);
}
.pact__step {
  display: grid;
  grid-template-columns: 56px 1fr;
  gap: var(--s-5);
  padding-block: var(--s-6);
  position: relative;
}
.pact__num {
  position: relative;
  font-family: var(--mono);
  font-size: 13px;
  font-weight: 700;
  color: var(--spot);
  letter-spacing: 0.12em;
  padding-top: 4px;
}
.pact__num::before {
  content: '';
  position: absolute;
  left: 7px; top: 8px;
  width: 13px; height: 13px;
  background: var(--ink);
  border: 1px solid var(--spot);
  border-radius: 50%;
  transform: translateX(-50%);
}
.pact__body h3 { margin-bottom: var(--s-3); }
.pact__body p { color: var(--mist); }
@media (min-width: 760px) {
  .pact__step { grid-template-columns: 88px 1fr; gap: var(--s-7); }
  .pact__body { display: grid; grid-template-columns: minmax(12rem, 1fr) 2fr; gap: var(--s-6); align-items: baseline; }
}

/* ========== FIELD REPORT (testimonial) ========== */
.report {
  max-width: var(--container);
  margin-inline: auto;
  padding: clamp(72px, 12vw, 160px) var(--pad-x);
  border-top: 1px solid var(--line);
}
.report > .file-label { margin-bottom: var(--s-7); }
.report__fig { margin: 0; }
.report__quote {
  font-family: var(--serif);
  font-style: italic;
  font-variation-settings: 'opsz' 72, 'wght' 400;
  font-size: clamp(1.7rem, 4.4vw, 3.4rem);
  line-height: 1.22;
  letter-spacing: -0.01em;
  color: var(--paper);
  max-width: 18em;
}
.report__cite { display: flex; flex-direction: column; gap: 4px; margin-top: var(--s-7); font-family: var(--mono); }
.report__name { font-size: 14px; letter-spacing: 0.08em; color: var(--paper); }
.report__role { font-size: 12px; letter-spacing: 0.08em; color: var(--mist); }
.report__result { margin-top: var(--s-4); font-size: 13px; }
.report__result b { color: var(--spot); font-weight: 700; }
.report__result .alt { color: var(--mist); }
@media (min-width: 880px) {
  .report__fig { display: grid; grid-template-columns: minmax(0, 2.2fr) minmax(0, 1fr); gap: clamp(40px, 6vw, 96px); align-items: end; }
  .report__cite { margin-top: 0; }
}

/* ========== SIGN-OFF (final CTA) ========== */
.signoff {
  position: relative;
  text-align: center;
  padding: clamp(80px, 14vw, 190px) var(--pad-x);
  border-top: 1px solid var(--line);
  overflow: hidden;
}
.signoff__bar { position: absolute; top: 0; left: 0; right: 0; height: 6px; background: var(--spot); }
.signoff__title { margin: 0 0 var(--s-6); }
.signoff__title em { color: var(--spot); }
.signoff__sub { max-width: 44ch; margin: 0 auto var(--s-7); color: var(--bone); font-size: var(--fs-read); }
.signoff .btn { margin-inline: auto; }
