/* ═══════════════════════════════════════════════════════════════
   MNLVG — Modern Sport Theme
   Barlow Condensed (headings/UI) + DM Sans (body)
   Fonts loaded via <link> in moon-master.html
   ═══════════════════════════════════════════════════════════════ */

/* ── Layout ──────────────────────────────────────────────────────── */
.container-lg { max-width: 1600px !important; }

/* ── Tokens ─────────────────────────────────────────────────────── */
:root {
    --bg: oklch(96.5% 0.006 255);
    --surface: oklch(100% 0 0);
    --surface-dim: oklch(94% 0.007 255);
    --border: oklch(88% 0.01 255);
    --text: oklch(18% 0.03 260);
    --text-muted: oklch(52% 0.025 260);
    --navy: oklch(40% 0.15 268);
    --navy-light: oklch(50% 0.16 268);
    --green: oklch(56% 0.19 148);
    --green-light: oklch(92% 0.06 148);
    --green-dim: oklch(49% 0.175 148);
    --table-header-bg: oklch(40% 0.15 268);
    --table-header-text: oklch(97% 0.005 260);
    --radius-sm: 4px;
    --radius: 6px;
    --shadow-sm:
        0 1px 3px oklch(18% 0.03 260 / 0.08),
        0 1px 2px oklch(18% 0.03 260 / 0.06);
    --shadow:
        0 4px 12px oklch(18% 0.03 260 / 0.1),
        0 2px 4px oklch(18% 0.03 260 / 0.06);

    /* spacing scale */
    --sp-1: 0.25rem;
    --sp-2: 0.5rem;
    --sp-3: 0.75rem;
    --sp-4: 1rem;
    --sp-5: 1.25rem;
    --sp-6: 1.5rem;
    --sp-8: 2rem;
    --sp-10: 2.5rem;
    --sp-12: 3rem;
}

/* ── Base ────────────────────────────────────────────────────────── */
html {
    font-size: 16px;
}

body {
    background-color: var(--bg) !important;
    color: var(--text) !important;
    font-family: "DM Sans", system-ui, sans-serif !important;
    line-height: 1.6;
    -webkit-font-smoothing: antialiased;
}

a {
    color: var(--green-dim);
    text-decoration: none;
    transition: color 0.15s;
}
a:hover {
    color: var(--green);
}

h1,
h2,
h3,
h4,
h5,
h6 {
    font-family: "Barlow Condensed", sans-serif !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.04em !important;
    color: var(--text) !important;
    line-height: 1.1 !important;
    margin-top: 0 !important;
}

h1 {
    font-size: clamp(1.8rem, 4vw, 2.6rem) !important;
}
h2 {
    font-size: clamp(1.3rem, 2.8vw, 1.75rem) !important;
}
h3 {
    font-size: clamp(1.1rem, 2vw, 1.35rem) !important;
}

/* ── Focus ───────────────────────────────────────────────────────── */
:focus-visible {
    outline: 2px solid var(--green) !important;
    outline-offset: 2px !important;
    border-radius: var(--radius-sm) !important;
}
.navbar :focus-visible {
    outline-color: var(--green) !important;
    outline-offset: 3px !important;
}

/* ── Page structure ──────────────────────────────────────────────── */
.page-wrapper {
    background-color: var(--bg) !important;
}

.content-wrapper {
    background-color: var(--bg) !important;
    padding-top: 2rem !important;
    padding-bottom: 3rem !important;
}

/* ── Navbar ──────────────────────────────────────────────────────── */
.navbar:not(.navbar-fixed-bottom) {
    background-color: var(--navy) !important;
    border-bottom: 3px solid var(--green) !important;
    border-top: none !important;
    padding: 0 1.5rem !important;
    min-height: 60px !important;
}

.navbar-brand {
    display: flex;
    align-items: center;
    transition: opacity 0.15s;
}
.navbar-brand:hover {
    opacity: 0.85;
    text-decoration: none !important;
}
.navbar-brand img {
    height: 36px;
}

