﻿:root{
  --bg:#f0ede8;--surface:#fff;--surface2:#f7f4f0;--border:#e2ddd6;
  --text-primary:#1a1714;--text-secondary:#6b6560;--text-muted:#9e9890;
  --accent:#c8393a;--accent-light:#fde8e8;
  --gold:#c9942a;--gold-light:#fef3d8;
  --green:#2a7a4b;--green-light:#e0f4ea;
  --blue:#1e4d8c;--blue-light:#dde9f9;
  --orange:#d4621e;--orange-light:#feeee4;
  --shadow-sm:0 1px 3px rgba(0,0,0,.08);--shadow-md:0 4px 16px rgba(0,0,0,.10);--shadow-lg:0 8px 32px rgba(0,0,0,.12);
  --radius:12px;--radius-sm:6px;
  --font-display:'Bebas Neue',sans-serif;--font-body:'DM Sans',sans-serif;--font-mono:'DM Mono',monospace;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
body{font-family:var(--font-body);background:var(--bg);color:var(--text-primary);min-height:100vh;font-size:14px;line-height:1.5}

/* HEADER */
header{background:var(--text-primary);color:#fff;padding:20px 40px 16px;border-bottom:3px solid var(--accent)}
.header-inner{max-width:1700px;margin:0 auto;display:flex;align-items:center;gap:20px;flex-wrap:wrap}
.header-title{font-family:var(--font-display);font-size:2.2rem;letter-spacing:.04em;line-height:1;color:#fff}
.header-title span{color:var(--accent)}
.header-sub{font-size:11px;color:rgba(255,255,255,.55);margin-top:3px}
.header-actions{margin-left:auto;display:flex;gap:6px;flex-wrap:wrap}

/* NAV */
nav{background:var(--surface);border-bottom:1px solid var(--border);padding:0 40px;position:sticky;top:0;z-index:100;box-shadow:var(--shadow-sm)}
.nav-tabs{max-width:1700px;margin:0 auto;display:flex;gap:0;overflow-x:auto}
.nav-tab{padding:12px 22px;background:none;border:none;border-bottom:3px solid transparent;cursor:pointer;font-family:var(--font-body);font-size:12px;font-weight:600;color:var(--text-secondary);letter-spacing:.02em;text-transform:uppercase;transition:all .2s;white-space:nowrap}
.nav-tab:hover{color:var(--text-primary)}
.nav-tab.active{color:var(--accent);border-bottom-color:var(--accent)}

/* MAIN */
main{max-width:1700px;margin:0 auto;padding:28px 40px}
.tab-panel{display:none}.tab-panel.active{display:block}

/* BUTTONS */
.btn{padding:8px 16px;border-radius:var(--radius-sm);border:none;cursor:pointer;font-family:var(--font-body);font-size:11px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;transition:all .15s;display:inline-flex;align-items:center;gap:5px;white-space:nowrap}
.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:#a82c2d}
.btn-secondary{background:var(--surface);color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover{background:var(--surface2)}
.btn-ghost{background:rgba(255,255,255,.12);color:#fff;border:1px solid rgba(255,255,255,.2)}.btn-ghost:hover{background:rgba(255,255,255,.2)}
.btn-success{background:var(--green);color:#fff}.btn-success:hover{background:#1e6040}
.btn-warning{background:var(--gold);color:#fff}.btn-warning:hover{background:#a87a22}
.btn-danger{background:#c0392b;color:#fff}.btn-danger:hover{background:#922b21}
.btn-orange{background:var(--orange);color:#fff}.btn-orange:hover{background:#b5531a}
.btn-sm{padding:5px 10px;font-size:10px}
.btn-xs{padding:3px 8px;font-size:10px}

/* BADGES */
.badge{display:inline-block;padding:2px 7px;border-radius:20px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.04em}
.badge-green{background:var(--green-light);color:var(--green)}
.badge-gold{background:var(--gold-light);color:var(--gold)}
.badge-blue{background:var(--blue-light);color:var(--blue)}
.badge-red{background:var(--accent-light);color:var(--accent)}
.badge-gray{background:var(--surface2);color:var(--text-muted)}
.badge-orange{background:var(--orange-light);color:var(--orange)}

/* PAGE HEADER */
.page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:20px;flex-wrap:wrap;gap:10px}
.page-header-actions{display:flex;gap:6px;flex-wrap:wrap;align-items:center}
.section-title{font-family:var(--font-display);font-size:1.5rem;letter-spacing:.05em;margin-bottom:4px}
.section-sub{font-size:12px;color:var(--text-secondary);margin-bottom:20px}

/* LEGEND */
.legend{display:flex;gap:14px;flex-wrap:wrap;font-size:11px;color:var(--text-secondary)}
.legend-item{display:flex;align-items:center;gap:5px}
.legend-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0}

/* FLAG */
.flag-img{display:inline-block;vertical-align:middle;border-radius:1px;flex-shrink:0;object-fit:cover}
.flag-fallback{display:inline-block;width:20px;height:14px;background:var(--border);border-radius:1px;vertical-align:middle;flex-shrink:0}

/* GROUPS GRID */
.groups-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(460px,1fr));gap:20px}
.group-card{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden;border:1px solid var(--border)}
.group-header{background:var(--text-primary);color:#fff;padding:12px 18px;display:flex;align-items:center;justify-content:space-between}
.group-title{font-family:var(--font-display);font-size:1.3rem;letter-spacing:.06em}

/* STANDINGS TABLE */
.standings-table{width:100%;border-collapse:collapse;font-size:12px}
.standings-table th{background:var(--surface2);padding:7px 9px;text-align:center;font-size:10px;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);font-weight:600;border-bottom:1px solid var(--border)}
.standings-table th:nth-child(2){text-align:left}
.standings-table td{padding:8px 9px;text-align:center;border-bottom:1px solid var(--border);font-variant-numeric:tabular-nums}
.standings-table td:nth-child(2){text-align:left;font-weight:600}
.standings-table td:last-child{font-weight:700;font-size:13px}
.standings-table tr.q1{background:var(--green-light)}
.standings-table tr.q2{background:var(--blue-light)}
.standings-table tr.q3-maybe{background:var(--gold-light)}
.standings-table tr:last-child td{border-bottom:none}
.team-cell{display:flex;align-items:center;gap:7px}
.sg-pos{color:var(--green);font-weight:700}
.sg-neg{color:var(--accent);font-weight:700}

/* MATCHES SECTION */
.matches-section{padding:14px 18px 18px;border-top:1px solid var(--border);background:var(--surface2)}
.matches-section-title{font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);font-weight:600;margin-bottom:10px}
.match-row{display:flex;align-items:center;gap:7px;margin-bottom:7px;background:var(--surface);border-radius:var(--radius-sm);padding:7px 11px;border:1px solid var(--border);font-size:12px}
.match-row.completed{border-color:#c8e6da}
.match-row.pending{opacity:.8}
.match-row.confirmed-real{border-color:var(--green);background:rgba(34,197,94,.05)}
.match-team{flex:1;min-width:0;font-weight:600;display:flex;align-items:center;gap:5px}
.match-team>span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}
.match-team.right{text-align:right;flex-direction:row-reverse}
.match-info{font-size:10px;color:var(--text-muted);margin-bottom:2px;text-align:center}
.score-wrap{display:flex;align-items:center;gap:5px;flex-shrink:0}
.match-id-label{font-size:10px;color:var(--text-muted);flex-shrink:0;min-width:58px;text-align:right}
.match-mc-btn{padding:4px 7px;border:1px solid var(--blue);border-radius:4px;background:var(--blue-light);color:var(--blue);font-size:9px;font-weight:700;cursor:pointer;line-height:1.2}
.match-mc-btn:hover{background:var(--blue);color:#fff}
.real-score-badge{flex-shrink:0;font-size:12px;line-height:1.2;cursor:default}
.score-input{width:36px;height:28px;border:1px solid var(--border);border-radius:4px;text-align:center;font-family:var(--font-mono);font-size:13px;font-weight:600;color:var(--text-primary);background:#fff;transition:border-color .15s}
.score-input:focus{outline:none;border-color:var(--accent)}
.score-input.filled{border-color:var(--green);background:#f2fff8}
.score-sep{font-size:13px;font-weight:700;color:var(--text-muted)}

/* GENERAL CLASSIFICATION TABLE */
.classif-table-wrap{overflow-x:auto}
.classif-table{width:100%;border-collapse:collapse;font-size:12px;min-width:900px}
.classif-table th{background:var(--text-primary);color:#fff;padding:8px 10px;text-align:center;font-size:10px;text-transform:uppercase;letter-spacing:.06em;font-weight:600;white-space:nowrap;position:sticky;top:0}
.classif-table th:nth-child(2){text-align:left}
.classif-table td{padding:8px 10px;text-align:center;border-bottom:1px solid var(--border);vertical-align:middle;font-variant-numeric:tabular-nums}
.classif-table td:nth-child(2){text-align:left;font-weight:600}
.classif-table tr.classif-1{background:var(--green-light)}
.classif-table tr.classif-2{background:var(--blue-light)}
.classif-table tr.classif-t3{background:var(--gold-light)}
.classif-table tr.classif-elim{opacity:.65}
.classif-table tr:hover{filter:brightness(.97)}
.filter-bar{display:flex;gap:6px;margin-bottom:14px;flex-wrap:wrap}

/* THIRDS TABLE */
.thirds-table{width:100%;border-collapse:collapse;font-size:12px}
.thirds-table th{background:var(--surface2);padding:7px 10px;text-align:center;font-size:10px;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);font-weight:600;border-bottom:1px solid var(--border)}
.thirds-table th:nth-child(3){text-align:left}
.thirds-table td{padding:8px 10px;text-align:center;border-bottom:1px solid var(--border)}
.thirds-table td:nth-child(3){text-align:left;font-weight:600}
.thirds-table tr.qualified-third{background:var(--gold-light)}
.thirds-table tr.elim-third{opacity:.55}
.drag-handle{cursor:grab;color:var(--text-muted);font-size:14px;padding:0 3px;user-select:none}
.drag-handle:active{cursor:grabbing}
.thirds-table tr.dragging{opacity:.4}
.thirds-table tr.drag-over{outline:2px solid var(--accent)}

/* BRACKET */
.bracket-outer{overflow-x:auto;background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow-md);padding:16px 6px}
.bracket-cols{display:flex;align-items:stretch;gap:0;min-width:1200px;min-height:600px}
.bracket-col{display:flex;flex-direction:column;justify-content:space-around;gap:6px;flex:1;min-width:155px;padding:0 3px}
.bracket-col-label{font-size:10px;text-transform:uppercase;letter-spacing:.08em;font-weight:700;color:var(--text-muted);text-align:center;padding:4px 0 8px;border-bottom:2px solid var(--border);margin-bottom:6px}
.bracket-col-label.center-lbl{color:var(--gold);border-color:var(--gold)}
.bm{background:var(--surface);border:1.5px solid var(--border);border-radius:7px;overflow:hidden;cursor:pointer;transition:box-shadow .15s,border-color .15s,transform .1s;margin:2px 0;position:relative}
.bm:hover{box-shadow:0 4px 18px rgba(0,0,0,.12);border-color:var(--accent);transform:translateY(-1px)}
.bm.has-winner{border-left:3px solid var(--green)}
.bm.is-final{border:2px solid var(--gold);box-shadow:0 4px 20px rgba(201,148,42,.2)}
.bm.t3-match{border-left:3px solid var(--orange)}
.bm.tbd-match{opacity:.7}
.bm-label{background:var(--text-primary);padding:2px 7px;font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:rgba(255,255,255,.6);display:flex;justify-content:space-between}
.bm-label.lbl-final{background:var(--gold);color:#fff}
.bm-label.lbl-t3{background:var(--orange);color:#fff}
.bm-team{display:flex;align-items:center;gap:5px;padding:5px 7px;font-size:11px;font-weight:500;border-bottom:1px solid var(--border);min-height:28px;transition:background .1s}
.bm-team:last-child{border-bottom:none}
.bm-team.winner{background:var(--green-light);font-weight:700}
.bm-team.loser{opacity:.42}
.bm-team.tbd{color:var(--text-muted);font-style:italic;font-weight:400;font-size:10px}
.bm-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;letter-spacing:-.01em}
.bm-score-wrap{display:flex;align-items:baseline;gap:2px;flex-shrink:0;justify-content:flex-end}
.bm-score{font-family:var(--font-mono);font-weight:700;font-size:13px;color:var(--text-secondary);line-height:1}
.bm-team.winner .bm-score{color:var(--green)}
.bm-pen-score{font-family:var(--font-mono);font-size:10px;font-weight:700;color:var(--accent);line-height:1}
.bm-team.winner .bm-pen-score{color:var(--green)}
.bm-team.loser .bm-pen-score{color:var(--text-muted)}
.bracket-trophy{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;padding:10px 6px;flex:0 0 110px}
.bracket-trophy-icon{font-size:2rem;line-height:1}
.bracket-trophy-name{font-family:var(--font-display);font-size:.9rem;letter-spacing:.05em;color:var(--gold);text-align:center;line-height:1.2}
.bracket-view-toggle{display:flex;gap:6px;margin-bottom:14px;align-items:center;flex-wrap:wrap}

/* MODAL */
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:1000;align-items:center;justify-content:center}
.modal-overlay.open{display:flex}
.modal{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:24px;min-width:340px;max-width:460px;width:100%;margin:16px}
.modal-title{font-family:var(--font-display);font-size:1.4rem;margin-bottom:3px;letter-spacing:.05em}
.modal-subtitle{font-size:11px;color:var(--text-muted);margin-bottom:18px}
.modal-teams{display:flex;align-items:center;gap:10px;margin-bottom:14px}
.modal-team{flex:1;text-align:center}
.modal-team-name{font-size:12px;font-weight:700;margin-bottom:7px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.modal-score-input{width:56px;height:46px;border:2px solid var(--border);border-radius:var(--radius-sm);text-align:center;font-family:var(--font-mono);font-size:20px;font-weight:700;margin:0 auto;display:block;color:var(--text-primary)}
.modal-score-input:focus{outline:none;border-color:var(--accent)}
.modal-vs{font-size:16px;font-weight:700;color:var(--text-muted);flex-shrink:0}
.modal-penalties{display:none;padding:12px;background:var(--accent-light);border-radius:var(--radius-sm);margin-bottom:14px}
.modal-penalties.show{display:block}
.modal-penalties-title{font-size:11px;text-transform:uppercase;letter-spacing:.06em;font-weight:700;color:var(--accent);margin-bottom:9px;text-align:center}
.modal-pen-row{display:flex;align-items:center;gap:10px;justify-content:center}
.modal-pen-team{flex:1;text-align:center}
.modal-pen-team-name{font-size:10px;font-weight:700;margin-bottom:5px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.modal-pen-error{display:none;color:var(--accent);font-size:11px;text-align:center;margin-top:7px;font-weight:600}
.ko-match-card.confirmed-real{border-color:var(--green)}
.modal-actions{display:flex;gap:7px;justify-content:flex-end;margin-top:18px}
.modal.with-match-mc{max-width:780px}
.single-mc-panel{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface2);padding:12px;margin-top:14px}
.single-mc-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;margin-bottom:4px}
.single-mc-desc{font-size:11px;color:var(--text-secondary);margin-bottom:10px}
.single-mc-desc .team-cell{display:inline-flex;margin-right:4px}
.single-mc-actions{display:flex;gap:6px;flex-wrap:wrap;align-items:center}
.single-mc-progress{height:7px;border-radius:10px;background:#e7e1da;overflow:hidden;margin:10px 0}
.single-mc-progress-fill{height:100%;background:var(--blue);transition:width .2s}
.single-mc-kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(105px,1fr));gap:7px;margin:10px 0}
.single-mc-kpi{background:#fff;border:1px solid var(--border);border-radius:5px;padding:8px;text-align:center}
.single-mc-kpi strong{display:block;font-family:var(--font-mono);font-size:14px;color:var(--blue)}
.single-mc-kpi span{font-size:9px;text-transform:uppercase;color:var(--text-muted)}
.single-mc-scores{display:flex;gap:6px;flex-wrap:wrap;margin-top:8px}
.single-mc-score{background:#fff;border:1px solid var(--border);border-radius:20px;padding:4px 8px;font-size:10px;cursor:pointer;transition:all .16s ease}
.single-mc-score:hover{background:var(--blue-light);border-color:var(--blue);color:var(--blue)}
.single-mc-score:focus-visible{outline:2px solid var(--blue);outline-offset:2px}
.match-entry{border-bottom:1px solid var(--border)}
.match-entry .match-row{border-bottom:none}
.match-model-odds{display:flex;align-items:center;gap:7px;flex-wrap:wrap;padding:6px 10px;background:var(--blue-light);border-radius:6px;font-size:10px;color:var(--text-secondary)}
.match-entry .match-model-odds{margin:0 0 6px}
.match-model-odds-title{font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--blue)}
.match-model-pill{background:#fff;border:1px solid rgba(39,91,159,.15);border-radius:14px;padding:3px 7px;font-family:var(--font-mono);white-space:nowrap}
.match-model-note{color:var(--text-muted)}
.match-score-likelihood{display:flex;gap:7px;align-items:center;flex-wrap:wrap;flex-basis:100%;padding-top:5px;margin-top:1px;border-top:1px solid rgba(39,91,159,.12)}
.match-score-likelihood-label{font-weight:700;color:var(--text-primary)}
.likelihood-badge{border-radius:12px;padding:3px 7px;font-weight:700}
.likelihood-common{background:var(--green-light);color:var(--green)}
.likelihood-possible{background:#fff;color:var(--blue)}
.likelihood-unlikely{background:var(--orange-light);color:var(--orange)}
.likelihood-rare{background:#fce8e6;color:#b5362f}
.phase-fill-toolbar{display:flex;gap:6px;align-items:center;flex-wrap:wrap;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:10px 12px;margin-bottom:14px}
.phase-fill-toolbar strong{font-size:11px;text-transform:uppercase;letter-spacing:.05em;margin-right:4px}
.modal-odds-preview{margin-bottom:14px}
.backtest-metrics{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:10px;padding:16px 18px}
.backtest-metric{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px}
.backtest-metric strong{display:block;font-family:var(--font-mono);font-size:19px;color:var(--blue);margin-bottom:3px}
.backtest-metric span{font-size:10px;text-transform:uppercase;color:var(--text-muted);font-weight:700}
.backtest-model-row{cursor:pointer}.backtest-model-row.active{background:var(--blue-light)}
.backtest-filter{display:flex;gap:6px;flex-wrap:wrap;padding:12px 18px;border-bottom:1px solid var(--border)}
.backtest-result-hit{color:var(--green);font-weight:700}.backtest-result-miss{color:var(--accent);font-weight:700}
.backtest-upset{background:var(--orange-light)}
.backtest-source{font-size:11px;color:var(--text-secondary);line-height:1.65;padding:13px 18px}

/* PODIUM */
.podium-section{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:14px;margin-bottom:28px}
.podium-card{background:var(--surface);border-radius:var(--radius);padding:20px;text-align:center;border:1px solid var(--border);box-shadow:var(--shadow-sm)}
.podium-card.champion{background:var(--text-primary);color:#fff;border-color:var(--gold);box-shadow:0 6px 28px rgba(201,148,42,.28)}
.podium-icon{font-size:1.8rem;margin-bottom:7px;line-height:1}
.podium-label{font-size:10px;text-transform:uppercase;letter-spacing:.08em;font-weight:600;color:var(--text-muted);margin-bottom:3px}
.podium-card.champion .podium-label{color:var(--gold)}
.podium-name{font-family:var(--font-display);font-size:1.6rem;letter-spacing:.04em;line-height:1;color:var(--text-primary)}
.podium-card.champion .podium-name{color:#fff}
.podium-flag{margin-bottom:8px}

/* DATA CARDS */
.data-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(270px,1fr));gap:18px}
.data-card{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);overflow:hidden}
.data-card-header{padding:14px 18px;border-bottom:1px solid var(--border);background:var(--surface2)}
.data-card-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.06em}
.data-card-body{padding:18px;display:flex;flex-direction:column;gap:9px}
.data-card-desc{font-size:12px;color:var(--text-secondary);line-height:1.6}
textarea.json-area{width:100%;height:160px;border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px;font-family:var(--font-mono);font-size:11px;resize:vertical;color:var(--text-primary)}
textarea.json-area:focus{outline:none;border-color:var(--accent)}

/* ALERTS / EMPTY */
.alert{display:flex;align-items:flex-start;gap:9px;padding:10px 14px;border-radius:var(--radius-sm);font-size:12px;margin-bottom:14px}
.alert-warning{background:var(--gold-light);border:1px solid #e6c75e;color:#7a5a00}
.alert-error{background:var(--accent-light);border:1px solid #f5a0a0;color:#7a1a1a}
.alert-success{background:var(--green-light);border:1px solid #70c08e;color:#1a5a35}
.alert-info{background:var(--blue-light);border:1px solid #80aae0;color:#1a3a6a}
.empty-state{text-align:center;padding:50px 20px;color:var(--text-muted)}
.empty-state-icon{font-size:2.6rem;margin-bottom:10px}
.empty-state-title{font-size:15px;font-weight:600;margin-bottom:5px;color:var(--text-secondary)}
.empty-state-desc{font-size:12px}

/* SECTION CARD */
.section-card{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow-sm);border:1px solid var(--border);overflow:hidden;margin-bottom:20px}
.section-card-header{padding:14px 18px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px}
.section-card-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.06em}

/* MANUAL */
.manual-hero{background:linear-gradient(120deg,var(--text-primary),#342d27);color:#fff;border-radius:var(--radius);padding:25px 28px;margin-bottom:20px;box-shadow:var(--shadow-md);display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap}
.manual-hero-title{font-family:var(--font-display);font-size:2rem;letter-spacing:.05em;line-height:1;margin-bottom:8px}
.manual-hero-text{font-size:13px;color:rgba(255,255,255,.7);max-width:720px}
.manual-actions{display:flex;gap:7px;flex-wrap:wrap}
.manual-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(290px,1fr));gap:18px;margin-bottom:20px}
.manual-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow-sm)}
.manual-card h3{font-family:var(--font-display);font-size:1.25rem;letter-spacing:.05em;margin-bottom:9px}
.manual-card p{font-size:12px;color:var(--text-secondary);line-height:1.65;margin-bottom:8px}
.manual-card p:last-child{margin-bottom:0}
.manual-list{list-style:none;display:flex;flex-direction:column;gap:8px;font-size:12px;color:var(--text-secondary)}
.manual-list li{position:relative;padding-left:18px;line-height:1.5}
.manual-list li::before{content:"";position:absolute;left:1px;top:7px;width:7px;height:7px;border-radius:50%;background:var(--accent)}
.manual-steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:12px;padding:18px}
.manual-step{border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px;background:var(--surface2)}
.manual-step-number{font-family:var(--font-mono);font-weight:700;color:var(--accent);font-size:11px;margin-bottom:5px}
.manual-step strong{display:block;font-size:12px;margin-bottom:4px}
.manual-step span{font-size:11px;color:var(--text-secondary);line-height:1.5}
.manual-feature-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(255px,1fr));gap:0}
.manual-feature{padding:16px 18px;border-bottom:1px solid var(--border);border-right:1px solid var(--border)}
.manual-feature-title{font-size:12px;font-weight:700;margin-bottom:5px}
.manual-feature-text{font-size:11px;color:var(--text-secondary);line-height:1.6}
.manual-note{padding:16px 18px;font-size:12px;line-height:1.7;color:var(--text-secondary)}
.manual-note strong{color:var(--text-primary)}

/* TOAST */
.toast{position:fixed;bottom:20px;right:20px;background:var(--text-primary);color:#fff;padding:10px 18px;border-radius:var(--radius-sm);font-size:12px;font-weight:500;box-shadow:var(--shadow-lg);z-index:9999;display:none;max-width:300px}
.toast.show{display:block;animation:slideIn .3s ease}
.toast.success{background:var(--green)}
.toast.error{background:var(--accent)}
@keyframes slideIn{from{transform:translateY(18px);opacity:0}to{transform:translateY(0);opacity:1}}

/* STATUS DOT */
.status-dot{width:7px;height:7px;border-radius:50%;display:inline-block;margin-right:4px}
.status-dot.green{background:var(--green)}.status-dot.red{background:var(--accent)}.status-dot.gray{background:var(--text-muted)}

/* ============================================================
   ESTATÍSTICAS — CSS
   ============================================================ */
.stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px;margin-bottom:24px}
.stats-grid-wide{display:grid;grid-template-columns:repeat(auto-fill,minmax(460px,1fr));gap:20px;margin-bottom:24px}
.stat-card{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow-sm);overflow:hidden}
.stat-card-header{background:var(--text-primary);color:#fff;padding:10px 16px;display:flex;align-items:center;gap:8px}
.stat-card-icon{font-size:1.1rem;line-height:1}
.stat-card-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.07em}
.stat-card-body{padding:0}

/* KPI tiles */
.kpi-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px;margin-bottom:24px}
.kpi-tile{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);padding:16px 14px;text-align:center;box-shadow:var(--shadow-sm)}
.kpi-value{font-family:var(--font-display);font-size:2rem;letter-spacing:.03em;line-height:1;color:var(--text-primary);margin-bottom:4px}
.kpi-label{font-size:10px;text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);font-weight:600;line-height:1.3}
.kpi-sub{font-size:11px;color:var(--text-secondary);margin-top:3px}

