/* ══════════════════════════════════════════════════════════════
   Scuby's AutoDarts – 2026 Glassmorphism Dashboard Theme
   ══════════════════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&family=JetBrains+Mono:wght@400;600&display=swap');

/* ── Beta Badge ── */
.beta-badge {
    display: inline-block;
    font-size: .7rem;
    font-weight: 800;
    letter-spacing: .08em;
    text-transform: uppercase;
    padding: .2em .55em;
    border-radius: 4px;
    background: linear-gradient(135deg, var(--accent), var(--accent-2));
    color: #fff;
    vertical-align: super;
    line-height: 1;
    margin-left: .25rem;
    box-shadow: 0 0 8px rgba(99,102,241, 0.4);
}

:root {
    --bg:         #080c1a;
    --bg-panel:   rgba(15, 23, 55, 0.65);
    --glass:      rgba(255,255,255, 0.04);
    --glass-border: rgba(255,255,255, 0.08);
    --accent:     #6366f1;
    --accent-2:   #8b5cf6;
    --accent-3:   #a78bfa;
    --neon-blue:  #38bdf8;
    --neon-cyan:  #22d3ee;
    --neon-pink:  #f472b6;
    --text:       #f0f4ff;
    --text-dim:   #7c8db5;
    --green:      #22c55e;
    --red:        #ef4444;
    --gold:       #fbbf24;
    --blue:       #60a5fa;
    --radius:     16px;
    --radius-sm:  10px;
    --radius-xs:  6px;
    --shadow-glow: 0 0 40px rgba(99,102,241, 0.12), 0 8px 32px rgba(0,0,0,0.4);
    --shadow-card: 0 4px 24px rgba(0,0,0, 0.3), inset 0 1px 0 rgba(255,255,255, 0.05);
    --transition:  all .3s cubic-bezier(.4,0,.2,1);
}

/* ── Reset & Base ── */
*, *::before, *::after { box-sizing: border-box; }

body {
    background: var(--bg);
    background-image:
        radial-gradient(ellipse 80% 60% at 20% 10%, rgba(99,102,241,0.12) 0%, transparent 60%),
        radial-gradient(ellipse 60% 50% at 80% 80%, rgba(56,189,248,0.08) 0%, transparent 60%),
        radial-gradient(ellipse 40% 40% at 50% 50%, rgba(139,92,246,0.06) 0%, transparent 70%);
    background-attachment: fixed;
    color: var(--text);
    font-family: 'Inter', system-ui, -apple-system, sans-serif;
    min-height: 100vh;
    -webkit-font-smoothing: antialiased;
}

/* ── Animated Gradient Navbar ── */
.navbar-brand-wrap {
    display: flex;
    align-items: center;
    gap: .75rem;
}

/* ── Tab Pills (glassmorphism) ── */
.nav-pills .nav-link {
    background: var(--bg-panel);
    border: 1px solid var(--glass-border);
    border-radius: var(--radius-sm);
    color: var(--text-dim);
    font-weight: 600;
    font-size: .88rem;
    letter-spacing: .03em;
    padding: .55rem 1.4rem;
    backdrop-filter: blur(12px);
    transition: var(--transition);
}
.nav-pills .nav-link:hover {
    color: var(--text);
    background: rgba(99,102,241, 0.15);
    border-color: rgba(99,102,241, 0.3);
}
.nav-pills .nav-link.active {
    background: linear-gradient(135deg, var(--accent) 0%, var(--accent-2) 100%);
    border-color: transparent;
    color: #fff;
    box-shadow: 0 0 20px rgba(99,102,241, 0.3);
}

/* ── Match History Filters ── */
#matchSearch,
#matchResult {
    background: rgba(15, 23, 55, 0.8);
    color: var(--text);
    border: 1px solid var(--glass-border);
    border-radius: var(--radius-xs);
    font-size: .82rem;
    transition: var(--transition);
    backdrop-filter: blur(8px);
}
#matchSearch:focus,
#matchResult:focus {
    border-color: var(--accent);
    box-shadow: 0 0 0 3px rgba(99,102,241, 0.15);
    outline: none;
}
#matchSearch::placeholder { color: var(--text-dim); }

/* ── Match History Table ── */
#matchTable {
    background: transparent;
    font-size: .87rem;
}
#matchTable thead th {
    border-bottom: 1px solid var(--glass-border);
    font-size: .78rem;
    text-transform: uppercase;
    letter-spacing: .05em;
    color: var(--text-dim);
    font-weight: 600;
}
#matchTable tbody tr {
    border-bottom: 1px solid rgba(255,255,255, 0.03);
    transition: background .2s;
}
#matchTable tbody tr:hover {
    background: rgba(99,102,241, 0.08);
}
.brand-icon {
    height: 3.2rem;
    max-height: 3.2rem;
    width: auto;
    vertical-align: middle;
    filter: drop-shadow(0 0 12px rgba(251,191,36,0.6));
}
.bg-brand {
    background: linear-gradient(135deg, #0f172a 0%, #1e1b4b 50%, #0f172a 100%) !important;
    border-bottom: 1px solid var(--glass-border);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    box-shadow: 0 1px 30px rgba(99,102,241, 0.15);
    padding: .75rem 1.5rem !important;
    position: relative;
    z-index: 1050;
}
.bg-brand .navbar-brand {
    font-weight: 800;
    font-size: 1.3rem;
    letter-spacing: -.02em;
    background: linear-gradient(135deg, #e0e7ff 0%, #a78bfa 50%, #38bdf8 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

/* ── Glass Cards ── */
.bg-panel {
    background: var(--bg-panel) !important;
    backdrop-filter: blur(24px) saturate(1.4);
    -webkit-backdrop-filter: blur(24px) saturate(1.4);
    border: 1px solid var(--glass-border) !important;
    box-shadow: var(--shadow-card);
}

.card {
    border-radius: var(--radius) !important;
    overflow: hidden;
    transition: var(--transition);
    border: 1px solid var(--glass-border);
}
.card:hover {
    border-color: rgba(99,102,241, 0.2);
    box-shadow: var(--shadow-glow);
    transform: translateY(-2px);
}
.card-header {
    background: rgba(255,255,255, 0.03) !important;
    border-bottom: 1px solid var(--glass-border) !important;
    color: var(--text);
    font-weight: 600;
    font-size: .9rem;
    letter-spacing: .01em;
    padding: .75rem 1.25rem;
}

/* ── Widget Collapse Toggle ── */
.collapsible-header {
    cursor: pointer;
    user-select: none;
    display: flex;
    align-items: center;
}
.collapsible-header:hover {
    background: rgba(255,255,255, 0.06) !important;
}
.collapse-chevron {
    margin-left: auto;
    font-size: .85rem;
    color: var(--text-dim);
    transition: transform .25s ease, color .2s;
    flex-shrink: 0;
}
.collapsible-header:hover .collapse-chevron { color: var(--accent); }
.widget-collapsed .collapse-chevron {
    transform: rotate(-90deg);
}

/* KPI collapse bar for headerless widgets */
.kpi-collapse-bar {
    display: flex;
    align-items: center;
    padding: .75rem 1.25rem;
    background: var(--bg-panel);
    backdrop-filter: blur(24px) saturate(1.4);
    -webkit-backdrop-filter: blur(24px) saturate(1.4);
    border: 1px solid var(--glass-border);
    border-radius: var(--radius);
    box-shadow: var(--shadow-card);
    font-size: .9rem;
    font-weight: 600;
    color: var(--text);
    letter-spacing: .01em;
    cursor: pointer;
    user-select: none;
}
.kpi-collapse-bar:hover {
    background: rgba(255,255,255, 0.06);
    border-color: rgba(99,102,241, 0.2);
}
.kpi-collapse-label {
    flex: 1;
}
.widget-collapsed .kpi-collapse-bar {
    border-radius: var(--radius);
}
.widget-collapsed .widget-inner {
    display: none !important;
}
.widget-collapsed > .grid-stack-item-content > .card > .card-body,
.widget-collapsed > .grid-stack-item-content > .card > .card-body * {
    display: none !important;
}

/* ── Widget Help (ⓘ) Icon ── */
.widget-help-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 1.3rem;
    height: 1.3rem;
    font-size: .75rem;
    line-height: 1;
    color: var(--text-dim);
    opacity: .5;
    cursor: pointer;
    margin-left: .5rem;
    flex-shrink: 0;
    border-radius: 50%;
    transition: opacity .2s, color .2s, background .2s;
    vertical-align: middle;
}
.widget-help-btn:hover {
    opacity: 1;
    color: var(--accent);
    background: rgba(99,102,241, 0.12);
}
.kpi-collapse-bar .widget-help-btn {
    margin-left: 0;
    margin-right: .5rem;
}

.card-body {
    padding: 1.25rem;
}

/* ── Accent Button ── */
.btn-accent {
    background: linear-gradient(135deg, var(--accent), var(--accent-2)) !important;
    color: #fff;
    border: none;
    font-weight: 700;
    border-radius: var(--radius-sm);
    padding: .65rem 1.5rem;
    text-transform: uppercase;
    letter-spacing: .05em;
    font-size: .85rem;
    box-shadow: 0 4px 20px rgba(99,102,241, 0.3);
    transition: var(--transition);
    position: relative;
    overflow: hidden;
}
.btn-accent::before {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, rgba(255,255,255,.15), transparent);
    opacity: 0;
    transition: opacity .3s;
}
.btn-accent:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 30px rgba(99,102,241, 0.4);
    color: #fff;
}
.btn-accent:hover::before { opacity: 1; }
.btn-accent:active { transform: translateY(0); }

