/* ============================================================
   303 BLUE — Motorsports Portal · shared stylesheet
   Inspired by Formula1.com editorial layout
   ============================================================ */
:root {
  --bg: #000;
  --bg-2: #0a0a0a;
  --bg-3: #141414;
  --bg-4: #1c1c1c;
  --ink: #fff;
  --ink-2: #c9c9c9;
  --ink-3: #8a8a8a;
  --ink-4: #555;
  --line: rgba(255, 255, 255, 0.08);
  --line-2: rgba(255, 255, 255, 0.16);
  --line-3: rgba(255, 255, 255, 0.04);
  --red: #e10600;
  --red-2: #ff1801;
  --red-dim: rgba(225, 6, 0, 0.12);
  --green: #00d742;
  --yellow: #ffb800;
}
* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; background: var(--bg); color: var(--ink); font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Helvetica Neue', sans-serif; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; overflow-x: hidden; }
body { font-size: 15px; line-height: 1.5; }
a { color: inherit; text-decoration: none; transition: color .15s; }
button { font-family: inherit; cursor: pointer; }
img, svg, object { display: block; max-width: 100%; }
::selection { background: var(--red); color: #fff; }

/* utility */
.wrap { max-width: 1440px; margin: 0 auto; padding: 0 32px; }
@media (max-width: 720px) { .wrap { padding: 0 18px; } }
.mono { font-family: 'Roboto Mono', 'SF Mono', Consolas, monospace; }
.italic { font-style: italic; }
.muted { color: var(--ink-3); }
.dim { color: var(--ink-4); }
.red { color: var(--red); }

/* ==== Top nav ==== */
header.site { position: sticky; top: 0; z-index: 50; background: rgba(0, 0, 0, 0.88); backdrop-filter: blur(14px); -webkit-backdrop-filter: blur(14px); border-bottom: 1px solid var(--line); }
.nav { display: flex; align-items: center; justify-content: space-between; height: 64px; gap: 24px; }
.logo { display: flex; align-items: center; gap: 12px; flex-shrink: 0; }
.logo .nbg-logo { height: 32px; width: auto; }
.logo .logo-sep { width: 1px; height: 22px; background: var(--line-2); }
.logo .logo-mark { width: 32px; height: 32px; background: var(--red); display: grid; place-items: center; font-style: italic; font-weight: 900; font-size: 22px; transform: skewX(-8deg); }
.logo .logo-mark span { transform: skewX(8deg); }
.logo .logo-text { font-weight: 800; font-size: 16px; letter-spacing: 2px; }
.logo .logo-text em { font-style: italic; color: var(--red); }
.nav-links { display: flex; gap: 28px; font-size: 12px; font-weight: 600; letter-spacing: 2px; text-transform: uppercase; color: var(--ink-2); }
.nav-links a { padding: 8px 0; transition: color .15s; position: relative; }
.nav-links a:hover, .nav-links a.active { color: var(--ink); }
.nav-links a.active::after { content: ""; position: absolute; left: 0; right: 0; bottom: -22px; height: 2px; background: var(--red); }
.nav-right { display: flex; align-items: center; gap: 12px; }
.lang-toggle { display: flex; align-items: center; border: 1px solid var(--line-2); overflow: hidden; }
.lang-toggle button { background: transparent; color: var(--ink-2); border: none; padding: 6px 10px; font-size: 11px; font-weight: 700; letter-spacing: 1px; }
.lang-toggle button.active { background: var(--red); color: #fff; }
.nav-cta { background: var(--red); color: #fff; border: none; padding: 10px 18px; font-size: 11px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; transition: background .15s; white-space: nowrap; }
.nav-cta:hover { background: var(--red-2); }
@media (max-width: 1024px) { .nav-links { display: none; } }
@media (max-width: 720px) { .nav .logo-text { display: none; } .nav-cta { display: none; } }

/* ==== Footer ==== */
footer.site { background: #050505; padding: 60px 0 24px; border-top: 1px solid var(--line); margin-top: 80px; }
.foot-grid { display: grid; grid-template-columns: 1.5fr 1fr 1fr 1fr; gap: 40px; padding-bottom: 40px; border-bottom: 1px solid var(--line); }
@media (max-width: 720px) { .foot-grid { grid-template-columns: 1fr 1fr; } }
.foot-col h4 { font-size: 11px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; color: var(--ink-3); margin: 0 0 16px; }
.foot-col a { display: block; font-size: 14px; color: var(--ink-2); padding: 4px 0; }
.foot-col a:hover { color: var(--red); }
.foot-col p { font-size: 13px; color: var(--ink-3); line-height: 1.6; margin: 12px 0 0; }
.foot-bot { display: flex; justify-content: space-between; padding-top: 24px; font-size: 11px; color: var(--ink-4); letter-spacing: 1px; flex-wrap: wrap; gap: 12px; }
.foot-bot .social { display: flex; gap: 18px; }
.foot-bot .social a { color: var(--ink-3); }
.foot-bot .social a:hover { color: var(--red); }

/* ==== Hero ==== */
.hero { position: relative; min-height: 90vh; display: flex; align-items: flex-end; padding: 80px 0 64px; overflow: hidden; }
.hero::before { content: ""; position: absolute; inset: 0; z-index: 0; background: linear-gradient(180deg, rgba(0, 0, 0, 0.3) 0%, rgba(0, 0, 0, 0.6) 60%, #000 100%), linear-gradient(90deg, rgba(0, 0, 0, 0.85) 0%, rgba(0, 0, 0, 0.2) 50%, transparent 100%), radial-gradient(ellipse at 75% 45%, rgba(225, 6, 0, 0.22) 0%, transparent 60%); }
.hero-bg-img { position: absolute; inset: 0; z-index: 0; background-size: cover; background-position: center; opacity: 0.55; }
.hero-bg-img::after { content: ""; position: absolute; inset: 0; background: linear-gradient(90deg, rgba(0, 0, 0, 0.85) 0%, rgba(0, 0, 0, 0.3) 50%, transparent 100%); }
.hero-content { position: relative; z-index: 1; max-width: 760px; }
.eyebrow { display: flex; align-items: center; gap: 14px; margin-bottom: 24px; }
.eyebrow .pill { display: inline-block; padding: 4px 10px; background: var(--red); color: #fff; font-size: 10px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; }
.eyebrow .pill.ghost { background: transparent; border: 1px solid var(--line-2); color: var(--ink-2); }
.eyebrow .line-x { flex: 0 0 60px; height: 1px; background: var(--ink-2); }
.eyebrow .label { font-size: 11px; font-weight: 600; letter-spacing: 3px; text-transform: uppercase; color: var(--ink-2); }
h1.hero-h { font-size: clamp(48px, 8vw, 128px); line-height: 0.92; font-weight: 900; letter-spacing: -2px; margin: 0 0 20px; }
h1.hero-h em { font-style: italic; color: var(--red); }
.hero-sub { font-size: clamp(15px, 1.4vw, 18px); line-height: 1.6; color: var(--ink-2); max-width: 560px; margin: 0 0 36px; }
.hero-cta { display: flex; gap: 12px; flex-wrap: wrap; }
.btn { display: inline-flex; align-items: center; gap: 8px; padding: 14px 24px; font-size: 12px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; border: none; transition: all .15s; }
.btn-primary { background: var(--red); color: #fff; }
.btn-primary:hover { background: var(--red-2); }
.btn-ghost { background: transparent; color: #fff; border: 1px solid var(--line-2); }
.btn-ghost:hover { border-color: #fff; }
.btn-sm { padding: 8px 14px; font-size: 11px; }
.hero-corner { position: absolute; right: 32px; bottom: 80px; z-index: 1; display: flex; gap: 32px; }
.corner-stat .v { font-size: 32px; font-weight: 900; font-style: italic; color: #fff; line-height: 1; }
.corner-stat .l { font-size: 10px; letter-spacing: 2px; text-transform: uppercase; color: var(--ink-3); margin-top: 4px; }
@media (max-width: 900px) { .hero-corner { display: none; } }

/* ==== Section base ==== */
section { padding: 80px 0; border-top: 1px solid var(--line); }
.sec-head { display: flex; justify-content: space-between; align-items: flex-end; margin-bottom: 40px; flex-wrap: wrap; gap: 16px; }
.sec-head h2 { font-size: clamp(28px, 4vw, 44px); font-weight: 800; letter-spacing: -1px; margin: 0; line-height: 1; }
.sec-head h2 em { font-style: italic; color: var(--red); }
.sec-head .link { font-size: 11px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; color: var(--ink-2); border-bottom: 1px solid var(--line-2); padding-bottom: 2px; }
.sec-head .link:hover { color: var(--red); border-color: var(--red); }
.sec-eyebrow { display: block; font-size: 11px; font-weight: 700; letter-spacing: 3px; text-transform: uppercase; color: var(--red); margin-bottom: 12px; }
.sec-sub { font-size: 15px; color: var(--ink-3); line-height: 1.6; max-width: 600px; margin: 0; }

/* ==== Standings table ==== */
.table-wrap { background: var(--bg-2); border: 1px solid var(--line); overflow-x: auto; }
table.standings { width: 100%; border-collapse: collapse; font-size: 14px; }
table.standings th { text-align: left; font-size: 11px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; color: var(--ink-3); padding: 16px 18px; border-bottom: 1px solid var(--line); }
table.standings th.right, table.standings td.right { text-align: right; }
table.standings td { padding: 14px 18px; border-bottom: 1px solid var(--line); vertical-align: middle; }
table.standings tbody tr:last-child td { border-bottom: none; }
table.standings tbody tr:hover td { background: rgba(255, 255, 255, 0.02); }
table.standings td .pos { display: inline-block; width: 28px; font-style: italic; font-weight: 900; }
table.standings td.pos-1 .pos, table.standings td.pos-2 .pos, table.standings td.pos-3 .pos { color: var(--red); }
.driver-cell { display: flex; align-items: center; gap: 12px; }
.driver-cell .avatar { width: 36px; height: 36px; border-radius: 50%; background: linear-gradient(135deg, #2a2a2a, #1a1a1a); display: grid; place-items: center; font-size: 11px; font-weight: 800; color: var(--ink-2); flex-shrink: 0; overflow: hidden; }
.driver-cell .avatar img { width: 100%; height: 100%; object-fit: cover; }
.driver-cell .info strong { display: block; font-weight: 700; font-size: 14px; }
.driver-cell .info span { font-size: 11px; color: var(--ink-3); letter-spacing: 1px; text-transform: uppercase; }
.driver-cell .info .team-color { display: inline-block; width: 8px; height: 8px; margin-right: 4px; vertical-align: middle; }
td.pts { font-family: 'Roboto Mono', monospace; font-weight: 700; color: var(--ink-2); }
td.team-cell { color: var(--ink-2); font-weight: 500; }
td.team-cell .team-color { display: inline-block; width: 4px; height: 14px; margin-right: 8px; vertical-align: middle; }

/* ==== Race cards / calendar ==== */
.race-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)); gap: 16px; }
.race-card { background: var(--bg-2); border: 1px solid var(--line); overflow: hidden; transition: border-color .2s, transform .2s; position: relative; }
.race-card:hover { border-color: var(--line-2); transform: translateY(-2px); }
.race-card .head { display: flex; justify-content: space-between; align-items: center; padding: 12px 18px; border-bottom: 1px solid var(--line); }
.race-card .head .round { font-size: 11px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; color: var(--ink-3); }
.race-card .head .date { font-family: 'Roboto Mono', monospace; font-size: 12px; color: var(--ink-2); }
.race-card .body { padding: 24px 18px; }
.race-card .body .country { font-size: 10px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; color: var(--red); margin-bottom: 8px; display: flex; align-items: center; gap: 6px; }
.race-card .body h3 { font-size: 22px; font-weight: 800; line-height: 1.15; margin: 0 0 6px; letter-spacing: -0.5px; }
.race-card .body .circuit { font-size: 13px; color: var(--ink-3); }
.race-card .track-art { height: 100px; background: #050505; border-top: 1px solid var(--line); position: relative; overflow: hidden; }
.race-card .track-art object { width: 100%; height: 100%; }
.race-card .track-art .no-track { position: absolute; inset: 0; display: grid; place-items: center; font-size: 10px; color: var(--ink-4); letter-spacing: 2px; text-transform: uppercase; }
.race-card.next { border-color: rgba(225, 6, 0, 0.4); }
.race-card.next::before { content: ""; position: absolute; top: 0; left: 0; right: 0; height: 2px; background: var(--red); }
.race-card.next .head .round { color: var(--red); }

/* ==== News cards ==== */
.news-grid { display: grid; grid-template-columns: 1.4fr 1fr 1fr; gap: 16px; }
@media (max-width: 900px) { .news-grid { grid-template-columns: 1fr; } }
.news-card { background: var(--bg-2); border: 1px solid var(--line); overflow: hidden; transition: border-color .2s; display: flex; flex-direction: column; }
.news-card:hover { border-color: var(--line-2); }
.news-card .img { aspect-ratio: 16/9; background: linear-gradient(135deg, #1a1a1a, #0a0a0a); position: relative; overflow: hidden; }
.news-card .img img { width: 100%; height: 100%; object-fit: cover; }
.news-card .body { padding: 20px; flex: 1; display: flex; flex-direction: column; }
.news-card .meta { display: flex; gap: 8px; font-size: 10px; letter-spacing: 2px; text-transform: uppercase; color: var(--ink-3); margin-bottom: 12px; }
.news-card .meta .cat { color: var(--red); font-weight: 700; }
.news-card h3 { font-size: 18px; font-weight: 800; line-height: 1.2; margin: 0 0 10px; letter-spacing: -0.3px; }
.news-card.featured { grid-row: span 2; }
.news-card.featured h3 { font-size: 28px; }
.news-card.featured .img { aspect-ratio: 4/3; }
.news-card p { font-size: 13px; color: var(--ink-3); line-height: 1.6; margin: 0 0 14px; }
.news-card a.read { font-size: 11px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; color: var(--red); margin-top: auto; }
.news-card a.read::after { content: " →"; }

/* ==== Track grid ==== */
.tracks-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 16px; }
.track-card { background: var(--bg-2); border: 1px solid var(--line); overflow: hidden; transition: border-color .2s; }
.track-card:hover { border-color: var(--line-2); }
.track-card .art { aspect-ratio: 16/9; background: #050505; position: relative; overflow: hidden; }
.track-card .art object { width: 100%; height: 100%; }
.track-card .art .placeholder { position: absolute; inset: 0; display: grid; place-items: center; font-size: 11px; color: var(--ink-4); letter-spacing: 2px; text-transform: uppercase; }
.track-card .body { padding: 18px; }
.track-card .body .country { font-size: 10px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; color: var(--red); margin-bottom: 6px; }
.track-card .body h3 { font-size: 18px; font-weight: 800; line-height: 1.2; margin: 0 0 12px; }
.track-card .body .meta { display: flex; gap: 16px; font-size: 11px; color: var(--ink-3); }
.track-card .body .meta strong { color: #fff; font-weight: 700; font-family: 'Roboto Mono', monospace; }

/* ==== Drivers grid ==== */
.drivers-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 16px; }
.driver-card { background: var(--bg-2); border: 1px solid var(--line); overflow: hidden; transition: border-color .2s, transform .2s; position: relative; }
.driver-card:hover { border-color: var(--line-2); transform: translateY(-2px); }
.driver-card .photo { aspect-ratio: 3/4; background: linear-gradient(135deg, #1a1a1a, #0a0a0a); position: relative; overflow: hidden; }
.driver-card .photo img { width: 100%; height: 100%; object-fit: cover; }
.driver-card .photo .num { position: absolute; top: 12px; left: 12px; background: var(--red); color: #fff; padding: 4px 10px; font-family: 'Roboto Mono', monospace; font-size: 14px; font-weight: 800; }
.driver-card .photo .team { position: absolute; bottom: 12px; right: 12px; background: rgba(0, 0, 0, 0.7); color: #fff; padding: 4px 10px; font-size: 10px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase; }
.driver-card .body { padding: 16px; }
.driver-card .body .name { font-size: 16px; font-weight: 800; letter-spacing: -0.3px; margin: 0 0 4px; }
.driver-card .body .country { font-size: 11px; color: var(--ink-3); letter-spacing: 1px; text-transform: uppercase; display: flex; align-items: center; gap: 4px; }
.driver-card .body .stats { display: flex; justify-content: space-between; margin-top: 12px; padding-top: 12px; border-top: 1px solid var(--line); font-size: 11px; color: var(--ink-3); }
.driver-card .body .stats strong { color: #fff; font-family: 'Roboto Mono', monospace; font-weight: 700; }

/* ==== Series grid ==== */
.series-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)); gap: 16px; }
.series-card { background: var(--bg-2); border: 1px solid var(--line); padding: 28px; transition: border-color .2s; position: relative; overflow: hidden; }
.series-card:hover { border-color: var(--line-2); }
.series-card .accent { position: absolute; left: 0; top: 0; bottom: 0; width: 4px; background: var(--series-color, var(--red)); }
.series-card .name { font-size: 12px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; color: var(--series-color, var(--red)); margin-bottom: 8px; }
.series-card h3 { font-size: 24px; font-weight: 800; margin: 0 0 8px; letter-spacing: -0.5px; }
.series-card .desc { font-size: 13px; color: var(--ink-3); line-height: 1.6; margin: 0 0 20px; }
.series-card .stats { display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px; padding-top: 16px; border-top: 1px solid var(--line); font-size: 11px; color: var(--ink-3); }
.series-card .stats strong { display: block; color: #fff; font-family: 'Roboto Mono', monospace; font-size: 16px; font-weight: 700; margin-bottom: 2px; }

/* ==== Tabs / filters ==== */
.tabs { display: flex; gap: 4px; border-bottom: 1px solid var(--line); margin-bottom: 32px; flex-wrap: wrap; }
.tabs .tab { background: transparent; border: none; color: var(--ink-3); padding: 14px 18px; font-size: 12px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; position: relative; }
.tabs .tab.active { color: var(--ink); }
.tabs .tab.active::after { content: ""; position: absolute; left: 0; right: 0; bottom: -1px; height: 2px; background: var(--red); }

/* ==== Loading & empty states ==== */
.loading, .empty { text-align: center; padding: 80px 20px; color: var(--ink-3); font-size: 14px; }
.loading::before { content: ""; display: block; width: 24px; height: 24px; margin: 0 auto 16px; border: 2px solid var(--line-2); border-top-color: var(--red); border-radius: 50%; animation: spin 0.8s linear infinite; }
@keyframes spin { to { transform: rotate(360deg); } }

/* ==== Track detail page ==== */
.track-hero { position: relative; min-height: 60vh; display: flex; align-items: flex-end; padding: 80px 0; overflow: hidden; }
.track-hero .bg { position: absolute; inset: 0; z-index: 0; background-size: cover; background-position: center; opacity: 0.5; }
.track-hero .bg::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(0, 0, 0, 0.4) 0%, rgba(0, 0, 0, 0.8) 100%); }
.track-hero .content { position: relative; z-index: 1; }
.track-detail-grid { display: grid; grid-template-columns: 1.5fr 1fr; gap: 40px; }
@media (max-width: 900px) { .track-detail-grid { grid-template-columns: 1fr; } }
.track-svg-stage { background: var(--bg-2); border: 1px solid var(--line); aspect-ratio: 10/7; position: relative; overflow: hidden; padding: 24px; }
.track-svg-stage object { width: 100%; height: 100%; }
.track-stats-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 0; border: 1px solid var(--line); background: var(--bg-2); }
.track-stats-grid .cell { padding: 18px 20px; border-right: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.track-stats-grid .cell:nth-child(2n) { border-right: none; }
.track-stats-grid .cell:nth-last-child(-n+2) { border-bottom: none; }
.track-stats-grid .l { font-size: 10px; letter-spacing: 2px; text-transform: uppercase; color: var(--ink-3); margin-bottom: 6px; }
.track-stats-grid .v { font-family: 'Roboto Mono', monospace; font-size: 20px; font-weight: 700; color: #fff; }
.track-stats-grid .v em { color: var(--red); font-style: normal; }

/* ==== Article (news detail) ==== */
.article-page { max-width: 760px; margin: 0 auto; padding: 80px 32px; }
.article-page .meta { font-size: 11px; letter-spacing: 2px; text-transform: uppercase; color: var(--ink-3); margin-bottom: 16px; }
.article-page h1 { font-size: 48px; font-weight: 900; line-height: 1.05; margin: 0 0 24px; letter-spacing: -1px; }
.article-page h1 em { font-style: italic; color: var(--red); }
.article-page .lead { font-size: 20px; color: var(--ink-2); line-height: 1.5; margin: 0 0 32px; }
.article-page p { font-size: 16px; color: var(--ink-2); line-height: 1.7; margin: 0 0 16px; }
.article-page .hero-img { width: 100%; aspect-ratio: 16/9; object-fit: cover; margin-bottom: 32px; border: 1px solid var(--line); }

/* ==== Form / search ==== */
.search-box { display: flex; background: var(--bg-2); border: 1px solid var(--line-2); }
.search-box input { flex: 1; background: transparent; border: none; color: var(--ink); padding: 14px 18px; font-size: 14px; font-family: inherit; outline: none; }
.search-box input::placeholder { color: var(--ink-4); }

/* ==== Responsive helpers ==== */
@media (max-width: 720px) {
  section { padding: 60px 0; }
  .hero { min-height: 80vh; padding: 60px 0 40px; }
  .track-stats-bar { grid-template-columns: repeat(2, 1fr) !important; }
  .driver-cell .info span { display: none; }
  .next-hero { min-height: auto; }
  .next-grid { grid-template-columns: 1fr; gap: 32px; }
  .sessions-grid { grid-template-columns: repeat(2, 1fr); }
  .cd-row { gap: 12px; }
  .cd-num { font-size: 32px !important; }
}

/* ==== Next race / countdown ==== */
.next-hero { position: relative; min-height: 520px; background: var(--bg-2); border: 1px solid var(--line); overflow: hidden; }
.next-bg { position: absolute; inset: 0; background-size: cover; background-position: center; opacity: 0.45; }
.next-bg::after { content: ""; position: absolute; inset: 0; background: linear-gradient(90deg, rgba(0,0,0,0.9) 0%, rgba(0,0,0,0.5) 60%, rgba(0,0,0,0.2) 100%); }
.next-grid { position: relative; display: grid; grid-template-columns: 1.4fr 1fr; gap: 48px; padding: 56px; align-items: center; }
.next-info h1.next-h { font-size: clamp(40px, 5.5vw, 76px); line-height: 0.95; font-weight: 900; letter-spacing: -1.5px; margin: 0 0 16px; }
.next-info h1.next-h em { font-style: italic; color: var(--red); }
.next-sub { font-size: 16px; color: var(--ink-2); line-height: 1.5; margin: 0 0 28px; max-width: 580px; }
.next-actions { display: flex; gap: 12px; flex-wrap: wrap; }
.next-countdown { background: rgba(0,0,0,0.5); backdrop-filter: blur(8px); padding: 32px; border: 1px solid var(--line-2); }
.cd-label { font-size: 11px; font-weight: 700; letter-spacing: 3px; text-transform: uppercase; color: var(--red); margin-bottom: 18px; }
.cd-row { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; margin-bottom: 24px; }
.cd-cell { display: flex; flex-direction: column; align-items: center; padding: 14px 4px; background: rgba(255,255,255,0.04); border: 1px solid var(--line); }
.cd-num { font-family: 'Roboto Mono', monospace; font-size: 44px; font-weight: 800; line-height: 1; color: #fff; font-style: italic; }
.cd-u { font-size: 9px; letter-spacing: 2px; text-transform: uppercase; color: var(--ink-3); margin-top: 6px; }
.cd-circuit { aspect-ratio: 16/8; background: rgba(0,0,0,0.3); border: 1px solid var(--line); display: grid; place-items: center; }
.cd-circuit object { width: 100%; height: 100%; opacity: 0.9; }
.cd-trackmap-placeholder { font-size: 10px; color: var(--ink-4); letter-spacing: 2px; text-transform: uppercase; }

/* ==== Sessions grid ==== */
.sessions-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: 12px; }
@media (max-width: 1024px) { .sessions-grid { grid-template-columns: repeat(3, 1fr); } }
.session-card { background: var(--bg-2); border: 1px solid var(--line); padding: 22px 18px; text-align: center; position: relative; transition: border-color .2s, transform .2s; }
.session-card:hover { border-color: var(--line-2); transform: translateY(-2px); }
.session-card.featured { background: linear-gradient(135deg, rgba(225,6,0,0.18) 0%, rgba(225,6,0,0.04) 100%); border-color: var(--red); }
.session-card.featured::before { content: ""; position: absolute; top: 0; left: 0; right: 0; height: 2px; background: var(--red); }
.sess-day { font-size: 10px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; color: var(--ink-3); margin-bottom: 8px; }
.sess-time { font-family: 'Roboto Mono', monospace; font-size: 22px; font-weight: 700; color: #fff; margin-bottom: 6px; }
.sess-label { font-size: 11px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; color: var(--ink-2); }
.session-card.featured .sess-day, .session-card.featured .sess-label { color: var(--red); }
.session-card.featured .sess-time { color: #fff; }

/* ==== Track detail (full) ==== */
.track-detail-page { padding: 0; }
.track-hero { position: relative; min-height: 60vh; display: flex; align-items: flex-end; padding: 80px 0; overflow: hidden; border-top: none; }
.track-hero .bg { position: absolute; inset: 0; z-index: 0; background-size: cover; background-position: center; opacity: 0.5; }
.track-hero .bg::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(0,0,0,0.4) 0%, rgba(0,0,0,0.85) 100%); }
.track-hero .content { position: relative; z-index: 1; }
.track-detail-grid { display: grid; grid-template-columns: 1.5fr 1fr; gap: 40px; padding: 60px 0; }
@media (max-width: 900px) { .track-detail-grid { grid-template-columns: 1fr; } }
.track-svg-stage { background: var(--bg-2); border: 1px solid var(--line); aspect-ratio: 10/7; position: relative; overflow: hidden; padding: 24px; }
.track-svg-stage object { width: 100%; height: 100%; }
.track-stats-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 0; border: 1px solid var(--line); background: var(--bg-2); }
.track-stats-grid .cell { padding: 18px 20px; border-right: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.track-stats-grid .cell:nth-child(2n) { border-right: none; }
.track-stats-grid .cell:nth-last-child(-n+2) { border-bottom: none; }
.track-stats-grid .l { font-size: 10px; letter-spacing: 2px; text-transform: uppercase; color: var(--ink-3); margin-bottom: 6px; }
.track-stats-grid .v { font-family: 'Roboto Mono', monospace; font-size: 20px; font-weight: 700; color: #fff; }
.track-stats-grid .v em { color: var(--red); font-style: normal; }
.corners-list { display: grid; grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); gap: 8px; margin-top: 16px; }
.corner-chip { display: flex; flex-direction: column; padding: 12px 14px; background: var(--bg-2); border: 1px solid var(--line); }
.corner-chip .name { font-size: 13px; font-weight: 700; color: #fff; }
.corner-chip .type { font-size: 10px; letter-spacing: 1px; text-transform: uppercase; color: var(--ink-3); margin-top: 4px; }

/* ==== Ticker ==== */
.ticker { background: linear-gradient(90deg, var(--red) 0%, #b30500 100%); color: #fff; overflow: hidden; border-bottom: 1px solid rgba(0,0,0,0.2); position: relative; z-index: 5; }
.ticker-wrap { display: flex; align-items: center; height: 38px; max-width: 1440px; margin: 0 auto; padding: 0 32px; }
.ticker-label { display: flex; align-items: center; gap: 8px; font-size: 10px; font-weight: 800; letter-spacing: 2px; text-transform: uppercase; padding-right: 18px; border-right: 1px solid rgba(255,255,255,0.3); margin-right: 18px; flex-shrink: 0; }
.ticker-label .pulse { display: inline-block; width: 8px; height: 8px; background: #fff; border-radius: 50%; box-shadow: 0 0 0 0 rgba(255,255,255,0.7); animation: pulse 1.6s infinite; }
@keyframes pulse {
  0% { box-shadow: 0 0 0 0 rgba(255,255,255,0.7); }
  70% { box-shadow: 0 0 0 10px rgba(255,255,255,0); }
  100% { box-shadow: 0 0 0 0 rgba(255,255,255,0); }
}
.ticker-track { flex: 1; overflow: hidden; white-space: nowrap; position: relative; }
.ticker-track::after { content: ""; position: absolute; right: 0; top: 0; bottom: 0; width: 60px; background: linear-gradient(90deg, transparent, #b30500); pointer-events: none; }
.ticker-item { display: inline-block; padding: 0 32px; font-size: 12px; letter-spacing: 0.5px; font-weight: 500; animation: ticker-slide 60s linear infinite; }
.ticker-cat { display: inline-block; padding: 2px 6px; background: rgba(0,0,0,0.25); font-weight: 800; font-size: 10px; letter-spacing: 1px; margin-right: 8px; text-transform: uppercase; }
@keyframes ticker-slide { from { transform: translateX(0); } to { transform: translateX(-50%); } }

/* ==== Hero grid (split layout) ==== */
.hero { position: relative; min-height: 90vh; display: flex; align-items: flex-end; padding: 80px 0 64px; overflow: hidden; }
.hero::before { content: ""; position: absolute; inset: 0; z-index: 0; background: linear-gradient(180deg, rgba(0,0,0,0.3) 0%, rgba(0,0,0,0.7) 60%, #000 100%), radial-gradient(ellipse at 80% 50%, rgba(225,6,0,0.18) 0%, transparent 60%); }
.hero-bg-img { position: absolute; inset: 0; z-index: 0; background-size: cover; background-position: center; opacity: 0.55; transition: background-image 1.2s ease-in-out; }
.hero-bg-img::after { content: ""; position: absolute; inset: 0; background: linear-gradient(90deg, rgba(0,0,0,0.9) 0%, rgba(0,0,0,0.4) 50%, transparent 100%); }
.hero-overlay-red { position: absolute; inset: 0; z-index: 0; pointer-events: none; background: radial-gradient(ellipse at 95% 50%, rgba(225,6,0,0.2) 0%, transparent 50%); }
.hero-grid { position: relative; z-index: 1; display: grid; grid-template-columns: 1.4fr 1fr; gap: 48px; align-items: end; width: 100%; }
.hero-content { max-width: 720px; }
.hero-side { display: flex; flex-direction: column; gap: 24px; padding-bottom: 8px; }
.hero-pill-row { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px; background: var(--line); border: 1px solid var(--line); }
.hero-pill { background: rgba(0,0,0,0.6); backdrop-filter: blur(8px); padding: 16px 12px; text-align: center; }
.hero-pill .hp-num { display: block; font-family: 'Roboto Mono', monospace; font-size: 24px; font-weight: 800; color: #fff; font-style: italic; line-height: 1; margin-bottom: 4px; }
.hero-pill .hp-l { font-size: 9px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; color: var(--ink-3); }
.hero-quote { background: rgba(0,0,0,0.5); backdrop-filter: blur(8px); border-left: 3px solid var(--red); padding: 24px 28px; position: relative; }
.hero-quote .hq-mark { position: absolute; top: 4px; left: 16px; font-size: 64px; line-height: 1; color: var(--red); font-family: Georgia, serif; opacity: 0.6; }
.hero-quote p { font-size: 16px; line-height: 1.5; color: #fff; margin: 0 0 8px 28px; font-style: italic; font-weight: 500; }
.hero-quote .hq-by { font-size: 11px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; color: var(--ink-3); margin-left: 28px; }
@media (max-width: 1024px) { .hero-grid { grid-template-columns: 1fr; gap: 32px; } }
@media (max-width: 720px) { .hero { min-height: 80vh; } .hero-pill-row { grid-template-columns: repeat(4, 1fr); } }

/* ==== Last race result section ==== */
.last-race { display: grid; grid-template-columns: 1fr 1.6fr; gap: 0; background: var(--bg-2); border: 1px solid var(--line); overflow: hidden; }
.lr-info { padding: 36px 32px; background: linear-gradient(135deg, rgba(225,6,0,0.12) 0%, transparent 100%); border-right: 1px solid var(--line); display: flex; flex-direction: column; justify-content: center; }
.lr-info .lr-gp { font-size: clamp(28px, 3vw, 40px); font-weight: 900; line-height: 1; margin: 16px 0 8px; letter-spacing: -1px; }
.lr-info .lr-gp em { font-style: italic; color: var(--red); }
.lr-info .lr-circuit { font-size: 14px; color: var(--ink-2); margin: 0 0 4px; }
.lr-info .lr-sprint { font-size: 11px; letter-spacing: 2px; text-transform: uppercase; color: var(--ink-3); margin: 12px 0 0; }
.lr-podium-wrap { padding: 24px; display: flex; flex-direction: column; gap: 24px; }
.lr-podium { display: grid; grid-template-columns: 1fr 1.1fr 1fr; gap: 8px; align-items: end; }
.podium-slot { display: flex; flex-direction: column; align-items: center; }
.podium-slot .podium-name { font-size: 11px; font-weight: 700; text-align: center; margin-bottom: 8px; line-height: 1.2; min-height: 32px; }
.podium-slot .podium-name strong { font-size: 14px; font-weight: 900; }
.podium-slot .podium-block { width: 100%; padding: 18px 8px; display: flex; flex-direction: column; align-items: center; gap: 4px; background: linear-gradient(180deg, var(--c) 0%, rgba(0,0,0,0.4) 100%); color: #fff; border-top: 3px solid #fff; }
.podium-slot.p1-h .podium-block { padding: 32px 8px; }
.podium-slot.p2-h .podium-block { padding: 22px 8px; }
.podium-slot.p3-h .podium-block { padding: 18px 8px; }
.podium-pos { font-family: 'Roboto Mono', monospace; font-size: 32px; font-weight: 900; font-style: italic; line-height: 1; }
.podium-slot.p1-h .podium-pos { font-size: 40px; }
.podium-pts { font-size: 10px; font-weight: 800; letter-spacing: 1.5px; }
.lr-rest { background: var(--bg-3); border: 1px solid var(--line); }
.lr-rest-head { padding: 10px 16px; background: rgba(255,255,255,0.03); border-bottom: 1px solid var(--line); font-size: 10px; font-weight: 800; letter-spacing: 2px; text-transform: uppercase; color: var(--ink-3); }
.lr-rest ol { list-style: none; padding: 0; margin: 0; }
.lr-rest li { display: grid; grid-template-columns: 32px 4px 1fr auto auto; align-items: center; gap: 12px; padding: 10px 16px; border-bottom: 1px solid var(--line); font-size: 13px; }
.lr-rest li:last-child { border-bottom: none; }
.lr-rest .lr-pos { font-family: 'Roboto Mono', monospace; font-size: 13px; font-weight: 700; color: var(--ink-3); text-align: center; }
.lr-rest .lr-color { width: 4px; height: 20px; }
.lr-rest .lr-name { color: #fff; font-weight: 600; }
.lr-rest .lr-team { font-size: 11px; color: var(--ink-3); letter-spacing: 0.5px; display: none; }
.lr-rest .lr-pts { font-family: 'Roboto Mono', monospace; font-weight: 700; color: var(--ink-2); }
@media (max-width: 1024px) { .last-race { grid-template-columns: 1fr; } .lr-info { border-right: none; border-bottom: 1px solid var(--line); } .lr-rest .lr-team { display: none; } }
@media (max-width: 600px) { .lr-podium { grid-template-columns: 1fr 1fr 1fr; gap: 4px; } .podium-slot .podium-name { font-size: 10px; } }

/* ==== Standings podium (championship top 3) ==== */
.podium-row { display: grid; grid-template-columns: 1fr 1.1fr 1fr; gap: 12px; align-items: end; }
.podium-card { background: var(--bg-2); border: 1px solid var(--line); overflow: hidden; position: relative; }
.podium-card::before { content: ""; position: absolute; top: 0; left: 0; right: 0; height: 3px; background: var(--tc); }
.podium-card.gold { background: linear-gradient(180deg, rgba(255,215,0,0.04) 0%, var(--bg-2) 60%); }
.podium-card.gold::before { background: linear-gradient(90deg, #FFD700, #B8860B); }
.podium-card.silver::before { background: linear-gradient(90deg, #E8E8E8, #A8A8A8); }
.podium-card.bronze::before { background: linear-gradient(90deg, #CD7F32, #8B4513); }
.podium-card-top { padding: 20px 16px 16px; display: flex; align-items: center; justify-content: space-between; background: linear-gradient(180deg, var(--tc) 0%, transparent 100%); opacity: 0.95; }
.podium-card-pos { font-family: 'Roboto Mono', monospace; font-size: 36px; font-weight: 900; font-style: italic; color: #fff; line-height: 1; text-shadow: 0 1px 4px rgba(0,0,0,0.4); }
.podium-card-num { font-family: 'Roboto Mono', monospace; font-size: 14px; font-weight: 800; color: rgba(255,255,255,0.95); padding: 4px 8px; background: rgba(0,0,0,0.4); }
.podium-card-mid { padding: 16px 16px 8px; }
.podium-card-name { font-size: 16px; font-weight: 500; line-height: 1.2; color: var(--ink-2); }
.podium-card-name strong { display: block; font-size: 24px; font-weight: 900; color: #fff; letter-spacing: -0.5px; margin-top: 2px; }
.podium-card-team { font-size: 11px; color: var(--ink-3); letter-spacing: 1px; text-transform: uppercase; margin-top: 4px; }
.podium-card-bot { display: grid; grid-template-columns: 1fr 1fr; gap: 0; border-top: 1px solid var(--line); }
.podium-card-stat { padding: 14px 16px; border-right: 1px solid var(--line); }
.podium-card-stat:last-child { border-right: none; }
.podium-card-stat .l { display: block; font-size: 9px; letter-spacing: 2px; text-transform: uppercase; color: var(--ink-3); margin-bottom: 4px; }
.podium-card-stat .v { display: block; font-family: 'Roboto Mono', monospace; font-size: 18px; font-weight: 800; color: #fff; }
@media (max-width: 600px) { .podium-row { grid-template-columns: 1fr; gap: 8px; } }

/* ==== Editorial (news) grid ==== */
.editorial-grid { display: grid; grid-template-columns: 1.6fr 1fr 1fr; grid-template-rows: auto auto; gap: 16px; }
.editorial-card { background: var(--bg-2); border: 1px solid var(--line); overflow: hidden; transition: border-color .2s, transform .2s; display: flex; flex-direction: column; }
.editorial-card:hover { border-color: var(--line-2); transform: translateY(-2px); }
.editorial-card .img { aspect-ratio: 16/9; background: #050505; overflow: hidden; }
.editorial-card .img img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s; }
.editorial-card:hover .img img { transform: scale(1.05); }
.editorial-card .body { padding: 18px 20px 20px; flex: 1; display: flex; flex-direction: column; }
.editorial-card .meta { display: flex; gap: 8px; font-size: 10px; letter-spacing: 2px; text-transform: uppercase; color: var(--ink-3); margin-bottom: 10px; }
.editorial-card .meta .cat { color: var(--red); font-weight: 700; }
.editorial-card h3 { font-size: 16px; font-weight: 800; line-height: 1.25; margin: 0 0 10px; letter-spacing: -0.3px; }
.editorial-card h3 a { color: #fff; }
.editorial-card h3 a:hover { color: var(--red); }
.editorial-card p { font-size: 13px; color: var(--ink-3); line-height: 1.55; margin: 0 0 14px; }
.editorial-card .footer { margin-top: auto; display: flex; justify-content: space-between; align-items: center; padding-top: 10px; border-top: 1px solid var(--line); font-size: 10px; color: var(--ink-3); letter-spacing: 1px; text-transform: uppercase; }
.editorial-card .footer a.read { font-size: 10px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; color: var(--red); }
.editorial-card.featured { grid-row: span 2; }
.editorial-card.featured .img { aspect-ratio: 16/10; }
.editorial-card.featured h3 { font-size: 28px; line-height: 1.15; }
.editorial-card.featured p { font-size: 14px; }
@media (max-width: 900px) { .editorial-grid { grid-template-columns: 1fr 1fr; } .editorial-card.featured { grid-row: auto; grid-column: span 2; } }
@media (max-width: 600px) { .editorial-grid { grid-template-columns: 1fr; } .editorial-card.featured { grid-column: auto; } }

/* ==== Driver card flag-dot ==== */
.driver-card .photo .avatar { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); width: 120px; height: 120px; border-radius: 50%; display: grid; place-items: center; font-family: 'Inter'; font-weight: 800; font-size: 48px; color: #fff; letter-spacing: -2px; z-index: 1; }
.driver-card .photo .num { z-index: 2; }
.driver-card .photo .team { z-index: 2; }
.flag-dot { display: inline-block; width: 8px; height: 8px; vertical-align: middle; margin-right: 4px; }

/* ==== Track detail - enhanced ==== */
.track-svg-stage { background: var(--bg-2); border: 1px solid var(--line); position: relative; overflow: hidden; padding: 0; }
.track-svg-stage::before { content: ""; position: absolute; inset: 0; background: radial-gradient(ellipse at center, rgba(225,6,0,0.06) 0%, transparent 70%); pointer-events: none; }
.track-svg-stage::after { content: ""; position: absolute; top: 0; left: 0; right: 0; height: 1px; background: linear-gradient(90deg, transparent, var(--red), transparent); }
.track-svg-stage .svg-frame { position: relative; aspect-ratio: 10/7; padding: 24px; }
.track-svg-stage object { width: 100%; height: 100%; position: relative; z-index: 1; }
.track-svg-stage .map-meta { position: absolute; top: 16px; right: 16px; z-index: 2; display: flex; flex-direction: column; gap: 4px; }
.track-svg-stage .map-meta .mm { background: rgba(0,0,0,0.6); backdrop-filter: blur(6px); border: 1px solid var(--line); padding: 6px 10px; font-size: 10px; letter-spacing: 1.5px; text-transform: uppercase; color: var(--ink-2); font-weight: 700; }
.track-svg-stage .map-meta .mm em { color: var(--red); font-style: normal; }
.track-svg-stage .map-corner-marker { position: absolute; z-index: 2; background: var(--red); color: #fff; padding: 2px 6px; font-size: 9px; font-weight: 800; letter-spacing: 1px; }
.track-spec-strip { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0; border: 1px solid var(--line); background: var(--bg-2); margin-bottom: 24px; }
.track-spec-strip .ts-cell { padding: 20px 18px; border-right: 1px solid var(--line); position: relative; }
.track-spec-strip .ts-cell:last-child { border-right: none; }
.track-spec-strip .ts-cell::before { content: ""; position: absolute; top: 0; left: 0; width: 24px; height: 2px; background: var(--red); }
.track-spec-strip .ts-l { font-size: 10px; letter-spacing: 2px; text-transform: uppercase; color: var(--ink-3); margin-bottom: 8px; font-weight: 700; }
.track-spec-strip .ts-v { font-family: 'Roboto Mono', monospace; font-size: 28px; font-weight: 800; color: #fff; line-height: 1; margin-bottom: 4px; }
.track-spec-strip .ts-v em { color: var(--red); font-style: normal; }
.track-spec-strip .ts-s { font-size: 11px; color: var(--ink-3); margin-top: 6px; }
@media (max-width: 900px) { .track-spec-strip { grid-template-columns: repeat(2, 1fr); } .track-spec-strip .ts-cell:nth-child(2) { border-right: none; } .track-spec-strip .ts-cell:nth-child(1), .track-spec-strip .ts-cell:nth-child(2) { border-bottom: 1px solid var(--line); } }

.track-sectors { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0; border: 1px solid var(--line); background: var(--bg-2); margin-top: 16px; }
.track-sectors .sector { padding: 20px 18px; border-right: 1px solid var(--line); position: relative; }
.track-sectors .sector:last-child { border-right: none; }
.track-sectors .sector::before { content: "S"; position: absolute; top: 12px; right: 14px; font-family: 'Roboto Mono', monospace; font-size: 11px; font-weight: 800; color: var(--ink-3); letter-spacing: 1px; }
.track-sectors .sector:nth-child(1)::before { content: "S1"; }
.track-sectors .sector:nth-child(2)::before { content: "S2"; }
.track-sectors .sector:nth-child(3)::before { content: "S3"; }
.track-sectors .sector .l { font-size: 10px; letter-spacing: 2px; text-transform: uppercase; color: var(--ink-3); margin-bottom: 8px; font-weight: 700; }
.track-sectors .sector .v { font-family: 'Roboto Mono', monospace; font-size: 22px; font-weight: 800; color: #fff; }
.track-sectors .sector .bar { height: 4px; background: var(--bg-3); margin-top: 12px; position: relative; overflow: hidden; }
.track-sectors .sector .bar i { position: absolute; left: 0; top: 0; bottom: 0; background: linear-gradient(90deg, var(--red), #ff3a30); }
@media (max-width: 720px) { .track-sectors { grid-template-columns: 1fr; } .track-sectors .sector { border-right: none; border-bottom: 1px solid var(--line); } .track-sectors .sector:last-child { border-bottom: none; } }

.corners-list .corner-chip { position: relative; padding-left: 18px; transition: border-color .2s, transform .2s; cursor: default; }
.corners-list .corner-chip:hover { border-color: var(--line-2); transform: translateY(-1px); }
.corners-list .corner-chip::before { content: ""; position: absolute; left: 0; top: 0; bottom: 0; width: 3px; background: var(--red); }
.corners-list .corner-chip .num { position: absolute; top: 8px; right: 10px; font-family: 'Roboto Mono', monospace; font-size: 10px; color: var(--ink-3); font-weight: 700; }

/* ==== Driver card - enhanced ==== */
.drivers-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap: 16px; }
.driver-card { background: var(--bg-2); border: 1px solid var(--line); overflow: hidden; transition: border-color .2s, transform .2s; position: relative; }
.driver-card:hover { border-color: var(--red); transform: translateY(-3px); box-shadow: 0 8px 24px rgba(225,6,0,0.15); }
.driver-card .photo { aspect-ratio: 3/4; background: linear-gradient(135deg, #1a1a1a, #0a0a0a); position: relative; overflow: hidden; }
.driver-card .photo::after { content: ""; position: absolute; left: 0; right: 0; bottom: 0; height: 50%; background: linear-gradient(180deg, transparent, rgba(0,0,0,0.85)); }
.driver-card .photo::before { content: ""; position: absolute; inset: 0; background: linear-gradient(135deg, var(--c, transparent) 0%, transparent 50%); opacity: 0.4; z-index: 0; }
.driver-card .photo img { width: 100%; height: 100%; object-fit: cover; }
.driver-card .photo .num { position: absolute; top: 12px; left: 12px; background: var(--red); color: #fff; padding: 4px 10px; font-family: 'Roboto Mono', monospace; font-size: 14px; font-weight: 800; z-index: 3; }
.driver-card .photo .team { position: absolute; top: 12px; right: 12px; background: rgba(0, 0, 0, 0.7); color: #fff; padding: 4px 10px; font-size: 10px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase; z-index: 3; }
.driver-card .photo .country { position: absolute; bottom: 12px; left: 12px; z-index: 3; display: flex; align-items: center; gap: 6px; font-size: 10px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; color: rgba(255,255,255,0.9); }
.driver-card .body { padding: 16px; position: relative; }
.driver-card .body::before { content: ""; position: absolute; top: 0; left: 16px; right: 16px; height: 2px; background: var(--c, var(--red)); }
.driver-card .body .name { font-size: 17px; font-weight: 800; letter-spacing: -0.3px; margin: 0 0 4px; line-height: 1.2; }
.driver-card .body .name em { color: var(--red); font-style: italic; }
.driver-card .body .team-name { font-size: 11px; color: var(--c, var(--ink-2)); letter-spacing: 1px; text-transform: uppercase; font-weight: 700; margin-bottom: 12px; }
.driver-card .body .stats { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 0; margin-top: 12px; padding-top: 12px; border-top: 1px solid var(--line); }
.driver-card .body .stat { text-align: center; padding: 4px 0; }
.driver-card .body .stat .l { display: block; font-size: 9px; letter-spacing: 1.5px; text-transform: uppercase; color: var(--ink-3); margin-bottom: 4px; }
.driver-card .body .stat .v { display: block; font-family: 'Roboto Mono', monospace; font-size: 16px; font-weight: 800; color: #fff; }
.driver-card.legend .photo::after { background: linear-gradient(180deg, transparent 30%, rgba(0,0,0,0.6) 60%, rgba(0,0,0,0.9) 100%); }
.driver-card.legend .body::before { background: linear-gradient(90deg, #FFD700, #B8860B); }
.driver-card.legend .photo::before { background: linear-gradient(135deg, #FFD700 0%, transparent 50%); opacity: 0.2; }

/* ==== Featured drivers on home page ==== */
.featured-drivers-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
@media (max-width: 1024px) { .featured-drivers-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .featured-drivers-grid { grid-template-columns: 1fr; } }
.featured-drivers-grid .driver-card .photo { aspect-ratio: 1; }
.featured-drivers-grid .driver-card .body .stats { grid-template-columns: 1fr 1fr; }
