/* MKWT Central Theme
   - One place for width, colors, spacing, cards, tables, nav, buttons.
   - Change variables in :root and everything updates across b/settings/stats.
*/
:root{
  --page-width: 1100px;
  --page-pad: 16px;

  /* Dominant black theme + Toad palette accents (blue/red/white) */
  --bg: #07080a;
  --card: #0c0f14;
  --card-2: #0a0c10;
  --hover: #10141b;

  --text: #ffffff;
  --muted: #9aa4b2;
  --border: #1d2736;

  /* Accent palette sampled from the reference image */
  --accent-blue: #386ecf;
  --accent-red: #ff3b30;
  --accent-white: #f8fafc;

  --primary: var(--accent-blue);
  --primary-text: #081018;

  --danger: var(--accent-red);
  --danger-text: #120707;

  --ring: 0 0 0 3px rgba(56,110,207,.28);

  --radius: 12px;
  --radius-sm: 10px;

  --shadow: 0 10px 30px rgba(0,0,0,.55);

  /* Overlays / sticky UI */
  --backdrop: rgba(0,0,0,.55);
  --nav-bg: rgba(0,0,0,.86);
  --nav-shadow: 0 10px 24px rgba(0,0,0,.35);
  --nav-text: #cbd5e1;

  /* Chart label colors (for custom canvas text) */
  --chart-label-fill: #ffffff;
  --chart-label-stroke: rgba(0,0,0,0.35);

  /* Chart helper colors */
  --primary-soft: rgba(56,110,207,0.12);
  --primary-strong: rgba(56,110,207,0.85);
  --chart-muted: rgba(255,255,255,0.55);
  --chart-zero-line: rgba(255,255,255,0.85);

  --link: #7dd3fc;
  --infoBtn-bg: rgba(255,255,255,0.06);
  --infoBtn-border: rgba(255,255,255,0.16);
  --infoBtn-text: rgba(255,255,255,0.92);

  /* Segmented mode buttons (Intermission / 3-Lap) */
  --modeBtn-bg: rgba(255,255,255,0.06);
  --modeBtn-border: rgba(255,255,255,0.22);
  --modeBtn-text: rgba(255,255,255,0.92);
  /* Active state = primary button style (matches Save + nav active) */
  --modeBtn-active-bg: var(--primary);
  --modeBtn-active-border: var(--primary);
  --modeBtn-active-text: var(--primary-text);
}


:root[data-theme="light"]{
  --bg: #f3f4f6;
  --card: #ffffff;
  --card-2: #f9fafb;
  --hover: #eef2f7;

  --text: #0b1220;
  --muted: #475569;
  --border: #d0d7e2;

  --accent-blue: #2563eb;
  --accent-red: #dc2626;
  --accent-white: #0b1220;

  --primary: var(--accent-blue);
  --primary-text: #ffffff;

  --danger: var(--accent-red);
  --danger-text: #ffffff;

  --ring: 0 0 0 3px rgba(37,99,235,.20);

  --link: #0369a1;

  --infoBtn-bg: rgba(0,0,0,0.04);
  --infoBtn-border: rgba(0,0,0,0.16);
  --infoBtn-text: rgba(0,0,0,0.75);

  /* Segmented mode buttons (Intermission / 3-Lap) */
  --modeBtn-bg: rgba(0,0,0,0.03);
  --modeBtn-border: rgba(2,6,23,0.22);
  --modeBtn-text: #0b1220;
  --modeBtn-active-bg: var(--primary);
  --modeBtn-active-border: var(--primary);
  --modeBtn-active-text: var(--primary-text);

  --shadow: 0 10px 25px rgba(2,6,23,.10);

  /* Overlays / sticky UI */
  --backdrop: rgba(15,23,42,.18);
  --nav-bg: rgba(255,255,255,.88);
  --nav-shadow: 0 10px 24px rgba(2,6,23,.10);
  --nav-text: #0b1220;

  /* Chart label colors (for custom canvas text) */
  --chart-label-fill: #0b1220;
  --chart-label-stroke: rgba(255,255,255,0.65);

  /* Chart helper colors */
  --primary-soft: rgba(37,99,235,0.10);
  --primary-strong: rgba(37,99,235,0.70);
  --chart-muted: rgba(15,23,42,0.60);
  --chart-zero-line: rgba(15,23,42,0.35);
}



