/* ============================================================
   LIQUID GLASS DESIGN SYSTEM — VMS Game
   Colours: TSS_Brand_Identity_Guidelines.md (glass layout unchanged)
   ============================================================ */

/* Official TSS + aliases used across CSS (mirror theme-colors.js / VMS_THEME) */
:root {
    --tss-magenta: #E2007A;
    --tss-magenta-web: #CC0E70;
    --tss-magenta-rgb: 204, 14, 112;
    --tss-navy: #004A91;
    --tss-navy-rgb: 0, 74, 145;
    --tss-grey: #A4A6A7;
    --tss-grey-rgb: 164, 166, 167;
    --tss-light-pink: #EC6DD4;
    --tss-light-pink-rgb: 236, 109, 212;
    --tss-light-blue: #53B7ED;
    --tss-light-blue-rgb: 83, 183, 237;
    --tss-light-grey: #EEEEEE;
    --tss-bg-secondary: #f5f5f5;
    --tss-surface-muted: #f8f9fa;
    --tss-surface-subtle: #f9f9f9;
    --tss-surface-warm: #f0f0f0;
    --tss-border-subtle: #dddddd;
    --tss-border-hairline: #e0e0e0;
    --tss-border-info-tint: #d0d8ec;
    --tss-border-neutral: #dee2e6;
    --tss-border-section: #e9ecef;
    --tss-border-card: #e3e6ea;
    --tss-divider-faint: #cccccc;
    --tss-text-readonly: #6c757d;
    --tss-text-primary: #333333;
    --tss-text-secondary: #666666;
    --tss-text-soft: #888888;
    --tss-text-muted: #999999;
    --tss-text-dim: #555555;
    --tss-text-caption: #777777;
    --tss-surface-blue-tint: #f8f9ff;
    --tss-danger: #e74c3c;
    --tss-danger-hover: #c0392b;
    --tss-success: #28a745;
    --tss-success-hover: #218838;
    --tss-warning-amber: #f39c12;
    --tss-gradient-decorative: linear-gradient(90deg, #53b7ed 0%, #a092e1 50%, #ec6dd4 100%);
    --tss-gradient-signature: linear-gradient(90deg, var(--tss-magenta-web) 0%, var(--tss-navy) 100%);

    /* Legacy hook names → TSS (supporting blue + navy) */
    --tss-teal: #53b7ed;
    --tss-teal-rgb: 83, 183, 237;
    --tss-blue: #004a91;
    --tss-blue-rgb: 0, 74, 145;

    --tss-blue-dim: #003b6e;
    --tss-panel-soft: rgba(var(--tss-light-blue-rgb), 0.11);
    --tss-panel-soft-border: rgba(var(--tss-navy-rgb), 0.18);

    /* Page shell behind glass (navy-tinted) */
    --tss-page-1: #031520;
    --tss-page-2: #062a44;
    --tss-page-3: #083556;
    --tss-page-4: #062c48;
    --tss-page-5: #051a2e;
}

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

html {
    height: 100%;
    overflow: hidden;
}

body {
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, Helvetica, sans-serif;
    background: linear-gradient(145deg, var(--tss-page-1) 0%, var(--tss-page-2) 25%, var(--tss-page-3) 50%, var(--tss-page-4) 75%, var(--tss-page-5) 100%);
    min-height: 100vh;
    height: 100vh;
    overflow: hidden;
    padding: 24px;
    color: var(--tss-text-primary);
    position: relative;
    display: flex;
    flex-direction: column;
    box-sizing: border-box;
}

/* Ambient light orbs — TSS light blue + navy */
body::after {
    content: '';
    position: fixed;
    inset: 0;
    background:
        radial-gradient(ellipse 70% 50% at 15% 10%, rgba(var(--tss-light-blue-rgb), 0.14) 0%, transparent 55%),
        radial-gradient(ellipse 50% 60% at 85% 85%, rgba(var(--tss-magenta-rgb), 0.08) 0%, transparent 55%),
        radial-gradient(ellipse 40% 40% at 50% 45%, rgba(var(--tss-navy-rgb), 0.12) 0%, transparent 60%);
    pointer-events: none;
    z-index: 0;
}

/* ── Main container — één wit paneel met ronding boven en onder, geen scroll (scroll zit in .container-body) ── */
.container {
    max-width: 1600px;
    width: 100%;
    margin: 0 auto;
    flex: 1 1 0;
    min-height: 0;
    display: flex;
    flex-direction: column;
    background: rgba(255, 255, 255, 0.94);
    backdrop-filter: blur(60px) saturate(200%);
    -webkit-backdrop-filter: blur(60px) saturate(200%);
    border-radius: 20px;
    box-shadow:
        0 0 0 1px rgba(255, 255, 255, 0.55) inset,
        0 32px 80px rgba(0, 0, 0, 0.55),
        0 8px 32px rgba(var(--tss-navy-rgb), 0.18);
    overflow: hidden;
    position: relative;
    z-index: 1;
}

/* TSS signature footer bar (magenta → navy), inside glass card */
.container::after {
    content: '';
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    height: 4px;
    z-index: 6;
    background: linear-gradient(90deg, var(--tss-magenta) 0%, var(--tss-navy) 100%);
    border-radius: 0 0 20px 20px;
    pointer-events: none;
}

/* ── Enige scrolllaag: groene scrollbar (TSS), onderaan zelfde ronding zichtbaar ── */
.container-body {
    flex: 1;
    min-height: 0;
    overflow-y: auto;
    overflow-x: hidden;
    scrollbar-width: thin;
    scrollbar-color: rgba(var(--tss-teal-rgb), 0.5) rgba(var(--tss-teal-rgb), 0.08);
}
.container-body::-webkit-scrollbar {
    width: 8px;
}
.container-body::-webkit-scrollbar-track {
    background: rgba(var(--tss-teal-rgb), 0.08);
    border-radius: 0 0 12px 12px;
}
.container-body::-webkit-scrollbar-thumb {
    background: rgba(var(--tss-teal-rgb), 0.35);
    border-radius: 10px;
}
.container-body::-webkit-scrollbar-thumb:hover {
    background: rgba(var(--tss-teal-rgb), 0.6);
}

/* ── Header (TSS signature: magenta → navy) ── */
header {
    background: var(--tss-gradient-signature);
    color: white;
    padding: 22px 30px;
    text-align: center;
    position: relative;
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
    box-shadow: 0 4px 24px rgba(0, 0, 0, 0.25);
}

/* Specular highlight along top edge */
header::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 1px;
    background: linear-gradient(90deg, transparent 0%, rgba(255,255,255,0.55) 50%, transparent 100%);
}

header h1 {
    font-size: 2em;
    font-weight: 700;
    margin-bottom: 4px;
    letter-spacing: -0.02em;
}

header p {
    font-size: 0.95em;
    opacity: 0.78;
    font-weight: 400;
}

/* ── Modals — altijd gecentreerd in het scherm ── */
.modal {
    display: none;
    position: fixed;
    top: 0; left: 0;
    width: 100%;
    height: 100%;
    /* TSS-tinted scrim (navy + magenta hint) */
    background: linear-gradient(
        160deg,
        rgba(var(--tss-navy-rgb), 0.55) 0%,
        rgba(8, 18, 32, 0.75) 45%,
        rgba(var(--tss-magenta-rgb), 0.12) 100%
    );
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    z-index: 1000;
    overflow: auto;
    justify-content: center;
    align-items: center;
    padding: 20px;
    box-sizing: border-box;
}

/* Wanneer modal zichtbaar is — content altijd in het midden */
.modal.active,
.modal[style*="display: flex"] {
    display: flex !important;
    align-items: center;
    justify-content: center;
}
.modal.active {
    display: flex;
}

/* GM game picker cards — hover lift (delegated click in app-gm.js; no inline handlers for CSP) */
.gm-game-card:hover {
    transform: translateY(-5px);
}

.modal-content {
    /* Slight cool mint lift — still reads as a light card, aligns with TSS */
    background: linear-gradient(
        180deg,
        rgba(255, 255, 255, 0.97) 0%,
        rgba(248, 252, 251, 0.96) 100%
    );
    backdrop-filter: blur(40px) saturate(180%);
    -webkit-backdrop-filter: blur(40px) saturate(180%);
    padding: 40px;
    border-radius: 20px;
    max-width: 800px;
    max-height: calc(100vh - 40px);
    overflow-y: auto;
    width: 90%;
    box-shadow:
        0 0 0 1px rgba(255, 255, 255, 0.5) inset,
        0 30px 70px rgba(0, 0, 0, 0.35),
        0 4px 20px rgba(var(--tss-teal-rgb), 0.12);
    margin: auto;
    border: 1px solid rgba(255, 255, 255, 0.35);
    flex-shrink: 0;
}

/* Styled scrollbar for modal content (TSS) */
.modal-content::-webkit-scrollbar {
    width: 6px;
}
.modal-content::-webkit-scrollbar-track {
    background: transparent;
}
.modal-content::-webkit-scrollbar-thumb {
    background: rgba(var(--tss-teal-rgb), 0.35);
    border-radius: 10px;
}
.modal-content::-webkit-scrollbar-thumb:hover {
    background: rgba(var(--tss-teal-rgb), 0.6);
}

.modal h2 {
    color: var(--tss-navy);
    margin-bottom: 20px;
    font-size: 1.7em;
    font-weight: 700;
    border-bottom: 2px solid var(--tss-magenta-web);
    padding-bottom: 12px;
    letter-spacing: -0.01em;
}

