/* ═══════════════════════════════════════════════════════════════
 * NEXUS DSP — Components
 * Nav · buttons · cards · forms · hero · footer · legal-doc
 * ═══════════════════════════════════════════════════════════════ */

/* ── Nav ───────────────────────────────────────────────────── */

.nav {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: var(--z-nav);
  background: transparent;
  transition: background var(--dur-med) var(--ease-out-expo),
              border-color var(--dur-med) var(--ease-out-expo),
              backdrop-filter var(--dur-med) var(--ease-out-expo);
  border-bottom: 1px solid transparent;
}

.nav.is-scrolled {
  background: rgba(15, 16, 12, 0.78);
  backdrop-filter: blur(16px) saturate(120%);
  -webkit-backdrop-filter: blur(16px) saturate(120%);
  border-bottom-color: var(--rule-2);
}

.nav__inner {
  max-width: var(--wrap-max);
  margin: 0 auto;
  padding: var(--sp-4) var(--wrap-pad);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-6);
}

.wordmark {
  display: inline-flex;
  align-items: baseline;
  gap: 4px;
  font-family: var(--font-serif);
  font-size: 1.5rem;
  font-weight: 600;
  letter-spacing: -0.02em;
  color: var(--ink);
  font-variation-settings: "opsz" 24;
}

.wordmark__dsp {
  color: var(--amber);
  font-family: var(--font-mono);
  font-size: 0.85rem;
  font-weight: 500;
  letter-spacing: 0.12em;
  margin-left: 2px;
  position: relative;
  top: -2px;
}

.wordmark__tm {
  font-family: var(--font-mono);
  font-size: 0.55rem;
  color: var(--ink-3);
  position: relative;
  top: -0.6em;
  margin-left: 1px;
  font-weight: 400;
}

.nav__links {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
}

.nav__link {
  display: inline-block;
  padding: var(--sp-3) var(--sp-4);
  font-family: var(--font-sans);
  font-size: var(--t-ui);
  font-weight: 500;
  color: var(--ink-2);
  border-radius: var(--r-sm);
  transition: color var(--dur-fast) var(--ease-out-expo);
  position: relative;
  min-height: 44px;
  display: inline-flex;
  align-items: center;
}

.nav__link:hover {
  color: var(--ink);
}

.nav__link::after {
  content: '';
  position: absolute;
  left: var(--sp-4);
  right: var(--sp-4);
  bottom: 10px;
  height: 1px;
  background: var(--amber);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform var(--dur-med) var(--ease-out-expo);
}

.nav__link:hover::after {
  transform: scaleX(1);
}

.nav__cta {
  display: none;
}

@media (min-width: 768px) {
  .nav__cta { display: inline-flex; }
}

/* Mobile nav toggle */
.nav__toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  border-radius: var(--r-sm);
  color: var(--ink);
  border: 1px solid var(--rule-2);
  transition: border-color var(--dur-fast) var(--ease-out-expo);
}

.nav__toggle:hover {
  border-color: var(--amber);
}

@media (min-width: 961px) {
  .nav__toggle { display: none; }
}

@media (max-width: 960px) {
  .nav__links,
  .nav__cta { display: none; }
}

/* Mobile drawer */
.drawer {
  position: fixed;
  inset: 0;
  background: var(--paper);
  z-index: var(--z-drawer);
  padding: 80px var(--wrap-pad) var(--sp-12);
  display: flex;
  flex-direction: column;
  gap: var(--sp-1);
  transform: translateX(100%);
  transition: transform var(--dur-med) var(--ease-out-expo);
  visibility: hidden;
}

.drawer.is-open {
  transform: translateX(0);
  visibility: visible;
}

.drawer__link {
  display: flex;
  align-items: center;
  padding: var(--sp-4) 0;
  font-family: var(--font-sans);
  font-size: 1.25rem;
  font-weight: 500;
  color: var(--ink);
  border-bottom: 1px solid var(--rule);
  min-height: 56px;
}

.drawer__link:hover {
  color: var(--amber);
}

.drawer__cta {
  margin-top: var(--sp-6);
  width: 100%;
}

/* ── Buttons ───────────────────────────────────────────────── */

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--sp-2);
  padding: 14px 22px;
  min-height: 48px;
  font-family: var(--font-sans);
  font-size: var(--t-ui);
  font-weight: 600;
  letter-spacing: 0.01em;
  border-radius: var(--r-sm);
  transition: transform var(--dur-fast) var(--ease-out-expo),
              background var(--dur-fast) var(--ease-out-expo),
              border-color var(--dur-fast) var(--ease-out-expo),
              color var(--dur-fast) var(--ease-out-expo);
  white-space: nowrap;
  cursor: pointer;
  border: 1px solid transparent;
  text-align: center;
}

.btn--primary {
  background: var(--amber);
  color: var(--paper);
}

.btn--primary:hover {
  background: #F9C679;
  transform: translateY(-1px);
}

.btn--ghost {
  background: transparent;
  color: var(--ink);
  border-color: var(--rule-2);
}

.btn--ghost:hover {
  border-color: var(--amber);
  color: var(--amber);
  transform: translateY(-1px);
}

.btn--subtle {
  background: transparent;
  color: var(--ink-2);
  padding: var(--sp-2) var(--sp-3);
  min-height: auto;
}

.btn--subtle:hover {
  color: var(--amber);
}

.btn--full {
  width: 100%;
}

.btn__arrow {
  font-family: var(--font-mono);
  font-weight: 400;
  transition: transform var(--dur-fast) var(--ease-out-expo);
}

.btn:hover .btn__arrow {
  transform: translateX(3px);
}

/* ── Section header ────────────────────────────────────────── */

.section {
  padding: var(--sp-20) 0;
}

.section--tall {
  padding: var(--sp-32) 0;
}

