/* ============================================================
   Noticias de F1 — estilos propios de la sección
   ------------------------------------------------------------
   Se carga DESPUÉS de colors_and_type.css y blog.css.
   - SOBREESCRIBE los VALORES de los tokens compartidos
     (--accent pasa de cobalto a rojo de carreras, etc.).
   - AÑADE tokens y clases nuevas propias de F1.
   - No renombra ningún token existente.
   Vanilla CSS. Funciona en claro/oscuro y ES/EN igual que el blog.
   ============================================================ */

/* ---------------------------------------------------------
   1 · OVERRIDES DE TOKENS COMPARTIDOS — identidad F1 (rojo)
   --------------------------------------------------------- */
:root {
  /* Acento — rojo de carreras (reemplaza al cobalto del blog) */
  --accent: #E8002D;
  --accent-hover: #C70027;
  --accent-press: #A8001F;
  --accent-soft: #FFEAEE;
  --accent-soft-border: #FFC7D0;
  --accent-fg: #C70027;
  --selection: #FFD2DA;
  --shadow-focus: 0 0 0 3px var(--accent-soft);

  /* La rejilla técnica del placeholder hereda el rojo */
  --grid-line: rgba(232, 0, 45, 0.10);

  /* ---- Tokens NUEVOS propios de F1 ---- */
  --f1-display: "Saira Semi Condensed", "Saira", var(--font-sans);
  --f1-display-wide: "Saira", var(--font-sans);

  /* Superficie "carbono" — paneles tipo telemetría, alto contraste */
  --f1-carbon: #16181F;
  --f1-carbon-2: #1E212B;
  --f1-carbon-line: #2C303C;
  --f1-carbon-fg: #F4F5F7;
  --f1-carbon-muted: #9AA1B2;
  --f1-carbon-faint: #6A7180;

  /* Colores por categoría — cada chip su color */
  --cat-race: #E8002D;     /* Carrera */
  --cat-quali: #8B2FE6;    /* Clasificación — púrpura (vuelta rápida) */
  --cat-market: #D98A00;   /* Mercado de pilotos — ámbar */
  --cat-tech: #0E8FA8;     /* Técnica — turquesa */
  --cat-rules: #1F9D63;    /* Reglamento — verde */

  --f1-purple: #8B2FE6;    /* púrpura "vuelta rápida" */
  --f1-amber: #D98A00;

  --f1-stripe: repeating-linear-gradient(-58deg, var(--accent) 0 8px, transparent 8px 16px);
}

[data-theme="dark"] {
  --accent: #FF3B4E;
  --accent-hover: #FF6470;
  --accent-press: #FF2538;
  --accent-soft: #2A0E14;
  --accent-soft-border: #56131E;
  --accent-fg: #FF6E7A;
  --selection: #4A101A;
  --grid-line: rgba(255, 59, 78, 0.15);

  --f1-carbon: #0A0B0F;
  --f1-carbon-2: #14161D;
  --f1-carbon-line: #242832;
  --f1-carbon-fg: #F4F5F7;
  --f1-carbon-muted: #9097A6;
  --f1-carbon-faint: #5C6270;

  --cat-race: #FF3B4E;
  --cat-quali: #B273F0;
  --cat-market: #E5A93A;
  --cat-tech: #3DBFD6;
  --cat-rules: #36C285;

  --f1-purple: #B273F0;
  --f1-amber: #E5A93A;
}

/* ---------------------------------------------------------
   2 · CARGA TIPOGRÁFICA — los grandes titulares usan Saira
   (display deportivo); el cuerpo y el mono quedan igual que
   el resto del sitio. El serif Newsreader se reserva para la
   marca en nav/footer.
   --------------------------------------------------------- */
.f1-kicker {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: var(--tracking-caps);
  text-transform: uppercase;
  font-weight: var(--weight-medium);
  color: var(--accent-fg);
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
}
.f1-kicker::before {
  content: "";
  width: 22px; height: 2px;
  background: var(--accent);
  border-radius: 2px;
}