.navbar .navbar-nav .nav-link {
    font-family: "Barlow Condensed", sans-serif !important;
    font-size: 1.05rem !important;
    font-weight: 600 !important;
    letter-spacing: 0.08em !important;
    text-transform: uppercase !important;
    color: oklch(82% 0.012 260) !important;
    padding: 0 1rem !important;
    display: flex !important;
    align-items: center !important;
    height: 60px;
    border-bottom: 3px solid transparent !important;
    margin-bottom: -3px;
    transition:
        color 0.15s,
        border-color 0.15s !important;
    text-decoration: none !important;
}
.navbar .navbar-nav .nav-link:hover {
    color: #fff !important;
    border-bottom-color: var(--green) !important;
}

.navbar-content {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.navbar .btn-primary {
    background-color: var(--green) !important;
    border: none !important;
    color: #fff !important;
    font-family: "Barlow Condensed", sans-serif !important;
    font-size: 1rem !important;
    font-weight: 600 !important;
    letter-spacing: 0.07em !important;
    text-transform: uppercase !important;
    border-radius: var(--radius-sm) !important;
    padding: 0.45rem 1rem !important;
    cursor: pointer;
    transition: background-color 0.15s !important;
}
.navbar .btn-primary:hover {
    background-color: var(--green-dim) !important;
}

.navbar .btn-action {
    background: oklch(48% 0.13 268) !important;
    border: none !important;
    color: oklch(72% 0.02 260) !important;
    border-radius: var(--radius-sm) !important;
    width: 36px !important;
    height: 36px !important;
    padding: 0 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    cursor: pointer;
    transition:
        background-color 0.15s,
        color 0.15s !important;
}
.navbar .btn-action:hover {
    background-color: oklch(56% 0.14 268) !important;
    color: #fff !important;
}

.navbar .dropdown .btn {
    font-family: "Barlow Condensed", sans-serif !important;
    font-size: 1rem !important;
    font-weight: 600 !important;
    letter-spacing: 0.07em !important;
    text-transform: uppercase !important;
    background: oklch(48% 0.13 268) !important;
    border: none !important;
    color: #fff !important;
    border-radius: var(--radius-sm) !important;
    padding: 0.45rem 0.9rem !important;
    cursor: pointer;
}

.navbar .badge-success {
    background-color: var(--green) !important;
    color: #fff !important;
    font-family: "Barlow Condensed", sans-serif !important;
    font-size: 0.8rem !important;
    font-weight: 600 !important;
    letter-spacing: 0.06em !important;
    text-transform: uppercase !important;
    border-radius: var(--radius-sm) !important;
    padding: 0.2rem 0.6rem !important;
}

/* ── Bottom navbar — hide (empty) ────────────────────────────────── */
.navbar-fixed-bottom {
    display: none !important;
}

/* ── Navbar responsive — our own breakpoints (Halfmoon d-md-* is broken) */
.nav-desktop {
    display: none !important;
}
.nav-auth-desktop {
    display: none !important;
}
.nav-mobile-dropdown {
    display: block !important;
}

@media (min-width: 769px) {
    .nav-desktop {
        display: flex !important;
    }
    .nav-auth-desktop {
        display: flex !important;
        align-items: center;
        gap: 0.25rem;
    }
    .nav-mobile-dropdown {
        display: none !important;
    }
}

/* ── Cards ───────────────────────────────────────────────────────── */
.card {
    background-color: var(--surface) !important;
    border: 1px solid var(--border) !important;
    border-radius: var(--radius) !important;
    box-shadow: var(--shadow-sm) !important;
    padding: 1.25rem 1.5rem !important;
    margin-bottom: 1.25rem !important;
    font-size: 1.125rem !important;
}

.card-title {
    font-family: "Barlow Condensed", sans-serif !important;
    font-size: 1.15rem !important;
    font-weight: 700 !important;
    letter-spacing: 0.05em !important;
    text-transform: uppercase !important;
    color: var(--text) !important;
    margin-bottom: 1rem !important;
    padding-bottom: 0.65rem !important;
    border-bottom: 2px solid var(--green) !important;
    display: flex;
    align-items: center;
    gap: 0.5rem;
}
.card-title::before {
    content: "";
    display: inline-block;
    width: 4px;
    height: 1.1em;
    background: var(--green);
    border-radius: 2px;
    flex-shrink: 0;
}

/* card image utility (replaces Bootstrap img-fluid / rounded-top) */
.card-img-top {
    width: 100%;
    display: block;
    height: auto;
    border-radius: var(--radius) var(--radius) 0 0;
}
.img-fluid {
    max-width: 100%;
    height: auto;
    display: block;
}

/* ── Tables ──────────────────────────────────────────────────────── */
.table {
    border-collapse: collapse !important;
    width: 100% !important;
    font-size: 1rem !important;
}

.table thead th,
.table th {
    font-family: "Barlow Condensed", sans-serif !important;
    font-size: 0.95rem !important;
    font-weight: 600 !important;
    letter-spacing: 0.1em !important;
    text-transform: uppercase !important;
    background-color: var(--table-header-bg) !important;
    color: var(--table-header-text) !important;
    padding: 0.6rem 0.9rem !important;
    border: none !important;
    white-space: nowrap;
}

.table td {
    padding: 0.5rem 0.9rem !important;
    border: none !important;
    border-bottom: 1px solid var(--border) !important;
    vertical-align: middle !important;
    text-wrap-mode: wrap !important;
}

.table tbody tr:last-child td {
    border-bottom: none !important;
}

.table tbody tr:hover td {
    background-color: var(--green-light) !important;
}

.table-striped tbody tr:nth-child(even) td {
    background-color: oklch(89% 0.022 268) !important;
}
.table-striped tbody tr:hover td {
    background-color: var(--green-light) !important;
}
.dark-mode .table-striped tbody tr:nth-child(even) td {
    background-color: oklch(25% 0.048 268) !important;
}

.table-responsive {
    border-radius: var(--radius) !important;
    overflow-x: auto !important;
    overflow-y: visible !important;
    -webkit-overflow-scrolling: touch !important;
    border: 1px solid var(--border) !important;
}

/* ── Buttons ─────────────────────────────────────────────────────── */
.btn {
    font-family: "Barlow Condensed", sans-serif !important;
    font-size: 1rem !important;
    font-weight: 600 !important;
    letter-spacing: 0.07em !important;
    text-transform: uppercase !important;
    border-radius: var(--radius-sm) !important;
    padding: 0.6rem 1.1rem !important; /* ≥44px touch target */
    cursor: pointer;
    transition:
        background-color 0.15s,
        color 0.15s,
        border-color 0.15s !important;
    text-decoration: none !important;
    display: inline-flex !important;
    align-items: center !important;
    gap: 0.35em !important;
    line-height: 1 !important;
}

.btn-primary {
    background-color: var(--navy) !important;
    border: 1px solid var(--navy) !important;
    color: #fff !important;
}
.btn-primary:hover {
    background-color: var(--navy-light) !important;
    border-color: var(--navy-light) !important;
    color: #fff !important;
}

.btn-secondary {
    background-color: transparent !important;
    border: 1px solid var(--border) !important;
    color: var(--text) !important;
}
.btn-secondary:hover {
    background-color: var(--surface-dim) !important;
    border-color: oklch(75% 0.012 260) !important;
    color: var(--text) !important;
}

/* ── Badges ──────────────────────────────────────────────────────── */
.badge {
    font-family: "Barlow Condensed", sans-serif !important;
    font-size: 0.95rem !important;
    font-weight: 600 !important;
    letter-spacing: 0.06em !important;
    text-transform: uppercase !important;
    border-radius: var(--radius-sm) !important;
    padding: 0.2rem 0.55rem !important;
}

/* ── Alerts (calendar match cells) ──────────────────────────────── */
.alert {
    border-radius: var(--radius-sm) !important;
    padding: 0.5rem 0.75rem !important;
    border: none !important;
}
.alert-success {
    background-color: var(--green-light) !important;
    color: var(--text) !important;
}
.alert-heading {
    font-family: "Barlow Condensed", sans-serif !important;
    font-size: 1rem !important;
    font-weight: 700 !important;
    letter-spacing: 0.04em !important;
    text-transform: uppercase !important;
    color: var(--navy) !important;
    margin-bottom: 0.15rem !important;
}
.alert-link {
    color: var(--green-dim) !important;
    font-family: "Barlow Condensed", sans-serif !important;
    font-size: 0.82rem !important;
    font-weight: 600 !important;
    letter-spacing: 0.05em !important;
    text-transform: uppercase !important;
}
.alert-link:hover {
    color: var(--green) !important;
}

/* ── Text utilities ──────────────────────────────────────────────── */
.text-muted {
    color: var(--text-muted) !important;
    font-size: 0.88rem !important;
}
.text-right {
    text-align: right !important;
}
.text-center,
.center,
.centered {
    text-align: center !important;
}
.fw-semibold {
    font-weight: 600 !important;
}

/* ── Dropdowns ───────────────────────────────────────────────────── */
.dropdown-menu {
    background-color: var(--surface) !important;
    border: 1px solid var(--border) !important;
    border-radius: var(--radius) !important;
    box-shadow: var(--shadow) !important;
    padding: 0.4rem 0 !important;
}
.dropdown-item {
    font-family: "Barlow Condensed", sans-serif !important;
    font-size: 1rem !important;
    font-weight: 600 !important;
    letter-spacing: 0.07em !important;
    text-transform: uppercase !important;
    color: var(--text) !important;
    padding: 0.55rem 1.1rem !important;
    display: block;
    text-decoration: none !important;
    transition:
        background-color 0.12s,
        color 0.12s;
}
.dropdown-item:hover {
    background-color: var(--green-light) !important;
    color: var(--navy) !important;
    text-decoration: none !important;
}

/* ── Misc ────────────────────────────────────────────────────────── */
.sticky-alerts {
    z-index: 9999 !important;
}
.m-5 {
    margin: 0.3rem !important;
}
.m-10 {
    margin: 0.6rem !important;
}
.mt-20 {
    margin-top: 1.25rem !important;
}
.mr-5 {
    margin-right: 0.3rem !important;
}

/* ── Calendar table ──────────────────────────────────────────────── */
.calendar-table td {
    min-width: 90px;
    vertical-align: top !important;
    padding: 0.4rem 0.5rem !important;
}
/* First 5 columns (Mon–Fri) — minimal width since matches are on weekends */
.calendar-table th:nth-child(-n + 5),
.calendar-table td:nth-child(-n + 5) {
    min-width: 40px;
}
.calendar-table .alert {
    padding: 0.4rem 0.5rem !important;
    margin: 0 !important;
}
.calendar-table .alert-heading {
    font-size: 1.05rem !important;
    margin-bottom: 0.15rem !important;
}
.calendar-table .alert-link {
    font-size: 0.9rem !important;
    line-height: 1.3;
    display: block;
}
@media (max-width: 600px) {
    .calendar-table th:nth-child(-n + 5),
    .calendar-table td:nth-child(-n + 5) {
        min-width: 28px;
    }
    .calendar-table th:nth-child(n + 6),
    .calendar-table td:nth-child(n + 6) {
        min-width: 75px;
    }
}

/* ── Match scorecard ─────────────────────────────────────────────── */
.match-scorecard {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 1rem 0 1.5rem;
}
.match-scorecard__team {
    flex: 1;
    display: flex;
    align-items: center;
    gap: 0.75rem;
    min-width: 0;
}
.match-scorecard__team--guest {
    flex-direction: row-reverse;
    text-align: right;
}
.match-scorecard__name {
    font-family: "Barlow Condensed", sans-serif;
    font-size: clamp(1.1rem, 3vw, 1.5rem);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.03em;
    color: var(--text);
    line-height: 1.1;
    min-width: 0;
    word-break: break-word;
}
.match-scorecard__name:hover {
    color: var(--green-dim);
    text-decoration: none;
}
.match-scorecard__score {
    font-family: "Barlow Condensed", sans-serif;
    font-size: clamp(2.2rem, 6vw, 3rem);
    font-weight: 800;
    color: var(--navy);
    flex-shrink: 0;
    line-height: 1;
    min-width: 1.5rem;
    text-align: center;
}
.match-scorecard__sep {
    font-family: "Barlow Condensed", sans-serif;
    font-size: clamp(2.2rem, 6vw, 3rem);
    font-weight: 800;
    color: var(--text-muted);
    flex-shrink: 0;
    line-height: 1;
}
.match-stats td {
    text-align: center !important;
}
.match-stats td:first-child {
    text-align: right !important;
}
.match-stats td:last-child {
    text-align: left !important;
}
.match-stats td:nth-child(2) {
    color: var(--text-muted);
    font-size: 0.82rem !important;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    white-space: nowrap;
    width: 9rem;
}
@media (max-width: 520px) {
    .match-scorecard {
        gap: 0.5rem;
    }
    .match-scorecard__team {
        gap: 0.4rem;
    }
    .match-stats td:nth-child(2) {
        width: 5.5rem;
        font-size: 0.72rem !important;
    }
}

/* ── Page header ─────────────────────────────────────────────────── */
/* Used for section titles that float directly in .row without a card */
.page-header {
    padding: var(--sp-6) 0 var(--sp-5);
    margin-bottom: var(--sp-4);
    border-bottom: 3px solid var(--green);
}
.page-header h1,
.page-header h2 {
    margin-bottom: var(--sp-1) !important;
}
.page-header .text-muted {
    margin-top: var(--sp-2);
    display: block;
}

/* ── Stats grid — pairs of half-width stat cards ─────────────────── */
/* Ensure col-md-6 pairs in .row get proper bottom margin when they wrap */
.row .col-md-6 .card,
.row .col-lg-5 .card,
.row .col-lg-7 .card {
    margin-bottom: 0 !important;
}
.row .col-md-6,
.row .col-lg-5,
.row .col-lg-7 {
    margin-bottom: var(--sp-5) !important;
}

/* ── Season round strip ───────────────────────────────────────────── */
/* Compact visual for schedule page round header */
.round-strip {
    display: flex;
    align-items: baseline;
    gap: var(--sp-4);
    margin-bottom: var(--sp-3);
}
.round-strip__num {
    font-family: "Barlow Condensed", sans-serif;
    font-size: 2.8rem;
    font-weight: 800;
    color: var(--green);
    line-height: 1;
    flex-shrink: 0;
    min-width: 2.5rem;
    text-align: right;
}
.round-strip__info {
    flex: 1;
    min-width: 0;
}
.round-strip__name {
    font-family: "Barlow Condensed", sans-serif;
    font-size: 1.15rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--text);
    line-height: 1.2;
}
.round-strip__date {
    font-size: 0.85rem;
    margin-top: 0.1rem;
    color: var(--green);
}
.round-strip__actions {
    display: flex;
    align-items: center;
    gap: var(--sp-3);
}