.section__head {
  max-width: 820px;
  margin-bottom: var(--sp-12);
}

.section__kicker {
  margin-bottom: var(--sp-5);
}

.section__h2 {
  margin-bottom: var(--sp-5);
}

.section__lede {
  font-size: var(--t-body-lg);
  line-height: 1.55;
  color: var(--ink-2);
  max-width: 620px;
}

/* ── Data card ─────────────────────────────────────────────── */

.card {
  background: var(--paper-3);
  border: 1px solid var(--rule);
  border-radius: var(--r-xl);
  padding: var(--sp-8);
  transition: border-color var(--dur-fast) var(--ease-out-expo),
              transform var(--dur-fast) var(--ease-out-expo);
}

.card:hover {
  border-color: var(--rule-2);
  transform: translateY(-1px);
}

.card__label {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  margin-bottom: var(--sp-4);
  font-family: var(--font-mono);
  font-size: var(--t-kicker);
  font-weight: 500;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--steel);
}

.card__h3 {
  margin-bottom: var(--sp-3);
  font-size: 1.35rem;
  letter-spacing: -0.012em;
}

.card__body {
  color: var(--ink-2);
  font-size: 0.975rem;
  line-height: 1.6;
}

.card__body p + p {
  margin-top: var(--sp-3);
}

/* ── Metric pill (inline) ──────────────────────────────────── */

.pill {
  display: inline-flex;
  align-items: baseline;
  gap: var(--sp-2);
  padding: 2px 0;
  font-family: var(--font-mono);
  font-size: var(--t-mono);
  font-feature-settings: "tnum";
}

.pill__label {
  color: var(--ink-3);
  text-transform: uppercase;
  font-size: var(--t-kicker);
  letter-spacing: 0.1em;
  font-weight: 500;
}

.pill__val {
  color: var(--ink);
  font-weight: 500;
}

.pill__unit {
  color: var(--ink-3);
  font-size: var(--t-kicker);
}

/* ── Pricing ───────────────────────────────────────────────── */

.pricing {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-5);
  margin-top: var(--sp-12);
}

@media (max-width: 900px) {
  .pricing { grid-template-columns: 1fr; gap: var(--sp-4); }
}

.tier {
  background: var(--paper-3);
  border: 1px solid var(--rule);
  border-radius: var(--r-xl);
  padding: var(--sp-8) var(--sp-8) var(--sp-10);
  position: relative;
  display: flex;
  flex-direction: column;
  transition: border-color var(--dur-fast) var(--ease-out-expo),
              transform var(--dur-fast) var(--ease-out-expo);
}

.tier:hover {
  border-color: var(--rule-2);
  transform: translateY(-2px);
}

.tier--anchor {
  background: var(--paper-4);
  border-color: var(--amber-rule);
}

.tier--anchor:hover {
  border-color: var(--amber);
}

.tier__ribbon {
  position: absolute;
  top: -10px;
  right: 24px;
  padding: 4px 12px;
  background: var(--amber);
  color: var(--paper);
  font-family: var(--font-mono);
  font-size: var(--t-kicker);
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  border-radius: var(--r-sm);
}

.tier__name {
  font-family: var(--font-serif);
  font-size: 1.75rem;
  font-weight: 600;
  color: var(--ink);
  margin-bottom: var(--sp-1);
  letter-spacing: -0.012em;
}

.tier__tag {
  font-family: var(--font-sans);
  font-size: var(--t-ui);
  color: var(--ink-2);
  margin-bottom: var(--sp-6);
}

.tier__price {
  display: flex;
  align-items: baseline;
  gap: var(--sp-1);
  margin-bottom: var(--sp-2);
  font-family: var(--font-serif);
  color: var(--ink);
}

.tier__price-amt {
  font-size: 3.25rem;
  font-weight: 600;
  letter-spacing: -0.04em;
  line-height: 1;
  font-variation-settings: "opsz" 32;
}

.tier__price-per {
  font-family: var(--font-sans);
  font-size: var(--t-ui);
  color: var(--ink-2);
  font-weight: 500;
}

.tier__stations {
  font-family: var(--font-mono);
  font-size: var(--t-mono);
  color: var(--ink-2);
  margin-bottom: var(--sp-6);
}

.tier__features {
  margin: 0 0 var(--sp-8);
  padding: var(--sp-5) 0 0;
  border-top: 1px solid var(--rule);
  flex: 1;
}

.tier__features li {
  padding: var(--sp-3) 0;
  border-bottom: 1px dashed var(--rule);
  font-family: var(--font-sans);
  font-size: var(--t-ui);
  color: var(--ink-2);
  display: grid;
  grid-template-columns: 16px 1fr;
  gap: var(--sp-3);
  align-items: flex-start;
  line-height: 1.5;
}

.tier__features li:last-child {
  border-bottom: none;
}

.tier__features li::before {
  content: '+';
  color: var(--amber);
  font-family: var(--font-mono);
  font-weight: 500;
  padding-top: 1px;
}

.tier__features li.out {
  color: var(--ink-3);
}

.tier__features li.out::before {
  content: '−';
  color: var(--ink-3);
}

.tier__cta {
  width: 100%;
}

/* ── Form ─────────────────────────────────────────────────── */

.form {
  display: flex;
  flex-direction: column;
  gap: var(--sp-6);
  max-width: 560px;
}

.field {
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
}

.field__label {
  font-family: var(--font-sans);
  font-size: var(--t-ui);
  font-weight: 500;
  color: var(--ink);
}

.field__hint {
  font-family: var(--font-mono);
  font-size: var(--t-kicker);
  color: var(--ink-3);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  margin-left: var(--sp-3);
}

