/* ============================================================
   CACHERACING.COM — «EDITORIAL PIT-WALL» v3 (web)
   Tokens portados de design_v3 (tokens-v3.css). Tema oscuro plano,
   esquinas RECTAS, sin gradientes/glow. Display: Archivo 700-900.
   Datos/tiempos: IBM Plex Mono + tabular-nums.
   ============================================================ */

:root {
  /* ---- Superficies ---- */
  --cr3-panel-alpha: 0.94;
  --cr3-panel: rgba(12, 13, 16, var(--cr3-panel-alpha));
  --cr3-bg-0: #0c0d10;
  --cr3-bg-1: #131419;
  --cr3-bg-2: #1a1b21;

  /* ---- Líneas ---- */
  --cr3-line: #26272d;
  --cr3-line-strong: #383a42;

  /* ---- Tinta ---- */
  --cr3-ink: #f4f4f6;
  --cr3-dim: #a9abb3;
  --cr3-faint: #6f7178;

  /* ---- Acentos ---- */
  --cr3-accent-rgb: 47, 116, 255;
  --cr3-accent: rgb(var(--cr3-accent-rgb));
  --cr3-accent-up: #6f9dff;
  --cr3-danger: #ff4d4f;
  --cr3-danger-up: #ff8b8b;
  --cr3-ok: #37d399;
  --cr3-warn: #ffb547;
  --cr3-gold: #e8c35a;
  --cr3-violet: #8b5cf6;

  /* ---- Tipografía ---- */
  --cr3-display: "Archivo", "Bahnschrift", "Segoe UI", sans-serif;
  --cr3-mono: "IBM Plex Mono", "Consolas", monospace;
  --cr3-track: 0.14em;

  /* ---- Geometría ---- */
  --cr3-r: 0px;            /* esquinas rectas SIEMPRE */
  --cr3-skew: -10deg;
  --cr3-s-1: 4px;  --cr3-s-2: 8px;  --cr3-s-3: 12px;
  --cr3-s-4: 16px; --cr3-s-5: 24px; --cr3-s-6: 32px;

  /* ---- Estados ---- */
  --cr3-hover: rgba(255, 255, 255, 0.04);
  --cr3-disabled-op: 0.4;
}

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

html { scroll-behavior: smooth; }

body {
  background: var(--cr3-bg-0);
  color: var(--cr3-ink);
  font-family: var(--cr3-mono);
  font-size: 15px;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
}

img { display: block; max-width: 100%; height: auto; }
a { color: var(--cr3-accent-up); text-decoration: none; }
a:hover { text-decoration: underline; }
button { font: inherit; cursor: pointer; }

:focus-visible { outline: 2px solid var(--cr3-accent); outline-offset: 2px; }

.wrap { max-width: 1000px; margin: 0 auto; padding: 0 20px; }
.is-hidden { display: none !important; }
.sp { flex: 1 1 auto; }
.ta-r { text-align: right; }

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  * { transition: none !important; animation: none !important; }
}

/* ============================================================
   CLASES NÚCLEO v3
   ============================================================ */
.c3-card {
  background: var(--cr3-panel);
  border: 1px solid var(--cr3-line);
  color: var(--cr3-ink);
}

.c3-index {
  font-family: var(--cr3-mono);
  font-size: 14px;
  font-weight: 500;
  letter-spacing: var(--cr3-track);
  color: var(--cr3-faint);
  text-transform: uppercase;
}

.c3-title {
  font-family: var(--cr3-display);
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 0.01em;
  line-height: 0.95;
  color: var(--cr3-ink);
}

.c3-kicker {
  font-family: var(--cr3-mono);
  font-size: 14px;
  font-weight: 600;
  letter-spacing: var(--cr3-track);
  text-transform: uppercase;
  color: var(--cr3-accent-up);
}

.c3-data {
  font-family: var(--cr3-mono);
  font-size: 15px;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--cr3-dim);
  font-variant-numeric: tabular-nums;
}