:root[data-theme="dendo"]{
  /* Dendo = Blue (dezent, Toad-inspired) */
  --bg: #05060a;
  --card: #0b0f18;
  --card-2: #0a0c12;
  --hover: #0f1524;

  --text: #ffffff;
  --muted: #a7b3c6;
  --border: rgba(239,68,68,.38);

  --accent-blue: #2f6fff;
  --accent-red: #ef4444; /* reserved for danger */
  --accent-white: #ffffff;

  --primary: #ef4444;
  --primary-text: #ffffff;

  --danger: #b91c1c;
  --danger-text: #ffffff;

  --ring: 0 0 0 3px rgba(47,111,255,.22);

  --link: #93c5fd;

  --infoBtn-bg: rgba(47,111,255,0.14);
  --infoBtn-border: rgba(47,111,255,0.35);
  --infoBtn-text: rgba(255,255,255,0.95);

  /* Mode toggle (Intermission / 3-Lap) should match card styling */
  --modeBtn-bg: var(--card-2);
  --modeBtn-border: var(--border);
  --modeBtn-text: var(--text);
  --modeBtn-active-bg: var(--primary);
  --modeBtn-active-border: var(--primary);
  --modeBtn-active-text: var(--primary-text);

  --shadow: 0 12px 34px rgba(0,0,0,.60);
}


:root[data-theme="green"]{
  /* Green (subtle) */
  /* slightly tinted backgrounds (not only borders) */
  --bg: #04100b;
  --card: #071711;
  --card-2: #06130e;
  --hover: #0a1c14;

  --text: #ffffff;
  --muted: #a7b3c6;
  --border: rgba(250,204,21,.42);

  --accent-blue: #facc15; /* links etc. */
  --accent-red: #ff3b30;  /* danger only */
  --accent-white: #ffffff;

  --primary: #facc15;
  --primary-text: #071018;

  --danger: #ff3b30;
  --danger-text: #ffffff;

  --ring: 0 0 0 3px rgba(34,197,94,.22);

  --link: #86efac;

  --infoBtn-bg: rgba(34,197,94,0.14);
  --infoBtn-border: rgba(34,197,94,0.35);
  --infoBtn-text: rgba(255,255,255,0.95);

  /* Mode toggle (Intermission / 3-Lap) should match card styling */
  --modeBtn-bg: var(--card-2);
  --modeBtn-border: var(--border);
  --modeBtn-text: var(--text);
  --modeBtn-active-bg: var(--primary);
  --modeBtn-active-border: var(--primary);
  --modeBtn-active-text: var(--primary-text);

  --shadow: 0 12px 34px rgba(0,0,0,.60);
}

:root[data-theme="red"]{
  /* Red (subtle) */
  /* slightly tinted backgrounds (not only borders) */
  --bg: #120607;
  --card: #1a0a0b;
  --card-2: #16090a;
  --hover: #220c0e;

  --text: #ffffff;
  --muted: #a7b3c6;
  --border: rgba(47,111,255,.35);

  --accent-blue: #93c5fd; /* links etc. */
  --accent-red: #ff3b30;
  --accent-white: #ffffff;

  --primary: #2f6fff;
  --primary-text: #ffffff;

  --danger: #b91c1c; /* deeper red for danger */
  --danger-text: #ffffff;

  --ring: 0 0 0 3px rgba(255,59,48,.20);

  --link: #fecaca;

  --infoBtn-bg: rgba(255,59,48,0.14);
  --infoBtn-border: rgba(255,59,48,0.33);
  --infoBtn-text: rgba(255,255,255,0.95);

  /* Mode toggle (Intermission / 3-Lap) should match card styling */
  --modeBtn-bg: var(--card-2);
  --modeBtn-border: var(--border);
  --modeBtn-text: var(--text);
  --modeBtn-active-bg: var(--primary);
  --modeBtn-active-border: var(--primary);
  --modeBtn-active-text: var(--primary-text);

  --shadow: 0 12px 34px rgba(0,0,0,.60);
}