/* timing-style mono utility (fechas, horas, gaps, puntos) */
.tnum {
  font-family: var(--font-mono);
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.01em;
}

/* ---------------------------------------------------------
   3 · BREAKING / ÚLTIMA HORA — franja de urgencia
   --------------------------------------------------------- */
.breaking {
  background: var(--f1-carbon);
  color: var(--f1-carbon-fg);
  border-bottom: 1px solid var(--f1-carbon-line);
  position: relative;
  overflow: hidden;
}
.breaking::before {
  /* fina banda diagonal roja a la izquierda — sello de velocidad */
  content: "";
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 6px;
  background: var(--f1-stripe);
  opacity: 0.95;
}
.breaking__inner {
  max-width: var(--container);
  margin-inline: auto;
  padding: var(--space-5) var(--space-6);
}
@media (max-width: 640px) { .breaking__inner { padding: var(--space-5) var(--space-4); } }

.breaking__head {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  margin-bottom: var(--space-4);
}
.breaking__label {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  font-weight: var(--weight-semibold);
  letter-spacing: var(--tracking-caps);
  text-transform: uppercase;
  color: #fff;
  background: var(--accent);
  padding: 5px 11px 5px 9px;
  border-radius: var(--radius-full);
}
.live-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: #fff;
  position: relative;
  flex-shrink: 0;
}
.live-dot::after {
  content: "";
  position: absolute;
  inset: -4px;
  border-radius: 50%;
  border: 2px solid #fff;
  opacity: 0.7;
  animation: live-pulse 1.8s var(--ease-out) infinite;
}
@keyframes live-pulse {
  0%   { transform: scale(0.6); opacity: 0.8; }
  70%  { transform: scale(1.6); opacity: 0; }
  100% { transform: scale(1.6); opacity: 0; }
}
@media (prefers-reduced-motion: reduce) { .live-dot::after { animation: none; } }

.breaking__stamp {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: 0.04em;
  color: var(--f1-carbon-muted);
}

.breaking__grid {
  display: grid;
  grid-template-columns: 1.5fr 1fr 1fr;
  gap: var(--space-5);
}
@media (max-width: 860px) { .breaking__grid { grid-template-columns: 1fr; gap: var(--space-4); } }

.breaking__item {
  display: block;
  position: relative;
  padding-left: var(--space-5);
}
.breaking__item + .breaking__item { }
@media (max-width: 860px) {
  .breaking__item + .breaking__item { padding-top: var(--space-4); border-top: 1px solid var(--f1-carbon-line); }
}
.breaking__item::before {
  content: "";
  position: absolute;
  left: 0; top: 2px; bottom: 2px;
  width: 3px;
  border-radius: 3px;
  background: var(--accent);
}
.breaking__lead .breaking__title { font-size: var(--text-xl); }
.breaking__title {
  font-family: var(--f1-display);
  font-weight: 700;
  font-size: var(--text-md);
  line-height: 1.08;
  letter-spacing: 0.005em;
  color: var(--f1-carbon-fg);
  text-wrap: balance;
  transition: color var(--dur-fast) var(--ease);
}
.breaking__item:hover .breaking__title { color: var(--accent); }
[data-theme="dark"] .breaking__item:hover .breaking__title { color: var(--accent-hover); }
.breaking__meta {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-top: var(--space-3);
  font-family: var(--font-mono);
  font-size: var(--text-2xs);
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--f1-carbon-muted);
}

/* ---------------------------------------------------------
   4 · IDENTIDAD DE LA SECCIÓN
   --------------------------------------------------------- */
