/* ================================================================
   CSS-Variablen — Light Mode (Standard)
================================================================ */
:root {
    --bg:        #f5f5f5;
    --surface:   #ffffff;
    --surface2:  #f9f9f9;
    --border:    #ebebeb;
    --border2:   #e0e0e0;
    --accent:    #16a34a;
    --accent-bg: rgba(22, 163, 74, 0.08);
    --accent-text: #16a34a;
    --text:      #0d0d0d;
    --text-sec:  #888888;
    --text-dim:  #bbbbbb;
    --danger:    #dc2626;
    --danger-dim:#fee2e2;
    --warn:      #d97706;
    --warn-bg:   #fef3c7;
    --sidebar-w: 240px;
    --radius:    10px;
    --radius-sm: 8px;
    --shadow:    0 1px 4px rgba(0,0,0,0.06);
    --shadow-md: 0 4px 16px rgba(0,0,0,0.08);
}

/* ================================================================
   Dark Mode — Premium Dark (Standard für neue User)
================================================================ */
body.dark {
    --bg:        #080808;
    --surface:   #101010;
    --surface2:  #181818;
    --border:    rgba(255,255,255,0.07);
    --border2:   rgba(255,255,255,0.12);
    --accent:    #16a34a;
    --accent-bg: rgba(74, 222, 128, 0.09);
    --accent-text: #4ade80;
    --text:      #f0f0f0;
    --text-sec:  rgba(255,255,255,0.42);
    --text-muted: rgba(255,255,255,0.22);
    --text-dim:  rgba(255,255,255,0.1);
    --danger:    #f87171;
    --danger-dim:rgba(248,113,113,0.12);
    --warn:      #fbbf24;
    --warn-bg:   rgba(251,191,36,0.1);
    --shadow:    0 1px 6px rgba(0,0,0,0.5);
    --shadow-md: 0 4px 24px rgba(0,0,0,0.6);
    --shadow-lg: 0 8px 40px rgba(0,0,0,0.7);
    --gold:      #f5c518;
}

/* ================================================================
   Reset & Base
================================================================ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html, body { height: 100%; }

body {
    font-family: 'Manrope', 'Segoe UI', Arial, sans-serif;
    background: var(--bg);
    color: var(--text);
    font-size: 13px;
    line-height: 1.5;
    overflow-x: hidden;
    transition: background 0.2s, color 0.2s;
}

a { color: var(--accent-text); text-decoration: none; }
a:hover { text-decoration: underline; }
code { font-family: monospace; background: var(--surface2); padding: 1px 5px; border-radius: 3px; font-size: 12px; border: 1px solid var(--border); }

/* ================================================================
   AUTH-SCREENS — "Stadium Night"
================================================================ */
#authScreen {
    min-height: 100vh;
    display: grid;
    grid-template-columns: 1fr 1fr;
    background: #070707;
}

/* ── Linke Panel: Atmosphäre ── */
.auth-panel-left {
    position: relative;
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 56px 48px;
    background: #080808;
}

/* Spielfeld-Linien als SVG-Background */
.auth-pitch-lines {
    position: absolute;
    inset: 0;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 500 700' fill='none' stroke='white'%3E%3Crect x='30' y='30' width='440' height='640' stroke-width='2' opacity='0.1'/%3E%3Cline x1='30' y1='350' x2='470' y2='350' stroke-width='1.5' opacity='0.08'/%3E%3Ccircle cx='250' cy='350' r='70' stroke-width='1.5' opacity='0.08'/%3E%3Ccircle cx='250' cy='350' r='3' fill='white' opacity='0.1' stroke='none'/%3E%3Crect x='120' y='30' width='260' height='90' stroke-width='1.5' opacity='0.06'/%3E%3Crect x='120' y='580' width='260' height='90' stroke-width='1.5' opacity='0.06'/%3E%3Crect x='180' y='30' width='140' height='44' stroke-width='1' opacity='0.05'/%3E%3Crect x='180' y='626' width='140' height='44' stroke-width='1' opacity='0.05'/%3E%3Ccircle cx='250' cy='100' r='3' fill='white' opacity='0.08' stroke='none'/%3E%3Ccircle cx='250' cy='600' r='3' fill='white' opacity='0.08' stroke='none'/%3E%3C/svg%3E");
    background-size: cover;
    background-position: center;
    opacity: 0.9;
}

/* Grüner Glow von unten */
.auth-glow-bottom {
    position: absolute;
    bottom: -80px;
    left: 50%;
    transform: translateX(-50%);
    width: 400px;
    height: 300px;
    background: radial-gradient(ellipse, rgba(74,222,128,0.18) 0%, transparent 70%);
    pointer-events: none;
}

/* Vertikale Trennlinie rechts */
.auth-panel-divider {
    position: absolute;
    right: 0; top: 8%; bottom: 8%;
    width: 1px;
    background: linear-gradient(to bottom, transparent, rgba(255,255,255,0.07) 40%, rgba(255,255,255,0.07) 60%, transparent);
}

/* Brand-Block */
.auth-brand {
    position: relative;
    z-index: 1;
    text-align: center;
    animation: authBrandIn 0.9s cubic-bezier(0.22,1,0.36,1) both;
}

@keyframes authBrandIn {
    from { opacity: 0; transform: translateY(28px); }
    to   { opacity: 1; transform: translateY(0); }
}

.auth-crest-wrap {
    position: relative;
    display: inline-block;
    margin-bottom: 28px;
}

/* Puls-Ring hinter dem Wappen */
.auth-crest-glow {
    position: absolute;
    inset: -20px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(74,222,128,0.45) 0%, transparent 70%);
    animation: crestPulse 3s ease-in-out infinite;
}

@keyframes crestPulse {
    0%, 100% { transform: scale(0.85); opacity: 0.5; }
    50%       { transform: scale(1.15); opacity: 1; }
}

.auth-crest {
    width: 150px;
    height: auto;
    display: block;
    position: relative;
    z-index: 1;
    filter: invert(1);
}

.auth-club-name {
    font-family: 'Bebas Neue', 'Arial Black', sans-serif;
    font-size: clamp(44px, 4.5vw, 68px);
    font-weight: normal;
    line-height: 0.92;
    letter-spacing: 0.05em;
    color: #ffffff;
    margin-bottom: 14px;
}

.auth-club-meta {
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.35em;
    text-transform: uppercase;
    color: rgba(255,255,255,0.28);
    margin-bottom: 8px;
}

.auth-club-tagline {
    display: inline-block;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.25em;
    text-transform: uppercase;
    color: rgba(74,222,128,0.75);
    padding: 4px 12px;
    border: 1px solid rgba(74,222,128,0.25);
    border-radius: 2px;
}

/* ── Rechte Panel: Formular ── */
.auth-panel-right {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 56px 48px;
    background: #0a0a0a;
}

/* Einladungs-Banner auf Registrierungsseite */
.invite-banner {
    display: flex;
    align-items: center;
    gap: 12px;
    background: color-mix(in srgb, var(--accent) 12%, transparent);
    border: 1px solid color-mix(in srgb, var(--accent) 40%, transparent);
    border-radius: 8px;
    padding: 12px 14px;
    margin-bottom: 20px;
}
.invite-banner-icon { font-size: 22px; flex-shrink: 0; }
.invite-banner-text { font-size: 13px; line-height: 1.4; }

.auth-card {
    width: 100%;
    max-width: 360px;
    background: transparent;
    border: none;
    border-radius: 0;
    padding: 0;
    text-align: center;
    box-shadow: none;
    animation: authCardIn 0.7s cubic-bezier(0.22,1,0.36,1) 0.15s both;
}

@keyframes authCardIn {
    from { opacity: 0; transform: translateX(20px); }
    to   { opacity: 1; transform: translateX(0); }
}

/* Hidden original auth-logo */
.auth-logo { display: none !important; }

.auth-title {
    font-family: 'Bebas Neue', 'Arial Black', sans-serif;
    font-size: 38px;
    font-weight: normal;
    letter-spacing: 0.07em;
    color: #f2f2f2;
    line-height: 1;
    margin-bottom: 6px;
}

.auth-sub {
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: rgba(255,255,255,0.28);
    margin-bottom: 40px;
}

/* Auth form fields */
.auth-form { text-align: left; }

.auth-form .field {
    margin-bottom: 0;
    border-bottom: 1px solid rgba(255,255,255,0.09);
    padding: 16px 0 12px;
    transition: border-color 0.2s;
}
.auth-form .field:first-child {
    border-top: 1px solid rgba(255,255,255,0.09);
}
.auth-form .field:focus-within {
    border-bottom-color: rgba(74,222,128,0.6);
}

.auth-form .field label {
    display: block;
    font-size: 10px;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: rgba(255,255,255,0.32);
    margin-bottom: 7px;
    font-weight: 700;
}

.auth-form .field input,
.auth-form .field select {
    width: 100%;
    background: transparent;
    border: none;
    outline: none;
    color: #f0f0f0;
    font-size: 15px;
    font-family: 'Manrope', sans-serif;
    font-weight: 500;
    padding: 0;
    caret-color: #4ade80;
}
.auth-form .field input::placeholder { color: rgba(255,255,255,0.15); }
.auth-form .field select option { background: #1a1a1a; }

.auth-form .form-error {
    margin-top: 16px;
    font-size: 12px;
    color: #f87171;
    background: rgba(248,113,113,0.1);
    border: 1px solid rgba(248,113,113,0.2);
    border-radius: 4px;
    padding: 8px 12px;
    text-align: left;
}

.auth-form .form-success {
    margin-top: 16px;
    font-size: 12px;
    color: #4ade80;
    background: rgba(74,222,128,0.08);
    border: 1px solid rgba(74,222,128,0.2);
    border-radius: 4px;
    padding: 8px 12px;
    text-align: left;
}

.auth-form .btn-primary {
    margin-top: 32px;
    background: #4ade80;
    color: #050505;
    border: none;
    font-family: 'Manrope', sans-serif;
    font-weight: 800;
    font-size: 11px;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    height: 50px;
    border-radius: 3px;
    cursor: pointer;
    width: 100%;
    transition: background 0.15s, transform 0.1s;
}
.auth-form .btn-primary:hover  { background: #86efac; transform: translateY(-1px); }
.auth-form .btn-primary:active { transform: translateY(0); }

.auth-link {
    margin-top: 22px;
    font-size: 12px;
    color: rgba(255,255,255,0.28);
    letter-spacing: 0.01em;
}
.auth-link a {
    color: #4ade80;
    font-weight: 700;
    text-decoration: none;
}
.auth-link a:hover { text-decoration: underline; }

/* ── Mobile: Stacked ── */
@media (max-width: 700px) {
    #authScreen {
        grid-template-columns: 1fr;
        grid-template-rows: auto 1fr;
    }
    .auth-panel-left {
        padding: 40px 24px 28px;
    }
    .auth-crest {
        width: 80px;
        margin-bottom: 16px;
    }
    .auth-club-name { font-size: 42px; }
    .auth-panel-divider { display: none; }
    .auth-glow-bottom { display: none; }
    .auth-panel-right {
        padding: 36px 24px 48px;
        align-items: flex-start;
    }
    .auth-card { animation-delay: 0s; }
}

/* ================================================================
   APP-SHELL
================================================================ */
#appShell {
    display: flex;
    height: 100vh;
    overflow: hidden;
}

/* ================================================================
   SIDEBAR
================================================================ */
#sidebar {
    width: var(--sidebar-w);
    flex-shrink: 0;
    background: var(--surface);
    border-right: 1px solid var(--border);
    display: flex;
    flex-direction: column;
    height: 100vh;
    overflow: hidden;
}
body.dark #sidebar {
    background: #0c0c0c;
    border-right-color: rgba(255,255,255,0.06);
}

.sidebar-top {
    padding: 20px 18px;
    border-bottom: 1px solid var(--border);
}

.sidebar-logo {
    display: flex;
    align-items: center;
    gap: 10px;
}

.logo-mark {
    width: 36px; height: 36px;
    background: var(--accent);
    border-radius: 10px;
    display: flex; align-items: center; justify-content: center;
    font-size: 18px;
    flex-shrink: 0;
}

.wsv-logo {
    width: 38px;
    height: 44px;
    object-fit: contain;
    flex-shrink: 0;
    filter: brightness(0) invert(1); /* weiß auf dunklem Hintergrund */
}

.wsv-logo-mobile {
    width: 26px;
    height: 30px;
    object-fit: contain;
    filter: brightness(0) invert(1);
}

.logo-text {
    font-size: 15px;
    font-weight: 800;
    letter-spacing: -0.02em;
    color: var(--text);
}

.logo-sub {
    font-size: 10px;
    color: var(--text-muted);
    letter-spacing: 0.02em;
}

.sidebar-nav {
    display: flex;
    flex-direction: column;
    gap: 2px;
    padding: 12px 10px;
    flex: 1;
}

.nav-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 9px 10px 9px 7px;
    border-left: 3px solid transparent;
    border-radius: var(--radius-sm);
    color: var(--text-sec);
    font-size: 13px;
    font-weight: 600;
    transition: background 0.15s, color 0.15s, border-color 0.15s;
    text-decoration: none;
    cursor: pointer;
}