/* Base */
*, *::before, *::after { box-sizing: border-box; }

/* >>> HIER <<< */
html {
  height: 100%;
  overflow-y: scroll;        /* Fix für Breiten-Verschiebung */
  scrollbar-gutter: stable;    background: var(--bg);
  color: var(--text);
/* modern, falls unterstützt */
}

body {
  margin: 0;
  font-family: Arial, sans-serif;
  background: var(--bg);
  color: var(--text);
  min-height: 100%;
}

a{ color: var(--link); text-decoration:none; }

/* Layout container */
.wrap{
  max-width: var(--page-width);
  margin: 24px auto;
  padding: 0 var(--page-pad);
}

/* Cards */
.card{
  background: var(--card);
  border-radius: var(--radius);
  padding: 16px;
  box-shadow: var(--shadow);
  margin-bottom: 16px;
}

/* Rows/Fields */
.row{ display:flex; gap:14px; flex-wrap:wrap; }
.row > *{ flex:1; min-width:220px; }

/* Keep specific select rows on a single line (even on small screens) */
.row.inlineSelects{ flex-wrap:nowrap; gap:12px; }
.row.inlineSelects > *{ min-width:0; }
.row.inlineSelects select{
  width:100%;
  /* responsive font-size so long track names fit better */
  font-size:clamp(11px, 2.9vw, 14px);
}

@media (max-width: 420px){
  .row.inlineSelects{ gap:10px; }
  .row.inlineSelects select{ font-size:clamp(10px, 3.1vw, 13px); }
}
.field{ display:flex; flex-direction:column; gap:6px; }
label.muted{ display:block; margin:0; }

/* Form controls */
input, select{
  width:100%;
  padding:10px;
  border-radius:8px;
  border:1px solid var(--border);
  background: var(--bg);
  color: var(--text);
}
input:focus, select:focus{
  outline: none;
  border-color: rgba(56,110,207,.75);
  box-shadow: var(--ring);
}
button{ border:none; background:transparent; color:inherit; font:inherit; }

/* Buttons */
.btn, .btn2, .danger, .navAction{
  padding:10px 12px;
  border-radius: var(--radius-sm);
  border: 1px solid transparent;
  cursor:pointer;
  font-weight:800;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  user-select:none;
  text-decoration:none;
  line-height:1;
}
.btn{ background: var(--primary); color: var(--primary-text); border-color: var(--primary); }
.btn2{ background: var(--infoBtn-bg); color: var(--text); border-color: var(--border); }
.navAction{ background: var(--infoBtn-bg); color: var(--text); border-color: var(--border); }
.danger{ background: var(--danger); color: var(--danger-text); border-color: var(--danger); }
.btn:hover{ filter: brightness(1.05); }
.btn2:hover{ border-color: var(--primary); background: var(--hover); }
/* Primary action (used for Guest login CTA in Settings) */

.navAction:hover{ border-color: var(--primary); background: var(--hover); }
.navAction.active{ background: var(--primary); color: var(--primary-text); border-color: var(--primary); }
.btn:active, .btn2:active, .navAction:active, .danger:active{ transform: translateY(1px); }
.btn:disabled, .btn2:disabled, .danger:disabled, .navAction:disabled{ opacity:.6; cursor:not-allowed; }