.f1-id {
  padding: var(--space-8) 0 var(--space-6);
  border-bottom: var(--border-hairline) solid var(--hairline);
}
.f1-id__inner { max-width: 60rem; }
.f1-id__kicker { margin-bottom: var(--space-4); }
.f1-id h1 {
  font-family: var(--f1-display);
  font-size: clamp(3rem, 9vw, 6rem);
  font-weight: 800;
  line-height: 0.92;
  letter-spacing: -0.01em;
  text-transform: uppercase;
  color: var(--fg-strong);
  margin-bottom: var(--space-4);
}
.f1-id h1 em {
  font-style: normal;
  color: var(--accent-fg);
}
.f1-id__sub {
  font-family: var(--font-sans);
  font-size: var(--text-md);
  line-height: var(--leading-normal);
  color: var(--fg-muted);
  max-width: 40rem;
}
.f1-id__placeholder {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  margin-top: var(--space-5);
  font-family: var(--font-mono);
  font-size: var(--text-2xs);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--fg-faint);
  background: var(--bg-subtle);
  border: var(--border-hairline) dashed var(--border-strong);
  padding: 5px 10px;
  border-radius: var(--radius-full);
}

/* ---------------------------------------------------------
   5 · WIDGET "PRÓXIMA CARRERA" — panel carbono destacado
   --------------------------------------------------------- */
.nextrace {
  background:
    radial-gradient(120% 140% at 88% -10%, color-mix(in srgb, var(--accent) 26%, transparent), transparent 52%),
    var(--f1-carbon);
  color: var(--f1-carbon-fg);
  border: 1px solid var(--f1-carbon-line);
  border-radius: var(--radius-lg);
  padding: var(--space-6) var(--space-7);
  position: relative;
  overflow: hidden;
}
@media (max-width: 640px) { .nextrace { padding: var(--space-5) var(--space-5); } }
.nextrace::after {
  /* franja de meta sutil en el borde inferior */
  content: "";
  position: absolute;
  left: 0; right: 0; bottom: 0;
  height: 4px;
  background: var(--f1-stripe);
  opacity: 0.85;
}
.nextrace__top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  margin-bottom: var(--space-5);
  flex-wrap: wrap;
}
.nextrace__label {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: var(--tracking-caps);
  text-transform: uppercase;
  color: var(--accent);
  font-weight: var(--weight-semibold);
}
[data-theme="dark"] .nextrace__label { color: var(--accent-hover); }
.nextrace__round {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: 0.04em;
  color: var(--f1-carbon-muted);
  border: 1px solid var(--f1-carbon-line);
  border-radius: var(--radius-full);
  padding: 4px 10px;
}
.nextrace__grid {
  display: grid;
  grid-template-columns: 1.2fr auto;
  gap: var(--space-6);
  align-items: end;
}
@media (max-width: 720px) { .nextrace__grid { grid-template-columns: 1fr; gap: var(--space-5); align-items: start; } }

.nextrace__gp {
  font-family: var(--f1-display);
  font-size: clamp(2rem, 5vw, var(--text-3xl));
  font-weight: 800;
  line-height: 0.96;
  text-transform: uppercase;
  letter-spacing: -0.005em;
  color: var(--f1-carbon-fg);
  margin-bottom: var(--space-3);
}
.nextrace__meta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2) var(--space-5);
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  color: var(--f1-carbon-muted);
}
.nextrace__meta b { color: var(--f1-carbon-fg); font-weight: var(--weight-medium); }
.nextrace__meta svg { width: 15px; height: 15px; vertical-align: -2px; margin-right: 6px; color: var(--accent); }
[data-theme="dark"] .nextrace__meta svg { color: var(--accent-hover); }

/* Countdown */
.countdown {
  display: flex;
  gap: var(--space-3);
}
.cd-cell {
  min-width: 64px;
  text-align: center;
  background: var(--f1-carbon-2);
  border: 1px solid var(--f1-carbon-line);
  border-radius: var(--radius);
  padding: var(--space-3) var(--space-3) var(--space-2);
}
.cd-cell__num {
  font-family: var(--font-mono);
  font-variant-numeric: tabular-nums;
  font-size: var(--text-2xl);
  font-weight: var(--weight-semibold);
  line-height: 1;
  color: var(--f1-carbon-fg);
  letter-spacing: -0.02em;
}
.cd-cell__lbl {
  display: block;
  margin-top: var(--space-2);
  font-family: var(--font-mono);
  font-size: var(--text-2xs);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--f1-carbon-faint);
}
.countdown--live {
  font-family: var(--f1-display);
  font-weight: 800;
  text-transform: uppercase;
  font-size: var(--text-2xl);
  color: var(--accent);
  display: inline-flex;
  align-items: center;
  gap: var(--space-3);
}

