/*
Theme Name: MSA Theme
Theme URI: https://manjaisports.com
Author: Manjai Sports Association
Author URI: https://manjaisports.com
Description: Custom theme for Manjai Sports Association — football fixtures, results, standings, team profiles, venue bookings, and more. Reads data directly from the FootManager plugin.
Version: 1.0.0
Requires at least: 6.0
Requires PHP: 8.0
Text Domain: msa-theme
*/

/* ===== CSS Custom Properties ===== */
:root {
    /* Brand Colors */
    --msa-primary: #F26522;
    --msa-primary-dark: #D4551A;
    --msa-primary-light: #FF8A50;
    --msa-red: #CE1126;
    --msa-blue: #0C1C8C;
    --msa-blue-dark: #091466;
    --msa-gold: #FFD700;

    /* Neutrals */
    --msa-white: #FFFFFF;
    --msa-gray-50: #F9FAFB;
    --msa-gray-100: #F3F4F6;
    --msa-gray-200: #E5E7EB;
    --msa-gray-300: #D1D5DB;
    --msa-gray-400: #9CA3AF;
    --msa-gray-500: #6B7280;
    --msa-gray-600: #4B5563;
    --msa-gray-700: #374151;
    --msa-gray-800: #1F2937;
    --msa-gray-900: #111827;

    /* Semantic */
    --msa-success: #10B981;
    --msa-warning: #F59E0B;
    --msa-danger: #EF4444;
    --msa-info: #3B82F6;
    --msa-live: #EF4444;

    /* Typography */
    --msa-font-sans: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
    --msa-font-mono: 'SF Mono', SFMono-Regular, Consolas, 'Liberation Mono', Menlo, monospace;

    /* Spacing */
    --msa-container: 1400px;
    --msa-gap: 1rem;
    --msa-gap-lg: 1.5rem;
    --msa-gap-xl: 2rem;

    /* Borders */
    --msa-radius: 8px;
    --msa-radius-sm: 4px;
    --msa-radius-lg: 12px;

    /* Shadows */
    --msa-shadow-sm: 0 1px 2px rgba(0,0,0,.05);
    --msa-shadow: 0 1px 3px rgba(0,0,0,.1), 0 1px 2px rgba(0,0,0,.06);
    --msa-shadow-md: 0 4px 6px rgba(0,0,0,.1), 0 2px 4px rgba(0,0,0,.06);
    --msa-shadow-lg: 0 10px 15px rgba(0,0,0,.1), 0 4px 6px rgba(0,0,0,.05);

    /* Transitions */
    --msa-transition: 150ms ease;
}

/* ===== Reset & Base ===== */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html { font-size: 16px; -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }

body {
    font-family: var(--msa-font-sans);
    color: var(--msa-gray-800);
    background: var(--msa-gray-50);
    line-height: 1.6;
}

img { max-width: 100%; height: auto; display: block; }
a { color: var(--msa-primary); text-decoration: none; transition: color var(--msa-transition); }
a:hover { color: var(--msa-primary-dark); }

h1, h2, h3, h4, h5, h6 { line-height: 1.25; font-weight: 700; color: var(--msa-gray-900); }
h1 { font-size: 2rem; }
h2 { font-size: 1.5rem; }
h3 { font-size: 1.25rem; }

/* ===== Layout ===== */
.msa-container {
    max-width: var(--msa-container);
    margin: 0 auto;
    padding: 0 1rem;
}

.msa-section {
    padding: var(--msa-gap-xl) 0;
}

.msa-section__header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: var(--msa-gap-lg);
}

.msa-section__title {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--msa-gray-900);
}

.msa-section__link {
    font-size: .875rem;
    font-weight: 600;
    color: var(--msa-primary);
}

/* ===== Grid System ===== */
.msa-grid {
    display: grid;
    gap: var(--msa-gap);
}

.msa-grid--2 { grid-template-columns: repeat(2, 1fr); }
.msa-grid--3 { grid-template-columns: repeat(3, 1fr); }
.msa-grid--4 { grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); }

@media (max-width: 576px) {
    .msa-grid--2, .msa-grid--3 {
        grid-template-columns: 1fr;
    }
}

@media (min-width: 577px) and (max-width: 768px) {
    .msa-grid--3 {
        grid-template-columns: repeat(2, 1fr);
    }
}