/* ── KPI Cards ── */
.kpi-card {
    background: var(--bg-panel);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border: 1px solid var(--glass-border);
    border-radius: var(--radius);
    padding: .7rem 1.1rem;
    box-shadow: var(--shadow-card);
    transition: var(--transition);
    position: relative;
    overflow: hidden;
}
.kpi-card::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 3px;
    background: linear-gradient(90deg, var(--accent), var(--neon-cyan), var(--accent-2));
    opacity: 0;
    transition: opacity .3s;
}
.kpi-card:hover {
    border-color: rgba(99,102,241, 0.2);
    transform: translateY(-3px);
    box-shadow: var(--shadow-glow);
}
.kpi-card:hover::before { opacity: 1; }

.kpi-title {
    font-size: .7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: var(--text-dim);
    margin-bottom: .6rem;
}
.kpi-values {
    display: flex;
    flex-wrap: wrap;
    gap: .4rem .85rem;
    align-items: baseline;
}
.kpi-val {
    font-family: 'JetBrains Mono', monospace;
    font-size: 1.2rem;
    font-weight: 700;
}
.kpi-delta {
    font-family: 'JetBrains Mono', monospace;
    font-size: .85rem;
    font-weight: 700;
    margin-left: auto;
    padding: .15rem .5rem;
    border-radius: var(--radius-xs);
}
.kpi-delta.pos {
    color: var(--green);
    background: rgba(34,197,94, 0.12);
}
.kpi-delta.neg {
    color: var(--red);
    background: rgba(239,68,68, 0.12);
}
.kpi-delta.neutral {
    color: var(--gold);
    background: rgba(251,191,36, 0.12);
}

/* ── Preset dropdown ── */
#layoutToolbar,
#matchLayoutToolbar {
    position: relative;
    z-index: 1020;
}
.preset-load-link { font-size: .85rem; }
.preset-delete-btn { font-size: .7rem; opacity: .5; }
.preset-delete-btn:hover { opacity: 1; }
#presetSaveModal .form-control { background: rgba(15,23,55,.8); color: var(--text); border-color: var(--glass-border); }
#presetSaveModal .form-control:focus { border-color: var(--accent); box-shadow: 0 0 0 3px rgba(99,102,241,.15); }

.period-color {
    display: inline-block;
    width: 10px;
    height: 10px;
    border-radius: 50%;
    margin-right: 5px;
    vertical-align: middle;
    box-shadow: 0 0 6px currentColor;
}

/* ── Period Selector ── */
#periodSearch {
    background: rgba(15, 23, 55, 0.8);
    color: var(--text);
    border: 1px solid var(--glass-border);
    border-radius: var(--radius-sm);
    padding: .55rem 1rem;
    font-size: .9rem;
    transition: var(--transition);
    backdrop-filter: blur(8px);
}
#periodSearch:focus {
    border-color: var(--accent);
    box-shadow: 0 0 0 3px rgba(99,102,241, 0.15);
    outline: none;
}
#periodSearch::placeholder { color: var(--text-dim); }

.period-checklist {
    max-height: 300px;
    overflow-y: auto;
    background: rgba(8, 12, 26, 0.7);
    border: 1px solid var(--glass-border);
    border-radius: var(--radius-sm);
    padding: .5rem;
    scrollbar-width: thin;
    scrollbar-color: var(--accent) transparent;
}
.period-checklist::-webkit-scrollbar { width: 6px; }
.period-checklist::-webkit-scrollbar-thumb {
    background: var(--accent);
    border-radius: 3px;
}
.period-checklist::-webkit-scrollbar-track { background: transparent; }

.period-checklist .form-check {
    padding: .35rem .6rem .35rem 1.85rem;
    border-radius: var(--radius-xs);
    margin-bottom: 1px;
    transition: background .15s;
}
.period-checklist .form-check:hover {
    background: rgba(99,102,241, 0.08);
}
.period-checklist .form-check-input {
    background-color: rgba(15,23,55, 0.8);
    border: 1.5px solid rgba(255,255,255,.15);
    border-radius: 4px;
    transition: var(--transition);
}
.period-checklist .form-check-input:checked {
    background-color: var(--accent);
    border-color: var(--accent);
    box-shadow: 0 0 8px rgba(99,102,241, 0.3);
}
.period-checklist .form-check-label {
    font-size: .85rem;
    cursor: pointer;
    width: 100%;
}
.period-checklist .period-avg {
    color: var(--text-dim);
    font-size: .75rem;
}
.period-checklist .period-hidden {
    display: none;
}

.btn-outline-light {
    border-color: var(--glass-border) !important;
    color: var(--text-dim) !important;
    font-size: .78rem;
    border-radius: var(--radius-xs);
    transition: var(--transition);
}
.btn-outline-light:hover {
    background: rgba(99,102,241, 0.15) !important;
    border-color: var(--accent) !important;
    color: var(--text) !important;
}

