:root {
    --mm-primary: #123C73;
    --mm-primary-light: #1C5AA6;
    --mm-secondary: #E53935;
    --mm-secondary-hover: #CF302D;
    --mm-accent: #F4B400;
    --mm-success: #2EAD67;
    --mm-warning: #F28C28;
    --mm-error: #C62828;
    --mm-info: #2F80ED;
    --mm-bg: #F4F7FA;
    --mm-surface: #ffffff;
    --mm-surface-alt: #EAF0F6;
    --mm-text: #1F2A37;
    --mm-text-muted: #5B6B7A;
    --mm-border: #D8E0E8;
    --mm-border-strong: #B8C4D1;
    --mm-table-header: var(--mm-primary);
    --mm-table-header-text: #ffffff;
    --mm-table-hover: rgba(18, 60, 115, 0.06);
    --mm-card-shadow: 0 2px 8px rgba(18, 60, 115, 0.08);
    --mm-card-shadow-hover: 0 6px 18px rgba(18, 60, 115, 0.14);
    --mm-footer-bg: #ffffff;
    --mm-footer-height: 30px;
    --mm-navbar-bg: linear-gradient(135deg, #123C73 0%, #1C5AA6 100%);
    --mm-input-focus-border: #2F80ED;
    --mm-input-focus-shadow: rgba(47, 128, 237, 0.22);
    --mm-dropdown-bg: #ffffff;
    --mm-dropdown-border: rgba(0,0,0,.175);
}

/* Dark theme via media query */
@media (prefers-color-scheme: dark) {
    :root:not([data-theme="light"]) {
        --mm-bg: #121212;
        --mm-surface: #1e1e1e;
        --mm-text: #e0e0e0;
        --mm-text-muted: #9e9e9e;
        --mm-border: #333333;
        --mm-table-hover: rgba(255,255,255,0.05);
        --mm-card-shadow: 0 2px 8px rgba(0,0,0,0.4);
        --mm-card-shadow-hover: 0 4px 16px rgba(0,0,0,0.6);
        --mm-footer-bg: #1e1e1e;
        --mm-input-focus-shadow: rgba(57, 73, 171, 0.3);
        --mm-dropdown-bg: #2a2a2a;
        --mm-dropdown-border: rgba(255,255,255,0.1);
        --bs-link-color: #e0e0e0;
        --bs-link-hover-color: #9e9e9e;
    }
}

/* Manual dark override */
[data-theme="dark"] {
    --mm-bg: #121212;
    --mm-surface: #1e1e1e;
    --mm-text: #e0e0e0;
    --mm-text-muted: #9e9e9e;
    --mm-border: #333333;
    --mm-table-hover: rgba(255,255,255,0.05);
    --mm-card-shadow: 0 2px 8px rgba(0,0,0,0.4);
    --mm-card-shadow-hover: 0 4px 16px rgba(0,0,0,0.6);
    --mm-footer-bg: #1e1e1e;
    --mm-input-focus-shadow: rgba(57, 73, 171, 0.3);
    --mm-dropdown-bg: #2a2a2a;
        padding: 0.55rem 0.7rem 2.2rem;
}

        --mm-range-min-percent: 0%;
        --mm-range-max-percent: 100%;
html {
    font-size: 14px;
}

@media (min-width: 768px) {
    html {
        top: 1.95rem;
    }
        background: transparent;
}

html, body {
    height: 100%;
    margin: 0;
}

html {
    position: relative;
}

body {
    display: flex;
    flex-direction: column;
    background-color: var(--mm-bg);
    color: var(--mm-text);
    font-family: 'Inter', 'Segoe UI', system-ui, -apple-system, sans-serif;
    transition: background-color 0.2s, color 0.2s;
}

h1, h2, h3, h4, h5, h6,
.page-header h1, .page-header h2, .page-header h3 {
    font-family: 'Barlow Condensed', 'Roboto Condensed', 'Inter', 'Segoe UI', sans-serif;
    letter-spacing: 0.02em;
}

.app-shell {
    display: flex;
    flex-direction: column;
    flex: 1 0 auto;
    padding-bottom: calc(var(--mm-footer-height) + 0.75rem);
}

main[role="main"] {
    flex: 1 0 auto;
}

.bg-dark-blue {
    background: linear-gradient(135deg, var(--mm-primary) 0%, var(--mm-primary-light) 100%);
}

.navbar-brand {
    font-size: 1.3rem;
}

.brand-logo-wrap {
    background: rgba(255, 255, 255, 0.96);
    border-radius: 8px;
    padding: 2px 4px;
    box-shadow: 0 1px 4px rgba(0,0,0,0.25);
}

.brand-logo {
    display: block;
    filter: drop-shadow(0 1px 2px rgba(0,0,0,0.35));
}

.brand-logo-dark {
    display: none;
}

[data-theme="dark"] .brand-logo-light {
    display: none;
}

[data-theme="dark"] .brand-logo-dark {
    display: block;
}

@media (prefers-color-scheme: dark) {
    :root:not([data-theme="light"]) .brand-logo-light {
        display: none;
    }

    :root:not([data-theme="light"]) .brand-logo-dark {
        display: block;
    }
}

/* Cards */
.card {
    border: 1px solid var(--mm-border);
    border-radius: 12px;
    box-shadow: var(--mm-card-shadow);
    transition: transform 0.15s, box-shadow 0.15s;
    background-color: var(--mm-surface);
    color: var(--mm-text);
}

.card:hover {
    transform: translateY(-2px);
    box-shadow: var(--mm-card-shadow-hover);
}

.card-header,
.card-header.bg-white {
    background: var(--mm-surface-alt) !important;
    border-bottom: 1px solid var(--mm-border);
    color: var(--mm-primary);
}

.card-header h5,
.card-header h6 {
    font-weight: 700;
    letter-spacing: 0.01em;
}

.card-stat {
    border-left: 4px solid;
}

.card-stat.teams { border-left-color: var(--mm-primary); }
.card-stat.wrestlers { border-left-color: var(--mm-secondary); }
.card-stat.events { border-left-color: var(--mm-success); }
.card-stat.matches { border-left-color: var(--mm-error); }

.card-stat.teams .stat-icon { color: var(--mm-primary-light); }
.card-stat.wrestlers .stat-icon { color: var(--mm-secondary); }
.card-stat.events .stat-icon { color: var(--mm-success); }
.card-stat.matches .stat-icon { color: var(--mm-error); }
.card-stat.users .stat-icon { color: var(--mm-info); }

.stat-icon {
    font-size: 2.5rem;
    opacity: 0.85;
    filter: drop-shadow(0 2px 4px rgba(0,0,0,0.25)) saturate(1.2);
}

.stat-number {
    font-size: 2rem;
    font-weight: 700;
    line-height: 1;
}

/* Buttons */
.btn-primary {
    background: var(--mm-secondary);
    border-color: var(--mm-secondary);
    color: #fff;
}

.btn-primary:hover {
    background: var(--mm-secondary-hover);
    border-color: var(--mm-secondary-hover);
    color: #fff;
}

.btn-accent {
    background: var(--mm-accent);
    border-color: var(--mm-accent);
    color: #1F2A37;
}

.btn-accent:hover {
    background: #d79f00;
    border-color: #d79f00;
    color: #1F2A37;
}

.btn-outline-secondary {
    border-color: var(--mm-primary);
    color: var(--mm-primary);
}

.btn-outline-secondary:hover {
    background: #EEF4FB;
    border-color: var(--mm-primary);
    color: var(--mm-primary);
}

/* Tables */
.table-modern {
    border-radius: 12px;
    overflow: hidden;
}

.table-modern thead th {
    background: var(--mm-primary);
    color: #fff;
    border: none;
    font-weight: 600;
    font-size: 0.85rem;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.table-modern tbody tr:hover {
    background-color: var(--mm-table-hover);
}

.table-modern tbody td {
    border-bottom: 1px solid var(--mm-border);
}

.card .table:not(.table-modern) thead th {
    background: var(--mm-surface-alt);
    color: var(--mm-primary);
    border-bottom: 1px solid var(--mm-border);
}

/* Status badges */
.badge-upcoming { background-color: var(--mm-info); }
.badge-inprogress { background-color: var(--mm-warning); }
.badge-completed { background-color: var(--mm-success); }
.badge-cancelled { background-color: var(--mm-text-muted); }

.badge-skill-beginner { background-color: #66bb6a; }
.badge-skill-novice { background-color: #42a5f5; }
.badge-skill-intermediate {
    background-color: #ffa726;
    color: black !important;
}
.badge-skill-advanced { background-color: #ef5350; }
.badge-skill-expert { background-color: #ab47bc; }

.badge-school {
    background-color: #eef2ff;
    color: #1a237e;
    border: 1px solid #c5cae9;
}

.weight-class-pill-0 { background-color: #0b7285; color: #fff; }
.weight-class-pill-1 { background-color: #c44536; color: #fff; }
.weight-class-pill-2 { background-color: #5f3dc4; color: #fff; }
.weight-class-pill-3 { background-color: #2b8a3e; color: #fff; }
.weight-class-pill-4 { background-color: #e67700; color: #fff; }
.weight-class-pill-5 { background-color: #a61e4d; color: #fff; }
.weight-class-pill-6 { background-color: #1d4ed8; color: #fff; }
.weight-class-pill-7 { background-color: #7c2d12; color: #fff; }

.html-editor {
    border: 1px solid var(--mm-border);
    border-radius: 10px;
    background: #fff;
    overflow: hidden;
}

.html-editor-toolbar {
    padding: 0.75rem;
    border-bottom: 1px solid var(--mm-border);
    background: var(--mm-surface-alt);
}

.html-editor-surface,
.html-editor-source {
    min-height: 18rem;
    border: 0;
    border-radius: 0;
    box-shadow: none !important;
}

.html-editor-surface {
    padding: 1rem;
    overflow: auto;
}

.html-editor-surface:focus {
    outline: none;
}

/* Social login buttons */
.btn-google { background: #db4437; border-color: #db4437; color: white; }
.btn-google:hover { background: #c33d2e; color: white; }
.btn-microsoft { background: #00a4ef; border-color: #00a4ef; color: white; }
.btn-microsoft:hover { background: #0090d0; color: white; }
.btn-facebook { background: #4267B2; border-color: #4267B2; color: white; }
.btn-facebook:hover { background: #375694; color: white; }
.btn-yahoo { background: #720e9e; border-color: #720e9e; color: white; }
.btn-yahoo:hover { background: #5a0b7d; color: white; }

/* Form styling */
.form-control:focus, .form-select:focus {
    border-color: var(--mm-input-focus-border);
    box-shadow: 0 0 0 0.2rem var(--mm-input-focus-shadow);
}

.form-control,
.form-select,
.input-group-text {
    border-radius: 10px;
    border-color: var(--mm-border);
    color: var(--mm-text);
}

.form-control::placeholder {
    color: #7a8998;
}

.form-label {
    color: var(--mm-primary);
    font-weight: 600;
}

.form-floating > .form-control-plaintext::placeholder,
.form-floating > .form-control::placeholder {
    color: var(--bs-secondary-color);
    text-align: end;
}

.form-floating > .form-control-plaintext:focus::placeholder,
.form-floating > .form-control:focus::placeholder {
    text-align: start;
}

/* Page headers */
.page-header {
    margin-bottom: 1.5rem;
    padding-bottom: 0.75rem;
    border-bottom: 2px solid var(--mm-border-strong);
}

/* Responsive table wrapper */
.table-responsive {
    border-radius: 12px;
}

/* Animation */
@keyframes fadeInUp {
    from { opacity: 0; transform: translateY(20px); }
    to { opacity: 1; transform: translateY(0); }
}

.fade-in {
    animation: fadeInUp 0.4s ease-out;
}

/* Footer */
.footer {
    background: var(--mm-footer-bg);
    border-color: var(--mm-border) !important;
    color: var(--mm-text-muted);
    position: fixed;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 1030;
    font-size: 0.85rem;
    min-height: var(--mm-footer-height);
    box-shadow: 0 -2px 8px rgba(18, 60, 115, 0.08);
}

.alert {
    border: 1px solid var(--mm-border);
    border-left-width: 4px;
    border-radius: 10px;
}

.alert-info {
    background-color: #e9f2ff;
    border-color: #b8d7ff;
    border-left-color: var(--mm-info);
    color: #174a86;
}

.alert-success {
    background-color: #e9f8f0;
    border-color: #b6e8cc;
    border-left-color: var(--mm-success);
    color: #1f7a49;
}

.alert-warning {
    background-color: #fff4e7;
    border-color: #ffd8ac;
    border-left-color: var(--mm-warning);
    color: #8a4f12;
}

.alert-danger {
    background-color: #fdecec;
    border-color: #f6c1bf;
    border-left-color: var(--mm-error);
    color: #8b1f1c;
}

.alert-light {
    background-color: #f8fafc;
    border-color: var(--mm-border);
    border-left-color: var(--mm-primary);
    color: var(--mm-text);
}

.badge.bg-light.text-dark,
.badge.bg-light.text-dark.border {
    background-color: var(--mm-surface-alt) !important;
    color: var(--mm-primary) !important;
    border-color: var(--mm-border-strong) !important;
}

/* Better card icon contrast */
.card .bi.fs-1,
.card .bi.fs-2,
.card .bi.fs-3 {
    opacity: 0.95;
    filter: drop-shadow(0 1px 2px rgba(0,0,0,0.2)) saturate(1.15);
}

/* Action button groups should not look cramped */
.action-toolbar {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    align-items: center;
    position: relative;
    z-index: 2;
    padding-top: .5rem;
}

.card-footer {
    padding-top: 0.6rem;
    padding-bottom: 0.6rem;
}

/* Compact list and table spacing */
.list-group-item {
    padding: 0.55rem 0.8rem;
}

.table > :not(caption) > * > * {
    padding: 0.45rem 0.55rem;
    vertical-align: middle;
}

/* Mobile specific */
@media (max-width: 576px) {
    .stat-number { font-size: 1.5rem; }
    .stat-icon { font-size: 2rem; }
    .page-header h2 { font-size: 1.3rem; }
}

/* ===== DARK MODE BOOTSTRAP OVERRIDES ===== */
/* Applied both via [data-theme="dark"] and @media prefers-color-scheme: dark */

/* Mixin-style: apply to both selectors */
:is([data-theme="dark"], :is(@media (prefers-color-scheme: dark)) :root:not([data-theme="light"])) { color-scheme: dark; }

/* ------ Dropdowns ------ */
[data-theme="dark"] .dropdown-menu,
@media (prefers-color-scheme: dark) { :root:not([data-theme="light"]) .dropdown-menu { background-color: var(--mm-dropdown-bg); border-color: var(--mm-dropdown-border); } }
[data-theme="dark"] .dropdown-menu { background-color: var(--mm-dropdown-bg); border-color: var(--mm-dropdown-border); }
[data-theme="dark"] .dropdown-item { color: var(--mm-text); }
[data-theme="dark"] .dropdown-item:hover,
[data-theme="dark"] .dropdown-item:focus { background-color: rgba(255,255,255,0.09); color: var(--mm-text); }
[data-theme="dark"] .dropdown-divider { border-color: var(--mm-border); }

/* ------ Tables ------ */
[data-theme="dark"] .table,
[data-theme="dark"] table {
    --bs-table-color: var(--mm-text);
    --bs-table-bg: var(--mm-surface);
    --bs-table-border-color: var(--mm-border);
    --bs-table-striped-bg: rgba(255,255,255,0.04);
    --bs-table-striped-color: var(--mm-text);
    --bs-table-hover-bg: rgba(255,255,255,0.06);
    --bs-table-hover-color: var(--mm-text);
    color: var(--mm-text);
    border-color: var(--mm-border);
}
[data-theme="dark"] .table-success {
    --bs-table-bg: rgba(46, 125, 50, 0.25);
    --bs-table-color: #a5d6a7;
    background-color: rgba(46, 125, 50, 0.25) !important;
    color: #a5d6a7;
}
[data-theme="dark"] .table > :not(caption) > * > * {
    color: var(--mm-text);
    border-color: var(--mm-border);
}

/* ------ Cards & list-group ------ */
[data-theme="dark"] .card { background-color: var(--mm-surface); color: var(--mm-text); border-color: var(--mm-border); }
[data-theme="dark"] .card-header,
[data-theme="dark"] .card-header.bg-white { background-color: #223244 !important; color: #e3eefc; border-color: #32465e; }
[data-theme="dark"] .card-footer { background-color: #252525; border-color: var(--mm-border); }
[data-theme="dark"] .card-body { background-color: var(--mm-surface); color: var(--mm-text); }
[data-theme="dark"] .list-group-item {
    background-color: var(--mm-surface);
    color: var(--mm-text);
    border-color: var(--mm-border);
}
[data-theme="dark"] .list-group-item-action:hover,
[data-theme="dark"] .list-group-item-action:focus { background-color: rgba(255,255,255,0.07); color: var(--mm-text); }
[data-theme="dark"] .list-group-flush > .list-group-item { border-color: var(--mm-border); }

/* ------ Forms ------ */
[data-theme="dark"] .form-control,
[data-theme="dark"] .form-select {
    background-color: #2a2a2a;
    border-color: var(--mm-border);
    color: var(--mm-text);
}
[data-theme="dark"] .form-control:focus,
[data-theme="dark"] .form-select:focus {
    background-color: #2a2a2a;
    border-color: var(--mm-info);
    color: var(--mm-text);
    box-shadow: 0 0 0 0.2rem rgba(47, 128, 237, 0.35);
}
[data-theme="dark"] .form-control:disabled,
[data-theme="dark"] .form-select:disabled { background-color: #1e1e1e; color: var(--mm-text-muted); }
[data-theme="dark"] .form-label { color: var(--mm-text); }
[data-theme="dark"] .form-text { color: var(--mm-text-muted); }
[data-theme="dark"] .form-check-label { color: var(--mm-text); }
[data-theme="dark"] .form-check-input { background-color: #2a2a2a; border-color: #555; }
[data-theme="dark"] .form-check-input:checked { background-color: #5c6bc0; border-color: #5c6bc0; }
[data-theme="dark"] .input-group-text {
    background-color: #333;
    border-color: var(--mm-border);
    color: var(--mm-text);
}

/* ------ Modals ------ */
[data-theme="dark"] .modal-content {
    background-color: var(--mm-surface);
    color: var(--mm-text);
    border-color: var(--mm-border);
}
[data-theme="dark"] .modal-header,
[data-theme="dark"] .modal-footer { border-color: var(--mm-border); }
[data-theme="dark"] .modal-backdrop { background-color: rgba(0,0,0,0.7); }

/* ------ Alerts ------ */
[data-theme="dark"] .alert-info { background-color: #0f2942; border-color: #2f80ed; border-left-color: #2f80ed; color: #b9dbff; }
[data-theme="dark"] .alert-success { background-color: #123325; border-color: #2ead67; border-left-color: #2ead67; color: #a8e8c8; }
[data-theme="dark"] .alert-warning { background-color: #3c2b12; border-color: #f28c28; border-left-color: #f28c28; color: #ffd9ae; }
[data-theme="dark"] .alert-danger { background-color: #40191a; border-color: #c62828; border-left-color: #c62828; color: #f4b9b7; }
[data-theme="dark"] .alert-light { background-color: #263544; border-color: #3b4f64; border-left-color: var(--mm-primary-light); color: #dce7f4; }

/* ------ Borders & misc ------ */
[data-theme="dark"] .border,
[data-theme="dark"] .border-top,
[data-theme="dark"] .border-bottom,
[data-theme="dark"] .border-start,
[data-theme="dark"] .border-end { border-color: var(--mm-border) !important; }
[data-theme="dark"] .page-header { border-color: var(--mm-border); }
[data-theme="dark"] hr { border-color: var(--mm-border); opacity: 0.5; }
[data-theme="dark"] .text-muted { color: var(--mm-text-muted) !important; }
[data-theme="dark"] .bg-white,
[data-theme="dark"] .bg-light { background-color: var(--mm-surface) !important; color: var(--mm-text); }
[data-theme="dark"] .bg-light-subtle { background-color: #2a2a2a !important; }
[data-theme="dark"] .nav-tabs { border-color: var(--mm-border); }
[data-theme="dark"] .nav-tabs .nav-link { color: var(--mm-text-muted); }
[data-theme="dark"] .nav-tabs .nav-link.active,
[data-theme="dark"] .nav-tabs .nav-item.show .nav-link {
    background-color: var(--mm-surface);
    border-color: var(--mm-border) var(--mm-border) var(--mm-surface);
    color: var(--mm-text);
}
[data-theme="dark"] .breadcrumb-item.active,
[data-theme="dark"] .breadcrumb-item + .breadcrumb-item::before { color: var(--mm-text-muted); }
[data-theme="dark"] .collapse.show,
[data-theme="dark"] .collapsing { background-color: transparent; }
[data-theme="dark"] code { background-color: #2a2a2a; color: #ce93d8; }
[data-theme="dark"] pre { background-color: #1e1e1e; color: var(--mm-text); border-color: var(--mm-border); }
[data-theme="dark"] .badge.bg-secondary { background-color: #444 !important; }
[data-theme="dark"] .badge-school { background-color: #263238; color: #e3f2fd; border-color: #455a64; }
[data-theme="dark"] .badge.bg-light,
[data-theme="dark"] .bg-light.text-dark,
[data-theme="dark"] .text-dark { color: var(--mm-text) }
[data-theme="dark"] .badge.bg-light.text-dark,
[data-theme="dark"] .badge.bg-light.text-dark.border {
    background-color: #2a3a4c !important;
    color: #dbe9fb !important;
    border-color: #40566f !important;
}
[data-theme="dark"] .text-light { color: var(--mm-text-muted) !important; }

/* === media query mirrors for system-dark users without manual toggle === */
@media (prefers-color-scheme: dark) {
    :root:not([data-theme="light"]) .dropdown-menu { background-color: var(--mm-dropdown-bg); border-color: var(--mm-dropdown-border); }
    :root:not([data-theme="light"]) .dropdown-item { color: var(--mm-text); }
    :root:not([data-theme="light"]) .dropdown-item:hover { background-color: rgba(255,255,255,0.08); }
    :root:not([data-theme="light"]) .table {
        --bs-table-color: var(--mm-text); --bs-table-bg: var(--mm-surface);
        --bs-table-border-color: var(--mm-border); --bs-table-hover-bg: rgba(255,255,255,0.06);
    }
    :root:not([data-theme="light"]) .table > :not(caption) > * > * { color: var(--mm-text); border-color: var(--mm-border); }
    :root:not([data-theme="light"]) .card { background-color: var(--mm-surface); color: var(--mm-text); }
    :root:not([data-theme="light"]) .card-header,
    :root:not([data-theme="light"]) .card-header.bg-white { background-color: #223244 !important; color: #e3eefc; border-color: #32465e; }
    :root:not([data-theme="light"]) .list-group-item { background-color: var(--mm-surface); color: var(--mm-text); border-color: var(--mm-border); }
    :root:not([data-theme="light"]) .form-control,
    :root:not([data-theme="light"]) .form-select { background-color: #2a2a2a; border-color: var(--mm-border); color: var(--mm-text); }
    :root:not([data-theme="light"]) .form-control:focus,
    :root:not([data-theme="light"]) .form-select:focus { background-color: #2a2a2a; border-color: var(--mm-info); color: var(--mm-text); box-shadow: 0 0 0 0.2rem rgba(47, 128, 237, 0.35); }
    :root:not([data-theme="light"]) .input-group-text { background-color: #333; border-color: var(--mm-border); color: var(--mm-text); }
    :root:not([data-theme="light"]) .form-label { color: var(--mm-text); }
    :root:not([data-theme="light"]) .form-check-label { color: var(--mm-text); }
    :root:not([data-theme="light"]) .form-check-input { background-color: #2a2a2a; border-color: #555; }
    :root:not([data-theme="light"]) .modal-content { background-color: var(--mm-surface); color: var(--mm-text); border-color: var(--mm-border); }
    :root:not([data-theme="light"]) .modal-header,
    :root:not([data-theme="light"]) .modal-footer { border-color: var(--mm-border); }
    :root:not([data-theme="light"]) .bg-white,
    :root:not([data-theme="light"]) .bg-light { background-color: var(--mm-surface) !important; }
    :root:not([data-theme="light"]) .bg-light-subtle { background-color: #2a2a2a !important; }
    :root:not([data-theme="light"]) .page-header { border-color: var(--mm-border); }
    :root:not([data-theme="light"]) hr { border-color: var(--mm-border); }
    :root:not([data-theme="light"]) .alert-info { background-color: #0f2942; border-color: #2f80ed; border-left-color: #2f80ed; color: #b9dbff; }
    :root:not([data-theme="light"]) .alert-success { background-color: #123325; border-color: #2ead67; border-left-color: #2ead67; color: #a8e8c8; }
    :root:not([data-theme="light"]) .alert-danger { background-color: #40191a; border-color: #c62828; border-left-color: #c62828; color: #f4b9b7; }
    :root:not([data-theme="light"]) .alert-warning { background-color: #3c2b12; border-color: #f28c28; border-left-color: #f28c28; color: #ffd9ae; }
    :root:not([data-theme="light"]) .alert-light { background-color: #263544; border-color: #3b4f64; border-left-color: var(--mm-primary-light); color: #dce7f4; }
    :root:not([data-theme="light"]) .border { border-color: var(--mm-border) !important; }
    :root:not([data-theme="light"]) .text-muted { color: var(--mm-text-muted) !important; }
    :root:not([data-theme="light"]) .table-success { --bs-table-bg: rgba(46,125,50,0.25); background-color: rgba(46,125,50,0.25) !important; color: #a5d6a7; }
}

/* Theme toggle button */
.btn-theme-toggle {
    background: transparent;
    border: 1px solid rgba(255,255,255,0.55);
    color: rgba(255,255,255,0.85);
    border-radius: 50%;
    width: 34px;
    height: 34px;
    padding: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background 0.2s;
}
.btn-theme-toggle:hover {
    background: rgba(255,255,255,0.15);
    color: #fff;
}

/* Scratch badge */
.badge-scratched { background-color: var(--mm-error); }

/* Unmatched highlight */
.unmatched-wrestler {
    border-left: 4px solid var(--mm-accent);
}

.unmatched-wrestler-draggable {
    cursor: grab;
}

.unmatched-wrestler-draggable.dragging {
    opacity: 0.45;
}

.unmatched-wrestler-card.slot-over {
    border-color: var(--mm-info) !important;
    box-shadow: 0 0 0 2px rgba(47, 128, 237, 0.2);
}

.unmatched-wrestler-card.tap-selected,
.manual-wrestler-item.tap-selected .card {
    border-color: var(--mm-warning) !important;
    box-shadow: 0 0 0 3px rgba(243, 156, 18, 0.22);
}

/* Landing hero */
.hero-section {
    background: linear-gradient(135deg, #123C73 0%, #1C5AA6 100%);
    color: #fff;
    border-radius: 16px;
    padding: 4rem 2rem;
}

/* View-scoped overrides migrated from Views/Shared/_Layout.cshtml.css
   to keep behavior after removing that view-scoped stylesheet. */

/* Make brand link wrap nicely in narrow navbar areas */
a.navbar-brand {
    white-space: normal;
    text-align: center;
    word-break: break-all;
}

/* Site link color (migrated from view-scoped stylesheet). If you prefer
   links to follow the theme, adjust this to use a CSS variable. */
a {
    color: #0077cc;
}

/* Nav pills active state */
.nav-pills .nav-link.active,
.nav-pills .show > .nav-link {
    color: #fff;
    background-color: #1b6ec2;
    border-color: #1861ac;
}

/* Simple border utilities (kept consistent with the previous view-scoped rules) */
.border-top {
    border-top: 1px solid #e5e5e5;
}
.border-bottom {
    border-bottom: 1px solid #e5e5e5;
}

/* Lightweight box-shadow utility used in some places */
.box-shadow {
    box-shadow: 0 .25rem .75rem rgba(0, 0, 0, .05);
}

/* Small button used for cookie/consent actions */
button.accept-policy {
    font-size: 1rem;
    line-height: inherit;
}

/* Requirements6: dual-range controls */
.mm-range-wrap {
    border: 1px solid var(--mm-border);
    border-radius: 10px;
    padding: 0.55rem 0.7rem 2.2rem;
    background: var(--mm-surface-alt);
    position: relative;
    --mm-range-min-percent: 0%;
    --mm-range-max-percent: 100%;
}

.mm-range-track {
    position: absolute;
    left: 0.55rem;
    right: 0.55rem;
    top: 2.25rem;
    height: 0.4rem;
    border-radius: 999px;
    background: linear-gradient(
        to right,
        var(--mm-border-strong) 0,
        var(--mm-border-strong) var(--mm-range-min-percent),
        var(--mm-info) var(--mm-range-min-percent),
        var(--mm-info) var(--mm-range-max-percent),
        var(--mm-border-strong) var(--mm-range-max-percent),
        var(--mm-border-strong) 100%
    );
    pointer-events: none;
}

.mm-range-wrap .form-range {
    position: absolute;
    left: 0.55rem;
    right: 0.55rem;
    top: 1.95rem;
    margin: 0;
    background: transparent;
}

.mm-range-wrap .form-range::-webkit-slider-runnable-track {
    background: transparent;
}

.mm-range-wrap .form-range::-moz-range-track {
    background: transparent;
}

.mm-range-wrap .form-range::-webkit-slider-thumb {
    position: relative;
    z-index: 2;
}

.mm-range-wrap .form-range::-moz-range-thumb {
    position: relative;
    z-index: 2;
}

.mm-range-tooltip {
    position: absolute;
    top: 1.1rem;
    transform: translateX(-50%);
    min-width: 1.8rem;
    text-align: center;
    border-radius: 999px;
    padding: 0.05rem 0.4rem;
    font-size: 0.72rem;
    font-weight: 700;
    color: #fff;
    background: var(--mm-primary-light);
    box-shadow: 0 1px 4px rgba(0, 0, 0, 0.2);
    pointer-events: none;
}

[data-theme="dark"] .mm-range-wrap {
    background: #223244;
    border-color: #3b4f64;
}

[data-theme="dark"] .mm-range-track {
    background: linear-gradient(
        to right,
        #3b4f64 0,
        #3b4f64 var(--mm-range-min-percent),
        #63a4ff var(--mm-range-min-percent),
        #63a4ff var(--mm-range-max-percent),
        #3b4f64 var(--mm-range-max-percent),
        #3b4f64 100%
    );
}

@media (prefers-color-scheme: dark) {
    :root:not([data-theme="light"]) .mm-range-wrap {
        background: #223244;
        border-color: #3b4f64;
    }

    :root:not([data-theme="light"]) .mm-range-track {
        background: linear-gradient(
            to right,
            #3b4f64 0,
            #3b4f64 var(--mm-range-min-percent),
            #63a4ff var(--mm-range-min-percent),
            #63a4ff var(--mm-range-max-percent),
            #3b4f64 var(--mm-range-max-percent),
            #3b4f64 100%
        );
    }
}

/* Requirements6: manual match board */
.manual-slot {
    min-height: 120px;
    border: 2px dashed var(--mm-border-strong);
    border-radius: 10px;
    padding: 0.75rem;
    background: var(--mm-surface-alt);
    display: flex;
    align-items: center;
    justify-content: center;
}

.manual-slot.slot-over {
    border-color: var(--mm-info);
    background: rgba(47, 128, 237, 0.08);
}

.manual-slot.filled {
    border-style: solid;
}

.manual-slot-empty {
    color: var(--mm-text-muted);
    font-size: 0.9rem;
}

.manual-slot-card {
    width: 100%;
}

[data-theme="dark"] .manual-slot {
    background: #18222f;
    border-color: #4f6a86;
}

[data-theme="dark"] .manual-slot.slot-over {
    background: rgba(99, 164, 255, 0.18);
    border-color: #7fb9ff;
}

[data-theme="dark"] .manual-slot-empty,
[data-theme="dark"] .manual-slot-card {
    color: #eaf3ff;
}

@media (prefers-color-scheme: dark) {
    :root:not([data-theme="light"]) .manual-slot {
        background: #18222f;
        border-color: #4f6a86;
    }

    :root:not([data-theme="light"]) .manual-slot.slot-over {
        background: rgba(99, 164, 255, 0.18);
        border-color: #7fb9ff;
    }

    :root:not([data-theme="light"]) .manual-slot-empty,
    :root:not([data-theme="light"]) .manual-slot-card {
        color: #eaf3ff;
    }
}

.manual-pair-sticky {
    position: sticky;
    top: 76px;
    z-index: 20;
}

.manual-wrestler-item {
    cursor: grab;
}

.manual-wrestler-item:active {
    cursor: grabbing;
}

.match-row-draggable {
    cursor: move;
}

.match-row-dragging {
    opacity: 0.5;
}