.field__control,
.form input[type="text"],
.form input[type="email"],
.form input[type="number"],
.form input[type="tel"],
.form input[type="url"],
.form select,
.form textarea {
  width: 100%;
  min-height: 48px;
  padding: 12px 14px;
  background: var(--paper-2);
  border: 1px solid var(--rule-2);
  border-radius: var(--r-sm);
  font-family: var(--font-sans);
  font-size: var(--t-ui);
  color: var(--ink);
  transition: border-color var(--dur-fast) var(--ease-out-expo);
}

.form textarea {
  min-height: 120px;
  padding: 14px;
  resize: vertical;
  font-family: var(--font-sans);
  line-height: 1.55;
}

.form input::placeholder,
.form textarea::placeholder {
  color: var(--ink-3);
}

.form input:hover,
.form select:hover,
.form textarea:hover {
  border-color: var(--ink-3);
}

.form input:focus-visible,
.form select:focus-visible,
.form textarea:focus-visible {
  border-color: var(--amber);
  outline: 2px solid var(--amber);
  outline-offset: 0;
  background: var(--paper-2);
}

.form .field--error input,
.form .field--error textarea,
.form .field--error select {
  border-color: var(--rose);
}

.field__error {
  font-family: var(--font-sans);
  font-size: var(--t-ui-sm);
  color: var(--rose);
}

.field__error::before {
  content: "!";
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 14px;
  height: 14px;
  background: var(--rose-dim);
  color: var(--rose);
  border-radius: 50%;
  font-family: var(--font-mono);
  font-size: 9px;
  font-weight: 600;
  margin-right: var(--sp-2);
  vertical-align: 1px;
}

.field--honeypot {
  position: absolute;
  left: -9999px;
  width: 1px;
  height: 1px;
  overflow: hidden;
}

/* ── Footer ─────────────────────────────────────────────────── */

.footer {
  margin-top: var(--sp-24);
  padding: var(--sp-12) 0 var(--sp-8);
  border-top: 1px solid var(--rule-2);
  background: var(--paper);
}

.footer__inner {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: var(--sp-12);
  margin-bottom: var(--sp-10);
}

@media (max-width: 900px) {
  .footer__inner { grid-template-columns: 1fr 1fr; gap: var(--sp-8); }
}

@media (max-width: 560px) {
  .footer__inner { grid-template-columns: 1fr; gap: var(--sp-6); }
}

.footer__brand .wordmark {
  font-size: 1.75rem;
  margin-bottom: var(--sp-3);
}

.footer__blurb {
  font-family: var(--font-serif);
  font-size: 0.9375rem;
  line-height: 1.6;
  color: var(--ink-2);
  max-width: 360px;
}

.footer__col h6 {
  font-family: var(--font-mono);
  font-size: var(--t-kicker);
  font-weight: 500;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--steel);
  margin-bottom: var(--sp-4);
  padding-bottom: var(--sp-3);
  border-bottom: 1px solid var(--rule-2);
}

.footer__col a {
  display: block;
  padding: var(--sp-2) 0;
  font-family: var(--font-sans);
  font-size: var(--t-ui);
  color: var(--ink-2);
  transition: color var(--dur-fast) var(--ease-out-expo);
  min-height: 36px;
  display: flex;
  align-items: center;
}

.footer__col a:hover {
  color: var(--amber);
}

.footer__meta {
  padding-top: var(--sp-5);
  border-top: 1px solid var(--rule-2);
  display: flex;
  justify-content: space-between;
  gap: var(--sp-6);
  flex-wrap: wrap;
  font-family: var(--font-mono);
  font-size: var(--t-kicker);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-3);
  font-weight: 500;
}

.footer__disclaimer {
  margin-top: var(--sp-6);
  padding: var(--sp-5);
  border: 1px dashed var(--rule-2);
  border-radius: var(--r-sm);
  font-family: var(--font-serif);
  font-size: 0.85rem;
  line-height: 1.6;
  color: var(--ink-2);
}

.footer__disclaimer b {
  color: var(--ink);
  font-weight: 600;
}

/* ═══════════════════════════════════════════════════════════════
 * HERO COMPOSITION — "The reading"
 * ═══════════════════════════════════════════════════════════════ */

.hero {
  padding-top: 120px;
  padding-bottom: var(--sp-24);
  position: relative;
}

.hero__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-16);
  align-items: start;
}

@media (min-width: 1024px) {
  .hero__grid {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1.05fr);
    gap: var(--sp-16);
    align-items: center;
  }
}

.hero__lede {
  max-width: 560px;
}

.hero__kicker {
  margin-bottom: var(--sp-6);
}

.hero__h1 {
  margin-bottom: var(--sp-6);
}

.hero__h1 .line-2 {
  color: var(--ink-2);
  display: block;
}

.hero__sub {
  font-family: var(--font-serif);
  font-size: var(--t-body-lg);
  line-height: 1.55;
  color: var(--ink-2);
  max-width: 580px;
  margin-bottom: var(--sp-10);
  letter-spacing: -0.005em;
}

.hero__sub strong {
  color: var(--ink);
  font-weight: 400;
  font-style: italic;
  font-variation-settings: "opsz" 18;
}

.hero__ctas {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-3);
  margin-bottom: var(--sp-10);
}

.hero__sign {
  display: flex;
  gap: var(--sp-6);
  padding-top: var(--sp-6);
  border-top: 1px solid var(--rule);
  font-family: var(--font-mono);
  font-size: var(--t-mono);
  color: var(--ink-3);
  flex-wrap: wrap;
}

.hero__sign b {
  color: var(--ink-2);
  font-weight: 500;
  display: block;
  margin-bottom: 2px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-size: var(--t-kicker);
}