/* Small text + status colors */
.muted{ color: var(--muted); font-size:12px; white-space:pre-wrap; }
.ok{ color:#7CFF7C; }
.bad{ color:#FF7C7C; }

.hidden{ display:none; }

/* Pills */
.pill{
  display:inline-block;
  padding:2px 8px;
  border-radius:999px;
  background: var(--border);
  color:#cbd5e1;
  font-size:12px;
}

/* Tables */
table{ width:100%; border-collapse:collapse; overflow:hidden; border-radius: var(--radius-sm); }
th, td{ padding:10px; border-bottom:1px solid var(--border); text-align:left; font-size:14px; }
th{ background: var(--card-2); color:#cbd5e1; }
tr:hover td{ background: var(--hover); }

.actions{ display:flex; gap:8px; justify-content:flex-end; }
.iconBtn{
  padding:6px 10px;
  border-radius:8px;
  border:1px solid var(--border);
  background: var(--bg);
  color: var(--text);
  cursor:pointer;
}
.iconBtn:hover{ filter:brightness(1.1); }
.iconBtn.danger, .iconDanger{ border-color:#7a3a3a; }

/* Dialog */
dialog{
  border:none;
  border-radius: var(--radius);
  padding:0;
  width:min(820px, 96vw);
  background: var(--card);
  color: var(--text);
  box-shadow:0 20px 60px rgba(0,0,0,.6);
}
dialog::backdrop{ background: var(--backdrop); }

/* Charts */
canvas{ background: var(--card-2); border-radius: var(--radius); }

/* Pie sizing (prevents giant pie) */
.pie-wrap{
  width: 360px;
  height: 220px;
  margin: 0 auto;
}
.pie-wrap canvas{
  width: 100% !important;
  height: 100% !important;
  background: transparent !important;
}

/* Topbar (stats header) */
.topbar{ display:flex; align-items:center; justify-content:space-between; gap:10px; flex-wrap:wrap; }

/* ===== Navigation (unified) ===== */
.nav{
  position:sticky;
  top:0;
  z-index:50;
  background: var(--nav-bg);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--border);
  box-shadow: var(--nav-shadow);
}
.navInner{
  max-width: var(--page-width);
  margin:0 auto;
  padding: 10px var(--page-pad);
  display:flex;
  align-items:center;
  gap:12px;
  flex-wrap:nowrap;
  overflow-x:auto;
}
.navInner::-webkit-scrollbar{ height:8px; }
.navInner::-webkit-scrollbar-thumb{ background: var(--border); border-radius:999px; }

.brand{ font-weight:900; letter-spacing:.3px; margin-right:6px; color: var(--accent-white); }

/* subtle "by Aytee" brand (used in navbar + headers) */
.brand .byAytee,
h2 .byAytee{
  font-weight:700;
  opacity:.55;
  font-size:.72em;
  letter-spacing:.2px;
  margin-left:6px;
  text-transform:none;
  white-space:nowrap;
}

.navLink{
  padding:8px 10px;
  border-radius: var(--radius-sm);
  border:1px solid transparent;
  color: var(--nav-text);
  text-decoration:none;
  font-weight:700;
}
.navLink:hover{ border-color: var(--border); background: var(--hover); }
.navLink.active{ background: var(--primary); color: var(--primary-text); border-color: var(--primary); }

.navLink.navIcon{
  width: 36px;
  text-align:center;
  padding:8px 0;
  font-size:16px;
  line-height:1;
}

.navSpacer{ flex:1; }
.navRight{ display:flex; align-items:center; gap:10px; flex-wrap:nowrap; }

/* Make action buttons match nav links */
.navAction{
  padding:8px 10px;
  border-radius: var(--radius-sm);
  border:1px solid var(--border);
  color: var(--nav-text);
  font-weight:700;
  background: var(--infoBtn-bg);
  cursor:pointer;
}
.navAction:hover{ border-color: var(--primary); background: var(--hover); }
.navAction.danger{
  background: var(--danger);
  color: var(--danger-text);
  border-color: var(--danger);
}
.navAction.danger:hover{ filter:brightness(1.05); }
.navAction input[type="file"]{ display:none; }

/* ===== Mobile / Small screens ===== */
@media (max-width: 720px){
  :root{ --page-pad: 12px; }

  .wrap{ margin: 16px auto; padding: 0 var(--page-pad); }

  /* Mobile: give every card a themed outline */
  .card{ border: 1px solid var(--border); }

  /* Nav: keep single line on mobile */
  .navInner{
    flex-wrap: nowrap;
    overflow-x: auto;
    row-gap: 0;
  }
  .navSpacer{ display:none; }
  .navRight{ display:none; }
  .navLink{
    padding: 8px 9px;
    font-size: 13px;
    white-space: nowrap;
  }
  .navLink.navIcon{ width: 34px; font-size: 16px; }

  /* Tables: tighter + hide less important columns on phone */
  th, td{ padding: 8px; font-size: 13px; }
  /* tracker.html: columns are handled in the 420px card layout below */
/* Charts: give more vertical room so Y-axis isn't cramped */
  canvas{ height: 260px !important; }
  .pie-wrap{ width: 100%; max-width: 360px; height: 220px; }
}
/* ===== Fix: Labels kleben optisch an falschem Feld ===== */

/* Mehr Abstand nach jedem Feld */
.field {
  margin-bottom: 18px;
}

/* Label klar vom vorherigen Input trennen */
.field > label {
  display: block;
  margin-top: 6px;      /* Abstand nach vorherigem Feld */
  margin-bottom: 6px;   /* Abstand zum eigenen Input */
  line-height: 1.2;
}

/* Inputs etwas tiefer setzen */
.field > input,
.field > select {
  margin-top: 2px;
}

/* ===== Strategy popup (tracker.html) ===== */
.field.hasStratIcon{ position: relative; }
.stratBtn{
  position: absolute;
  top: 6px;
  right: 6px;
  width: 22px;
  height: 22px;
  border-radius: 999px;
  border: 1px solid var(--infoBtn-border);
  background: var(--infoBtn-bg);
  color: var(--infoBtn-text);
  font-weight: 800;
  font-size: 12px;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  cursor: pointer;
  opacity: 0.75;
  user-select: none;
  -webkit-tap-highlight-color: transparent;
}
.stratBtn:hover{ opacity: 0.95; }
.stratBtn:active{ transform: translateY(1px); }

.stratPopup{
  position: fixed;
  z-index: 9999;
  display: none;
  max-width: min(320px, calc(100vw - 24px));
  border: 1px solid var(--border);
  border-radius: 12px;
  background: rgba(16,18,22,0.98);
  box-shadow: 0 10px 30px rgba(0,0,0,0.35);
  padding: 10px 12px;
}
.stratPopup.isOpen{ display: block; }
.stratPopup__body{ font-size: 13px; line-height: 1.35; }


/* ===== iPhone / Narrow screens: Match list as cards ===== */
@media (max-width: 480px) and (pointer: coarse){

  /* use card layout only for the match list table */
  #listCard table thead { display: none; }

  /* each row becomes a card */
  #listCard table tbody tr{
    display: grid;
    grid-template-columns: 1fr minmax(96px, 120px); /* left: text | right: VR */
    gap: 4px 8px;
    background: rgba(255,255,255,0.04);
    border: 1px solid var(--border);
    border-radius: 12px;
    padding: 10px;
    margin-bottom: 10px;
  }

  /* neutralize table cell look */
  #listCard table tbody td{
    border: none !important;
    padding: 0 !important;
    background: transparent !important;
    white-space: normal;
    display: block; /* IMPORTANT: overrides any earlier display:none */
  }

  /* ===== Mobile Card Icons for Opponents & Placement ===== */

  /* Opponents: ♟ */
  #listCard table tbody td:nth-child(7)::before{
    content: "♟ ";
    opacity: .85;
    margin-right: 2px;
  }

  /* Placement: ♕ */
  #listCard table tbody td:nth-child(8)::before{
    content: "♕ ";
    opacity: .85;
    margin-right: 2px;
  }

  /* If empty -> no icon */
  #listCard table tbody td:nth-child(7):empty::before,
  #listCard table tbody td:nth-child(8):empty::before{
    content: "";
  }

  /* Match # */
  #listCard table tbody td:nth-child(1){
    grid-column: 1;
    grid-row: 1;
    font-weight: 900;
  }

  /* Make each card a positioning context */