/* ---------------------------------------------------------
   6 · LAYOUT DE LA PÁGINA DE FEED (feed + sidebar)
   --------------------------------------------------------- */
.f1-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 19rem;
  gap: var(--space-7);
  align-items: start;
}
@media (max-width: 980px) { .f1-layout { grid-template-columns: 1fr; gap: var(--space-7); } }

/* ---------------------------------------------------------
   7 · CHIPS DE CATEGORÍA (filtro)
   --------------------------------------------------------- */
.feed-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  padding-bottom: var(--space-4);
  margin-bottom: var(--space-5);
  border-bottom: var(--border-hairline) solid var(--hairline);
  flex-wrap: wrap;
}
.feed-head h2 {
  font-family: var(--f1-display);
  font-size: var(--text-xl);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.01em;
  color: var(--fg-strong);
  white-space: nowrap;
  flex-shrink: 0;
}
.feed-count {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--fg-faint);
  letter-spacing: 0.04em;
}

.chips {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  margin-bottom: var(--space-6);
}
.chip {
  --chip-color: var(--fg-muted);
  display: inline-flex;
  align-items: center;
  gap: 7px;
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  font-weight: var(--weight-medium);
  letter-spacing: 0.02em;
  text-transform: uppercase;
  color: var(--fg-muted);
  background: var(--bg-surface);
  border: var(--border-hairline) solid var(--border);
  padding: 7px 13px;
  border-radius: var(--radius-full);
  cursor: pointer;
  transition: color var(--dur-fast) var(--ease), background var(--dur-fast) var(--ease), border-color var(--dur-fast) var(--ease);
}
.chip::before {
  content: "";
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--chip-color);
}
.chip[data-cat="todas"]::before {
  background: conic-gradient(var(--cat-race), var(--cat-quali), var(--cat-market), var(--cat-tech), var(--cat-rules), var(--cat-race));
}
.chip:hover { border-color: var(--border-strong); color: var(--fg-strong); }
.chip[aria-pressed="true"] {
  color: var(--fg-onaccent);
  background: var(--chip-color);
  border-color: transparent;
}
.chip[aria-pressed="true"]::before { background: var(--fg-onaccent); opacity: 0.9; }
.chip[data-cat="todas"][aria-pressed="true"] { background: var(--fg-strong); }
[data-theme="dark"] .chip[aria-pressed="true"] { color: #0A0B0F; }

/* asignación de color por categoría */
.chip[data-cat="carrera"]      { --chip-color: var(--cat-race); }
.chip[data-cat="clasificacion"]{ --chip-color: var(--cat-quali); }
.chip[data-cat="mercado"]      { --chip-color: var(--cat-market); }
.chip[data-cat="tecnica"]      { --chip-color: var(--cat-tech); }
.chip[data-cat="reglamento"]   { --chip-color: var(--cat-rules); }

/* tag por categoría (reutilizable en items y artículo) */
.cat-tag {
  --c: var(--fg-muted);
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--font-mono);
  font-size: var(--text-2xs);
  letter-spacing: 0.05em;
  text-transform: uppercase;
  font-weight: var(--weight-medium);
  color: var(--c);
  padding: 3px 9px 3px 8px;
  border-radius: var(--radius-full);
  border: var(--border-hairline) solid color-mix(in srgb, var(--c) 32%, transparent);
  background: color-mix(in srgb, var(--c) 11%, transparent);
}
.cat-tag::before { content: ""; width: 6px; height: 6px; border-radius: 50%; background: var(--c); }
.cat-tag[data-cat="carrera"]       { --c: var(--cat-race); }
.cat-tag[data-cat="clasificacion"] { --c: var(--cat-quali); }
.cat-tag[data-cat="mercado"]       { --c: var(--cat-market); }
.cat-tag[data-cat="tecnica"]       { --c: var(--cat-tech); }
.cat-tag[data-cat="reglamento"]    { --c: var(--cat-rules); }