/* Hero composition container */
.hero__scene {
  position: relative;
  padding: var(--sp-3);
  border-radius: var(--r-xl);
  background: linear-gradient(180deg, var(--paper-3) 0%, var(--paper-2) 100%);
  border: 1px solid var(--rule);
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.02) inset,
              0 30px 60px -30px rgba(0, 0, 0, 0.5);
  min-height: 500px;
}

/* Layer 1 — Weekly Service Overview replica */
.wso {
  background: var(--paper-2);
  border: 1px solid var(--rule-2);
  border-radius: calc(var(--r-xl) - 4px);
  overflow: hidden;
  position: relative;
}

.wso__head {
  padding: var(--sp-4) var(--sp-5);
  border-bottom: 1px solid var(--rule-2);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-4);
  flex-wrap: wrap;
  background: var(--paper-3);
}

.wso__title {
  font-family: var(--font-mono);
  font-size: var(--t-kicker);
  font-weight: 500;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--steel);
}

.wso__title b {
  color: var(--ink);
  margin-left: var(--sp-2);
  font-weight: 500;
}

.wso__week {
  font-family: var(--font-mono);
  font-size: var(--t-kicker);
  color: var(--ink-3);
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.wso__week b {
  color: var(--ink);
  font-weight: 500;
}

.wso__cols {
  display: grid;
  grid-template-columns: 32px 1.6fr repeat(8, minmax(0, 1fr)) 52px;
  padding: var(--sp-3) var(--sp-5);
  background: var(--paper-3);
  border-bottom: 1px solid var(--rule);
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-3);
  gap: 2px;
}

.wso__cols span {
  text-align: right;
}

.wso__cols span:first-child,
.wso__cols span:nth-child(2) {
  text-align: left;
}

.wso__row {
  display: grid;
  grid-template-columns: 32px 1.6fr repeat(8, minmax(0, 1fr)) 52px;
  padding: var(--sp-3) var(--sp-5);
  border-bottom: 1px solid var(--rule);
  align-items: center;
  font-family: var(--font-mono);
  font-size: var(--t-mono);
  color: var(--ink);
  gap: 2px;
  transition: background var(--dur-fast) var(--ease-out-expo);
  opacity: 0;
  transform: translate(20px, 10px);
  animation: rowIn var(--dur-hero) var(--ease-out-expo) forwards;
}

.wso__row:last-child { border-bottom: none; }

.wso__row:nth-child(1) { animation-delay: 0ms; }
.wso__row:nth-child(2) { animation-delay: 50ms; }
.wso__row:nth-child(3) { animation-delay: 100ms; }
.wso__row:nth-child(4) { animation-delay: 150ms; }
.wso__row:nth-child(5) { animation-delay: 200ms; }
.wso__row:nth-child(6) { animation-delay: 250ms; }

.wso__row:hover {
  background: var(--paper-3);
}

.wso__rank {
  font-size: 11px;
  color: var(--ink-3);
  font-weight: 500;
  text-align: left;
}

.wso__who {
  display: flex;
  flex-direction: column;
  gap: 2px;
  text-align: left;
  min-width: 0;
}

.wso__who-name {
  color: var(--ink);
  font-family: var(--font-sans);
  font-size: var(--t-ui);
  font-weight: 500;
  letter-spacing: -0.005em;
  display: flex;
  align-items: center;
  gap: var(--sp-2);
}

.wso__who-id {
  color: var(--ink-3);
  font-size: 10px;
  letter-spacing: 0.05em;
  font-weight: 400;
}

.wso__val {
  text-align: right;
  font-feature-settings: "tnum";
  font-size: 12px;
}

.wso__val--dim   { color: var(--ink-3); }
.wso__val--good  { color: var(--sage); }
.wso__val--warn  { color: var(--warn); }
.wso__val--crit  { color: var(--rose); }
.wso__val--accent { color: var(--amber); font-weight: 500; }

.wso__sqi {
  text-align: right;
  font-size: var(--t-ui);
  font-weight: 500;
  letter-spacing: -0.01em;
}

/* Tier pill inside WSO row */
.t-pill {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  padding: 1px 6px 2px;
  font-family: var(--font-mono);
  font-size: 9px;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  border-radius: var(--r-sm);
  border: 1px solid transparent;
  flex-shrink: 0;
}

.t-pill--elite  { color: var(--amber); background: var(--amber-dim); border-color: var(--amber-rule); }
.t-pill--splus  { color: var(--steel); background: var(--steel-dim); border-color: var(--steel); }
.t-pill--sla    { color: var(--sage);  background: var(--sage-dim);  border-color: var(--sage); }
.t-pill--slam   { color: var(--warn);  background: var(--warn-dim);  border-color: var(--warn); }
.t-pill--crit   { color: var(--rose);  background: var(--rose-dim);  border-color: var(--rose); }

/* Layer 2 — Copy Message floating card */
.msg {
  position: absolute;
  right: 12px;
  top: 42%;
  width: 270px;
  background: var(--paper-4);
  border: 1px solid var(--rule-2);
  border-radius: var(--r-lg);
  padding: var(--sp-4) var(--sp-5) var(--sp-5);
  font-family: var(--font-sans);
  font-size: 0.8125rem;
  line-height: 1.5;
  color: var(--ink-2);
  box-shadow: 0 20px 40px -18px rgba(0, 0, 0, 0.6);
  opacity: 0;
  transform: translate(16px, 8px);
  animation: fadeIn var(--dur-slow) var(--ease-out-expo) 500ms forwards;
  z-index: 2;
}

.msg::before {
  content: '';
  position: absolute;
  left: -1px;
  top: -1px;
  width: 10px;
  height: 10px;
  border-top: 2px solid var(--amber);
  border-left: 2px solid var(--amber);
  border-top-left-radius: var(--r-lg);
}