/* GM-dashboard: volle breedte zoals team-view, geen tweede smallere "container" */
#gameMasterModal.modal {
    padding: 0;
    align-items: stretch;
}
#gameMasterModal .modal-content {
    max-width: none;
    width: 100%;
    margin: 0;
    border-radius: 0;
}

/* Game Master Setup modal: scroll alleen binnen de witte doos, niet de hele overlay.
   Buitenste .modal-content behoudt border-radius; binnenste .modal-content-scroll scrollt.
   Extra marge onderaan zodat de onderrand en onderronding van de witte doos altijd zichtbaar zijn. */
#adminSetupModal.modal {
    overflow: hidden;
    align-items: flex-start;
    padding-bottom: 48px; /* meer ruimte onder de witte doos */
    box-sizing: border-box;
}
#adminSetupModal .modal-content {
    max-height: calc(100vh - 88px); /* 20 top + 48 bottom marge = duidelijke ruimte onderin */
    overflow: hidden;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    padding: 0; /* padding zit in .modal-content-scroll */
}
#adminSetupModal .modal-content-scroll {
    overflow-y: auto;
    min-height: 0;
    padding: 40px;
}
#adminSetupModal .modal-content-scroll::-webkit-scrollbar {
    width: 6px;
}
#adminSetupModal .modal-content-scroll::-webkit-scrollbar-track {
    background: transparent;
}
#adminSetupModal .modal-content-scroll::-webkit-scrollbar-thumb {
    background: rgba(var(--tss-teal-rgb), 0.35);
    border-radius: 10px;
}
#adminSetupModal .modal-content-scroll::-webkit-scrollbar-thumb:hover {
    background: rgba(var(--tss-teal-rgb), 0.6);
}

/* ── Form elements ── */
.form-group {
    margin-bottom: 20px;
}

.form-group label {
    display: block;
    margin-bottom: 7px;
    font-weight: 600;
    font-size: 0.9em;
    color: #444;
    letter-spacing: 0.01em;
}

.form-group input,
.form-group select,
.form-group textarea {
    width: 100%;
    padding: 10px 12px;
    border: 1.5px solid rgba(0, 0, 0, 0.12);
    border-radius: 10px;
    font-size: 1em;
    font-family: inherit;
    background: rgba(255, 255, 255, 0.8);
    transition: border-color 0.18s, box-shadow 0.18s;
}

.form-group input:focus,
.form-group select:focus {
    outline: none;
    border-color: var(--tss-magenta-web);
    box-shadow: 0 0 0 3px rgba(var(--tss-magenta-rgb), 0.22);
    background: white;
}

/* ── Buttons ── */
.button-group {
    display: flex;
    gap: 10px;
    margin-top: 30px;
}

button {
    padding: 11px 20px;
    border: none;
    border-radius: 10px;
    font-size: 0.95em;
    font-weight: 600;
    font-family: inherit;
    cursor: pointer;
    transition: all 0.18s ease;
}

.btn-primary {
    background: var(--tss-magenta-web);
    color: #fff;
    flex: 1;
    box-shadow: 0 2px 10px rgba(var(--tss-magenta-rgb), 0.35);
    transition: filter 0.18s ease, transform 0.18s ease, box-shadow 0.18s ease;
}

.btn-primary:hover {
    filter: brightness(1.06);
    transform: translateY(-1px);
    box-shadow: 0 5px 18px rgba(var(--tss-magenta-rgb), 0.45);
}

.btn-primary:active {
    transform: translateY(0);
    box-shadow: 0 2px 8px rgba(var(--tss-magenta-rgb), 0.28);
    filter: brightness(0.9);
}

/* Team view: alarm panel + red buzzer (Decisions tab) */
.buzzer-submit-wrap {
    display: flex;
    justify-content: center;
    align-items: center;
    margin-top: 30px;
    padding: 28px 16px 48px;
}

.buzzer-panel {
    width: 100%;
    max-width: 440px;
    border-radius: 16px;
    background: linear-gradient(
        168deg,
        rgba(46, 46, 46, 0.78) 0%,
        rgba(14, 14, 14, 0.85) 42%,
        rgba(28, 28, 28, 0.8) 100%
    );
    backdrop-filter: blur(18px) saturate(1.25);
    -webkit-backdrop-filter: blur(18px) saturate(1.25);
    border: 1px solid rgba(255, 255, 255, 0.16);
    box-shadow:
        0 0 0 1px rgba(0, 0, 0, 0.45) inset,
        0 1px 0 rgba(255, 255, 255, 0.22) inset,
        0 24px 48px rgba(0, 0, 0, 0.45),
        0 8px 24px rgba(0, 0, 0, 0.35);
    overflow: hidden;
}

.buzzer-hazard {
    height: 14px;
    width: 100%;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.2) 0%, transparent 45%),
        repeating-linear-gradient(
            -45deg,
            rgba(232, 184, 0, 0.95) 0px,
            rgba(232, 184, 0, 0.95) 10px,
            rgba(26, 26, 26, 0.92) 10px,
            rgba(26, 26, 26, 0.92) 20px
        );
    box-shadow: inset 0 -1px 0 rgba(0, 0, 0, 0.45);
}

.buzzer-panel-inner {
    padding: 18px 22px 26px;
}

.buzzer-panel-eyebrow {
    margin: 0 0 14px;
    text-align: center;
    font-size: 0.78rem;
    font-weight: 800;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: #ff4d4d;
    text-shadow: 0 0 12px rgba(255, 40, 40, 0.55);
}

.buzzer-well {
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 32px 22px 36px;
    border-radius: 50%;
    background:
        linear-gradient(155deg, rgba(255, 255, 255, 0.09) 0%, transparent 42%),
        radial-gradient(
            ellipse 85% 70% at 50% 100%,
            rgba(0, 0, 0, 0.72) 0%,
            rgba(12, 12, 12, 0.55) 55%,
            rgba(40, 40, 40, 0.42) 100%
        );
    backdrop-filter: blur(12px) saturate(1.1);
    -webkit-backdrop-filter: blur(12px) saturate(1.1);
    border: 1px solid rgba(255, 255, 255, 0.1);
    box-shadow:
        inset 0 18px 36px rgba(0, 0, 0, 0.75),
        inset 0 4px 14px rgba(0, 0, 0, 0.45),
        inset 0 1px 0 rgba(255, 255, 255, 0.12),
        0 1px 0 rgba(255, 255, 255, 0.06);
}

.btn-buzzer-label {
    position: relative;
    z-index: 2;
    white-space: pre-line;
    text-align: center;
}

.btn-buzzer {
    position: relative;
    isolation: isolate;
    display: flex;
    align-items: center;
    justify-content: center;
    width: min(272px, 74vw);
    height: min(272px, 74vw);
    max-width: 272px;
    max-height: 272px;
    padding: 22px 26px;
    border-radius: 50%;
    font-size: clamp(1rem, 4.5vw, 1.28rem);
    font-weight: 900;
    line-height: 1.15;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: #fff;
    text-shadow:
        0 1px 0 rgba(0, 0, 0, 0.5),
        0 0 20px rgba(255, 80, 80, 0.4);
    background:
        radial-gradient(ellipse 95% 55% at 50% 0%, rgba(255, 255, 255, 0.45) 0%, transparent 52%),
        radial-gradient(circle at 28% 20%, rgba(255, 220, 220, 0.55) 0%, transparent 38%),
        radial-gradient(circle at 50% 92%, rgba(50, 0, 0, 0.65) 0%, transparent 52%),
        radial-gradient(
            circle at 38% 34%,
            rgba(255, 160, 160, 0.95) 0%,
            #ff2020 36%,
            #c00000 58%,
            #6a0000 84%,
            #2a0000 100%
        );
    border: 5px solid rgba(30, 0, 0, 0.92);
    box-shadow:
        0 0 0 1px rgba(255, 255, 255, 0.35) inset,
        0 12px 0 #1a0000,
        0 18px 40px rgba(0, 0, 0, 0.55),
        0 0 28px rgba(255, 0, 0, 0.35),
        inset 0 18px 36px rgba(255, 255, 255, 0.32),
        inset 0 -20px 30px rgba(0, 0, 0, 0.48);
    transition: transform 0.1s ease, box-shadow 0.1s ease, filter 0.15s ease;
    animation: buzzer-pulse 2.2s ease-in-out infinite;
}

/* Glass “dome” highlight over cap */
.btn-buzzer::before {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 0;
    border-radius: 50%;
    background: linear-gradient(
        168deg,
        rgba(255, 255, 255, 0.55) 0%,
        rgba(255, 255, 255, 0.18) 22%,
        rgba(255, 255, 255, 0.04) 38%,
        transparent 52%
    );
    pointer-events: none;
    mix-blend-mode: soft-light;
}

.btn-buzzer::after {
    content: "";
    position: absolute;
    inset: 10%;
    z-index: 1;
    border-radius: 50%;
    background:
        radial-gradient(
            ellipse 70% 45% at 32% 24%,
            rgba(255, 255, 255, 0.75) 0%,
            rgba(255, 255, 255, 0.15) 45%,
            transparent 62%
        ),
        radial-gradient(circle at 78% 22%, rgba(255, 255, 255, 0.2) 0%, transparent 35%);
    pointer-events: none;
    opacity: 0.88;
    mix-blend-mode: overlay;
}