#listCard table tbody tr{
  position: relative;
  padding-bottom: 22px; /* space for the date at the bottom */
}

/* Created/Date -> pin to bottom-left WITHOUT stretching the card */
#listCard table tbody tr td:nth-child(2){
  position: absolute;
  left: 10px;
  bottom: 8px;

  font-size: 11px;
  opacity: .55;
  line-height: 1.2;
  margin: 0 !important;
  padding: 0 !important;
  background: transparent !important;
  white-space: nowrap;
}

  /* Intermission */
  #listCard table tbody td:nth-child(3){
    grid-column: 1;
    grid-row: 3;
    font-weight: 800;
  }

  /* Track */
  #listCard table tbody td:nth-child(4){
    grid-column: 1;
    grid-row: 4;
    font-weight: 800;
  }

  /* VR after (right, top) */
  #listCard table tbody td:nth-child(6){
    grid-column: 2;
    grid-row: 1;
    text-align: right;
    font-weight: 900;
    font-size: 15px;
    white-space: nowrap;
  }

  /* VR Δ (right, under VR after) */
  #listCard table tbody td:nth-child(5){
    grid-column: 2;
    grid-row: 2;
    text-align: right;
    font-weight: 900;
    font-size: 13px;
    white-space: nowrap;
  }

  /* Opponents */
  #listCard table tbody td:nth-child(7){
    grid-column: 2;
    grid-row: 3;
    text-align: right;
    font-size: 11px;
    opacity: .75;
    white-space: nowrap;
  }

  /* Placement */
  #listCard table tbody td:nth-child(8){
    grid-column: 2;
    grid-row: 4;
    text-align: right;
    font-size: 11px;
    opacity: .75;
    white-space: nowrap;
  }

  /* Actions: bottom-right */
  #listCard table tbody td:nth-child(9){
    grid-column: 2;
    grid-row: 5;
    display: flex !important; /* override */
    justify-content: flex-end;
    gap: 8px;
    margin-top: 6px;
  }

  /* hide Opp/Place if truly empty */
  #listCard table tbody td:nth-child(7):empty,
  #listCard table tbody td:nth-child(8):empty{
    display: none !important;
  }
}