/* ── Loading Spinner ── */
.spinner-border {
    border-color: var(--accent);
    border-right-color: transparent;
    animation: spinner-border .9s linear infinite;
}
#spinner p {
    color: var(--text-dim);
    font-weight: 500;
    letter-spacing: .02em;
}

/* ── Dartboard canvas containers ── */
.board-wrap-full {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: .5rem;
}
.board-wrap-full canvas {
    border-radius: var(--radius-sm);
    max-width: 100%;
    box-shadow: 0 4px 20px rgba(0,0,0, 0.5);
}
.board-label {
    font-size: .78rem;
    margin-top: .5rem;
    text-align: center;
    color: var(--text-dim);
    line-height: 1.5;
}
.board-label strong {
    color: var(--text);
    font-weight: 600;
}

/* ── Chart.js canvas ── */
canvas {
    max-width: 100%;
}

/* ── Heatmap toggle switch ── */
.form-check-input:focus {
    box-shadow: 0 0 0 3px rgba(99,102,241, 0.2);
}
.form-switch .form-check-input:checked {
    background-color: var(--accent);
    border-color: var(--accent);
}

/* ── Footer ── */
footer {
    border-top: 1px solid var(--glass-border);
    margin-top: 2rem;
}
footer a {
    text-decoration: none;
    color: var(--accent-3) !important;
    transition: color .2s;
}
footer a:hover {
    color: var(--neon-cyan) !important;
    text-decoration: underline;
}

/* ── Chart Zoom Modal ── */
.bg-modal {
    background: rgba(8, 12, 26, 0.95) !important;
    backdrop-filter: blur(30px) saturate(1.4);
    -webkit-backdrop-filter: blur(30px) saturate(1.4);
    border: 1px solid var(--glass-border) !important;
    border-radius: var(--radius) !important;
    box-shadow: 0 0 80px rgba(99,102,241, 0.15), 0 16px 64px rgba(0,0,0,0.6);
}
.bg-modal .modal-header {
    padding: 1rem 1.5rem .5rem;
}
.bg-modal .modal-title {
    font-weight: 700;
    font-size: 1rem;
    letter-spacing: .01em;
    color: var(--text);
}
.bg-modal .modal-body {
    padding: 1rem 1.5rem 1.5rem;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    min-height: 60vh;
}

/* ── Stats comparison table ── */
#matchStatsTable {
    font-family: 'JetBrains Mono', 'Inter', monospace;
    font-size: .82rem;
}
#matchStatsTable thead th {
    background: rgba(99,102,241,0.08);
    border-bottom: 1px solid rgba(255,255,255,0.06);
    padding: .55rem .75rem;
    font-size: .78rem;
    letter-spacing: .02em;
}
#matchStatsTable tbody tr:nth-child(odd) {
    background: rgba(255,255,255,0.02);
}
#matchStatsTable tbody tr:hover {
    background: rgba(99,102,241,0.08);
}
#matchStatsTable tbody td {
    padding: .4rem .75rem;
    border-bottom: 1px solid rgba(255,255,255,0.03);
}

/* ══════════════════════════════════════════════════════════════
   GridStack Dashboard Layout Overrides
   ══════════════════════════════════════════════════════════════ */

.grid-stack {
    min-height: 100px;
}

.grid-stack > .grid-stack-item > .grid-stack-item-content {
    border-radius: var(--radius);
    overflow: hidden;
}

/* Widget inner for KPI rows that have no card wrapper */
.widget-inner {
    display: flex;
    flex-wrap: wrap;
    gap: .5rem;
    height: 100%;
    align-content: flex-start;
    width: 100%;
    padding: .25rem;
    overflow: hidden;
}
.widget-inner > div {
    flex: 1 1 200px;
    min-width: 160px;
}

/* When editing: show drag handles & resize outlines */
.gs-editing .grid-stack-item-content {
    outline: 2px dashed rgba(99,102,241, 0.4);
    outline-offset: -2px;
    cursor: move;
}

.gs-editing .grid-stack-item:hover > .grid-stack-item-content {
    outline-color: var(--accent);
    box-shadow: 0 0 20px rgba(99,102,241, 0.2);
}

/* ══════════════════════════════════════════════════════════════
   Admin & Settings Pages
   ══════════════════════════════════════════════════════════════ */

.admin-modal-content {
    background: rgba(15, 23, 55, 0.95) !important;
    backdrop-filter: blur(30px) saturate(1.4);
    -webkit-backdrop-filter: blur(30px) saturate(1.4);
    border: 1px solid var(--glass-border) !important;
    border-radius: var(--radius) !important;
    box-shadow: 0 0 80px rgba(99,102,241, 0.15), 0 16px 64px rgba(0,0,0,0.6);
}

.admin-label {
    font-size: .78rem;
    font-weight: 600;
    letter-spacing: .03em;
    text-transform: uppercase;
    color: var(--text-dim);
    margin-bottom: .3rem;
    display: block;
}

.admin-input {
    background: rgba(255,255,255, 0.04) !important;
    border: 1px solid var(--glass-border) !important;
    border-radius: var(--radius-xs) !important;
    color: var(--text) !important;
    padding: .55rem .8rem !important;
    font-size: .87rem !important;
    transition: var(--transition);
}
.admin-input:focus {
    background: rgba(255,255,255, 0.06) !important;
    border-color: var(--accent) !important;
    box-shadow: 0 0 0 3px rgba(99,102,241, 0.15) !important;
    color: var(--text) !important;
}
.admin-input::placeholder { color: var(--text-dim) !important; }
.admin-input[readonly] { opacity: .55; cursor: not-allowed; }
select.admin-input option {
    background: #1a1a2e;
    color: var(--text);
}

.admin-error {
    background: rgba(239,68,68, 0.12);
    border: 1px solid rgba(239,68,68, 0.3);
    border-radius: var(--radius-xs);
    color: #fca5a5;
    padding: .5rem .8rem;
    font-size: .84rem;
    text-align: center;
}

.admin-table {
    background: transparent;
    font-size: .87rem;
}
.admin-table thead th {
    border-bottom: 1px solid var(--glass-border);
    font-size: .76rem;
    text-transform: uppercase;
    letter-spacing: .05em;
    color: var(--text-dim);
    font-weight: 600;
    padding: .6rem .75rem;
}
.admin-table tbody tr {
    border-bottom: 1px solid rgba(255,255,255, 0.03);
    transition: background .2s;
}
.admin-table tbody tr:hover {
    background: rgba(99,102,241, 0.08);
}
.admin-table tbody td {
    padding: .55rem .75rem;
    vertical-align: middle;
}

/* ── Admin select dropdown ── */
.admin-select {
    max-width: 340px;
    font-size: .84rem;
    background-color: rgba(15, 23, 55, 0.9);
    border: 1px solid rgba(99, 102, 241, 0.3);
    color: var(--text);
    border-radius: var(--radius-xs);
    padding: .4rem .7rem;
    transition: var(--transition);
}
.admin-select:focus {
    background-color: rgba(15, 23, 55, 0.95);
    border-color: var(--accent);
    box-shadow: 0 0 0 3px rgba(99, 102, 241, 0.15);
    color: #fff;
}
.admin-select option {
    background: #0f1737;
    color: var(--text);
    padding: .4rem .6rem;
}
.admin-select option:checked,
.admin-select option:hover {
    background: linear-gradient(135deg, var(--accent), var(--accent-2));
    color: #fff;
}