/* ---------------------------------------------------------
   8 · FEED DENSO DE NOTICIAS
   --------------------------------------------------------- */
.f1-feed { display: flex; flex-direction: column; }
.f1-item {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: var(--space-5);
  align-items: start;
  padding: var(--space-5) 0;
  border-top: var(--border-hairline) solid var(--hairline);
  position: relative;
}
.f1-item:first-child { border-top: 0; }
.f1-item:last-child { border-bottom: var(--border-hairline) solid var(--hairline); }
.f1-item__body { min-width: 0; }
.f1-item__row {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  margin-bottom: var(--space-3);
  flex-wrap: wrap;
}
.f1-item__time {
  font-family: var(--font-mono);
  font-variant-numeric: tabular-nums;
  font-size: var(--text-xs);
  letter-spacing: 0.02em;
  text-transform: uppercase;
  color: var(--fg-faint);
}
.f1-item__title {
  font-family: var(--f1-display-wide);
  font-size: var(--text-lg);
  font-weight: 600;
  line-height: 1.12;
  letter-spacing: 0.002em;
  color: var(--fg-strong);
  transition: color var(--dur-fast) var(--ease);
  text-wrap: pretty;
}
.f1-item:hover .f1-item__title { color: var(--accent-fg); }
.f1-item__teaser {
  margin-top: var(--space-2);
  font-size: var(--text-sm);
  line-height: var(--leading-normal);
  color: var(--fg-muted);
  max-width: 44rem;
}
.f1-item__thumb {
  width: 116px;
  aspect-ratio: 4 / 3;
  border-radius: var(--radius-sm);
  align-self: start;
}
.f1-item__thumb.ph { border-radius: var(--radius-sm); }
.f1-item__thumb::after { display: none; }
@media (max-width: 560px) {
  .f1-item { grid-template-columns: 1fr; }
  .f1-item__thumb { order: -1; width: 100%; aspect-ratio: 16 / 9; }
}

.feed-empty {
  display: none;
  padding: var(--space-7) 0;
  text-align: center;
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  color: var(--fg-faint);
}

/* ---------------------------------------------------------
   9 · SIDEBAR — clasificación (standings)
   --------------------------------------------------------- */
.sidebar { display: flex; flex-direction: column; gap: var(--space-6); position: sticky; top: 84px; }
@media (max-width: 980px) { .sidebar { position: static; } }

.standings {
  background: var(--bg-surface);
  border: var(--border-hairline) solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
}
.standings__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  padding: var(--space-4) var(--space-5);
  border-bottom: var(--border-hairline) solid var(--hairline);
}
.standings__title {
  font-family: var(--f1-display);
  font-size: var(--text-md);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.02em;
  color: var(--fg-strong);
}
.standings__tag {
  font-family: var(--font-mono);
  font-size: var(--text-2xs);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--fg-faint);
}
.standings__row {
  display: grid;
  grid-template-columns: 26px 1fr auto;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-3) var(--space-5);
  border-top: var(--border-hairline) solid var(--hairline);
}
.standings__row:first-of-type { border-top: 0; }
.standings__pos {
  font-family: var(--font-mono);
  font-variant-numeric: tabular-nums;
  font-size: var(--text-sm);
  font-weight: var(--weight-semibold);
  color: var(--fg-muted);
  text-align: center;
}
.standings__row--p1 .standings__pos { color: var(--accent-fg); }
.standings__name {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  min-width: 0;
}
.standings__name > span:last-child {
  display: flex;
  flex-direction: column;
  min-width: 0;
}
.team-bar { width: 4px; height: 22px; border-radius: 2px; flex-shrink: 0; background: var(--team, var(--fg-faint)); }
.standings__driver { font-weight: var(--weight-semibold); font-size: var(--text-sm); color: var(--fg-strong); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; line-height: 1.2; }
.standings__team { font-family: var(--font-mono); font-size: var(--text-2xs); text-transform: uppercase; letter-spacing: 0.04em; color: var(--fg-faint); margin-top: 1px; }
.standings__pts {
  font-family: var(--font-mono);
  font-variant-numeric: tabular-nums;
  font-size: var(--text-sm);
  font-weight: var(--weight-semibold);
  color: var(--fg-strong);
}
.standings__pts small { color: var(--fg-faint); font-weight: var(--weight-regular); }
.standings__foot {
  padding: var(--space-3) var(--space-5);
  border-top: var(--border-hairline) solid var(--hairline);
  background: var(--bg-subtle);
}
.standings__foot a {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--accent-fg);
  letter-spacing: 0.02em;
}

