*,*:before,*:after{box-sizing:border-box}body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;background:#0f1a12;color:#eef5ee;min-height:100vh}#root{min-height:100vh}.app{max-width:1200px;margin:0 auto;padding:1rem}.app-header{text-align:center;margin-bottom:1.5rem}.app-header h1{margin:0 0 .25rem;font-size:clamp(1.5rem,4vw,2.25rem)}.app-header p{margin:0;opacity:.75}.layout{display:grid;gap:1rem}@media(min-width:900px){.layout-match{grid-template-columns:1.4fr 1fr}}.panel{background:#16261a;border:1px solid #2a4a30;border-radius:12px;padding:1rem}.tactic-form label{display:block;margin-bottom:.75rem;font-size:.9rem}.tactic-form input,.tactic-form textarea,.tactic-form select{width:100%;margin-top:.35rem;padding:.55rem .65rem;border-radius:8px;border:1px solid #35593d;background:#0f1a12;color:inherit}.tactic-form textarea{min-height:100px;resize:vertical}.mode-toggle{display:flex;gap:.5rem;margin-bottom:1rem}.mode-toggle button{flex:1}button{cursor:pointer;border:1px solid #3d7a4d;background:#245532;color:#eef5ee;border-radius:8px;padding:.55rem .85rem;font-weight:600}button:hover{background:#2d6a3d}button:disabled{opacity:.5;cursor:not-allowed}button.active{background:#3d9a52}.primary-btn{width:100%;margin-top:.5rem;padding:.75rem;font-size:1rem}.error-banner{background:#4a1f1f;border:1px solid #8a3030;color:#ffd4d4;padding:.75rem;border-radius:8px;margin-bottom:1rem}.loading{text-align:center;padding:3rem 1rem;opacity:.85}.match-meta{display:flex;flex-wrap:wrap;gap:.75rem;align-items:center;justify-content:space-between;margin-bottom:.75rem}.scoreline{font-size:1.5rem;font-weight:700}.controls{display:flex;gap:.5rem}.pitch-wrap{width:100%;aspect-ratio:100 / 68;background:#1a3d22;border-radius:8px;overflow:hidden}.pitch-wrap canvas{width:100%;height:100%;display:block}.tactic-cards{display:grid;gap:.5rem;margin-top:.75rem}.tactic-card{background:#0f1a12;border-radius:8px;padding:.65rem;font-size:.85rem}.tactic-card strong{display:block;margin-bottom:.25rem}.player-instructions{margin-top:.35rem;color:#9cb8a4;font-size:.78rem;line-height:1.35}.event-timeline{max-height:320px;overflow-y:auto}.event-item{padding:.5rem .65rem;border-left:3px solid #2a4a30;margin-bottom:.35rem;font-size:.85rem;border-radius:0 6px 6px 0}.event-item.active{border-left-color:#6fcf7f;background:#1a3020}.event-minute{opacity:.65;margin-right:.35rem}.report-panel h2{margin-top:0}.report-panel ul{padding-left:1.2rem}.report-panel li{margin-bottom:.35rem}.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem;font-size:.85rem;margin:.75rem 0}.stat-box{background:#0f1a12;padding:.5rem;border-radius:6px}.app-version{position:fixed;right:.75rem;bottom:.5rem;font-size:.7rem;opacity:.45;font-variant-numeric:tabular-nums;pointer-events:none;-webkit-user-select:none;user-select:none}