.btn-buzzer:hover {
    filter: brightness(1.08) saturate(1.08);
    box-shadow:
        0 0 0 1px rgba(255, 255, 255, 0.42) inset,
        0 12px 0 #1a0000,
        0 22px 48px rgba(0, 0, 0, 0.55),
        0 0 40px rgba(255, 30, 30, 0.55),
        inset 0 18px 38px rgba(255, 255, 255, 0.42),
        inset 0 -20px 30px rgba(0, 0, 0, 0.45);
}

.btn-buzzer:active {
    transform: translateY(10px);
    animation: none;
    box-shadow:
        0 0 0 1px rgba(255, 255, 255, 0.22) inset,
        0 2px 0 #1a0000,
        0 8px 20px rgba(0, 0, 0, 0.5),
        0 0 18px rgba(255, 0, 0, 0.3),
        inset 0 10px 28px rgba(0, 0, 0, 0.4),
        inset 0 5px 16px rgba(255, 255, 255, 0.14);
    filter: brightness(0.92);
}

.btn-buzzer:focus-visible {
    outline: 3px solid #ffe066;
    outline-offset: 6px;
}

@keyframes buzzer-pulse {
    0%,
    100% {
        box-shadow:
            0 0 0 1px rgba(255, 255, 255, 0.35) inset,
            0 12px 0 #1a0000,
            0 18px 40px rgba(0, 0, 0, 0.55),
            0 0 22px rgba(255, 0, 0, 0.28),
            inset 0 18px 36px rgba(255, 255, 255, 0.3),
            inset 0 -20px 30px rgba(0, 0, 0, 0.48);
    }
    50% {
        box-shadow:
            0 0 0 1px rgba(255, 255, 255, 0.4) inset,
            0 12px 0 #1a0000,
            0 18px 40px rgba(0, 0, 0, 0.55),
            0 0 42px rgba(255, 40, 40, 0.65),
            inset 0 18px 38px rgba(255, 255, 255, 0.38),
            inset 0 -20px 30px rgba(0, 0, 0, 0.48);
    }
}

@media (prefers-reduced-motion: reduce) {
    .btn-buzzer {
        animation: none;
    }
}

.btn-secondary {
    background: var(--tss-navy);
    color: #fff;
    border: 1px solid rgba(255, 255, 255, 0.2);
    flex: 1;
}

.btn-secondary:hover {
    background: var(--tss-blue-dim);
    border-color: rgba(255, 255, 255, 0.28);
    transform: translateY(-1px);
}

/* GM dashboard: consistent Save buttons (TSS blue) and status text */
.gm-save-btn {
    padding: 10px 20px;
    background: var(--tss-blue);
    color: white;
    border: none;
    border-radius: 5px;
    cursor: pointer;
    font-weight: 600;
    font-size: 0.95em;
}
.gm-save-btn:hover {
    background: var(--tss-blue-dim);
}
.gm-save-status {
    margin-left: 10px;
    color: #28a745;
    font-size: 0.9em;
}

/* ── Content area ── */
.content {
    padding: 30px;
}

/* ── Info / Warning boxes ── */
.info-box {
    background: rgba(var(--tss-blue-rgb), 0.1);
    border-left: 3px solid var(--tss-blue);
    padding: 12px 14px;
    border-radius: 8px;
    margin: 15px 0;
    font-size: 0.92em;
    color: var(--tss-blue);
}

.warning-box {
    background: rgba(255, 193, 7, 0.1);
    border-left: 3px solid #ffc107;
    padding: 12px 14px;
    border-radius: 8px;
    margin: 15px 0;
    font-size: 0.92em;
    color: #7a5500;
}

/* ── Team UI Tabs — segmented control style ── */
.tabs {
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
    margin-bottom: 28px;
    padding: 5px;
    background: rgba(var(--tss-teal-rgb), 0.07);
    border-radius: 14px;
    border: 1px solid rgba(var(--tss-teal-rgb), 0.13);
}

.tab-button {
    padding: 9px 18px;
    background: transparent;
    border: none;
    border-radius: 10px;
    cursor: pointer;
    font-weight: 600;
    font-size: 0.88em;
    color: #666;
    transition: all 0.18s ease;
    font-family: inherit;
}

.tab-button:hover {
    background: rgba(var(--tss-teal-rgb), 0.1);
    color: var(--tss-teal);
}

.tab-button.active {
    background: white;
    color: var(--tss-navy);
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1), 0 1px 4px rgba(0, 0, 0, 0.06);
    font-weight: 700;
}

.tab-content {
    display: none;
}

.tab-content.active {
    display: block;
}

/* ── GM Dashboard tabs ── */
.tab-button-gm {
    padding: 10px 18px;
    background: transparent;
    border: none;
    border-bottom: 2px solid transparent;
    cursor: pointer;
    font-weight: 600;
    font-size: 0.88em;
    color: #777;
    transition: all 0.18s ease;
    border-radius: 8px 8px 0 0;
    font-family: inherit;
}

.tab-button-gm:hover {
    background: rgba(var(--tss-teal-rgb), 0.07);
    color: var(--tss-teal);
}

.tab-button-gm.active {
    background: rgba(var(--tss-light-blue-rgb), 0.08);
    color: var(--tss-navy);
    border-bottom: 2.5px solid var(--tss-magenta-web);
    font-weight: 700;
}

.gm-tab-content {
    display: none;
}

.gm-tab-content.active {
    display: block;
}

/* ── Expense sections ── */
.expense-section {
    background: rgba(255, 255, 255, 0.85);
    border: 1px solid rgba(var(--tss-teal-rgb), 0.14);
    border-radius: 14px;
    padding: 20px;
    margin-bottom: 20px;
    box-shadow: 0 2px 10px rgba(0,0,0,0.04);
}

.expense-section h3 {
    color: var(--tss-navy);
    margin-bottom: 15px;
    font-size: 1.1em;
    font-weight: 700;
    border-bottom: 2px solid var(--tss-magenta-web);
    padding-bottom: 10px;
}

/* Operating Expenses: label + two fixed-width value columns so headers align with inputs */
#operating-expenses .expense-item,
#operating-expenses .expense-total {
    display: grid;
    grid-template-columns: minmax(180px, 1fr) 11.25rem 11.25rem;
    gap: 10px 14px;
    margin-bottom: 12px;
    align-items: stretch;
}

#operating-expenses .expense-total {
    margin-bottom: 0;
}

.expense-compare-header {
    margin-bottom: 8px;
    padding-bottom: 8px;
    border-bottom: 1px solid rgba(0, 0, 0, 0.08);
}

.opex-compare-header-spacer {
    min-height: 1px;
}

.expense-compare-col-title {
    display: flex;
    align-items: flex-end;
    justify-content: center;
    text-align: center;
    font-weight: 600;
    font-size: 0.82em;
    color: var(--tss-blue);
    line-height: 1.25;
    padding: 0 6px 4px;
    word-break: break-word;
}

.expense-prev {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    text-align: right;
    font-size: 0.92em;
    color: #495057;
    padding: 9px 10px;
    background: #f4f6f8;
    border-radius: 8px;
    border: 1px solid #e9ecef;
    min-height: 42px;
    box-sizing: border-box;
}

/* Bucket footer, middle column: plain figures like the forecast total (no inner card) */
.expense-prev.expense-prev-total {
    font-weight: 700;
    color: var(--tss-blue);
    background: transparent;
    border: none;
    padding: 0;
    min-height: 0;
    justify-content: flex-end;
}

.expense-label {
    font-size: 0.93em;
    color: #555;
}

#operating-expenses .expense-item .expense-label,
#operating-expenses .expense-total > span:first-child {
    align-self: center;
}

.expense-input {
    padding: 9px 10px;
    border: 1.5px solid rgba(0,0,0,0.1);
    border-radius: 8px;
    font-size: 1em;
    text-align: right;
    width: 100%;
    min-width: 0;
    box-sizing: border-box;
    background: rgba(255,255,255,0.9);
    transition: border-color 0.18s, box-shadow 0.18s;
    font-family: inherit;
}

.expense-input:focus {
    outline: none;
    border-color: var(--tss-magenta-web);
    box-shadow: 0 0 0 3px rgba(var(--tss-magenta-rgb), 0.2);
}

.expense-input[readonly] {
    background: rgba(248, 249, 250, 0.8) !important;
    cursor: not-allowed;
    color: #888;
}

.expense-total {
    align-items: center;
    padding: 10px 14px;
    background: rgba(var(--tss-teal-rgb), 0.07);
    border-radius: 8px;
    font-weight: 700;
    margin-top: 10px;
    border-top: 2px solid rgba(var(--tss-teal-rgb), 0.2);
    color: var(--tss-blue);
}

.expense-total span:last-child {
    text-align: right;
}

/* ── Metrics ── */
.metric {
    margin-bottom: 12px;
    padding: 12px 14px;
    background: rgba(255, 255, 255, 0.75);
    border-radius: 10px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    border: 1px solid rgba(0,0,0,0.05);
}

.metric-label {
    font-weight: 600;
    color: #555;
    font-size: 0.92em;
}

.metric-value {
    font-size: 1.15em;
    font-weight: 700;
    color: var(--tss-blue);
}

