*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

/* ── Tokens ─────────────────────────────────────────────
   Night-friendly palette.
   Primary text ~4:1 contrast — readable but not eye-burning.
   Secondary ~2.5:1, muted ~1.5:1 for decorative labels.
──────────────────────────────────────────────────────── */
:root {
  --bg:     #0d0c14;
  --s1:     #121120;
  --s2:     #181628;
  --s3:     #1e1c34;
  --border: #28263e;

  --accent: #b83232;           /* subdued F1 red */

  --t1:     #7a7a9c;           /* primary   — muted indigo-gray, ~4:1 on --bg   */
  --t2:     #565470;           /* secondary — clearly dimmer                     */
  --t3:     #38364e;           /* muted     — labels, decorative                 */

  --ff-d: 'Barlow Condensed', sans-serif;
  --ff-b: 'Inter', sans-serif;
  --r: 8px;
}

/* ── Base ── */
html   { font-family: var(--ff-b); background: var(--bg); color: var(--t1); font-size: 15px; }
button { font-family: inherit; cursor: pointer; }

/* ── Flag images (flagcdn.com PNG, <img> tag) ── */
.flag-ico {
  display: inline-block;
  border-radius: 2px;
  vertical-align: middle;
  flex-shrink: 0;
  object-fit: cover;
  line-height: 1;
}

/* ── Header ── */
.app-header {
  background: var(--s1);
  border-bottom: 1px solid var(--border);
  position: sticky; top: 0; z-index: 100;
}
.header-inner {
  max-width: 1600px; margin: 0 auto;
  padding: 0 20px; height: 46px;
  display: flex; align-items: center; justify-content: space-between;
}
.logo { display: flex; align-items: center; gap: 9px; }
.logo-svg { height: 20px; width: auto; display: block; }
.logo-text {
  font-family: var(--ff-d);
  font-size: 18px; font-weight: 700; letter-spacing: 4px; color: var(--t1);
}
.header-meta { display: flex; align-items: center; gap: 8px; }
.meta-tag  { font-family: var(--ff-d); font-size: 12px; font-weight: 600; letter-spacing: 1.5px; color: var(--t2); }
.meta-sep  { color: var(--t3); font-size: 10px; }
.meta-next { font-size: 12px; font-weight: 500; color: var(--accent); letter-spacing: 0.2px; }

/* ── Calendar ── */
.calendar-section { max-width: 1600px; margin: 0 auto; padding: 14px 20px 10px; }
.calendar-outer   { position: relative; display: flex; align-items: center; }

.calendar-fade { position: absolute; top: 0; bottom: 0; width: 64px; pointer-events: none; z-index: 2; }
.cal-fade-left  { left: 32px;  background: linear-gradient(to right, var(--bg) 20%, transparent); }
.cal-fade-right { right: 32px; background: linear-gradient(to left,  var(--bg) 20%, transparent); }

.cal-btn {
  width: 28px; height: 28px; flex-shrink: 0;
  background: var(--s2); border: 1px solid var(--border);
  border-radius: 6px; color: var(--t2); font-size: 20px; line-height: 1;
  display: flex; align-items: center; justify-content: center;
  transition: color .15s, border-color .15s; z-index: 3;
}
.cal-btn:hover { color: var(--t1); border-color: var(--t3); }

.calendar-track {
  flex: 1;
  display: flex; gap: 10px;
  overflow-x: auto; scroll-behavior: smooth;
  padding: 8px 44px 14px;
  scrollbar-width: none;
}
.calendar-track::-webkit-scrollbar { display: none; }

/* ── Race Card ── */
.race-card {
  flex-shrink: 0; width: 148px;
  background: var(--s1); border: 1px solid var(--border);
  border-radius: var(--r); overflow: hidden; position: relative;
  transition: opacity .2s, filter .2s, transform .2s;
}
.race-card.past   { opacity: .28; filter: grayscale(.6); }
.race-card.past:hover { opacity: .46; }
.race-card.future { opacity: .52; }
.race-card.future:hover { opacity: .74; transform: translateY(-2px); }
.race-card.current {
  width: 214px;
  border-color: var(--accent);
  box-shadow: 0 0 0 1px var(--accent), 0 0 24px rgba(196,48,48,.16);
  transform: translateY(-4px);
  opacity: 1;
}