/* ===== Card ===== */
.msa-card {
    background: var(--msa-white);
    border-radius: var(--msa-radius);
    box-shadow: var(--msa-shadow);
    overflow: hidden;
    transition: box-shadow var(--msa-transition), transform var(--msa-transition);
}

.msa-card:hover { box-shadow: var(--msa-shadow-md); transform: translateY(-2px); }

.msa-card__body { padding: var(--msa-gap); }
.msa-card__footer {
    padding: .75rem var(--msa-gap);
    border-top: 1px solid var(--msa-gray-100);
    font-size: .875rem;
    color: var(--msa-gray-500);
}

/* ===== Buttons ===== */
.msa-btn {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    padding: .625rem 1.25rem;
    font-size: .875rem;
    font-weight: 600;
    border-radius: var(--msa-radius);
    border: none;
    cursor: pointer;
    transition: background var(--msa-transition), color var(--msa-transition);
    text-decoration: none;
    line-height: 1.4;
}

.msa-btn--primary {
    background: var(--msa-primary);
    color: var(--msa-white);
}
.msa-btn--primary:hover {
    background: var(--msa-primary-dark);
    color: var(--msa-white);
}

.msa-btn--secondary {
    background: var(--msa-gray-100);
    color: var(--msa-gray-700);
}
.msa-btn--secondary:hover { background: var(--msa-gray-200); }

.msa-btn--outline {
    background: transparent;
    border: 2px solid var(--msa-primary);
    color: var(--msa-primary);
}
.msa-btn--outline:hover {
    background: var(--msa-primary);
    color: var(--msa-white);
}

.msa-btn--sm { padding: .375rem .75rem; font-size: .8125rem; }
.msa-btn--lg { padding: .75rem 1.5rem; font-size: 1rem; }
.msa-btn--block { width: 100%; justify-content: center; }

/* ===== Badge ===== */
.msa-badge {
    display: inline-flex;
    align-items: center;
    padding: .125rem .5rem;
    font-size: .75rem;
    font-weight: 600;
    border-radius: 999px;
    line-height: 1.5;
}

.msa-badge--live { background: var(--msa-live); color: var(--msa-white); animation: msa-pulse 2s infinite; }
.msa-badge--fixture { background: var(--msa-blue); color: var(--msa-white); }
.msa-badge--result { background: var(--msa-gray-200); color: var(--msa-gray-700); }
.msa-badge--pending { background: var(--msa-warning); color: var(--msa-gray-900); }
.msa-badge--approved { background: var(--msa-success); color: var(--msa-white); }
.msa-badge--rejected { background: var(--msa-danger); color: var(--msa-white); }

@keyframes msa-pulse {
    0%, 100% { opacity: 1; }
    50% { opacity: .7; }
}

/* ===== Header ===== */
.msa-header {
    background: var(--msa-primary);
    color: var(--msa-white);
    position: sticky;
    top: 0;
    z-index: 100;
    box-shadow: var(--msa-shadow-md);
}

.msa-header__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    height: 64px;
}

.msa-header__brand {
    display: flex;
    align-items: center;
    gap: .75rem;
    color: var(--msa-white);
    font-weight: 700;
    font-size: 1.125rem;
}

.msa-header__brand img {
    height: 40px;
    width: 40px;
    border-radius: 50%;
}

.msa-header__nav {
    display: flex;
    align-items: center;
    gap: .25rem;
    list-style: none;
}

.msa-header__nav a {
    display: block;
    padding: .5rem .75rem;
    color: rgba(255,255,255,.85);
    font-size: .875rem;
    font-weight: 500;
    border-radius: var(--msa-radius-sm);
    transition: all var(--msa-transition);
}

.msa-header__nav a:hover,
.msa-header__nav a.active {
    color: var(--msa-white);
    background: rgba(255,255,255,.1);
}

.msa-header__toggle {
    display: none;
    background: none;
    border: none;
    color: var(--msa-white);
    font-size: 1.5rem;
    cursor: pointer;
    padding: .5rem;
}

@media (max-width: 768px) {
    .msa-header__toggle { display: block; }
    .msa-header__nav {
        display: none;
        position: absolute;
        top: 64px;
        left: 0;
        right: 0;
        flex-direction: column;
        background: var(--msa-primary-dark);
        padding: .5rem;
        box-shadow: var(--msa-shadow-lg);
    }
    .msa-header__nav.open { display: flex; }
    .msa-header__nav a { padding: .75rem 1rem; }
}

