/* ============================================================
   Vereinsmanager Dashboard
   Design: Untitled UI inspired
   Version: 2.0.0
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Material+Symbols+Outlined:opsz,wght,FILL,GRAD@20..48,100..700,0..1,-50..200');

/* ── WP CORE OVERRIDE: Remove is-layout-flow top margin ──────────────── */
/* Override WP's is-layout-flow margin and any auto vertical margin within our plugin */
.vm-dash :where(.is-layout-flow) > *,
.vm-dash * :where(.is-layout-flow) > *,
.vm-dash .vm-content > *,
.vm-dash .vm-content :where(.is-layout-flow) > *,
.vm-content :where(.is-layout-flow) > *,
.vm-dash .vm-card,
.vm-dash .vm-card:first-child,
.vm-dash [class*="-grid"] > *,
.vm-dash [class*="-grid"] > *:first-child,
#vm-view-home > *, #vm-view-mitglieder > *, #vm-view-teams > *,
#vm-view-spieltage > *, #vm-view-verguetungen > *,
#vm-view-home :where(.is-layout-flow) > *,
#vm-view-teams :where(.is-layout-flow) > *,
#vm-view-mitglieder :where(.is-layout-flow) > *,
#vm-view-spieltage :where(.is-layout-flow) > *,
#vm-view-verguetungen :where(.is-layout-flow) > *,
.vm-dash > * { margin-block-start: 0 !important; margin-top: 0 !important; }
/* Keep material icons safe */
.material-symbols-outlined,
.material-icons,
.material-icons-outlined { margin-block-start: 0 !important; margin-block-end: 0 !important; }


:root {
    --vm-font:        'Inter', -apple-system, sans-serif;
    --vm-gray-25:     #FCFCFD;
    --vm-gray-50:     #F9FAFB;
    --vm-gray-100:    #F2F4F7;
    --vm-gray-200:    #EAECF0;
    --vm-gray-300:    #D0D5DD;
    --vm-gray-400:    #98A2B3;
    --vm-gray-500:    #667085;
    --vm-gray-600:    #475467;
    --vm-gray-700:    #344054;
    --vm-gray-800:    #1D2939;
    --vm-gray-900:    #101828;
    --vm-p-50:        #ECFDFF;
    --vm-p-100:       #CFF9FE;
    --vm-p-500:       #06AED4;
    --vm-p-600:       #0E7090;
    --vm-p-700:       #164C63;
    --vm-ok-50:       #ECFDF3;
    --vm-ok-700:      #027A48;
    --vm-warn-50:     #FFFAEB;
    --vm-warn-700:    #B54708;
    --vm-err-50:      #FEF3F2;
    --vm-err-500:     #F04438;
    --vm-err-700:     #B42318;
    --vm-sidebar-w:   280px;
    --vm-sidebar-col: 72px;
    --vm-topbar-h:    64px;
    --vm-r-sm:        6px;
    --vm-r-md:        8px;
    --vm-r-lg:        12px;
    --vm-r-xl:        16px;
    --vm-shadow-xs:   0 1px 2px rgba(16,24,40,.05);
    --vm-shadow-sm:   0 1px 3px rgba(16,24,40,.1),0 1px 2px rgba(16,24,40,.06);
    --vm-shadow-xl:   0 20px 24px -4px rgba(16,24,40,.08),0 8px 8px -4px rgba(16,24,40,.03);
}

.vm-dash * { box-sizing: border-box; margin: 0; padding: 0; }

.vm-dash {
    font-family: var(--vm-font);
    font-size: 14px;
    color: var(--vm-gray-900);
    background: var(--vm-gray-50);
    height: 100vh;
    max-height: 100vh;
    display: flex;
    position: relative;
    line-height: 1.5;
    overflow: hidden;
}

/* ── SIDEBAR ─────────────────────────────────────────────── */
.vm-sidebar {
    width: var(--vm-sidebar-w);
    background: #fff;
    border-right: 1px solid var(--vm-gray-200);
    display: flex;
    flex-direction: column;
    transition: width .2s ease;
    flex-shrink: 0;
    position: relative;
    z-index: 100;
}
.vm-sidebar.collapsed { width: var(--vm-sidebar-col); }

.vm-sb-head {
    height: var(--vm-topbar-h);
    padding: 0 16px 0 20px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    border-bottom: 1px solid var(--vm-gray-200);
    flex-shrink: 0;
    gap: 8px;
    transition: padding .2s;
}
.vm-sidebar.collapsed .vm-sb-head { padding: 0 12px; justify-content: center; }

.vm-sb-logo {
    display: flex;
    align-items: center;
    gap: 10px;
    overflow: hidden;
    min-width: 0;
}