.card-top  { padding: 10px 12px 8px; }
.card-round {
  font-family: var(--ff-d); font-size: 10px; font-weight: 600;
  letter-spacing: 1.5px; color: var(--t3); margin-bottom: 8px; text-transform: uppercase;
}
.card-flag { display: block; margin-bottom: 8px; }
.card-country {
  font-family: var(--ff-d); font-size: 19px; font-weight: 800;
  text-transform: uppercase; color: var(--t1); line-height: 1.1;
}
.card-date { font-size: 12px; color: var(--t2); margin-top: 3px; }

/* ── Session Schedule (current card only) ── */
.card-schedule {
  padding: 7px 12px 5px;
  border-top: 1px solid var(--border);
}
.sched-row {
  display: grid;
  grid-template-columns: 40px 1fr auto;
  align-items: center;
  gap: 4px;
  padding: 3px 0;
}
.sched-label {
  font-family: var(--ff-d); font-size: 10px; font-weight: 700;
  letter-spacing: .8px; color: var(--t2); text-transform: uppercase;
}
.sched-day  { font-size: 10px; color: var(--t3); }
.sched-time {
  font-family: var(--ff-d); font-size: 13px; font-weight: 700;
  color: var(--t1); text-align: right;
}
.sched-row.is-race .sched-label,
.sched-row.is-race .sched-day  { color: var(--accent); opacity:.8; }
.sched-row.is-race .sched-time { color: var(--accent); }

.card-footer {
  padding: 6px 12px;
  border-top: 1px solid var(--border);
  display: flex; align-items: center; justify-content: space-between; gap: 4px;
  min-height: 28px;
}
.card-status {
  font-family: var(--ff-d); font-size: 10px; font-weight: 700;
  letter-spacing: .8px; padding: 2px 6px; border-radius: 3px;
  text-transform: uppercase; flex-shrink: 0;
}
.status-past    { background: rgba(255,255,255,.04); color: var(--t3); }
.status-current { background: var(--accent); color: rgba(255,255,255,.85); }
.status-future  { background: rgba(255,255,255,.03); color: var(--t2); }

.card-winner {
  font-size: 11px; color: var(--t2);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis; min-width: 0;
  display: flex; align-items: center; gap: 4px; justify-content: flex-end;
}
.winner-dot { width: 5px; height: 5px; border-radius: 50%; flex-shrink: 0; }

.sprint-badge {
  position: absolute; top: 8px; right: 8px;
  background: rgba(76,30,120,.7); color: rgba(200,160,255,.85);
  font-family: var(--ff-d); font-size: 9px; font-weight: 700;
  letter-spacing: 1px; padding: 2px 5px; border-radius: 3px;
}

/* ── Panels ── */
.panels-grid {
  max-width: 1600px; margin: 0 auto;
  padding: 0 20px 28px;
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px;
}
@media (max-width: 900px) { .panels-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 600px) { .panels-grid { grid-template-columns: 1fr; } }

.panel {
  background: var(--s1); border: 1px solid var(--border);
  border-radius: var(--r); overflow: hidden;
  display: flex; flex-direction: column;
}
.panel-title {
  font-family: var(--ff-d); font-size: 12px; font-weight: 700;
  letter-spacing: 2px; text-transform: uppercase; color: var(--t2);
  padding: 9px 14px; border-bottom: 1px solid var(--border); background: var(--s2); flex-shrink: 0;
}
.panel-body {
  overflow-y: auto; flex: 1;
  max-height: calc(100vh - 290px);
  scrollbar-width: thin; scrollbar-color: var(--border) transparent;
}
.panel-body::-webkit-scrollbar { width: 3px; }
.panel-body::-webkit-scrollbar-thumb { background: var(--border); border-radius: 2px; }