/* ===== Mobile UX fixes (global) ===== */
input, select, textarea, button{
  font-size: 16px; /* prevents iOS input zoom */
}
html{ -webkit-text-size-adjust: 100%; }

/* ===== VR Delta negative toggle button ===== */
.vr-delta-wrap{
  display:flex;
  align-items:center;
  gap:10px;
}
.vr-delta-wrap .vr-sign{
  width:44px;
  height:44px;
  border-radius:12px;
  font-size:22px;
  line-height:1;
  background:#1e2533;
  color:#ffffff;
  border:1px solid rgba(255,255,255,0.08);
}
.vr-delta-wrap .vr-sign.is-negative{
  background:#3a1f28;
  border-color: rgba(255, 90, 120, 0.35);
}
.vr-delta-wrap input{
  flex:1;
}

/* ===== Match mode toggle (Intermission / 3-Lap) ===== */
.modeToggle{
  display:flex;
  gap:10px;
  margin: 0 0 12px 0;
}
.modeToggle .modeBtn{
  padding:10px 14px;
  border-radius:12px;
  background: var(--modeBtn-bg);
  border: 2px solid var(--modeBtn-border);
  color: var(--modeBtn-text);
  font-weight: 800;
  cursor: pointer;
  line-height: 1;
}
.modeToggle .modeBtn.isActive{
  background: var(--modeBtn-active-bg);
  border-color: var(--modeBtn-active-border);
  color: var(--modeBtn-active-text);
}

.modeToggle .modeBtn:focus-visible{
  outline: none;
  box-shadow: var(--ring);
}

/* Actions cell: keep buttons aligned even when delete is hidden */
td:last-child{
  white-space: nowrap;
}


/* ===== Table UX: Intermission stacked start/end ===== */
.intermission-stack{display:flex;flex-direction:column;gap:4px;}
.intermission-stack .label{font-size:11px;opacity:.7;}
.intermission-stack .value{font-weight:500;}
.track-placeholder{opacity:.4;}

/* Hide placeholder dashes in mobile / PWA card view, keep them on desktop table */
@media (max-width: 700px){
  .track-placeholder,
  .intermission-placeholder{ display:none !important; }
}

/* ===== Edit dialog mode toggle ===== */
.modeToggleRow{display:flex;gap:10px;margin:10px 0 14px;}
.modeBtnSmall{padding:8px 10px;border-radius:999px;border:2px solid var(--modeBtn-border);background:var(--modeBtn-bg);color:var(--modeBtn-text);font-weight:700;cursor:pointer;line-height:1;}
.modeBtnSmall.isActive{background:var(--modeBtn-active-bg);border-color:var(--modeBtn-active-border);color:var(--modeBtn-active-text);}