/* ===== Hero Carousel ===== */
.msa-carousel {
    position: relative;
    overflow: hidden;
    background: var(--msa-primary-dark);
}

.msa-carousel__track {
    position: relative;
    height: 500px;
}

.msa-carousel__slide {
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center;
    opacity: 0;
    transition: opacity .8s ease;
    z-index: 0;
}

.msa-carousel__slide.active {
    opacity: 1;
    z-index: 1;
}

.msa-carousel__overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(180,60,10,.85) 0%, rgba(180,60,10,.4) 50%, rgba(180,60,10,.25) 100%);
}

.msa-carousel__content {
    position: relative;
    z-index: 2;
    height: 100%;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    padding-bottom: 4rem;
    color: var(--msa-white);
}

.msa-carousel__title {
    font-size: 2.75rem;
    font-weight: 800;
    color: var(--msa-white);
    margin-bottom: .5rem;
    text-shadow: 0 2px 8px rgba(0,0,0,.3);
    max-width: 700px;
}

.msa-carousel__subtitle {
    font-size: 1.125rem;
    color: rgba(255,255,255,.85);
    margin-bottom: 1.5rem;
    max-width: 600px;
    text-shadow: 0 1px 4px rgba(0,0,0,.2);
}

/* Arrows */
.msa-carousel__arrow {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    z-index: 3;
    background: rgba(255,255,255,.15);
    backdrop-filter: blur(4px);
    border: none;
    color: var(--msa-white);
    width: 48px;
    height: 48px;
    border-radius: 50%;
    font-size: 1.25rem;
    cursor: pointer;
    transition: background var(--msa-transition);
    display: flex;
    align-items: center;
    justify-content: center;
}

.msa-carousel__arrow:hover { background: rgba(255,255,255,.3); }
.msa-carousel__arrow--prev { left: 1rem; }
.msa-carousel__arrow--next { right: 1rem; }

/* Dots */
.msa-carousel__dots {
    position: absolute;
    bottom: 1.25rem;
    left: 50%;
    transform: translateX(-50%);
    z-index: 3;
    display: flex;
    gap: .5rem;
}

.msa-carousel__dot {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    border: 2px solid rgba(255,255,255,.5);
    background: transparent;
    cursor: pointer;
    transition: all var(--msa-transition);
    padding: 0;
}

.msa-carousel__dot.active,
.msa-carousel__dot:hover {
    background: var(--msa-white);
    border-color: var(--msa-white);
}

/* Progress bar */
.msa-carousel__progress {
    position: absolute;
    bottom: 0;
    left: 0;
    height: 3px;
    background: var(--msa-primary);
    z-index: 3;
    transition: width linear;
}

@media (max-width: 768px) {
    .msa-carousel__track { height: 380px; }
    .msa-carousel__title { font-size: 1.75rem; }
    .msa-carousel__subtitle { font-size: 1rem; }
    .msa-carousel__content { padding-bottom: 3rem; }
    .msa-carousel__arrow { width: 36px; height: 36px; font-size: 1rem; }
    .msa-carousel__arrow--prev { left: .5rem; }
    .msa-carousel__arrow--next { right: .5rem; }
}

@media (min-width: 1400px) {
    .msa-carousel__track { height: 560px; }
}

/* ===== Footer ===== */
.msa-footer {
    background: var(--msa-gray-900);
    color: var(--msa-gray-400);
    padding: 3rem 0 1.5rem;
    margin-top: 3rem;
}

.msa-footer__grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: var(--msa-gap-xl);
    margin-bottom: 2rem;
}

.msa-footer__heading {
    color: var(--msa-white);
    font-size: .875rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .05em;
    margin-bottom: 1rem;
}

.msa-footer__links {
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: .5rem;
}

.msa-footer__links a {
    color: var(--msa-gray-400);
    font-size: .875rem;
}
.msa-footer__links a:hover { color: var(--msa-white); }

.msa-footer__bottom {
    padding-top: 1.5rem;
    border-top: 1px solid var(--msa-gray-700);
    text-align: center;
    font-size: .8125rem;
}

/* ===== Hero ===== */
.msa-hero {
    background: linear-gradient(135deg, var(--msa-primary) 0%, var(--msa-primary-dark) 100%);
    color: var(--msa-white);
    padding: 4rem 0;
    text-align: center;
}

.msa-hero__title {
    font-size: 2.5rem;
    font-weight: 800;
    color: var(--msa-white);
    margin-bottom: .5rem;
}