.bg-accent-badge {
    background: linear-gradient(135deg, var(--accent) 0%, var(--accent-2) 100%) !important;
    font-size: .72rem;
    font-weight: 600;
    letter-spacing: .03em;
    padding: .25rem .55rem;
    border-radius: var(--radius-xs);
}

/* ── Admin user cards ── */
.admin-user-card {
    background: var(--glass);
    border: 1px solid var(--glass-border);
    border-radius: var(--radius-sm);
    margin-bottom: .5rem;
    transition: var(--transition);
}
.admin-user-card:hover {
    background: rgba(99,102,241, 0.06);
    border-color: rgba(99,102,241, 0.18);
}
.admin-user-card-body {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: .65rem .9rem;
    gap: .75rem;
}
.admin-user-info {
    display: flex;
    align-items: center;
    gap: .75rem;
    min-width: 0;
    flex: 1;
}
.admin-user-avatar {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--accent), var(--accent-2));
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: .85rem;
    color: #fff;
    flex-shrink: 0;
    text-transform: uppercase;
}
.admin-user-details {
    min-width: 0;
    flex: 1;
}
.admin-user-name {
    font-weight: 700;
    font-size: .88rem;
    color: var(--text);
    display: flex;
    align-items: center;
    gap: .4rem;
    flex-wrap: wrap;
}
.admin-user-name .badge {
    font-size: .62rem;
    padding: .15rem .4rem;
    vertical-align: middle;
}
.admin-user-meta {
    display: flex;
    align-items: center;
    gap: .75rem;
    flex-wrap: wrap;
    font-size: .76rem;
    color: var(--text-dim);
    margin-top: .1rem;
}
.admin-user-meta code {
    color: var(--neon-cyan);
    font-size: .76rem;
}
.admin-user-stats {
    color: var(--text-dim);
    font-variant-numeric: tabular-nums;
}

/* Badge variants */
.admin-badge-pro {
    background: linear-gradient(135deg, #059669, #10b981) !important;
    color: #fff;
    font-size: .62rem;
    font-weight: 600;
    padding: .15rem .4rem;
    border-radius: var(--radius-xs);
}
.admin-badge-trial {
    background: linear-gradient(135deg, #0891b2, #22d3ee) !important;
    color: #fff;
    font-size: .62rem;
    font-weight: 600;
    padding: .15rem .4rem;
    border-radius: var(--radius-xs);
}
.admin-badge-expired {
    background: rgba(255,255,255, 0.08) !important;
    color: var(--text-dim);
    font-size: .62rem;
    font-weight: 600;
    padding: .15rem .4rem;
    border-radius: var(--radius-xs);
}

/* Admin action buttons */
.admin-user-actions {
    display: flex;
    gap: .35rem;
    flex-shrink: 0;
}
.admin-action-btn {
    font-size: .72rem;
    font-weight: 600;
    padding: .3rem .6rem;
    border-radius: var(--radius-xs);
    border: 1px solid rgba(255,255,255, 0.10);
    background: rgba(255,255,255, 0.04);
    color: var(--text);
    cursor: pointer;
    transition: var(--transition);
    white-space: nowrap;
}
.admin-action-btn:hover {
    transform: translateY(-1px);
}
.admin-action-btn:disabled {
    opacity: .35;
    cursor: not-allowed;
    transform: none;
}
.admin-action-import {
    border-color: rgba(56,189,248, 0.25);
    color: var(--neon-blue);
}
.admin-action-import:hover:not(:disabled) {
    background: rgba(56,189,248, 0.12);
    border-color: rgba(56,189,248, 0.4);
}
.admin-action-purge {
    border-color: rgba(251,191,36, 0.25);
    color: #fbbf24;
}
.admin-action-purge:hover {
    background: rgba(251,191,36, 0.12);
    border-color: rgba(251,191,36, 0.4);
}
.admin-action-edit {
    border-color: rgba(99,102,241, 0.25);
    color: var(--accent-3);
}
.admin-action-edit:hover {
    background: rgba(99,102,241, 0.12);
    border-color: rgba(99,102,241, 0.4);
}
.admin-action-delete {
    border-color: rgba(239,68,68, 0.25);
    color: #f87171;
}
.admin-action-delete:hover {
    background: rgba(239,68,68, 0.12);
    border-color: rgba(239,68,68, 0.4);
}

/* Responsive: stack on small screens */
@media (max-width: 768px) {
    .admin-user-card-body {
        flex-direction: column;
        align-items: flex-start;
    }
    .admin-user-actions {
        width: 100%;
        justify-content: flex-end;
        padding-top: .4rem;
        border-top: 1px solid rgba(255,255,255, 0.04);
        margin-top: .3rem;
    }
}

/* ── Admin modal toggle switches ── */
.admin-toggle {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    cursor: pointer;
    user-select: none;
}
.admin-toggle input {
    position: absolute;
    opacity: 0;
    width: 0;
    height: 0;
}
.admin-toggle-track {
    position: relative;
    width: 38px;
    height: 20px;
    border-radius: 999px;
    background: rgba(255,255,255, 0.08);
    border: 1px solid rgba(255,255,255, 0.12);
    transition: background .25s, border-color .25s, box-shadow .25s;
    flex-shrink: 0;
}
.admin-toggle-thumb {
    position: absolute;
    top: 2px;
    left: 2px;
    width: 14px;
    height: 14px;
    border-radius: 50%;
    background: var(--text-dim);
    transition: transform .25s, background .25s, box-shadow .25s;
}
.admin-toggle input:checked + .admin-toggle-admin {
    background: rgba(99, 102, 241, 0.25);
    border-color: rgba(99, 102, 241, 0.5);
}
.admin-toggle input:checked + .admin-toggle-admin .admin-toggle-thumb {
    transform: translateX(18px);
    background: var(--accent);
    box-shadow: 0 0 8px rgba(99, 102, 241, 0.5);
}
.admin-toggle input:checked + .admin-toggle-pro {
    background: rgba(5, 150, 105, 0.25);
    border-color: rgba(16, 185, 129, 0.5);
}
.admin-toggle input:checked + .admin-toggle-pro .admin-toggle-thumb {
    transform: translateX(18px);
    background: #10b981;
    box-shadow: 0 0 8px rgba(16, 185, 129, 0.5);
}
.admin-toggle input:focus + .admin-toggle-track {
    box-shadow: 0 0 0 3px rgba(99, 102, 241, 0.2);
}
.admin-toggle-label {
    font-size: .8rem;
    font-weight: 600;
    color: var(--text-dim);
    transition: color .25s;
}
.admin-toggle input:checked ~ .admin-toggle-label {
    color: var(--text);
}

.settings-section-title {
    font-weight: 700;
    font-size: .95rem;
    letter-spacing: -.01em;
    margin-bottom: 1rem;
    color: var(--text);
}

.settings-status {
    font-size: .82rem;
    font-weight: 500;
    padding: .25rem .6rem;
    border-radius: var(--radius-xs);
    transition: opacity .3s;
}
.settings-status-ok {
    color: var(--green);
    background: rgba(34,197,94, 0.1);
}
.settings-status-error {
    color: var(--red);
    background: rgba(239,68,68, 0.1);
}

/* Resize handle styling */
.grid-stack-item > .ui-resizable-se {
    background: none;
    width: 20px;
    height: 20px;
    right: 4px;
    bottom: 4px;
    opacity: 0;
    transition: opacity .2s;
}
.gs-editing .grid-stack-item > .ui-resizable-se {
    opacity: 1;
}
.gs-editing .grid-stack-item > .ui-resizable-se::after {
    content: "⤡";
    position: absolute;
    right: 2px;
    bottom: 0;
    font-size: 14px;
    color: var(--accent);
}

/* Placeholder when dragging */
.grid-stack-placeholder > .placeholder-content {
    background: rgba(99,102,241, 0.15) !important;
    border: 2px dashed var(--accent) !important;
    border-radius: var(--radius);
}

/* Hidden widget */
.widget-hidden { display: none !important; }

/* Toolbar styling */
#layoutToolbar, #matchLayoutToolbar {
    padding: .5rem .75rem;
    background: var(--bg-panel);
    border: 1px solid var(--glass-border);
    border-radius: var(--radius-sm);
    backdrop-filter: blur(12px);
}

/* Widget panel toggle switches */
#widgetPanel .form-check-label,
#matchWidgetPanel .form-check-label {
    font-size: .8rem;
    color: var(--text-dim);
    cursor: pointer;
}
#widgetPanel .form-check-input:checked + .form-check-label,
#matchWidgetPanel .form-check-input:checked + .form-check-label {
    color: var(--text);
}