.metric-value.negative { color: #dc3545; }
.metric-value.positive { color: #28a745; }

/* ── P&L Table ── */
.pl-table {
    width: 100%;
    border-collapse: collapse;
    background: white;
    border-radius: 12px;
    overflow: hidden;
    margin-top: 20px;
    box-shadow: 0 2px 12px rgba(0,0,0,0.06);
}

.pl-table th,
.pl-table td {
    padding: 11px 14px;
    text-align: right;
    border-bottom: 1px solid rgba(0,0,0,0.06);
}

.pl-table th {
    background: var(--tss-navy);
    color: #fff;
    font-weight: 600;
    font-size: 0.82em;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.pl-table td:first-child,
.pl-table th:first-child {
    text-align: left;
}

.pl-table tr.section-header {
    background: rgba(var(--tss-teal-rgb), 0.06);
    font-weight: 700;
    color: var(--tss-blue);
    font-size: 0.9em;
}

.pl-table tr.total-row {
    background: rgba(var(--tss-teal-rgb), 0.08);
    font-weight: 700;
    border-top: 2px solid rgba(var(--tss-teal-rgb), 0.25);
}

/* Header filter dropdowns: transparent so gradient shows through */
.pl-table select.table-header-filter {
    background: transparent !important;
    color: inherit;
    border: 1px solid rgba(255,255,255,0.5);
    border-radius: 4px;
}
.pl-table select.table-header-filter option {
    background: #fff;
    color: #333;
}

/* Initiatives overview table: more compact to fit section */
/* R&D 6-year cashflow: wide table — scroll inside card instead of overflowing */
.rd-cashflow-table-wrap {
    max-width: 100%;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    margin-top: 20px;
    border-radius: 12px;
    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.06);
    background: #fff;
}

.rd-cashflow-table-wrap .pl-table.rd-cashflow-table {
    margin-top: 0;
    box-shadow: none;
    border-radius: 0;
    width: 100%;
    max-width: 100%;
    table-layout: fixed;
}

/* Narrower columns: stacked header lines + compact cells (no horizontal scroll on typical widths) */
.rd-cashflow-table.pl-table th {
    white-space: normal;
    line-height: 1.25;
    vertical-align: middle;
    text-align: center;
    padding: 10px 5px;
    font-size: 0.68em;
    hyphens: none;
}

.rd-cashflow-table.pl-table th:first-child {
    text-align: left;
    width: 9%;
}

.rd-cashflow-table.pl-table td {
    padding: 8px 5px;
    font-size: 0.8em;
}

.rd-initiatives-overview-table.pl-table th,
.rd-initiatives-overview-table.pl-table td {
    padding: 6px 10px;
    font-size: 0.88em;
}
.rd-initiatives-overview-table.pl-table th {
    font-size: 0.78em;
}

/* ── KPI Dashboard ── */
.kpi-dashboard {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 14px;
    margin-top: 20px;
}

.kpi-card {
    background: rgba(255, 255, 255, 0.85);
    border: 1px solid rgba(255, 255, 255, 0.7);
    border-radius: 14px;
    padding: 16px;
    box-shadow: 0 2px 12px rgba(0,0,0,0.06);
    transition: transform 0.18s ease, box-shadow 0.18s ease;
}

.kpi-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 22px rgba(0,0,0,0.1);
}

.kpi-card h4 {
    color: var(--tss-magenta-web);
    font-size: 0.78em;
    margin-bottom: 8px;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    font-weight: 700;
}

.kpi-value {
    font-size: 1.55em;
    font-weight: 700;
    color: var(--tss-text-primary);
    letter-spacing: -0.02em;
}

/* ── Comparison / data tables ── */
.comparison-table {
    width: 100%;
    border-collapse: collapse;
    background: white;
    border-radius: 12px;
    overflow: hidden;
    box-shadow: 0 2px 14px rgba(0,0,0,0.07);
    margin-top: 16px;
}

.comparison-table th,
.comparison-table td {
    padding: 11px 14px;
    text-align: left;
    border-bottom: 1px solid rgba(0,0,0,0.05);
    font-size: 0.9em;
}

.comparison-table th {
    background: var(--tss-navy);
    color: #fff;
    font-weight: 600;
    font-size: 0.82em;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.comparison-table tbody tr:hover {
    background: rgba(var(--tss-teal-rgb), 0.04);
}

.comparison-table tr.my-team {
    background: rgba(var(--tss-teal-rgb), 0.07);
    font-weight: 600;
}

/* ── Round counter ── */
.round-counter {
    text-align: center;
    padding: 22px;
    background: rgba(var(--tss-teal-rgb), 0.06);
    border-radius: 14px;
    margin-bottom: 20px;
    border: 1px solid rgba(var(--tss-teal-rgb), 0.12);
}

.round-counter h2 {
    color: var(--tss-navy);
    font-size: 2em;
    margin-bottom: 8px;
    font-weight: 700;
}

/* ── Team info panel ── */
.team-info {
    text-align: center;
    margin-bottom: 20px;
    padding: 16px;
    background: rgba(248, 249, 250, 0.8);
    border-radius: 12px;
    border: 1px solid rgba(0,0,0,0.06);
}

.team-info h3 {
    color: var(--tss-navy);
    margin-bottom: 5px;
    font-weight: 700;
}

/* ── Code display ── */
.code-display {
    background: rgba(255, 255, 255, 0.9);
    padding: 20px;
    border-radius: 12px;
    margin: 15px 0;
    text-align: center;
    border: 2px solid rgba(var(--tss-teal-rgb), 0.3);
    box-shadow: 0 2px 10px rgba(var(--tss-teal-rgb), 0.1);
}

.code-display .code {
    font-size: 1.4em;
    font-weight: 700;
    color: var(--tss-navy);
    font-family: 'SF Mono', 'Fira Code', 'Courier New', monospace;
    letter-spacing: 3px;
}

/* ── Round timer (floating pill) — TSS ── */
#roundTimer {
    position: fixed;
    top: 20px;
    right: 220px;
    background: linear-gradient(135deg, rgba(var(--tss-magenta-rgb), 0.9) 0%, rgba(var(--tss-navy-rgb), 0.92) 100%);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    color: white;
    padding: 12px 30px;
    border-radius: 50px;
    font-size: 1.3em;
    font-weight: 700;
    box-shadow:
        0 0 0 1px rgba(255,255,255,0.25) inset,
        0 8px 24px rgba(0, 0, 0, 0.3);
    z-index: 2000;
    display: none;
    font-family: 'SF Mono', 'Fira Code', 'Courier New', monospace;
    letter-spacing: 3px;
    border: 1px solid rgba(255, 255, 255, 0.2);
}

#roundTimer.warning {
    background: linear-gradient(135deg, rgba(243, 156, 18, 0.92) 0%, rgba(230, 126, 34, 0.92) 100%);
    animation: pulse 1s infinite;
}

#roundTimer.critical {
    background: linear-gradient(135deg, rgba(231, 76, 60, 0.92) 0%, rgba(192, 57, 43, 0.92) 100%);
    animation: pulse 0.5s infinite;
}

@keyframes pulse {
    0%, 100% { transform: scale(1); }
    50%       { transform: scale(1.04); }
}

/* ── Upload area (TSS) ── */
.upload-area {
    border: 2px dashed rgba(var(--tss-teal-rgb), 0.4);
    border-radius: 12px;
    padding: 30px;
    text-align: center;
    background: rgba(var(--tss-teal-rgb), 0.04);
    margin-bottom: 20px;
    transition: border-color 0.18s, background 0.18s;
}

.upload-area:hover {
    border-color: rgba(var(--tss-teal-rgb), 0.65);
    background: rgba(var(--tss-teal-rgb), 0.07);
}

.file-name {
    margin-top: 10px;
    color: #888;
    font-size: 0.88em;
}

/* ── Help tooltips ── */
.help-icon {
    display: inline-block;
    width: 17px;
    height: 17px;
    line-height: 17px;
    text-align: center;
    background: var(--tss-gradient-signature);
    color: white;
    border-radius: 50%;
    font-size: 11px;
    font-weight: 700;
    cursor: help;
    margin-left: 5px;
    position: relative;
}

.help-icon:hover::after {
    content: attr(data-tooltip);
    position: absolute;
    bottom: 125%;
    left: 50%;
    transform: translateX(-50%);
    background: rgba(18, 15, 45, 0.94);
    backdrop-filter: blur(12px);
    color: white;
    padding: 10px 14px;
    border-radius: 10px;
    font-size: 12px;
    font-weight: 400;
    white-space: normal;
    width: 260px;
    z-index: 1000;
    box-shadow: 0 8px 24px rgba(0,0,0,0.35);
    line-height: 1.5;
    text-align: left;
    border: 1px solid rgba(255,255,255,0.15);
}

.help-icon:hover::before {
    content: '';
    position: absolute;
    bottom: 115%;
    left: 50%;
    transform: translateX(-50%);
    border: 5px solid transparent;
    border-top-color: rgba(18, 15, 45, 0.94);
    z-index: 1000;
}

/* ── Metric cards ── */
.metric-card {
    background: rgba(255, 255, 255, 0.88);
    border-radius: 14px;
    padding: 16px;
    box-shadow: 0 2px 12px rgba(0,0,0,0.06);
    border: 1px solid rgba(0,0,0,0.05);
    transition: transform 0.18s ease, box-shadow 0.18s ease;
}

.metric-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(0,0,0,0.1);
}

/* ── Trend indicators ── */
.trend-arrow {
    display: inline-block;
    margin-left: 5px;
    font-size: 1.1em;
    font-weight: 700;
}

