/* ════════════════════════════════════════════════════════════════
   CSV SF Bochum-Linden – Mannschaftskasse
   Design-System: "Premium Amateur Football" — Schwarz/Gold, modern,
   mobil-freundlich. Bootstrap 5 als Basis.
   ════════════════════════════════════════════════════════════════ */

:root {
    /* ── Clubfarben ──────────────────────────────────────────── */
    --csv-ink:        #1a1d21;   /* tiefes Anthrazit statt reinem Schwarz */
    --csv-ink-2:      #24282e;   /* etwas heller, für Verläufe/Hover */
    --csv-ink-3:      #14161a;   /* dunkler als ink, für Hero-Tiefe */
    --csv-ink-soft:   #2f343b;   /* Karten-Header auf dunkel, Borders */

    --csv-gold:       #fcf514;   /* Vereins-Gelb aus dem Logo (Primär) */
    --csv-gold-2:     #fdf75e;   /* helleres Gelb (Hover/Glanz) */
    --csv-gold-deep:  #8a7200;   /* dunkles Gold-Gelb (lesbar als Text auf hell) */

    /* ── Neutrale Grautöne (warm abgestimmt) ─────────────────── */
    --csv-bg:         #f4f4f2;   /* App-Hintergrund, leicht warm */
    --csv-surface:    #ffffff;   /* Karten */
    --csv-surface-2:  #faf9f7;   /* abgesetzte Flächen (z.B. Gruppenkopf) */
    --csv-line:       #e8e6e1;   /* dezente Linien */
    --csv-line-soft:  #f0eeea;

    --csv-text:       #23262b;   /* Haupttext */
    --csv-text-muted: #6b7077;   /* gedämpfter Text */
    --csv-text-faint: #9aa0a7;

    /* ── Statusfarben (harmonisch, nicht grell) ──────────────── */
    --csv-success:    #2e9e5b;
    --csv-success-bg: #e7f4ec;
    --csv-danger:     #d64545;
    --csv-danger-bg:  #fae9e9;
    --csv-warning:    #e0a318;
    --csv-warning-bg: #fdf3dc;
    --csv-info:       #2f6fb0;
    --csv-info-bg:    #e8f0f8;

    /* ── Form & Schatten ─────────────────────────────────────── */
    --csv-radius:     .85rem;
    --csv-radius-sm:  .55rem;
    --csv-radius-lg:  1.15rem;
    --csv-shadow-sm:  0 1px 2px rgba(26,29,33,.05), 0 1px 3px rgba(26,29,33,.06);
    --csv-shadow:     0 2px 6px rgba(26,29,33,.06), 0 6px 18px rgba(26,29,33,.07);
    --csv-shadow-lg:  0 10px 35px rgba(26,29,33,.16);

    /* Bootstrap-Überschreibungen — KEINE blauen Standard-Links mehr.
       Links erben standardmäßig die Textfarbe; nur :hover wird golden. */
    --bs-body-color: var(--csv-text);
    --bs-link-color: inherit;
    --bs-link-hover-color: var(--csv-gold-deep);
    --bs-border-color: var(--csv-line);
}

/* ── Grundlayout & Typografie ────────────────────────────────── */
body {
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto,
                 "Helvetica Neue", Arial, sans-serif;
    background-color: var(--csv-bg);
    color: var(--csv-text);
    font-size: 1rem;
    line-height: 1.55;
    -webkit-font-smoothing: antialiased;
    -webkit-text-size-adjust: 100%;
}

h1, h2, h3, h4, h5, h6,
.h1, .h2, .h3, .h4, .h5, .h6 {
    color: var(--csv-ink);
    font-weight: 800;
    letter-spacing: -.015em;
    line-height: 1.18;
}

h1, .h1 { font-size: clamp(1.5rem, 4.2vw, 2rem); }
h2, .h2 { font-size: clamp(1.3rem, 3.4vw, 1.6rem); }
h3, .h3 { font-size: clamp(1.15rem, 2.8vw, 1.4rem); }

/* ════════════════════════════════════════════════════════════════
   KEINE BLAUEN LINKS. Jeder rohe Link erbt die umgebende Textfarbe,
   wird beim Hover golden. Buttons & spezielle Klassen behalten ihre
   eigene Gestaltung (durch höhere Spezifität / eigene Regeln).
   ════════════════════════════════════════════════════════════════ */
a {
    color: inherit;
    text-decoration: none;
    transition: color .15s ease;
}
a:hover {
    color: var(--csv-gold-deep);
    text-decoration: none;
}
/* Buttons sollen NIE die Link-Hoverfarbe übernehmen */
a.btn:hover { color: inherit; }
a.btn-csv, a.btn-csv:hover,
a.btn-primary, a.btn-primary:hover,
a.btn-dark, a.btn-dark:hover,
a.btn-success, a.btn-success:hover { text-decoration: none; }

.text-muted { color: var(--csv-text-muted) !important; }

/* Inline-Link in Fließtext/Tabellen, der dezent golden wirken soll */
.link-gold { color: var(--csv-gold-deep) !important; font-weight: 600; }
.link-gold:hover { color: var(--csv-ink) !important; }
/* Spielername als Link in Tabellen */
.link-player { color: var(--csv-ink); font-weight: 700; }
.link-player:hover { color: var(--csv-gold-deep); }

/* Optische Überschrift mit goldenem Akzentstrich darunter */
.page-title {
    position: relative;
    display: inline-block;
    padding-bottom: .35rem;
    margin-bottom: 1.25rem;
}
.page-title::after {
    content: "";
    position: absolute;
    left: 0; bottom: 0;
    width: 2.4rem; height: 3px;
    border-radius: 3px;
    background: var(--csv-gold);
}

