/* ============================================================
   Athleten- + Admin-Backend
   ============================================================ */
.dash {
  display: grid;
  grid-template-columns: 260px 1fr;
  min-height: 100vh;
  background: var(--c-graphite);
}
@media (max-width: 880px) { .dash { grid-template-columns: 1fr; } }

.dash__side {
  background: var(--c-black);
  border-right: 1px solid var(--c-border);
  padding: var(--sp-5);
  display: flex; flex-direction: column; gap: var(--sp-5);
  position: sticky; top: 0; height: 100vh;
}
@media (max-width: 880px) { .dash__side { position: static; height: auto; } }

.dash__brand {
  display: flex; align-items: center; gap: var(--sp-3);
  padding-bottom: var(--sp-4);
  border-bottom: 1px solid var(--c-border);
}
.dash__brand img { height: 32px; }
.dash__brand strong { font-family: var(--ff-display); font-size: var(--fs-md); letter-spacing: var(--ls-wide); text-transform: uppercase; }

.dash__user { display: flex; align-items: center; gap: var(--sp-3); padding: var(--sp-3) 0; }
.dash__avatar {
  width: 44px; height: 44px; border-radius: 50%;
  background: var(--c-accent); color: var(--c-white);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--ff-display); font-size: var(--fs-md);
  text-transform: uppercase;
}
.dash__user .name { font-weight: 600; font-size: var(--fs-sm); }
.dash__user .role { font-size: var(--fs-xs); color: var(--c-text-mute); text-transform: uppercase; letter-spacing: var(--ls-wide); }

.dash__nav { display: flex; flex-direction: column; gap: 2px; flex: 1; }
.dash__nav a {
  display: flex; align-items: center; gap: var(--sp-3);
  padding: var(--sp-3) var(--sp-4); border-radius: var(--r-md);
  color: var(--c-text-soft); font-size: var(--fs-sm); font-weight: 500;
  transition: background var(--t-fast), color var(--t-fast);
}
.dash__nav a:hover { background: rgba(255,255,255,0.04); color: var(--c-text); }
.dash__nav a.is-active { background: var(--c-accent); color: var(--c-white); }
.dash__nav a svg { width: 18px; height: 18px; }
.dash__logout {
  border: 1px solid var(--c-border-strong);
  padding: var(--sp-3); border-radius: var(--r-md);
  color: var(--c-text-mute); text-align: center; font-size: var(--fs-xs);
  letter-spacing: var(--ls-wide); text-transform: uppercase;
}
.dash__logout:hover { color: var(--c-accent); border-color: var(--c-accent); }

.dash__main { padding: var(--sp-7) clamp(var(--sp-5), 4vw, var(--sp-8)); }
.dash__head {
  display: flex; flex-wrap: wrap; align-items: end; justify-content: space-between;
  gap: var(--sp-4); margin-bottom: var(--sp-7);
}
.dash__head h1 {
  font-size: var(--fs-3xl); margin: 0;
  font-family: var(--ff-display); text-transform: uppercase;
}

.kpi-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: var(--sp-4); margin-bottom: var(--sp-7); }
.kpi {
  background: var(--c-bg-card); border: 1px solid var(--c-border);
  border-radius: var(--r-lg); padding: var(--sp-5);
  position: relative; overflow: hidden;
}
.kpi::after {
  content: ""; position: absolute; bottom: 0; left: 0; height: 3px; background: var(--c-accent);
  width: var(--p, 0%); transition: width 1.2s var(--ease-out);
}
.kpi__label {
  font-size: var(--fs-xs); letter-spacing: var(--ls-wide);
  text-transform: uppercase; color: var(--c-text-mute);
}
.kpi__value {
  font-family: var(--ff-display);
  font-size: var(--fs-3xl); margin-top: var(--sp-2);
  line-height: 1;
}
.kpi__value .unit { font-size: var(--fs-md); color: var(--c-text-mute); margin-left: 4px; }
.kpi__delta { font-size: var(--fs-xs); margin-top: var(--sp-3); color: var(--c-success); }
.kpi__delta.is-down { color: var(--c-error); }

.panel {
  background: var(--c-bg-card); border: 1px solid var(--c-border);
  border-radius: var(--r-lg); padding: var(--sp-5) var(--sp-6);
  margin-bottom: var(--sp-5);
}
.panel__head {
  display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between;
  gap: var(--sp-3); margin-bottom: var(--sp-5);
}
.panel__head h2 { margin: 0; font-size: var(--fs-xl); }