.trend-up     { color: #28a745; }
.trend-down   { color: #dc3545; }
.trend-neutral{ color: #f0a500; }

/* ── Badges ── */
.success-badge {
    display: inline-block;
    padding: 3px 11px;
    border-radius: 20px;
    font-size: 0.82em;
    font-weight: 700;
    animation: fadeIn 0.25s ease;
}

@keyframes fadeIn {
    from { opacity: 0; transform: scale(0.9); }
    to   { opacity: 1; transform: scale(1); }
}

/* ── Health score gradient text ── */
.health-score {
    font-size: 2.4em;
    font-weight: 800;
    background: var(--tss-gradient-decorative);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    letter-spacing: -0.03em;
}

/* ── Recommendation list ── */
.recommendation-list {
    list-style: none;
    padding: 0;
}

.recommendation-list li {
    padding: 10px 12px;
    margin: 7px 0;
    border-left: 3px solid var(--tss-teal);
    background: rgba(var(--tss-teal-rgb), 0.05);
    border-radius: 6px;
    display: flex;
    align-items: flex-start;
    gap: 10px;
    font-size: 0.92em;
    color: rgba(255, 255, 255, 0.95);
}

.recommendation-list li::before {
    content: '›';
    color: rgba(255, 255, 255, 0.85);
    font-weight: 800;
    font-size: 1.3em;
    line-height: 1.1;
    flex-shrink: 0;
}

/* ── Hidden utility ── */
.hidden {
    display: none !important;
}

/* ── GM Toggle Switches ── */
.gm-toggle {
    position: relative;
    display: inline-block;
    width: 42px;
    height: 24px;
    flex-shrink: 0;
}
.gm-toggle input {
    opacity: 0;
    width: 0;
    height: 0;
    position: absolute;
}
.gm-toggle-slider {
    position: absolute;
    cursor: pointer;
    top: 0; left: 0; right: 0; bottom: 0;
    background: #ccc;
    border-radius: 24px;
    transition: 0.2s;
}
.gm-toggle-slider:before {
    content: "";
    position: absolute;
    height: 18px;
    width: 18px;
    left: 3px;
    bottom: 3px;
    background: white;
    border-radius: 50%;
    transition: 0.2s;
    box-shadow: 0 1px 3px rgba(0,0,0,0.25);
}
.gm-toggle input:checked + .gm-toggle-slider { background: var(--tss-magenta-web); }
.gm-toggle input:checked + .gm-toggle-slider:before { transform: translateX(18px); }

/* Smaller variant for event-type lists */
.gm-toggle-sm {
    width: 32px;
    height: 18px;
}
.gm-toggle-sm .gm-toggle-slider:before {
    height: 12px;
    width: 12px;
    left: 3px;
    bottom: 3px;
}
.gm-toggle-sm input:checked + .gm-toggle-slider:before { transform: translateX(14px); }

/* ══════════════════════════════════════════════════════════════
   DARK MODE
   Single source of truth — applied via body.dark-mode class.
   JS only does: document.body.classList.toggle('dark-mode').
   !important is needed to override inline style attributes.

   Palette (follows WCAG 4.5:1 contrast + dark-mode UX guide):
     Layer 0  #1a1a1a  page background
     Layer 1  #252525  modals / main surface
     Layer 2  #2e2e2e  cards / panels
     Layer 3  #383838  inputs / elevated surfaces
     Layer 4  #444444  hover / pressed
     Border   #3e3e3e
     Text     #e0e0e0  primary (never pure white)
     Text2    #a0a0a0  secondary / muted
     Accent   light magenta/pink on dark (TSS web magenta family)
   ══════════════════════════════════════════════════════════════ */

/* ── CSS custom properties ── */
body.dark-mode {
    --dm-0:      #1a1a1a;
    --dm-1:      #252525;
    --dm-2:      #2e2e2e;
    --dm-3:      #383838;
    --dm-4:      #444444;
    --dm-border: #3e3e3e;
    --dm-text:   #e0e0e0;
    --dm-text2:  #a0a0a0;
    --dm-text3:  #5e5e5e;
    /* Readable accent on dark surfaces (TSS magenta family) */
    --dm-accent-rgb: 232, 148, 200;
    --dm-accent: rgb(var(--dm-accent-rgb));
    --dm-ok:     #5cb87a;
    --dm-warn:   #d4a520;
    --dm-danger: #d96b6b;
    --dm-info:   #5ba3d4;

    /* Inline HTML uses var(--tss-surface-*) / borders / text — not literal hex, so
       [style*="#f9f9f9"] patches never matched. Remap tokens to dark layers. */
    --tss-surface-muted: var(--dm-2);
    --tss-surface-subtle: var(--dm-2);
    --tss-surface-warm: var(--dm-3);
    --tss-surface-blue-tint: rgba(var(--tss-navy-rgb), 0.25);
    --tss-bg-secondary: var(--dm-2);
    --tss-light-grey: var(--dm-border);
    --tss-border-subtle: var(--dm-border);
    --tss-border-hairline: var(--dm-border);
    --tss-border-info-tint: rgba(var(--tss-teal-rgb), 0.35);
    --tss-border-neutral: var(--dm-border);
    --tss-border-section: var(--dm-border);
    --tss-border-card: var(--dm-border);
    --tss-divider-faint: var(--dm-border);
    --tss-text-readonly: var(--dm-text2);
    --tss-text-primary: var(--dm-text);
    --tss-text-secondary: var(--dm-text2);
    --tss-text-soft: var(--dm-text2);
    --tss-text-muted: var(--dm-text2);
    --tss-text-dim: var(--dm-text2);
    --tss-text-caption: var(--dm-text2);
    --tss-panel-soft: rgba(var(--dm-accent-rgb), 0.12);
    --tss-panel-soft-border: rgba(var(--dm-accent-rgb), 0.28);
}

/* ── Page & containers ── */
body.dark-mode {
    background: var(--dm-0) !important;
    background-image: none !important;
    color: var(--dm-text) !important;
}

body.dark-mode .container,
body.dark-mode #gameContent {
    background: var(--dm-1) !important;
    color: var(--dm-text) !important;
}

body.dark-mode .content {
    background: var(--dm-0) !important;
}

/* ── Modal overlay tint ── */
body.dark-mode .modal {
    background: rgba(0, 0, 0, 0.82);
}

/* ── Modal surface ── */
body.dark-mode .modal-content {
    background: var(--dm-1) !important;
    color: var(--dm-text) !important;
    border-color: var(--dm-border) !important;
    box-shadow:
        0 0 0 1px rgba(255, 255, 255, 0.05) inset,
        0 30px 60px rgba(0, 0, 0, 0.70),
        0 4px 20px rgba(var(--tss-magenta-rgb), 0.1) !important;
}

/* ── Universal text override inside dark surfaces ──
   !important beats inline style="color: #xxx" attrs.
   Scoped to modal-content and #gameContent only.      ── */
body.dark-mode .modal-content p,
body.dark-mode .modal-content span:not(.gm-toggle-slider),
body.dark-mode .modal-content div,
body.dark-mode .modal-content label,
body.dark-mode .modal-content small,
body.dark-mode .modal-content li,
body.dark-mode .modal-content strong,
body.dark-mode .modal-content em,
body.dark-mode .modal-content a,
body.dark-mode .modal-content td,
body.dark-mode .modal-content th,
body.dark-mode #gameContent p,
body.dark-mode #gameContent span:not(.gm-toggle-slider),
body.dark-mode #gameContent div,
body.dark-mode #gameContent label,
body.dark-mode #gameContent small,
body.dark-mode #gameContent li,
body.dark-mode #gameContent strong,
body.dark-mode #gameContent em,
body.dark-mode #gameContent td,
body.dark-mode #gameContent th {
    color: var(--dm-text) !important;
}

/* ── Headings: desaturated accent (more readable than bright purple) ── */
body.dark-mode .modal-content h1,
body.dark-mode .modal-content h2,
body.dark-mode .modal-content h3,
body.dark-mode .modal-content h4,
body.dark-mode .modal-content h5,
body.dark-mode #gameContent h1,
body.dark-mode #gameContent h2,
body.dark-mode #gameContent h3,
body.dark-mode #gameContent h4,
body.dark-mode #gameContent h5 {
    color: var(--dm-accent) !important;
    border-color: rgba(var(--dm-accent-rgb), 0.28) !important;
}

/* ── Secondary / muted text ── */
body.dark-mode .modal-content small,
body.dark-mode #gameContent small {
    color: var(--dm-text2) !important;
}

/* Forecast vs Actuals (GM) — disclosure summary; inline navy is illegible on dark table rows */
.fa-how-calculated-summary {
    cursor: pointer;
    font-weight: 600;
    color: var(--tss-blue);
}
body.dark-mode #gameContent .fa-how-calculated-summary,
body.dark-mode .modal-content .fa-how-calculated-summary {
    color: var(--dm-info) !important;
}

/* Workforce — R&D initiative → PS demand (JS used to set #e7f3ff inline; rgb() bypassed dark attribute patches) */
.wf-rd-initiative-impact {
    padding: 12px;
    border-radius: 5px;
    margin-bottom: 15px;
    background: #e7f3ff;
    border: 1px solid #0d6efd;
}
.wf-rd-initiative-impact-title {
    font-weight: 600;
    margin-bottom: 5px;
    color: var(--tss-blue);
}
.wf-rd-initiative-impact-body {
    font-size: 0.9em;
    color: var(--tss-text-dim);
}
body.dark-mode #gameContent .wf-rd-initiative-impact {
    background: var(--dm-2) !important;
    border-color: var(--dm-border) !important;
}
body.dark-mode #gameContent .wf-rd-initiative-impact-title {
    color: var(--dm-accent) !important;
}
body.dark-mode #gameContent .wf-rd-initiative-impact-body {
    color: var(--dm-text) !important;
}
body.dark-mode #gameContent .wf-rd-initiative-impact-body strong {
    color: var(--dm-text) !important;
}