.c3-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  transform: skewX(var(--cr3-skew));
  background: var(--cr3-accent);
  color: #0b0c0f;
  font-family: var(--cr3-mono);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: var(--cr3-track);
  text-transform: uppercase;
  padding: 5px 12px;
}
.c3-badge > * { transform: skewX(calc(var(--cr3-skew) * -1)); }
.c3-badge i { width: 7px; height: 7px; border-radius: 50%; background: #0b0c0f; }
.c3-badge--ok { background: var(--cr3-ok); }
.c3-badge--warn { background: var(--cr3-warn); }
.c3-badge--violet { background: var(--cr3-violet); }
.c3-badge--danger { background: var(--cr3-danger); }
.c3-badge--ghost {
  background: transparent;
  color: var(--cr3-accent-up);
  border: 1px solid rgba(var(--cr3-accent-rgb), 0.5);
}
.c3-badge--ghost i { background: var(--cr3-accent-up); }

.c3-rule { height: 1px; background: var(--cr3-line); border: 0; }

.c3-corner {
  position: absolute;
  right: -5px; bottom: 18px;
  width: 5px; height: 42px;
  background: var(--cr3-accent);
}

.c3-bar { position: absolute; background: var(--cr3-accent); }
.c3-bar--top { top: -5px; left: 16px; width: 96px; height: 5px; }

/* ============================================================
   HERO / MASTHEAD
   ============================================================ */
.hero { padding-top: 36px; }
.hero-index { padding-bottom: 18px; border-bottom: 1px solid var(--cr3-line); }

.hero-mast {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 24px;
  padding: 32px 0 8px 0;
}
.hero-logo { height: 140px; width: auto; flex: 0 0 auto; }
.hero-text { display: flex; flex-direction: column; gap: 14px; min-width: 0; }

.hero-title { font-size: clamp(56px, 13vw, 112px); }
.hero-title b { color: var(--cr3-accent-up); font-weight: 900; }

.hero-kicker { font-size: 14px; }

.hero-cta {
  display: flex;
  align-items: center;
  gap: var(--cr3-s-3);
  width: 100%;
  max-width: 420px;
  margin-top: 10px;
  background: var(--cr3-accent);
  color: #0b0c0f;
  font-family: var(--cr3-mono);
  font-size: 15px;
  font-weight: 700;
  letter-spacing: var(--cr3-track);
  text-transform: uppercase;
  padding: 14px 16px;
}
.hero-cta:hover { background: var(--cr3-accent-up); text-decoration: none; }
.hero-cta .arrow { flex: 1 1 auto; text-align: right; font-weight: 400; }

@media (min-width: 720px) {
  .hero { padding-top: 48px; }
  .hero-mast { flex-direction: row; align-items: center; gap: 40px; padding: 44px 0 12px 0; }
  .hero-logo { height: 200px; }
}

/* ============================================================
   SECCIONES + TARJETAS
   ============================================================ */
.sec { padding: 36px 0 0 0; }
.sec-head { padding-bottom: 12px; }

.card { position: relative; padding: 0 0 18px 0; margin-top: 5px; }
.card + .card { margin-top: 32px; }   /* tarjetas apiladas dentro de la misma sección */

.card-head {
  display: flex;
  align-items: center;
  gap: var(--cr3-s-3);
  padding: 14px 16px 0 16px;
}
.card-head-data { font-size: 14px; }

.card-title { font-size: clamp(30px, 7vw, 44px); padding: 12px 16px 0 16px; word-break: break-word; }
.card-title--sm { font-size: clamp(24px, 5.5vw, 34px); }
.card-kicker { padding: 8px 16px 0 16px; }
.card-names { padding: 14px 16px 0 16px; font-size: 14px; }
.card-note { padding: 10px 16px 0 16px; font-size: 13px; color: var(--cr3-warn); }
.card-record { padding: 10px 16px 0 16px; font-size: 14px; color: var(--cr3-gold); }

/* ============================================================
   CARRERA EN VIVO
   ============================================================ */
.clockbox {
  display: flex;
  align-items: baseline;
  padding: 14px 16px 0 16px;
}
.clock {
  font-family: var(--cr3-mono);
  font-size: clamp(34px, 9vw, 52px);
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.01em;
  line-height: 1;
  color: var(--cr3-ink);
}
.clock.is-count { color: var(--cr3-warn); }
.clock.is-green { color: var(--cr3-ok); }

/* --- cola de salida escalonada --- */
.launch { margin: 18px 16px 0 16px; border: 1px solid var(--cr3-line); background: var(--cr3-bg-1); }
.launch-title { padding: 10px 12px; border-bottom: 1px solid var(--cr3-line); font-size: 12px; }
.launch-row {
  display: flex;
  align-items: baseline;
  gap: 10px;
  padding: 9px 12px;
  border-top: 1px solid var(--cr3-line);
  font-family: var(--cr3-mono);
  font-size: 14px;
  font-variant-numeric: tabular-nums;
}
.launch-row:first-of-type { border-top: 0; }
.launch-row .n { color: var(--cr3-faint); font-weight: 700; flex: 0 0 auto; }
.launch-row .who {
  font-family: var(--cr3-display);
  font-weight: 800;
  font-size: 16px;
  text-transform: uppercase;
  letter-spacing: 0.02em;
  color: var(--cr3-ink);
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.launch-row .sp { flex: 1 1 auto; }
.launch-row .go { color: var(--cr3-warn); font-weight: 700; letter-spacing: 0.08em; flex: 0 0 auto; }
.launch-row .wait { color: var(--cr3-faint); letter-spacing: 0.08em; flex: 0 0 auto; }
.launch-row.is-next .who { color: var(--cr3-warn); }

/* --- leaderboard --- */
.lb { margin-top: 18px; overflow-x: auto; }
.lb-inner { min-width: 640px; }

.lb-head {
  display: grid;
  grid-template-columns: 48px minmax(0, 1fr) 84px 120px 96px;
  gap: var(--cr3-s-2);
  padding: 10px 16px;
  border-top: 1px solid var(--cr3-line);
  border-bottom: 1px solid var(--cr3-line);
  font-family: var(--cr3-mono);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: var(--cr3-track);
  text-transform: uppercase;
  color: var(--cr3-faint);
}

.lb-row {
  display: grid;
  grid-template-columns: 48px minmax(0, 1fr) 84px 120px 96px;
  align-items: baseline;
  gap: var(--cr3-s-2);
  padding: 10px 16px;
  border-top: 1px solid var(--cr3-line);
}
.lb-row:first-child { border-top: 0; }

.lb-pos {
  font-family: var(--cr3-mono);
  font-size: 15px;
  font-weight: 700;
  color: var(--cr3-faint);
  font-variant-numeric: tabular-nums;
}
.lb-row.is-p1 .lb-pos { color: var(--cr3-gold); }

.lb-name {
  font-family: var(--cr3-display);
  font-weight: 800;
  font-size: 18px;
  text-transform: uppercase;
  letter-spacing: 0.02em;
  color: var(--cr3-ink);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  display: flex;
  align-items: baseline;
  gap: 8px;
  min-width: 0;
}
.lb-name > * { flex: 0 0 auto; }
.lb-name .txt { flex: 0 1 auto; min-width: 0; overflow: hidden; text-overflow: ellipsis; }

/* mini-badges de fila (categoría / DESC / PAUSA) */
.lb-tag {
  font-family: var(--cr3-mono);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.1em;
  color: #0b0c0f;
  background: var(--cr3-accent);
  padding: 1px 6px;
  transform: skewX(var(--cr3-skew));
}
.lb-tag span { display: inline-block; transform: skewX(calc(var(--cr3-skew) * -1)); }
.lb-tag--cat2 { background: var(--cr3-dim); }
.lb-tag--desc { background: var(--cr3-danger); }
.lb-tag--pause { background: var(--cr3-warn); }

.lb-wp, .lb-time, .lb-diff {
  font-family: var(--cr3-mono);
  font-variant-numeric: tabular-nums;
  text-align: right;
}
.lb-wp { font-size: 14px; color: var(--cr3-dim); }
.lb-time { font-size: 16px; font-weight: 600; color: var(--cr3-ink); }
.lb-time.is-gold { color: var(--cr3-gold); }
.lb-diff { font-size: 14px; color: var(--cr3-faint); }

.lb-row.is-out { opacity: 0.45; }
.lb-row.is-out .lb-name { text-decoration: line-through; }
.lb-row.is-out .lb-time { color: var(--cr3-danger); font-size: 13px; letter-spacing: 0.1em; font-weight: 700; }

/* ============================================================
   SEGUIMIENTO LIVE · TELEMETRÍA POR PILOTO
   ============================================================ */
.sec-head--row { display: flex; align-items: center; gap: var(--cr3-s-3); }

/* indicador de frescura (EN VIVO / HACE Ns) */
.tele-fresh {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--cr3-mono);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: var(--cr3-track);
  text-transform: uppercase;
  color: var(--cr3-faint);
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}
.tele-fresh i { width: 8px; height: 8px; border-radius: 50%; background: var(--cr3-faint); flex: 0 0 auto; }
.tele-fresh.is-live { color: var(--cr3-ok); }
.tele-fresh.is-live i { background: var(--cr3-ok); animation: cr3-pulse 1.6s ease-in-out infinite; }
.tele-fresh.is-warn { color: var(--cr3-warn); }
.tele-fresh.is-warn i { background: var(--cr3-warn); }
.tele-fresh.is-bad { color: var(--cr3-danger); }
.tele-fresh.is-bad i { background: var(--cr3-danger); }

@keyframes cr3-pulse {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.3; }
}