.msa-hero__subtitle {
    font-size: 1.125rem;
    color: rgba(255,255,255,.8);
    margin-bottom: 2rem;
}

@media (max-width: 768px) {
    .msa-hero { padding: 2.5rem 0; }
    .msa-hero__title { font-size: 1.75rem; }
}

/* ===== Tables ===== */
.msa-table-wrap {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

.msa-table {
    width: 100%;
    border-collapse: collapse;
    font-size: .875rem;
}

.msa-table th {
    background: var(--msa-gray-50);
    padding: .625rem .75rem;
    text-align: left;
    font-weight: 600;
    color: var(--msa-gray-600);
    border-bottom: 2px solid var(--msa-gray-200);
    white-space: nowrap;
}

.msa-table td {
    padding: .625rem .75rem;
    border-bottom: 1px solid var(--msa-gray-100);
    vertical-align: middle;
}

.msa-table tbody tr:hover { background: var(--msa-gray-50); }
.msa-table .num { text-align: center; font-variant-numeric: tabular-nums; }

/* ===== Forms ===== */
.msa-form-group {
    margin-bottom: 1rem;
}

.msa-form-group label {
    display: block;
    font-size: .875rem;
    font-weight: 600;
    margin-bottom: .375rem;
    color: var(--msa-gray-700);
}

.msa-input, .msa-select, .msa-textarea {
    width: 100%;
    padding: .625rem .75rem;
    font-size: .875rem;
    border: 1px solid var(--msa-gray-300);
    border-radius: var(--msa-radius);
    background: var(--msa-white);
    color: var(--msa-gray-800);
    transition: border-color var(--msa-transition);
}

.msa-input:focus, .msa-select:focus, .msa-textarea:focus {
    outline: none;
    border-color: var(--msa-primary);
    box-shadow: 0 0 0 3px rgba(242,101,34,.15);
}

.msa-textarea { resize: vertical; min-height: 100px; }

/* ===== Filter Bar ===== */
.msa-filters {
    display: flex;
    flex-wrap: wrap;
    gap: .75rem;
    padding: 1rem;
    background: var(--msa-white);
    border-radius: var(--msa-radius);
    box-shadow: var(--msa-shadow-sm);
    margin-bottom: var(--msa-gap-lg);
}

.msa-filters .msa-select { width: auto; min-width: 180px; }

@media (max-width: 768px) {
    .msa-filters { flex-direction: column; }
    .msa-filters .msa-select { width: 100%; }
}

/* ===== Match Score Card ===== */
.msa-match-card {
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    align-items: center;
    gap: .75rem;
    padding: 1rem;
    text-align: center;
}

.msa-match-card__team {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: .375rem;
}

.msa-match-card__team img {
    width: 48px;
    height: 48px;
    object-fit: contain;
}

.msa-match-card__team-name {
    font-size: .8125rem;
    font-weight: 600;
    color: var(--msa-gray-800);
}

.msa-match-card__score {
    font-size: 1.5rem;
    font-weight: 800;
    color: var(--msa-gray-900);
    min-width: 80px;
}

.msa-match-card__score--fixture {
    font-size: .875rem;
    font-weight: 600;
    color: var(--msa-gray-500);
}

.msa-match-card__meta {
    grid-column: 1 / -1;
    font-size: .75rem;
    color: var(--msa-gray-500);
    border-top: 1px solid var(--msa-gray-100);
    padding-top: .5rem;
    display: flex;
    justify-content: center;
    gap: 1rem;
}

/* ===== Standings Position Colors ===== */
.msa-standings-pos--1 { border-left: 3px solid var(--msa-gold); }
.msa-standings-pos--promotion { border-left: 3px solid var(--msa-success); }
.msa-standings-pos--relegation { border-left: 3px solid var(--msa-danger); }

/* ===== Timeline ===== */
.msa-timeline {
    position: relative;
    padding: 1rem 0;
}

.msa-timeline::before {
    content: '';
    position: absolute;
    left: 50%;
    top: 0;
    bottom: 0;
    width: 2px;
    background: var(--msa-gray-200);
    transform: translateX(-50%);
}

.msa-timeline__event {
    display: flex;
    align-items: center;
    margin-bottom: .75rem;
    position: relative;
}

.msa-timeline__event--home {
    flex-direction: row;
    padding-right: 52%;
    justify-content: flex-end;
    text-align: right;
}

.msa-timeline__event--away {
    flex-direction: row-reverse;
    padding-left: 52%;
    justify-content: flex-end;
    text-align: left;
}

.msa-timeline__minute {
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    background: var(--msa-gray-100);
    padding: .125rem .5rem;
    border-radius: 999px;
    font-size: .75rem;
    font-weight: 600;
    color: var(--msa-gray-600);
    z-index: 1;
}

.msa-timeline__detail {
    font-size: .8125rem;
    padding: 0 .75rem;
}

.msa-timeline__icon {
    font-size: 1rem;
}

/* ===== Knockout Bracket ===== */
.msa-bracket {
    display: flex;
    overflow-x: auto;
    padding: 1rem 0;
    -webkit-overflow-scrolling: touch;
    align-items: stretch;
}

.msa-bracket__round {
    flex: 0 0 auto;
    display: flex;
    flex-direction: column;
}

.msa-bracket__round-title {
    font-size: .6875rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .05em;
    color: var(--msa-gray-500);
    margin-bottom: .5rem;
    text-align: center;
    white-space: nowrap;
}

.msa-bracket__round-title--final {
    color: var(--msa-gold);
}

.msa-bracket__matches {
    display: flex;
    flex-direction: column;
    justify-content: space-around;
    flex: 1;
}

.msa-bracket__match-wrapper {
    display: flex;
    align-items: center;
    flex: 1;
    justify-content: center;
    padding: 2px 0;
}

.msa-bracket__match {
    display: block;
    background: #fff;
    border: 1px solid var(--msa-gray-200);
    border-radius: 4px;
    overflow: hidden;
    text-decoration: none;
    color: inherit;
    transition: box-shadow .15s, border-color .15s;
    width: 176px;
}

.msa-bracket__match:hover {
    border-color: var(--msa-primary);
    box-shadow: 0 2px 8px rgba(0,0,0,.08);
}

/* Connector lines — left side (default) */
.msa-bracket__connector {
    flex: 0 0 24px;
    display: flex;
    flex-direction: column;
    justify-content: space-around;
    align-self: stretch;
}

.msa-bracket__connector-pair {
    flex: 1;
    position: relative;
}

.msa-bracket__connector-pair::before {
    content: '';
    position: absolute;
    right: 0;
    top: 25%;
    bottom: 25%;
    width: 1px;
    background: var(--msa-gray-300);
}

.msa-bracket__connector-pair::after {
    content: '';
    position: absolute;
    right: -12px;
    top: 50%;
    width: 12px;
    height: 1px;
    background: var(--msa-gray-300);
}

/* Connector lines — mirrored (right side) */
.msa-bracket__connector--mirrored .msa-bracket__connector-pair::before {
    right: auto;
    left: 0;
}

.msa-bracket__connector--mirrored .msa-bracket__connector-pair::after {
    right: auto;
    left: -12px;
}

/* Team row */
.msa-bracket__team {
    display: flex;
    align-items: center;
    gap: .375rem;
    padding: .375rem .5rem;
    font-size: .75rem;
    border-bottom: 1px solid var(--msa-gray-100);
}

.msa-bracket__team:last-child {
    border-bottom: none;
}

.msa-bracket__team--winner {
    background: rgba(40, 167, 69, .06);
}

.msa-bracket__team--winner .msa-bracket__name {
    font-weight: 700;
}

.msa-bracket__team--winner .msa-bracket__score {
    font-weight: 800;
}

.msa-bracket__logo {
    width: 16px;
    height: 16px;
    object-fit: contain;
    flex-shrink: 0;
}

.msa-bracket__logo--placeholder {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: var(--msa-gray-200);
    color: var(--msa-gray-600);
    font-size: .5rem;
    font-weight: 700;
    text-transform: uppercase;
    border-radius: 50%;
}

.msa-bracket__name {
    flex: 1;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    font-size: .6875rem;
}

.msa-bracket__score {
    font-weight: 600;
    min-width: .875rem;
    text-align: center;
    color: var(--msa-gray-600);
    font-size: .75rem;
}

.msa-bracket__score--winner {
    color: var(--msa-success);
}

.msa-bracket__pen {
    font-size: .5625rem;
    color: var(--msa-gray-400);
}

/* Final round center styling */
.msa-bracket__round--final {
    display: flex;
    flex-direction: column;
    justify-content: center;
    margin: 0 4px;
}

.msa-bracket__round--final .msa-bracket__match {
    width: 192px;
}

@media (max-width: 768px) {
    .msa-bracket {
        flex-direction: column;
        align-items: stretch;
    }
    .msa-bracket__round {
        min-width: 0;
    }
    .msa-bracket__match {
        width: 100%;
    }
    .msa-bracket__matches {
        gap: .375rem;
    }
    .msa-bracket__match-wrapper {
        flex: 0;
    }
    .msa-bracket__connector {
        display: none;
    }
    .msa-bracket__team--mirrored {
        flex-direction: row;
    }
    .msa-bracket__round--final {
        margin: 0;
    }
    .msa-bracket__round--final .msa-bracket__match {
        width: 100%;
    }
}

/* ===== Slot Picker ===== */
.msa-slot-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(100px, 1fr));
    gap: .5rem;
}