/* Ensure charts fill their grid cell — desktop only */
html:not(.mobile-view) .grid-stack-item-content .card-body canvas {
    width: 100% !important;
    height: 100% !important;
}

/* Override the gridstack default to work with our dark theme */
.grid-stack-item {
    transition: none;  /* gridstack handles its own animations */
}

/* Make sure card fills grid item */
.grid-stack-item-content > .card {
    height: 100%;
    display: flex;
    flex-direction: column;
}
.grid-stack-item-content > .card > .card-body {
    flex: 1 1 0;
    overflow: hidden;
    position: relative;
    min-height: 0;
}
html:not(.mobile-view) .grid-stack-item-content > .card > .card-body > canvas {
    position: absolute;
    inset: 0;
    width: 100% !important;
    height: 100% !important;
    padding: .5rem;
}
.bg-modal .modal-body canvas {
    max-width: 100%;
    max-height: 80vh;
}
#chartModalBody .board-wrap-full {
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: center;
    gap: 1.5rem;
}

/* Clickable chart cards */
.card.bg-panel.chart-clickable {
    cursor: pointer;
}
.card.bg-panel.chart-clickable:hover::after {
    content: '⤢';
    position: absolute;
    top: .6rem;
    right: .8rem;
    font-size: 1.1rem;
    color: var(--text-dim);
    opacity: .6;
    pointer-events: none;
    transition: opacity .2s;
}
.card.bg-panel.chart-clickable:hover::after { opacity: 1; }
.card.bg-panel.chart-clickable { position: relative; }


/* ══════════════════════════════════════════════════════════════
   Pro-Lock Overlay — Shown on free-tier locked widgets
   ══════════════════════════════════════════════════════════════ */
.widget-pro-locked .grid-stack-item-content {
    position: relative;
}
.pro-lock-overlay {
    position: absolute;
    inset: 0;
    z-index: 10;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(10, 10, 20, 0.82);
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
    border-radius: var(--radius);
    pointer-events: auto;
}
.pro-lock-inner {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: .35rem;
    text-align: center;
    padding: 1.5rem;
}
.pro-lock-icon {
    font-size: 2rem;
    filter: drop-shadow(0 0 8px rgba(251,191,36,.4));
}
.pro-lock-label {
    font-size: .9rem;
    font-weight: 700;
    color: #fbbf24;
    letter-spacing: .03em;
}
.pro-lock-hint {
    font-size: .75rem;
    color: var(--text-dim);
    max-width: 220px;
}
/* Keep the card header visible behind the overlay */
.widget-pro-locked .card-header {
    position: relative;
    z-index: 11;
    opacity: .55;
}
/* Prevent interaction with locked chart content */
.widget-pro-locked .card-body {
    pointer-events: none;
    filter: blur(3px);
    opacity: .15;
}


/* ══════════════════════════════════════════════════════════════
   Mobile View — Static Full-Glance Layout
   ══════════════════════════════════════════════════════════════ */

/* Mobile detection: body gets .mobile-view from JS */

/* ── Hide desktop-only controls ── */
.mobile-view #layoutToolbar,
.mobile-view #matchLayoutToolbar,
.mobile-view #widgetPanel,
.mobile-view #matchWidgetPanel,
.mobile-view .gs-editing {
    display: none !important;
}

/* ── GridStack: static full-width stacked layout ── */
.mobile-view .grid-stack {
    display: block !important;
    height: auto !important;
    min-height: 0 !important;
    position: static !important;
}

/* Override ALL gridstack width/position selectors – force every item full-width */
.mobile-view .grid-stack > .grid-stack-item,
.mobile-view .grid-stack-item,
.mobile-view .grid-stack-item[gs-w],
.mobile-view .grid-stack-item[gs-w="1"],
.mobile-view .grid-stack-item[gs-w="2"],
.mobile-view .grid-stack-item[gs-w="3"],
.mobile-view .grid-stack-item[gs-w="4"],
.mobile-view .grid-stack-item[gs-w="5"],
.mobile-view .grid-stack-item[gs-w="6"],
.mobile-view .grid-stack-item[gs-w="7"],
.mobile-view .grid-stack-item[gs-w="8"],
.mobile-view .grid-stack-item[gs-w="9"],
.mobile-view .grid-stack-item[gs-w="10"],
.mobile-view .grid-stack-item[gs-w="11"],
.mobile-view .grid-stack-item[gs-w="12"] {
    position: static !important;
    width: 100% !important;
    height: auto !important;
    min-height: 0 !important;
    max-height: none !important;
    margin: 0 !important;
    top: auto !important;
    left: auto !important;
    right: auto !important;
    transform: none !important;
    display: block !important;
    margin-bottom: .75rem !important;
}

/* Also override .gs-12 class selectors from gridstack CDN CSS */
.mobile-view .gs-12 > .grid-stack-item,
.mobile-view .gs-12 > .grid-stack-item[gs-w="6"],
.mobile-view .gs-12 > .grid-stack-item[gs-w] {
    width: 100% !important;
    left: auto !important;
    position: static !important;
}

.mobile-view .grid-stack-item-content,
.mobile-view .grid-stack > .grid-stack-item > .grid-stack-item-content {
    position: static !important;
    width: 100% !important;
    height: auto !important;
    min-height: 0 !important;
    max-height: none !important;
    inset: auto !important;
    overflow: visible !important;
}

.mobile-view .grid-stack-item-content > .card {
    height: auto !important;
    max-height: none !important;
    overflow: visible !important;
}

.mobile-view .grid-stack-item-content > .card > .card-body {
    overflow: visible !important;
    overflow-y: visible !important;
    position: relative !important;
    min-height: 0 !important;
    height: auto !important;
    max-height: none !important;
    flex: none !important;
}