/* grid responsive: 1 col móvil · 2-3 desktop */
.tele-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 28px 20px;
  padding-top: 10px; /* hueco para la c3-bar--top de la primera fila */
}
@media (min-width: 640px) { .tele-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 960px) { .tele-grid { grid-template-columns: repeat(3, 1fr); } }

.tele-card { position: relative; padding: 0 0 16px 0; }
.tele-card .c3-bar--top { width: 64px; }
.tele-card .c3-corner { bottom: 14px; height: 34px; }

.tele-head { padding: 12px 14px 0 14px; }
.tele-user {
  font-size: clamp(22px, 4.5vw, 27px);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.tele-veh {
  padding-top: 6px;
  font-size: 12px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* métricas 2×2: mono grande tabular */
.tele-metrics {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px 16px;
  padding: 14px 14px 0 14px;
}
.tele-m { min-width: 0; }
.tele-m-label { font-size: 11px; }
.tele-m-value {
  font-family: var(--cr3-mono);
  font-size: clamp(20px, 4.6vw, 25px);
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.01em;
  line-height: 1.1;
  color: var(--cr3-ink);
  padding-top: 4px;
  white-space: nowrap;
}
.tele-m-value.is-warn { color: var(--cr3-warn); }
.tele-m-value.is-bad { color: var(--cr3-danger); }
.tele-m-unit { font-size: 13px; font-weight: 600; letter-spacing: 0.06em; color: var(--cr3-dim); }

/* barra horizontal v3 (gasolina) */
.tele-bar {
  height: 6px;
  margin-top: 8px;
  background: var(--cr3-bg-2);
  border: 1px solid var(--cr3-line);
}
.tele-bar i {
  display: block;
  height: 100%;
  width: 0%;
  background: var(--cr3-faint);
  transition: width 160ms linear, background-color 160ms linear;
}
.tele-bar i.is-ok { background: var(--cr3-ok); }
.tele-bar i.is-warn { background: var(--cr3-warn); }
.tele-bar i.is-bad { background: var(--cr3-danger); }

/* iconos de métricas (WEB-6): HP/temp/aceite — mismos 22px que la bomba */
.tele-ico {
  width: 22px;
  height: 22px;
  flex: 0 0 auto;
  color: var(--cr3-faint);
  transition: color 160ms linear;
}
.tele-ico.is-ok { color: var(--cr3-ok); }
.tele-ico.is-warn { color: var(--cr3-warn); }
.tele-ico.is-bad { color: var(--cr3-danger); }
.tele-ico--hp { color: var(--cr3-accent); }

/* bomba de gasolina (WEB-5): icono junto al % — acompaña el estado del tanque */
.tele-fuel-row { display: flex; align-items: center; gap: 8px; }
.tele-pump {
  width: 22px;
  height: 22px;
  flex: 0 0 auto;
  color: var(--cr3-faint);
  transition: color 160ms linear;
}
.tele-pump.is-ok { color: var(--cr3-ok); }
.tele-pump.is-warn { color: var(--cr3-warn); }
.tele-pump.is-bad {
  color: var(--cr3-danger);
  animation: pumpPulse 1.1s ease-in-out infinite alternate;
}
@keyframes pumpPulse { from { opacity: 0.5; } to { opacity: 1; } }

/* aceite: punto de estado + etiqueta */
.tele-oil { display: flex; align-items: center; gap: 7px; padding-top: 7px; }
.tele-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--cr3-faint); flex: 0 0 auto; }
.tele-dot.is-ok { background: var(--cr3-ok); }
.tele-dot.is-bad { background: var(--cr3-danger); }
.tele-oil-lbl {
  font-family: var(--cr3-mono);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--cr3-faint);
}
.tele-oil-lbl.is-ok { color: var(--cr3-ok); }
.tele-oil-lbl.is-bad { color: var(--cr3-danger); }

/* ============================================================
   FOOTER
   ============================================================ */
.foot { padding: 48px 20px 28px 20px; }
.foot-row {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 24px;
  justify-content: space-between;
  padding-top: 14px;
}
.foot-row .c3-data { font-size: 13px; }
.foot-upd { color: var(--cr3-faint); }
