/* SRCCA VLS On-Road – Rangliste
   Gestaltung: Timing-Board. Dichte Zeilen wie eine Live-Zeitnahme,
   tabellarische Mono-Ziffern fuer saubere Spalten, Leader rot markiert,
   Streichresultat sichtbar durchgestrichen. */

:root{
  --ink:#0E1116; --ink-2:#171C24; --paper:#FFFFFF; --zebra:#F5F6F8;
  --line:#E3E6EA; --line-strong:#C9CED5; --steel:#69727E; --steel-2:#9AA1AB;
  --red:#C8102E; --red-deep:#9C0B23; --drop:#AEB5BE; --gold:#C9A227;
  --shadow:0 1px 0 rgba(14,17,22,.04), 0 8px 24px -16px rgba(14,17,22,.25);
}

*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0; background:#EEF0F3; color:var(--ink);
  font-family:"Inter",system-ui,-apple-system,"Segoe UI",sans-serif;
  font-size:15px; line-height:1.4;
}
.wrap{max-width:1120px; margin:0 auto; padding:0 16px 64px}

/* ---- Timing bar (Kopf) ---- */
.topbar{background:var(--ink); color:#fff; border-bottom:3px solid var(--red)}
.topbar__in{max-width:1120px; margin:0 auto; padding:18px 16px;
  display:flex; align-items:baseline; gap:16px 24px; flex-wrap:wrap}
.brand{font-family:"Saira Condensed","Arial Narrow",sans-serif; font-weight:700;
  font-size:26px; letter-spacing:.04em; text-transform:uppercase; line-height:1; margin:0}
.brand b{color:var(--red); font-weight:800}
.topbar__meta{margin-left:auto; display:flex; gap:18px; align-items:baseline;
  font-family:"Roboto Mono",ui-monospace,monospace; font-size:12px; color:var(--steel-2);
  letter-spacing:.02em}
.topbar__meta strong{color:#fff; font-weight:500}
.tb-admin{display:inline-flex; align-items:center; color:var(--steel-2); transition:.12s; margin-left:4px}
.tb-admin:hover{color:#fff}

/* Beta-Overlay-Banner */
.betabar{background:repeating-linear-gradient(45deg,#1b1f27,#1b1f27 12px,#222732 12px,#222732 24px);
  color:#ffd23f; text-align:center; font-family:"Saira Condensed",sans-serif; font-weight:700;
  text-transform:uppercase; letter-spacing:.14em; font-size:12px; padding:5px 10px;
  border-bottom:2px solid var(--red)}

/* Like / Dislike in der Navigation */
.votes{display:inline-flex; gap:6px; align-items:center}
.vote{display:inline-flex; align-items:center; gap:5px; background:transparent; border:1px solid #2a313c;
  color:var(--steel-2); border-radius:14px; padding:3px 10px; cursor:pointer; font:inherit; font-size:12px;
  font-family:"Roboto Mono",monospace; transition:.12s; line-height:1}
.vote:hover{color:#fff; border-color:var(--steel)}
.vote svg{width:15px; height:15px}
.vote[data-choice="dislike"] svg{transform:scaleY(-1)}
.vote.is-on[data-choice="like"]{color:#7ee0a0; border-color:#2f6b48; background:rgba(46,107,72,.18)}
.vote.is-on[data-choice="dislike"]{color:#f29; color:#ff8aa0; border-color:#7a2f3e; background:rgba(122,47,62,.18)}
.vote .vc{font-weight:600}

/* ---- Klassen-Umschalter ---- */
.tabs{display:flex; gap:6px; margin:22px 0 14px}
.tab{appearance:none; border:1px solid var(--line-strong); background:var(--paper);
  font-family:"Saira Condensed","Arial Narrow",sans-serif; font-weight:600;
  text-transform:uppercase; letter-spacing:.06em; font-size:16px; color:var(--steel);
  padding:9px 22px; border-radius:2px; cursor:pointer; transition:.12s}
.tab:hover{color:var(--ink); border-color:var(--steel)}
.tab[aria-selected="true"]{background:var(--ink); color:#fff; border-color:var(--ink)}
.tab[aria-selected="true"]::before{content:""; display:inline-block; width:8px; height:8px;
  background:var(--red); margin-right:9px; transform:translateY(-1px)}

/* ---- Wertungs-Umschalter ---- */
.controls{display:flex; align-items:center; gap:12px; flex-wrap:wrap; margin:0 0 16px}
.controls__lbl{font-family:"Saira Condensed",sans-serif; text-transform:uppercase;
  letter-spacing:.06em; font-size:12px; color:var(--steel); font-weight:600}
.modes{display:inline-flex; border:1px solid var(--line-strong); border-radius:3px; overflow:hidden}
.mode{appearance:none; border:0; border-left:1px solid var(--line-strong); background:var(--paper);
  font-family:"Inter",sans-serif; font-size:13px; color:var(--steel); padding:7px 14px; cursor:pointer;
  transition:.12s; white-space:nowrap}
.mode:first-child{border-left:0}
.mode:hover{color:var(--ink); background:var(--zebra)}
.mode[aria-pressed="true"]{background:var(--red); color:#fff}

.board[hidden]{display:none}
.board__title{font-family:"Saira Condensed",sans-serif; text-transform:uppercase;
  letter-spacing:.05em; font-size:14px; color:var(--steel); margin:0 0 8px; font-weight:600}

/* ---- Tabelle ---- */
.scroller{overflow-x:auto; background:var(--paper); border:1px solid var(--line);
  border-radius:4px; box-shadow:var(--shadow)}
table.grid{border-collapse:collapse; width:100%; min-width:680px}
.grid thead th{position:sticky; top:0; background:var(--ink-2); color:#fff;
  font-family:"Saira Condensed",sans-serif; font-weight:600; text-transform:uppercase;
  letter-spacing:.04em; font-size:12.5px; padding:10px 10px; text-align:center;
  white-space:nowrap; border-bottom:2px solid var(--red)}
.grid thead th .lf{display:block; font-family:"Roboto Mono",monospace; font-weight:700;
  font-size:14px; letter-spacing:0}
.grid thead th .lftag{display:block; font-size:9px; font-weight:600; letter-spacing:.08em;
  color:var(--steel-2); text-transform:uppercase; line-height:1.1}
.grid thead th .org{display:block; font-size:10px; color:var(--steel-2); font-weight:400;
  font-family:"Inter",sans-serif; text-transform:none; letter-spacing:0; margin-top:1px}
.grid th.c-rank{width:46px}
.grid th.c-name{text-align:left; padding-left:14px}
.grid th.c-total{width:84px}

.grid tbody td{padding:9px 10px; text-align:center; border-bottom:1px solid var(--line);
  font-family:"Roboto Mono",ui-monospace,monospace; font-variant-numeric:tabular-nums}
.grid tbody tr:nth-child(even){background:var(--zebra)}
.grid tbody tr:hover{background:#EAF0F6}

td.c-rank{font-weight:700; font-size:16px; color:var(--ink); width:46px}
td.c-name{text-align:left; padding-left:14px; font-family:"Inter",sans-serif}
.c-name .nm{font-weight:600; color:var(--ink); display:block; line-height:1.15}
.c-name .sub{display:block; font-size:11.5px; color:var(--steel); margin-top:1px}

td.c-race .g{font-weight:600; font-size:15px; color:var(--ink)}
td.c-race .qf{display:block; font-size:10.5px; color:var(--steel-2); margin-top:1px}
td.c-race.is-empty{color:var(--steel-2)}
td.c-race.is-empty .g{color:var(--line-strong); font-weight:400}
td.c-race.is-drop .g{color:var(--drop); text-decoration:line-through; text-decoration-thickness:1.5px}
td.c-race.is-drop .qf{color:var(--drop)}
td.c-race .tag{display:inline-block; font-family:"Inter",sans-serif; font-size:9px;
  text-transform:uppercase; letter-spacing:.06em; color:var(--steel); border:1px solid var(--line-strong);
  border-radius:2px; padding:0 3px; margin-top:2px}

td.c-total{font-weight:700; font-size:18px; color:var(--ink); width:84px}

/* Leader / Podium-Akzent als linke Kante */
tr.row td:first-child{border-left:3px solid transparent}
tr.row--p1 td:first-child{border-left-color:var(--red)}
tr.row--p2 td:first-child{border-left-color:var(--ink)}
tr.row--p3 td:first-child{border-left-color:var(--steel)}
tr.row--p1 td.c-total{color:var(--red)}
tr.row--p1 td.c-rank{color:var(--red)}

/* Fahrer ohne Wertung (0 Punkte) dezent */
tr.row--zero td.c-rank{color:var(--steel-2)}
tr.row--zero td.c-name .nm{color:var(--steel); font-weight:500}
tr.row--zero td.c-total{color:var(--steel-2); font-weight:600; font-size:15px}

.legend{display:flex; gap:18px 26px; flex-wrap:wrap; margin:12px 2px 0;
  font-size:12px; color:var(--steel)}
.legend span{display:inline-flex; align-items:center; gap:7px}
.legend .sw{width:22px; height:0; border-top:2px solid var(--drop); text-decoration:line-through}
.legend i{font-style:normal; color:var(--drop); text-decoration:line-through; font-family:"Roboto Mono",monospace}

.foot{margin-top:26px; font-size:12px; color:var(--steel); line-height:1.6}
.foot a{color:var(--red-deep)}

/* ---- Umschaltung Desktop-Tabelle / Mobil-Karten ---- */
.only-mob{display:none}
@media (max-width:640px){
  .only-desk{display:none}
  .only-mob{display:block}
}

/* ---- Mobil: eine Karte pro Fahrer (kein Querscrollen) ---- */
.mcards{display:flex; flex-direction:column; gap:8px}
.mcard{background:var(--paper); border:1px solid var(--line); border-left:4px solid transparent;
  border-radius:6px; padding:10px 12px; box-shadow:var(--shadow)}
.mcard.row--p1{border-left-color:var(--red)}
.mcard.row--p2{border-left-color:var(--ink)}
.mcard.row--p3{border-left-color:var(--steel)}
.mcard.row--zero{opacity:.65}
.mc-top{display:flex; align-items:baseline; gap:10px}
.mc-rank{font-family:"Roboto Mono",monospace; font-weight:700; font-size:19px; min-width:1.3em; color:var(--ink)}
.mcard.row--p1 .mc-rank{color:var(--red)}
.mc-name{flex:1; font-weight:600; font-size:15px; line-height:1.15; color:var(--ink)}
.mc-name small{display:block; font-weight:400; font-size:11.5px; color:var(--steel); margin-top:2px}
.mc-total{font-family:"Roboto Mono",monospace; font-weight:700; font-size:19px; color:var(--ink)}
.mcard.row--p1 .mc-total{color:var(--red)}
.mc-races{display:flex; flex-wrap:wrap; gap:6px; margin-top:9px}
.mc-r{flex:1 1 64px; min-width:64px; background:var(--zebra); border-radius:4px; padding:5px 8px;
  display:flex; flex-direction:column; line-height:1.18}
.mc-rl{font-size:9px; text-transform:uppercase; letter-spacing:.05em; color:var(--steel); font-weight:600}
.mc-rg{font-family:"Roboto Mono",monospace; font-weight:700; font-size:15px; color:var(--ink)}
.mc-rq{font-family:"Roboto Mono",monospace; font-size:10px; color:var(--steel-2)}
.mc-r.is-drop .mc-rg{text-decoration:line-through; color:var(--drop)}
.mc-r.is-drop{opacity:.7}
.mc-empty .mc-rg{color:var(--line-strong); font-weight:400}

/* ---- Fixierte Spalten (Rang + Fahrer links, Total rechts) beim Querscrollen ---- */
.grid th.c-rank, .grid td.c-rank{position:sticky; left:0; z-index:2}
.grid th.c-name, .grid td.c-name{position:sticky; left:46px; z-index:2; box-shadow:1px 0 0 var(--line)}
.grid th.c-total, .grid td.c-total{position:sticky; right:0; z-index:2; box-shadow:-1px 0 0 var(--line)}
/* Datenzellen (Körper): heller Hintergrund, damit beim Scrollen nichts durchscheint */
.grid tbody td.c-rank, .grid tbody td.c-name, .grid tbody td.c-total{background:var(--paper)}
/* Kopfzellen behalten den dunklen Header-Hintergrund (sonst weisse Schrift auf weiss) */
.grid thead th.c-rank, .grid thead th.c-name, .grid thead th.c-total{background:var(--ink-2); z-index:4}
.grid thead th{z-index:3}
/* Zebra/Hover auch auf den fixierten Datenzellen */
.grid tbody tr:nth-child(even) td.c-rank,
.grid tbody tr:nth-child(even) td.c-name,
.grid tbody tr:nth-child(even) td.c-total{background:var(--zebra)}
.grid tbody tr:hover td.c-rank,
.grid tbody tr:hover td.c-name,
.grid tbody tr:hover td.c-total{background:#EAF0F6}

@media (max-width:620px){
  .wrap{padding:0 10px 48px}
  .brand{font-size:20px}
  .topbar__meta{width:100%; margin-left:0; gap:12px}
  .tabs{margin:16px 0 10px}
  .tab{padding:8px 16px; font-size:14px; flex:1}
  .controls{margin-bottom:12px}
  .mode{padding:7px 10px; font-size:12px}
  .grid thead th{padding:8px 6px; font-size:11px}
  .grid tbody td{padding:7px 6px}
  td.c-rank, .grid th.c-rank{width:34px}
  .grid th.c-name, .grid td.c-name{left:34px}            /* an schmaleren Rang anpassen */
  td.c-name{max-width:120px; padding-left:8px}
  .c-name .nm{font-size:12.5px}
  .c-name .sub{font-size:10px}
  td.c-race .g{font-size:13px}
  td.c-race .qf{font-size:9.5px}
  td.c-total{width:58px; font-size:15px}
  .legend{font-size:11px; gap:8px 16px}
}
@media (prefers-reduced-motion:reduce){*{transition:none!important}}