/* kleine Uppercase-Section-Überschrift (über Kachelreihen etc.) */
.eyebrow {
    font-size: .72rem;
    text-transform: uppercase;
    letter-spacing: .1em;
    font-weight: 800;
    color: var(--csv-text-muted);
    margin-bottom: .6rem;
    display: flex;
    align-items: center;
    gap: .5rem;
}
.eyebrow::before {
    content: "";
    width: .9rem; height: 2px; border-radius: 2px;
    background: var(--csv-gold);
}

/* ── Navbar (öffentlich + Admin teilen .navbar-csv) ──────────── */
.navbar-csv {
    background: linear-gradient(180deg, var(--csv-ink-2) 0%, var(--csv-ink) 100%) !important;
    border-bottom: 3px solid var(--csv-gold);
    padding-top: .55rem;
    padding-bottom: .55rem;
    box-shadow: 0 2px 12px rgba(26,29,33,.18);
}

.navbar-csv .navbar-brand {
    color: #fff !important;
    font-weight: 800;
}
.navbar-csv .navbar-brand .brand-kicker {
    display: block;
    font-size: .68rem;
    color: var(--csv-gold);
    line-height: 1;
    font-weight: 700;
    letter-spacing: .1em;
    text-transform: uppercase;
    margin-bottom: .12rem;
}
.navbar-csv .navbar-brand .brand-main {
    font-size: 1rem;
    line-height: 1.15;
}
.navbar-csv .navbar-brand:hover { color: #fff !important; }
.navbar-csv .navbar-brand:hover .brand-main { color: var(--csv-gold-2); }

.navbar-csv .nav-link {
    color: rgba(255,255,255,.78) !important;
    font-size: .92rem;
    font-weight: 600;
    padding: .45rem .8rem !important;
    border-radius: .45rem;
    transition: color .15s, background .15s;
}
.navbar-csv .nav-link:hover {
    color: #fff !important;
    background: rgba(255,255,255,.08);
}
.navbar-csv .nav-link.active {
    color: var(--csv-ink) !important;
    background: var(--csv-gold);
    font-weight: 700;
}

.navbar-csv .navbar-toggler {
    border-color: rgba(252,245,20,.55);
    padding: .35rem .55rem;
}
.navbar-csv .navbar-toggler:focus { box-shadow: 0 0 0 .2rem rgba(252,245,20,.3); }
.navbar-csv .navbar-toggler-icon {
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba(252,245,20,0.9)' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2.4' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e");
}

/* Admin-Bereich-Button im öffentlichen Navbar — auffällig, gold,
   IMMER sichtbar (außerhalb des Hamburger-Collapse einsetzbar). */
.navbar-csv .nav-admin,
.btn-admin-cta {
    color: var(--csv-ink) !important;
    background: var(--csv-gold);
    font-weight: 800 !important;
    border-radius: .5rem;
    border: none;
    padding: .45rem .85rem !important;
    box-shadow: 0 2px 8px rgba(252,245,20,.3);
    white-space: nowrap;
}
.navbar-csv .nav-admin:hover,
.btn-admin-cta:hover {
    background: var(--csv-gold-2);
    color: var(--csv-ink) !important;
    box-shadow: 0 4px 14px rgba(252,245,20,.45);
}

/* dezenter Admin-Login-Link, wenn nicht eingeloggt */
.navbar-csv .nav-admin-discreet {
    color: rgba(255,255,255,.6) !important;
    border: 1px solid rgba(255,255,255,.2);
    font-weight: 600 !important;
    white-space: nowrap;
}
.navbar-csv .nav-admin-discreet:hover {
    color: var(--csv-gold-2) !important;
    border-color: rgba(252,245,20,.45);
    background: transparent;
}

/* "Zur App" / Admin-Wechsel-Button im Admin-Navbar */
.btn-to-app {
    color: var(--csv-ink);
    background: var(--csv-gold);
    font-weight: 800;
    font-size: .85rem;
    padding: .4rem .85rem;
    border-radius: .5rem;
    border: none;
    white-space: nowrap;
    box-shadow: 0 2px 8px rgba(252,245,20,.3);
}
.btn-to-app:hover { background: var(--csv-gold-2); color: var(--csv-ink); }

.admin-userchip {
    display: inline-flex;
    align-items: center;
    gap: .4rem;
    color: rgba(255,255,255,.85);
    background: rgba(255,255,255,.08);
    border: 1px solid rgba(255,255,255,.12);
    font-size: .8rem;
    padding: .3rem .6rem;
    border-radius: 2rem;
}
.admin-userchip .role {
    color: var(--csv-gold);
    font-weight: 700;
    text-transform: uppercase;
    font-size: .68rem;
    letter-spacing: .04em;
}
.navbar-csv .link-logout {
    color: rgba(255,255,255,.6) !important;
    font-size: .85rem;
    font-weight: 600;
}
.navbar-csv .link-logout:hover { color: var(--csv-danger) !important; background: transparent; }

/* ════════════════════════════════════════════════════════════════
   HERO – Startseite. Vollbreiter, dunkler Banner mit Gold-Akzent,
   Wappen, Titel, Untertitel. Bricht aus dem .container aus.
   ════════════════════════════════════════════════════════════════ */
.hero {
    position: relative;
    overflow: hidden;
    color: #fff;
    border-bottom: 3px solid var(--csv-gold);
    padding: 3rem 1rem 2.5rem;
    text-align: center;
    isolation: isolate;
}
/* GRUNDEBENE (immer aktiv): dunkler Anthrazit-Verlauf mit Goldschimmer.
   Garantierter Fallback, falls KEIN Mannschaftsfoto vorhanden ist. */
.hero::after {
    content: "";
    position: absolute; inset: 0;
    z-index: -2;
    background:
        radial-gradient(900px 360px at 50% -30%, rgba(252,245,20,.20), transparent 70%),
        linear-gradient(165deg, var(--csv-ink-2) 0%, var(--csv-ink) 55%, var(--csv-ink-3) 100%);
}
/* FOTO-EBENE (optional): liegt über der Grundebene.
   Existiert static/img/team.jpg, scheint das Foto gedämpft durch.
   Der dunkle Gradient ist der ERSTE Layer und läuft IMMER -> sichert
   Lesbarkeit & Schwarz-Gold-Look, egal ob das Foto existiert oder nicht.
   Fehlt team.jpg, schlägt nur der url()-Layer fehl, der Rest bleibt. */
.hero::before {
    content: "";
    position: absolute; inset: 0;
    z-index: -1;
    background:
        linear-gradient(165deg, rgba(26,29,33,.93) 0%, rgba(26,29,33,.72) 45%, rgba(20,22,26,.92) 100%),
        repeating-linear-gradient(115deg, rgba(255,255,255,.022) 0 2px, transparent 2px 22px),
        url('/static/img/team.jpg') center 28%/cover no-repeat;
    pointer-events: none;
}
.hero > * { position: relative; z-index: 1; }

.hero-crest {
    width: 88px; height: 88px;
    object-fit: contain;
    filter: drop-shadow(0 8px 20px rgba(0,0,0,.55));
    margin-bottom: .9rem;
}
.hero-kicker {
    display: inline-block;
    color: var(--csv-gold);
    font-size: .72rem;
    font-weight: 800;
    letter-spacing: .18em;
    text-transform: uppercase;
    margin-bottom: .6rem;
    padding: .28rem .8rem;
    background: rgba(252,245,20,.1);
    border: 1px solid rgba(252,245,20,.45);
    border-radius: 2rem;
    backdrop-filter: blur(2px);
}
.hero-title {
    color: #fff;
    font-size: clamp(1.75rem, 6.4vw, 2.8rem);
    font-weight: 900;
    letter-spacing: -.02em;
    line-height: 1.04;
    margin: 0 0 .4rem;
    text-shadow: 0 2px 18px rgba(0,0,0,.55);
}
.hero-title .accent { color: var(--csv-gold); }
.hero-sub {
    color: rgba(255,255,255,.78);
    font-size: clamp(.95rem, 2.6vw, 1.1rem);
    font-weight: 600;
    margin: 0;
    text-shadow: 0 1px 10px rgba(0,0,0,.5);
}
.hero-sub .dot { color: var(--csv-gold); margin: 0 .4rem; }

/* Stat-Kacheln im Hero (dunkel-transluzent, gold akzentuiert) */
.hero-stats {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: .7rem;
    max-width: 540px;
    margin: 1.85rem auto 0;
}
.hero-stat {
    background: rgba(10,12,15,.46);
    border: 1px solid rgba(255,255,255,.12);
    border-radius: var(--csv-radius);
    padding: .95rem .5rem .85rem;
    position: relative;
    overflow: hidden;
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
    transition: transform .15s ease, border-color .15s ease;
}
.hero-stat::before {
    content: "";
    position: absolute; left: 0; right: 0; top: 0; height: 2px;
    background: linear-gradient(90deg, transparent, var(--csv-gold), transparent);
}
.hero-stat:hover { transform: translateY(-2px); border-color: rgba(252,245,20,.4); }
.hero-stat .hs-value {
    font-size: clamp(1.4rem, 6vw, 1.9rem);
    font-weight: 900;
    color: #fff;
    line-height: 1;
    letter-spacing: -.02em;
    font-variant-numeric: tabular-nums;
}
.hero-stat .hs-value.gold { color: var(--csv-gold); }
.hero-stat .hs-value.alert { color: #ff8f6e; }
.hero-stat .hs-label {
    margin-top: .35rem;
    font-size: .64rem;
    text-transform: uppercase;
    letter-spacing: .07em;
    font-weight: 700;
    color: rgba(255,255,255,.62);
}

/* die Inhalts-Sektion direkt unter dem Hero hebt sich heran */
.hero + main .container,
main .container.pull-up { margin-top: -1.5rem; }

/* ── Buttons ─────────────────────────────────────────────────── */
.btn { font-weight: 600; border-radius: .6rem; }

.btn-csv {
    background-color: var(--csv-gold);
    border-color: var(--csv-gold);
    color: var(--csv-ink);
    font-weight: 800;
}
.btn-csv:hover, .btn-csv:focus {
    background-color: var(--csv-gold-2);
    border-color: var(--csv-gold-2);
    color: var(--csv-ink);
    box-shadow: 0 4px 12px rgba(252,245,20,.35);
}

.btn-outline-csv {
    border: 2px solid var(--csv-gold);
    color: var(--csv-ink);
    font-weight: 700;
    background: transparent;
}
.btn-outline-csv:hover {
    background-color: var(--csv-gold);
    border-color: var(--csv-gold);
    color: var(--csv-ink);
}

/* heller Outline-Button auf dunklem Grund (Hero) */
.btn-ghost-light {
    border: 1.5px solid rgba(255,255,255,.28);
    color: #fff;
    background: rgba(255,255,255,.04);
    font-weight: 700;
}
.btn-ghost-light:hover {
    border-color: var(--csv-gold);
    color: var(--csv-gold);
    background: rgba(252,245,20,.08);
}

/* Bootstrap-Primary an Clubfarbe Anthrazit binden (Admin-Formulare) */
.btn-primary {
    --bs-btn-bg: var(--csv-ink);
    --bs-btn-border-color: var(--csv-ink);
    --bs-btn-hover-bg: var(--csv-ink-2);
    --bs-btn-hover-border-color: var(--csv-ink-2);
    --bs-btn-active-bg: #000;
    --bs-btn-active-border-color: #000;
    --bs-btn-disabled-bg: var(--csv-ink);
    --bs-btn-disabled-border-color: var(--csv-ink);
}
.btn-outline-primary {
    --bs-btn-color: var(--csv-ink);
    --bs-btn-border-color: var(--csv-ink);
    --bs-btn-hover-bg: var(--csv-ink);
    --bs-btn-hover-border-color: var(--csv-ink);
    --bs-btn-active-bg: var(--csv-ink);
    --bs-btn-active-border-color: var(--csv-ink);
}
.btn-outline-secondary {
    --bs-btn-color: var(--csv-text-muted);
    --bs-btn-border-color: var(--csv-line);
    --bs-btn-hover-bg: var(--csv-ink);
    --bs-btn-hover-border-color: var(--csv-ink);
    --bs-btn-hover-color: #fff;
    --bs-btn-active-bg: var(--csv-ink);
}
.btn-dark {
    --bs-btn-bg: var(--csv-ink);
    --bs-btn-border-color: var(--csv-ink);
    --bs-btn-hover-bg: var(--csv-ink-2);
    --bs-btn-hover-border-color: var(--csv-ink-2);
}
.btn-success {
    --bs-btn-bg: var(--csv-success);
    --bs-btn-border-color: var(--csv-success);
    --bs-btn-hover-bg: #28874e;
    --bs-btn-hover-border-color: #28874e;
}
.btn-warning {
    --bs-btn-bg: var(--csv-warning);
    --bs-btn-border-color: var(--csv-warning);
    --bs-btn-color: #fff;
    --bs-btn-hover-bg: #c98f12;
    --bs-btn-hover-border-color: #c98f12;
    --bs-btn-hover-color: #fff;
}

/* Fingerfreundlich auf Touch: etwas größere Tap-Targets */
@media (max-width: 575.98px) {
    .btn { padding-top: .5rem; padding-bottom: .5rem; }
    .btn-sm { padding-top: .35rem; padding-bottom: .35rem; }
}

/* ── Cards ───────────────────────────────────────────────────── */
.card {
    border-radius: var(--csv-radius);
    border: 1px solid var(--csv-line);
    background: var(--csv-surface);
    box-shadow: var(--csv-shadow-sm);
}
.card.shadow-sm { box-shadow: var(--csv-shadow-sm) !important; }
.shadow-lg { box-shadow: var(--csv-shadow-lg) !important; }

.card-header {
    background: var(--csv-surface) !important;
    border-bottom: 1px solid var(--csv-line) !important;
    font-weight: 700;
    color: var(--csv-ink);
    padding: .85rem 1.1rem .85rem 1.25rem;
    position: relative;
}
/* goldener Akzent links am Karten-Header */
.card-header::before {
    content: "";
    position: absolute;
    left: 0; top: .85rem; bottom: .85rem;
    width: 3px;
    border-radius: 0 3px 3px 0;
    background: var(--csv-gold);
}

.card-body { padding: 1.1rem 1.25rem; }

/* Stat-Karten (öffentliche Index-Kacheln, falls genutzt) */
.card-stat {
    border: 1px solid var(--csv-line) !important;
    border-radius: var(--csv-radius);
    text-align: center;
    overflow: hidden;
    position: relative;
    transition: transform .15s, box-shadow .15s;
}
.card-stat::before {
    content: "";
    position: absolute; left: 0; right: 0; top: 0;
    height: 3px;
    background: linear-gradient(90deg, var(--csv-gold), var(--csv-gold-2));
}
.card-stat:hover { transform: translateY(-2px); box-shadow: var(--csv-shadow); }

.stat-label {
    font-size: .72rem;
    color: var(--csv-text-muted);
    text-transform: uppercase;
    letter-spacing: .07em;
    font-weight: 700;
    margin-bottom: .2rem;
}
.stat-value {
    font-size: clamp(1.5rem, 6vw, 2rem);
    font-weight: 800;
    color: var(--csv-ink);
    line-height: 1.05;
    letter-spacing: -.02em;
}

/* ════════════════════════════════════════════════════════════════
   ADMIN-DASHBOARD – farbcodierte KPI-Karten mit Icon-Badges.
   ════════════════════════════════════════════════════════════════ */
.kpi-card {
    position: relative;
    overflow: hidden;
    border: 1px solid var(--csv-line) !important;
    border-radius: var(--csv-radius);
    transition: transform .15s, box-shadow .15s;
}
.kpi-card:hover { transform: translateY(-2px); box-shadow: var(--csv-shadow); }
.kpi-card .card-body { padding: 1.1rem 1.2rem; }
.kpi-card .kpi-label {
    font-size: .7rem; text-transform: uppercase; letter-spacing: .07em;
    font-weight: 800; color: var(--csv-text-muted);
    margin-bottom: .2rem;
}
.kpi-card .kpi-value {
    font-size: 1.65rem; font-weight: 900; color: var(--csv-ink); line-height: 1.05;
    letter-spacing: -.02em;
}
.kpi-card .kpi-sub { font-size: .74rem; color: var(--csv-text-faint); font-weight: 600; margin-top: .15rem; }
.kpi-card .kpi-icon {
    position: absolute; top: 1rem; right: 1.1rem;
    width: 2.6rem; height: 2.6rem; border-radius: .7rem;
    display: flex; align-items: center; justify-content: center;
    font-size: 1.3rem;
    background: var(--csv-surface-2);
    border: 1px solid var(--csv-line);
}
/* linker farbiger Balken je nach KPI-Typ */
.kpi-card::before {
    content: "";
    position: absolute; left: 0; top: 0; bottom: 0; width: 4px;
    background: var(--csv-gold);
}
/* Haupt-KPI Kassenstand: schwarz mit goldenem Text, prominent */
.kpi-card.kpi-primary {
    background: linear-gradient(155deg, var(--csv-ink-2), var(--csv-ink));
    border-color: var(--csv-ink) !important;
}
.kpi-card.kpi-primary::before { background: var(--csv-gold); width: 5px; }
.kpi-card.kpi-primary .kpi-label { color: rgba(255,255,255,.65); }
.kpi-card.kpi-primary .kpi-value { color: var(--csv-gold); font-size: 1.9rem; }
.kpi-card.kpi-primary .kpi-sub { color: rgba(255,255,255,.5); }
.kpi-card.kpi-primary .kpi-icon {
    background: rgba(252,245,20,.14);
    border-color: rgba(252,245,20,.3);
    color: var(--csv-gold);
}
.kpi-card.kpi-danger::before { background: var(--csv-danger); }
.kpi-card.kpi-danger .kpi-icon { background: var(--csv-danger-bg); border-color: rgba(214,69,69,.25); }
.kpi-card.kpi-warning::before { background: var(--csv-warning); }
.kpi-card.kpi-warning .kpi-icon { background: var(--csv-warning-bg); border-color: rgba(224,163,24,.25); }
.kpi-card.kpi-neutral::before { background: var(--csv-text-faint); }

/* Feed (statt Tabelle) für letzte Strafen */
.feed { list-style: none; margin: 0; padding: 0; }
.feed-item {
    display: flex;
    align-items: center;
    gap: .85rem;
    padding: .8rem 1.25rem;
    border-bottom: 1px solid var(--csv-line-soft);
}
.feed-item:last-child { border-bottom: none; }
.feed-item:hover { background: var(--csv-surface-2); }
.feed-avatar {
    flex: none;
    width: 2.3rem; height: 2.3rem; border-radius: .6rem;
    display: flex; align-items: center; justify-content: center;
    background: var(--csv-ink);
    color: var(--csv-gold);
    font-weight: 800;
    font-size: .82rem;
    text-transform: uppercase;
}
.feed-main { min-width: 0; flex: 1; }
.feed-name { font-weight: 700; color: var(--csv-ink); line-height: 1.2; }
.feed-desc {
    font-size: .82rem; color: var(--csv-text-muted);
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.feed-meta { text-align: right; flex: none; }
.feed-amount { font-weight: 800; color: var(--csv-ink); font-variant-numeric: tabular-nums; }
.feed-date { font-size: .72rem; color: var(--csv-text-faint); }

/* Geburtstags-Liste, elegant */
.bday-list { list-style: none; margin: 0; padding: 0; }
.bday-item {
    display: flex; align-items: center; gap: .75rem;
    padding: .7rem 1.25rem;
    border-bottom: 1px solid var(--csv-line-soft);
}
.bday-item:last-child { border-bottom: none; }
.bday-emoji { font-size: 1.15rem; flex: none; }
.bday-name { font-weight: 600; color: var(--csv-ink); flex: 1; }
.bday-when {
    font-size: .72rem; font-weight: 700;
    color: var(--csv-text-muted);
    background: var(--csv-surface-2);
    border: 1px solid var(--csv-line);
    padding: .15rem .55rem;
    border-radius: 2rem;
    white-space: nowrap;
}
.bday-when.today { color: var(--csv-ink); background: var(--csv-gold); border-color: var(--csv-gold); }
.bday-empty { padding: 1rem 1.25rem; color: var(--csv-text-faint); }

/* ── Tabellen ────────────────────────────────────────────────── */
.table {
    --bs-table-color: var(--csv-text);
    margin-bottom: 0;
}
/* dunkle Header mit goldener Unterlinie — kein graues Bootstrap-Light mehr */
.table thead th,
.table > thead.table-light th {
    background-color: var(--csv-ink);
    color: rgba(255,255,255,.82);
    font-weight: 700;
    font-size: .72rem;
    text-transform: uppercase;
    letter-spacing: .06em;
    border-bottom: 2px solid var(--csv-gold);
    padding-top: .7rem;
    padding-bottom: .7rem;
    white-space: nowrap;
}
.table td { padding-top: .65rem; padding-bottom: .65rem; vertical-align: middle; }
.table-sm td, .table-sm th { vertical-align: middle; }
.table tbody tr { border-color: var(--csv-line-soft); }
.table-hover > tbody > tr:hover > * { background-color: var(--csv-surface-2); }
.table tfoot th, .table tfoot td {
    background: var(--csv-surface-2);
    border-top: 2px solid var(--csv-line);
    font-weight: 700;
}

/* Beträge in Tabellen tabellarisch ausrichten */
.table .text-end { font-variant-numeric: tabular-nums; }

/* Rang-Kreis im Scoreboard */
.rank-pill {
    display: inline-flex; align-items: center; justify-content: center;
    width: 1.7rem; height: 1.7rem; border-radius: 50%;
    font-weight: 800; font-size: .8rem;
    background: var(--csv-surface-2); color: var(--csv-text-muted);
    border: 1px solid var(--csv-line);
}
.rank-pill.rank-1 { background: var(--csv-gold); color: var(--csv-ink); border-color: var(--csv-gold); }
.rank-pill.rank-2 { background: #e3e3e0; color: var(--csv-ink); border-color: #d6d6d2; }
.rank-pill.rank-3 { background: #f0dcc0; color: #7a5905; border-color: #e7cda6; }

/* ── Badges ──────────────────────────────────────────────────── */
.badge { font-weight: 700; letter-spacing: .01em; }

.bg-success { background-color: var(--csv-success) !important; }
.bg-danger  { background-color: var(--csv-danger)  !important; }
.bg-warning { background-color: var(--csv-warning) !important; }
.bg-info    { background-color: var(--csv-info)    !important; }
.bg-dark    { background-color: var(--csv-ink)     !important; }
.bg-secondary { background-color: #8a9099 !important; }
.text-success { color: var(--csv-success) !important; }
.text-danger  { color: var(--csv-danger)  !important; }
.text-warning { color: var(--csv-warning) !important; }

/* Badge Trikotnummer */
.badge-jersey {
    display: inline-block;
    background-color: var(--csv-ink);
    color: var(--csv-gold);
    font-weight: 800;
    font-size: .9rem;
    padding: .3em .6em;
    border-radius: .4rem;
    line-height: 1.1;
}

/* Spieler-Balance Badges */
.balance-badge {
    font-size: 1rem;
    padding: .5em .9em;
    border-radius: .55rem;
    font-weight: 800;
}

/* ── Listengruppen ───────────────────────────────────────────── */
.list-group-item { border-color: var(--csv-line-soft); }
.list-group-item-action:hover { background-color: var(--csv-surface-2); }
.list-group-item.active {
    background-color: var(--csv-gold);
    border-color: var(--csv-gold);
    color: var(--csv-ink);
}

/* Suchergebnis-Items fingerfreundlich */
.list-group-item.search-hit {
    padding: .85rem 1rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: .75rem;
}
.list-group-item.search-hit .hit-name { font-weight: 700; color: var(--csv-ink); }
.list-group-item.search-hit:hover .hit-name { color: var(--csv-gold-deep); }

/* ── Formulare ───────────────────────────────────────────────── */
.form-label {
    font-weight: 700;
    color: var(--csv-text-muted);
    margin-bottom: .35rem;
    font-size: .74rem;
    text-transform: uppercase;
    letter-spacing: .05em;
}
.form-control, .form-select {
    border-color: var(--csv-line);
    border-radius: var(--csv-radius-sm);
    color: var(--csv-text);
}
.form-control:focus, .form-select:focus {
    border-color: var(--csv-gold);
    box-shadow: 0 0 0 .2rem rgba(252,245,20,.22);
}
.form-check-input:checked {
    background-color: var(--csv-gold);
    border-color: var(--csv-gold);
}
.form-check-input:focus { box-shadow: 0 0 0 .2rem rgba(252,245,20,.22); }
/* Touch: größere Checkboxen auf Spielerauswahl-Seiten */
.player-pick .form-check { padding: .55rem .55rem .55rem 2rem; }
.player-pick .form-check-input { width: 1.2em; height: 1.2em; margin-left: -1.6rem; }
.player-pick .form-check-label { cursor: pointer; }
.player-pick .form-check:hover { background: var(--csv-surface-2); border-radius: .5rem; }

/* ── Alerts ──────────────────────────────────────────────────── */
.alert {
    border: 1px solid transparent;
    border-radius: var(--csv-radius-sm);
    border-left-width: 4px;
}
.alert-success { background: var(--csv-success-bg); border-color: var(--csv-success); color: #1c633a; }
.alert-danger  { background: var(--csv-danger-bg);  border-color: var(--csv-danger);  color: #8f2727; }
.alert-warning { background: var(--csv-warning-bg); border-color: var(--csv-warning); color: #7a5905; }
.alert-info    { background: var(--csv-info-bg);    border-color: var(--csv-info);    color: #234e74; }

/* ── Strafenkatalog ──────────────────────────────────────────── */
.catalog-category-header {
    margin-bottom: -1px;
}
.catalog-category {
    background: var(--csv-ink);
    color: var(--csv-gold);
    font-weight: 800;
    font-size: .76rem;
    text-transform: uppercase;
    letter-spacing: .08em;
    padding: .45rem 1rem;
    border-radius: .6rem .6rem 0 0;
    display: inline-block;
    margin-bottom: 0;
}

/* saubere Listen-Optik für die Katalog-Einträge (statt Tabelle) */
.catalog-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    padding: .75rem 1.2rem;
    border-bottom: 1px solid var(--csv-line-soft);
}
.catalog-row:last-child { border-bottom: none; }
.catalog-row:hover { background: var(--csv-surface-2); }
.catalog-name {
    color: var(--csv-ink);
    font-weight: 600;
    line-height: 1.25;
}
.catalog-amt {
    flex: none;
    text-align: right;
    font-weight: 800;
    color: var(--csv-ink);
    white-space: nowrap;
    font-variant-numeric: tabular-nums;
    line-height: 1.15;
}
.catalog-unit {
    display: block;
    font-weight: 600;
    font-size: .74rem;
    letter-spacing: .01em;
    color: var(--csv-text-muted);
}

/* Gruppenkopf (aufklappbare Monatsblöcke) */
.group-head {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: .65rem 1rem;
    background: var(--csv-surface-2);
    cursor: pointer;
    user-select: none;
}
.group-head:hover { background: var(--csv-line-soft); }
.group-head .group-sum { color: var(--csv-gold-deep); font-weight: 800; }
.group-total {
    display: flex; justify-content: flex-end;
    padding: .65rem 1rem;
    background: var(--csv-surface-2);
    border-top: 1px solid var(--csv-line);
    font-weight: 800; color: var(--csv-ink);
}

/* ── Accordion (Monatsübersicht) ─────────────────────────────── */
.accordion-button {
    font-weight: 600;
    color: var(--csv-ink);
}
.accordion-button:not(.collapsed) {
    background-color: var(--csv-surface-2);
    color: var(--csv-ink);
    box-shadow: inset 0 -1px 0 var(--csv-line);
}
.accordion-button:focus { box-shadow: 0 0 0 .2rem rgba(252,245,20,.22); }
.accordion-button:not(.collapsed)::after {
    filter: sepia(1) saturate(4) hue-rotate(2deg);
}

/* ════════════════════════════════════════════════════════════════
   ADMIN-SIDEBAR – dunkel (#1a1d21) mit goldenen aktiven Links,
   goldener Balken links am aktiven Eintrag, dezente Trennlinien.
   ════════════════════════════════════════════════════════════════ */
aside.admin-shell {
    background: var(--csv-ink);
    border-right: 1px solid #000;
}
.admin-sidebar { width: 248px; }
.admin-sidebar .sidebar-section {
    font-size: .66rem;
    text-transform: uppercase;
    letter-spacing: .12em;
    font-weight: 800;
    color: rgba(255,255,255,.4);
    padding: 1rem .85rem .4rem;
}
.admin-sidebar .sidebar-section:first-child { padding-top: .35rem; }
.admin-sidebar .nav-link {
    color: rgba(255,255,255,.78);
    font-weight: 600;
    font-size: .92rem;
    padding: .6rem .85rem;
    border-radius: .55rem;
    margin-bottom: .12rem;
    display: flex;
    align-items: center;
    gap: .65rem;
    position: relative;
    transition: background .12s, color .12s;
}
.admin-sidebar .nav-link .nav-ico {
    width: 1.25rem; text-align: center; opacity: .65; flex: none;
}
.admin-sidebar .nav-link:hover {
    background: rgba(255,255,255,.07);
    color: #fff;
}
.admin-sidebar .nav-link:hover .nav-ico { opacity: 1; }
.admin-sidebar .nav-link.active {
    background: rgba(252,245,20,.13);
    color: var(--csv-gold);
    font-weight: 800;
}
/* goldener Balken links am aktiven Eintrag */
.admin-sidebar .nav-link.active::before {
    content: "";
    position: absolute; left: -.1rem; top: .45rem; bottom: .45rem;
    width: 3px; border-radius: 3px;
    background: var(--csv-gold);
}
.admin-sidebar .nav-link.active .nav-ico { opacity: 1; color: var(--csv-gold); }
/* Sub-Items */
.admin-sidebar .nav-sub {
    margin: .15rem 0 .35rem 1rem;
    padding-left: .7rem;
    border-left: 1px solid rgba(255,255,255,.12);
}
.admin-sidebar .nav-sub .nav-link {
    font-size: .86rem;
    padding: .42rem .65rem;
    color: rgba(255,255,255,.6);
}
.admin-sidebar .nav-sub .nav-link.active {
    background: rgba(252,245,20,.13);
    color: var(--csv-gold);
}
.admin-sidebar .nav-sub .nav-link.active::before { display: none; }
.admin-sidebar .nav-sub .nav-link:hover { color: #fff; }
/* Toggle für Strafen-Gruppe */
.admin-sidebar .nav-toggle::after {
    content: "▾";
    margin-left: auto;
    font-size: .7rem;
    opacity: .6;
    transition: transform .15s;
}
.admin-sidebar .nav-toggle.collapsed::after { transform: rotate(-90deg); }
.admin-sidebar .sidebar-divider {
    height: 1px; background: rgba(255,255,255,.1);
    margin: .7rem .35rem;
}

/* Offcanvas (mobile Sidebar) ebenfalls dunkel */
.offcanvas .admin-sidebar { width: auto; }
.offcanvas-body.admin-sidebar, .offcanvas.offcanvas-start:has(.admin-sidebar) {
    background: var(--csv-ink);
}
.offcanvas-header {
    background: var(--csv-ink-2);
    border-bottom: 2px solid var(--csv-gold);
}
.offcanvas-title { color: var(--csv-gold); font-weight: 800; }
.offcanvas .btn-close { filter: invert(1) grayscale(1) brightness(1.6); }

/* ── Footer ──────────────────────────────────────────────────── */
footer.csv-footer {
    background: var(--csv-ink);
    border-top: 3px solid var(--csv-gold);
    color: rgba(255,255,255,.5);
    font-size: .82rem;
    padding: 1.1rem 0;
}
footer.csv-footer .footer-club {
    color: var(--csv-gold);
    font-weight: 700;
}
footer.csv-footer a:hover { color: var(--csv-gold-2); }

/* ── Login-Seite ─────────────────────────────────────────────── */
.login-shell {
    min-height: 100vh;
    display: flex;
    align-items: center;
    position: relative;
    overflow: hidden;
    background:
        radial-gradient(1100px 460px at 50% -8%, rgba(252,245,20,.16), transparent 62%),
        linear-gradient(170deg, var(--csv-ink-2) 0%, var(--csv-ink) 55%, var(--csv-ink-3) 100%);
}
.login-shell::before {
    content: "";
    position: absolute; inset: 0;
    background-image: repeating-linear-gradient(
        115deg, rgba(255,255,255,.022) 0 2px, transparent 2px 22px);
    pointer-events: none;
}
.login-shell > .container { position: relative; z-index: 1; }
.login-crest {
    filter: drop-shadow(0 6px 16px rgba(0,0,0,.45));
}
.login-kicker {
    color: rgba(255,255,255,.5);
    font-size: .82rem;
    margin-top: .25rem;
}
.login-title {
    color: #fff;
    font-size: 1.25rem;
    font-weight: 900;
    letter-spacing: -.01em;
    margin-bottom: 0;
}
.login-title .accent { color: var(--csv-gold); }
.login-badge {
    display: inline-block;
    color: var(--csv-gold);
    font-size: .68rem; font-weight: 800;
    text-transform: uppercase; letter-spacing: .16em;
    border: 1px solid rgba(252,245,20,.4);
    border-radius: 2rem;
    padding: .2rem .7rem;
    margin-bottom: .9rem;
}
.login-card {
    border: none;
    border-top: 4px solid var(--csv-gold);
    border-radius: var(--csv-radius);
}
.login-back { color: rgba(255,255,255,.55); font-size: .82rem; }
.login-back:hover { color: var(--csv-gold-2); }

/* ── Fehlerseiten ────────────────────────────────────────────── */
.error-page { text-align: center; padding: 3.5rem 1rem; }
.error-code {
    font-size: clamp(4rem, 18vw, 7rem);
    font-weight: 900;
    line-height: 1;
    letter-spacing: -.03em;
    color: var(--csv-ink);
    position: relative;
    display: inline-block;
}
.error-code::after {
    content: "";
    display: block;
    width: 3rem; height: 4px;
    background: var(--csv-gold);
    border-radius: 4px;
    margin: .75rem auto 0;
}
.error-lead { color: var(--csv-text-muted); font-size: 1.1rem; margin-top: 1.25rem; }

/* Spieler-Kopfkarte (mini-hero, schwarz/gold) */
.player-hero {
    background: linear-gradient(150deg, var(--csv-ink-2), var(--csv-ink));
    border: none;
    border-radius: var(--csv-radius-lg);
    overflow: hidden;
    position: relative;
    box-shadow: var(--csv-shadow);
}
/* goldene Akzentkante oben */
.player-hero::before {
    content: "";
    position: absolute; left: 0; right: 0; top: 0; height: 3px;
    z-index: 2;
    background: linear-gradient(90deg, var(--csv-gold), var(--csv-gold-2), transparent);
}
/* dezenter Goldschimmer rechts oben für Tiefe */
.player-hero::after {
    content: "";
    position: absolute; inset: 0;
    pointer-events: none;
    background: radial-gradient(420px 200px at 100% -30%, rgba(252,245,20,.16), transparent 70%);
}
.player-hero .card-body { padding: 1.4rem 1.5rem; position: relative; z-index: 1; }
.player-hero-num {
    display: inline-flex; align-items: center; justify-content: center;
    width: 3.8rem; height: 3.8rem;
    background: var(--csv-gold);
    color: var(--csv-ink);
    font-weight: 900;
    font-size: 1.75rem;
    border-radius: .9rem;
    line-height: 1;
    box-shadow: 0 6px 18px rgba(252,245,20,.32);
    font-variant-numeric: tabular-nums;
}
.player-hero-name { color: #fff; font-size: clamp(1.4rem, 5vw, 1.9rem); line-height: 1.1; }
.player-hero-nick { color: var(--csv-gold); font-weight: 600; font-size: .92rem; }
.player-hero-ballabel {
    font-size: .68rem; text-transform: uppercase; letter-spacing: .08em;
    font-weight: 800; color: rgba(255,255,255,.55); margin-bottom: .3rem;
}

/* Schnellzugriff-Kacheln (Startseite) */
.nav-tile { transition: transform .15s, box-shadow .15s, border-color .15s; }
.nav-tile:hover {
    transform: translateY(-2px);
    box-shadow: var(--csv-shadow);
    border-color: var(--csv-gold);
}
.nav-tile:hover .feed-avatar { background: var(--csv-gold); color: var(--csv-ink); }

/* ── Utility ─────────────────────────────────────────────────── */
.content-layer { position: relative; }
.text-gold { color: var(--csv-gold-deep) !important; }
.fw-black { font-weight: 900 !important; }
.toggle-icon { display: inline-block; width: 1em; }

/* ── Navbar Kassenstand ──────────────────────────────────────── */
.navbar-kassenstand {
    font-size: .82rem; color: rgba(255,255,255,.8);
    border: 1px solid rgba(255,255,255,.2);
    border-radius: var(--csv-radius-sm);
    padding: .2rem .6rem;
    gap: .15rem;
}

/* ── Print-Styles (für PDF über Browser-Druck) ───────────────── */
@media print {
    .admin-sidebar,
    .navbar-csv,
    .offcanvas,
    .d-print-none,
    .btn,
    .alert { display: none !important; }

    body { background: #fff !important; color: #000 !important; }
    .card { border: 1px solid #ccc !important; box-shadow: none !important; page-break-inside: avoid; }
    .card-header { background: #f5f5f5 !important; color: #000 !important; }
    .badge.bg-dark { background: #333 !important; }
    main { padding: 0 !important; }
    .d-flex.flex-grow-1 { display: block !important; }
    table { font-size: .82rem; }
    a { color: #000 !important; text-decoration: none !important; }
}