/* ── Teams ── */
.team-item  { border-bottom: 1px solid var(--border); }
.team-item:last-child { border-bottom: none; }

.team-header {
  display: flex; align-items: center; gap: 9px; padding: 9px 14px 7px;
}
.team-stripe { width: 3px; height: 32px; border-radius: 2px; flex-shrink: 0; }
.team-badge  {
  width: 32px; height: 32px; border-radius: 6px; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  font-family: var(--ff-d); font-size: 9px; font-weight: 800;
}
.team-info  { flex: 1; min-width: 0; }
.team-name  {
  font-family: var(--ff-d); font-size: 15px; font-weight: 700;
  color: var(--t1); white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.team-pts   { font-size: 11px; color: var(--t3); margin-top: 2px; }

.team-drivers { padding: 0 14px 9px 26px; display: flex; flex-direction: column; gap: 5px; }
.driver-pill  {
  display: flex; align-items: center; gap: 8px;
  padding: 6px 10px; background: var(--s2);
  border-radius: 6px; border: 1px solid var(--border);
}
.driver-num       { font-family: var(--ff-d); font-size: 16px; font-weight: 800; width: 22px; text-align: center; flex-shrink: 0; line-height: 1; }
.driver-pill-name { font-size: 14px; font-weight: 500; color: var(--t1); flex: 1; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

/* ── Driver Standings ── */
.driver-row {
  display: flex; align-items: center; gap: 8px;
  padding: 8px 14px;
  border-bottom: 1px solid var(--border);
  transition: background .12s;
}
.driver-row:last-child { border-bottom: none; }
.driver-row:hover { background: var(--s2); }

.dr-pos      { font-family: var(--ff-d); font-size: 16px; font-weight: 800; color: var(--t3); width: 20px; text-align: center; flex-shrink: 0; }
.dr-pos.top3 { color: var(--t1); }
.dr-line     { width: 2px; height: 30px; border-radius: 1px; flex-shrink: 0; }
.dr-info     { flex: 1; min-width: 0; }
.dr-name     { font-size: 14px; font-weight: 600; color: var(--t1); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; display: flex; align-items: center; gap: 5px; }
.dr-sub      { font-size: 12px; color: var(--t2); margin-top: 2px; display: flex; align-items: center; gap: 5px; flex-wrap: wrap; }
.badge-w     { color: #7a6030; }
.badge-p     { color: #464460; }
.dr-right    { text-align: right; flex-shrink: 0; }
.dr-pts      { font-family: var(--ff-d); font-size: 20px; font-weight: 800; color: var(--t1); line-height: 1; }
.dr-pts-lbl  { font-size: 10px; color: var(--t3); letter-spacing: .4px; }

/* ── Constructor Standings ── */
.ctor-row {
  display: flex; align-items: center; gap: 9px;
  padding: 9px 14px;
  border-bottom: 1px solid var(--border);
  transition: background .12s;
}
.ctor-row:last-child { border-bottom: none; }
.ctor-row:hover { background: var(--s2); }

.ctor-pos        { font-family: var(--ff-d); font-size: 16px; font-weight: 800; color: var(--t3); width: 20px; text-align: center; flex-shrink: 0; }
.ctor-pos.top3   { color: var(--t1); }
.ctor-badge      { width: 32px; height: 32px; border-radius: 6px; flex-shrink: 0; display: flex; align-items: center; justify-content: center; font-family: var(--ff-d); font-size: 9px; font-weight: 800; }
.ctor-info       { flex: 1; min-width: 0; }
.ctor-name       { font-size: 15px; font-weight: 600; color: var(--t1); }
.ctor-bar-wrap   { height: 2px; background: var(--s3); border-radius: 1px; margin-top: 5px; overflow: hidden; }
.ctor-bar        { height: 100%; border-radius: 1px; transition: width .6s ease; }
.ctor-pts        { font-family: var(--ff-d); font-size: 20px; font-weight: 800; color: var(--t1); flex-shrink: 0; min-width: 44px; text-align: right; }