/* ── Dark mode ───────────────────────────────────────────────────── */
.dark-mode {
    --bg: oklch(15% 0.025 265);
    --surface: oklch(19% 0.03 265);
    --surface-dim: oklch(22% 0.03 265);
    --border: oklch(32% 0.035 265);
    --text: oklch(92% 0.01 260);
    --text-muted: oklch(60% 0.02 260);
    --green-light: oklch(25% 0.06 148);
    --green-dim: oklch(62% 0.18 148);
    --navy: oklch(26% 0.08 268);
    --navy-light: oklch(36% 0.1 268);
    --table-header-bg: oklch(34% 0.11 268);
    --table-header-text: oklch(97% 0.005 260);
}

.dark-mode .page-wrapper {
    background-color: var(--bg) !important;
}
.dark-mode .content-wrapper {
    background-color: var(--bg) !important;
}

.dark-mode .card {
    background-color: var(--surface) !important;
    box-shadow: 0 2px 8px oklch(5% 0.02 260 / 0.4) !important;
}

.dark-mode .navbar:not(.navbar-fixed-bottom) {
    background-color: oklch(17% 0.06 268) !important;
}
.dark-mode .navbar .btn-action {
    background: oklch(30% 0.075 268) !important;
}

.dark-mode .match-scorecard__score {
    color: oklch(85% 0.015 260) !important;
}

.dark-mode .table-responsive {
    border-color: var(--border) !important;
}

.dark-mode .dropdown-menu {
    background-color: var(--surface) !important;
    box-shadow: 0 8px 24px oklch(5% 0.02 260 / 0.5) !important;
}
.dark-mode .btn-secondary {
    color: var(--text) !important;
}
.dark-mode .btn-secondary:hover {
    background-color: var(--surface-dim) !important;
}

.dark-mode .alert-heading {
    color: var(--green-dim) !important;
}