.msg__head {
  display: flex;
  gap: var(--sp-2);
  align-items: baseline;
  font-family: var(--font-mono);
  font-size: var(--t-kicker);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ink-3);
  margin-bottom: var(--sp-3);
  padding-bottom: var(--sp-3);
  border-bottom: 1px solid var(--rule);
}

.msg__head b {
  color: var(--ink);
  font-weight: 500;
}

.msg__line {
  color: var(--ink);
  font-weight: 500;
  margin-bottom: var(--sp-3);
  font-family: var(--font-serif);
  font-size: 0.95rem;
  line-height: 1.45;
}

.msg__body {
  margin: 0;
  padding: 0;
}

.msg__body li {
  padding-left: var(--sp-4);
  position: relative;
  margin-bottom: var(--sp-2);
  color: var(--ink-2);
}

.msg__body li::before {
  content: '·';
  position: absolute;
  left: 6px;
  top: -2px;
  color: var(--amber);
  font-family: var(--font-mono);
  font-size: 1.2rem;
}

.msg__foot {
  margin-top: var(--sp-4);
  padding-top: var(--sp-3);
  border-top: 1px solid var(--rule);
  font-family: var(--font-mono);
  font-size: var(--t-kicker);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-3);
}

/* Layer 3 — MEP snippet */
.mep {
  position: absolute;
  right: 22px;
  bottom: 18px;
  padding: var(--sp-3) var(--sp-4);
  background: var(--paper-4);
  border: 1px solid var(--rule);
  border-left: 2px solid var(--steel);
  border-radius: var(--r-sm);
  font-family: var(--font-mono);
  font-size: var(--t-kicker);
  letter-spacing: 0.08em;
  color: var(--ink-2);
  max-width: 280px;
  opacity: 0;
  animation: fadeIn var(--dur-slow) var(--ease-out-expo) 900ms forwards;
  transition: opacity var(--dur-med) var(--ease-out-expo);
}

.mep:hover {
  opacity: 1 !important;
}

.mep__label {
  color: var(--steel);
  text-transform: uppercase;
  font-weight: 500;
  margin-bottom: 2px;
}

.mep__val {
  font-family: var(--font-sans);
  font-size: var(--t-ui);
  color: var(--ink);
  letter-spacing: -0.005em;
  font-weight: 500;
  text-transform: none;
}

.mep__val b {
  color: var(--amber);
  font-family: var(--font-mono);
  font-weight: 500;
  font-feature-settings: "tnum";
}

/* Compact hero scene on small viewports */
@media (max-width: 1023px) {
  .hero { padding-top: 96px; padding-bottom: var(--sp-16); }
  .hero__scene { min-height: 0; padding: var(--sp-2); }
  .wso__cols,
  .wso__row {
    grid-template-columns: 24px 1.4fr repeat(4, minmax(0, 1fr)) 52px;
    font-size: 11px;
  }
  .wso__cols span:nth-child(3),
  .wso__cols span:nth-child(4),
  .wso__cols span:nth-child(5),
  .wso__cols span:nth-child(6),
  .wso__cols span:nth-child(7),
  .wso__cols span:nth-child(8),
  .wso__cols span:nth-child(9),
  .wso__cols span:nth-child(10),
  .wso__cols span:nth-child(11),
  .wso__row > *:nth-child(3),
  .wso__row > *:nth-child(4),
  .wso__row > *:nth-child(5),
  .wso__row > *:nth-child(6),
  .wso__row > *:nth-child(7),
  .wso__row > *:nth-child(8),
  .wso__row > *:nth-child(9),
  .wso__row > *:nth-child(10),
  .wso__row > *:nth-child(11) {
    display: none;
  }
  /* On mobile keep only rank + who + sqi + show just DCR + DSC + tier pill */
  .wso__cols span.m-keep,
  .wso__row > *.m-keep {
    display: block;
  }
  .msg { position: static; width: auto; margin-top: var(--sp-4); transform: none; }
  .msg::before { display: none; }
  .mep { position: static; margin-top: var(--sp-4); max-width: none; }
}

@keyframes rowIn {
  to { opacity: 1; transform: translate(0, 0); }
}

@keyframes fadeIn {
  to { opacity: 1; transform: translate(0, 0); }
}

@media (prefers-reduced-motion: reduce) {
  .wso__row,
  .msg,
  .mep {
    animation: none;
    opacity: 1;
    transform: none;
  }
}

/* ═══════════════════════════════════════════════════════════════
 * SECTION: THE 4-DAY WINDOW
 * ═══════════════════════════════════════════════════════════════ */

.window {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border: 1px solid var(--rule-2);
  border-radius: var(--r-lg);
  overflow: hidden;
  background: var(--paper-3);
}

@media (max-width: 800px) {
  .window { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 480px) {
  .window { grid-template-columns: 1fr; }
}

.window__cell {
  padding: var(--sp-6);
  border-right: 1px solid var(--rule);
  border-bottom: 1px solid var(--rule);
}

.window__cell:nth-child(4n) { border-right: none; }

@media (max-width: 800px) {
  .window__cell { border-right: none; }
  .window__cell:nth-child(odd) { border-right: 1px solid var(--rule); }
}

.window__day {
  font-family: var(--font-mono);
  font-size: var(--t-kicker);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--steel);
  margin-bottom: var(--sp-3);
  font-weight: 500;
}

.window__event {
  font-family: var(--font-serif);
  font-size: 1.25rem;
  line-height: 1.3;
  color: var(--ink);
  font-weight: 600;
  letter-spacing: -0.01em;
  margin-bottom: var(--sp-3);
}

.window__body {
  font-family: var(--font-sans);
  font-size: var(--t-ui);
  line-height: 1.55;
  color: var(--ink-2);
}

/* ═══════════════════════════════════════════════════════════════
 * SECTION: CAPABILITIES GRID
 * ═══════════════════════════════════════════════════════════════ */