.nav-item:hover { background: var(--surface2); color: var(--text); text-decoration: none; }
.nav-item.active {
    background: var(--accent-bg);
    color: var(--accent-text);
    border-left-color: var(--accent);
}
.nav-item .nav-icon { font-size: 15px; width: 18px; text-align: center; }

.sidebar-bottom {
    padding: 12px 16px 10px;
    border-top: 1px solid var(--border);
    display: flex;
    flex-direction: column;
    gap: 6px;
}
.sidebar-bottom > .user-chip { flex: none; }
.sidebar-actions {
    display: flex;
    gap: 4px;
}

.user-chip { display: flex; align-items: center; gap: 10px; flex: 1; min-width: 0; }
.user-avatar {
    width: 34px; height: 34px;
    background: var(--accent);
    color: #fff;
    border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    font-weight: 800;
    font-size: 13px;
    flex-shrink: 0;
}

.user-info { min-width: 0; }
.user-name { font-size: 13px; font-weight: 700; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.user-role { font-size: 11px; color: var(--text-sec); font-weight: 500; }

.btn-help {
    background: none;
    border: 1px solid var(--accent);
    color: var(--accent-text);
    width: 30px; height: 30px;
    border-radius: 50%;
    cursor: pointer; font-size: 14px; font-weight: 800;
    display: flex; align-items: center; justify-content: center;
    flex-shrink: 0;
    transition: background 0.15s, box-shadow 0.15s;
}
.btn-help:hover { background: var(--accent-bg); box-shadow: 0 0 8px rgba(74,222,128,0.3); }

.btn-logout {
    background: none;
    border: 1px solid var(--border2);
    color: var(--text-sec);
    width: 30px; height: 30px;
    border-radius: var(--radius-sm);
    cursor: pointer; font-size: 14px;
    display: flex; align-items: center; justify-content: center;
    flex-shrink: 0;
    transition: border-color 0.15s, color 0.15s;
}
.btn-logout:hover { border-color: var(--danger); color: var(--danger); }

.btn-profile {
    background: none;
    border: 1px solid var(--border2);
    color: var(--text-sec);
    width: 30px; height: 30px;
    border-radius: var(--radius-sm);
    cursor: pointer; font-size: 14px;
    display: flex; align-items: center; justify-content: center;
    flex-shrink: 0;
    transition: border-color 0.15s, color 0.15s;
}
.btn-profile:hover { border-color: var(--accent); color: var(--accent-text); }

.btn-darkmode {
    background: none;
    border: 1px solid var(--border2);
    color: var(--text-sec);
    width: 30px; height: 30px;
    border-radius: var(--radius-sm);
    cursor: pointer; font-size: 14px;
    display: flex; align-items: center; justify-content: center;
    flex-shrink: 0;
    transition: border-color 0.15s, color 0.15s;
}
.btn-darkmode:hover { border-color: var(--accent); color: var(--accent-text); }

.btn-theme {
    background: none;
    border: 1px solid var(--border2);
    color: var(--text-sec);
    width: 30px; height: 30px;
    border-radius: var(--radius-sm);
    cursor: pointer; font-size: 14px;
    display: flex; align-items: center; justify-content: center;
    flex-shrink: 0;
    transition: border-color 0.15s, color 0.15s;
}
.btn-theme:hover { border-color: var(--accent); color: var(--accent-text); }

/* Theme-Switcher Modal */
.theme-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
    gap: 12px;
    margin-top: 8px;
}

.theme-card {
    cursor: pointer;
    border-radius: var(--radius);
    overflow: hidden;
    border: 2px solid var(--border);
    transition: border-color 0.15s, transform 0.12s;
}
.theme-card:hover { border-color: var(--accent); transform: translateY(-2px); }
.theme-card-active { border-color: var(--accent) !important; }

.theme-preview {
    height: 80px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 6px;
    padding: 10px;
    position: relative;
}

.tp-pitch {
    width: 80%;
    height: 42px;
    border-radius: 4px;
    display: flex;
    align-items: center;
    justify-content: space-evenly;
    padding: 0 8px;
}

.tp-dot {
    width: 10px; height: 10px;
    border-radius: 50%;
    opacity: 0.9;
}

.tp-score {
    font-family: 'Bebas Neue', sans-serif;
    font-size: 12px;
    position: absolute;
    top: 5px; right: 8px;
}

.theme-card-name {
    padding: 6px 8px 2px;
    font-size: 12px;
    font-weight: 700;
    color: var(--text);
    background: var(--surface);
}

.theme-card-desc {
    padding: 0 8px 8px;
    font-size: 10px;
    color: var(--text-sec);
    line-height: 1.4;
    background: var(--surface);
}

/* Wide Modal für Theme-Switcher */
.modal-box.modal-wide { max-width: 640px; }

/* Settings Modal */
.settings-section-title {
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--text3);
    margin-bottom: 10px;
}
.settings-toggle-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    font-size: 14px;
    color: var(--text1);
    cursor: pointer;
    padding: 6px 0;
}
.settings-toggle-row input[type="checkbox"] {
    width: 18px;
    height: 18px;
    accent-color: var(--accent);
    cursor: pointer;
    flex-shrink: 0;
}

/* ================================================================
   MAIN CONTENT
================================================================ */
#mainContent {
    flex: 1;
    overflow-y: auto;
    background: var(--bg);
    display: flex;
    flex-direction: column;
}

/* Topbar */
.topbar {
    background: var(--surface);
    border-bottom: 1px solid var(--border);
    padding: 14px 28px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-shrink: 0;
    position: sticky;
    top: 0;
    z-index: 10;
}

.breadcrumb {
    font-size: 12px;
    color: var(--text-sec);
    font-weight: 500;
    display: flex;
    align-items: center;
    gap: 6px;
}
.breadcrumb strong { color: var(--text); font-weight: 700; }
.breadcrumb-sep { color: var(--text-dim); }

.topbar-actions { display: flex; gap: 8px; align-items: center; }

.page {
    padding: 28px;
    max-width: 1000px;
    width: 100%;
    margin: 0 auto;
    animation: fadeIn 0.2s ease;
    flex: 1;
}

@keyframes fadeIn { from { opacity: 0; transform: translateY(4px); } to { opacity: 1; transform: none; } }

/* ================================================================
   PAGE ELEMENTS
================================================================ */
.page-eyebrow {
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--accent-text);
    margin-bottom: 4px;
}

.page-title {
    font-size: 24px;
    font-weight: 800;
    letter-spacing: -0.03em;
    line-height: 1.1;
    color: var(--text);
}

.page-meta { font-size: 12px; color: var(--text-sec); margin-top: 4px; font-weight: 500; }

.page-header {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    margin-bottom: 24px;
    gap: 16px;
    flex-wrap: wrap;
}

.page-back {
    font-size: 12px;
    color: var(--text-sec);
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 0;
    font-weight: 600;
    transition: color 0.15s;
}
.page-back:hover { color: var(--text); }

.page-actions { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }

/* ================================================================
   SECTIONS
================================================================ */
.section { margin-top: 28px; }

.section-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 12px;
    gap: 12px;
}

.section-title {
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--text-sec);
}
body.dark .section-title { color: rgba(255,255,255,0.65); }

.section-actions { display: flex; gap: 8px; }

/* ================================================================
   BUTTONS
================================================================ */
.btn {
    display: inline-flex; align-items: center; justify-content: center;
    gap: 6px;
    padding: 8px 16px;
    border-radius: var(--radius-sm);
    font-family: 'Manrope', 'Segoe UI', Arial, sans-serif;
    font-size: 13px;
    font-weight: 700;
    cursor: pointer;
    border: none;
    transition: all 0.15s;
    white-space: nowrap;
    text-decoration: none;
    line-height: 1;
}