/* nota de datos de ejemplo */
.sample-note {
  font-family: var(--font-mono);
  font-size: var(--text-2xs);
  line-height: var(--leading-normal);
  letter-spacing: 0.02em;
  color: var(--fg-faint);
  text-align: center;
}

/* ---------------------------------------------------------
   10 · ARTÍCULO — overrides de titular display + tabla F1
   --------------------------------------------------------- */
.f1-post .post-head h1,
.f1-post .pnav-card__title { font-family: var(--f1-display); text-transform: none; }
.f1-post .post-head h1 {
  font-weight: 800;
  letter-spacing: -0.005em;
  line-height: 1.02;
  font-size: clamp(2.4rem, 5.5vw, 3.6rem);
  text-transform: uppercase;
}
.f1-post .post-head__lead { font-family: var(--font-sans); }
.f1-post .byline__avatar { font-family: var(--font-mono); }

/* Tabla de resultados de carrera */
.results {
  border: var(--border-hairline) solid var(--border);
  border-radius: var(--radius);
  overflow: hidden;
}
.results table { width: 100%; border-collapse: collapse; font-size: var(--text-sm); }
.results thead th {
  text-align: left;
  font-family: var(--font-mono);
  font-size: var(--text-2xs);
  letter-spacing: 0.07em;
  text-transform: uppercase;
  font-weight: var(--weight-medium);
  color: var(--fg-muted);
  background: var(--bg-subtle);
  padding: var(--space-3) var(--space-4);
  border-bottom: var(--border-hairline) solid var(--border);
}
.results th.col-pos, .results td.col-pos { width: 56px; text-align: center; }
.results th.col-num, .results td.col-num { text-align: right; font-family: var(--font-mono); font-variant-numeric: tabular-nums; white-space: nowrap; }
.results tbody td {
  padding: var(--space-3) var(--space-4);
  border-bottom: var(--border-hairline) solid var(--hairline);
  color: var(--fg);
  vertical-align: middle;
}
.results tbody tr:last-child td { border-bottom: 0; }
.results tbody tr:hover td { background: var(--bg-subtle); }
.res-pos {
  display: inline-grid;
  place-items: center;
  width: 26px; height: 26px;
  border-radius: var(--radius-sm);
  font-family: var(--font-mono);
  font-variant-numeric: tabular-nums;
  font-weight: var(--weight-semibold);
  font-size: var(--text-xs);
  color: var(--fg-muted);
  background: var(--bg-subtle);
  border: var(--border-hairline) solid var(--border);
}
tr.is-p1 .res-pos { background: var(--accent); color: #fff; border-color: transparent; }
.res-driver { display: flex; align-items: center; gap: var(--space-3); }
.res-driver .team-bar { height: 20px; }
.res-driver b { font-weight: var(--weight-semibold); color: var(--fg-strong); }
.res-team { font-family: var(--font-mono); font-size: var(--text-2xs); text-transform: uppercase; letter-spacing: 0.04em; color: var(--fg-muted); }
.fastlap {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-family: var(--font-mono);
  font-size: var(--text-2xs);
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: #fff;
  background: var(--f1-purple);
  border-radius: var(--radius-full);
  padding: 2px 8px;
}

/* ---------------------------------------------------------
   11 · CARD DENSO REUTILIZABLE EN BREAKING (oscuro)
   --------------------------------------------------------- */
.section--tight { padding: var(--space-7) 0; }

/* ---------------------------------------------------------
   12 · TIMING EN VIVO (OpenF1) — panel carbono
   --------------------------------------------------------- */
.livetiming {
  background:
    radial-gradient(120% 140% at 88% -10%, color-mix(in srgb, var(--accent) 26%, transparent), transparent 52%),
    var(--f1-carbon);
  color: var(--f1-carbon-fg);
  border: 1px solid var(--f1-carbon-line);
  border-radius: var(--radius-lg);
  overflow: hidden;
  position: relative;
}
.livetiming::after {
  content: "";
  position: absolute;
  left: 0; right: 0; bottom: 0;
  height: 4px;
  background: var(--f1-stripe);
  opacity: 0.85;
}
.livetiming__top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  padding: var(--space-5) var(--space-6) var(--space-4);
  border-bottom: 1px solid var(--f1-carbon-line);
  flex-wrap: wrap;
}
.lt-label {
  display: inline-flex;
  align-items: center;
  gap: var(--space-3);
  font-family: var(--f1-display);
  font-weight: 700;
  font-size: var(--text-md);
  text-transform: uppercase;
  letter-spacing: 0.02em;
  color: var(--f1-carbon-fg);
}
.lt-label .live-dot { background: var(--accent); }
.lt-label .live-dot::after { border-color: var(--accent); }
.lt-stamp {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: 0.04em;
  color: var(--f1-carbon-muted);
}
.lt-stamp::before {
  content: "↻ ";
  color: var(--accent);
}
.lt-rows { padding: var(--space-2) 0; }
.lt-row {
  display: grid;
  grid-template-columns: 40px 1fr auto;
  align-items: center;
  gap: var(--space-4);
  padding: var(--space-3) var(--space-6);
  border-top: 1px solid color-mix(in srgb, var(--f1-carbon-line) 60%, transparent);
}
.lt-row:first-child { border-top: 0; }
.lt-pos {
  font-family: var(--font-mono);
  font-variant-numeric: tabular-nums;
  font-size: var(--text-md);
  font-weight: var(--weight-semibold);
  color: var(--f1-carbon-muted);
  text-align: center;
}
.lt-row--p1 .lt-pos { color: var(--accent); }
[data-theme="dark"] .lt-row--p1 .lt-pos { color: var(--accent-hover); }
.lt-drv {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  min-width: 0;
}
.lt-drv .team-bar { height: 24px; }
.lt-drv b {
  font-family: var(--f1-display-wide);
  font-weight: 700;
  font-size: var(--text-md);
  letter-spacing: 0.04em;
  color: var(--f1-carbon-fg);
}
.lt-team {
  font-family: var(--font-mono);
  font-size: var(--text-2xs);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--f1-carbon-muted);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.lt-gap {
  font-family: var(--font-mono);
  font-variant-numeric: tabular-nums;
  font-size: var(--text-sm);
  font-weight: var(--weight-medium);
  color: var(--f1-carbon-fg);
  white-space: nowrap;
}
.lt-row--p1 .lt-gap {
  text-transform: uppercase;
  font-size: var(--text-2xs);
  letter-spacing: 0.08em;
  color: var(--accent);
}
[data-theme="dark"] .lt-row--p1 .lt-gap { color: var(--accent-hover); }
.lt-foot {
  padding: var(--space-3) var(--space-6);
  border-top: 1px solid var(--f1-carbon-line);
  font-family: var(--font-mono);
  font-size: var(--text-2xs);
  letter-spacing: 0.03em;
  color: var(--f1-carbon-faint);
}
@media (max-width: 560px) {
  .lt-row, .livetiming__top, .lt-foot { padding-left: var(--space-5); padding-right: var(--space-5); }
  .lt-team { display: none; }
}
