*,*: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}.app-header-compact{margin-bottom:1rem;text-align:left}.app-header-compact h1{font-size:1.35rem;margin:0}.layout{display:grid;gap:1rem}@media(min-width:900px){.layout-match{grid-template-columns:1.4fr 1fr;align-items:stretch}}.setup-layout{display:grid;gap:1rem;max-width:900px;margin:0 auto}@media(min-width:860px){.setup-layout{grid-template-columns:1.15fr .85fr;align-items:start}}.setup-tips h2{margin-top:0;font-size:1.1rem}.setup-tips ol{padding-left:1.2rem;margin:0 0 1rem}.setup-tips li{margin-bottom:.5rem;line-height:1.4}.setup-tips-hint{margin:0;font-size:.85rem;opacity:.75;line-height:1.45}.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}.prompt-chips{display:flex;flex-wrap:wrap;gap:.4rem;margin:-.35rem 0 .9rem}.chip{background:#16261a;border:1px solid #2a4a30;color:#cfe5d3;padding:.32rem .7rem;border-radius:999px;font-size:.76rem;font-weight:500}.chip:hover{background:#1e3626;border-color:#3d7a4d}.mode-toggle{display:flex;gap:.5rem;margin-bottom:1rem}.mode-toggle button{flex:1}.team-picker{border:none;margin:0 0 .9rem;padding:0}.team-picker legend{font-size:.9rem;margin-bottom:.45rem}.team-picker-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.45rem}.team-card{display:flex;align-items:center;gap:.5rem;padding:.55rem .65rem;border-radius:8px;border:1px solid #35593d;background:#0f1a12;color:inherit;text-align:left;width:100%}.team-card:hover{border-color:#3d7a4d;background:#16261a}.team-card.selected{border-color:#5cb86a;background:#1e3626;box-shadow:0 0 0 1px #5cb86a}.team-card-flag{font-size:1.35rem;line-height:1}.team-card-name{font-size:.88rem;font-weight:600}.opponent-hint{margin:-.25rem 0 .9rem;font-size:.85rem;opacity:.75}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{display:flex;flex-direction:column;align-items:center;gap:1rem;text-align:center;padding:3.5rem 1rem;opacity:.85;max-width:480px;margin:0 auto}.spinner{width:2.25rem;height:2.25rem;border-radius:50%;border:3px solid #2a4a30;border-top-color:#6fcf7f;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.new-match-bar{display:flex;justify-content:center;margin-top:1.5rem;padding-top:1.25rem;border-top:1px solid #2a4a30}.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;display:flex;flex-wrap:wrap;align-items:baseline;gap:.15rem}.score-team{font-size:1rem;font-weight:600;opacity:.92}.score-digit{display:inline-block;min-width:1.1ch;text-align:center;transition:transform .12s ease,text-shadow .12s ease}.score-sep{opacity:.65;padding:0 .1rem}@keyframes scoreboard-goal-pulse{0%{transform:scale(1);text-shadow:none;color:inherit}18%{transform:scale(1.45);text-shadow:0 0 18px rgba(255,220,120,.95),0 0 36px rgba(255,180,60,.55);color:#ffe8a9}45%{transform:scale(1.18);text-shadow:0 0 12px rgba(255,220,120,.7);color:#fff3c8}to{transform:scale(1);text-shadow:none;color:inherit}}.scoreboard-goal-flash{animation:scoreboard-goal-pulse .9s cubic-bezier(.22,1,.36,1)}.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}.pitch-stage{position:relative}.pitch-stage-rewind .pitch-wrap{filter:blur(var(--rewind-blur, 0px));transition:filter .12s ease-out}.pitch-stage-rewind .pitch-wrap canvas{transform:scale(1.012);transition:transform .12s ease-out}.moment-pop{position:absolute;left:50%;top:1rem;transform:translate(-50%);z-index:2;padding:.5rem .9rem;border-radius:999px;font-weight:800;letter-spacing:.03em;text-transform:uppercase;color:#f5fff1;border:1px solid rgba(255,255,255,.22);background:linear-gradient(180deg,#223f26e6,#101b12f2);box-shadow:0 8px 22px #00000061;pointer-events:none;transition:opacity .18s ease}.moment-pop-home{border-color:#6eb9ff73;box-shadow:0 8px 24px #4da3ff2e}.moment-pop-away{border-color:#ff7a7a80;box-shadow:0 8px 24px #ff6b6b33}.moment-pop-goal{color:#ffe8a9;font-size:1.05rem;letter-spacing:.06em;border-color:#ffd25a8c;background:linear-gradient(180deg,#3a2c0ceb,#161208f5);box-shadow:0 10px 28px #ffbe3c38,inset 0 0 0 1px #ffeba01f}.moment-pop-goal-active{animation:goal-pop-celebrate .68s cubic-bezier(.22,1,.36,1)}@keyframes goal-pop-celebrate{0%{transform:translate(-50%) scale(.72);opacity:0}35%{transform:translate(-50%) scale(1.08)}to{transform:translate(-50%) scale(1);opacity:1}}.moment-pop-goal-active:before,.moment-pop-goal-active:after{content:"";position:absolute;top:-6px;right:-6px;bottom:-6px;left:-6px;border-radius:inherit;pointer-events:none;opacity:.75}.moment-pop-goal-active:before{background:radial-gradient(circle at 18% 35%,rgba(255,220,120,.55) 0 2px,transparent 3px),radial-gradient(circle at 72% 28%,rgba(120,210,255,.5) 0 2px,transparent 3px),radial-gradient(circle at 84% 62%,rgba(255,140,160,.45) 0 2px,transparent 3px),radial-gradient(circle at 28% 68%,rgba(180,255,160,.45) 0 2px,transparent 3px);animation:goal-confetti .72s ease-out forwards}.moment-pop-goal-active:after{top:0;right:0;bottom:0;left:0;box-shadow:0 0 #ffdc7873;animation:goal-pop-ring .68s ease-out forwards}@keyframes goal-confetti{0%{transform:scale(.6);opacity:0}30%{opacity:1}to{transform:scale(1.35) translateY(-6px);opacity:0}}@keyframes goal-pop-ring{0%{box-shadow:0 0 #ffdc788c}to{box-shadow:0 0 0 14px #ffdc7800}}.motd-tribute{position:absolute;left:50%;bottom:.75rem;z-index:3;width:min(240px,72%);pointer-events:none;image-rendering:pixelated;transform:translate(-50%);transform-origin:center bottom;transition:opacity 80ms linear;animation:motd-bounce-in .22s cubic-bezier(.34,1.4,.64,1) both}.motd-tribute__banner{font-family:Courier New,Courier,monospace;font-size:.62rem;font-weight:800;letter-spacing:.14em;text-transform:uppercase;text-align:center;color:#ffe566;text-shadow:1px 0 0 #1a1208,-1px 0 0 #1a1208,0 1px 0 #1a1208,0 -1px 0 #1a1208,2px 2px 0 #3d2808;margin-bottom:.15rem}.motd-tribute__subtitle{font-family:Courier New,Courier,monospace;font-size:.55rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;text-align:center;color:#c8f0d0;margin-bottom:.2rem;opacity:.92}.motd-tribute__quote{margin:0 0 .3rem;padding:.28rem .35rem;text-align:center;background:linear-gradient(180deg,#1a2840,#0f1828);border:2px solid #2a4a38;border-radius:3px;box-shadow:inset 0 1px #ffe6781f,0 2px #0a0f0c;min-height:1.6rem;display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:0;animation:motd-quote-fade .28s ease-out both}.motd-tribute__quote-text{font-family:Courier New,Courier,monospace;font-size:.52rem;font-weight:700;line-height:1.35;letter-spacing:.03em;color:#fff4c8;text-shadow:1px 0 0 #1a1208,-1px 0 0 #1a1208,0 1px 0 #1a1208,0 -1px 0 #1a1208}.motd-tribute__quote-caret{font-family:Courier New,Courier,monospace;font-size:.52rem;font-weight:700;color:#ffe566;animation:motd-caret-blink .55s step-end infinite}.motd-tribute__quote--complete .motd-tribute__quote-text{color:#ffe08a}.motd-tribute__scene{display:block;width:100%;height:auto;border:2px solid #1f3d28;border-radius:4px;box-shadow:0 0 0 1px #0a0f0c,0 6px 18px #0000008c;image-rendering:pixelated}.motd-tribute__caption{margin-top:.2rem;font-size:.48rem;letter-spacing:.04em;text-align:center;color:#b4d2be8c;text-transform:uppercase}@keyframes motd-quote-fade{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}@keyframes motd-caret-blink{0%,to{opacity:1}50%{opacity:0}}@keyframes motd-bounce-in{0%{transform:translate(-50%,12px) scale(.35);opacity:0}55%{transform:translate(-50%,-2px) scale(1.06);opacity:1}78%{transform:translate(-50%,1px) scale(.97)}to{transform:translate(-50%) scale(1);opacity:1}}.moment-pop-save{color:#c9ebff}.moment-pop-shot{color:#ffd4a8}.moment-pop-tackle{color:#d8f5c8}.moment-pop-foul{color:#ffb4b4}.moment-pop-set_piece{color:#e8d4ff}.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}.match-sidebar{display:flex;flex-direction:column;gap:.5rem;min-height:0}.speed-toggle{min-width:3rem}.match-log-toggle{display:flex;align-items:center;gap:.5rem;font-size:.85rem;cursor:pointer;-webkit-user-select:none;user-select:none;padding:.25rem 0}.match-log-toggle input{accent-color:#3d9a52}.event-timeline{display:flex;flex-direction:column;min-height:0;flex:1}.event-timeline h3{margin:0 0 .5rem;font-size:1rem}.event-timeline-list{flex:1;min-height:0;max-height:min(72vh,760px);overflow-y:auto}.match-log{display:flex;flex-direction:column;min-height:0;flex:1}.match-log h3{margin:0 0 .5rem;font-size:1rem}.match-log-list{flex:1;min-height:0;max-height:min(72vh,760px);overflow-y:auto;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:.78rem;line-height:1.35}.match-log-empty{margin:0;opacity:.7;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif}.match-log-item{display:grid;grid-template-columns:2.5rem 3.5rem 1fr auto;gap:.35rem .5rem;align-items:baseline;padding:.35rem .5rem;border-left:3px solid #2a4a30;margin-bottom:.2rem;border-radius:0 6px 6px 0}.match-log-item.active{border-left-color:#6fcf7f;background:#1a3020}.match-log-minute{opacity:.65;font-variant-numeric:tabular-nums}.match-log-type{font-weight:700;font-size:.72rem;text-transform:uppercase;letter-spacing:.02em}.match-log-type-goal{color:#ffd666}.match-log-type-shot{color:#ff9f7a}.match-log-type-save{color:#7ec8ff}.match-log-type-pass{color:#9cb8a4}.match-log-type-tackle,.match-log-type-beat,.match-log-type-skill,.match-log-type-interception,.match-log-type-turnover{color:#c9a0dc}.match-log-type-skill{color:#e8b86d}.match-log-type-kickoff,.match-log-type-half_time,.match-log-type-full_time{color:#6fcf7f}.match-log-text{min-width:0;word-break:break-word}.match-log-team{font-size:.68rem;opacity:.55;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:5rem}.match-log-home{border-left-color:#3d7a4d}.match-log-away{border-left-color:#4a6a9a}.match-log-neutral{border-left-color:#2a4a30}@media(max-width:899px){.match-log-list,.event-timeline-list{max-height:280px}.match-log-item{grid-template-columns:2.25rem 3rem 1fr}.match-log-team{display:none}.match-meta{flex-direction:column;align-items:stretch}.scoreline{font-size:1.15rem}}.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}