.caps {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-4);
  margin-top: var(--sp-10);
}

@media (max-width: 900px) {
  .caps { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 560px) {
  .caps { grid-template-columns: 1fr; }
}

/* ═══════════════════════════════════════════════════════════════
 * SECTION: EVIDENCE (before/after)
 * ═══════════════════════════════════════════════════════════════ */

.evidence {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--sp-5);
  margin-top: var(--sp-10);
}

@media (max-width: 800px) {
  .evidence { grid-template-columns: 1fr; }
}

.evidence__col {
  background: var(--paper-3);
  border: 1px solid var(--rule);
  border-radius: var(--r-lg);
  overflow: hidden;
}

.evidence__head {
  padding: var(--sp-3) var(--sp-5);
  border-bottom: 1px solid var(--rule);
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: var(--sp-4);
  font-family: var(--font-mono);
  font-size: var(--t-kicker);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-3);
  font-weight: 500;
  background: var(--paper-2);
}

.evidence__head b {
  color: var(--ink);
  font-weight: 500;
  letter-spacing: 0.1em;
}

.evidence__body {
  padding: var(--sp-5);
  min-height: 240px;
  font-family: var(--font-mono);
  font-size: var(--t-mono);
  color: var(--ink-2);
}

.evidence__body.before {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 1px;
  background: var(--rule);
  padding: 1px;
}

.evidence__body.before span {
  background: var(--paper-3);
  padding: 6px 8px;
  color: var(--ink-3);
  font-size: 11px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.evidence__body.before span.h {
  background: var(--paper-2);
  color: var(--ink-2);
  font-weight: 500;
  font-size: 10px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.defence {
  display: flex;
  flex-direction: column;
  gap: var(--sp-4);
}

.defence__block {
  padding: var(--sp-4) var(--sp-5);
  background: var(--paper-2);
  border-left: 2px solid var(--amber);
  border-radius: 0 var(--r-sm) var(--r-sm) 0;
  font-family: var(--font-serif);
  font-size: 0.9375rem;
  line-height: 1.55;
  color: var(--ink);
}

.defence__block b {
  color: var(--amber);
  font-weight: 500;
  font-family: var(--font-mono);
  font-size: 0.85rem;
  letter-spacing: -0.01em;
  display: block;
  margin-bottom: 4px;
}

/* ═══════════════════════════════════════════════════════════════
 * SECTION: DRIVER CONVERSATION (big Copy Message card)
 * ═══════════════════════════════════════════════════════════════ */

.convo {
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: var(--sp-12);
  margin-top: var(--sp-10);
  align-items: start;
}

@media (max-width: 900px) {
  .convo { grid-template-columns: 1fr; }
}

.convo__note {
  font-family: var(--font-serif);
  font-size: 1.0625rem;
  line-height: 1.65;
  color: var(--ink-2);
}

.convo__note p + p {
  margin-top: var(--sp-4);
}

.convo__note b {
  color: var(--ink);
  font-weight: 600;
}

.convo__msg {
  padding: var(--sp-6) var(--sp-6) var(--sp-8);
  background: var(--paper-3);
  border: 1px solid var(--rule-2);
  border-radius: var(--r-lg);
  font-family: var(--font-sans);
  font-size: var(--t-ui);
  line-height: 1.6;
  color: var(--ink);
}

.convo__msg-head {
  padding-bottom: var(--sp-3);
  border-bottom: 1px solid var(--rule);
  margin-bottom: var(--sp-4);
  font-family: var(--font-mono);
  font-size: var(--t-kicker);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-3);
}

.convo__msg-head b {
  color: var(--ink);
  font-weight: 500;
  margin-right: var(--sp-3);
}

.convo__msg pre {
  font-family: var(--font-mono);
  font-size: 0.8125rem;
  line-height: 1.75;
  color: var(--ink-2);
  white-space: pre-wrap;
  word-break: break-word;
}

.convo__msg pre b {
  color: var(--ink);
  font-weight: 500;
}

.convo__foot {
  margin-top: var(--sp-5);
  padding-top: var(--sp-4);
  border-top: 1px solid var(--rule);
  font-family: var(--font-mono);
  font-size: var(--t-kicker);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--sage);
}

/* ═══════════════════════════════════════════════════════════════
 * SECTION: PILOTS + SECURITY
 * ═══════════════════════════════════════════════════════════════ */

.trust {
  display: grid;
  grid-template-columns: 1.3fr 1fr;
  gap: var(--sp-12);
  margin-top: var(--sp-10);
}

@media (max-width: 900px) {
  .trust { grid-template-columns: 1fr; }
}

.trust__pilots h3 {
  font-size: 1.35rem;
  margin-bottom: var(--sp-4);
  font-weight: 600;
}

.trust__co {
  display: flex;
  gap: var(--sp-6);
  flex-wrap: wrap;
  padding: var(--sp-5) 0;
  border-top: 1px solid var(--rule);
  border-bottom: 1px solid var(--rule);
  font-family: var(--font-serif);
  font-size: 1.0625rem;
  color: var(--ink);
  letter-spacing: -0.01em;
  font-variation-settings: "opsz" 18;
}

.trust__co span {
  position: relative;
  padding-right: var(--sp-6);
}

.trust__co span::after {
  content: '·';
  position: absolute;
  right: -2px;
  color: var(--ink-3);
}

.trust__co span:last-child { padding-right: 0; }
.trust__co span:last-child::after { content: none; }

.trust__co-tag {
  color: var(--ink-3);
  font-family: var(--font-mono);
  font-size: 0.75rem;
  letter-spacing: 0.08em;
}

.trust__facts {
  display: flex;
  flex-direction: column;
  gap: 0;
  background: var(--paper-3);
  border: 1px solid var(--rule-2);
  border-radius: var(--r-lg);
  overflow: hidden;
}