:root[data-theme="purple"]{
  /* Purpur Pop: dark purple base + pink accents */
  --bg: #07060b;
  --card: #0f0a16;
  --card-2: #0c0812;
  --hover: #140f1e;

  --text: #ffffff;
  --muted: rgba(255,255,255,0.72);

  --border: rgba(255,105,180,0.55); /* hotpink tint */
  --border-strong: rgba(255,105,180,0.75);

  --primary: #ff5fb8;
  --primary-2: #c84cff;

  --danger: #ff3b3b;

  --btn-bg: rgba(255,95,184,0.18);
  --btn-bg-hover: rgba(255,95,184,0.26);
  --btn-border: rgba(255,95,184,0.55);
  --btn-text: #ffffff;

  --toggle-bg: rgba(255,255,255,0.08);
  --toggle-border: rgba(255,105,180,0.55);
  --toggle-text: rgba(255,255,255,0.88);
  --toggle-active-bg: rgba(255,95,184,0.24);
  --toggle-active-text: #ffffff;

  --backdrop: rgba(10,6,18,0.60);

  /* Segmented mode buttons (Intermission / 3-Lap) */
  --modeBtn-bg: var(--card-2);
  --modeBtn-border: var(--border);
  --modeBtn-text: var(--text);
  --modeBtn-active-bg: var(--primary);
  --modeBtn-active-border: var(--primary);
  --modeBtn-active-text: var(--primary-text);
}

:root[data-theme="rose"]{
  /* Rosa Reinweiß: soft white with rose tint */
  --bg: #f7f0f4;
  --card: #ffffff;
  --card-2: #fff6fb;
  --hover: #f2e7ef;

  --text: #0b1220;
  --muted: rgba(15,23,42,0.64);

  --border: rgba(236,72,153,0.35); /* rose */
  --border-strong: rgba(236,72,153,0.55);

  --primary: #ec4899;
  --primary-2: #be185d;

  --danger: #dc2626;

  --btn-bg: rgba(236,72,153,0.10);
  --btn-bg-hover: rgba(236,72,153,0.16);
  --btn-border: rgba(236,72,153,0.45);
  --btn-text: #0b1220;

  --toggle-bg: rgba(15,23,42,0.04);
  --toggle-border: rgba(236,72,153,0.45);
  --toggle-text: rgba(11,18,32,0.90);
  --toggle-active-bg: rgba(236,72,153,0.14);
  --toggle-active-text: #0b1220;

  --backdrop: rgba(255,255,255,0.72);

  /* Segmented mode buttons (Intermission / 3-Lap) */
  --modeBtn-bg: var(--card-2);
  --modeBtn-border: rgba(236,72,153,0.45);
  --modeBtn-text: #0b1220;
  --modeBtn-active-bg: var(--primary);
  --modeBtn-active-border: var(--primary);
  --modeBtn-active-text: var(--primary-text);
}

/* ===== Login responsive (from shared) ===== */
.login-wrap{
  min-height:100dvh;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:16px;
}
.login-card{
  width:min(92vw,420px);
  padding:18px;
  border-radius:14px;
}

/* ===== Utility classes (replaces repeated inline styles) ===== */
.navAction--sm{ padding:6px 10px; }
.flex-1{ flex:1; }
.row-inline{ display:flex; align-items:center; gap:8px; }
.row-inline--gap10{ display:flex; align-items:center; gap:10px; }
.mt-0{ margin-top:0; }
.mt-8{ margin-top:8px; }
.mt-10{ margin-top:10px; }
.mt-12{ margin-top:12px; }
.mb-0{ margin-bottom:0; }
.mb-10{ margin-bottom:10px; }
.mb-12{ margin-bottom:12px; }
.m-0{ margin:0; }
.divider{ margin:16px 0; border:none; border-top:1px solid var(--border); }
.section-header{ display:flex; align-items:center; gap:8px; margin:0 0 10px 0; }
.hint{ margin-top:6px; font-size:12px; opacity:.85; }