.msa-slot {
    padding: .5rem;
    text-align: center;
    border: 2px solid var(--msa-gray-200);
    border-radius: var(--msa-radius);
    font-size: .8125rem;
    font-weight: 600;
    cursor: pointer;
    transition: all var(--msa-transition);
}

.msa-slot:hover { border-color: var(--msa-primary); }
.msa-slot.selected { border-color: var(--msa-primary); background: rgba(242,101,34,.1); }
.msa-slot.booked { background: var(--msa-gray-100); color: var(--msa-gray-400); cursor: not-allowed; border-color: var(--msa-gray-100); }

/* ===== Voting ===== */
.msa-vote-card {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 1rem;
    border: 2px solid var(--msa-gray-200);
    border-radius: var(--msa-radius);
    cursor: pointer;
    transition: all var(--msa-transition);
}

.msa-vote-card:hover { border-color: var(--msa-primary); }
.msa-vote-card.selected { border-color: var(--msa-primary); background: rgba(242,101,34,.05); }

.msa-vote-card__photo {
    width: 60px;
    height: 60px;
    border-radius: 50%;
    object-fit: cover;
    background: var(--msa-gray-200);
}

.msa-vote-bar {
    height: 8px;
    background: var(--msa-gray-100);
    border-radius: 999px;
    overflow: hidden;
    margin-top: .5rem;
}