.trust__fact {
  padding: var(--sp-4) var(--sp-5);
  border-bottom: 1px solid var(--rule);
  display: grid;
  grid-template-columns: 110px 1fr;
  gap: var(--sp-4);
  align-items: baseline;
}

.trust__fact:last-child { border-bottom: none; }

.trust__fact-k {
  font-family: var(--font-mono);
  font-size: var(--t-kicker);
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--steel);
}

.trust__fact-v {
  font-family: var(--font-sans);
  font-size: var(--t-ui);
  color: var(--ink);
  font-weight: 500;
}

.trust__fact-v b {
  color: var(--amber);
  font-weight: 500;
  font-family: var(--font-mono);
  font-size: 0.8125rem;
  letter-spacing: -0.005em;
}

/* ═══════════════════════════════════════════════════════════════
 * SECTION: CLOSING CTA
 * ═══════════════════════════════════════════════════════════════ */

.close {
  text-align: left;
  padding: var(--sp-24) 0 var(--sp-20);
  border-top: 1px solid var(--rule-2);
}

.close__kicker { margin-bottom: var(--sp-6); }

.close h2 {
  font-size: clamp(2.5rem, 5.2vw, 4rem);
  line-height: 1.02;
  max-width: 820px;
  margin-bottom: var(--sp-8);
  font-variation-settings: "opsz" 40;
}

.close h2 em {
  font-style: italic;
  font-variation-settings: "opsz" 40;
  color: var(--amber);
}

.close__sub {
  font-family: var(--font-serif);
  font-size: var(--t-body-lg);
  line-height: 1.55;
  color: var(--ink-2);
  max-width: 620px;
  margin-bottom: var(--sp-10);
}

.close__ctas {
  display: flex;
  gap: var(--sp-3);
  flex-wrap: wrap;
}

/* ═══════════════════════════════════════════════════════════════
 * SECTION: THE READ (section 2, explainer)
 * ═══════════════════════════════════════════════════════════════ */

.read {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--sp-12);
  margin-top: var(--sp-10);
  align-items: center;
}

@media (max-width: 900px) {
  .read { grid-template-columns: 1fr; }
}

.read__note {
  font-family: var(--font-serif);
  font-size: 1.0625rem;
  line-height: 1.65;
  color: var(--ink-2);
}

.read__note p + p { margin-top: var(--sp-4); }
.read__note b { color: var(--ink); font-weight: 600; }

.read__panel {
  padding: var(--sp-5);
  background: var(--paper-3);
  border: 1px solid var(--rule-2);
  border-radius: var(--r-lg);
  font-family: var(--font-mono);
  font-size: var(--t-mono);
  color: var(--ink-2);
}

.read__row {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: var(--sp-4);
  padding: var(--sp-3) 0;
  border-bottom: 1px solid var(--rule);
}

.read__row:first-child { padding-top: 0; }
.read__row:last-child { border-bottom: none; padding-bottom: 0; }

.read__row-k {
  color: var(--steel);
  font-size: var(--t-kicker);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  padding-top: 2px;
  font-weight: 500;
  min-width: 80px;
}

.read__row-v {
  color: var(--ink);
  font-family: var(--font-sans);
  font-size: var(--t-ui);
  line-height: 1.5;
}

.read__row-v b {
  color: var(--amber);
  font-family: var(--font-mono);
  font-size: 0.8125rem;
  font-weight: 500;
}

/* ═══════════════════════════════════════════════════════════════
 * LEGAL / DOCS PAGES
 * ═══════════════════════════════════════════════════════════════ */

.doc {
  padding: 140px 0 var(--sp-20);
}

.doc__head {
  margin-bottom: var(--sp-12);
  padding-bottom: var(--sp-10);
  border-bottom: 1px solid var(--rule-2);
}

.doc__strap {
  font-family: var(--font-mono);
  font-size: var(--t-kicker);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--steel);
  margin-bottom: var(--sp-4);
  font-weight: 500;
}

.doc__title {
  margin-bottom: var(--sp-5);
  letter-spacing: -0.02em;
}

.doc__meta {
  display: flex;
  gap: var(--sp-6);
  flex-wrap: wrap;
  font-family: var(--font-mono);
  font-size: var(--t-kicker);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ink-3);
  font-weight: 500;
}

.doc__meta b {
  color: var(--ink);
  font-weight: 500;
}

.doc__layout {
  display: grid;
  grid-template-columns: 200px 1fr;
  gap: var(--sp-16);
  align-items: start;
}

@media (max-width: 900px) {
  .doc__layout { grid-template-columns: 1fr; gap: var(--sp-8); }
}

.doc__toc {
  position: sticky;
  top: 100px;
  font-family: var(--font-sans);
  font-size: var(--t-ui);
}

@media (max-width: 900px) {
  .doc__toc { position: static; }
}

.doc__toc-head {
  font-family: var(--font-mono);
  font-size: var(--t-kicker);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--steel);
  margin-bottom: var(--sp-3);
  padding-bottom: var(--sp-3);
  border-bottom: 1px solid var(--rule-2);
  font-weight: 500;
}

.doc__toc a {
  display: block;
  padding: var(--sp-2) 0;
  color: var(--ink-2);
  transition: color var(--dur-fast) var(--ease-out-expo);
  font-size: 0.875rem;
  line-height: 1.4;
  border-left: 2px solid transparent;
  padding-left: var(--sp-3);
  margin-left: calc(-1 * var(--sp-3));
}

.doc__toc a:hover {
  color: var(--ink);
  border-left-color: var(--amber);
}

.doc__main {
  max-width: var(--body-max);
}

.doc__sec {
  margin-top: var(--sp-12);
}

.doc__sec:first-child { margin-top: 0; }