/* ── Inputs / selects / textareas ── */
body.dark-mode input:not([type="range"]),
body.dark-mode textarea,
body.dark-mode select {
    background-color: var(--dm-3) !important;
    color: var(--dm-text) !important;
    border-color: var(--dm-border) !important;
}

body.dark-mode input::placeholder,
body.dark-mode textarea::placeholder {
    color: var(--dm-text3) !important;
}

body.dark-mode input[type="range"] {
    accent-color: var(--dm-accent);
}

/* ── Tables ── */
body.dark-mode table {
    background-color: var(--dm-2) !important;
}

body.dark-mode th {
    background: var(--dm-3) !important;
    color: var(--dm-text) !important;
    border-color: var(--dm-border) !important;
}

body.dark-mode td {
    border-color: var(--dm-border) !important;
}

/* P&L / data tables: branded header on dark surfaces */
body.dark-mode .pl-table th {
    background: linear-gradient(90deg, #8f1f5c 0%, #003b6e 100%) !important;
    color: #f2f2f2 !important;
}

body.dark-mode .rd-cashflow-table-wrap {
    background: var(--dm-2) !important;
    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.35) !important;
}

/* ── Comparison table: keep gradient header readable ── */
body.dark-mode .comparison-table th {
    background: linear-gradient(90deg, #8f1f5c 0%, #003b6e 100%) !important;
    color: #f2f2f2 !important;
}

body.dark-mode .comparison-table tbody tr:hover td,
body.dark-mode .comparison-table tbody tr:hover {
    background: var(--dm-4) !important;
}

body.dark-mode .comparison-table tr.my-team td {
    background: rgba(var(--dm-accent-rgb), 0.12) !important;
}

/* ── Buttons ── */
body.dark-mode .btn-secondary {
    background: rgba(var(--tss-navy-rgb), 0.55) !important;
    color: #fff !important;
    border-color: rgba(255, 255, 255, 0.22) !important;
}

body.dark-mode .btn-secondary:hover {
    background: rgba(var(--tss-navy-rgb), 0.72) !important;
    border-color: rgba(255, 255, 255, 0.3) !important;
}

/* ── GM tab buttons ── */
body.dark-mode .tab-button-gm {
    color: #c8c8c8 !important;
    border-bottom-color: transparent !important;
}

body.dark-mode .tab-button-gm:hover {
    background: rgba(var(--dm-accent-rgb), 0.1) !important;
    color: var(--dm-accent) !important;
}

body.dark-mode .tab-button-gm.active {
    background: rgba(var(--dm-accent-rgb), 0.14) !important;
    color: var(--dm-accent) !important;
    border-bottom-color: var(--dm-accent) !important;
}

body.dark-mode .gm-save-btn {
    background: linear-gradient(90deg, #8f1f5c 0%, #003b6e 100%) !important;
    color: #fff !important;
}
body.dark-mode .gm-save-btn:hover {
    background: linear-gradient(90deg, #a0286a 0%, #004a85 100%) !important;
    filter: none;
}

/* ── Tab content panes ── */
body.dark-mode .tab-content,
body.dark-mode .gm-tab-content {
    background: transparent !important;
}

/* ── GM workforce data badges ── */
.gm-badge-draft {
    background: #fff3cd;
    color: #856404;
}
.gm-badge-actuals {
    background: #d4edda;
    color: #155724;
}
body.dark-mode .gm-badge-draft {
    background: #3a2800 !important;
    color: #f5c842 !important;
}
body.dark-mode .gm-badge-actuals {
    background: #0d2e1a !important;
    color: #5cb87a !important;
}

/* ── KPI cards ── */
body.dark-mode .kpi-card {
    background: var(--dm-2) !important;
    border-color: var(--dm-border) !important;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.35) !important;
}

body.dark-mode .kpi-card h4 {
    color: var(--dm-accent) !important;
}

body.dark-mode .kpi-value {
    color: var(--dm-text) !important;
}

/* ── Metric cards (class-based, not inline style) ── */
body.dark-mode .metric-card {
    background: var(--dm-2) !important;
    border-color: var(--dm-border) !important;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.35) !important;
}

/* ── Expense sections ── */
body.dark-mode .expense-section {
    background: var(--dm-2) !important;
    border-color: var(--dm-border) !important;
}

body.dark-mode .expense-section h3 {
    color: var(--dm-accent) !important;
    border-bottom-color: rgba(var(--dm-accent-rgb), 0.28) !important;
}

body.dark-mode .expense-compare-col-title {
    color: var(--dm-accent) !important;
}

/* Prior-year column: read-only reference — flat, dashed; not input-like */
body.dark-mode #gameContent .expense-prev:not(.expense-prev-total) {
    background: var(--dm-2) !important;
    border: 1px dashed rgba(255, 255, 255, 0.16) !important;
    color: var(--dm-text2) !important;
    box-shadow: none !important;
}

body.dark-mode #gameContent .expense-prev.expense-prev-total {
    background: transparent !important;
    border: none !important;
    color: var(--dm-accent) !important;
}

/* Current-round calculated fields: same visual language as prior-year (not editable) */
body.dark-mode #gameContent #operating-expenses .expense-input[readonly] {
    background: var(--dm-2) !important;
    color: var(--dm-text2) !important;
    border: 1px dashed rgba(255, 255, 255, 0.16) !important;
    box-shadow: none !important;
    cursor: not-allowed !important;
}

/* Current-round editable fields: stronger border + depth so they read as inputs */
body.dark-mode #gameContent #operating-expenses .expense-input:not([readonly]) {
    background: var(--dm-3) !important;
    color: var(--dm-text) !important;
    border: 1.5px solid rgba(var(--dm-accent-rgb), 0.42) !important;
    box-shadow:
        inset 0 2px 4px rgba(0, 0, 0, 0.28),
        0 0 0 1px rgba(255, 255, 255, 0.05) !important;
    cursor: text;
}

body.dark-mode #gameContent #operating-expenses .expense-input:not([readonly]):focus {
    border-color: var(--dm-accent) !important;
    box-shadow:
        inset 0 2px 4px rgba(0, 0, 0, 0.22),
        0 0 0 3px rgba(var(--dm-accent-rgb), 0.28) !important;
}

body.dark-mode #operating-expenses .expense-compare-header {
    border-bottom-color: var(--dm-border) !important;
}

body.dark-mode #gameContent .expense-label {
    color: var(--dm-text2) !important;
}

body.dark-mode .metric-value:not(.negative):not(.positive) {
    color: var(--dm-accent) !important;
}

/* ── Team info bar ── */
body.dark-mode .team-info {
    background: var(--dm-1) !important;
    border-color: var(--dm-border) !important;
}

/* Team login code cards — light panel + modal div { color: dm-text !important } = washed-out text */
body.dark-mode .code-display {
    background: var(--dm-2) !important;
    border-color: rgba(var(--tss-teal-rgb), 0.38) !important;
    box-shadow: 0 2px 14px rgba(0, 0, 0, 0.4);
}

body.dark-mode .modal-content .code-display .code {
    color: var(--dm-info) !important;
}

body.dark-mode .modal-content .code-display > div:first-child {
    color: var(--dm-accent) !important;
}

/* ── Round counter ── */
body.dark-mode .round-counter {
    background: rgba(var(--dm-accent-rgb), 0.08) !important;
    border-color: rgba(var(--dm-accent-rgb), 0.22) !important;
}

body.dark-mode .round-counter h2 {
    color: var(--dm-accent) !important;
}

/* ══ Inline background colour patches ══
   CSS attribute selectors [style*="…"] override the most
   common hardcoded background colours used in HTML divs.
   This is the single place to maintain all colour mappings.  */

/* Light grey / white panels → Layer 2 */
body.dark-mode .modal-content [style*="#f9f9f9"],
body.dark-mode .modal-content [style*="#f8f9fa"],
body.dark-mode .modal-content [style*="#f5f5f5"],
body.dark-mode .modal-content [style*="#f0f0f0"],
body.dark-mode .modal-content [style*="#eeeeee"],
body.dark-mode .modal-content [style*="#e9ecef"],
body.dark-mode .modal-content [style*="background: white"],
body.dark-mode .modal-content [style*="background:white"],
body.dark-mode .modal-content [style*="background: #fff"],
body.dark-mode .modal-content [style*="background:#fff"],
body.dark-mode .modal-content [style*="background: #FFF"],
body.dark-mode .modal-content [style*="rgba(255, 255, 255, 0.85)"],
body.dark-mode .modal-content [style*="rgba(255,255,255,0.85)"],
body.dark-mode #gameContent [style*="#f9f9f9"],
body.dark-mode #gameContent [style*="#f8f9fa"],
body.dark-mode #gameContent [style*="#f5f5f5"],
body.dark-mode #gameContent [style*="#f0f0f0"],
body.dark-mode #gameContent [style*="#eeeeee"],
body.dark-mode #gameContent [style*="#e9ecef"],
body.dark-mode #gameContent [style*="background: #fff"],
body.dark-mode #gameContent [style*="background:#fff"],
body.dark-mode #gameContent [style*="background: white"],
body.dark-mode #gameContent [style*="background:white"],
body.dark-mode #gameContent [style*="rgba(255, 255, 255, 0.85)"],
body.dark-mode #gameContent [style*="rgba(255,255,255,0.85)"] {
    background: var(--dm-2) !important;
    border-color: var(--dm-border) !important;
}

