    * { box-sizing: border-box; margin: 0; padding: 0; }

    :root {
      --primary-color: #0b2545;
      --primary-dark: #001427;
      --neutral-black: #111111;
      --neutral-gray-bg: #f8f9fa;
      --neutral-border: #e9ecef;
      --neutral-text: #212529;
      --neutral-text-soft: #495057;
      --neutral-text-mute: #6c757d;
      --argentina-cyan: #75AADB;
      --argentina-bg: #eaf4fb;
      --gold: #d4a017;
      --knockout-bg: #fff8ec;
      --knockout-border: #f0d690;
      --live-red: #e0162b;
      --live-bg: #fff0f1;
    }

    body {
      font-family: 'Roboto', Arial, sans-serif;
      background: var(--neutral-gray-bg);
      color: var(--neutral-text);
      min-height: 100vh;
      padding: 30px 0 60px;
      -webkit-font-smoothing: antialiased;
    }

    .container {
      max-width: 1100px;
      margin: 0 auto;
      padding: 0 16px;
    }

    /* Header */
    .page-header {
      background: #fff;
      border-radius: 14px;
      padding: 24px 26px;
      margin-bottom: 18px;
      box-shadow: 0 2px 10px rgba(0,0,0,0.05);
    }

    .page-header h1 {
      font-family: 'Roboto Condensed', 'Roboto', Arial, sans-serif;
      font-size: 28px;
      font-weight: 900;
      color: var(--neutral-black);
      text-transform: uppercase;
      letter-spacing: 0.5px;
      line-height: 1.1;
    }

    .page-header .subtitle {
      font-size: 13px;
      color: var(--neutral-text-soft);
      margin-top: 6px;
      font-weight: 500;
    }

    .page-header .accent-bar {
      width: 56px;
      height: 4px;
      background: var(--primary-color);
      border-radius: 2px;
      margin-top: 14px;
    }

    /* Status line (live / last updated) */
    .status-line {
      display: flex;
      align-items: center;
      flex-wrap: wrap;
      gap: 8px 14px;
      margin-top: 12px;
      font-size: 12px;
      font-weight: 700;
      color: var(--neutral-text-mute);
    }

    .status-pill {
      display: inline-flex;
      align-items: center;
      gap: 6px;
      padding: 4px 10px;
      border-radius: 999px;
      background: var(--neutral-gray-bg);
      letter-spacing: 0.4px;
    }

    .status-pill.is-live {
      background: var(--live-bg);
      color: var(--live-red);
    }

    .status-pill .dot {
      width: 8px;
      height: 8px;
      border-radius: 50%;
      background: currentColor;
      flex-shrink: 0;
    }

    .status-pill.is-live .dot {
      animation: pulse 1.3s ease-in-out infinite;
    }

    @keyframes pulse {
      0%, 100% { opacity: 1; transform: scale(1); }
      50% { opacity: 0.35; transform: scale(0.7); }
    }

    .status-updated { font-weight: 500; }

    /* Filters */
    .filter-bar {
      background: #fff;
      border-radius: 14px;
      padding: 14px 16px;
      margin-bottom: 16px;
      box-shadow: 0 2px 10px rgba(0,0,0,0.05);
      position: sticky;
      top: 12px;
      z-index: 50;
    }

    .filter-label {
      font-size: 11px;
      font-weight: 700;
      color: var(--neutral-text-mute);
      text-transform: uppercase;
      letter-spacing: 0.6px;
      margin-bottom: 8px;
      padding: 0 4px;
    }

    .filter-chips {
      display: flex;
      flex-wrap: wrap;
      gap: 6px;
    }

    .chip {
      border: 1px solid var(--neutral-border);
      background: #fff;
      color: var(--neutral-text);
      padding: 6px 12px;
      border-radius: 999px;
      font-size: 12.5px;
      font-weight: 700;
      cursor: pointer;
      transition: all 0.18s ease;
      font-family: inherit;
      letter-spacing: 0.2px;
      white-space: nowrap;
    }

    .chip:hover {
      border-color: var(--primary-color);
      color: var(--primary-color);
    }

    .chip.active {
      background: var(--primary-color);
      border-color: var(--primary-color);
      color: #fff;
    }

    .chip.chip-arg {
      border-color: var(--argentina-cyan);
      color: var(--primary-dark);
    }

    .chip.chip-arg.active {
      background: var(--argentina-cyan);
      border-color: var(--argentina-cyan);
      color: #fff;
    }

    .chip.chip-today {
      border-color: var(--primary-color);
      color: var(--primary-dark);
    }

    .chip.chip-today.active {
      background: var(--primary-dark);
      border-color: var(--primary-dark);
      color: #fff;
    }

    .chip.chip-ko {
      border-color: var(--gold);
      color: #8b6914;
    }

    .chip.chip-ko.active {
      background: var(--gold);
      border-color: var(--gold);
      color: #fff;
    }

    /* Day section */
    .day-section {
      margin-bottom: 24px;
      scroll-margin-top: 90px;
    }

    .calendar.animate .day-section {
      animation: fadeIn 0.35s ease;
    }

    @keyframes fadeIn {
      from { opacity: 0; transform: translateY(8px); }
      to { opacity: 1; transform: translateY(0); }
    }

    .day-header {
      display: flex;
      align-items: baseline;
      gap: 14px;
      padding: 0 8px 12px;
      border-bottom: 2px solid var(--neutral-border);
      margin-bottom: 14px;
    }

    .day-section.is-today .day-header {
      border-bottom-color: var(--primary-color);
    }

    .day-weekday {
      font-family: 'Roboto Condensed', 'Roboto', Arial, sans-serif;
      font-size: 13px;
      font-weight: 900;
      color: var(--primary-color);
      text-transform: uppercase;
      letter-spacing: 0.8px;
    }

    .day-date {
      font-family: 'Roboto Condensed', 'Roboto', Arial, sans-serif;
      font-size: 22px;
      font-weight: 900;
      color: var(--neutral-black);
      text-transform: uppercase;
    }

    .today-tag {
      background: var(--primary-color);
      color: #fff;
      font-size: 10.5px;
      font-weight: 900;
      letter-spacing: 0.6px;
      padding: 3px 9px;
      border-radius: 999px;
      text-transform: uppercase;
    }

    .day-count {
      margin-left: auto;
      font-size: 12px;
      color: var(--neutral-text-mute);
      font-weight: 500;
    }

    /* Match cards grid */
    .match-grid {
      display: grid;
      grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
      gap: 12px;
    }

    .match-card {
      background: #fff;
      border: 1px solid var(--neutral-border);
      border-radius: 12px;
      padding: 14px 14px 12px;
      transition: all 0.18s ease;
      display: flex;
      flex-direction: column;
      gap: 10px;
      position: relative;
    }

    .match-card:hover {
      border-color: var(--primary-color);
      box-shadow: 0 3px 14px rgba(11,37,69,0.10);
      transform: translateY(-1px);
    }

    .match-card.is-argentina {
      border: 1.5px solid var(--argentina-cyan);
      background: linear-gradient(180deg, var(--argentina-bg) 0%, #fff 50%);
    }

    .match-card.is-argentina:hover {
      box-shadow: 0 3px 14px rgba(117,170,219,0.25);
    }

    .match-card.is-knockout {
      background: linear-gradient(180deg, var(--knockout-bg) 0%, #fff 60%);
      border-color: var(--knockout-border);
    }

    .match-card.is-final {
      border: 2px solid var(--gold);
      background: linear-gradient(180deg, #fff5d6 0%, #fff 60%);
    }

    .match-card.is-live {
      border: 1.5px solid var(--live-red);
      box-shadow: 0 0 0 3px rgba(224,22,43,0.08);
    }

    .match-meta {
      display: flex;
      align-items: center;
      justify-content: space-between;
      font-size: 11.5px;
      font-weight: 700;
      color: var(--neutral-text-mute);
      text-transform: uppercase;
      letter-spacing: 0.5px;
    }

    .stage-badge {
      background: var(--neutral-gray-bg);
      color: var(--neutral-text);
      padding: 3px 9px;
      border-radius: 999px;
      font-size: 10.5px;
      font-weight: 900;
      letter-spacing: 0.5px;
    }

    .match-card.is-knockout .stage-badge,
    .match-card.is-final .stage-badge {
      background: var(--gold);
      color: #fff;
    }

    /* Right-side status indicator */
    .match-status {
      font-variant-numeric: tabular-nums;
      color: var(--neutral-black);
      display: inline-flex;
      align-items: center;
      gap: 5px;
    }

    .match-status small {
      color: var(--neutral-text-mute);
      font-weight: 500;
      margin-left: 4px;
      font-size: 10px;
    }

    .match-status.status-live {
      color: var(--live-red);
      font-weight: 900;
    }

    .match-status.status-live .dot {
      width: 7px;
      height: 7px;
      border-radius: 50%;
      background: var(--live-red);
      animation: pulse 1.3s ease-in-out infinite;
    }

    .match-status.status-finished {
      color: var(--neutral-text-mute);
    }

    .teams {
      display: grid;
      grid-template-columns: 1fr auto 1fr;
      align-items: center;
      gap: 8px;
    }

    .team {
      display: flex;
      align-items: center;
      gap: 9px;
      min-width: 0;
    }

    .team.away {
      flex-direction: row-reverse;
      text-align: right;
    }

    .flag {
      width: 28px;
      height: 28px;
      border-radius: 50%;
      overflow: hidden;
      flex-shrink: 0;
      background: #eee;
      border: 1px solid var(--neutral-border);
      display: flex;
      align-items: center;
      justify-content: center;
    }

    .flag img {
      width: 100%;
      height: 100%;
      object-fit: cover;
    }

    .team-name {
      font-family: 'Roboto Condensed', 'Roboto', Arial, sans-serif;
      font-size: 14px;
      font-weight: 900;
      color: var(--neutral-text);
      text-transform: uppercase;
      line-height: 1.15;
      overflow: hidden;
      text-overflow: ellipsis;
      white-space: nowrap;
    }

    .team.is-winner .team-name { color: var(--neutral-black); }
    .team.is-loser .team-name { color: var(--neutral-text-mute); opacity: 0.7; }

    .team.placeholder .team-name {
      color: var(--neutral-text-mute);
      font-weight: 700;
      font-size: 12.5px;
    }

    .team.placeholder .flag {
      background: #e9ecf1;
      color: var(--neutral-text-mute);
      font-size: 11px;
      font-weight: 900;
    }

    .vs {
      font-family: 'Roboto Condensed', 'Roboto', Arial, sans-serif;
      font-size: 12px;
      font-weight: 900;
      color: var(--neutral-text-mute);
      padding: 0 4px;
      letter-spacing: 0.5px;
    }

    /* Score (live / finished) */
    .score {
      font-family: 'Roboto Condensed', 'Roboto', Arial, sans-serif;
      font-weight: 900;
      font-size: 22px;
      color: var(--neutral-black);
      letter-spacing: 1px;
      text-align: center;
      line-height: 1;
      font-variant-numeric: tabular-nums;
      white-space: nowrap;
    }

    .match-card.is-live .score { color: var(--live-red); }

    .score .pens {
      display: block;
      font-family: 'Roboto', Arial, sans-serif;
      font-size: 9.5px;
      font-weight: 700;
      color: var(--neutral-text-mute);
      letter-spacing: 0.2px;
      margin-top: 3px;
    }

    .venue {
      display: flex;
      align-items: center;
      gap: 6px;
      font-size: 11.5px;
      color: var(--neutral-text-soft);
      font-weight: 500;
      border-top: 1px dashed var(--neutral-border);
      padding-top: 9px;
    }

    .venue-icon {
      flex-shrink: 0;
      color: var(--primary-color);
      display: inline-flex;
    }

    /* Iconos SVG (set Lucide, en línea) */
    .ic-svg {
      width: 1em;
      height: 1em;
      display: inline-block;
      vertical-align: -0.125em;
      flex-shrink: 0;
    }

    .venue-icon .ic-svg { width: 14px; height: 14px; }
    .day-nav-btn .ic-svg { width: 22px; height: 22px; }
    .modal-close .ic-svg { width: 18px; height: 18px; }
    .modal-meta .ic .ic-svg { width: 15px; height: 15px; }
    .match-status.status-live .ic-svg,
    .status-pill .ic-svg { width: 12px; height: 12px; }

    .venue-text {
      overflow: hidden;
      text-overflow: ellipsis;
      white-space: nowrap;
    }

    /* Empty / error / loading states */
    .empty-state {
      background: #fff;
      border-radius: 14px;
      padding: 60px 30px;
      text-align: center;
      color: var(--neutral-text-mute);
    }

    .empty-state h3 {
      font-size: 16px;
      font-weight: 700;
      margin-bottom: 6px;
      color: var(--neutral-text-soft);
    }

    .empty-state p { font-size: 13px; }

    .retry-btn {
      margin-top: 16px;
      border: 1px solid var(--primary-color);
      background: var(--primary-color);
      color: #fff;
      padding: 9px 20px;
      border-radius: 999px;
      font-size: 13px;
      font-weight: 700;
      cursor: pointer;
      font-family: inherit;
      transition: all 0.18s ease;
    }

    .retry-btn:hover { background: var(--primary-dark); border-color: var(--primary-dark); }

    /* Skeleton loader */
    .skeleton-day { margin-bottom: 24px; }
    .skeleton-head {
      height: 26px; width: 220px; border-radius: 6px; margin-bottom: 16px;
      background: linear-gradient(90deg, #ececec 25%, #f5f5f5 50%, #ececec 75%);
      background-size: 200% 100%;
      animation: shimmer 1.3s infinite;
    }
    .skeleton-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)); gap: 12px; }
    .skeleton-card {
      height: 132px; border-radius: 12px;
      background: linear-gradient(90deg, #ececec 25%, #f5f5f5 50%, #ececec 75%);
      background-size: 200% 100%;
      animation: shimmer 1.3s infinite;
    }
    @keyframes shimmer {
      0% { background-position: 200% 0; }
      100% { background-position: -200% 0; }
    }

    /* Navegador de días */
    .day-nav {
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 12px;
      background: #fff;
      border-radius: 12px;
      padding: 10px 14px;
      margin-bottom: 16px;
      box-shadow: 0 2px 10px rgba(0,0,0,0.05);
    }

    .day-nav-btn {
      width: 38px;
      height: 38px;
      border-radius: 50%;
      border: 1px solid var(--neutral-border);
      background: #fff;
      color: #555;
      cursor: pointer;
      font-size: 18px;
      line-height: 1;
      display: flex;
      align-items: center;
      justify-content: center;
      transition: all 0.18s ease;
      flex-shrink: 0;
    }

    .day-nav-btn:hover:not(:disabled) {
      background: var(--primary-color);
      border-color: var(--primary-color);
      color: #fff;
    }

    .day-nav-btn:disabled { opacity: 0.35; cursor: not-allowed; }

    .day-nav-label {
      font-family: 'Roboto Condensed', 'Roboto', Arial, sans-serif;
      font-weight: 900;
      text-transform: uppercase;
      letter-spacing: 0.5px;
      font-size: 15px;
      color: var(--neutral-black);
      min-width: 210px;
      text-align: center;
    }

    .day-nav-label small {
      display: block;
      font-family: 'Roboto', Arial, sans-serif;
      font-weight: 700;
      font-size: 10.5px;
      color: var(--neutral-text-mute);
      letter-spacing: 0.3px;
      text-transform: none;
      margin-top: 2px;
    }

    .day-nav.is-inactive .day-nav-label { color: var(--neutral-text-mute); }

    .day-nav-clear {
      background: none;
      border: none;
      color: var(--primary-color);
      font-weight: 700;
      font-size: 12px;
      cursor: pointer;
      font-family: inherit;
      text-decoration: underline;
      flex-shrink: 0;
    }

    .match-card { cursor: pointer; }

    /* Modal de detalle de partido */
    .modal-overlay {
      position: fixed;
      inset: 0;
      background: rgba(0,0,0,0.5);
      display: flex;
      align-items: center;
      justify-content: center;
      padding: 20px;
      z-index: 200;
      animation: fadeIn 0.2s ease;
    }

    .modal-overlay[hidden] { display: none; }

    .modal {
      background: #fff;
      border-radius: 16px;
      width: 100%;
      max-width: 440px;
      box-shadow: 0 20px 60px rgba(0,0,0,0.3);
      overflow: hidden;
      position: relative;
    }

    .modal.is-live { box-shadow: 0 20px 60px rgba(224,22,43,0.3); }

    .modal-close {
      position: absolute;
      top: 12px;
      right: 12px;
      width: 32px;
      height: 32px;
      border-radius: 50%;
      border: none;
      background: rgba(0,0,0,0.06);
      color: #333;
      cursor: pointer;
      font-size: 16px;
      line-height: 1;
      z-index: 2;
    }

    .modal-close:hover { background: rgba(0,0,0,0.12); }

    .modal-head {
      padding: 20px 20px 14px;
      text-align: center;
      border-bottom: 1px solid var(--neutral-border);
    }

    .modal-when {
      margin-top: 10px;
      font-size: 12.5px;
      font-weight: 700;
      color: var(--neutral-text-soft);
    }

    .modal-teams {
      display: grid;
      grid-template-columns: 1fr auto 1fr;
      align-items: start;
      gap: 12px;
      padding: 22px 20px;
    }

    .modal-team {
      display: flex;
      flex-direction: column;
      align-items: center;
      gap: 9px;
      text-align: center;
      min-width: 0;
    }

    .modal-team .flag { width: 48px; height: 48px; }

    .modal-team .team-name {
      font-size: 15px;
      white-space: normal;
      overflow: visible;
    }

    .modal-team.placeholder .flag { background: #e9ecf1; color: var(--neutral-text-mute); }
    .modal-team.placeholder .team-name { color: var(--neutral-text-mute); font-weight: 700; font-size: 13px; }

    .modal-score {
      font-family: 'Roboto Condensed', 'Roboto', Arial, sans-serif;
      font-weight: 900;
      font-size: 34px;
      color: var(--neutral-black);
      font-variant-numeric: tabular-nums;
      line-height: 1;
      align-self: center;
      text-align: center;
      white-space: nowrap;
    }

    .modal.is-live .modal-score { color: var(--live-red); }
    .modal-score.modal-vs { font-size: 18px; color: var(--neutral-text-mute); }

    .modal-score small {
      display: block;
      font-family: 'Roboto', Arial, sans-serif;
      font-size: 10px;
      font-weight: 700;
      color: var(--neutral-text-mute);
      margin-top: 4px;
    }

    .modal-meta {
      padding: 0 20px 18px;
      display: flex;
      flex-direction: column;
      gap: 9px;
      font-size: 13px;
      color: var(--neutral-text-soft);
      font-weight: 500;
    }

    .modal-meta .row { display: flex; align-items: center; gap: 9px; }
    .modal-meta .ic { color: var(--primary-color); width: 16px; text-align: center; flex-shrink: 0; }

    .map-link { color: var(--primary-color); font-weight: 700; text-decoration: none; white-space: nowrap; }
    .map-link:hover { text-decoration: underline; }

    /* Badge del modo simulación */
    .demo-badge {
      position: fixed; top: 10px; right: 10px; z-index: 300;
      background: var(--gold); color: #fff; font-size: 11px; font-weight: 900;
      padding: 6px 12px; border-radius: 999px; letter-spacing: 0.5px;
      box-shadow: 0 2px 8px rgba(0,0,0,0.2); text-transform: uppercase;
    }

    /* Tabla de posiciones */
    .standings-grid {
      display: grid;
      grid-template-columns: repeat(auto-fill, minmax(330px, 1fr));
      gap: 14px;
    }

    .standings-card {
      background: #fff;
      border: 1px solid var(--neutral-border);
      border-radius: 12px;
      overflow: hidden;
    }

    .standings-card h3 {
      font-family: 'Roboto Condensed', 'Roboto', Arial, sans-serif;
      font-size: 14px;
      font-weight: 900;
      text-transform: uppercase;
      letter-spacing: 0.5px;
      padding: 12px 14px;
      border-bottom: 2px solid var(--neutral-border);
      color: var(--neutral-black);
    }

    .standings-table { width: 100%; border-collapse: collapse; font-size: 12.5px; }
    .standings-table th {
      font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.3px;
      color: var(--neutral-text-mute); padding: 7px 4px; text-align: center;
      border-bottom: 1px solid var(--neutral-border);
    }
    .standings-table th.team-col, .standings-table td.team-col { text-align: left; padding-left: 12px; }
    .standings-table td {
      padding: 8px 4px; text-align: center; border-bottom: 1px solid #f0f0f0;
      font-variant-numeric: tabular-nums;
    }
    .standings-table tr:last-child td { border-bottom: none; }
    .standings-table .pos { font-weight: 900; color: var(--neutral-text-mute); width: 22px; }
    .standings-table .pts { font-weight: 900; color: var(--neutral-black); }
    .standings-table .st-team { display: flex; align-items: center; gap: 8px; min-width: 0; }
    .standings-table .st-team .flag { width: 22px; height: 22px; }
    .standings-table .st-team .nm {
      font-weight: 700; text-transform: uppercase; font-size: 12px;
      overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
    }
    .standings-table tr.qualifies { background: rgba(46,158,91,0.06); }
    .standings-table tr.qualifies .pos { color: #2e9e5b; }
    .standings-table tr.is-arg .nm { color: var(--primary-color); }
    .standings-legend {
      margin-top: 14px; font-size: 11.5px; color: var(--neutral-text-mute);
      display: flex; align-items: center; gap: 7px; justify-content: center;
    }
    .standings-legend .dotq { width: 11px; height: 11px; border-radius: 3px; background: #2e9e5b; display: inline-block; }

    /* Pestañas modal */
    .modal-tabs { display: flex; border-top: 1px solid var(--neutral-border); border-bottom: 1px solid var(--neutral-border); }
    .modal-tab {
      flex: 1; background: none; border: none; padding: 11px 8px;
      font-family: inherit; font-weight: 700; font-size: 12.5px; color: var(--neutral-text-mute);
      cursor: pointer; border-bottom: 2px solid transparent; transition: all 0.15s ease;
    }
    .modal-tab:hover { color: var(--neutral-text); }
    .modal-tab.active { color: var(--primary-color); border-bottom-color: var(--primary-color); }
    .modal-extra { max-height: 300px; overflow-y: auto; padding: 14px 20px 18px; }
    .extra-empty { text-align: center; color: var(--neutral-text-mute); font-size: 12.5px; padding: 18px 0; }

    /* Minuto a minuto (timeline) */
    .ev { display: flex; align-items: flex-start; gap: 10px; padding: 7px 0; font-size: 12.5px; }
    .ev + .ev { border-top: 1px dashed var(--neutral-border); }
    .ev-min { font-weight: 900; font-variant-numeric: tabular-nums; color: var(--neutral-text-mute); min-width: 42px; font-size: 12px; }
    .ev-ic { flex-shrink: 0; color: var(--neutral-text-soft); display: inline-flex; padding-top: 1px; }
    .ev-ic.goal { color: #111; }
    .ev-card { width: 11px; height: 15px; border-radius: 2px; flex-shrink: 0; margin-top: 1px; }
    .ev-card.y { background: #f4c20d; }
    .ev-card.r { background: var(--live-red); }
    .ev-desc { color: var(--neutral-text); line-height: 1.35; }
    .ev.goal .ev-desc { font-weight: 700; }
    .ev-score { font-weight: 900; color: var(--primary-color); margin-left: 4px; }

    /* Formaciones */
    .lineups { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
    .lineup h4 {
      font-size: 12px; font-weight: 900; text-transform: uppercase; letter-spacing: 0.4px;
      margin-bottom: 4px; display: flex; align-items: center; gap: 7px;
    }
    .lineup h4 .flag { width: 20px; height: 20px; }
    .lineup .formation { font-size: 11px; font-weight: 700; color: var(--neutral-text-mute); margin-bottom: 8px; }
    .lineup ul { list-style: none; display: flex; flex-direction: column; gap: 4px; }
    .lineup li { display: flex; align-items: center; gap: 7px; font-size: 12px; }
    .lineup .num { font-weight: 900; color: var(--neutral-text-mute); min-width: 18px; font-variant-numeric: tabular-nums; font-size: 11.5px; }
    .lineup .pn { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
    .lineup .cap { font-size: 9px; font-weight: 900; color: var(--gold); border: 1px solid var(--gold); border-radius: 3px; padding: 0 3px; }
    .lineup .subhead { font-size: 10px; font-weight: 700; text-transform: uppercase; color: var(--neutral-text-mute); margin: 10px 0 4px; letter-spacing: 0.3px; }
    .lineup .coach { font-size: 11.5px; color: var(--neutral-text-soft); margin-top: 10px; }
    @media (max-width: 480px) { .lineups { grid-template-columns: 1fr; } }

    /* Footer note */
    .footer-note {
      margin-top: 24px;
      text-align: center;
      font-size: 11.5px;
      color: var(--neutral-text-mute);
      line-height: 1.5;
    }

    /* Responsive */
    @media (max-width: 768px) {
      body { padding: 14px 0 40px; }
      .container { padding: 0 12px; }
      .page-header { padding: 18px 18px; border-radius: 12px; }
      .page-header h1 { font-size: 22px; }
      .filter-bar { padding: 12px 12px; border-radius: 12px; top: 8px; }
      .day-date { font-size: 19px; }
      .day-weekday { font-size: 12px; }
      .match-grid { grid-template-columns: 1fr; gap: 10px; }
      .match-card { padding: 12px 12px 10px; }
      .team-name { font-size: 13px; }
      .flag { width: 26px; height: 26px; }
      .score { font-size: 20px; }
    }

    @media (max-width: 420px) {
      .page-header h1 { font-size: 19px; }
      .filter-chips { gap: 5px; }
      .chip { padding: 5px 10px; font-size: 11.5px; }
      .team-name { font-size: 12.5px; }
      .stage-badge { font-size: 10px; padding: 2px 7px; }
      .day-nav { gap: 8px; padding: 8px 10px; flex-wrap: wrap; }
      .day-nav-label { min-width: 0; flex: 1; font-size: 13.5px; }
      .day-nav-clear { width: 100%; text-align: center; order: 3; }
    }

    /* Reduced motion */
    @media (prefers-reduced-motion: reduce) {
      .calendar.animate .day-section { animation: none; }
      .match-card:hover { transform: none; }
      .status-pill.is-live .dot,
      .match-status.status-live .dot,
      .skeleton-head, .skeleton-card { animation: none; }
    }