.vm-sb-logo-icon {
    width: 36px; height: 36px;
    background: var(--vm-p-600);
    border-radius: var(--vm-r-md);
    display: flex; align-items: center; justify-content: center;
    flex-shrink: 0;
    overflow: hidden;
    padding: 4px;
}
.vm-sb-logo-icon .material-symbols-outlined { font-size: 18px; color: #fff; }
.vm-sb-logo-icon img { width: 100%; height: 100%; object-fit: contain; border-radius: 4px; }

.vm-sb-toggle {
    width: 28px; height: 28px;
    border: 1px solid var(--vm-gray-200);
    border-radius: var(--vm-r-sm);
    background: #fff;
    cursor: pointer;
    display: flex; align-items: center; justify-content: center;
    flex-shrink: 0;
    transition: background .12s;
}
.vm-sb-toggle:hover { background: var(--vm-gray-50); }
.vm-sb-toggle .material-symbols-outlined { font-size: 16px; color: var(--vm-gray-500); }

.vm-sb-nav { flex: 1; padding: 12px 10px; overflow-y: auto; overflow-x: hidden; }

.vm-nav-sep {
    font-size: 11px; font-weight: 600;
    letter-spacing: .06em; text-transform: uppercase;
    color: var(--vm-gray-400);
    padding: 10px 10px 4px;
    white-space: nowrap;
    transition: opacity .15s;
}
.vm-sidebar.collapsed .vm-nav-sep { opacity: 0; }

.vm-nav-item {
    display: flex; align-items: center; gap: 10px;
    padding: 8px 10px;
    border-radius: var(--vm-r-md);
    cursor: pointer;
    border: none; background: none;
    width: 100%; text-align: left;
    color: var(--vm-gray-600);
    font-family: var(--vm-font);
    font-size: 14px; font-weight: 500;
    transition: background .12s, color .12s;
    white-space: nowrap;
    position: relative;
}
.vm-nav-item:hover { background: var(--vm-gray-50); color: var(--vm-gray-900); }
.vm-nav-item.active { background: var(--vm-p-50); color: var(--vm-p-700); }
.vm-nav-item .material-symbols-outlined {
    font-size: 20px; flex-shrink: 0;
    font-variation-settings: 'FILL' 0,'wght' 400,'GRAD' 0,'opsz' 20;
}
.vm-nav-item.active .material-symbols-outlined {
    font-variation-settings: 'FILL' 1,'wght' 400,'GRAD' 0,'opsz' 20;
}
.vm-nav-label { transition: opacity .15s, max-width .2s; max-width: 160px; overflow: hidden; }
.vm-sidebar.collapsed .vm-nav-label { opacity: 0; max-width: 0; }

.vm-sidebar.collapsed .vm-nav-item:hover::after {
    content: attr(data-label);
    position: absolute;
    left: calc(100% + 8px);
    top: 50%; transform: translateY(-50%);
    background: var(--vm-gray-900); color: #fff;
    padding: 5px 10px; border-radius: var(--vm-r-sm);
    font-size: 13px; white-space: nowrap; z-index: 300;
    pointer-events: none;
    box-shadow: var(--vm-shadow-sm);
}

.vm-sb-foot {
    padding: 12px 10px;
    border-top: 1px solid var(--vm-gray-200);
}

.vm-sb-user {
    display: flex; align-items: center; gap: 10px;
    padding: 8px 10px; border-radius: var(--vm-r-md);
    overflow: hidden;
}
.vm-user-avatar {
    width: 34px; height: 34px; border-radius: 50%;
    background: var(--vm-p-100); color: var(--vm-p-700);
    display: flex; align-items: center; justify-content: center;
    font-size: 13px; font-weight: 600; flex-shrink: 0;
}
.vm-user-info { overflow: hidden; min-width: 0; transition: opacity .15s; }
.vm-sidebar.collapsed .vm-user-info { opacity: 0; }
.vm-user-name { font-size: 13px; font-weight: 600; color: var(--vm-gray-700); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.vm-user-role { font-size: 11px; color: var(--vm-gray-500); white-space: nowrap; }

/* ── MAIN ────────────────────────────────────────────────── */
.vm-main { flex: 1; min-width: 0; display: flex; flex-direction: column; overflow: hidden; }

.vm-topbar {
    height: var(--vm-topbar-h);
    background: #fff;
    border-bottom: 1px solid var(--vm-gray-200);
    padding: 0 24px;
    display: flex; align-items: center; justify-content: space-between;
    flex-shrink: 0; gap: 12px;
}

.vm-topbar-left { display: flex; align-items: center; gap: 12px; }

.vm-mobile-btn {
    display: none; width: 36px; height: 36px;
    border: 1px solid var(--vm-gray-200); border-radius: var(--vm-r-sm);
    background: #fff; cursor: pointer;
    align-items: center; justify-content: center;
}
.vm-mobile-btn .material-symbols-outlined { font-size: 20px; color: var(--vm-gray-600); }

.vm-topbar-title { font-size: 18px; font-weight: 600; color: var(--vm-gray-900); }

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

.vm-content { flex: 1; padding: 24px; overflow-y: auto; height: calc(100vh - var(--vm-topbar-h)); }

.vm-view { display: none; }
.vm-view.active { display: block; }

/* ── PAGE HEADER ─────────────────────────────────────────── */
.vm-ph {
    display: flex; align-items: flex-start;
    justify-content: space-between;
    margin-bottom: 20px; gap: 16px; flex-wrap: wrap;
}
.vm-ph h1 { font-size: 20px; font-weight: 600; color: var(--vm-gray-900); margin-bottom: 2px; }
.vm-ph p  { font-size: 14px; color: var(--vm-gray-500); }
.vm-ph-actions { display: flex; gap: 8px; flex-wrap: wrap; }

/* ── STATS ───────────────────────────────────────────────── */
.vm-stats {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px,1fr));
    gap: 16px; margin-bottom: 24px;
}
.vm-stat {
    background: #fff; border: 1px solid var(--vm-gray-200);
    border-radius: var(--vm-r-lg); padding: 20px;
    box-shadow: var(--vm-shadow-xs);
}
.vm-stat-lbl {
    font-size: 12px; font-weight: 600; color: var(--vm-gray-500);
    text-transform: uppercase; letter-spacing: .04em;
    margin-bottom: 10px; display: flex; align-items: center; gap: 6px;
}
.vm-stat-lbl .material-symbols-outlined { font-size: 16px; }
.vm-stat-val { font-size: 28px; font-weight: 600; color: var(--vm-gray-900); line-height: 1; }
.vm-stat-sub { font-size: 12px; color: var(--vm-gray-400); margin-top: 4px; }