/* Bar chart rows */
.bar-row{display:flex;align-items:center;gap:10px;padding:7px 14px;border-bottom:1px solid var(--border);font-size:12px}
.bar-row:last-child{border-bottom:none}
.bar-rank{font-family:var(--font-mono);font-size:11px;color:var(--text-muted);min-width:18px;text-align:right;flex-shrink:0}
.bar-team{display:flex;align-items:center;gap:6px;min-width:130px;flex-shrink:0;font-weight:600}
.bar-track{flex:1;background:var(--surface2);border-radius:20px;height:10px;overflow:hidden;position:relative}
.bar-fill{height:100%;border-radius:20px;transition:width .3s ease}
.bar-fill.green{background:var(--green)}
.bar-fill.blue{background:var(--blue)}
.bar-fill.accent{background:var(--accent)}
.bar-fill.gold{background:var(--gold)}
.bar-fill.orange{background:var(--orange)}
.bar-fill.purple{background:#7c4dbd}
.bar-value{font-family:var(--font-mono);font-size:12px;font-weight:700;min-width:36px;text-align:right;flex-shrink:0}

/* Head-to-head / results matrix */
.stats-section-title{font-family:var(--font-display);font-size:1.3rem;letter-spacing:.04em;margin:28px 0 12px;padding-bottom:8px;border-bottom:2px solid var(--border)}
.stats-section-title:first-child{margin-top:0}

/* Result pills */
.result-pill{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;font-size:10px;font-weight:700;flex-shrink:0}
.pill-w{background:var(--green);color:#fff}
.pill-d{background:var(--gold);color:#fff}
.pill-l{background:var(--accent);color:#fff}

/* Clean sheet badge */
.cs-badge{display:inline-block;padding:2px 6px;border-radius:4px;font-size:10px;font-weight:700;background:var(--green-light);color:var(--green)}

/* Tabs within stats */
.stats-sub-tabs{display:flex;gap:4px;margin-bottom:16px;flex-wrap:wrap}
.stats-sub-tab{padding:6px 14px;border:1px solid var(--border);border-radius:20px;background:var(--surface);cursor:pointer;font-size:11px;font-weight:600;color:var(--text-secondary);transition:all .15s}
.stats-sub-tab.active{background:var(--accent);color:#fff;border-color:var(--accent)}

/* FINAL RANKING TABLE ROWS */
.classif-table tr.final-rank-1{background:linear-gradient(90deg,#fef3d8 0%,#fffdf5 100%);font-weight:700}
.classif-table tr.final-rank-2{background:linear-gradient(90deg,#e8f4ea 0%,#f7fdf8 100%)}
.classif-table tr.final-rank-34{background:linear-gradient(90deg,#ede8f4 0%,#faf8fd 100%)}
.classif-table tr.final-rank-sf{background:var(--blue-light)}
.classif-table tr.final-rank-qf{background:var(--blue-light);opacity:.85}
.classif-table tr.final-rank-r16{background:var(--surface2)}
.classif-table tr.final-rank-out{opacity:.6}
.classif-table tr.final-rank-1 td:first-child::before{content:"🥇 ";font-size:11px}
.classif-table tr.final-rank-2 td:first-child::before{content:"🥈 ";font-size:11px}

/* CLASSIF SECTION */
.classif-section{margin-bottom:28px}
.classif-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;flex-wrap:wrap;gap:8px}
.classif-section-title{font-family:var(--font-display);font-size:1.2rem;letter-spacing:.04em}

/* MANUAL ORDER */
.manual-order-indicator{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;background:var(--orange-light);border:1px solid #e6a870;border-radius:20px;font-size:10px;font-weight:700;color:var(--orange);text-transform:uppercase;letter-spacing:.04em}
.thirds-controls{padding:10px 14px;background:var(--gold-light);border-bottom:1px solid #e6c75e;display:flex;align-items:center;gap:9px;flex-wrap:wrap;font-size:12px;color:#7a5a00}

/* BRACKET LIST FALLBACK */
.ko-matches-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:10px}
.ko-match-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden;cursor:pointer;transition:box-shadow .15s}
.ko-match-card:hover{box-shadow:var(--shadow-md)}
.ko-match-card.has-winner{border-left:3px solid var(--green)}
.ko-match-card.final-match{border:2px solid var(--gold)}
.ko-match-header{background:var(--surface2);padding:5px 10px;font-size:10px;text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);font-weight:600;border-bottom:1px solid var(--border);display:flex;justify-content:space-between}
.ko-match-body{padding:10px}
.ko-team-row{display:flex;align-items:center;gap:8px;padding:6px 8px;border-radius:4px;font-size:12px;font-weight:600;border:1px solid transparent}
.ko-team-row.winner{background:var(--green-light);border-color:#c8e6da}
.ko-team-row.loser{opacity:.5}
.ko-team-row.tbd{color:var(--text-muted);font-style:italic;font-weight:400}
.ko-team-name{flex:1}.ko-team-score{font-family:var(--font-mono);font-weight:700;font-size:15px;min-width:22px;text-align:right}
.ko-match-footer{padding:5px 10px;border-top:1px solid var(--border);font-size:10px;color:var(--text-muted);text-align:center}
.ko-match-footer.has-winner{color:var(--green);font-weight:600}

/* CLEAN PHASE BUTTONS */
.clean-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:10px;margin-bottom:18px}
.clean-btn-item{display:flex;flex-direction:column;gap:4px}
.clean-btn-item .desc{font-size:10px;color:var(--text-muted);padding:0 2px}

/* RATINGS FIFA / MONTE CARLO */
.mc-toolbar{display:flex;gap:8px;align-items:center;flex-wrap:wrap;padding:16px 18px}
.mc-form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(195px,1fr));gap:14px;padding:16px 18px}
.mc-field{display:flex;flex-direction:column;gap:6px}
.mc-field label,.mc-check label{font-size:11px;font-weight:600;color:var(--text-secondary)}
.mc-input,.rating-input{border:1px solid var(--border);border-radius:var(--radius-sm);padding:8px 9px;background:#fff;color:var(--text-primary);font-family:var(--font-body);font-size:12px}
.mc-input:focus,.rating-input:focus{outline:none;border-color:var(--accent)}
.rating-input{width:98px;text-align:right;font-family:var(--font-mono);padding:5px 6px}
.rating-input.note{width:190px;text-align:left;font-family:var(--font-body)}
.mc-checks{display:flex;flex-wrap:wrap;gap:16px;padding:0 18px 16px}
.mc-check{display:flex;align-items:center;gap:6px}
.mc-check input{accent-color:var(--accent)}
.mc-progress-wrap{padding:0 18px 18px}
.mc-progress{width:100%;height:12px;border-radius:20px;background:var(--surface2);border:1px solid var(--border);overflow:hidden}
.mc-progress-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--gold));transition:width .2s ease}
.mc-status-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(125px,1fr));gap:9px;margin:14px 0}
.mc-status-tile{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px;text-align:center}
.mc-status-value{font-family:var(--font-mono);font-size:16px;font-weight:700}
.mc-status-label{font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}
.ratings-table td,.mc-table td{white-space:nowrap}
.ratings-table th.sortable,.mc-table th.sortable{cursor:pointer}
.rating-status{display:inline-block;padding:2px 7px;border-radius:20px;font-size:10px;font-weight:600;text-transform:uppercase}
.rating-status.ok{background:var(--green-light);color:var(--green)}
.rating-status.missing{background:var(--accent-light);color:var(--accent)}
.rating-status.estimated{background:var(--gold-light);color:var(--gold)}
.mc-results-wrap{overflow-x:auto}
.mc-table{min-width:1580px}
.mc-highlight-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;margin-bottom:18px}
.mc-highlight{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px;box-shadow:var(--shadow-sm)}
.mc-highlight-label{font-size:10px;color:var(--text-muted);font-weight:700;text-transform:uppercase;letter-spacing:.06em}
.mc-highlight-team{font-weight:700;margin:7px 0 3px;display:flex;gap:7px;align-items:center}
.mc-highlight-value{font-family:var(--font-mono);color:var(--accent);font-weight:700}
.mc-file-area{height:95px!important}
.odds-tab-btn{padding:8px 16px;background:none;border:none;border-bottom:3px solid transparent;cursor:pointer;font-family:var(--font-body);font-size:11px;font-weight:600;color:var(--text-secondary);letter-spacing:.04em;text-transform:uppercase;transition:all .15s;white-space:nowrap}
.odds-tab-btn:hover{color:var(--text-primary)}
.odds-tab-btn.active{color:var(--accent);border-bottom-color:var(--accent)}
.odds-upload-zone{border:2px dashed var(--border);border-radius:var(--radius);padding:32px 20px;text-align:center;cursor:pointer;transition:all .2s;background:var(--surface2)}
.odds-upload-zone:hover,.odds-upload-zone.drag-over{border-color:var(--accent);background:var(--accent-light)}
.outlier-active-row{background:var(--gold-light)}
.outlier-toggle{cursor:pointer;display:inline-flex;align-items:center;gap:6px}
.outlier-toggle input{cursor:pointer;width:15px;height:15px}
.outlier-toggle-label{font-size:11px;font-weight:600;color:var(--text-secondary)}
.outlier-active-row .outlier-toggle-label{color:var(--gold)}

/* RESPONSIVE */
@media(max-width:768px){
  header{padding:14px 18px}nav{padding:0 16px}main{padding:18px 14px}
  .groups-grid{grid-template-columns:1fr}
  .header-title{font-size:1.7rem}
  .header-actions{margin-left:0;width:100%}
  .bracket-cols{min-width:1100px}
  .manual-hero{padding:20px 18px}
  .manual-hero-title{font-size:1.6rem}
  .match-row{gap:4px;padding:6px 8px}
  .match-mc-btn{display:none}
  .match-id-label{display:none}
}