.msa-vote-bar__fill {
    height: 100%;
    background: var(--msa-primary);
    border-radius: 999px;
    transition: width .5s ease;
}

/* ===== Page Title Bar ===== */
.msa-page-title {
    background: var(--msa-primary);
    color: var(--msa-white);
    padding: 2rem 0;
}

.msa-page-title h1 { color: var(--msa-white); }
.msa-page-title p { color: rgba(255,255,255,.8); margin-top: .25rem; }

/* ===== Category Toggle ===== */
.msa-category-toggle {
    display: inline-flex;
    background: var(--msa-gray-100);
    border-radius: .5rem;
    padding: .25rem;
    margin-bottom: 1rem;
}
.msa-category-btn {
    padding: .5rem 1.25rem;
    font-size: .875rem;
    font-weight: 600;
    border: none;
    border-radius: .375rem;
    background: transparent;
    color: var(--msa-gray-500);
    cursor: pointer;
    transition: all .2s;
}
.msa-category-btn:hover { color: var(--msa-gray-700); }
.msa-category-btn.active {
    background: #fff;
    color: var(--msa-primary);
    box-shadow: 0 1px 3px rgba(0,0,0,.1);
}

/* ===== Tabs ===== */
.msa-tabs {
    display: flex;
    gap: .25rem;
    border-bottom: 2px solid var(--msa-gray-200);
    margin-bottom: var(--msa-gap-lg);
    overflow-x: auto;
}

.msa-tab {
    padding: .75rem 1rem;
    font-size: .875rem;
    font-weight: 600;
    color: var(--msa-gray-500);
    border: none;
    background: none;
    cursor: pointer;
    border-bottom: 2px solid transparent;
    margin-bottom: -2px;
    white-space: nowrap;
    transition: all var(--msa-transition);
}

.msa-tab:hover { color: var(--msa-gray-700); }
.msa-tab.active { color: var(--msa-primary); border-bottom-color: var(--msa-primary); }

/* ===== Alerts ===== */
.msa-alert {
    padding: .75rem 1rem;
    border-radius: var(--msa-radius);
    font-size: .875rem;
    margin-bottom: 1rem;
}