.btn-primary   { background: var(--accent); color: #fff; }
.btn-primary:hover { background: #15803d; }
.btn-secondary { background: var(--surface); color: var(--text); border: 1px solid var(--border2); box-shadow: var(--shadow); }
.btn-secondary:hover { border-color: var(--accent); color: var(--accent-text); }
.btn-ghost     { background: transparent; color: var(--text-sec); border: 1px solid var(--border2); }
.btn-ghost:hover { color: var(--text); border-color: var(--border2); background: var(--surface2); }
.btn-danger    { background: var(--danger); color: #fff; }
.btn-danger:hover { opacity: 0.9; }
.btn-danger-ghost   { background: transparent; color: var(--danger); border: 1px solid var(--border2); }
.btn-danger-ghost:hover { background: var(--danger-dim); border-color: var(--danger); }
.btn-whatsapp  { background: #25D366; color: #fff; }
.btn-whatsapp:hover { background: #1ebe5a; }
.btn-danger-outline { background: transparent; color: var(--danger); border: 1px solid var(--danger); }
.btn-danger-outline:hover { background: var(--danger-dim); }
.btn-full      { width: 100%; }

.btn-icon {
    display: inline-flex; align-items: center; justify-content: center;
    width: 28px; height: 28px;
    border-radius: var(--radius-sm);
    background: transparent;
    border: none;
    cursor: pointer;
    font-size: 13px;
    transition: all 0.15s;
}
.btn-danger-icon { color: var(--text-dim); }
.btn-danger-icon:hover { color: var(--danger); background: var(--danger-dim); }

/* Rückennummer-Chip in der Spielerliste */
.btn-nr-chip {
    font-family: 'Bebas Neue', sans-serif;
    font-size: 13px;
    letter-spacing: 0.04em;
    padding: 3px 10px;
    border-radius: 99px;
    border: 1.5px solid;
    cursor: pointer;
    transition: all 0.15s;
    flex-shrink: 0;
    white-space: nowrap;
}
.btn-nr-set {
    color: var(--accent);
    border-color: rgba(74,222,128,0.4);
    background: var(--accent-bg);
}
.btn-nr-set:hover {
    background: rgba(74,222,128,0.2);
    border-color: var(--accent);
}
.btn-nr-empty {
    color: var(--text-dim);
    border-color: var(--border2);
    border-style: dashed;
    background: transparent;
    font-size: 11px;
    font-family: inherit;
    font-weight: 600;
}
.btn-nr-empty:hover {
    color: var(--text-sec);
    border-color: var(--border2);
    background: var(--surface2);
}

.field-hint { font-size: 10px; font-weight: 400; color: var(--text-dim); font-family: inherit; }

/* ================================================================
   AUFSTELLUNG — Positionstyp-Farben auf den Dots
================================================================ */
.pos-dot.filled[data-pos-type="gk"] .pos-label {
    background: rgba(161,98,7,0.85);
    border-color: #fde68a;
    box-shadow: 0 0 14px rgba(250,204,21,0.4), 0 2px 8px rgba(0,0,0,0.4);
}
.pos-dot.filled[data-pos-type="def"] .pos-label {
    background: rgba(29,78,216,0.85);
    border-color: #93c5fd;
    box-shadow: 0 0 14px rgba(96,165,250,0.4), 0 2px 8px rgba(0,0,0,0.4);
}
.pos-dot.filled[data-pos-type="mid"] .pos-label {
    background: rgba(22,163,74,0.92);
    border-color: #86efac;
    box-shadow: 0 0 14px rgba(74,222,128,0.45), 0 2px 8px rgba(0,0,0,0.4);
}
.pos-dot.filled[data-pos-type="att"] .pos-label {
    background: rgba(185,28,28,0.85);
    border-color: #fca5a5;
    box-shadow: 0 0 14px rgba(248,113,113,0.4), 0 2px 8px rgba(0,0,0,0.4);
}
/* selected player: immer akzent-grün */
.pos-dot.selected-player .pos-label {
    background: var(--accent) !important;
    border-color: #fff !important;
    box-shadow: 0 0 18px rgba(74,222,128,0.6) !important;
}

/* ================================================================
   AUFSTELLUNG — Player-First sticky
================================================================ */
.player-first-list {
    position: sticky;
    top: 0;
    z-index: 20;
    background: var(--surface);
    border-bottom: 1px solid var(--border);
    margin: 0 0 10px;
    padding: 8px 10px;
    border-radius: 0;
}
body.dark .player-first-list { background: var(--bg); }

/* ================================================================
   AUFSTELLUNG — Locked Header (Read-only Übersicht)
================================================================ */
.lineup-locked-header {
    display: flex;
    align-items: center;
    gap: 14px;
    background: var(--surface2);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    padding: 12px 16px;
    margin-bottom: 14px;
    flex-wrap: wrap;
}
.llh-badge {
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.05em;
    color: var(--text-sec);
    text-transform: uppercase;
    white-space: nowrap;
}
.llh-result {
    display: flex;
    align-items: center;
    gap: 6px;
    font-family: 'Bebas Neue', sans-serif;
    font-size: 32px;
    letter-spacing: 0.05em;
    line-height: 1;
}
.llh-score-own { color: var(--accent); }
.llh-score-opp { color: var(--danger); }
.llh-sep       { color: var(--text-dim); }
.llh-vs {
    font-size: 13px;
    font-weight: 600;
    color: var(--text-sec);
    margin-left: auto;
    text-align: right;
}

/* ================================================================
   AUFSTELLUNG — Toolbar responsive
================================================================ */
@media (max-width: 480px) {
    .lineup-toolbar { gap: 6px; }
    .lineup-form-select { max-width: 130px; font-size: 12px; }
    .lineup-toolbar-right .btn { font-size: 11px; padding: 4px 7px; }
}

/* ================================================================
   FORMS
================================================================ */
.field { display: flex; flex-direction: column; gap: 5px; margin-bottom: 14px; }
.field label { font-size: 11px; font-weight: 700; letter-spacing: 0.06em; text-transform: uppercase; color: var(--text-sec); }

input[type="text"],
input[type="email"],
input[type="password"],
input[type="date"],
input[type="number"],
select,
textarea {
    background: var(--surface);
    border: 1px solid var(--border2);
    color: var(--text);
    border-radius: var(--radius-sm);
    padding: 9px 12px;
    font-family: 'Manrope', 'Segoe UI', Arial, sans-serif;
    font-size: 13px;
    outline: none;
    transition: border-color 0.15s, box-shadow 0.15s;
    width: 100%;
}

input:focus, select:focus, textarea:focus {
    border-color: var(--accent);
    box-shadow: 0 0 0 3px var(--accent-bg);
}
textarea { resize: vertical; min-height: 80px; }
select { appearance: none; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M6 8 0 0h12z' fill='%23888'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 12px center; padding-right: 32px; cursor: pointer; }

.field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.field-inline { display: flex; align-items: center; gap: 10px; }
.field-inline label { white-space: nowrap; margin: 0; }
.field-inline select { margin: 0; }

.form-error {
    padding: 8px 12px;
    background: var(--danger-dim);
    border: 1px solid var(--danger);
    border-radius: var(--radius-sm);
    color: var(--danger);
    font-size: 13px;
    font-weight: 600;
    margin-bottom: 12px;
}
.form-success {
    padding: 8px 12px;
    background: var(--accent-bg);
    border: 1px solid var(--accent);
    border-radius: var(--radius-sm);
    color: var(--accent-text);
    font-size: 13px;
    margin-bottom: 12px;
}

.modal-hint {
    font-size: 12px;
    color: var(--text-sec);
    margin-bottom: 12px;
    padding: 8px 12px;
    background: var(--accent-bg);
    border-radius: var(--radius-sm);
    border-left: 3px solid var(--accent);
}

/* ================================================================
   STATS CARDS (Dashboard)
================================================================ */
.stats-row {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(130px, 1fr));
    gap: 12px;
    margin-bottom: 24px;
}

.stat-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 16px 18px;
    box-shadow: var(--shadow);
}
.stat-value {
    font-size: 26px;
    font-weight: 800;
    letter-spacing: -0.04em;
    color: var(--text);
    line-height: 1;
}
.stat-label {
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--text-sec);
    margin-top: 4px;
}

/* ================================================================
   TEAM CARDS (Dashboard)
================================================================ */
.team-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 12px;
}

.team-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 16px;
    display: flex;
    align-items: center;
    gap: 14px;
    cursor: pointer;
    transition: border-color 0.15s, box-shadow 0.15s;
    box-shadow: var(--shadow);
}
.team-card:hover { border-color: var(--accent); box-shadow: var(--shadow-md); }

.tc-avatar {
    width: 42px; height: 42px;
    background: var(--accent-bg);
    color: var(--accent-text);
    border-radius: 10px;
    display: flex; align-items: center; justify-content: center;
    font-size: 20px;
    font-weight: 800;
    flex-shrink: 0;
    border: 1px solid var(--border);
}

.tc-body { flex: 1; min-width: 0; }
.tc-name { font-weight: 700; font-size: 13px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.tc-meta { font-size: 12px; color: var(--text-sec); margin-top: 2px; font-weight: 500; }
.tc-arrow { color: var(--text-dim); font-size: 18px; }

.empty-state {
    text-align: center;
    padding: 60px 24px;
    color: var(--text-sec);
    grid-column: 1 / -1;
}
.empty-icon { font-size: 40px; display: block; margin-bottom: 14px; }
.empty-state p { line-height: 1.7; font-size: 13px; }

/* ================================================================
   TEAM HERO
================================================================ */
.team-hero {
    display: flex;
    align-items: center;
    gap: 16px;
    margin-bottom: 8px;
    flex-wrap: wrap;
}

.team-hero-avatar {
    width: 56px; height: 56px;
    background: var(--accent-bg);
    color: var(--accent-text);
    border: 1px solid var(--border);
    border-radius: 12px;
    display: flex; align-items: center; justify-content: center;
    font-size: 26px;
    font-weight: 800;
    flex-shrink: 0;
}

.team-hero-actions { margin-left: auto; }

/* ================================================================
   PLAYER LIST
================================================================ */
.player-list { display: flex; flex-direction: column; gap: 2px; }

.player-item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px 12px;
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    transition: border-color 0.1s;
}
.player-item:hover { border-color: var(--border2); background: var(--surface2); }

.player-avatar {
    width: 30px; height: 30px;
    background: var(--surface2);
    border: 1px solid var(--border2);
    border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    font-size: 10px;
    font-weight: 700;
    color: var(--text-sec);
    flex-shrink: 0;
}
.player-avatar.small { width: 26px; height: 26px; font-size: 9px; }

.player-name { flex: 1; font-size: 13px; font-weight: 500; }

/* Rückennummer im Avatar */
.player-nr-avatar {
    font-family: 'Bebas Neue', sans-serif;
    font-size: 14px;
    color: var(--accent-text);
    letter-spacing: 0.02em;
}

.empty-inline {
    padding: 20px;
    text-align: center;
    color: var(--text-sec);
    font-size: 13px;
    background: var(--surface);
    border: 1px dashed var(--border2);
    border-radius: var(--radius);
}

/* ================================================================
   MATCHDAY LIST — Große Ergebnis-Karten
================================================================ */
.matchday-list { display: flex; flex-direction: column; gap: 10px; }

.md-result-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-left: 3px solid var(--border2);
    border-radius: 12px;
    padding: 16px 20px;
    cursor: pointer;
    transition: border-color 0.18s, transform 0.12s, box-shadow 0.18s;
    box-shadow: var(--shadow);
    position: relative;
    overflow: hidden;
}
.md-result-card::before {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, rgba(74,222,128,0.03) 0%, transparent 60%);
    opacity: 0;
    transition: opacity 0.2s;
}
.md-result-card:hover { border-color: var(--accent); border-left-color: var(--accent); transform: translateY(-2px); box-shadow: var(--shadow-md); }
.md-result-card:hover::before { opacity: 1; }

/* Win/Loss-Farbstreifen links */
.md-result-card.result-win  { border-left-color: var(--accent); }
.md-result-card.result-loss { border-left-color: var(--danger); }
.md-result-card.result-draw { border-left-color: var(--warn); }

.md-card-top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 12px;
}

.md-card-date {
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.07em;
    text-transform: uppercase;
    color: var(--text-sec);
}