.table-wrap { overflow-x: auto; margin: 0 calc(var(--sp-5) * -1); padding: 0 var(--sp-5); }
table.tbl { width: 100%; border-collapse: collapse; font-size: var(--fs-sm); min-width: 540px; }
table.tbl thead th {
  text-align: left; padding: var(--sp-3) var(--sp-4);
  border-bottom: 2px solid var(--c-border-strong);
  font-size: var(--fs-xs); text-transform: uppercase; letter-spacing: var(--ls-wide);
  color: var(--c-text-mute); white-space: nowrap;
}
table.tbl tbody td { padding: var(--sp-4); border-bottom: 1px solid var(--c-border); vertical-align: middle; }
table.tbl tbody tr:hover { background: rgba(255,255,255,0.03); }

.badge {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 4px 10px; font-size: var(--fs-xs); font-weight: 600;
  border-radius: var(--r-full); letter-spacing: var(--ls-wide); text-transform: uppercase;
}
.badge--ok { background: rgba(0,200,83,0.16); color: #4cd97f; }
.badge--wait { background: rgba(255,179,0,0.16); color: #ffc740; }
.badge--rej { background: rgba(225,6,0,0.16); color: var(--c-red-300); }
.badge--info { background: rgba(255,255,255,0.08); color: var(--c-text-soft); }

.benefit-pill {
  display: inline-flex; align-items: center; gap: var(--sp-2);
  padding: var(--sp-2) var(--sp-3);
  background: rgba(225,6,0,0.12); color: var(--c-accent);
  border: 1px solid rgba(225,6,0,0.4);
  border-radius: var(--r-full);
  font-size: var(--fs-xs); font-weight: 600; text-transform: uppercase; letter-spacing: var(--ls-wide);
}

.athlete-row { display: flex; align-items: center; gap: var(--sp-3); }
.athlete-row .av {
  width: 32px; height: 32px; border-radius: 50%;
  background: var(--c-charcoal); display: flex; align-items: center; justify-content: center;
  font-size: var(--fs-xs); font-family: var(--ff-display); color: var(--c-white);
}

.race-card {
  background: var(--c-bg-card); border: 1px solid var(--c-border);
  border-radius: var(--r-lg); padding: var(--sp-5);
  display: grid; grid-template-columns: 80px 1fr auto; gap: var(--sp-4);
  align-items: center;
  transition: border-color var(--t-base), transform var(--t-base);
}
.race-card:hover { border-color: var(--c-accent); transform: translateX(2px); }
.race-card__date {
  text-align: center; padding: var(--sp-3) 0;
  background: var(--c-black); border-radius: var(--r-md);
  border: 1px solid var(--c-border);
}
.race-card__date .d { font-family: var(--ff-display); font-size: var(--fs-xl); line-height: 1; color: var(--c-accent); }
.race-card__date .m { font-size: var(--fs-xs); text-transform: uppercase; letter-spacing: var(--ls-wide); color: var(--c-text-mute); }
.race-card__title { font-family: var(--ff-display); font-size: var(--fs-lg); text-transform: uppercase; }
.race-card__meta { color: var(--c-text-mute); font-size: var(--fs-xs); display: flex; flex-wrap: wrap; gap: var(--sp-3); margin-top: 4px; letter-spacing: var(--ls-wide); text-transform: uppercase; }

.login-shell {
  min-height: 100vh; display: flex; align-items: center; justify-content: center;
  padding: var(--sp-5);
  background: radial-gradient(circle at 30% 30%, rgba(225,6,0,0.18), transparent 60%), var(--c-black);
}
.login-card {
  background: var(--c-bg-card); border: 1px solid var(--c-border);
  border-radius: var(--r-lg); padding: var(--sp-7);
  width: 100%; max-width: 440px;
  box-shadow: var(--sh-lg);
}
.login-card .brand { justify-content: center; margin-bottom: var(--sp-5); }
.login-card h1 { text-align: center; font-size: var(--fs-2xl); margin-bottom: var(--sp-2); }
.login-card .sub { text-align: center; color: var(--c-text-mute); margin-bottom: var(--sp-6); font-size: var(--fs-sm); }