.msa-alert--info { background: #EFF6FF; color: #1E40AF; border: 1px solid #BFDBFE; }
.msa-alert--success { background: #ECFDF5; color: #065F46; border: 1px solid #A7F3D0; }
.msa-alert--warning { background: #FFFBEB; color: #92400E; border: 1px solid #FDE68A; }
.msa-alert--error { background: #FEF2F2; color: #991B1B; border: 1px solid #FECACA; }

/* ===== Loading ===== */
.msa-loading {
    display: flex;
    justify-content: center;
    padding: 2rem;
}

.msa-spinner {
    width: 32px;
    height: 32px;
    border: 3px solid var(--msa-gray-200);
    border-top-color: var(--msa-primary);
    border-radius: 50%;
    animation: msa-spin .6s linear infinite;
}

@keyframes msa-spin { to { transform: rotate(360deg); } }

/* ===== Empty State ===== */
.msa-empty {
    text-align: center;
    padding: 3rem 1rem;
    color: var(--msa-gray-500);
}

.msa-empty__icon { font-size: 2.5rem; margin-bottom: .75rem; }
.msa-empty__text { font-size: .875rem; }

/* ===== Round Groups ===== */
.msa-round-group {
    margin-bottom: 2rem;
}

.msa-round-group:last-child {
    margin-bottom: 0;
}

.msa-round-group__title {
    font-size: .875rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .04em;
    color: var(--msa-gray-500);
    padding-bottom: .5rem;
    margin-bottom: 1rem;
    border-bottom: 2px solid var(--msa-gray-200);
}

/* ===== Venue Buttons ===== */
.msa-venue-btns {
    display: flex;
    gap: .5rem;
    flex-wrap: wrap;
    margin-bottom: 1.5rem;
}

.msa-venue-btn {
    padding: .625rem 1.25rem;
    font-size: .875rem;
    font-weight: 600;
    border: 2px solid var(--msa-gray-200);
    border-radius: var(--msa-radius);
    background: var(--msa-white);
    cursor: pointer;
    transition: all var(--msa-transition);
}

.msa-venue-btn:hover { border-color: var(--msa-primary); }
.msa-venue-btn.active { border-color: var(--msa-primary); background: rgba(242,101,34,.08); color: var(--msa-primary); }

/* ===== Calendar ===== */
.msa-calendar {
    background: var(--msa-white);
    border-radius: var(--msa-radius);
    box-shadow: var(--msa-shadow);
    overflow: hidden;
}

.msa-calendar__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 1rem;
    background: var(--msa-gray-50);
    border-bottom: 1px solid var(--msa-gray-200);
}

.msa-calendar__title {
    font-size: 1rem;
    font-weight: 700;
    color: var(--msa-gray-800);
}

.msa-calendar__nav {
    background: none;
    border: 1px solid var(--msa-gray-300);
    border-radius: var(--msa-radius-sm);
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    font-size: 1rem;
    color: var(--msa-gray-600);
    transition: all var(--msa-transition);
}

.msa-calendar__nav:hover { background: var(--msa-gray-100); color: var(--msa-gray-800); }

.msa-calendar__grid {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
}

.msa-calendar__dow {
    padding: .5rem;
    text-align: center;
    font-size: .75rem;
    font-weight: 600;
    color: var(--msa-gray-500);
    text-transform: uppercase;
    border-bottom: 1px solid var(--msa-gray-100);
}

.msa-calendar__day {
    padding: .625rem .375rem;
    text-align: center;
    font-size: .8125rem;
    border: 1px solid transparent;
    cursor: pointer;
    transition: all var(--msa-transition);
    min-height: 44px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 2px;
}

.msa-calendar__day:hover { background: var(--msa-gray-50); }

.msa-calendar__day--empty {
    cursor: default;
    background: none;
}

.msa-calendar__day--past {
    color: var(--msa-gray-300);
    cursor: default;
}

.msa-calendar__day--past:hover { background: none; }

.msa-calendar__day--available .msa-calendar__dot { background: var(--msa-success); }
.msa-calendar__day--partial .msa-calendar__dot { background: var(--msa-warning); }
.msa-calendar__day--full .msa-calendar__dot { background: var(--msa-danger); }

.msa-calendar__day--selected {
    background: rgba(242,101,34,.1);
    border-color: var(--msa-primary);
    border-radius: var(--msa-radius-sm);
    font-weight: 700;
    color: var(--msa-primary);
}

.msa-calendar__dot {
    width: 6px;
    height: 6px;
    border-radius: 50%;
}

.msa-calendar__legend {
    display: flex;
    gap: 1rem;
    padding: .75rem 1rem;
    border-top: 1px solid var(--msa-gray-100);
    font-size: .75rem;
    color: var(--msa-gray-500);
}

.msa-calendar__legend-item {
    display: flex;
    align-items: center;
    gap: .375rem;
}

.msa-calendar__legend-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
}

@media (max-width: 768px) {
    .msa-calendar__day { min-height: 38px; font-size: .75rem; padding: .5rem .25rem; }
    .msa-venue-btns { flex-direction: column; }
    .msa-venue-btn { width: 100%; text-align: center; }
}

/* Book Venue two-column → stacked on mobile */
@media (max-width: 1024px) {
    .msa-book-venue-grid { grid-template-columns: 1fr !important; }
}

/* ===== Modal ===== */
.msa-modal {
    position: fixed;
    inset: 0;
    z-index: 200;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1rem;
}

.msa-modal__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(0,0,0,.5);
    backdrop-filter: blur(2px);
}

.msa-modal__content {
    position: relative;
    background: var(--msa-white);
    border-radius: var(--msa-radius-lg);
    box-shadow: var(--msa-shadow-lg);
    width: 100%;
    max-width: 560px;
    max-height: 90vh;
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

.msa-modal__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 1rem 1.25rem;
    border-bottom: 1px solid var(--msa-gray-100);
}

.msa-modal__header h3 {
    font-size: 1.125rem;
    margin: 0;
}

.msa-modal__close {
    background: none;
    border: none;
    font-size: 1.5rem;
    color: var(--msa-gray-400);
    cursor: pointer;
    padding: .25rem;
    line-height: 1;
}

.msa-modal__close:hover { color: var(--msa-gray-700); }

.msa-modal__body {
    padding: 1.25rem;
    overflow-y: auto;
    flex: 1;
}

.msa-modal__footer {
    display: flex;
    justify-content: flex-end;
    gap: .75rem;
    padding: 1rem 1.25rem;
    border-top: 1px solid var(--msa-gray-100);
}

[x-cloak] { display: none !important; }

@media (max-width: 768px) {
    .msa-modal__content { max-width: 100%; margin: 0; border-radius: var(--msa-radius); }
    .msa-modal__body { padding: 1rem; }
}

/* ===== Lineup Form ===== */
.msa-lineup-grid {
    display: flex;
    flex-direction: column;
    gap: .25rem;
}

.msa-lineup-player {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: .5rem .75rem;
    border: 1px solid var(--msa-gray-100);
    border-radius: var(--msa-radius-sm);
    cursor: default;
    transition: all var(--msa-transition);
}

.msa-lineup-player:hover { background: var(--msa-gray-50); }

.msa-lineup-player--starting {
    background: rgba(16,185,129,.08);
    border-color: var(--msa-success);
}

.msa-lineup-player--sub {
    background: rgba(59,130,246,.06);
    border-color: var(--msa-info);
}

.msa-lineup-player--unavailable {
    opacity: .5;
    cursor: not-allowed;
}

/* ===== Legends ===== */
.msa-legend-card {
    text-align: center;
}

.msa-legend-card__photo {
    width: 100px;
    height: 100px;
    border-radius: 50%;
    object-fit: cover;
    margin: 0 auto;
}

.msa-legend-card__photo--initials {
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--msa-gray-200);
    color: var(--msa-gray-600);
    font-size: 1.5rem;
    font-weight: 700;
    width: 100px;
    height: 100px;
    border-radius: 50%;
    margin: 0 auto;
}

.msa-legend-modal .msa-modal__content {
    max-width: 640px;
}

.msa-legend-modal__layout {
    display: flex;
    gap: 1.5rem;
    align-items: flex-start;
}

.msa-legend-modal__photo-col {
    flex-shrink: 0;
}

.msa-legend-modal__photo {
    width: 120px;
    height: 120px;
    border-radius: 50%;
    object-fit: cover;
}

.msa-legend-modal__details {
    flex: 1;
    min-width: 0;
}

@media (max-width: 576px) {
    .msa-legend-modal__layout {
        flex-direction: column;
        align-items: center;
        text-align: center;
    }
    .msa-legend-modal__details {
        width: 100%;
        text-align: left;
    }
}

/* ===== WordPress overrides ===== */
.wp-admin-bar-fix { margin-top: 32px; }
@media (max-width: 782px) { .wp-admin-bar-fix { margin-top: 46px; } }