.md-status {
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    padding: 2px 8px;
    border-radius: 4px;
}
.md-status-locked { background: rgba(251,191,36,0.12); color: var(--warn); }
.md-status-open   { background: rgba(239,68,68,0.10); color: #f87171; display: inline-flex; align-items: center; gap: 5px; }

/* Pulsierender Live-Dot */
.live-dot {
    display: inline-block;
    width: 7px; height: 7px;
    border-radius: 50%;
    background: #ef4444;
    animation: live-pulse 1.6s ease-in-out infinite;
    flex-shrink: 0;
}
@keyframes live-pulse {
    0%, 100% { opacity: 1; transform: scale(1); box-shadow: 0 0 0 0 rgba(239,68,68,0.4); }
    50%       { opacity: 0.7; transform: scale(0.85); box-shadow: 0 0 0 4px rgba(239,68,68,0); }
}

.md-card-match {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 10px;
}

.md-card-team {
    flex: 1;
    font-family: 'Bebas Neue', sans-serif;
    font-size: 24px;
    letter-spacing: 0.04em;
    line-height: 1;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.md-card-home { text-align: right; color: var(--text); }
.md-card-away { text-align: left; color: var(--text-sec); }

.md-score {
    display: flex;
    align-items: center;
    gap: 2px;
    flex-shrink: 0;
}
.md-score-num {
    font-family: 'Bebas Neue', sans-serif;
    font-size: 46px;
    line-height: 1;
    color: var(--text);
    min-width: 28px;
    text-align: center;
}
/* Heimtore bei Sieg grün, bei Niederlage gedimmt */
.result-win  .md-score-num:first-child { color: var(--accent-text); }
.result-loss .md-score-num:first-child { color: var(--text-sec); }
.result-win  .md-score-num:last-child  { color: var(--text-sec); }
.result-loss .md-score-num:last-child  { color: var(--danger); }
.md-score-sep {
    font-family: 'Bebas Neue', sans-serif;
    font-size: 32px;
    color: var(--text-sec);
    line-height: 1;
    padding: 0 2px;
}
.md-score-vs {
    font-family: 'Bebas Neue', sans-serif;
    font-size: 20px;
    color: var(--text-sec);
    letter-spacing: 0.1em;
    padding: 0 10px;
    flex-shrink: 0;
}

.md-card-events {
    display: flex;
    align-items: center;
    gap: 6px;
    flex-wrap: wrap;
}
.md-icon-pill {
    display: inline-flex;
    align-items: center;
    gap: 3px;
    font-size: 11px;
    font-weight: 700;
    background: var(--surface2);
    border: 1px solid var(--border);
    border-radius: 6px;
    padding: 2px 8px;
    color: var(--text-sec);
}

/* ================================================================
   BADGES
================================================================ */
.badge {
    display: inline-flex; align-items: center;
    padding: 2px 8px;
    border-radius: 99px;
    font-size: 11px;
    font-weight: 700;
}
.badge-locked { background: var(--warn-bg); color: var(--warn); }
.badge-open   { background: var(--accent-bg); color: var(--accent-text); }

.role-badge { display: inline-block; padding: 2px 8px; border-radius: 99px; font-size: 11px; font-weight: 700; }
.role-admin      { background: #fee2e2; color: #dc2626; }
.role-trainer    { background: var(--accent-bg); color: var(--accent-text); }
.role-co-trainer { background: #eff6ff; color: #3b82f6; }
.role-viewer     { background: var(--surface2); color: var(--text-sec); border: 1px solid var(--border); }

body.dark .role-admin     { background: #2d1111; color: #f87171; }
body.dark .role-trainer   { background: rgba(22,163,74,.12); color: #4ade80; }
body.dark .role-co-trainer{ background: #1e2d4a; color: #60a5fa; }
body.dark .role-viewer    { background: var(--surface2); color: var(--text-sec); }

/* ================================================================
   MATCHDAY PAGE HEADER (neu)
================================================================ */
.md-page-header {
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 20px 24px 16px;
    border-bottom: 1px solid rgba(255,255,255,0.07);
    flex-wrap: wrap;
    background: linear-gradient(135deg, #0a1628 0%, #0d1f0d 60%, #091a09 100%);
    position: relative;
    overflow: hidden;
    border-radius: var(--radius) var(--radius) 0 0;
}
.md-page-header::before {
    content: '';
    position: absolute;
    inset: 0;
    opacity: 0.05;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 600 400' fill='none' stroke='%234ade80'%3E%3Crect x='20' y='20' width='560' height='360' stroke-width='2'/%3E%3Cline x1='20' y1='200' x2='580' y2='200' stroke-width='1.5'/%3E%3Ccircle cx='300' cy='200' r='60' stroke-width='1.5'/%3E%3Ccircle cx='300' cy='200' r='4' fill='%234ade80' stroke='none'/%3E%3Crect x='20' y='130' width='100' height='140' stroke-width='1.5'/%3E%3Crect x='480' y='130' width='100' height='140' stroke-width='1.5'/%3E%3C/svg%3E");
    background-size: cover;
    background-position: center;
    pointer-events: none;
}
body:not(.dark) .md-page-header {
    background: linear-gradient(135deg, #0f1f10 0%, #1a3a1a 60%, #102010 100%);
}

.md-back {
    display: flex;
    align-items: center;
    gap: 4px;
    color: var(--text-sec);
    cursor: pointer;
    font-size: 13px;
    font-weight: 600;
    transition: color 0.15s;
    white-space: nowrap;
    flex-shrink: 0;
}
.md-back:hover { color: var(--accent-text); }
.md-back-arrow { font-size: 22px; line-height: 1; margin-top: -1px; }
.md-back-label { font-size: 12px; }

.md-title-block { flex: 1; min-width: 0; text-align: center; }

/* Neues Match-Header-Layout mit Score */
.md-hdr-match {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    min-width: 0;
}
.md-hdr-team {
    font-family: 'Bebas Neue', sans-serif;
    font-size: 22px;
    letter-spacing: 0.04em;
    line-height: 1.1;
    flex: 1;
    word-break: break-word;
}
.md-hdr-home { text-align: right; color: var(--text); }
.md-hdr-away { text-align: left; color: var(--text-sec); }
.md-hdr-score {
    display: flex;
    align-items: center;
    gap: 1px;
    flex-shrink: 0;
}
.md-hdr-num {
    font-family: 'Bebas Neue', sans-serif;
    font-size: 40px;
    line-height: 1;
    color: var(--text);
    min-width: 26px;
    text-align: center;
}
.md-hdr-sep {
    font-family: 'Bebas Neue', sans-serif;
    font-size: 26px;
    color: var(--text-sec);
    line-height: 1;
    padding: 0 2px;
}
.md-hdr-vs {
    font-family: 'Bebas Neue', sans-serif;
    font-size: 18px;
    color: var(--text-sec);
    letter-spacing: 0.1em;
    padding: 0 8px;
    flex-shrink: 0;
}

.md-meta { justify-content: center; }
.md-vs      { color: var(--text-sec); font-weight: 400; margin: 0 6px; }
.md-team    { color: var(--text-sec); font-size: 16px; }
.md-opponent { color: var(--text); }
.md-meta    { font-size: 12px; color: var(--text-sec); margin-top: 4px; display: flex; align-items: center; justify-content: center; gap: 8px; }

.md-actions { display: flex; gap: 8px; flex-shrink: 0; }
.md-mobile-actions { display: none; } /* nur Mobile */

/* Bottom-Tabs im Matchday (Desktop: normale Tabs oben) */
.md-tabs-bottom {
    display: flex;
    border-top: 1px solid var(--border);
    margin-top: 20px;
}

.md-tab {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 3px;
    padding: 10px 8px;
    background: none;
    border: none;
    border-top: 2px solid transparent;
    color: var(--text-sec);
    font-size: 12px;
    font-weight: 600;
    cursor: pointer;
    transition: color 0.15s, border-color 0.15s, background 0.15s;
    position: relative;
}
.md-tab:hover { color: var(--text); }
.md-tab.active {
    color: var(--accent-text);
    border-top-color: var(--accent);
    background: var(--accent-bg);
}
.md-tab-icon { font-size: 18px; line-height: 1; }
.md-tab-label { font-size: 11px; display: flex; align-items: center; gap: 4px; letter-spacing: 0.02em; }
.md-tab-count {
    background: var(--surface2);
    border-radius: 10px;
    padding: 1px 5px;
    font-size: 10px;
}
.md-tab.active .md-tab-count { background: rgba(74,222,128,0.18); color: var(--accent-text); }

.desktop-only { } /* Platzhalter, wird auf Mobile ausgeblendet */

/* Tab-Überschrift im Content-Bereich */
.md-tab-heading {
    padding: 12px 24px 4px;
    font-size: 13px;
    font-weight: 700;
    color: var(--text-sec);
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

/* Alte Tabs (andere Views) */
.tabs {
    display: flex;
    gap: 0;
    border-bottom: 1px solid var(--border);
    margin-bottom: 20px;
}

.tab {
    padding: 10px 16px;
    background: none;
    border: none;
    border-bottom: 2px solid transparent;
    margin-bottom: -1px;
    font-family: 'Manrope', 'Segoe UI', Arial, sans-serif;
    font-size: 13px;
    font-weight: 600;
    color: var(--text-sec);
    cursor: pointer;
    transition: color 0.15s, border-color 0.15s;
}
.tab:hover { color: var(--text); }
.tab.active { color: var(--accent-text); border-bottom-color: var(--accent); }

.tab-section { padding-top: 4px; }
.tab-hint { font-size: 13px; color: var(--text-sec); margin-bottom: 8px; }

.squad-tab-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 12px;
}
.squad-tab-header .tab-hint { margin-bottom: 0; }
.squad-save-row { display: flex; align-items: center; gap: 12px; }
.squad-count { font-size: 13px; color: var(--text-sec); font-weight: 600; }
.btn-sm { padding: 5px 10px; font-size: 12px; }

/* ================================================================
   KADER TAB
================================================================ */
.squad-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: 6px;
    max-height: 400px;
    overflow-y: auto;
    padding: 4px;
}

.squad-player {
    display: flex; align-items: center; gap: 10px;
    padding: 9px 12px;
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    cursor: pointer;
    transition: border-color 0.1s;
}
.squad-player:hover { border-color: var(--border2); }
.squad-player.selected { border-color: var(--accent); background: var(--accent-bg); }
.squad-player input { flex-shrink: 0; accent-color: var(--accent); width: 14px; height: 14px; cursor: pointer; }
.sp-name { font-size: 13px; font-weight: 600; flex: 1; }
.sp-nr {
    font-family: 'Bebas Neue', sans-serif;
    font-size: 15px;
    color: var(--accent-text);
    min-width: 20px;
    text-align: center;
    letter-spacing: 0.02em;
    flex-shrink: 0;
}

/* ================================================================
   AUFSTELLUNG / PITCH
================================================================ */
/* ---- Lineup Toolbar (neue einzeilige Steuerleiste) ---- */
.lineup-toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    margin-bottom: 10px;
    flex-wrap: wrap;
}
.lineup-toolbar-left {
    display: flex;
    align-items: center;
    gap: 6px;
    flex: 1;
    min-width: 0;
}
.lineup-toolbar-right {
    display: flex;
    align-items: center;
    gap: 6px;
    flex-shrink: 0;
}
.lineup-form-select {
    flex: 1;
    min-width: 0;
    max-width: 180px;
    font-size: 13px;
    padding: 5px 8px;
    background: var(--surface2);
    border: 1px solid var(--border2);
    border-radius: var(--radius-sm);
    color: var(--text);
    cursor: pointer;
}

/* Legacy — wird nicht mehr gerendert, aber behalten für rerenderLineup-Fallback */
.lineup-controls { display: flex; flex-direction: column; gap: 8px; margin-bottom: 10px; }
.lineup-row-actions { display: flex; align-items: center; gap: 8px; flex-wrap: nowrap; }

.pitch-wrap { max-width: 400px; margin: 0 auto 12px; }

.pitch {
    position: relative;
    width: 100%;
    aspect-ratio: 2 / 3;
    /* Rasenstreifen: alternating dunkel/hell */
    background:
        repeating-linear-gradient(
            to bottom,
            rgba(0,0,0,0.10) 0px, rgba(0,0,0,0.10) 30px,
            rgba(0,0,0,0)    30px, rgba(0,0,0,0)    60px
        ),
        linear-gradient(160deg, #0f4d23 0%, #166534 30%, #15803d 50%, #166534 70%, #0f4d23 100%);
    border-radius: 12px;
    border: 2px solid #0c3d1a;
    overflow: hidden;
    box-shadow: inset 0 0 60px rgba(0,0,0,0.4), 0 4px 24px rgba(0,0,0,0.5);
}

.pitch-center-line {
    position: absolute; top: 50%; left: 3%; right: 3%;
    height: 1px; background: rgba(255,255,255,0.35);
    pointer-events: none;
    box-shadow: 0 0 4px rgba(255,255,255,0.15);
}
.pitch-center-circle {
    position: absolute; top: 50%; left: 50%;
    width: 70px; height: 70px;
    border: 1px solid rgba(255,255,255,0.35);
    border-radius: 50%;
    transform: translate(-50%, -50%);
    pointer-events: none;
    box-shadow: 0 0 8px rgba(255,255,255,0.08);
}
.pitch-center-dot {
    position: absolute; top: 50%; left: 50%;
    width: 5px; height: 5px;
    background: rgba(255,255,255,0.45);
    border-radius: 50%;
    transform: translate(-50%, -50%);
    pointer-events: none;
}

/* Formation-Pill: oben rechts auf dem Pitch */
.pitch-formation-pill {
    position: absolute;
    top: 8px; right: 8px;
    background: rgba(0,0,0,0.65);
    color: rgba(255,255,255,0.85);
    font-family: 'Manrope', sans-serif;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.05em;
    padding: 3px 8px;
    border-radius: 10px;
    pointer-events: none;
    backdrop-filter: blur(4px);
    border: 1px solid rgba(255,255,255,0.15);
}
.pitch::before {
    content: ''; position: absolute;
    top: 2%; left: 22%; right: 22%; height: 15%;
    border: 1px solid rgba(255,255,255,0.3); border-top: none;
    pointer-events: none;
    box-shadow: inset 0 4px 12px rgba(0,0,0,0.2);
}
.pitch::after {
    content: ''; position: absolute;
    bottom: 2%; left: 22%; right: 22%; height: 15%;
    border: 1px solid rgba(255,255,255,0.3); border-bottom: none;
    pointer-events: none;
}

.pos-dot {
    position: absolute;
    transform: translate(-50%, -50%);
    display: flex; flex-direction: column; align-items: center;
    cursor: pointer; z-index: 10;
    width: 68px;
    transition: left 0.1s, top 0.1s;
}
.pos-dot[draggable="true"] { cursor: grab; }
.pos-dot[draggable="true"]:active,
.pos-dot.dragging { cursor: grabbing; opacity: 0.7; transition: none; }

.pos-label {
    width: 50px; height: 50px;
    border-radius: 50%;
    background: rgba(0,0,0,0.5);
    border: 2px solid rgba(255,255,255,0.5);
    display: flex; align-items: center; justify-content: center;
    font-size: 11px; font-weight: 700; color: #fff;
    transition: background 0.15s, border-color 0.15s;
    backdrop-filter: blur(2px);
}

.pos-dot.filled .pos-label {
    background: rgba(22,163,74,0.92);
    border-color: #86efac;
    border-width: 2px;
    color: #fff;
    box-shadow: 0 0 14px rgba(74,222,128,0.45), 0 2px 8px rgba(0,0,0,0.4);
}
/* Rückennummer im Pitch-Dot: größer und schärfer */
.pos-dot.has-number .pos-label {
    font-family: 'Bebas Neue', sans-serif;
    font-size: 18px;
    letter-spacing: 0.02em;
}

/* Leere Positions-Slots: kleiner und dezenter */
.pos-dot.empty-slot .pos-label {
    width: 28px; height: 28px;
    font-size: 8px;
    background: rgba(0,0,0,0.25);
    border: 1px dashed rgba(255,255,255,0.3);
    color: rgba(255,255,255,0.5);
}
.pos-dot.empty-slot .pos-player { display: none; }
.pos-dot.empty-slot:hover .pos-label {
    border-color: rgba(255,255,255,0.7);
    background: rgba(0,0,0,0.45);
}
.pos-dot:hover .pos-label { border-color: #fff; background: rgba(0,0,0,0.7); }

.pos-player {
    font-size: 10px; color: rgba(255,255,255,0.9);
    margin-top: 3px; white-space: nowrap;
    max-width: 68px; overflow: hidden; text-overflow: ellipsis;
    text-shadow: 0 1px 3px rgba(0,0,0,0.8);
    text-align: center;
}

.bench-section { margin-top: 12px; }
.bench-title { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.08em; color: var(--text-sec); margin-bottom: 8px; }

/* Ersatzbank-Grid (neue Karten-Ansicht) */
.bench-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
    gap: 6px;
    align-items: start;
}
.bench-card {
    display: flex;
    align-items: center;
    gap: 0;
    background: var(--surface2);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    overflow: hidden;
    transition: border-color 0.15s;
}
.bench-card-nr {
    font-family: 'Bebas Neue', sans-serif;
    font-size: 14px;
    min-width: 32px;
    text-align: center;
    padding: 8px 0;
    color: var(--text-sec);
    background: var(--surface);
    border-right: 1px solid var(--border);
    flex-shrink: 0;
}
.bench-card-name {
    flex: 1;
    font-size: 12px;
    font-weight: 600;
    padding: 8px 8px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.bench-remove {
    background: none; border: none; cursor: pointer;
    color: var(--text-dim); font-size: 12px; line-height: 1;
    padding: 8px 8px; flex-shrink: 0;
}
.bench-remove:hover { color: var(--danger); }
.bench-add {
    padding: 8px 12px;
    background: none; border: 1px dashed var(--border2);
    border-radius: var(--radius-sm); font-size: 12px; font-family: 'Manrope', sans-serif;
    color: var(--text-sec); cursor: pointer; font-weight: 600;
    transition: border-color 0.15s, color 0.15s;
    text-align: center;
}
.bench-add:hover { border-color: var(--accent); color: var(--accent-text); }

/* Legacy bench-list/bench-player (Fallback) */
.bench-list { display: flex; flex-wrap: wrap; gap: 6px; align-items: center; }
.bench-player { display: inline-flex; align-items: center; gap: 6px; padding: 5px 10px; background: var(--surface); border: 1px solid var(--border2); border-radius: 99px; font-size: 12px; font-weight: 500; }

.player-select-list { max-height: 320px; overflow-y: auto; display: flex; flex-direction: column; gap: 2px; }
.psl-item {
    display: flex; align-items: center; gap: 10px;
    padding: 9px 12px;
    border-radius: var(--radius-sm);
    cursor: pointer;
    transition: background 0.1s;
    border: 1px solid transparent;
}
.psl-item:hover { background: var(--surface2); }
.psl-item.active { background: var(--accent-bg); border-color: var(--accent); }
.psl-empty { color: var(--text-sec); font-style: italic; font-size: 13px; }
.psl-hint  { color: var(--accent); font-size: 11px; font-weight: 600; margin-left: 4px; opacity: .8; }

/* ================================================================
   EREIGNISSE
================================================================ */
.events-actions { margin-bottom: 14px; display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.events-list { display: flex; flex-direction: column; gap: 4px; }

.event-item {
    display: flex; align-items: center; gap: 10px;
    padding: 10px 12px;
    background: var(--surface);
    border: 1px solid var(--border);
    border-left: 3px solid var(--border2); /* Farbkante per Event-Typ überschrieben */
    border-radius: var(--radius-sm);
    box-shadow: var(--shadow);
}
/* Event-Typ-Farbkante links */
.event-item[data-type="goal"]             { border-left-color: var(--accent); }
.event-item[data-type="yellow_card"]      { border-left-color: #fbbf24; }
.event-item[data-type="red_card"]         { border-left-color: var(--danger); }
.event-item[data-type="substitution"]     { border-left-color: #3b82f6; }
.event-item[data-type="note"]             { border-left-color: #8b5cf6; }
.event-item[data-type="formation_change"] { border-left-color: #06b6d4; }
.event-item[data-type="halftime"]         { border-left-color: var(--warn); }
/* Gegner-Tor (kein Spieler): orange */
.event-item[data-type="goal"][data-is-opponent="true"] { border-left-color: #f97316; }
.event-body { flex: 1; min-width: 0; }
.event-actions {
    display: flex;
    align-items: center;
    gap: 2px;
    flex-shrink: 0;
}
.event-wa {
    font-size: 16px;
    text-decoration: none;
    opacity: 0.7;
    transition: opacity 0.15s;
    padding: 2px 4px;
    border-radius: 4px;
}
.event-wa:hover { opacity: 1; background: rgba(37,211,102,0.12); }

.event-minute {
    font-size: 18px;
    font-weight: 800;
    color: var(--accent-text);
    font-variant-numeric: tabular-nums;
    min-width: 36px;
    line-height: 1.2;
    letter-spacing: -0.03em;
}

.event-body { flex: 1; }
.event-label { font-size: 13px; font-weight: 700; margin-bottom: 2px; }
.event-detail { font-size: 13px; color: var(--text-sec); font-weight: 500; }
.event-assist { color: var(--text-muted); font-size: 12px; }

/* Auswechslung: Sofascore-Doppelformat */
.event-sub-pair {
    display: flex;
    flex-direction: column;
    gap: 2px;
    margin-top: 2px;
}
.event-sub-in, .event-sub-out {
    display: flex;
    align-items: center;
    gap: 5px;
    font-size: 13px;
    font-weight: 600;
}
.event-sub-in  { color: #4ade80; }
.event-sub-out { color: #f87171; }
.sub-arrow-in, .sub-arrow-out {
    font-size: 12px;
    font-weight: 900;
    flex-shrink: 0;
}
.event-note { font-size: 12px; color: var(--text-sec); margin-top: 4px; }

/* HZ-Trenner in der Events-Liste */
.events-ht-divider {
    display: flex;
    align-items: center;
    gap: 10px;
    margin: 12px 0 8px;
    opacity: 0.55;
}
.ht-line { flex: 1; height: 1px; background: var(--border2); }
.ht-label {
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.06em;
    color: var(--warn);
    white-space: nowrap;
}

/* ================================================================
   ADMIN — STATS + TABLE
================================================================ */
.stats-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(130px, 1fr));
    gap: 12px;
    margin-bottom: 28px;
}

.user-table-wrap {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    overflow: hidden;
    box-shadow: var(--shadow);
}
.user-table { width: 100%; border-collapse: collapse; }
.user-table th {
    text-align: left; padding: 10px 14px;
    font-size: 11px; font-weight: 700; letter-spacing: 0.06em; text-transform: uppercase;
    color: var(--text-sec); border-bottom: 1px solid var(--border);
    background: var(--surface2);
}
.user-table td { padding: 11px 14px; border-bottom: 1px solid var(--border); font-size: 13px; vertical-align: middle; }
.user-table tr:last-child td { border-bottom: none; }
.user-table tr:hover td { background: var(--surface2); }
.text-secondary { color: var(--text-sec); }
.action-cell { display: flex; align-items: center; gap: 6px; }

.role-select {
    padding: 4px 8px; font-size: 12px; font-weight: 600;
    background: var(--surface2); border: 1px solid var(--border2);
    color: var(--text); border-radius: var(--radius-sm);
    cursor: pointer; font-family: 'Manrope', sans-serif;
}

/* ================================================================
   MODAL
================================================================ */
.modal-overlay {
    position: fixed; inset: 0;
    background: rgba(0,0,0,0.4);
    display: flex; align-items: center; justify-content: center;
    z-index: 1000; padding: 24px;
    backdrop-filter: blur(4px);
}

body.dark .modal-overlay { background: rgba(0,0,0,0.7); }

.modal-box {
    background: var(--surface);
    border: 1px solid var(--border2);
    border-radius: 14px;
    width: 100%; max-width: 480px;
    max-height: 90vh;
    display: flex; flex-direction: column;
    box-shadow: var(--shadow-md);
    animation: popIn 0.18s ease;
}

@keyframes popIn {
    from { opacity: 0; transform: scale(0.96); }
    to   { opacity: 1; transform: none; }
}

.modal-header {
    padding: 18px 20px 14px;
    border-bottom: 1px solid var(--border);
    display: flex; align-items: center; justify-content: space-between;
}
.modal-header h3 { font-size: 15px; font-weight: 800; }
.modal-close { background: none; border: none; cursor: pointer; color: var(--text-sec); font-size: 16px; padding: 2px; line-height: 1; }
.modal-close:hover { color: var(--text); }

.modal-body { padding: 18px 20px; overflow-y: auto; }
.modal-footer {
    padding: 14px 20px;
    border-top: 1px solid var(--border);
    display: flex; align-items: center; justify-content: flex-end; gap: 8px;
    flex-wrap: wrap;
}

/* ================================================================
   TOAST
================================================================ */
#toastContainer {
    position: fixed; bottom: 24px; right: 24px;
    display: flex; flex-direction: column; gap: 8px;
    z-index: 2000;
}

.toast {
    padding: 10px 16px;
    border-radius: var(--radius-sm);
    font-size: 13px; font-weight: 700;
    max-width: 320px;
    opacity: 0; transform: translateX(16px);
    transition: opacity 0.2s, transform 0.2s;
    box-shadow: var(--shadow-md);
}
.toast.show { opacity: 1; transform: none; }
.toast-success { background: var(--surface); border: 1px solid var(--accent); color: var(--accent-text); }
.toast-error   { background: var(--surface); border: 1px solid var(--danger); color: var(--danger); }
.toast-info    { background: var(--surface); border: 1px solid var(--border2); color: var(--text); }

/* ================================================================
   LOADING / UTILS
================================================================ */
.loading {
    text-align: center; padding: 60px 24px;
    color: var(--text-sec); font-weight: 600;
    animation: pulse 1.5s ease-in-out infinite;
}
@keyframes pulse { 0%,100% { opacity: 0.4; } 50% { opacity: 1; } }

/* ================================================================
   SPIELTAG ABSCHLIESSEN
================================================================ */
.close-matchday-section {
    margin-top: 32px;
    padding-top: 24px;
    border-top: 1px solid var(--border);
    text-align: center;
}

.btn-close-matchday {
    background: var(--accent);
    color: #fff;
    border: none;
    padding: 14px 32px;
    border-radius: var(--radius);
    font-size: 15px;
    font-weight: 700;
    cursor: pointer;
    letter-spacing: 0.02em;
    transition: opacity 0.15s;
}
.btn-close-matchday:hover { opacity: 0.85; }

.locked-hint {
    color: var(--text-sec);
    font-size: 13px;
    font-weight: 600;
}

/* Score-Banner im Close-Modal */
.close-score-banner {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    background: var(--surface2);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    padding: 16px 12px;
    margin-bottom: 16px;
    text-align: center;
}
.close-score-side { flex: 1; }
.close-score-team {
    font-size: 13px;
    font-weight: 700;
    color: var(--text);
}
.close-score-team.opp { color: var(--text-sec); }
.close-score-result {
    display: flex;
    align-items: center;
    gap: 6px;
    font-family: 'Bebas Neue', sans-serif;
    font-size: 40px;
    letter-spacing: 0.05em;
    line-height: 1;
    flex-shrink: 0;
}
.close-score-own { color: var(--accent); }
.close-score-opp { color: var(--danger); }
.close-score-sep { color: var(--text-dim); font-size: 30px; }

/* Stat-Farben */
.close-stat-value.own { color: var(--accent); }
.close-stat-value.opp { color: var(--danger); }

/* Modal: Zusammenfassung */
.close-summary-intro {
    font-size: 13px;
    color: var(--text-sec);
    margin-bottom: 16px;
    line-height: 1.5;
}

.close-summary-grid {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 8px;
    margin-bottom: 20px;
}

.close-stat {
    background: var(--surface2);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    padding: 12px 8px;
    text-align: center;
}
.close-stat-value {
    font-size: 24px;
    font-weight: 800;
    color: var(--text);
    line-height: 1;
}
.close-stat-label {
    font-size: 11px;
    color: var(--text-sec);
    margin-top: 4px;
}

.close-detail {
    margin-bottom: 14px;
}
.close-detail-title {
    font-size: 12px;
    font-weight: 700;
    color: var(--text-sec);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-bottom: 6px;
}
.close-detail-row {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 5px 0;
    border-bottom: 1px solid var(--border);
    font-size: 13px;
}
.close-detail-row:last-child { border-bottom: none; }
.close-minute {
    font-size: 11px;
    font-weight: 700;
    color: var(--text-sec);
    min-width: 28px;
}
.close-assist {
    font-size: 12px;
    color: var(--text-sec);
    margin-left: auto;
}

.close-export-hint {
    margin-top: 16px;
    padding: 10px 12px;
    background: var(--accent-bg);
    border-radius: var(--radius-sm);
    font-size: 12px;
    color: var(--accent-text);
}

/* Spielbericht-Notiz im Abschließen-Modal */
.close-note-section {
    margin-top: 20px;
    border-top: 1px solid var(--border);
    padding-top: 16px;
}
.close-note-label {
    display: flex;
    align-items: baseline;
    gap: 8px;
    font-size: 12px;
    font-weight: 700;
    color: var(--text);
    margin-bottom: 8px;
}
.close-note-hint {
    font-size: 11px;
    font-weight: 400;
    color: var(--text-sec);
}
.close-note-wrap {
    position: relative;
}
.close-note-input {
    width: 100%;
    background: var(--surface2);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    padding: 10px 44px 10px 12px;
    font-size: 13px;
    font-family: inherit;
    color: var(--text);
    resize: vertical;
    line-height: 1.5;
}
.close-note-input:focus {
    outline: none;
    border-color: var(--accent);
}
.btn-mic {
    position: absolute;
    bottom: 8px;
    right: 8px;
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: 6px;
    width: 30px;
    height: 30px;
    font-size: 14px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background 0.15s;
}
.btn-mic:hover { background: var(--accent-bg); }

/* ================================================================
   CSV-IMPORT VORSCHAU
================================================================ */
.csv-preview {
    margin-top: 12px;
    border: 1px solid var(--border2);
    border-radius: var(--radius-sm);
    overflow: hidden;
    font-size: 13px;
}

.csv-preview-header {
    display: flex;
    gap: 12px;
    padding: 8px 12px;
    background: var(--surface2);
    border-bottom: 1px solid var(--border);
    font-weight: 700;
}

.csv-stat.ok  { color: var(--accent-text); }
.csv-stat.err { color: var(--warn); }

.csv-preview-list {
    max-height: 220px;
    overflow-y: auto;
}

.csv-row {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 5px 12px;
    border-bottom: 1px solid var(--border);
    font-size: 12px;
}
.csv-row:last-child { border-bottom: none; }
.csv-row.ok  { color: var(--text); }
.csv-row.err { color: var(--warn); background: var(--warn-bg); }

.csv-icon { font-size: 11px; flex-shrink: 0; width: 14px; }

.hidden { display: none !important; }

/* ================================================================
   MOBILE HEADER + BOTTOM NAV (nur auf kleinen Bildschirmen)
================================================================ */

#mobileHeader {
    display: none; /* Desktop: unsichtbar */
}

#mobileBottomNav {
    display: none; /* Desktop: unsichtbar */
}

@media (max-width: 768px) {

    /* Sidebar auf Mobile verstecken */
    #sidebar { display: none; }

    /* App-Shell: vertikal stapeln */
    #appShell {
        flex-direction: column;
        height: 100dvh; /* dynamic viewport height für Mobile-Browser */
    }

    /* Top-Header */
    #mobileHeader {
        display: flex;
        align-items: center;
        justify-content: space-between;
        padding: 0 16px;
        height: 52px;
        background: var(--surface);
        border-bottom: 1px solid var(--border);
        flex-shrink: 0;
        z-index: 100;
    }
    body.dark #mobileHeader { background: #0c0c0c; border-bottom-color: rgba(255,255,255,0.06); }
    body.dark #mobileBottomNav { background: #0c0c0c; border-top-color: rgba(255,255,255,0.06); }

    /* Back-Button: Mindest-Touch-Fläche 44×44px */
    #mobileBack {
        min-width: 44px;
        min-height: 44px;
        display: flex;
        align-items: center;
        justify-content: center;
        background: none;
        border: none;
        font-size: 26px;
        color: var(--text-sec);
        cursor: pointer;
        padding: 0 4px;
        flex-shrink: 0;
        transition: color 0.15s;
        line-height: 1;
    }
    #mobileBack:hover, #mobileBack:active { color: var(--accent-text); }

    .mobile-logo {
        display: flex;
        align-items: center;
        gap: 8px;
    }

    /* Main-Content: scrollbar, Platz für Bottom-Nav lassen */
    #mainContent {
        flex: 1;
        overflow-y: auto;
        padding-bottom: 70px; /* Höhe der Bottom-Nav */
    }

    /* Bottom-Nav */
    #mobileBottomNav {
        display: flex;
        position: fixed;
        bottom: 0; left: 0; right: 0;
        height: 60px;
        background: var(--surface);
        border-top: 1px solid var(--border);
        z-index: 200;
        padding-bottom: env(safe-area-inset-bottom); /* iPhone Notch */
    }

    .mob-nav-item {
        flex: 1;
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        gap: 3px;
        color: var(--text-sec);
        text-decoration: none;
        font-size: 11px;
        font-weight: 600;
        transition: color 0.15s;
        padding: 6px 0;
    }
    .mob-nav-item:active,
    .mob-nav-item.active { color: var(--accent-text); }

    .mob-nav-icon { font-size: 20px; line-height: 1; }
    .mob-nav-label { font-size: 10px; letter-spacing: 0.02em; }

    .mob-nav-divider {
        width: 1px;
        height: 28px;
        background: var(--border);
        align-self: center;
        flex-shrink: 0;
    }
    .mob-nav-icon-btn {
        background: none;
        border: none;
        font-size: 18px;
        padding: 0 10px;
        cursor: pointer;
        color: var(--text-sec);
        flex-shrink: 0;
        flex: 0;
        min-width: 40px;
    }
    .mob-nav-icon-btn:active { color: var(--accent-text); }

    /* Seiten-Padding auf Mobile kleiner */
    .page { padding: 16px; }

    /* Cards nebeneinander → untereinander */
    .team-grid,
    .stats-grid { grid-template-columns: 1fr 1fr; }

    /* Pitch-Wrap: volle Breite auf Mobile */
    .pitch-wrap { max-width: 100%; }

    /* Tabs scrollbar auf Mobile */
    .tabs {
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        flex-wrap: nowrap;
        scrollbar-width: none;
    }
    .tabs::-webkit-scrollbar { display: none; }

    /* Lineup-Controls untereinander */
    .lineup-controls {
        flex-direction: column;
        align-items: stretch;
        gap: 8px;
    }
    .lineup-controls > .field-inline .btn { width: auto; }
    .lineup-row-actions .btn { width: auto; }

    /* Page-Header: Buttons unter den Titel */
    .page-header {
        flex-direction: column;
        align-items: flex-start;
        gap: 12px;
    }
    .page-header .header-actions { width: 100%; }
    .page-header .header-actions .btn { flex: 1; }

    /* Modal volle Breite auf Mobile */
    .modal-box {
        margin: 0;
        border-radius: var(--radius) var(--radius) 0 0;
        position: fixed;
        bottom: 0; left: 0; right: 0;
        max-height: 90dvh;
        overflow-y: auto;
    }
    .modal-overlay {
        align-items: flex-end;
    }

    /* Auth-Card auf Mobile volle Breite */
    .auth-card {
        width: 100%;
        min-height: 100dvh;
        border-radius: 0;
        padding: 40px 24px;
    }

    /* User-Tabelle auf Mobile scrollbar */
    .user-table-wrap { overflow-x: auto; }

    /* Bench-List auf Mobile umbruchsfähig */
    .bench-list { flex-wrap: wrap; }

    /* Export-Buttons untereinander */
    .export-actions { flex-direction: column; }

    /* ---- Matchday-Page auf Mobile ---- */

    /* Desktop-Elemente ausblenden (Back-Button + Desktop-Aktionen) */
    .desktop-only { display: none !important; }
    .md-tab-heading { display: none; }

    /* Matchday-Seite: kein Page-Padding, Header + Content steuern selbst */
    #viewMatchday.page { padding: 0; }

    .md-page-header {
        padding: 10px 16px 8px;
        background: var(--surface);
        border-bottom: 1px solid var(--border);
    }

    #tabContent { padding: 16px; }

    /* Rechter Slot im Mobile-Header */
    .mobile-header-right {
        display: flex;
        align-items: center;
        gap: 4px;
        flex-shrink: 0;
    }
    .mh-actions { display: flex; gap: 4px; }
    .mobile-title-main { font-size: 15px; font-weight: 700; }

    /* Tab-Content: Platz für fixierte Tabs am unteren Rand */
    #tabContent { padding-bottom: 72px; }

    /* md-tabs-bottom: fixiert am unteren Rand, über der globalen Nav */
    .md-tabs-bottom {
        position: fixed;
        bottom: 0; left: 0; right: 0;
        background: var(--surface);
        border-top: 1px solid var(--border);
        margin-top: 0;
        z-index: 150;
        padding-bottom: env(safe-area-inset-bottom);
        backdrop-filter: blur(12px);
        -webkit-backdrop-filter: blur(12px);
    }
    body.dark .md-tabs-bottom {
        background: rgba(12,12,12,0.95);
        border-top-color: rgba(255,255,255,0.08);
    }

    /* Aktive Tab-Markierung: unten → Linie oben bleibt, Farbe anpassen */
    .md-tab {
        padding: 10px 4px 8px;
    }
    .md-tab-icon { font-size: 20px; }
    .md-tab-label { font-size: 10px; }

    /* Timer-Pill in der Bottom-Nav (bei laufendem Spiel) */
    .md-tab-timer-pill {
        position: absolute;
        top: 6px;
        right: 4px;
        background: var(--accent);
        color: #fff;
        font-family: 'Bebas Neue', sans-serif;
        font-size: 10px;
        padding: 1px 5px;
        border-radius: 6px;
        line-height: 1.3;
        letter-spacing: 0.03em;
        animation: pulse-pill 1.5s ease-in-out infinite;
    }
    @keyframes pulse-pill {
        0%, 100% { opacity: 1; }
        50% { opacity: 0.6; }
    }

    /* md-tabs-bottom auf Mobile: etwas mehr Höhe */
    .md-tabs-bottom { height: 58px; }
}

/* Noch kleinere Geräte (< 400px) */
@media (max-width: 400px) {
    .team-grid,
    .stats-grid { grid-template-columns: 1fr; }
}

/* ================================================================
   PHASE 4 — Live-Spieltag Features
================================================================ */

/* ---- Lineup-Controls erweitert ---- */
.lineup-counter {
    font-size: 12px;
    font-weight: 700;
    color: var(--text-sec);
    min-width: 32px;
    text-align: center;
}
.lineup-counter.counter-full { color: var(--accent-text); }

.recent-events {
    margin-top: 12px;
    border-top: 1px solid var(--border);
    padding-top: 10px;
}
.recent-events-title {
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.08em;
    color: var(--text-sec);
    text-transform: uppercase;
    margin-bottom: 6px;
}
.recent-event-item {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 4px 0;
    font-size: 13px;
    border-bottom: 1px solid var(--border);
}
.recent-event-item:last-child { border-bottom: none; }
.recent-event-min {
    font-weight: 700;
    color: var(--accent-text);
    min-width: 28px;
    font-size: 12px;
}
.recent-event-label { color: var(--text-sec); white-space: nowrap; }
.recent-event-player { color: var(--text); font-weight: 600; }
.recent-event-note { color: var(--text-sec); font-size: 11px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

.autosave-indicator {
    font-size: 11px;
    margin-left: auto;
    opacity: 0.6;
    transition: opacity 0.3s;
}
.autosave-indicator.saving { color: var(--text-sec); }
.autosave-indicator.saved  { color: var(--accent-text); }
.autosave-indicator.error  { color: var(--danger); opacity: 1; }

/* ---- Spiel starten Row ---- */
.game-start-row {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    margin: 8px 0 4px;
}
.start-min-row {
    display: flex;
    align-items: center;
    gap: 8px;
    justify-content: center;
    margin: 4px 0 8px;
    animation: fadeIn 0.15s ease;
}
@keyframes fadeIn { from { opacity: 0; transform: translateY(-4px); } to { opacity: 1; transform: translateY(0); } }

.btn-game-start {
    background: #dc2626;
    color: #fff;
    border: none;
    border-radius: var(--radius-sm);
    padding: 10px 24px;
    font-size: 14px;
    font-weight: 700;
    cursor: pointer;
    transition: background 0.15s, opacity 0.15s;
}
.btn-game-start:hover:not(:disabled) { background: #b91c1c; }
.btn-game-start:disabled { background: var(--text-dim); cursor: not-allowed; opacity: 0.5; }
.start-min-toggle { font-size: 11px; color: var(--text-sec); padding: 4px 8px; }

.start-min-wrap {
    display: flex;
    align-items: center;
    gap: 5px;
}
.start-min-label { font-size: 11px; color: var(--text-sec); white-space: nowrap; }
.start-min-input {
    width: 52px;
    padding: 5px 6px;
    border: 1px solid var(--border2);
    border-radius: var(--radius-sm);
    background: var(--surface);
    color: var(--text);
    font-size: 13px;
    text-align: center;
}

/* ---- Timer Row ---- */
.timer-row {
    display: flex;
    align-items: center;
    gap: 10px;
    background: var(--surface);
    border: 1px solid var(--border2);
    border-radius: var(--radius);
    padding: 12px 16px;
    margin-bottom: 10px;
    box-shadow: var(--shadow-md);
}
.timer-row.timer-is-running {
    border-color: rgba(74,222,128,0.3);
    background: linear-gradient(135deg, rgba(74,222,128,0.04) 0%, var(--surface) 60%);
}
.timer-display {
    font-family: 'Bebas Neue', monospace;
    font-size: 52px;
    font-weight: normal;
    color: var(--text);
    min-width: 80px;
    letter-spacing: 0.04em;
    line-height: 1;
    font-variant-numeric: tabular-nums;
}
.timer-row.timer-is-running .timer-display {
    color: var(--accent-text);
    text-shadow: 0 0 24px rgba(74,222,128,0.35);
}
.stoppage-timer {
    color: var(--accent-text);
    font-size: 32px;
    animation: stoppage-pulse 1s ease-in-out infinite;
}
@keyframes stoppage-pulse {
    0%, 100% { opacity: 1; }
    50%       { opacity: 0.6; }
}
.btn-timer {
    background: var(--surface);
    border: 1px solid var(--border2);
    border-radius: var(--radius-sm);
    padding: 5px 10px;
    font-size: 14px;
    cursor: pointer;
    color: var(--text);
    transition: background 0.1s;
}
.btn-timer:hover { background: var(--border); }
.btn-timer-reset { color: var(--danger); border-color: var(--danger); }

/* ---- Pitch-Größen ---- */
.pitch-wrap { max-width: 400px; margin: 0 auto 20px; }
.pitch-wrap.pitch-small  { max-width: 280px; }
.pitch-wrap.pitch-medium { max-width: 340px; }
.pitch-wrap.pitch-large  { max-width: 400px; }

/* Pitch im Auswahl-Modus: Leere Positionen leuchten */
.pitch-wrap[data-selecting="true"] .pos-dot:not(.filled) {
    border-color: var(--accent);
    background: var(--accent-bg);
    animation: pulse-pos 1.2s infinite;
}
@keyframes pulse-pos {
    0%, 100% { box-shadow: 0 0 0 0 rgba(22,163,74,0.4); }
    50%       { box-shadow: 0 0 0 6px rgba(22,163,74,0); }
}
.pos-dot.selected-player { background: var(--accent); color: #fff; }

/* ---- Player-First Liste (Basis — sticky-Styles weiter unten) ---- */
.player-first-list {
    margin: 0 0 10px;
    background: var(--surface2);
    border-bottom: 1px solid var(--border);
    border-radius: 0;
    padding: 8px 10px;
}
.pfl-header { font-size: 10px; font-weight: 700; text-transform: uppercase; color: var(--text-sec); margin-bottom: 6px; letter-spacing: 0.06em; }
.pfl-players { display: flex; flex-wrap: wrap; gap: 6px; }
.pfl-player {
    display: flex;
    align-items: center;
    gap: 5px;
    background: var(--surface);
    border: 1px solid var(--border2);
    border-radius: 20px;
    padding: 4px 10px 4px 6px;
    font-size: 12px;
    cursor: pointer;
    color: var(--text);
    transition: border-color 0.1s, background 0.1s;
}
.pfl-player:hover { border-color: var(--accent); }
.pfl-player.pfl-selected { background: var(--accent); color: #fff; border-color: var(--accent); }
.pfl-avatar {
    width: 22px; height: 22px;
    background: var(--border2);
    border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    font-size: 9px; font-weight: 700;
}
.pfl-player.pfl-selected .pfl-avatar { background: rgba(255,255,255,0.25); }

/* ---- Score-Anzeige im Ereignisse-Tab ---- */
.score-display {
    display: flex;
    align-items: center;
    gap: 4px;
    font-size: 20px;
    font-weight: 800;
    margin-left: auto;
}
.score-own  { color: var(--accent-text); }
.score-opp  { color: var(--danger); }
.score-sep  { color: var(--text-sec); }

/* ---- Event-Rückennummer ---- */
.event-nr { font-weight: 700; color: var(--accent-text); font-size: 11px; }
.event-opponent { color: var(--danger); font-style: italic; }

/* ---- Screenshot-Row ---- */
.lineup-screenshot-row {
    display: flex;
    justify-content: flex-end;
    margin-top: 8px;
}

/* ---- Squad Header Actions ---- */
.squad-header-actions {
    display: flex;
    align-items: center;
    gap: 6px;
    flex-wrap: wrap;
}
.btn-xs {
    padding: 3px 8px;
    font-size: 11px;
    border-radius: 6px;
}

/* ---- WhatsApp Toast ---- */
.toast-wa {
    display: flex;
    align-items: center;
    gap: 10px;
}
.toast-wa-btn {
    background: #25D366;
    color: #fff;
    border-radius: 6px;
    padding: 3px 8px;
    font-size: 12px;
    font-weight: 600;
    text-decoration: none;
    white-space: nowrap;
}

/* ---- Mobile Anpassungen für neue Features ---- */
@media (max-width: 767px) {
    .timer-row { flex-wrap: wrap; gap: 6px; }
    .timer-display { font-size: 36px; }
    .pitch-wrap.pitch-small  { max-width: 100%; }
    .pitch-wrap.pitch-medium { max-width: 100%; }
    .game-start-row { margin: 4px 0; }
    .score-display { font-size: 16px; }
}

/* ================================================================
   DASHBOARD-REDESIGN (Phase 4 — v0.8)
================================================================ */

/* Hero-Banner */
.db-hero {
    position: relative;
    overflow: hidden;
    background: linear-gradient(135deg, #0a1628 0%, #0d1f0d 60%, #091a09 100%);
    border-radius: var(--radius);
    padding: 28px 28px 24px;
    margin-bottom: 24px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    flex-wrap: wrap;
}
body:not(.dark) .db-hero {
    background: linear-gradient(135deg, #0f1f10 0%, #1a3a1a 60%, #102010 100%);
}

/* Spielfeld-Silhouette */
.db-pitch-bg {
    position: absolute;
    inset: 0;
    opacity: 0.06;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 600 400' fill='none' stroke='%234ade80'%3E%3Crect x='20' y='20' width='560' height='360' stroke-width='2'/%3E%3Cline x1='20' y1='200' x2='580' y2='200' stroke-width='1.5'/%3E%3Ccircle cx='300' cy='200' r='60' stroke-width='1.5'/%3E%3Ccircle cx='300' cy='200' r='4' fill='%234ade80' stroke='none'/%3E%3Crect x='20' y='130' width='100' height='140' stroke-width='1.5'/%3E%3Crect x='480' y='130' width='100' height='140' stroke-width='1.5'/%3E%3Crect x='20' y='163' width='44' height='74' stroke-width='1'/%3E%3Crect x='536' y='163' width='44' height='74' stroke-width='1'/%3E%3Ccircle cx='80' cy='200' r='3' fill='%234ade80' stroke='none' opacity='0.6'/%3E%3Ccircle cx='520' cy='200' r='3' fill='%234ade80' stroke='none' opacity='0.6'/%3E%3C/svg%3E");
    background-size: cover;
    background-position: center;
    pointer-events: none;
}

.db-hero-content {
    position: relative;
    z-index: 1;
}
.db-greeting {
    font-size: 13px;
    color: rgba(255,255,255,0.55);
    font-weight: 500;
    letter-spacing: 0.02em;
}
.db-username {
    font-family: 'Bebas Neue', 'Impact', sans-serif;
    font-size: 32px;
    color: #fff;
    letter-spacing: 0.04em;
    line-height: 1.1;
    margin-top: 2px;
}

/* Stat-Chips */
.db-stats {
    position: relative;
    z-index: 1;
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
}
.db-stat-chip {
    background: rgba(255,255,255,0.08);
    border: 1px solid rgba(255,255,255,0.12);
    border-radius: 10px;
    padding: 10px 16px;
    text-align: center;
    min-width: 68px;
    backdrop-filter: blur(4px);
}
.db-stat-num {
    display: block;
    font-family: 'Bebas Neue', 'Impact', sans-serif;
    font-size: 26px;
    color: var(--accent-text, #4ade80);
    line-height: 1;
}
.db-stat-label {
    display: block;
    font-size: 10px;
    color: rgba(255,255,255,0.5);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    margin-top: 2px;
}

/* Dashboard-Sektion */
.db-section {
    margin-bottom: 24px;
}
.db-section-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 14px;
}
.db-section-title {
    font-family: 'Bebas Neue', 'Impact', sans-serif;
    font-size: 17px;
    letter-spacing: 0.06em;
    color: var(--text-sec);
}

/* Team-Card Badges */
.tc-badge {
    display: inline-block;
    background: var(--accent-bg);
    color: var(--accent-text);
    border-radius: 5px;
    font-size: 11px;
    padding: 1px 7px;
    font-weight: 600;
    margin-right: 4px;
}
.tc-badge-sec {
    background: var(--surface2);
    color: var(--text-sec);
    border: 1px solid var(--border);
}

/* ================================================================
   GAST-BANNER (Share-Link Modus)
================================================================ */
.guest-banner {
    display: flex;
    align-items: center;
    gap: 10px;
    background: linear-gradient(90deg, rgba(74,222,128,0.1) 0%, transparent 100%);
    border: 1px solid rgba(74,222,128,0.25);
    border-radius: var(--radius);
    padding: 10px 16px;
    margin-bottom: 12px;
    font-size: 13px;
}
.gb-icon { font-size: 16px; flex-shrink: 0; }
.gb-text { font-weight: 700; color: var(--accent-text); }
.gb-hint {
    margin-left: auto;
    font-size: 11px;
    color: var(--text-sec);
    white-space: nowrap;
}
@media (max-width: 600px) {
    .gb-hint { display: none; }
    .db-hero { padding: 20px 16px 18px; }
    .db-username { font-size: 24px; }
    .db-stat-chip { padding: 8px 12px; min-width: 56px; }
    .db-stat-num { font-size: 20px; }
}

/* ================================================================
   SHARE-BUTTON (aktiver Link)
================================================================ */
/* Share-Button: eigenständiger auffälliger Stil */
.btn-share {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 7px 14px;
    border-radius: var(--radius-sm);
    font-size: 13px;
    font-weight: 700;
    cursor: pointer;
    border: 1px solid rgba(74,222,128,0.5);
    background: rgba(74,222,128,0.1);
    color: var(--accent-text);
    transition: background 0.15s, border-color 0.15s, box-shadow 0.15s;
    letter-spacing: 0.01em;
}
.btn-share:hover {
    background: rgba(74,222,128,0.18);
    border-color: var(--accent);
    box-shadow: 0 0 12px rgba(74,222,128,0.2);
}
/* Pulsierender Glow wenn Link aktiv ist */
.btn-share.share-active {
    background: rgba(74,222,128,0.15);
    border-color: var(--accent);
    animation: share-pulse 2s ease-in-out infinite;
}
@keyframes share-pulse {
    0%, 100% { box-shadow: 0 0 0 0 rgba(74,222,128,0.3); }
    50%       { box-shadow: 0 0 0 6px rgba(74,222,128,0); }
}
.btn-share.btn-sm { padding: 5px 10px; font-size: 12px; }
.share-url-box {
    display: flex;
    gap: 8px;
    align-items: center;
}
.share-info-box {
    background: var(--surface2);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    padding: 10px 14px;
    display: flex;
    flex-direction: column;
    gap: 6px;
}
.share-info-row {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 13px;
    font-weight: 500;
    color: var(--text);
}
.share-info-warn { color: var(--warn); font-weight: 600; }

/* ---- Mobile-Title Logo-Alignment ---- */
#mobileTitle {
    display: flex;
    align-items: center;
    gap: 10px;
}
#mobileTitle .wsv-logo-mobile {
    flex-shrink: 0;
}
#mobileTitle .logo-text {
    line-height: 1;
}

/* ---- Sidebar Copyright ---- */
.sidebar-copyright {
    font-size: 10px;
    color: var(--text-dim);
    line-height: 1.5;
    padding: 8px 0 2px;
    text-align: center;
    opacity: 0.6;
}
.sidebar-copyright a.impressum-link {
    color: var(--text-dim);
    text-decoration: underline;
    opacity: 0.8;
}
.sidebar-copyright a.impressum-link:hover { opacity: 1; }
.auth-copyright {
    margin-top: 20px;
    font-size: 11px;
    color: rgba(255,255,255,0.25);
    text-align: center;
}
.auth-copyright a { color: rgba(255,255,255,0.45); text-decoration: underline; }
.auth-copyright a:hover { color: rgba(255,255,255,0.7); }
.impressum-content h3 { font-size: 14px; color: var(--accent-text); margin: 0 0 8px; text-transform: uppercase; letter-spacing: .05em; }
.impressum-content p { font-size: 13px; color: var(--text-sec); line-height: 1.6; margin: 0 0 10px; }
.impressum-content a { color: var(--accent-text); }
.impressum-content ul { font-size: 13px; color: var(--text-sec); margin: 0 0 10px; }

/* ---- Spieltag-Header: Texte auf dunklem Hero-Hintergrund ---- */
.md-page-header .md-back          { color: rgba(255,255,255,0.5); }
.md-page-header .md-back:hover    { color: #4ade80; }
.md-page-header .md-hdr-home      { color: #fff; }
.md-page-header .md-hdr-away      { color: rgba(255,255,255,0.65); }
.md-page-header .md-hdr-num       { color: #fff; }
.md-page-header .md-hdr-sep       { color: rgba(255,255,255,0.4); }
.md-page-header .md-hdr-vs        { color: rgba(255,255,255,0.4); }
.md-page-header .md-meta          { color: rgba(255,255,255,0.45); }
.md-page-header .badge-locked     { background: rgba(74,222,128,0.15); color: #4ade80; border-color: rgba(74,222,128,0.3); }

/* ---- db-hero-action (Delete-Button im Hero) ---- */
.db-hero-action {
    color: rgba(255,255,255,0.5) !important;
    border-color: rgba(255,255,255,0.2) !important;
    font-size: 12px;
}
.db-hero-action:hover {
    color: var(--danger) !important;
    border-color: var(--danger) !important;
}

/* ---- Team Verwalten Button (im Hero) ---- */
.db-manage-btn {
    color: rgba(255,255,255,0.6) !important;
    border-color: rgba(255,255,255,0.2) !important;
    font-size: 12px;
    align-self: center;
}
.db-manage-btn:hover {
    color: #fff !important;
    border-color: rgba(255,255,255,0.4) !important;
    background: rgba(255,255,255,0.08) !important;
}

/* ---- Team Verwalten Menü (Modal-Inhalt) ---- */
.manage-menu {
    display: flex;
    flex-direction: column;
    gap: 4px;
}
.manage-item {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 12px 14px;
    border-radius: var(--radius-sm);
    border: 1px solid var(--border);
    background: var(--surface2);
    cursor: pointer;
    text-align: left;
    width: 100%;
    transition: background 0.15s, border-color 0.15s;
}
.manage-item:hover { background: var(--accent-bg); border-color: var(--accent); }
.mi-icon { font-size: 20px; flex-shrink: 0; width: 28px; text-align: center; }
.mi-label { font-weight: 700; font-size: 13px; color: var(--text); }
.mi-hint  { font-size: 11px; color: var(--text-sec); margin-top: 1px; }
.manage-separator {
    border-top: 1px solid var(--border);
    margin: 6px 0;
}
.manage-item-danger:hover { background: var(--danger-dim); border-color: var(--danger); }
.manage-item-danger:hover .mi-label { color: var(--danger); }

/* ================================================================
   KADER TAB — Neue Karten-Ansicht
================================================================ */

/* Sticky Header mit Fortschritt + Speichern-Button */
.squad-sticky-header {
    position: sticky;
    top: 0;
    z-index: 10;
    background: var(--surface);
    border-bottom: 1px solid var(--border);
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 10px 0 12px;
    margin-bottom: 14px;
}
body.dark .squad-sticky-header { background: var(--bg); }

.squad-progress-wrap { flex: 1; }
.squad-progress-label {
    font-size: 12px;
    color: var(--text-sec);
    font-weight: 700;
    letter-spacing: 0.03em;
    margin-bottom: 6px;
}
.squad-progress-label #squadCount {
    font-size: 18px;
    color: var(--accent);
    font-family: 'Bebas Neue', sans-serif;
    letter-spacing: 0.05em;
}
.squad-progress-bar {
    height: 5px;
    background: var(--border);
    border-radius: 99px;
    overflow: hidden;
}
.squad-progress-bar > div {
    height: 100%;
    background: var(--accent);
    border-radius: 99px;
    transition: width 0.3s ease;
}
.squad-locked-badge {
    font-size: 11px;
    font-weight: 700;
    color: var(--text-sec);
    white-space: nowrap;
}

/* "Kader übernehmen"-Button — prominent */
.squad-copy-btn {
    width: 100%;
    justify-content: center;
    margin-bottom: 10px;
    font-size: 13px;
    gap: 6px;
}

/* Kleine Aktions-Zeile */
.squad-actions-row {
    display: flex;
    align-items: center;
    gap: 6px;
    margin-bottom: 12px;
    flex-wrap: wrap;
}

/* Karten-Grid */
.squad-cards-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
    gap: 8px;
}

/* Einzelne Spieler-Karte */
.squad-card {
    display: flex;
    align-items: center;
    gap: 0;
    background: var(--surface2);
    border: 1.5px solid var(--border);
    border-radius: var(--radius-sm);
    cursor: pointer;
    overflow: hidden;
    transition: border-color 0.15s, background 0.15s, transform 0.1s;
    user-select: none;
    position: relative;
}
.squad-card:hover { border-color: var(--border2); transform: translateY(-1px); }
.squad-card.selected {
    border-color: var(--accent);
    background: var(--accent-bg);
}
.squad-card.selected .squad-check-icon { opacity: 1; }

/* Rückennummer-Badge links */
.squad-nr-badge {
    font-family: 'Bebas Neue', sans-serif;
    font-size: 15px;
    min-width: 36px;
    text-align: center;
    padding: 10px 0;
    color: var(--text-sec);
    background: var(--surface);
    border-right: 1px solid var(--border);
    flex-shrink: 0;
    transition: color 0.15s, background 0.15s;
}
.squad-card.selected .squad-nr-badge {
    color: var(--accent);
    background: var(--accent-bg);
    border-right-color: rgba(74,222,128,0.2);
}

/* Name */
.squad-card-name {
    flex: 1;
    font-size: 13px;
    font-weight: 600;
    padding: 10px 10px;
    color: var(--text);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

/* Häkchen rechts */
.squad-check-icon {
    font-size: 13px;
    color: var(--accent);
    padding: 0 10px;
    opacity: 0;
    transition: opacity 0.15s;
    flex-shrink: 0;
    font-weight: 700;
}

/* ================================================================
   DESIGN-POLISH: Sammelblock für alle visuellen Optimierungen
================================================================ */

/* --- 1. Auth-Screen: Pitch-Lines atmen --- */
.auth-pitch-lines {
    animation: pitchBreath 9s ease-in-out infinite;
}
@keyframes pitchBreath {
    0%, 100% { opacity: 0.9; transform: scale(1); }
    50%       { opacity: 0.6; transform: scale(1.025); }
}

/* --- 2. Mobile Bottom-Nav: aktiver Punkt --- */
.mob-nav-item { position: relative; }
.mob-nav-item.active::after {
    content: '';
    position: absolute;
    bottom: 5px;
    left: 50%;
    transform: translateX(-50%);
    width: 5px;
    height: 5px;
    border-radius: 50%;
    background: var(--accent-text);
}

/* --- 3. Admin-Tabelle: Zebrastreifen + besseres Hover --- */
.user-table tbody tr:nth-child(even) td { background: var(--surface2); }
.user-table tr:hover td { background: var(--accent-bg) !important; }

/* --- 4. Ereignisse: subtiler Farbhauch pro Typ --- */
.event-item[data-type="goal"] {
    background: linear-gradient(90deg, rgba(22,163,74,0.07) 0%, var(--surface) 45%);
}
.event-item[data-type="goal"][data-is-opponent="true"] {
    background: linear-gradient(90deg, rgba(249,115,22,0.07) 0%, var(--surface) 45%);
}
.event-item[data-type="yellow_card"] {
    background: linear-gradient(90deg, rgba(251,191,36,0.07) 0%, var(--surface) 45%);
}
.event-item[data-type="red_card"] {
    background: linear-gradient(90deg, rgba(220,38,38,0.07) 0%, var(--surface) 45%);
}
.event-item[data-type="substitution"] {
    background: linear-gradient(90deg, rgba(59,130,246,0.07) 0%, var(--surface) 45%);
}
.event-item[data-type="note"] {
    background: linear-gradient(90deg, rgba(139,92,246,0.06) 0%, var(--surface) 45%);
}
.event-item[data-type="formation_change"] {
    background: linear-gradient(90deg, rgba(6,182,212,0.06) 0%, var(--surface) 45%);
}

/* --- 5. Team-Card Avatar: größer, Bebas Neue --- */
.tc-avatar {
    width: 52px !important;
    height: 52px !important;
    font-family: 'Bebas Neue', 'Impact', sans-serif !important;
    font-size: 28px !important;
    border-radius: 14px !important;
    letter-spacing: 0.02em;
}

/* --- 6. Team-Card: Hover-Glow via Box-Shadow --- */
.team-card:hover {
    transform: translateY(-1px);
    box-shadow: 0 6px 24px rgba(0,0,0,0.12), 0 0 0 1px var(--accent) !important;
}
body.dark .team-card:hover {
    box-shadow: 0 6px 32px rgba(0,0,0,0.5), 0 0 0 1px var(--accent) !important;
}
.team-card { transition: border-color 0.15s, box-shadow 0.2s, transform 0.15s; }


/* ================================================================
   ONBOARDING — Einrichtungs-Wizard
================================================================ */
.ob-wrap {
    max-width: 560px;
    margin: 0 auto;
    padding: 24px 0 40px;
}

/* Fortschritts-Leiste */
.ob-progress {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0;
    margin-bottom: 32px;
    padding: 0 16px;
}
.ob-prog-step {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 6px;
    flex-shrink: 0;
}
.ob-prog-dot {
    width: 32px; height: 32px;
    border-radius: 50%;
    background: var(--surface2);
    border: 2px solid var(--border2);
    display: flex; align-items: center; justify-content: center;
    font-size: 13px; font-weight: 700;
    color: var(--text-sec);
    transition: all 0.2s;
}
.ob-prog-step.active .ob-prog-dot {
    background: var(--accent);
    border-color: var(--accent);
    color: #fff;
    box-shadow: 0 0 12px rgba(74,222,128,0.4);
}
.ob-prog-step.done .ob-prog-dot {
    background: var(--accent-bg);
    border-color: var(--accent);
    color: var(--accent-text);
}
.ob-prog-label {
    font-size: 11px;
    font-weight: 600;
    color: var(--text-sec);
    white-space: nowrap;
}
.ob-prog-step.active .ob-prog-label { color: var(--accent-text); }
.ob-prog-line {
    flex: 1;
    height: 2px;
    background: var(--border2);
    min-width: 20px;
    max-width: 60px;
    margin-bottom: 18px;
    margin-left: 4px;
    margin-right: 4px;
}

/* Card */
.ob-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 28px 28px 24px;
    box-shadow: var(--shadow-md);
}

/* Hero (Schritt 1) */
.ob-hero {
    text-align: center;
    margin-bottom: 24px;
}
.ob-hero-crest {
    font-size: 48px;
    margin-bottom: 12px;
    display: block;
}
.ob-step-icon {
    font-size: 40px;
    text-align: center;
    margin-bottom: 12px;
}
.ob-title {
    font-family: 'Bebas Neue', 'Impact', sans-serif;
    font-size: 28px;
    letter-spacing: 0.03em;
    line-height: 1.1;
    color: var(--text);
    margin-bottom: 6px;
    text-align: center;
}
.ob-sub {
    font-size: 13px;
    color: var(--text-sec);
    text-align: center;
    margin-bottom: 0;
}

/* Feature-Kacheln (Schritt 1) */
.ob-features {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
    margin: 20px 0 24px;
}
.ob-feature {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    background: var(--surface2);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    padding: 12px;
}
.ob-feat-icon { font-size: 20px; flex-shrink: 0; }
.ob-feat-title { font-size: 13px; font-weight: 700; color: var(--text); }
.ob-feat-desc { font-size: 12px; color: var(--text-sec); margin-top: 2px; line-height: 1.4; }

/* CSV-Hinweis */
.ob-two-col {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
    margin-bottom: 4px;
}
.ob-label {
    display: block;
    font-size: 12px;
    font-weight: 700;
    color: var(--text-sec);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-bottom: 7px;
}
.ob-team-types {
    display: flex;
    flex-wrap: wrap;
    gap: 7px;
}
.ob-team-types--sm .ob-type-chip { font-size: 11px; padding: 4px 9px; }
.ob-type-chip {
    background: var(--surface2);
    border: 1px solid var(--border2);
    color: var(--text-sec);
    border-radius: 20px;
    padding: 5px 12px;
    font-size: 12px;
    font-weight: 600;
    cursor: pointer;
    transition: background 0.15s, border-color 0.15s, color 0.15s;
}
.ob-type-chip:hover { border-color: var(--accent-text); color: var(--accent-text); }
.ob-type-chip.active {
    background: var(--accent-bg);
    border-color: var(--accent-text);
    color: var(--accent-text);
}
.ob-csv-hint {
    background: var(--surface2);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    padding: 10px 14px;
    font-size: 12px;
    color: var(--text);
    margin-bottom: 4px;
    line-height: 1.5;
}
.ob-file-btn {
    cursor: pointer;
    display: inline-block;
}
.ob-csv-result {
    display: flex;
    gap: 12px;
    align-items: center;
    margin-top: 8px;
    font-size: 12px;
    font-weight: 600;
}
.ob-csv-ok { color: var(--accent-text); }
.ob-csv-err { color: var(--warn); }

/* CTA-Button + Skip-Link */
.ob-cta { margin-top: 20px; }
.ob-skip {
    display: block;
    width: 100%;
    text-align: center;
    margin-top: 10px;
    color: var(--text-sec);
    font-size: 12px;
}

/* Fertig-Screen (Schritt 4) */
.ob-done { text-align: center; }
.ob-done-icon { font-size: 56px; display: block; margin-bottom: 12px; }
.ob-next-steps {
    text-align: left;
    display: flex;
    flex-direction: column;
    gap: 10px;
    margin: 20px 0 4px;
}
.ob-next {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    background: var(--surface2);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    padding: 10px 14px;
}
.ob-next-num {
    width: 24px; height: 24px;
    background: var(--accent);
    color: #fff;
    border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    font-size: 12px; font-weight: 800;
    flex-shrink: 0;
    margin-top: 1px;
}
.ob-next-title { font-size: 13px; font-weight: 700; color: var(--text); }
.ob-next-desc { font-size: 12px; color: var(--text-sec); margin-top: 1px; }

/* Mobile */
@media (max-width: 768px) {
    .ob-wrap { padding: 16px; }
    .ob-card { padding: 20px 16px; }
    .ob-features { grid-template-columns: 1fr; }
    .ob-title { font-size: 22px; }
    .ob-prog-line { min-width: 12px; max-width: 30px; }
}

/* ================================================================
   GUIDED TOUR BANNER
================================================================ */
.tour-banner {
    margin: 16px 24px 0;
    background: linear-gradient(135deg, rgba(74,222,128,0.08) 0%, var(--surface) 100%);
    border: 1px solid rgba(74,222,128,0.35);
    border-left: 4px solid var(--accent-text);
    border-radius: var(--radius);
    padding: 16px 18px;
    display: flex;
    flex-direction: column;
    gap: 8px;
}
.tour-banner-head {
    display: flex;
    align-items: center;
    gap: 8px;
}
.tour-banner-icon { font-size: 20px; }
.tour-step-label {
    font-size: 11px;
    font-weight: 700;
    color: var(--accent-text);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    flex: 1;
}
.tour-skip {
    background: none;
    border: none;
    color: var(--text-sec);
    font-size: 11px;
    cursor: pointer;
    padding: 2px 4px;
    border-radius: 4px;
    transition: color 0.15s;
}
.tour-skip:hover { color: var(--danger); }
.tour-banner-title {
    font-family: 'Bebas Neue', sans-serif;
    font-size: 18px;
    letter-spacing: 0.04em;
    color: var(--text);
}
.tour-banner-text {
    font-size: 13px;
    color: var(--text-sec);
    line-height: 1.55;
}
.tour-next { align-self: flex-start; margin-top: 4px; }

/* ================================================================
   SEITEN-HINWEIS-BANNER (einmalig)
================================================================ */
.page-hint {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    background: var(--accent-bg);
    border: 1px solid rgba(74,222,128,0.25);
    border-radius: var(--radius-sm);
    padding: 10px 14px;
    margin-bottom: 16px;
    transition: opacity 0.3s;
}
.page-hint-body {
    display: flex;
    align-items: center;
    gap: 10px;
    flex: 1;
    min-width: 0;
}
.page-hint-icon { font-size: 18px; flex-shrink: 0; }
.page-hint-text {
    font-size: 12px;
    color: var(--text);
    line-height: 1.4;
    overflow: hidden;
}
.page-hint-text strong { color: var(--accent-text); }
.page-hint-close {
    background: none;
    border: none;
    color: var(--text-sec);
    cursor: pointer;
    font-size: 14px;
    padding: 2px 4px;
    flex-shrink: 0;
    transition: color 0.15s;
}
.page-hint-close:hover { color: var(--text); }

/* Assistent-Link (immer unter dem Banner) */
.assistant-link-row {
    text-align: center;
    padding: 6px 0 2px;
}
.assistant-link {
    font-size: 12px;
    color: var(--text-sec);
    text-decoration: none;
    opacity: 0.7;
    transition: opacity 0.15s;
}
.assistant-link:hover { opacity: 1; color: var(--accent); }

/* Help-Modal */
.help-list {
    display: flex;
    flex-direction: column;
    gap: 10px;
    padding: 4px 0;
}
.help-item {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    padding: 10px 12px;
    background: var(--surface2);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    font-size: 13px;
    color: var(--text);
    line-height: 1.4;
}
.help-icon { font-size: 18px; flex-shrink: 0; width: 24px; text-align: center; }