/* ── Charts: remove desktop absolute positioning, let Chart.js handle sizing ── */
.mobile-view .grid-stack-item-content > .card > .card-body > canvas,
.mobile-view .grid-stack-item-content .card-body canvas {
    position: static !important;
    inset: auto !important;
}

/* ── KPI rows: compact 2-column grid ── */
.mobile-view .widget-inner {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: .4rem;
    height: auto !important;
    max-height: none !important;
    padding: .15rem;
    overflow: visible !important;
}
.mobile-view .widget-inner > div {
    min-width: 0;
}

/* ── KPI cards: tight and readable ── */
.mobile-view .kpi-card {
    padding: .45rem .6rem;
    min-height: 0;
    border-radius: var(--radius-sm);
}
.mobile-view .kpi-card:hover {
    transform: none;
}
.mobile-view .kpi-val {
    font-size: .88rem;
}
.mobile-view .kpi-title {
    font-size: .58rem;
    margin-bottom: .3rem;
}
.mobile-view .kpi-delta {
    font-size: .65rem;
    padding: .1rem .35rem;
}
.mobile-view .kpi-values {
    gap: .15rem .4rem;
}
.mobile-view .kpi-card::before {
    display: none;
}

/* ── Dartboards: scale down ── */
.mobile-view .board-wrap-full canvas {
    max-width: 280px;
}

/* ── Navbar: hamburger collapse on mobile ── */
.mobile-view .bg-brand {
    padding: .4rem .75rem !important;
}
.mobile-view .bg-brand .navbar-brand {
    font-size: .95rem;
}
.mobile-view .navbar-toggler {
    border-color: var(--glass-border);
    padding: .25rem .5rem;
}
.mobile-view .navbar-toggler:focus {
    box-shadow: 0 0 0 3px rgba(99,102,241, 0.2);
}
.mobile-view .nav-actions {
    flex-direction: column !important;
    align-items: stretch !important;
    gap: .5rem !important;
    padding: .75rem 0;
    width: 100%;
}
.mobile-view .nav-actions .dropdown {
    width: 100%;
}
.mobile-view .nav-actions .dropdown .btn {
    width: 100%;
    text-align: left;
}
.mobile-view .nav-actions > a.btn {
    text-align: left;
}
.mobile-view .nav-actions > span {
    padding: .2rem 0;
}

/* ── Period selector: compact ── */
.mobile-view .period-checklist {
    max-height: 200px;
}
.mobile-view #intervalTabs {
    display: flex;
    flex-wrap: wrap;
    gap: .25rem;
}
.mobile-view #intervalTabs .btn {
    font-size: .7rem;
    padding: .25rem .5rem;
}

/* ── Container: reduce padding ── */
.mobile-view .container-fluid {
    padding-left: .5rem !important;
    padding-right: .5rem !important;
}

/* ── Cards: smaller headers ── */
.mobile-view .card-header {
    font-size: .8rem;
    padding: .5rem .75rem;
}
.mobile-view .card:hover {
    transform: none;
}

/* ── Footer: compact ── */
.mobile-view footer {
    font-size: .72rem;
    padding: .75rem 0 !important;
}

/* ── Match history table ── */
.mobile-view #matchTable {
    font-size: .73rem;
}
.mobile-view #matchTable thead th {
    font-size: .65rem;
    padding: .3rem .4rem;
}

/* ── Leg Replay – highlight clickable rows ── */
.leg-replay-row {
    border-left: 3px solid var(--neon-cyan);
    background: rgba(34, 211, 238, 0.08);
    transition: background .15s;
}
.leg-replay-row:hover {
    background: rgba(34, 211, 238, 0.22);
}
.leg-replay-badge {
    display: inline-block;
    font-size: .65rem;
    font-weight: 700;
    letter-spacing: .03em;
    padding: 1px 6px;
    margin-left: 6px;
    border-radius: 4px;
    vertical-align: middle;
    background: rgba(34, 211, 238, 0.15);
    color: var(--neon-cyan);
    border: 1px solid rgba(34, 211, 238, 0.35);
    transition: background .15s, border-color .15s;
}
.leg-replay-row:hover .leg-replay-badge {
    background: rgba(34, 211, 238, 0.30);
    border-color: var(--neon-cyan);
}

.replay-speed-btn {
    min-width: 52px;
    font-weight: 600;
    font-size: .75rem;
    letter-spacing: .02em;
}

/* ══════════════════════════════════════════════════════════════
   Light Theme
   ══════════════════════════════════════════════════════════════ */

[data-theme="light"] {
    --bg:         #f0f2f5;
    --bg-panel:   rgba(255, 255, 255, 0.92);
    --glass:      rgba(0, 0, 0, 0.03);
    --glass-border: rgba(0, 0, 0, 0.10);
    --accent:     #4f46e5;
    --accent-2:   #7c3aed;
    --accent-3:   #6d28d9;
    --neon-blue:  #2563eb;
    --neon-cyan:  #0891b2;
    --neon-pink:  #db2777;
    --text:       #111827;
    --text-dim:   #6b7280;
    --green:      #16a34a;
    --red:        #dc2626;
    --gold:       #d97706;
    --blue:       #2563eb;
    --shadow-glow: 0 0 40px rgba(79,70,229, 0.06), 0 8px 32px rgba(0,0,0,0.06);
    --shadow-card: 0 1px 3px rgba(0,0,0, 0.06), 0 4px 16px rgba(0,0,0, 0.04);
}

[data-theme="light"] body {
    background: var(--bg);
    background-image:
        radial-gradient(ellipse 80% 60% at 20% 10%, rgba(79,70,229,0.04) 0%, transparent 60%),
        radial-gradient(ellipse 60% 50% at 80% 80%, rgba(37,99,235,0.03) 0%, transparent 60%);
    color: var(--text);
}

[data-theme="light"] .bg-panel,
[data-theme="light"] .card.bg-panel {
    background: var(--bg-panel) !important;
    border-color: var(--glass-border) !important;
    backdrop-filter: blur(12px);
    box-shadow: var(--shadow-card);
}