/* ── CARD ────────────────────────────────────────────────── */
.vm-card {
    background: #fff; border: 1px solid var(--vm-gray-200);
    border-radius: var(--vm-r-lg); box-shadow: var(--vm-shadow-xs);
    overflow: hidden;
}
.vm-card + .vm-card { margin-top: 16px; }
.vm-card-head {
    padding: 14px 20px;
    border-bottom: 1px solid var(--vm-gray-200);
    display: flex; align-items: center; justify-content: space-between;
    gap: 12px; flex-wrap: wrap;
}
.vm-card-title { font-size: 15px; font-weight: 600; color: var(--vm-gray-900); display: flex; align-items: center; gap: 8px; }
.vm-card-title .material-symbols-outlined { font-size: 18px; color: var(--vm-gray-400); }

/* ── TOOLBAR ─────────────────────────────────────────────── */
.vm-tb {
    padding: 12px 20px;
    display: flex; gap: 10px; flex-wrap: wrap;
    border-bottom: 1px solid var(--vm-gray-200);
    background: var(--vm-gray-25);
}

/* ── INPUT / SELECT / TEXTAREA ───────────────────────────── */
.vm-inp, .vm-sel, .vm-ta {
    width: 100%;
    padding: 9px 13px;
    border: 1px solid var(--vm-gray-300);
    border-radius: var(--vm-r-sm);
    font-size: 14px; font-family: var(--vm-font);
    color: var(--vm-gray-900); background: #fff;
    outline: none; transition: border-color .15s, box-shadow .15s;
    box-shadow: var(--vm-shadow-xs);
}
.vm-inp::placeholder { color: var(--vm-gray-400); }
.vm-inp:focus, .vm-sel:focus, .vm-ta:focus {
    border-color: var(--vm-p-500);
    box-shadow: 0 0 0 3px rgba(6,174,212,.12);
}
.vm-ta { resize: vertical; min-height: 80px; line-height: 1.5; }

.vm-inp-wrap { position: relative; }
.vm-inp-icon {
    position: absolute; left: 11px; top: 50%; transform: translateY(-50%);
    color: var(--vm-gray-400); pointer-events: none;
}
.vm-inp-icon .material-symbols-outlined { font-size: 17px; }
.vm-inp-icon-pad { padding-left: 36px !important; }

.vm-inp-row { display: flex; gap: 8px; }
.vm-inp-row .vm-inp { flex: 1; }

/* ── BUTTONS ─────────────────────────────────────────────── */
.vm-btn {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 9px 16px; border-radius: var(--vm-r-sm);
    font-size: 14px; font-weight: 600; font-family: var(--vm-font);
    cursor: pointer; border: 1px solid transparent;
    transition: all .12s; white-space: nowrap;
    line-height: 1; box-shadow: var(--vm-shadow-xs);
}
.vm-btn:disabled { opacity: .5; cursor: not-allowed; }
.vm-btn:active:not(:disabled) { transform: scale(.98); }
.vm-btn .material-symbols-outlined { font-size: 16px; }