/* Light blue / purple info panels → dark teal-blue */
body.dark-mode .modal-content [style*="#f0f3ff"],
body.dark-mode .modal-content [style*="#f0f2ff"],
body.dark-mode .modal-content [style*="#f0f4ff"],
body.dark-mode .modal-content [style*="#e8f0fe"],
body.dark-mode .modal-content [style*="#e8f4f8"],
body.dark-mode .modal-content [style*="#e3e8ff"],
body.dark-mode .modal-content [style*="#ede7f6"],
body.dark-mode .modal-content [style*="#eef2ff"],
body.dark-mode .modal-content [style*="#f3e5f5"],
body.dark-mode .modal-content [style*="#e8eaf6"],
body.dark-mode .modal-content [style*="#eef1ff"],
body.dark-mode .modal-content [style*="#e8ecff"],
body.dark-mode #gameContent [style*="#f0f3ff"],
body.dark-mode #gameContent [style*="#f0f2ff"],
body.dark-mode #gameContent [style*="#f0f4ff"],
body.dark-mode #gameContent [style*="#e8f0fe"],
body.dark-mode #gameContent [style*="#e8f4f8"],
body.dark-mode #gameContent [style*="#e8f4fd"],
body.dark-mode #gameContent [style*="#e8eaf6"],
body.dark-mode #gameContent [style*="#e3e8ff"],
body.dark-mode #gameContent [style*="#e3f2fd"],
body.dark-mode #gameContent [style*="#ede7f6"],
body.dark-mode #gameContent [style*="#eef2ff"],
body.dark-mode #gameContent [style*="#eef1ff"],
body.dark-mode #gameContent [style*="#e8ecff"],
body.dark-mode #gameContent [style*="#e7f3ff"],
body.dark-mode .modal-content [style*="#e7f3ff"],
body.dark-mode #gameContent [style*="#e8f4ff"],
body.dark-mode .modal-content [style*="#e8f4ff"] {
    background: rgba(var(--tss-blue-rgb), 0.22) !important;
    border-color: rgba(var(--tss-teal-rgb), 0.35) !important;
}

/* TSS soft panels (CSS var or literal rgba from JS templates) */
body.dark-mode .modal-content [style*="tss-teal-rgb"],
body.dark-mode #gameContent [style*="tss-teal-rgb"],
body.dark-mode .modal-content [style*="83, 183, 237"],
body.dark-mode #gameContent [style*="83, 183, 237"],
body.dark-mode .modal-content [style*="83,183,237"],
body.dark-mode #gameContent [style*="83,183,237"],
body.dark-mode .modal-content [style*="67, 206, 162"],
body.dark-mode #gameContent [style*="67, 206, 162"],
body.dark-mode .modal-content [style*="67,206,162"],
body.dark-mode #gameContent [style*="67,206,162"] {
    background: rgba(var(--dm-accent-rgb), 0.14) !important;
    border-color: rgba(var(--dm-accent-rgb), 0.35) !important;
}

/* Warning / amber / peach panels → dark amber */
body.dark-mode .modal-content [style*="#fff3cd"],
body.dark-mode .modal-content [style*="#fff3e0"],
body.dark-mode .modal-content [style*="#fff8e1"],
body.dark-mode .modal-content [style*="#fef9e7"],
body.dark-mode .modal-content [style*="#ffeeba"],
body.dark-mode .modal-content [style*="#fff0d0"],
body.dark-mode .modal-content [style*="#fde8d8"],
body.dark-mode .modal-content [style*="#ffe8d0"],
body.dark-mode #gameContent [style*="#fff3cd"],
body.dark-mode #gameContent [style*="#fff3e0"],
body.dark-mode #gameContent [style*="#fff8e1"],
body.dark-mode #gameContent [style*="#fef9e7"],
body.dark-mode #gameContent [style*="#fff0d0"],
body.dark-mode #gameContent [style*="#fde8d8"],
body.dark-mode #gameContent [style*="#ffe8d0"] {
    background: #2b2000 !important;
    border-color: #564000 !important;
}

/* Success / green panels → dark green */
body.dark-mode .modal-content [style*="#d4edda"],
body.dark-mode .modal-content [style*="#e8f5e9"],
body.dark-mode .modal-content [style*="#c3e6cb"],
body.dark-mode .modal-content [style*="#dff0d8"],
body.dark-mode .modal-content [style*="#f8fff8"],
body.dark-mode #gameContent [style*="#d4edda"],
body.dark-mode #gameContent [style*="#e8f5e9"],
body.dark-mode #gameContent [style*="#f8fff8"] {
    background: #1a2c20 !important;
    border-color: #2c5035 !important;
}

/* Error / red panels → dark red */
body.dark-mode .modal-content [style*="#f8d7da"],
body.dark-mode .modal-content [style*="#fdecea"],
body.dark-mode .modal-content [style*="#ffebee"],
body.dark-mode .modal-content [style*="#fff8f8"],
body.dark-mode #gameContent [style*="#f8d7da"],
body.dark-mode #gameContent [style*="#fff8f8"] {
    background: #2c1818 !important;
    border-color: #5a2a2a !important;
}

/* Gradient accent bars — TSS magenta/navy in dark mode */
body.dark-mode .modal-content [style*="linear-gradient(135deg, #43cea2"],
body.dark-mode .modal-content [style*="linear-gradient(135deg, #667eea"],
body.dark-mode .modal-content [style*="linear-gradient(135deg, var(--tss-teal)"],
body.dark-mode .modal-content [style*="linear-gradient(135deg, var(--tss-magenta-web)"],
body.dark-mode #gameContent [style*="linear-gradient(135deg, #43cea2"],
body.dark-mode #gameContent [style*="linear-gradient(135deg, #667eea"],
body.dark-mode #gameContent [style*="linear-gradient(135deg, var(--tss-teal)"],
body.dark-mode #gameContent [style*="linear-gradient(135deg, var(--tss-magenta-web)"],
body.dark-mode .modal-content [style*="linear-gradient(135deg,#667eea"],
body.dark-mode #gameContent [style*="linear-gradient(135deg,#667eea"] {
    background: linear-gradient(90deg, #8f1f5c 0%, #003b6e 100%) !important;
}

/* Horizontal progress bars (innovation etc.) */
body.dark-mode .modal-content [style*="linear-gradient(90deg, var(--tss-teal)"],
body.dark-mode #gameContent [style*="linear-gradient(90deg, var(--tss-teal)"] {
    background: linear-gradient(90deg, #8f1f5c, #003b6e) !important;
}

/* Team view: mixed gradient using TSS soft start */
body.dark-mode .modal-content [style*="rgba(var(--tss-teal-rgb),0.11) 0%"],
body.dark-mode #gameContent [style*="rgba(var(--tss-teal-rgb),0.11) 0%"] {
    background: linear-gradient(135deg, rgba(var(--dm-accent-rgb), 0.12) 0%, rgba(var(--tss-blue-rgb), 0.35) 100%) !important;
    border-color: rgba(var(--dm-accent-rgb), 0.45) !important;
}

/* ── Toggle slider: keep its own colours ── */
body.dark-mode .gm-toggle-slider {
    /* unchecked state stays grey — already looks fine in dark */
}

/* ── Financials section-header rows (JS sets backgroundColor via .style, so class needed) ── */
body.dark-mode .fin-section-header {
    background-color: var(--dm-3) !important;
}

body.dark-mode .fin-section-header td {
    color: var(--dm-accent) !important;
}

/* ── JS-dynamically-styled elements (set via element.style.X — browser converts to rgb, so target by ID) ── */
body.dark-mode #psBillabilityNpsNote {
    background: var(--dm-3) !important;
    color: var(--dm-text) !important;
    border-color: var(--dm-border) !important;
}

body.dark-mode #wcCashImpact {
    background: var(--dm-2) !important;
    color: var(--dm-text) !important;
    border-color: var(--dm-border) !important;
}

/* ── SVG charts — dark mode ──────────────────────────────────────────────────
   SVG presentational attributes (fill/stroke="…") can be overridden by CSS.
   Only structural colours are targeted here; team colours remain untouched.
   ─────────────────────────────────────────────────────────────────────────── */

/* Plot area background */
body.dark-mode svg rect[fill="#fafafa"] {
    fill: var(--dm-1) !important;
    stroke: var(--dm-border) !important;
}

/* Axis border lines & zero-reference lines */
body.dark-mode svg line[stroke="#999"],
body.dark-mode svg line[stroke="#ddd"],
body.dark-mode svg line[stroke="#ccc"] {
    stroke: #555 !important;
}

/* Grid lines */
body.dark-mode svg line[stroke="#e0e0e0"],
body.dark-mode svg line[stroke="#eee"],
body.dark-mode svg line[stroke="#f0f0f0"] {
    stroke: #2e2e48 !important;
}

/* Tick + axis labels (grey/dark text → readable on dark background) */
body.dark-mode svg text[fill="#666"],
body.dark-mode svg text[fill="#555"],
body.dark-mode svg text[fill="#333"],
body.dark-mode svg text[fill="#aaa"] {
    fill: #909090 !important;
}

body.dark-mode svg text[fill="#667eea"],
body.dark-mode svg text[fill="#185a9d"],
body.dark-mode svg text[fill="#004A91"],
body.dark-mode svg text[fill="#004a91"] {
    fill: var(--dm-accent) !important;
}