/* ── Navbar ── */
[data-theme="light"] .bg-brand {
    background: linear-gradient(135deg, #f8fafc 0%, #eef2ff 50%, #f8fafc 100%) !important;
    border-bottom: 1px solid rgba(0,0,0,0.08);
    box-shadow: 0 1px 8px rgba(0,0,0,0.06);
}
[data-theme="light"] .bg-brand .navbar-brand {
    background: linear-gradient(135deg, #4f46e5 0%, #7c3aed 50%, #2563eb 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}
[data-theme="light"] .navbar-dark .navbar-toggler-icon {
    filter: invert(1) brightness(0.3);
}

/* ── Cards & Panels ── */
[data-theme="light"] .card {
    border-color: rgba(0,0,0,0.08);
}
[data-theme="light"] .card:hover {
    border-color: rgba(79,70,229, 0.2);
    box-shadow: var(--shadow-glow);
}
[data-theme="light"] .card-header {
    background: rgba(0,0,0, 0.02) !important;
    border-bottom-color: rgba(0,0,0,0.06) !important;
    color: var(--text);
}
[data-theme="light"] .collapsible-header:hover {
    background: rgba(0,0,0, 0.03) !important;
}

/* ── KPI Cards ── */
[data-theme="light"] .kpi-card {
    background: #fff;
    border-color: rgba(0,0,0, 0.08);
    color: var(--text);
    box-shadow: 0 1px 3px rgba(0,0,0,0.04);
}
[data-theme="light"] .kpi-card:hover {
    border-color: rgba(79,70,229, 0.2);
}
[data-theme="light"] .kpi-value,
[data-theme="light"] .kpi-val {
    color: var(--text);
}
[data-theme="light"] .kpi-label,
[data-theme="light"] .kpi-title {
    color: var(--text-dim);
}
[data-theme="light"] .kpi-collapse-bar {
    background: #fff;
    border-color: rgba(0,0,0,0.08);
    color: var(--text);
}
[data-theme="light"] .kpi-collapse-bar:hover {
    background: rgba(0,0,0,0.02);
    border-color: rgba(79,70,229,0.2);
}

/* ── Tables (override .table-dark) ── */
[data-theme="light"] .table-dark {
    --bs-table-bg: #fff;
    --bs-table-color: #111827;
    --bs-table-border-color: rgba(0,0,0,0.06);
    --bs-table-hover-bg: rgba(79,70,229,0.04);
    --bs-table-striped-bg: rgba(0,0,0,0.015);
}
[data-theme="light"] .table-dark thead th {
    color: #374151;
    background: rgba(0,0,0,0.02);
}
[data-theme="light"] #matchStatsTable thead th {
    background: rgba(79,70,229,0.05);
    border-bottom-color: rgba(0,0,0,0.06);
    color: #374151;
}
[data-theme="light"] #matchStatsTable tbody tr:nth-child(odd) {
    background: rgba(0,0,0,0.015);
}
[data-theme="light"] #matchStatsTable tbody tr:hover {
    background: rgba(79,70,229,0.05);
}
[data-theme="light"] #matchStatsTable tbody td {
    border-bottom-color: rgba(0,0,0,0.04);
}
[data-theme="light"] #matchTable {
    color: var(--text);
}
[data-theme="light"] #matchTable thead th {
    color: #374151;
    border-bottom-color: rgba(0,0,0,0.08);
}
[data-theme="light"] #matchTable tbody tr {
    border-bottom-color: rgba(0,0,0,0.04);
}
[data-theme="light"] #matchTable tbody tr:hover {
    background: rgba(79,70,229,0.04);
}

/* ── Buttons ── */
[data-theme="light"] .btn-outline-light {
    color: #374151;
    border-color: #d1d5db;
}
[data-theme="light"] .btn-outline-light:hover,
[data-theme="light"] .btn-outline-light.active {
    background: var(--accent);
    color: #fff;
    border-color: var(--accent);
}
[data-theme="light"] .btn-accent {
    box-shadow: 0 2px 8px rgba(245,158,11, 0.2);
}

/* ── Nav Pills ── */
[data-theme="light"] .nav-pills .nav-link {
    background: #fff;
    border-color: rgba(0,0,0,0.08);
    color: #6b7280;
}
[data-theme="light"] .nav-pills .nav-link:hover {
    color: var(--text);
    background: rgba(79,70,229, 0.06);
    border-color: rgba(79,70,229, 0.2);
}
[data-theme="light"] .nav-pills .nav-link.active {
    background: linear-gradient(135deg, #4f46e5, #7c3aed);
    border-color: transparent;
    color: #fff;
    box-shadow: 0 2px 8px rgba(79,70,229,0.25);
}

/* ── Modals ── */
[data-theme="light"] .bg-modal,
[data-theme="light"] .modal-content.bg-panel {
    background: rgba(255,255,255,0.97) !important;
    color: var(--text);
    border-color: rgba(0,0,0,0.1) !important;
    box-shadow: 0 16px 64px rgba(0,0,0,0.12);
}
[data-theme="light"] .modal-content.bg-dark {
    background: #fff !important;
    color: var(--text) !important;
    border-color: rgba(0,0,0,0.1) !important;
}
[data-theme="light"] .modal-content.bg-dark .text-light {
    color: var(--text) !important;
}
[data-theme="light"] .modal-content.bg-dark .text-muted {
    color: var(--text-dim) !important;
}
[data-theme="light"] .modal-content.bg-dark .border-secondary {
    border-color: rgba(0,0,0,0.1) !important;
}
[data-theme="light"] .modal-content.bg-dark .modal-header {
    border-bottom-color: rgba(0,0,0,0.06) !important;
}

/* ── Forms & Inputs ── */
[data-theme="light"] .form-control,
[data-theme="light"] .form-select {
    background: #fff;
    border-color: #d1d5db;
    color: #111827;
}
[data-theme="light"] .form-control:focus,
[data-theme="light"] .form-select:focus {
    background: #fff;
    border-color: var(--accent);
    box-shadow: 0 0 0 3px rgba(79,70,229,0.12);
    color: #111827;
}
[data-theme="light"] .form-control::placeholder {
    color: #9ca3af;
}
[data-theme="light"] #matchSearch,
[data-theme="light"] #matchResult {
    background: #fff;
    color: var(--text);
    border-color: #d1d5db;
}
[data-theme="light"] #matchSearch:focus,
[data-theme="light"] #matchResult:focus {
    border-color: var(--accent);
    box-shadow: 0 0 0 3px rgba(79,70,229,0.12);
}
[data-theme="light"] #matchSearch::placeholder {
    color: #9ca3af;
}

/* ── Period Selector ── */
[data-theme="light"] #periodSearch {
    background: #fff;
    color: var(--text);
    border-color: #d1d5db;
}
[data-theme="light"] #periodSearch:focus {
    border-color: var(--accent);
    box-shadow: 0 0 0 3px rgba(79,70,229,0.12);
}
[data-theme="light"] #periodSearch::placeholder {
    color: #9ca3af;
}
[data-theme="light"] .period-checklist {
    background: #fff;
    border-color: #e5e7eb;
}
[data-theme="light"] .period-checklist .form-check:hover {
    background: rgba(79,70,229,0.04);
}
[data-theme="light"] .period-checklist .form-check-input {
    background-color: #fff;
    border-color: #d1d5db;
}
[data-theme="light"] .period-checklist .form-check-input:checked {
    background-color: var(--accent);
    border-color: var(--accent);
}
[data-theme="light"] .period-checklist label {
    color: var(--text);
    border-color: rgba(0,0,0,0.04);
}
[data-theme="light"] .period-checklist label:hover {
    background: rgba(79,70,229,0.04);
}

/* ── Dropdowns ── */
[data-theme="light"] .dropdown-menu-dark {
    --bs-dropdown-bg: #fff;
    --bs-dropdown-color: #111827;
    --bs-dropdown-link-color: #111827;
    --bs-dropdown-link-hover-bg: rgba(79,70,229,0.06);
    --bs-dropdown-border-color: rgba(0,0,0,0.08);
    box-shadow: 0 4px 16px rgba(0,0,0,0.1);
}

/* ── Spinner ── */
[data-theme="light"] .spinner-border {
    border-color: var(--accent);
    border-right-color: transparent;
}
[data-theme="light"] .spinner-border.text-light {
    border-color: var(--accent) !important;
    border-right-color: transparent !important;
}

/* ── Text utilities ── */
[data-theme="light"] .text-muted {
    color: #6b7280 !important;
}
[data-theme="light"] .text-light {
    color: var(--text) !important;
}
[data-theme="light"] code {
    color: #7c3aed;
}