.vm-btn-primary   { background: var(--vm-p-600); color: #fff; border-color: var(--vm-p-600); }
.vm-btn-primary:hover:not(:disabled) { background: var(--vm-p-700); border-color: var(--vm-p-700); }

.vm-btn-secondary { background: #fff; color: var(--vm-gray-700); border-color: var(--vm-gray-300); }
.vm-btn-secondary:hover:not(:disabled) { background: var(--vm-gray-50); }

.vm-btn-danger    { background: var(--vm-err-500); color: #fff; border-color: var(--vm-err-500); }
.vm-btn-danger:hover:not(:disabled)   { background: var(--vm-err-700); border-color: var(--vm-err-700); }

.vm-btn-ghost     { background: none; border-color: transparent; color: var(--vm-gray-600); box-shadow: none; }
.vm-btn-ghost:hover:not(:disabled) { background: var(--vm-gray-100); }

.vm-btn-sm { padding: 6px 12px; font-size: 13px; }

.vm-ibtn {
    width: 32px; height: 32px;
    display: inline-flex; align-items: center; justify-content: center;
    border: none; background: none; border-radius: var(--vm-r-sm);
    cursor: pointer; color: var(--vm-gray-400);
    transition: background .12s, color .12s;
}
.vm-ibtn:hover { background: var(--vm-gray-100); color: var(--vm-gray-700); }
.vm-ibtn.del:hover { background: var(--vm-err-50); color: var(--vm-err-500); }
.vm-ibtn .material-symbols-outlined { font-size: 18px; }

/* ── TABLE ───────────────────────────────────────────────── */
.vm-tbl-wrap { overflow-x: auto; }
.vm-tbl {
    width: 100%; border-collapse: collapse; font-size: 14px;
}
.vm-tbl th {
    padding: 10px 16px; text-align: left;
    font-size: 11px; font-weight: 600; color: var(--vm-gray-500);
    text-transform: uppercase; letter-spacing: .05em;
    border-bottom: 1px solid var(--vm-gray-200);
    background: var(--vm-gray-25); white-space: nowrap;
}
.vm-tbl th.s { cursor: pointer; user-select: none; }
.vm-tbl th.s:hover { color: var(--vm-gray-700); }
.vm-tbl th.sa::after { content: ' \2191'; }
.vm-tbl th.sd::after { content: ' \2193'; }
.vm-tbl td {
    padding: 12px 16px;
    border-bottom: 1px solid var(--vm-gray-200);
    color: var(--vm-gray-700); vertical-align: middle;
}
.vm-tbl tbody tr:last-child td { border-bottom: none; }
.vm-tbl tbody tr:hover td { background: var(--vm-gray-25); }
.vm-tbl td.r, .vm-tbl th.r { text-align: right; white-space: nowrap; }
.vm-tbl td.mono { font-family: 'SF Mono',monospace; font-size: 12px; color: var(--vm-gray-400); }
.vm-tbl-name strong { color: var(--vm-gray-900); font-weight: 600; }
.vm-tbl-sub { font-size: 12px; color: var(--vm-gray-400); }

/* ── STAT-BOX (Snapshot) ─────────────────────────────────── */
.vm-stat-box {
    border-radius: var(--vm-r-lg);
    padding: 16px;
    text-align: center;
    border: 1px solid var(--vm-gray-200);
    background: var(--vm-gray-50);
}
.vm-stat-box.is-ok  { background: var(--vm-ok-50);  border-color: #A9EFC5; }
.vm-stat-box.is-err { background: #fef2f2;           border-color: #fecaca; }
.vm-stat-box.is-p   { background: var(--vm-p-50);   border-color: var(--vm-p-100); }

.vm-stat-value {
    font-size: 24px;
    font-weight: 600;
    line-height: 1;
    color: var(--vm-gray-900);
}
.vm-stat-value.is-ok  { color: #15803d; }
.vm-stat-value.is-err { color: #b91c1c; }
.vm-stat-value.is-p   { color: var(--vm-p-700); }
.vm-stat-value.is-neg { color: #b91c1c; }

.vm-stat-label {
    font-size: 12px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .04em;
    color: var(--vm-gray-500);
    margin-top: 6px;
}

/* ── BADGE ───────────────────────────────────────────────── */
.vm-badge {
    display: inline-flex; align-items: center; gap: 4px;
    padding: 2px 8px; border-radius: 16px;
    font-size: 12px; font-weight: 500; white-space: nowrap;
}
.vm-badge .material-symbols-outlined { font-size: 12px; }
.vm-badge-ok   { background: var(--vm-ok-50);   color: var(--vm-ok-700); }
.vm-badge-warn { background: var(--vm-warn-50);  color: var(--vm-warn-700); }
.vm-badge-err  { background: var(--vm-err-50);   color: var(--vm-err-700); }
.vm-badge-gray { background: var(--vm-gray-100); color: var(--vm-gray-700); }
.vm-badge-blue { background: var(--vm-p-50);     color: var(--vm-p-700); }

/* ── LOADING / EMPTY ─────────────────────────────────────── */
.vm-loading {
    display: flex; align-items: center; justify-content: center;
    gap: 12px; padding: 48px; color: var(--vm-gray-400);
}
.vm-spinner {
    width: 20px; height: 20px;
    border: 2px solid var(--vm-gray-200);
    border-top-color: var(--vm-p-500);
    border-radius: 50%;
    animation: vm-spin .7s linear infinite;
}
@keyframes vm-spin { to { transform: rotate(360deg); } }

.vm-empty {
    display: flex; flex-direction: column;
    align-items: center; justify-content: center;
    padding: 48px 24px; gap: 10px; text-align: center;
}
.vm-empty .material-symbols-outlined { font-size: 40px; color: var(--vm-gray-300); }
.vm-empty p { font-size: 14px; color: var(--vm-gray-400); }

/* ── PAGINATION ──────────────────────────────────────────── */
.vm-pag {
    display: flex; align-items: center; justify-content: space-between;
    padding: 12px 20px; border-top: 1px solid var(--vm-gray-200);
    font-size: 13px; color: var(--vm-gray-500); gap: 8px; flex-wrap: wrap;
}
.vm-pag-btns { display: flex; gap: 4px; }
.vm-pag-btn {
    min-width: 32px; height: 32px; padding: 0 8px;
    border: 1px solid var(--vm-gray-300); border-radius: var(--vm-r-sm);
    background: #fff; color: var(--vm-gray-600);
    font-size: 13px; font-family: var(--vm-font);
    cursor: pointer; display: flex; align-items: center; justify-content: center;
    transition: all .12s;
}
.vm-pag-btn:hover { background: var(--vm-gray-50); }
.vm-pag-btn.on { background: var(--vm-p-50); color: var(--vm-p-700); border-color: var(--vm-p-100); font-weight: 600; }

/* ── TABS ────────────────────────────────────────────────── */
.vm-tabs { display: flex; border-bottom: 1px solid var(--vm-gray-200); padding: 0 20px; }
.vm-tab {
    padding: 12px 14px; font-size: 14px; font-weight: 500;
    font-family: var(--vm-font); color: var(--vm-gray-500);
    cursor: pointer; border: none; background: none;
    border-bottom: 2px solid transparent; margin-bottom: -1px;
    transition: color .12s, border-color .12s;
    display: flex; align-items: center; gap: 6px; white-space: nowrap;
}
.vm-tab .material-symbols-outlined { font-size: 16px; }
.vm-tab:hover { color: var(--vm-gray-700); }
.vm-tab.on { color: var(--vm-p-700); border-bottom-color: var(--vm-p-600); }
.vm-tab-panel { display: none; }
.vm-tab-panel.on { display: block; padding-top: 20px; }

/* ── MODAL ───────────────────────────────────────────────── */
.vm-overlay {
    position: fixed; inset: 0;
    background: rgba(52,64,84,.6);
    z-index: 1000;
    display: flex; align-items: center; justify-content: center;
    padding: 16px;
    backdrop-filter: blur(3px);
}
.vm-modal {
    background: #fff; border-radius: var(--vm-r-xl);
    box-shadow: var(--vm-shadow-xl);
    width: 100%; max-width: 680px; max-height: 92vh;
    display: flex; flex-direction: column; overflow: hidden;
    animation: vm-modal-in .18s ease;
}
@keyframes vm-modal-in {
    from { opacity:0; transform:translateY(16px) scale(.98); }
    to   { opacity:1; transform:none; }
}
.vm-modal-sm { max-width: 480px; }
.vm-modal-lg { max-width: 860px; }

.vm-modal-head {
    padding: 20px 24px 16px;
    border-bottom: 1px solid var(--vm-gray-200);
    display: flex; align-items: center; justify-content: space-between;
    flex-shrink: 0;
}
.vm-modal-head h3 { font-size: 16px; font-weight: 600; color: var(--vm-gray-900); }
.vm-mclose {
    width: 32px; height: 32px; border: none; background: none;
    border-radius: var(--vm-r-sm); cursor: pointer; color: var(--vm-gray-400);
    display: flex; align-items: center; justify-content: center;
    transition: background .12s;
}
.vm-mclose:hover { background: var(--vm-gray-100); color: var(--vm-gray-600); }
.vm-mclose .material-symbols-outlined { font-size: 20px; }

.vm-modal-body { padding: 20px 24px; overflow-y: auto; flex: 1; }
.vm-modal-foot {
    padding: 14px 24px; border-top: 1px solid var(--vm-gray-200);
    display: flex; justify-content: flex-end; gap: 8px; flex-shrink: 0;
}

/* ── FORM ────────────────────────────────────────────────── */
.vm-fs {
    border: 1px solid var(--vm-gray-200);
    border-radius: var(--vm-r-md);
    padding: 14px 16px; margin-bottom: 14px;
}
.vm-fs legend {
    font-size: 11px; font-weight: 600;
    color: var(--vm-gray-500); text-transform: uppercase;
    letter-spacing: .06em; padding: 0 6px;
}
.vm-fg { display: flex; flex-direction: column; gap: 5px; }
.vm-fg-full { grid-column: 1 / -1; }
.vm-fgrid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.vm-lbl { font-size: 13px; font-weight: 500; color: var(--vm-gray-700); }
.vm-req { color: var(--vm-err-500); margin-left: 2px; }

.vm-cb {
    display: flex; align-items: center; gap: 8px;
    cursor: pointer; font-size: 14px; color: var(--vm-gray-700);
    font-weight: 500; user-select: none;
}
.vm-cb input { position: absolute; opacity: 0; width: 0; height: 0; }
.vm-cb-box {
    width: 16px; height: 16px;
    border: 1.5px solid var(--vm-gray-300); border-radius: 4px;
    background: #fff; flex-shrink: 0;
    display: flex; align-items: center; justify-content: center;
    transition: all .12s;
}
.vm-cb input:checked + .vm-cb-box {
    background: var(--vm-p-600); border-color: var(--vm-p-600);
}
.vm-cb input:checked + .vm-cb-box::after {
    content: '';
    width: 9px; height: 5px;
    border-left: 2px solid #fff; border-bottom: 2px solid #fff;
    transform: rotate(-45deg) translateY(-1px); display: block;
}

/* ── ALERT ───────────────────────────────────────────────── */
.vm-alert {
    padding: 10px 14px; border-radius: var(--vm-r-md);
    font-size: 13px; margin-bottom: 14px;
    display: flex; align-items: center; gap: 8px;
}
.vm-alert .material-symbols-outlined { font-size: 16px; flex-shrink: 0; }
.vm-alert-err { background: var(--vm-err-50); color: var(--vm-err-700); border: 1px solid #FECDCA; }
.vm-alert-ok  { background: var(--vm-ok-50);  color: var(--vm-ok-700);  border: 1px solid #A9EFC5; }

/* ── MOBILE OVERLAY ──────────────────────────────────────── */
.vm-mob-overlay {
    display: none; position: fixed; inset: 0;
    background: rgba(0,0,0,.4); z-index: 99;
}

/* ── RESPONSIVE ──────────────────────────────────────────── */
@media (max-width: 768px) {
    .vm-sidebar {
        position: fixed; top: 0; left: 0; height: 100%;
        transform: translateX(-100%);
        transition: transform .25s ease;
        z-index: 200; box-shadow: var(--vm-shadow-xl);
        width: var(--vm-sidebar-w) !important;
    }
    .vm-sidebar.open { transform: translateX(0); }
    .vm-mob-overlay.on { display: block; }
    .vm-mobile-btn { display: flex; }
    /* Mobile: Höhe & Overflow aufheben, Seite als Ganzes scrollen lassen */
    .vm-dash {
        display: block;
        height: auto;
        max-height: none;
        overflow: visible;
    }
    .vm-main { overflow: visible; height: auto; }
    .vm-content {
        height: auto;
        overflow: visible;
        -webkit-overflow-scrolling: touch;
    }
    .vm-sb-toggle { display: none; }
}
@media (max-width: 640px) {
    .vm-content { padding: 16px; }
    .vm-fgrid { grid-template-columns: 1fr; }
    .vm-ph { flex-direction: column; }
    .vm-stats { grid-template-columns: 1fr 1fr; }
    .vm-hide-sm { display: none !important; }
}
@media (max-width: 400px) {
    .vm-stats { grid-template-columns: 1fr; }
}

/* ── Topbar title hidden on desktop (shown in content) ── */
@media (min-width: 769px) {
    /* topbar title shown on all sizes now */
}

/* Club name in topbar */
.vm-topbar-club {
    font-size: 15px;
    font-weight: 600;
    color: var(--vm-gray-900);
}
@media (max-width: 768px) {
    .vm-topbar-club { display: none; }
}

/* Collapsed sidebar: hide toggle, keep logo centered */
.vm-sidebar.collapsed .vm-sb-toggle { display: none; }
.vm-sidebar.collapsed .vm-sb-logo { justify-content: center; }

/* ── DETAIL-VIEWS ─────────────────────────────────────────── */
.vm-detail-header {
    display: flex;
    align-items: flex-start;
    gap: 20px;
    padding: 24px;
    border-bottom: 1px solid var(--vm-gray-200);
}

.vm-detail-avatar {
    width: 72px; height: 72px;
    border-radius: 50%;
    background: var(--vm-p-50);
    border: 3px solid var(--vm-p-100);
    display: flex; align-items: center; justify-content: center;
    flex-shrink: 0;
    font-size: 26px; font-weight: 700;
    color: var(--vm-p-600);
    overflow: hidden;
}
.vm-detail-avatar img { width: 100%; height: 100%; object-fit: cover; }

.vm-inforow {
    display: flex; gap: 8px;
    padding: 10px 0;
    border-bottom: 1px solid var(--vm-gray-100);
    font-size: 14px;
}
.vm-inforow:last-child { border-bottom: none; }
.vm-inforow-label {
    min-width: 160px; flex-shrink: 0;
    font-size: 13px; font-weight: 500;
    color: var(--vm-gray-500);
}
.vm-inforow-value { color: var(--vm-gray-900); }

.vm-stat-pill {
    background: var(--vm-gray-50);
    border: 1px solid var(--vm-gray-200);
    border-radius: var(--vm-r-lg);
    padding: 16px;
    text-align: center;
}
.vm-stat-pill-val {
    font-size: 28px; font-weight: 700;
    color: var(--vm-gray-900); line-height: 1;
}
.vm-stat-pill-lbl {
    font-size: 11px; font-weight: 600;
    text-transform: uppercase; letter-spacing: .05em;
    color: var(--vm-gray-500); margin-top: 6px;
}

/* ── TEAM CARDS ───────────────────────────────────────────── */
#t-teams-grid .vm-card { cursor: pointer; height: 100%; }
#t-teams-grid .vm-card:hover { box-shadow: var(--vm-shadow-md); }
#t-teams-grid > div.vm-card { height: auto; }
#t-kader-list .vm-card { cursor: pointer; }
#t-kader-list .vm-card:hover { box-shadow: var(--vm-shadow-sm); }
#t-saisons-section .vm-btn.vm-btn-ghost {
    border-radius: var(--vm-r-md) var(--vm-r-md) 0 0;
    font-size: 14px; padding: 12px 16px;
}
#t-saisons-section #t-saisons-body {
    border-radius: 0 0 var(--vm-r-md) var(--vm-r-md);
}

/* ── Collapsed sidebar: logo clickable to expand ─────────── */
.vm-sidebar.collapsed .vm-sb-logo-icon { cursor: pointer; }
.vm-sidebar.collapsed .vm-sb-logo-icon:hover { opacity: .85; }

/* ── TOPBAR BREADCRUMB ────────────────────────────────────── */
#vm-breadcrumb {
    display: flex;
    align-items: center;
    gap: 4px;
    flex-wrap: nowrap;
    overflow: hidden;
}

#vm-breadcrumb .vm-bc-sep {
    font-size: 14px;
    color: var(--vm-gray-300);
    flex-shrink: 0;
    user-select: none;
}

#vm-breadcrumb .vm-bc-item {
    font-size: 14px;
    font-weight: 500;
    color: var(--vm-gray-500);
    background: none;
    border: none;
    padding: 0;
    cursor: pointer;
    font-family: var(--vm-font);
    white-space: nowrap;
    transition: color .12s;
    text-decoration: none;
    flex-shrink: 1;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 160px;
}

#vm-breadcrumb .vm-bc-item:hover {
    color: var(--vm-p-600);
}

#vm-breadcrumb .vm-bc-current {
    font-size: 14px;
    font-weight: 600;
    color: var(--vm-gray-900);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 200px;
    flex-shrink: 1;
}

/* Divider between club name and breadcrumb */
.vm-topbar-club + #vm-breadcrumb::before {
    content: '';
    display: inline-block;
    width: 1px;
    height: 16px;
    background: var(--vm-gray-200);
    margin: 0 8px;
    flex-shrink: 0;
}

@media (max-width: 640px) {
    #vm-breadcrumb .vm-bc-item { max-width: 80px; }
    #vm-breadcrumb .vm-bc-current { max-width: 100px; }
}

/* ── CUSTOM SELECT ────────────────────────────────────────── */
.vm-sel {
    appearance: none;
    -webkit-appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2398A2B3' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 10px center;
    background-size: 16px;
    padding-right: 36px !important;
    cursor: pointer;
}

.vm-sel:focus {
    border-color: var(--vm-p-500);
    box-shadow: 0 0 0 3px rgba(6,174,212,.12);
    outline: none;
}

.vm-sel option {
    font-family: var(--vm-font);
    font-size: 14px;
    color: var(--vm-gray-900);
    background: #fff;
    padding: 6px;
}

/* Also style plain selects in modals/forms that use vm-sel class */
select.vm-sel { color: var(--vm-gray-900); }

/* ── ACTION MENU ──────────────────────────────────────────── */
.vm-action-menu {
    position: relative;
    display: inline-block;
}

.vm-action-trigger {
    width: 32px; height: 32px;
    display: inline-flex; align-items: center; justify-content: center;
    border: 1px solid var(--vm-gray-200);
    border-radius: var(--vm-r-sm);
    background: #fff;
    cursor: pointer;
    color: var(--vm-gray-500);
    transition: background .12s, color .12s;
    font-family: var(--vm-font);
}
.vm-action-trigger:hover { background: var(--vm-gray-50); color: var(--vm-gray-700); }
.vm-action-trigger .material-symbols-outlined { font-size: 18px; }

.vm-action-dropdown {
    position: fixed;
    background: #fff;
    border: 1px solid var(--vm-gray-200);
    border-radius: var(--vm-r-md);
    box-shadow: var(--vm-shadow-lg);
    min-width: 160px;
    z-index: 600;
    display: none;
    overflow: hidden;
    animation: vm-modal-in .12s ease;
}

.vm-action-menu.open .vm-action-dropdown { display: block; }

.vm-action-item {
    display: flex; align-items: center; gap: 8px;
    padding: 9px 14px;
    font-size: 13px; font-weight: 500;
    color: var(--vm-gray-700);
    cursor: pointer;
    background: none; border: none; width: 100%; text-align: left;
    font-family: var(--vm-font);
    transition: background .1s;
    white-space: nowrap;
}
.vm-action-item:hover { background: var(--vm-gray-50); }
.vm-action-item .material-symbols-outlined { font-size: 16px; color: var(--vm-gray-400); }
.vm-action-item.danger { color: var(--vm-err-700); }
.vm-action-item.danger .material-symbols-outlined { color: var(--vm-err-400); }
.vm-action-item.danger:hover { background: var(--vm-err-50); }
.vm-action-divider { height: 1px; background: var(--vm-gray-100); margin: 4px 0; }

/* Clickable table name cells */
.vm-tbl-link {
    color: var(--vm-gray-900);
    text-decoration: none;
    font-weight: 600;
    cursor: pointer;
    transition: color .12s;
    background: none; border: none;
    font-family: var(--vm-font);
    font-size: 14px;
    padding: 0;
    text-align: left;
}
.vm-tbl-link:hover { color: var(--vm-p-600); text-decoration: underline; }

/* ── KADER-ERFASSUNG ────────────────────────────────────── */

/* Custom radio buttons */
.vm-kader-radio { display: none; }
.vm-kader-chip {
    display: inline-flex; align-items: center; gap: 4px;
    padding: 3px 10px; border-radius: 20px; font-size: 11px; font-weight: 600;
    border: 1.5px solid var(--vm-gray-200); background: #fff;
    cursor: pointer; user-select: none; transition: all .12s;
    color: var(--vm-gray-500); white-space: nowrap;
}
.vm-kader-chip:hover { border-color: var(--vm-gray-400); color: var(--vm-gray-700); }
.vm-kader-radio:checked + .vm-kader-chip {
    border-color: transparent; color: #fff;
}
/* Start-11 → green */
.vm-kader-opt-s11 .vm-kader-radio:checked + .vm-kader-chip { background: var(--vm-ok-600, #16a34a); }
/* Wechsler → blue */
.vm-kader-opt-wech .vm-kader-radio:checked + .vm-kader-chip { background: var(--vm-p-600); }
/* Kader → amber */
.vm-kader-opt-kad .vm-kader-radio:checked + .vm-kader-chip { background: #d97706; }
/* Nicht dabei → gray outline when checked */
.vm-kader-opt-none .vm-kader-radio:checked + .vm-kader-chip {
    background: var(--vm-gray-200); color: var(--vm-gray-600); border-color: var(--vm-gray-300);
}

/* Kader row highlight based on selection */
.vm-kader-row { transition: background .1s; cursor: default; }
.vm-kader-row:hover { background: var(--vm-gray-50); }
.vm-kader-row.status-s11 { background: #f0fdf4; }
.vm-kader-row.status-s11:hover { background: #dcfce7; }
.vm-kader-row.status-wech { background: var(--vm-p-50); }
.vm-kader-row.status-wech:hover { background: var(--vm-p-100); }
.vm-kader-row.status-kad { background: #fffbeb; }
.vm-kader-row.status-kad:hover { background: #fef3c7; }
.vm-kader-row.status-trainer { background: #fdf4ff; }
.vm-kader-row.status-trainer:hover { background: #f3e8ff; }

/* Kader summary boxes */
.vm-kader-stats {
    display: flex; gap: 6px; flex-wrap: wrap; align-items: center;
    padding: 4px 0;
}
.vm-card-head .vm-kader-stats { border: none; padding: 2px 0; }
.vm-kader-stat-box {
    display: inline-flex; align-items: center; gap: 4px;
    padding: 3px 8px; border-radius: 20px;
    font-size: 11px; font-weight: 700;
}
.vm-kader-stat-box .stat-n { font-size: 13px; font-weight: 800; }
.vm-kader-stat-box.s11  { background: #f0fdf4; color: #15803d; }
.vm-kader-stat-box.wech { background: var(--vm-p-50); color: var(--vm-p-700); }
.vm-kader-stat-box.kad  { background: #fffbeb; color: #92400e; }
.vm-kader-stat-box.trnr { background: #fdf4ff; color: #7e22ce; }
.vm-kader-stat-box.ges  { background: var(--vm-gray-900); color: #fff; }

/* Kader head stats badges */
.vm-kader-stat-badge { border-radius: 12px; padding: 2px 8px; font-size: 11px; font-weight: 700; }
.vm-kader-stat-badge.s11  { background: #dcfce7; color: #15803d; }
.vm-kader-stat-badge.s11.warn { background: #fee2e2; color: #991b1b; }
.vm-kader-stat-badge.wech { background: var(--vm-p-50); color: var(--vm-p-700); }
.vm-kader-stat-badge.kad  { background: #fef3c7; color: #92400e; }
.vm-kader-stat-badge.trnr { background: #f3e8ff; color: #7e22ce; }
.vm-kader-stat-badge.ges  { background: #f0fdf4; color: #166534; }

/* ── SIDEBAR NAV COUNTER BADGES ────────────────────────── */
.vm-nav-count {
    margin-left: auto;
    flex-shrink: 0;
    background: var(--vm-gray-200);
    color: var(--vm-gray-600);
    font-size: 10px; font-weight: 700;
    padding: 1px 7px;
    border-radius: 10px;
    min-width: 20px;
    text-align: center;
    line-height: 18px;
}
.vm-nav-item.active .vm-nav-count {
    background: var(--vm-p-200);
    color: var(--vm-p-800);
}
.vm-sidebar.collapsed /* ── STICKY TABLE HEADERS ───────────────────────────────── */
/* Sticky thead + tfoot: only tbody scrolls */
.vm-tbl-sticky-wrap {
    overflow-y: auto;
    max-height: 60vh;
    position: relative;
}
.vm-tbl-sticky thead th {
    position: sticky;
    top: 0;
    background: #fff;
    z-index: 3;
    box-shadow: 0 1px 0 var(--vm-gray-200);
}
.vm-tbl-sticky tfoot td {
    position: sticky;
    bottom: 0;
    background: var(--vm-gray-50);
    z-index: 3;
    box-shadow: 0 -1px 0 var(--vm-gray-200);
}
/* VM card-head stays fixed above table */
.vm-card-head { position: relative; z-index: 1; }

/* ── WORDPRESS TOOLBAR HIDE & FULLSCREEN ────────────────── */
#wpadminbar { display: none !important; }
html { margin-top: 0 !important; }
body { margin-top: 0 !important; }

/* Ensure plugin fills full viewport (nur auf Desktop) */
@media (min-width: 769px) {
    .vm-dash {
        height: 100vh !important;
        max-height: 100vh !important;
        overflow: hidden;
    }
}
.vm-badge-purple { background: #f3e8ff; color: #7e22ce; }


/* ══════════════════════════════════════════════════════════
   MOBILE-FREUNDLICHE TABELLEN & STAT-BOXEN (≤640px)
   ══════════════════════════════════════════════════════════ */
@media (max-width: 640px) {

    /* Content-Bereich: symmetrisches Padding */
    .vm-content { padding: 16px; }

    /* ── 1. Tabellen zu Cards transformieren ─────────────── */
    .vm-tbl-wrap {
        overflow-x: visible;
        padding: 8px 0 4px;  /* oben etwas mehr Abstand zum Card-Head */
    }

    .vm-tbl,
    .vm-tbl thead,
    .vm-tbl tbody,
    .vm-tbl tr,
    .vm-tbl td {
        display: block;
        width: 100%;
        box-sizing: border-box;
    }
    .vm-tbl[style*="table-layout"],
    .vm-tbl { table-layout: auto !important; }

    /* Header ausblenden – Labels werden per data-label angezeigt */
    .vm-tbl thead { display: none; }

    /* Jede Tabellenzeile = eine Card */
    .vm-tbl tbody tr {
        background: #fff;
        border: 1px solid var(--vm-gray-200);
        border-radius: var(--vm-r-md);
        padding: 12px 14px;
        box-shadow: var(--vm-shadow-xs);
        margin: 0 0 10px 0;  /* nur unten Abstand zwischen Cards */
    }
    .vm-tbl tbody tr:last-child { margin-bottom: 0; }
    .vm-tbl tbody tr:hover td { background: transparent; }

    /* Zellen innerhalb einer Card: Grid aus Label + Wert */
    .vm-tbl td {
        display: grid !important;
        grid-template-columns: 110px 1fr;
        align-items: baseline;
        gap: 10px;
        padding: 5px 0 !important;
        border: none !important;
        text-align: left !important;
        white-space: normal !important;
        word-break: break-word;
        overflow: visible !important;
        text-overflow: clip !important;
        font-size: 14px;
        color: var(--vm-gray-900);
        font-family: var(--vm-font);
    }
    .vm-tbl td:first-child { padding-top: 0 !important; }
    .vm-tbl td:last-child { padding-bottom: 0 !important; }

    /* Label aus data-label ableiten – linksbündig, einheitliche Schrift */
    .vm-tbl td[data-label]::before {
        content: attr(data-label);
        font-size: 11px;
        font-weight: 600;
        color: var(--vm-gray-500);
        text-transform: uppercase;
        letter-spacing: .04em;
        font-family: var(--vm-font);
        text-align: left;
        white-space: nowrap;
    }
    /* Werte rechtsbündig wenn .r (Zahlenspalten) */
    .vm-tbl td.r { text-align: right !important; }
    .vm-tbl td.r > * { text-align: right; }

    /* Chips und Badges NICHT auf volle Breite strecken */
    .vm-tbl td .vm-badge,
    .vm-tbl td .vm-chip {
        display: inline-flex !important;
        width: auto !important;
        max-width: max-content;
    }

    /* Leere Zellen ausblenden */
    .vm-tbl td:empty { display: none !important; }

    /* Aktions-Zellen (nur Buttons/Icons): rechts unten mit Trenner */
    .vm-tbl td.vm-td-actions {
        grid-template-columns: 1fr !important;
        justify-items: end;
        text-align: right !important;
        margin-top: 8px;
        padding-top: 10px !important;
        border-top: 1px solid var(--vm-gray-100) !important;
    }
    .vm-tbl td.vm-td-actions::before { content: none !important; }

    /* ── 2. Gruppenzeilen (Monatsheader etc.) ──────────── */
    .vm-tbl tr.vm-group-row {
        background: transparent !important;
        border: none !important;
        box-shadow: none !important;
        padding: 0 !important;
        margin: 14px 0 4px !important;
    }
    .vm-tbl tr.vm-group-row:first-child { margin-top: 0 !important; }
    .vm-tbl tr.vm-group-row td {
        display: block !important;
        background: var(--vm-gray-100) !important;
        color: var(--vm-gray-600) !important;
        font-size: 11px !important;
        font-weight: 700 !important;
        padding: 5px 10px !important;
        border-radius: 4px !important;
        text-transform: uppercase;
        letter-spacing: .05em;
    }
    .vm-tbl tr.vm-group-row td::before { content: none !important; }

    /* ── 3. Snapshot-Boxen einheitlich ──────────── */
    .vm-stat-box { padding: 12px; }
    .vm-stat-value { font-size: 18px !important; }
    .vm-stat-label { font-size: 11px; margin-top: 4px; }

    /* Euro-Beträge umbrechen wenn nötig */
    .mono { word-break: break-all; }

    /* Stat-Grids: 2 Spalten auf Mobile */
    .vm-card [style*="grid-template-columns:repeat(auto-fit,minmax(120px"],
    .vm-card [style*="grid-template-columns:repeat(auto-fit,minmax(140px"],
    .vm-card [style*="grid-template-columns:repeat(auto-fit,minmax(160px"] {
        gap: 8px !important;
        grid-template-columns: 1fr 1fr !important;
    }
}