body.dark-mode svg polyline[stroke="#667eea"],
body.dark-mode svg polyline[stroke="#185a9d"],
body.dark-mode svg polyline[stroke="#004A91"],
body.dark-mode svg polyline[stroke="#004a91"] {
    stroke: var(--dm-accent) !important;
}

/* ── Scrollbar inside modals ── */
body.dark-mode .modal-content::-webkit-scrollbar-track {
    background: var(--dm-2);
}

body.dark-mode .modal-content::-webkit-scrollbar-thumb {
    background: var(--dm-4);
    border-color: var(--dm-2);
}

/* ── Support Strategy Mini-Game ── */
.support-strategy-card {
    flex: 1;
    cursor: pointer;
    border: 2px solid #ddd;
    border-radius: 10px;
    padding: 14px 16px;
    background: #fff;
    transition: border-color 0.2s, background 0.2s, box-shadow 0.2s;
    position: relative;
}
.support-strategy-card:hover {
    border-color: rgba(var(--tss-teal-rgb), 0.6);
    box-shadow: 0 2px 8px rgba(var(--tss-teal-rgb), 0.15);
}
.support-strategy-card.active {
    border-color: var(--tss-teal);
    background: #e6f7f4;
    box-shadow: 0 2px 10px rgba(var(--tss-teal-rgb), 0.2);
}
.support-strategy-card.recommended::after {
    content: '★ Recommended';
    position: absolute;
    top: -10px;
    right: 10px;
    background: var(--tss-teal);
    color: white;
    font-size: 0.72em;
    font-weight: 700;
    padding: 2px 8px;
    border-radius: 10px;
}
.support-strategy-card.active.recommended::after {
    background: var(--tss-blue);
}
.support-strategy-card .strategy-icon {
    font-size: 1.5em;
    margin-bottom: 4px;
}
.support-strategy-card strong {
    display: block;
    margin-bottom: 4px;
    color: #333;
}
.support-strategy-card p {
    font-size: 0.85em;
    color: #555;
    margin: 0 0 6px 0;
}
.support-strategy-card small {
    font-size: 0.78em;
    color: #888;
}
.scenario-card {
    border-radius: 10px;
    padding: 12px 16px;
    display: flex;
    align-items: flex-start;
    gap: 12px;
    font-size: 0.9em;
}
.scenario-card .scenario-icon {
    font-size: 1.8em;
    line-height: 1;
    flex-shrink: 0;
}
.scenario-card .scenario-body strong {
    display: block;
    margin-bottom: 2px;
}
.scenario-card.scenario-warning { background: #fff3cd; border: 1px solid #ffc107; }
.scenario-card.scenario-danger  { background: #fde8e8; border: 1px solid #dc3545; }
.scenario-card.scenario-success { background: #e8f5e9; border: 1px solid #28a745; }
.scenario-card.scenario-info    { background: #e6f7f4; border: 1px solid var(--tss-teal); }

/* Dark mode */
body.dark-mode .support-strategy-card {
    background: var(--dm-2);
    border-color: var(--dm-4);
    color: var(--dm-text);
}
body.dark-mode .support-strategy-card.active {
    border-color: var(--dm-accent);
    background: var(--dm-3);
}
body.dark-mode .support-strategy-card strong { color: var(--dm-text); }
body.dark-mode .support-strategy-card p { color: #aaa; }
body.dark-mode .support-strategy-card small { color: #777; }
body.dark-mode .scenario-card.scenario-warning { background: #3a2e00; border-color: #996600; }
body.dark-mode .scenario-card.scenario-danger  { background: #3a0a0a; border-color: #992222; }
body.dark-mode .scenario-card.scenario-success { background: #0a2e0a; border-color: #226622; }
body.dark-mode .scenario-card.scenario-info    { background: var(--dm-3); border-color: var(--tss-teal); }

/* GM disruption preview: random event impact tables share column layout */
#disruptionPreviewPanel .random-event-impact-table {
    table-layout: fixed;
    width: 100%;
}
#disruptionPreviewPanel .random-event-impact-table th,
#disruptionPreviewPanel .random-event-impact-table td {
    vertical-align: top;
    overflow-wrap: break-word;
    word-break: break-word;
}
#disruptionPreviewPanel .random-event-impact-table th:nth-child(1),
#disruptionPreviewPanel .random-event-impact-table td:nth-child(1) { width: 14%; }
#disruptionPreviewPanel .random-event-impact-table th:nth-child(2),
#disruptionPreviewPanel .random-event-impact-table td:nth-child(2) { width: 13%; }
#disruptionPreviewPanel .random-event-impact-table th:nth-child(3),
#disruptionPreviewPanel .random-event-impact-table td:nth-child(3) { width: 13%; }
#disruptionPreviewPanel .random-event-impact-table th:nth-child(4),
#disruptionPreviewPanel .random-event-impact-table td:nth-child(4) { width: 13%; }
#disruptionPreviewPanel .random-event-impact-table th:nth-child(5),
#disruptionPreviewPanel .random-event-impact-table td:nth-child(5) { width: 12%; }
#disruptionPreviewPanel .random-event-impact-table th:nth-child(6),
#disruptionPreviewPanel .random-event-impact-table td:nth-child(6) { width: 18%; }
#disruptionPreviewPanel .random-event-impact-table th:nth-child(7),
#disruptionPreviewPanel .random-event-impact-table td:nth-child(7) { width: 17%; }

/* Fixed top bar (index.html): same height for language / theme / logout */
/* Version sits below logout in the margin; does not participate in flex row height (keeps buttons aligned). */
#headerButtons .header-logout-wrap {
    position: relative;
    display: inline-flex;
    align-items: center;
}
#headerButtons .header-app-version {
    position: absolute;
    top: calc(100% + 3px);
    left: 50%;
    transform: translateX(-50%);
    font-size: 0.65em;
    opacity: 0.45;
    user-select: none;
    white-space: nowrap;
    color: white;
    pointer-events: none;
    line-height: 1.2;
}
#headerButtons .vms-lang-switcher__btn,
#headerButtons #themeToggle,
#headerButtons #logoutBtn {
    min-height: 36px;
    box-sizing: border-box;
}
#headerButtons .vms-lang-switcher__btn {
    padding: 0 10px;
    border-radius: 8px;
}
#headerButtons #themeToggle,
#headerButtons #logoutBtn {
    align-items: center;
    justify-content: center;
    padding: 0 12px;
    border-radius: 8px;
    cursor: pointer;
    line-height: 1;
}
#headerButtons #themeToggle {
    background: rgba(255, 255, 255, 0.15);
    border: 1px solid rgba(255, 255, 255, 0.3);
    backdrop-filter: blur(10px);
    color: #fff;
    font-size: 1rem;
}
#headerButtons #logoutBtn {
    background: var(--tss-danger);
    color: #fff;
    border: none;
    font-weight: 600;
    font-size: 0.875rem;
    gap: 6px;
}

/* Language switcher: custom control (real flag SVGs; native <select> drops emoji flags on Windows) */
.vms-lang-switcher {
    position: relative;
    display: inline-block;
    font-size: 0.85em;
}
.vms-lang-switcher__btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 5px 8px;
    border-radius: 7px;
    border: 1px solid rgba(255, 255, 255, 0.35);
    background: rgba(255, 255, 255, 0.15);
    color: white;
    cursor: pointer;
    backdrop-filter: blur(10px);
    font: inherit;
    line-height: 1.2;
}
.vms-lang-switcher__btn:focus-visible {
    outline: 2px solid rgba(255, 255, 255, 0.6);
    outline-offset: 2px;
}
.vms-lang-switcher__flag {
    display: inline-block;
    width: 20px;
    height: 15px;
    vertical-align: middle;
    border-radius: 2px;
    flex-shrink: 0;
    box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.15);
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}
.vms-lang-switcher__chev {
    font-size: 0.7em;
    opacity: 0.9;
    margin-left: 2px;
}
.vms-lang-switcher__menu {
    position: absolute;
    right: 0;
    top: calc(100% + 4px);
    min-width: 100%;
    list-style: none;
    margin: 0;
    padding: 4px 0;
    border-radius: 8px;
    border: 1px solid rgba(255, 255, 255, 0.25);
    background: rgba(30, 40, 55, 0.97);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.25);
    z-index: 1200;
}
.vms-lang-switcher__option {
    display: flex;
    align-items: center;
    gap: 8px;
    width: 100%;
    padding: 8px 12px;
    border: none;
    background: transparent;
    color: white;
    font: inherit;
    text-align: left;
    cursor: pointer;
}
.vms-lang-switcher__option:hover,
.vms-lang-switcher__option:focus-visible {
    background: rgba(255, 255, 255, 0.12);
    outline: none;
}
.vms-lang-switcher--light .vms-lang-switcher__btn {
    color: var(--tss-text-primary);
    background: #f5f5f5;
    border: 1px solid #ccc;
    backdrop-filter: none;
}
.vms-lang-switcher--light .vms-lang-switcher__btn:focus-visible {
    outline-color: var(--tss-navy);
}
.vms-lang-switcher--light .vms-lang-switcher__menu {
    background: #fff;
    border-color: #ccc;
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.12);
}
.vms-lang-switcher--light .vms-lang-switcher__option {
    color: var(--tss-text-primary);
}
.vms-lang-switcher--light .vms-lang-switcher__option:hover,
.vms-lang-switcher--light .vms-lang-switcher__option:focus-visible {
    background: #eee;
}

.gm-filter-option:hover { background: #f0f4ff; }

/* Off-screen but in the tree: screen readers + Chromium password-form hints */
.vms-sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}
