@import url("https://fonts.googleapis.com/css2?family=Inter:wght@400;600;800&family=Outfit:wght@400;700;900&display=swap");:root{--bg-dark:#0f172a;--bg-card:rgba(30,41,59,0.7);--border-color:rgba(255,255,255,0.1);--text-main:#f8fafc;--text-muted:#94a3b8;--pitch-green-light:#22c55e;--pitch-green-dark:#16a34a;--pitch-line:rgba(255,255,255,0.6);--accent-blue:#3b82f6;--accent-goal:#22c55e;--accent-point:#f8fafc;--accent-wide:#ef4444;--accent-red:#ef4444;--accent-short:#facc15;--accent-turnover:#c084fc;--accent-foul:#fb923c;--accent-kickout:#38bdf8;--accent-opposition:#fb7185;--accent-yellow:#facc15;--accent-black:#18181b;--accent-red-card:#dc2626;--accent-block:#a855f7;--accent-save:#0d9488}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Inter,sans-serif;background-color:var(--bg-dark);color:var(--text-main);min-height:100vh;display:flex;flex-direction:column;align-items:center;overflow-x:hidden;padding:20px}h1,h2,h3{font-family:Outfit,sans-serif}.glass-card{background:var(--bg-card);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border-color);border-radius:16px;box-shadow:0 4px 30px rgba(0,0,0,.1);padding:24px;width:100%;max-width:100%;box-sizing:border-box}header{width:100%;max-width:800px;justify-content:space-between;margin-bottom:30px}.scoreboard,header{display:flex;align-items:center}.scoreboard{gap:20px}.team-score{text-align:center}.team-name{font-size:1.2rem;font-weight:700;margin-bottom:8px;color:var(--text-muted)}.score-display{font-size:2.2rem;letter-spacing:1px;text-shadow:0 0 20px rgba(255,255,255,.1);display:flex;justify-content:center;align-items:center}.score-display,.timer{font-weight:900;font-family:Outfit,sans-serif}.timer{font-size:3.5rem;color:#fff;text-shadow:0 0 20px rgba(255,255,255,.3);letter-spacing:3px;line-height:1}.timer.overtime{color:var(--accent-red-card);text-shadow:0 0 20px rgba(220,38,38,.5)}.pitch-container{width:100%;max-width:500px;aspect-ratio:1/1.6;position:relative;border-radius:12px;overflow:hidden;box-shadow:0 20px 40px rgba(0,0,0,.4);cursor:crosshair;background:repeating-linear-gradient(0deg,var(--pitch-green-dark),var(--pitch-green-dark) 10%,var(--pitch-green-light) 10%,var(--pitch-green-light) 20%);border:4px solid var(--pitch-line)}.pitch-lines{top:0;height:100%;pointer-events:none}.line-center,.pitch-lines{position:absolute;left:0;width:100%}.line-center{top:50%;height:2px;background-color:var(--pitch-line)}.zone-label-attack,.zone-label-defense{position:absolute;width:100%;text-align:center;font-family:Outfit,sans-serif;font-size:1rem;font-weight:700;color:rgba(255,255,255,.3);pointer-events:none;letter-spacing:2px;text-transform:uppercase}.zone-label-attack{bottom:52%}.zone-label-defense{top:52%}.line-13-bottom,.line-13-top,.line-20-bottom,.line-20-top,.line-45-bottom,.line-45-top,.line-65-bottom,.line-65-top{position:absolute;left:0;width:100%;height:1px;background-color:var(--pitch-line)}.line-13-top{top:9%}.line-20-top{top:14%}.line-45-top{top:31%}.line-65-top{top:45%}.line-65-bottom{bottom:45%}.line-45-bottom{bottom:31%}.line-20-bottom{bottom:14%}.line-13-bottom{bottom:9%}.goal-bottom,.goal-top{position:absolute;width:15%;height:3%;left:42.5%;border:2px solid var(--pitch-line)}.goal-top{top:0;border-top:none}.goal-bottom{bottom:0;border-bottom:none}.arc-bottom,.arc-top{position:absolute;width:20%;aspect-ratio:1;left:40%;border:2px solid var(--pitch-line);border-radius:50%}.arc-top{top:14%;transform:translateY(-50%);clip-path:polygon(0 50%,100% 50%,100% 100%,0 100%)}.arc-bottom{bottom:14%;transform:translateY(50%);clip-path:polygon(0 0,100% 0,100% 50%,0 50%)}.pin{position:absolute;width:12px;height:12px;border-radius:50%;transform:translate(-50%,-50%);box-shadow:0 0 10px rgba(0,0,0,.5);animation:popIn .3s cubic-bezier(.175,.885,.32,1.275) forwards;pointer-events:auto;cursor:pointer;border:1.5px solid rgba(0,0,0,.8)}.pin.goal{background-color:var(--accent-goal)}.pin.point{background-color:var(--accent-point)}.pin.wide{background-color:var(--accent-wide)}.pin.short{background-color:var(--accent-short)}.pin.turnover_lost,.pin.turnover_won{background-color:var(--accent-turnover);border-radius:2px}.pin.foul{background-color:var(--accent-foul);clip-path:polygon(50% 0,0 100%,100% 100%);border-radius:0;border:none}.pin.kickout{background-color:var(--accent-kickout)}.pin.yellow_card{background-color:var(--accent-yellow);border-radius:4px}.pin.black_card{background-color:var(--accent-black);border-radius:4px;border:1px solid rgba(255,255,255,.5)}.pin.red_card{background-color:var(--accent-red-card);border-radius:4px}.pin.block{background-color:var(--accent-block);clip-path:polygon(50% 0,100% 50%,50% 100%,0 50%);border-radius:0;border:none}.pin.save{background-color:var(--accent-save);border-radius:50%;border:1px solid white}.pin.opposition{border:2px solid var(--accent-opposition)}.pin:hover{transform:translate(-50%,-50%) scale(1.3);z-index:10}@keyframes popIn{0%{transform:translate(-50%,-50%) scale(0);opacity:0}to{transform:translate(-50%,-50%) scale(1);opacity:1}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.6);backdrop-filter:blur(4px);display:flex;justify-content:center;align-items:center;z-index:100;opacity:0;pointer-events:none;transition:opacity .2s ease}.modal-overlay.active{opacity:1;pointer-events:auto}.modal-content{text-align:center;animation:slideUp .3s ease;width:95%;max-width:400px;box-sizing:border-box}.modal-content.hidden{display:none}.modal-title{margin-bottom:10px;font-size:1.5rem}.toast{position:fixed;bottom:20px;left:50%;transform:translateX(-50%) translateY(100px);background:var(--accent-wide);color:#fff;padding:12px 24px;border-radius:8px;font-weight:600;box-shadow:0 4px 15px rgba(0,0,0,.5);z-index:1000;transition:transform .3s cubic-bezier(.175,.885,.32,1.275)}.toast.show{transform:translateX(-50%) translateY(0)}.who-label{color:var(--text-muted);margin-bottom:20px;font-weight:600}.roster-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:10px;margin-bottom:15px;max-height:250px;overflow-y:auto;padding-right:5px}.roster-grid::-webkit-scrollbar{width:6px}.roster-grid::-webkit-scrollbar-thumb{background:rgba(255,255,255,.2);border-radius:3px}.btn-roster{background:rgba(255,255,255,.1);border:1px solid var(--border-color);color:#fff;padding:10px 0;border-radius:6px;font-weight:700;cursor:pointer;transition:all .2s}.btn-roster:hover{background:var(--accent-blue);border-color:var(--accent-blue)}.roster-extras{display:flex;gap:10px;margin-top:15px}.btn-opposition{flex:1;background:rgba(251,113,133,.2);border:1px solid var(--accent-opposition);color:#fff}.event-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.btn{padding:12px;border:none;border-radius:8px;background-color:rgba(255,255,255,.1);font-family:Inter,sans-serif;font-weight:600;font-size:.95rem;cursor:pointer;transition:all .2s;color:#fff}.btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,.2)}.btn-primary{background:var(--accent-blue);width:100%;margin-top:20px}.btn-goal{background-color:var(--accent-goal);color:#000}.btn-point{background-color:var(--accent-point);color:#000}.btn-wide{background-color:var(--accent-wide)}.btn-short{background-color:var(--accent-short);color:#000}.btn-turnover-won{background-color:var(--accent-turnover)}.btn-turnover-lost{background-color:transparent;border:1px solid var(--accent-turnover)}.btn-foul{background-color:var(--accent-foul);color:#000}.btn-kickout{background-color:var(--accent-kickout);color:#000}.btn-yellow-card{background-color:var(--accent-yellow);color:#000}.btn-black-card{background-color:var(--accent-black);color:#fff;border:1px solid rgba(255,255,255,.2)}.btn-red-card{background-color:var(--accent-red-card);color:#fff}.btn-block{background-color:var(--accent-block);color:#fff}.btn-cancel{background-color:transparent;border:1px solid var(--border-color);flex:1;margin-top:0}#btn-cancel-what{width:100%;margin-top:15px}.setup-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:var(--bg-dark);z-index:200;display:flex;justify-content:center;align-items:center;opacity:0;pointer-events:none;transition:opacity .3s ease}.setup-overlay.active{opacity:1;pointer-events:auto}.setup-card{width:95%;max-width:600px;box-sizing:border-box}.setup-title{text-align:center;margin-bottom:25px;color:var(--accent-blue)}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;font-size:.9rem;color:var(--text-muted)}.form-group input{width:100%;padding:12px;border-radius:8px;border:1px solid var(--border-color);background:rgba(0,0,0,.3);color:#fff;font-family:Inter,sans-serif;font-size:1rem}.form-group input:focus{outline:none;border-color:var(--accent-blue)}.post-match-dashboard{position:fixed;top:0;left:0;right:0;bottom:0;background:var(--bg-dark);z-index:50;overflow-y:auto;padding:20px;display:none;flex-direction:column;align-items:center}.post-match-dashboard.active{display:flex}.dashboard-header{width:100%;max-width:800px;text-align:center;margin-bottom:20px}.dashboard-header .final-score{font-size:2rem;font-family:Outfit,sans-serif;font-weight:800;color:var(--accent-blue);margin-top:10px}.dashboard-tabs{display:flex;width:100%;max-width:800px;gap:10px;margin-bottom:20px;padding:10px}.tab-btn{flex:1;padding:12px;background:rgba(255,255,255,.05);border:1px solid transparent;color:var(--text-muted);border-radius:8px;font-family:Inter,sans-serif;font-weight:600;cursor:pointer;transition:all .2s}.tab-btn.active{background:var(--bg-card);border-color:var(--accent-blue);color:#fff;box-shadow:0 0 15px rgba(59,130,246,.2)}.tab-content{width:100%;max-width:800px;display:none}.tab-content.active{display:block}.log-container{display:flex;flex-direction:column;gap:10px;max-height:60vh;overflow-y:auto}.log-item{display:flex;justify-content:space-between;align-items:center;padding:15px;background:rgba(0,0,0,.2);border-radius:8px;border-left:4px solid var(--border-color)}.log-item.goal{border-left-color:var(--accent-goal)}.log-item.point{border-left-color:var(--accent-point)}.log-item.wide{border-left-color:var(--accent-wide)}.log-item.turnover_lost,.log-item.turnover_won{border-left-color:var(--accent-turnover)}.log-item.foul{border-left-color:var(--accent-foul)}.log-item.kickout{border-left-color:var(--accent-kickout)}.log-item.yellow_card{border-left-color:var(--accent-yellow)}.log-item.black_card{border-left-color:var(--accent-black)}.log-item.red_card{border-left-color:var(--accent-red-card)}.log-item.block{border-left-color:var(--accent-block)}.log-time{font-family:Outfit,sans-serif;font-weight:700;color:var(--text-muted);width:60px}.log-who{flex:1;font-weight:600}.log-what{font-weight:600;text-transform:uppercase;font-size:.85rem;padding:4px 8px;border-radius:4px;background:rgba(255,255,255,.1)}.chip-group{align-items:flex-start;flex-wrap:wrap}.heatmap-pitch .pin{pointer-events:none}.filter-chips-container{display:flex;flex-direction:column;gap:15px;margin-bottom:15px}.chip-group{display:flex;align-items:center;gap:10px}.chip-label{font-weight:600;color:var(--text-muted);min-width:75px}.chip-scroll{display:flex;flex-wrap:wrap;gap:8px;padding-bottom:4px}.chip-scroll::-webkit-scrollbar{display:none}.chip{background:rgba(255,255,255,.1);border:1px solid var(--border-color);color:var(--text-main);padding:8px 16px;border-radius:20px;font-family:Inter,sans-serif;font-size:.9rem;font-weight:600;cursor:pointer;white-space:nowrap;transition:all .2s}.chip.active{background:var(--accent-blue);border-color:var(--accent-blue);box-shadow:0 0 10px rgba(59,130,246,.3)}.summary-stats-bar{text-align:center;padding:12px;margin-bottom:20px}.summary-total{font-weight:800;font-size:1.1rem;color:var(--accent-blue);margin-bottom:5px}.summary-insights{font-size:.85rem;color:var(--text-muted);display:flex;flex-direction:column;gap:3px}.event-detail-card{position:absolute;bottom:20px;left:50%;transform:translateX(-50%);width:90%;max-width:400px;z-index:60;border:2px solid var(--accent-blue);animation:slideUp .3s ease}.event-detail-card.hidden{display:none}.detail-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;border-bottom:1px solid var(--border-color);padding-bottom:10px}.detail-header h3{font-size:1.2rem;color:#fff}.detail-header span{font-family:Outfit,sans-serif;color:var(--text-muted);font-weight:700}.detail-body{font-size:1rem;font-weight:600;color:var(--text-main);text-transform:uppercase}.heatmap-pitch{margin:0 auto}.heatmap-pitch .pin{box-shadow:0 0 15px 5px currentColor;opacity:.8;animation:none}.controls{margin-top:30px;display:flex;gap:15px}@media (max-width:600px){body{padding:10px}header{flex-direction:column;gap:10px;margin-bottom:20px}.scoreboard{width:100%;justify-content:space-around}.score-display,.timer{font-size:2rem}.event-grid{gap:8px}.btn{padding:10px 8px;font-size:.85rem}.roster-grid{gap:5px}.btn-roster{padding:8px 0;font-size:.9rem}.dashboard-tabs{flex-direction:column;gap:5px}.log-item{padding:10px;flex-wrap:wrap;gap:5px}.log-what{font-size:.75rem}.controls{flex-wrap:wrap;justify-content:center}.controls .btn{flex:1 1 45%}}.pin-wrapper{position:absolute;z-index:10}.pin-wrapper:hover{z-index:1000}.pin-tooltip{visibility:hidden;opacity:0;transition:opacity .2s ease,transform .2s ease;position:absolute;bottom:15px;left:50%;transform:translateX(-50%) translateY(10px);background:rgba(0,0,0,.9);color:white;padding:8px 12px;border-radius:8px;font-size:12px;white-space:nowrap;border:1px solid var(--accent-blue);box-shadow:0 4px 10px rgba(0,0,0,.5);pointer-events:none;font-family:Inter,sans-serif;text-align:center}.pin-wrapper:hover .pin-tooltip{visibility:visible;opacity:1;transform:translateX(-50%) translateY(0)}.dashboard-header-container{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:25px;width:100%;gap:15px}.dashboard-header-title{min-width:0}.dashboard-header-title h1,.dashboard-header-title h2{color:white;margin:0;font-size:1.4rem;line-height:1.2}.dashboard-header-title p{color:var(--text-muted);margin:4px 0 0;font-size:.85rem}.dashboard-header-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}.feedback-btn{background:var(--accent-blue);color:white;border:none;padding:8px 15px;font-weight:700;cursor:pointer;display:flex;align-items:center;gap:8px;font-size:.9rem;border-radius:8px;transition:all .2s}.feedback-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,.2)}@media (max-width:600px){.dashboard-header-container{flex-direction:column;align-items:flex-start;gap:10px;margin-bottom:20px}.dashboard-header-title{text-align:left}.dashboard-header-title h1,.dashboard-header-title h2{font-size:1.3rem}.dashboard-header-actions{justify-content:flex-start;flex-wrap:wrap;gap:8px;width:100%}.feedback-btn-text,.role-switcher-label{display:none}.feedback-btn{padding:8px 10px}}.stats-table{width:100%;border-collapse:collapse;margin:15px 0;font-family:Inter,sans-serif;color:var(--text-main);background:rgba(0,0,0,.2);border-radius:8px;overflow:hidden}.stats-table td,.stats-table th{padding:12px 16px;text-align:center}.stats-table th{background:rgba(255,255,255,.05);font-family:Outfit,sans-serif;font-weight:700;color:var(--accent-blue);border-bottom:1px solid var(--border-color)}.stats-table td{border-bottom:1px solid rgba(255,255,255,.05);font-weight:500}.stats-table td:first-child,.stats-table th:first-child{text-align:left;font-weight:600;color:var(--text-muted)}.stats-table tr:hover td{background:rgba(255,255,255,.02)}.stats-table tr:last-child td{border-bottom:none}#printable-report-area{display:none}@media print{*{-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important}body{background:#ffffff!important;color:#000000!important;font-family:Inter,sans-serif;padding:0!important;margin:0!important}body>:not(#printable-report-area){display:none!important}#printable-report-area{display:block!important;width:100%!important;max-width:800px;margin:0 auto;padding:20px;color:#0f172a!important;background:#ffffff!important}.print-header{text-align:center;border-bottom:2px solid #e2e8f0;padding-bottom:20px;margin-bottom:25px}.print-header h1{font-family:Outfit,sans-serif;font-size:2.2rem;color:#1e3a8a!important;margin-bottom:5px}.print-header .print-meta{font-size:.95rem;color:#475569!important;font-weight:500}.print-score-banner{display:flex;justify-content:space-around;align-items:center;background:#f1f5f9!important;border:1px solid #cbd5e1;border-radius:12px;padding:15px;margin-bottom:30px}.print-team-score{text-align:center;flex:1}.print-team-score .team-name{font-size:1.3rem;font-weight:800;color:#0f172a!important;margin-bottom:5px}.print-team-score .score{font-family:Outfit,sans-serif;font-size:2.2rem;font-weight:900;color:#1e3a8a!important}.print-vs{font-size:1.2rem;font-weight:800;color:#64748b!important;padding:0 15px}.print-section{margin-bottom:35px;page-break-inside:avoid}.print-section h2{font-family:Outfit,sans-serif;font-size:1.5rem;color:#1e3a8a!important;border-bottom:1.5px solid #cbd5e1;padding-bottom:8px;margin-bottom:15px}.print-stats-table{width:100%;border-collapse:collapse;margin:10px 0}.print-stats-table td,.print-stats-table th{padding:10px 12px;text-align:center;border-bottom:1px solid #e2e8f0}.print-stats-table th{background:#f8fafc!important;color:#1e3a8a!important;font-weight:700;border-bottom:2px solid #cbd5e1}.print-stats-table td{color:#334155!important;font-weight:500}.print-stats-table td:first-child,.print-stats-table th:first-child{text-align:left;color:#0f172a!important;font-weight:600}.print-stats-table tr:nth-child(2n){background:#f8fafc!important}.print-page-break{page-break-before:always}.print-heatmap-layout{display:flex;flex-direction:column;align-items:center;gap:15px}.print-legend{display:flex;flex-wrap:wrap;justify-content:center;gap:15px;font-size:.85rem;font-weight:600;color:#475569!important;margin-bottom:10px}.legend-item{display:flex;align-items:center;gap:6px}.legend-color{width:12px;height:12px;border-radius:50%;border:1px solid rgba(0,0,0,.5)}.legend-color.square{border-radius:2px}.legend-color.triangle{clip-path:polygon(50% 0,0 100%,100% 100%);border-radius:0;border:none;width:14px;height:12px}.printable-pitch{background:#f1f5f9!important;border:3px solid #475569!important;box-shadow:none!important;width:320px!important;margin:15px auto!important;aspect-ratio:1/1.6!important;position:relative;border-radius:12px;overflow:hidden}.printable-pitch .pitch-lines div{background-color:#64748b!important;border-color:#64748b!important}.printable-pitch .arc-bottom,.printable-pitch .arc-top,.printable-pitch .goal-bottom,.printable-pitch .goal-top{border-color:#64748b!important}.printable-pitch .zone-label-attack,.printable-pitch .zone-label-defense{color:#94a3b8!important}.printable-pitch .pin{box-shadow:0 0 0 1.5px #000000!important;opacity:1!important;-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important}}