.doc__sec-num {
  font-family: var(--font-mono);
  font-size: var(--t-kicker);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--amber);
  margin-bottom: var(--sp-3);
  font-weight: 500;
}

.doc__sec h2 {
  font-size: 1.625rem;
  line-height: 1.2;
  letter-spacing: -0.01em;
  margin-bottom: var(--sp-5);
  scroll-margin-top: 100px;
}

.doc__sec h3 {
  font-size: 1.1rem;
  font-weight: 600;
  margin-top: var(--sp-6);
  margin-bottom: var(--sp-3);
  color: var(--ink);
  scroll-margin-top: 100px;
}

.doc__sec p {
  font-family: var(--font-serif);
  font-size: 17px;
  line-height: 1.7;
  color: var(--ink);
  margin-bottom: var(--sp-4);
}

.doc__sec p b,
.doc__sec p strong {
  color: var(--ink);
  font-weight: 600;
}

.doc__sec ul {
  margin: var(--sp-3) 0 var(--sp-5);
}

.doc__sec ul li {
  padding: var(--sp-2) 0 var(--sp-2) var(--sp-5);
  position: relative;
  font-family: var(--font-serif);
  font-size: 17px;
  line-height: 1.65;
  color: var(--ink);
}

.doc__sec ul li::before {
  content: '·';
  position: absolute;
  left: 8px;
  top: 0;
  color: var(--amber);
  font-size: 1.6rem;
  line-height: 1.2;
  font-family: var(--font-mono);
}

.doc__sec ul li b {
  color: var(--ink);
  font-weight: 600;
}

.doc__sec a {
  color: var(--amber);
  border-bottom: 1px solid var(--amber-rule);
  transition: border-color var(--dur-fast) var(--ease-out-expo);
}

.doc__sec a:hover {
  border-bottom-color: var(--amber);
}

/* Docs tables */
.doc__table {
  margin: var(--sp-5) 0;
  border: 1px solid var(--rule-2);
  border-radius: var(--r-sm);
  overflow-x: auto;
}

.doc__table table {
  font-family: var(--font-mono);
  font-size: var(--t-mono);
  min-width: 520px;
}

.doc__table th {
  text-align: left;
  padding: var(--sp-3) var(--sp-4);
  font-size: var(--t-kicker);
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--steel);
  background: var(--paper-2);
  border-bottom: 1px solid var(--rule-2);
}

.doc__table td {
  padding: var(--sp-3) var(--sp-4);
  color: var(--ink-2);
  border-bottom: 1px solid var(--rule);
  vertical-align: top;
  line-height: 1.5;
}

.doc__table td:first-child {
  color: var(--ink);
  font-weight: 500;
  white-space: nowrap;
}

.doc__table tr:last-child td {
  border-bottom: none;
}

/* Security-page specific facts block */
.sec-facts {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--sp-4);
  margin: var(--sp-8) 0;
}

@media (max-width: 640px) {
  .sec-facts { grid-template-columns: 1fr; }
}

.sec-fact {
  padding: var(--sp-5);
  background: var(--paper-3);
  border: 1px solid var(--rule);
  border-radius: var(--r-lg);
}

.sec-fact__label {
  font-family: var(--font-mono);
  font-size: var(--t-kicker);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--steel);
  margin-bottom: var(--sp-3);
  font-weight: 500;
}

.sec-fact__val {
  font-family: var(--font-serif);
  font-size: 1.125rem;
  line-height: 1.4;
  color: var(--ink);
  font-weight: 600;
  margin-bottom: var(--sp-2);
}

.sec-fact__note {
  font-family: var(--font-sans);
  font-size: var(--t-ui-sm);
  line-height: 1.5;
  color: var(--ink-2);
}

/* ═══════════════════════════════════════════════════════════════
 * THANKS PAGE
 * ═══════════════════════════════════════════════════════════════ */

.thanks {
  padding: 180px 0 var(--sp-24);
}

.thanks__kicker { margin-bottom: var(--sp-5); }

.thanks h1 {
  font-size: clamp(2.5rem, 5.5vw, 4.25rem);
  line-height: 1.02;
  max-width: 760px;
  margin-bottom: var(--sp-6);
  letter-spacing: -0.02em;
  font-variation-settings: "opsz" 42;
}

.thanks h1 em {
  font-style: italic;
  color: var(--amber);
  font-variation-settings: "opsz" 42;
}

.thanks__sub {
  font-family: var(--font-serif);
  font-size: var(--t-body-lg);
  line-height: 1.55;
  color: var(--ink-2);
  max-width: 620px;
  margin-bottom: var(--sp-12);
}

.steps {
  margin: var(--sp-8) 0 var(--sp-12);
  border-top: 1px solid var(--rule);
  border-bottom: 1px solid var(--rule);
}

.step {
  display: grid;
  grid-template-columns: 56px 1fr;
  gap: var(--sp-5);
  padding: var(--sp-5) 0;
  border-bottom: 1px dashed var(--rule);
  align-items: start;
}

.step:last-child { border-bottom: none; }

.step__n {
  font-family: var(--font-mono);
  font-size: 1.5rem;
  font-weight: 500;
  color: var(--amber);
  line-height: 1;
  padding-top: 2px;
}

.step__head {
  font-family: var(--font-serif);
  font-size: 1.25rem;
  font-weight: 600;
  color: var(--ink);
  margin-bottom: var(--sp-2);
  letter-spacing: -0.01em;
}

.step__body {
  font-family: var(--font-sans);
  font-size: var(--t-ui);
  line-height: 1.6;
  color: var(--ink-2);
  max-width: 640px;
}

/* ═══════════════════════════════════════════════════════════════
 * UTIL
 * ═══════════════════════════════════════════════════════════════ */

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}