/* ── Footer ── */
[data-theme="light"] footer {
    border-top-color: rgba(0,0,0,0.06);
}
[data-theme="light"] footer a {
    color: var(--accent) !important;
}
[data-theme="light"] footer a:hover {
    color: var(--accent-2) !important;
}

/* ── Toolbar & Layout ── */
[data-theme="light"] #layoutToolbar,
[data-theme="light"] #matchLayoutToolbar {
    background: #fff;
    border-color: rgba(0,0,0,0.08);
}

/* ── GridStack Editing ── */
[data-theme="light"] .gs-editing .grid-stack-item-content {
    outline-color: rgba(79,70,229,0.3);
}

/* ── Progress Bars ── */
[data-theme="light"] .progress {
    background: rgba(0,0,0,0.06) !important;
}

/* ── Admin elements ── */
[data-theme="light"] .admin-modal-content {
    background: #fff !important;
    border-color: rgba(0,0,0,0.1) !important;
    box-shadow: 0 16px 64px rgba(0,0,0,0.12);
}
[data-theme="light"] .admin-input {
    background: #fff !important;
    border-color: #d1d5db !important;
    color: var(--text) !important;
}
[data-theme="light"] .admin-input:focus {
    background: #fff !important;
    border-color: var(--accent) !important;
}
[data-theme="light"] .admin-input::placeholder {
    color: #9ca3af !important;
}
[data-theme="light"] select.admin-input option {
    background: #fff;
    color: var(--text);
}
[data-theme="light"] .admin-select {
    background-color: #fff;
    border-color: #d1d5db;
    color: var(--text);
}
[data-theme="light"] .admin-select:focus {
    background-color: #fff;
    border-color: var(--accent);
}
[data-theme="light"] .admin-select option {
    background: #fff;
    color: var(--text);
}
[data-theme="light"] .admin-toggle-track {
    background: rgba(0,0,0,0.08);
    border-color: rgba(0,0,0,0.12);
}
[data-theme="light"] .admin-toggle-thumb {
    background: #9ca3af;
}
[data-theme="light"] .admin-action-btn {
    border-color: rgba(0,0,0,0.08);
    background: rgba(0,0,0,0.02);
    color: var(--text);
}
[data-theme="light"] .admin-user-card {
    background: rgba(0,0,0,0.015);
    border-color: rgba(0,0,0,0.06);
}
[data-theme="light"] .admin-user-card:hover {
    background: rgba(79,70,229,0.03);
    border-color: rgba(79,70,229,0.12);
}
[data-theme="light"] .admin-table thead th {
    color: #374151;
    border-bottom-color: rgba(0,0,0,0.08);
}
[data-theme="light"] .admin-table tbody tr {
    border-bottom-color: rgba(0,0,0,0.04);
}
[data-theme="light"] .admin-table tbody tr:hover {
    background: rgba(79,70,229,0.04);
}

/* ── Form switches ── */
[data-theme="light"] .form-check-input {
    background-color: #e5e7eb;
    border-color: #d1d5db;
}
[data-theme="light"] .form-check-input:checked {
    background-color: var(--accent);
    border-color: var(--accent);
}

/* ── Preset modal ── */
[data-theme="light"] #presetSaveModal .form-control {
    background: #fff;
    color: var(--text);
    border-color: #d1d5db;
}
[data-theme="light"] #presetSaveModal .form-control:focus {
    border-color: var(--accent);
}

/* ── Board labels & chart labels ── */
[data-theme="light"] .board-label {
    color: var(--text-dim);
}
[data-theme="light"] .board-label strong {
    color: var(--text);
}

/* ── Scrollbar ── */
[data-theme="light"] .period-checklist {
    scrollbar-color: #c7c7c7 transparent;
}
[data-theme="light"] .period-checklist::-webkit-scrollbar-thumb {
    background: #c7c7c7;
}

/* ── Import info ── */
[data-theme="light"] #importInfo {
    color: var(--text-dim);
}

/* ── Pro lock ── */
[data-theme="light"] .pro-lock-overlay {
    background: rgba(255,255,255,0.85);
}
[data-theme="light"] .widget-pro-locked .card-body {
    filter: blur(3px);
    opacity: .25;
}

/* ── Leg Replay rows ── */
[data-theme="light"] .leg-replay-row {
    border-left-color: var(--accent);
    background: rgba(79,70,229, 0.05);
}
[data-theme="light"] .leg-replay-row:hover {
    background: rgba(79,70,229, 0.10);
}
[data-theme="light"] .leg-replay-badge {
    background: rgba(79,70,229, 0.08);
    color: var(--accent);
    border-color: rgba(79,70,229, 0.25);
}
[data-theme="light"] .leg-replay-row:hover .leg-replay-badge {
    background: rgba(79,70,229, 0.16);
    border-color: var(--accent);
}

/* ── Hidden widgets ── */
.mobile-view .widget-hidden {
    display: none !important;
}

/* ── Advanced stats KPI: 2-column grid ── */
.mobile-view #advKpiRow1 .col-md-3,
.mobile-view #advKpiRow1 .col-sm-4,
.mobile-view #advKpiRow1 .col-6 {
    flex: 0 0 50%;
    max-width: 50%;
}

/* ── Override inline overflow on card bodies ── */
.mobile-view .card-body[style*="overflow"] {
    overflow: visible !important;
    max-height: none !important;
}

/* ── Grid-stack item inner rows ── */
.mobile-view .grid-stack-item .row {
    margin: 0;
}

/* ── Scrollable containers: show all ── */
.mobile-view .card-body .table-responsive {
    overflow-x: auto !important;
    overflow-y: visible !important;
    max-height: none !important;
}
.mobile-view .card-body .p-0[style*="max-height"] {
    max-height: none !important;
    overflow: visible !important;
}

/* ── Board rows: wrap tightly ── */
.mobile-view #bestLegBoards,
.mobile-view #heatmapBoards,
.mobile-view #matchBoards {
    flex-wrap: wrap;
    gap: .5rem;
    justify-content: center;
}

/* ── Tabs: horizontal scroll ── */
.mobile-view .nav-pills {
    flex-wrap: nowrap;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    gap: .3rem;
}
.mobile-view .nav-pills .nav-link {
    font-size: .78rem;
    padding: .45rem .85rem;
    white-space: nowrap;
}

/* ── Buttons: touch-friendly ── */
.mobile-view .btn-sm {
    padding: .35rem .6rem;
    font-size: .75rem;
    min-height: 36px;
}
.mobile-view .btn-accent.btn-lg {
    padding: .55rem 1rem;
    font-size: .82rem;
    min-height: 44px;
}

/* ── Match comparison: static layout ── */
.mobile-view #matchCompare .grid-stack-item-content > .card > .card-body {
    max-height: none;
    overflow-y: visible;
}

/* ── Modals ── */
.mobile-view .modal-dialog {
    margin: .5rem;
}
.mobile-view .modal-fullscreen-lg-down {
    max-width: 100%;
    height: auto;
}

/* ── Period selector card on mobile ── */
.mobile-view .col-md-10 {
    margin-bottom: .5rem;
}
.mobile-view .col-md-2 .btn-accent {
    width: 100%;
}
