.navbar{padding:1rem;position:fixed;width:100%;height:90px;top:0;z-index:1000;font-family:Inter,sans-serif}.navbar-container{max-width:1500px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;padding:0 1rem}.navbar-logo{text-decoration:none;display:flex;align-items:center;gap:.5rem}.navbar-logo img{height:80px;width:auto;margin-top:-15px!important}.navbar-logo span{font-size:1.5rem;font-weight:700}.nav-links{display:flex;gap:2rem}.nav-link{text-decoration:none;font-weight:400;transition:opacity .2s}.nav-link:hover{opacity:.8}.hamburger-menu{display:none;background:none;border:none;font-size:1.5rem;cursor:pointer}.language-flag{width:24px;height:16px;display:inline-block;vertical-align:middle;cursor:pointer}@media (max-width: 768px){.navbar-logo img{height:60px}.navbar-logo span{font-size:1.2rem}.hamburger-menu{display:block}.nav-links{display:none;flex-direction:column;position:absolute;top:100%;left:0;right:0;padding:1rem}.nav-links.open{display:flex}.nav-link{padding:.5rem 0}}:root{--blue-main: #1F5D5E}.footer{background-color:var(--blue-main);color:#fff;padding:1rem;margin-top:auto;font-family:Inter,sans-serif;justify-items:center;position:fixed;bottom:0;width:100%;z-index:1000}.footer-container{max-width:1500px;width:100%;display:flex;justify-content:space-between;align-items:center}.footer-title{font-weight:700}.footer-links{font-size:.7rem;display:flex;gap:2rem}.footer-copyright{font-weight:400}@media (max-width: 768px){.footer-container{flex-direction:column;gap:1rem;text-align:center}.footer-links{flex-direction:column;gap:1rem}}.home-container{padding-top:64px;font-family:Inter,sans-serif;height:calc(100vh - 60px);width:100%;overflow:auto}.hero{position:relative;padding:4rem 2rem;text-align:center;overflow:hidden;height:600px}.hero-background{position:absolute;top:0;left:0;right:0;bottom:0;background-size:cover;background-position:center;z-index:0}.hero-overlay{position:absolute;opacity:.9;top:0;left:0;right:0;bottom:0;z-index:1}.hero-content{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center}.hero-logo{height:450px;width:auto;margin-top:-6.5rem;margin-bottom:-3.5rem}.hero-title{font-size:3rem;margin-bottom:1rem;font-family:Montserrat,sans-serif;font-weight:700}.hero-subtitle{font-size:1.2rem;max-width:600px;margin:1rem auto;font-weight:400}.playstore-button{display:inline-block;transition:all .2s ease;margin-top:2rem}.playstore-button:hover{opacity:.8}.playstore-badge{height:60px;width:auto}.main-content{max-width:1200px;margin:4rem auto;padding:0 2rem}.features-section{margin-bottom:4rem}.features-title{text-align:center;margin-bottom:3rem;font-family:Montserrat,sans-serif;font-weight:700}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem;margin-top:2rem}.feature-card{padding:2rem;border-radius:8px;box-shadow:0 2px 4px #0000001a}.feature-card-title{margin-bottom:1rem;font-family:Montserrat,sans-serif;font-weight:700}@media (max-width: 768px){.hero{height:auto;padding:2rem 1rem}.hero-logo{height:300px;margin-top:-3rem;margin-bottom:-2rem}.hero-title{font-size:2rem}.hero-subtitle{font-size:1rem}}.contact-section{margin-top:4rem;padding:3rem 0;background:#f8f9fa;border-radius:12px}.contact-title{text-align:center;margin-bottom:2rem;font-family:Montserrat,sans-serif;font-weight:700;font-size:2rem}.contact-form-container{max-width:600px;margin:0 auto;padding:0 2rem}.contact-form{background:white;padding:2rem;border-radius:8px;box-shadow:0 2px 10px #0000001a}.form-group{margin-bottom:1.5rem}.form-label{display:block;margin-bottom:.5rem;font-weight:600;color:#333;font-size:.9rem}.form-input,.form-textarea{width:100%;padding:.75rem;border:2px solid #e1e5e9;border-radius:6px;font-size:1rem;font-family:inherit;transition:border-color .3s ease;box-sizing:border-box}.form-input:focus,.form-textarea:focus{outline:none;border-color:var(--blue-main, #1F5D5E);box-shadow:0 0 0 3px #1f5d5e1a}.form-textarea{resize:vertical;min-height:120px}.contact-submit-btn{background:var(--blue-main, #1F5D5E);color:#fff;border:none;padding:1rem 2rem;border-radius:6px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;width:100%;font-family:inherit}.contact-submit-btn:hover{background:#164a4b;transform:translateY(-1px);box-shadow:0 4px 12px #1f5d5e4d}.contact-submit-btn:active{transform:translateY(0)}@media (max-width: 768px){.contact-section{margin-top:2rem;padding:2rem 0}.contact-title{font-size:1.5rem;margin-bottom:1.5rem}.contact-form-container{padding:0 1rem}.contact-form{padding:1.5rem}}.match-card{padding:15px 20px;background:rgba(255,255,255,.9);border-radius:6px;margin-bottom:.75rem;cursor:pointer;transition:background-color .2s}.match-card:hover{background:white}.match-card .score-container{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-top:5px}.match-card .team-name{flex:1;font-size:1.2rem!important;color:var(--blue-main)!important;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding:.5rem}.match-card .score-box{background:var(--blue-main);padding:.25rem .75rem;border-radius:4px;min-width:32px;text-align:center}.match-card .score-box span{font-size:1.5rem!important}.matches-container{position:relative;min-height:100vh;width:100%;margin-bottom:60px;overflow:hidden}.matches-background{position:fixed;top:0;left:0;width:100%;height:100%;background-size:cover;background-position:center;background-repeat:no-repeat;z-index:1}.matches-overlay{position:fixed;top:0;left:0;width:100%;height:100%;opacity:.85;z-index:2}.matches-content{position:relative;z-index:3;padding-top:100px}.matches-content main{max-width:800px;margin:0 auto;padding:0 1rem}.matches-title{color:#fff;text-align:center;margin-bottom:2rem;margin-top:2rem}.matches-list{display:flex;flex-direction:column;gap:.5rem}.no-matches{text-align:center;color:var(--grey-main)}.matches-header{margin-bottom:2rem}.search-container{max-width:300px;margin:0 auto 2rem}.search-input{width:100%;padding:.5rem 1rem;border:none;border-radius:4px;background:rgba(255,255,255,.9);font-size:1rem;transition:all .3s ease}.search-input:focus{outline:none;border-color:var(--blue-light);box-shadow:0 0 0 3px #4299e180}.loading,.error{text-align:center;color:var(--white-main);padding:2rem}.event-header{margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid rgba(255,255,255,.2);justify-content:center;display:flex;align-items:center}.event-name{font-weight:500;color:var(--blue-main)!important;text-transform:uppercase;letter-spacing:.5px;font-size:12px!important}@media (max-width: 768px){.matches-list{grid-template-columns:1fr}.match-card{padding:12px 15px}.match-card .team-name{font-size:.9rem!important}.match-card .score-box{width:40px;height:40px;font-size:1.2rem!important}.event-name{font-size:11px!important}}@media (max-width: 640px){.matches-content{padding-top:80px}.match-card{padding:.75rem 1rem}.score-container{grid-template-columns:1.5fr 40px 40px 1.5fr;gap:.5rem}}.kpi-container{min-height:200px;position:relative;background:rgba(255,255,255,.9);border-radius:8px;box-shadow:0 2px 4px #0000001a;overflow:hidden;justify-items:center}.kpi-container h3{text-align:center;color:var(--blue-main)}.kpi-container.loading{display:flex;flex-direction:column;justify-content:center;align-items:center;min-height:200px}.kpi-container.error{display:flex;flex-direction:column;justify-content:center;align-items:center;min-height:400px;border-left:4px solid #e74c3c}.loading-spinner{width:50px;height:50px;border:4px solid #f3f3f3;border-top:4px solid var(--blue-main);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-text{color:var(--blue-main);font-size:14px;font-weight:500}.error-text{color:#e74c3c;font-size:14px;text-align:center;max-width:300px}.retry-button{margin-top:10px;padding:8px 16px;background:var(--blue-main);color:#fff;border:none;border-radius:4px;cursor:pointer;transition:background .2s ease}.retry-button:hover{background:#154c4d}.fade-in{animation:fadeIn .3s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.kpi-card{background:rgba(255,255,255,.9);border-radius:8px;padding:1rem;margin:10px 0;box-shadow:0 2px 4px #0000001a;text-align:center;min-width:150px;min-height:120px;display:flex;flex-direction:column;justify-content:center;align-items:center}.kpi-card.loading .loading-spinner{width:30px;height:30px;border-width:3px;margin-bottom:.5rem}.kpi-card.loading .loading-text{font-size:12px}.kpi-card h2{font-size:1rem;margin-bottom:.5rem;color:var(--blue-main);font-weight:600}.kpi-subtitle{font-size:.8rem;color:#666;margin-bottom:1rem;text-align:center}.kpi-value{font-size:3rem;font-weight:700;color:var(--dark-green-main);margin:45px auto}.kpi-card.error{border-left:4px solid #e74c3c}.kpi-card.error .error-text{font-size:.9rem;max-width:none}.heatmap-container{width:100%;max-width:none;margin:0;padding:1rem;background:white;border-radius:8px;box-shadow:0 2px 4px #0000001a;min-height:500px;position:relative}.heatmap-container.loading,.heatmap-container.error{display:flex;flex-direction:column;justify-content:center;align-items:center;min-height:600px}.heatmap-container h2{text-align:center;color:var(--blue-main);margin-bottom:1rem;font-size:1rem;font-weight:600}.heatmap-grid{display:grid;grid-template-columns:60px 1fr;grid-template-rows:1fr auto auto;gap:8px;width:100%}.heatmap-y-label{grid-column:1;grid-row:1;display:flex;align-items:center;justify-content:center;writing-mode:vertical-rl;text-orientation:mixed;padding:8px;background:#f8f9fa;border-radius:4px}.heatmap-main{grid-column:2;grid-row:1;display:flex;gap:3px;width:100%;height:100%}.heatmap-axis.y-axis{display:flex;flex-direction:column;justify-content:space-between;min-width:30px;height:100%}.heatmap-content{flex:1;height:100%;width:100%}.heatmap-cells{display:flex;flex-direction:column;height:100%;width:100%;gap:1px}.heatmap-row{display:flex;flex:1;width:100%;gap:1px}.heatmap-cell{flex:1;min-width:30px;min-height:30px;border:1px solid #e5e5e5;display:flex;flex-direction:column;align-items:center;justify-content:center;font-size:.65rem;position:relative;cursor:pointer;transition:all .2s ease}.heatmap-axis.x-axis{grid-column:2;grid-row:2;display:flex;justify-content:space-between;align-items:center;padding:0 3px;height:35px}.heatmap-x-label{grid-column:1 / 3;grid-row:3;display:flex;align-items:center;justify-content:center;padding:8px;background:#f8f9fa;border-radius:4px;margin-top:5px}.axis-label{display:flex;align-items:center;justify-content:center;font-weight:700;color:var(--blue-main);font-size:.7rem;min-width:25px;height:25px;background:#f8f9fa;border-radius:3px}.axis-title{font-weight:700;font-size:14px;color:#1f5d5e;letter-spacing:1px}.cell-content{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;height:100%}.cell-count{font-weight:700;color:#fff;text-shadow:1px 1px 2px rgba(0,0,0,.7);margin-bottom:1px;font-size:.65rem}.cell-winrate{font-size:.5rem;color:#fff;text-shadow:1px 1px 2px rgba(0,0,0,.7)}.heatmap-cell.empty{background:#f8f9fa;opacity:.3}.heatmap-cell.filled:hover{transform:scale(1.05);z-index:10;border-color:var(--blue-main);box-shadow:0 2px 8px #0003}.heatmap-cell.selected{transform:scale(1.05);z-index:10;border:2px solid var(--blue-main);box-shadow:0 2px 8px #1f5d5e66}.heatmap-cell.filled{cursor:pointer}.selected-cell-info{background:var(--blue-main);color:#fff;padding:10px 15px;border-radius:6px;margin-bottom:15px;font-size:.9rem;text-align:center;box-shadow:0 2px 4px #0000001a}@media (hover: none) and (pointer: coarse){.heatmap-cell.filled:hover{transform:none;z-index:auto;border-color:transparent;box-shadow:none}}.break-probability-chart{width:100%;max-width:none;margin:0;padding:20px;min-height:600px;position:relative;background:white;border-radius:8px;box-shadow:0 2px 4px #0000001a}.break-probability-chart.loading,.break-probability-chart.error{display:flex;flex-direction:column;justify-content:center;align-items:center;min-height:600px}.chart-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;flex-wrap:wrap;gap:10px}.chart-header h2{margin:0;color:var(--blue-main);font-size:1rem;font-weight:600}.view-toggle{display:flex;border:1px solid var(--blue-main);border-radius:6px;overflow:hidden}.view-toggle button{padding:8px 16px;border:none;background:white;color:var(--blue-main);cursor:pointer;transition:all .2s ease;font-size:14px}.view-toggle button:hover{background:#f0f8ff}.view-toggle button.active{background:var(--blue-main);color:#fff}.stats-summary{display:flex;gap:20px;margin-bottom:20px;flex-wrap:wrap}.stat-item{display:flex;flex-direction:column;align-items:center;padding:12px;background:#f8f9fa;border-radius:8px;min-width:120px}.stat-label{font-size:12px;color:#666;margin-bottom:4px;text-align:center}.stat-value{font-size:18px;font-weight:700;color:var(--blue-main);margin-left:10px}.chart-container{width:100%;margin:20px 0;background:white;border-radius:8px;padding:20px;box-shadow:0 2px 4px #0000001a}.break-tooltip{background:white;border:1px solid #ccc;border-radius:6px;padding:12px;box-shadow:0 2px 8px #00000026}.tooltip-label{font-weight:700;margin:0 0 8px;color:var(--blue-main)}.tooltip-value{margin:0 0 4px}.tooltip-prob{font-weight:700;color:#1f5d5e}.tooltip-details{margin:0;font-size:12px;color:#666}.chart-insights{margin-top:20px;padding:16px;background:#f8f9fa;border-radius:8px;border-left:4px solid var(--blue-main)}.chart-insights h4{margin:0 0 12px;color:var(--blue-main);font-size:16px}.chart-insights ul{margin:0;padding-left:20px}.chart-insights li{margin-bottom:8px;color:#555;line-height:1.4}.player-stats-container{width:100%;max-width:none;margin:0;padding:1.5rem;background:white;border-radius:8px;box-shadow:0 2px 4px #0000001a}.player-stats-header{margin-bottom:1.5rem;text-align:center}.player-stats-header h2{color:var(--blue-main);margin-bottom:1rem;font-size:1rem;font-weight:600}.player-stats-summary{display:flex;justify-content:center;gap:2rem;margin-bottom:1rem}.summary-item{padding:.5rem 1rem;background:#f8f9fa;border-radius:20px;font-size:.9rem;color:var(--blue-main);font-weight:500}.player-stats-controls{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding:1rem;background:#f8f9fa;border-radius:8px}.control-group{display:flex;align-items:center;gap:.5rem}.control-group label{font-weight:500;color:var(--blue-main);white-space:nowrap}.control-select{padding:.5rem;border:1px solid #ddd;border-radius:4px;background:white;font-size:.9rem;cursor:pointer}.player-stats-table-container{overflow-x:auto;border-radius:8px;border:1px solid #e5e5e5}.player-stats-table{width:100%;border-collapse:collapse;background:white}.player-stats-table th{background:var(--blue-main);color:#fff;padding:1.2rem .5rem;text-align:left;font-weight:600;position:sticky;top:0;z-index:10}.player-stats-table th.stat-col{cursor:pointer;transition:background-color .2s ease;text-align:center}.player-stats-table th.stat-col:hover{background:#154c4d}.player-stats-table th.active-sort{background:#0a3334;position:relative}.player-stats-table th.active-sort:after{content:" ▼";font-size:.8rem}.player-stats-table td{padding:.75rem;border-bottom:1px solid #f0f0f0}.rank-col{width:5%}.name-col{width:25%}.team-col{width:20%}.stat-col{width:10%;text-align:center}.player-row:nth-child(2n){background:#fafafa}.player-row:hover{background:#f0f8ff}.rank-cell{text-align:center}.rank-badge{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:50%;background:#e9ecef;color:#495057;font-weight:700;font-size:.9rem}.rank-badge.rank-1{background:#ffd700;color:#856404}.rank-badge.rank-2{background:#c0c0c0;color:#495057}.rank-badge.rank-3{background:#cd7f32;color:#fff}.name-cell{font-weight:600;color:var(--blue-main)}.team-cell{color:#6c757d;font-size:.9rem}.stat-cell{text-align:center;font-weight:500}.total-cell{color:var(--blue-main);font-size:1.1rem}.no-data{text-align:center;padding:2rem;color:#6c757d;font-style:italic}.top-players-chart{padding:20px;min-height:500px;position:relative}.top-players-chart.loading,.top-players-chart.error{display:flex;flex-direction:column;justify-content:center;align-items:center;min-height:500px}.players-list{display:flex;flex-direction:column;gap:10px;margin-top:20px}.player-item{display:flex;justify-content:space-between;align-items:center;padding:12px;background:#f8f9fa;border-radius:8px;border-left:4px solid var(--blue-main)}.player-info{display:flex;flex-direction:column}.player-name{font-weight:700;color:var(--blue-main)}.player-team{font-size:12px;color:#666}.player-stats{text-align:right}.player-value{font-size:18px;font-weight:700;color:var(--dark-green-main)}.player-details{font-size:12px;color:#666}.team-comparison{padding:20px;min-height:400px;position:relative}.team-comparison.loading,.team-comparison.error{display:flex;flex-direction:column;justify-content:center;align-items:center;min-height:400px}.comparison-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:20px}.team-card{padding:16px;background:#f8f9fa;border-radius:8px;text-align:center}.team-name{font-weight:700;font-size:18px;color:var(--blue-main);margin-bottom:10px}.team-metric{display:flex;justify-content:space-between;margin:8px 0;padding:4px 0;border-bottom:1px solid #e0e0e0}.metric-label{color:#666}.metric-value{font-weight:700;color:var(--dark-green-main)}.match-timeline{padding:20px;min-height:600px;position:relative}.match-timeline.loading,.match-timeline.error{display:flex;flex-direction:column;justify-content:center;align-items:center;min-height:600px}.timeline-container{position:relative;margin:20px 0}.timeline-point{position:absolute;width:12px;height:12px;border-radius:50%;background:var(--blue-main);border:2px solid white;box-shadow:0 2px 4px #0003}.timeline-line{position:absolute;height:2px;background:var(--blue-main);top:50%;transform:translateY(-50%)}.skeleton{background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0 50%,#f0f0f0 75%);background-size:200% 100%;animation:skeleton-loading 1.5s infinite}@keyframes skeleton-loading{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-text{height:20px;border-radius:4px;margin-bottom:10px}.skeleton-text.small{width:60%}.skeleton-text.medium{width:80%}.skeleton-text.large{width:100%}.skeleton-chart{width:100%;height:300px;border-radius:8px;margin:20px 0}@media (max-width: 1024px){.heatmap-container{max-width:800px}.heatmap-grid{height:450px}.heatmap-cell{max-width:25px;max-height:25px;min-width:18px;min-height:18px;font-size:.6rem}.axis-label{min-width:22px;height:22px;font-size:.65rem}}@media (max-width: 768px){.kpi-container{min-height:300px}.heatmap-container{padding:.5rem;margin:1rem 0;max-width:600px;min-height:500px}.heatmap-grid{grid-template-columns:50px 1fr;height:350px;gap:5px}.heatmap-cell{max-width:20px;max-height:20px;min-width:15px;min-height:15px;font-size:.5rem}.axis-label{min-width:18px;height:18px;font-size:.6rem}.axis-title{font-size:12px}.cell-winrate{display:none}.break-probability-chart,.top-players-chart,.match-timeline{min-height:400px;padding:10px}.team-comparison{min-height:300px;padding:10px}.loading-spinner{width:40px;height:40px;border-width:3px}.kpi-card{min-height:100px}.kpi-card.loading .loading-spinner{width:25px;height:25px;border-width:2px}.chart-header{flex-direction:column;align-items:stretch}.stats-summary{flex-direction:column}.stat-item{flex-direction:row;justify-content:space-between;align-items:center}.view-toggle{width:100%}.view-toggle button{flex:1}.comparison-grid{grid-template-columns:1fr}.player-stats-summary{flex-direction:column;gap:.5rem}.player-stats-controls{flex-direction:column;gap:1rem;align-items:stretch}.control-group{justify-content:space-between}.rank-col{width:10%}.name-col{width:40%}.team-col{width:30%}.stat-col{width:20%}.player-stats-table th,.player-stats-table td{padding:.5rem .25rem;font-size:.85rem}.rank-badge{width:25px;height:25px;font-size:.8rem}}@media (max-width: 480px){.kpi-container{min-height:250px}.heatmap-container{max-width:400px;margin:0}.heatmap-grid{grid-template-columns:40px 1fr;height:300px}.heatmap-cell{max-width:15px;max-height:15px;min-width:12px;min-height:12px;font-size:.45rem}.axis-label{min-width:15px;height:15px;font-size:.55rem}.cell-count{font-size:.45rem}.break-probability-chart,.top-players-chart,.match-timeline{min-height:350px;padding:10px}.team-comparison{min-height:250px;padding:10px}.loading-spinner{width:35px;height:35px}.kpi-card{min-height:80px}.team-col,.team-cell{display:none}.name-col{width:180px}}.pie-chart-container{display:flex;flex-direction:column;align-items:center;gap:20px}.pie-chart-container .recharts-legend-wrapper{padding-top:10px!important}.pie-chart-container .recharts-legend-item{display:inline-block!important;margin:2px 6px!important;vertical-align:middle!important}.pie-chart-container .recharts-legend-item-text{font-size:11px!important;margin-left:4px!important}.custom-tooltip{background:rgba(0,0,0,.8);border:none;border-radius:8px;padding:10px;color:#fff;font-size:.9rem}.tooltip-label{margin:0 0 5px;font-weight:600}.tooltip-value{margin:0;color:#ccc}.distribution-stats{display:flex;flex-direction:column;gap:8px;background:#f8f9fa;padding:15px;margin-top:20px;border-radius:8px;width:100%;max-width:300px}.stat-row{display:flex;justify-content:space-between;align-items:center}.stat-label{font-size:.9rem;color:#666}.stat-value{font-size:1.1rem;font-weight:600;color:var(--blue-main)}.kpi-card h2,.kpi-container h2,.heatmap-container h2,.player-stats-container h2,.player-stats-header h2,.chart-header h2{font-size:1rem!important;margin-bottom:.5rem!important;color:var(--blue-main)!important;font-weight:600!important}.kpi-card h2,.kpi-container h2,.heatmap-container h2{text-align:center}.pagination-controls{display:flex;justify-content:center;align-items:center;gap:1rem;margin-top:1.5rem;border-top:1px solid #e5e5e5}.pagination-controls span{font-size:.9rem;color:var(--blue-main);font-weight:500}.pagination-controls .kpi-button{padding:.2rem 1rem;font-size:.9rem;margin:10px}.pagination-controls .kpi-button:disabled{background-color:#e9ecef;color:#6c757d;cursor:not-allowed;opacity:.7}.kpi-header{width:100%;text-align:center;margin-bottom:1.5rem}.kpi-subtitle{font-size:.9rem;color:#6c757d;max-width:600px;margin:.5rem auto 0}.kpi-controls{display:flex;justify-content:center;align-items:flex-end;gap:1.5rem;padding:1rem;background-color:#f8f9fa;border-radius:8px;margin-bottom:1rem;width:100%}.kpi-input-group{display:flex;flex-direction:column}.kpi-input-group label{font-size:.8rem;font-weight:500;color:#495057;margin-bottom:.25rem;text-align:left}.kpi-input{padding:.5rem;border:1px solid #ced4da;border-radius:4px;font-size:1rem;width:80px;text-align:center}.kpi-button{padding:.5rem 1.5rem;font-size:1rem;font-weight:500;background-color:var(--blue-main);color:#fff;border:none;border-radius:4px;cursor:pointer;transition:background-color .2s}.kpi-button:hover{background-color:#154c4d}.kpi-button:disabled{background-color:#e9ecef;color:#6c757d;cursor:not-allowed}@media (max-width: 768px){.kpi-controls{flex-direction:column;align-items:stretch;gap:1rem}.kpi-input-group{align-items:center}.kpi-input{width:100%}}.kpi-tabs{display:flex;justify-content:center;border-bottom:2px solid #e5e5e5;margin-top:1rem;margin-bottom:1.5rem}.kpi-tab{padding:.75rem 1.5rem;cursor:pointer;border:none;background-color:transparent;color:#6c757d;font-weight:500;font-size:1rem;position:relative;transition:color .2s ease-in-out}.kpi-tab:hover{color:var(--blue-main)}.kpi-tab.active{color:var(--blue-main);font-weight:600}.kpi-tab.active:after{content:"";position:absolute;bottom:-2px;left:0;width:100%;height:2px;background-color:var(--blue-main)}.player-row.clickable{cursor:pointer;transition:background-color .2s ease}.player-row.clickable:hover{background-color:#f0f8ff}.details-row td{padding:0!important;border-bottom:2px solid var(--blue-main)}.player-details-content{display:flex;justify-content:space-around;padding:1.5rem;background-color:#f8f9fa}.details-section{width:45%}.details-section h4{margin-top:0;margin-bottom:1rem;color:var(--blue-main);font-size:1rem;border-bottom:1px solid #e5e5e5;padding-bottom:.5rem}.details-section ul{list-style-type:none;padding:0;margin:0}.details-section li{display:flex;justify-content:space-between;padding:.25rem 0;font-size:.9rem;color:#495057}.details-section li:after{content:""}.details-loading{display:flex;flex-direction:column;justify-content:center;align-items:center;padding:2rem;background-color:#f8f9fa}.loading-spinner.small{width:30px;height:30px;border-width:3px}.no-data,.kpi-initial-state{display:flex;justify-content:center;align-items:center;text-align:center;padding:2rem;margin-top:1.5rem;border-radius:8px;width:100%}.no-data{background-color:#fff4f4;color:#d9534f;border:1px dashed #d9534f}.kpi-initial-state{background-color:#f0f8ff;color:#4a90e2;border:1px dashed #4a90e2}.no-data p,.kpi-initial-state p{margin:0;font-weight:500}.kpi-dual-view{display:flex;gap:2rem;width:100%;margin-top:1.5rem}.kpi-chart-container{flex:3;min-width:350px;display:flex;flex-direction:column;align-items:center;min-height:400px;height:auto}.kpi-table-container{flex:2;overflow-x:auto}@media (max-width: 992px){.kpi-dual-view{flex-direction:column;align-items:center}.kpi-chart-container{width:100%;max-width:400px}.kpi-table-container{width:100%}}:root{--blue-main: #1F5D5E;--black-main: #000000;--grey-main: #666666;--white-main: #FFFFFF;--dark-green-main: #4CB3A0}.statistics-container{padding:20px;max-width:1400px;margin:100px auto 150px}.statistics-header{margin-bottom:30px}.statistics-title{color:var(--blue-main);margin-bottom:20px;font-size:2.5rem;text-align:center}.statistics-kpis{display:grid;grid-template-columns:repeat(2,minmax(300px,1fr));gap:20px;margin-bottom:30px}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px;margin-bottom:30px}.statistics-charts{display:grid;grid-template-columns:1fr;gap:30px}.statistics-filters{background:white;border-radius:12px;padding:20px;box-shadow:0 2px 8px #0000001a;margin-bottom:20px}.filters-row{display:flex;gap:20px;align-items:flex-end;flex-wrap:wrap}.filter-group{display:flex;flex-direction:column;min-width:200px;flex:1}.filter-label{font-weight:600;color:var(--blue-main);margin-bottom:8px;font-size:.9rem}.filter-select{padding:10px 12px;border:2px solid #e1e5e9;border-radius:8px;font-size:.95rem;background:white;transition:border-color .2s ease;cursor:pointer}.filter-select:focus{outline:none;border-color:var(--blue-main);box-shadow:0 0 0 3px #1f5d5e1a}.filter-select:disabled{background:#f5f5f5;cursor:not-allowed}.filter-actions{display:flex;align-items:center}.reset-filters-btn{padding:10px 20px;background:#6c757d;color:#fff;border:none;border-radius:8px;font-size:.9rem;cursor:pointer;transition:background-color .2s ease}.reset-filters-btn:hover:not(:disabled){background:#5a6268}.reset-filters-btn:disabled{background:#ccc;cursor:not-allowed}.active-filters{margin-top:15px;padding-top:15px;border-top:1px solid #e1e5e9;display:flex;gap:10px;align-items:center;flex-wrap:wrap}.active-filters-label{font-weight:600;color:#666;font-size:.9rem}.filter-tag{display:inline-flex;align-items:center;gap:8px;background:var(--blue-main);color:#fff;padding:6px 12px;border-radius:20px;font-size:.85rem;font-weight:500}.remove-filter{background:rgba(255,255,255,.3);border:none;color:#fff;border-radius:50%;width:18px;height:18px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:12px;transition:background-color .2s ease}.remove-filter:hover{background:rgba(255,255,255,.5)}.data-disclaimer{margin-bottom:30px}.disclaimer-content{background:linear-gradient(135deg,#fff3cd,#ffeaa7);border:1px solid #f39c12;border-radius:12px;padding:20px;display:flex;align-items:flex-start;gap:15px;box-shadow:0 2px 8px #f39c121a}.disclaimer-icon{font-size:1.5rem;flex-shrink:0;margin-top:2px}.disclaimer-text{flex:1}.disclaimer-text p{margin:0;color:#856404;line-height:1.5}.disclaimer-text p:first-child{font-weight:600;margin-bottom:8px;font-size:1.1rem}.disclaimer-details{font-size:.95rem;opacity:.9}.multiselect-actions{display:flex;gap:8px;padding:8px 12px;border-bottom:1px solid #f0f0f0;background-color:#f8f9fa}.select-all-btn,.deselect-all-btn{flex:1;padding:6px 12px;border:1px solid #ddd;border-radius:4px;background:white;color:#666;font-size:.8rem;cursor:pointer;transition:all .2s ease}.select-all-btn:hover{background:var(--blue-main);color:#fff;border-color:var(--blue-main)}.deselect-all-btn:hover{background:#dc3545;color:#fff;border-color:#dc3545}.select-all-btn:disabled,.deselect-all-btn:disabled{background:#f5f5f5;color:#999;cursor:not-allowed;border-color:#ddd}.multiselect-search{padding:8px 12px;border-bottom:1px solid #f0f0f0;background-color:#fafafa}.search-input{width:100%;padding:8px 12px;border:1px solid #ddd;border-radius:4px;font-size:.9rem;outline:none;transition:border-color .2s ease}.search-input:focus{border-color:var(--blue-main);box-shadow:0 0 0 2px #1f5d5e1a}.search-input::placeholder{color:#999}.multiselect-container{position:relative}.multiselect-header{padding:10px 12px;border:2px solid #e1e5e9;border-radius:8px;background:white;cursor:pointer;display:flex;justify-content:space-between;align-items:center;transition:border-color .2s ease;font-size:.95rem;color:#555}.multiselect-header:hover{border-color:var(--blue-main)}.multiselect-header:after{content:"▼";font-size:.8rem;color:#666;transition:transform .2s ease}.multiselect-container.open .multiselect-header:after{transform:rotate(180deg)}.multiselect-options{position:absolute;top:100%;left:0;right:0;background:white;border:2px solid var(--blue-main);border-top:none;border-radius:0 0 8px 8px;max-height:200px;overflow-y:auto;z-index:1000;box-shadow:0 4px 12px #00000026;display:none}.multiselect-container.open .multiselect-options{display:block}.multiselect-option{display:flex;align-items:center;padding:10px 12px;cursor:pointer;transition:background-color .2s ease;border-bottom:1px solid #f0f0f0}.multiselect-option:last-child{border-bottom:none}.multiselect-option:hover{background-color:#f8f9fa}.multiselect-option input[type=checkbox]{margin-right:10px;width:16px;height:16px;accent-color:var(--blue-main);cursor:pointer}.checkbox-label{flex:1;cursor:pointer;font-size:.9rem;color:#333}.multiselect-option input[type=checkbox]:checked+.checkbox-label{font-weight:600;color:var(--blue-main)}@media (max-width: 768px){.statistics-container{padding:15px}.statistics-title{font-size:2rem}.filters-row{flex-direction:column;align-items:stretch}.filter-group{min-width:auto}.statistics-kpis,.kpi-grid{grid-template-columns:1fr}.active-filters{flex-direction:column;align-items:flex-start}.multiselect-options{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:90vw;max-width:400px;max-height:60vh;border-radius:12px;border:2px solid var(--blue-main);box-shadow:0 8px 32px #0000004d}.multiselect-container:hover .multiselect-options{display:none}.multiselect-container.open .multiselect-options{display:block}}@media (max-width: 480px){.statistics-filters{padding:15px}.filter-tag{font-size:.8rem;padding:5px 10px}.multiselect-header{font-size:.9rem;padding:8px 10px}.multiselect-option{padding:8px 10px}.checkbox-label{font-size:.85rem}.multiselect-actions{flex-direction:column;gap:6px}.select-all-btn,.deselect-all-btn{font-size:.75rem;padding:5px 8px}.search-input{font-size:.85rem;padding:6px 8px}}.privacy-container{height:calc(100vh - 150px);padding-top:40px;padding-bottom:40px;margin-top:90px;overflow-y:auto}.privacy-main{max-width:800px;margin:0 auto;padding:0 20px}.privacy-title{font-size:2rem;margin-bottom:1rem}.privacy-update{margin-bottom:2rem;font-style:italic}.privacy-section{margin-bottom:2rem}.privacy-section-title{font-size:1.5rem;margin-bottom:1rem}.privacy-section-content{line-height:1.6;white-space:pre-wrap}@media (max-width: 768px){.privacy-container{padding-top:100px}.privacy-main{padding:0 1rem}}.not-found-container{padding-top:140px;min-height:100vh;font-family:Inter,sans-serif;text-align:center}.not-found-title{margin-bottom:1rem;font-family:Montserrat,sans-serif;font-weight:700}.not-found-message{margin-bottom:2rem;font-weight:400}.not-found-link{display:inline-block;padding:.8rem 1.5rem;border-radius:4px;text-decoration:none;font-weight:600}@media (max-width: 768px){.not-found-container{padding-top:100px;padding:100px 1rem 0}}.point-list-header{height:101px;background-color:#fff;width:100%}.point-list-header.absolute{padding-top:10px;position:fixed;top:100px;z-index:9999}.point-list-header.with-shadow{box-shadow:0 2px 4px #0000001a}.header-title{display:flex;align-items:center;justify-content:center;height:25px;gap:10px}.title-text{font-size:20px;color:var(--dark-green-main);font-weight:700}.team-name{width:35%;height:60px;display:flex;justify-content:center;align-items:center}.team-name span{font-size:20px;color:var(--blue-main);font-weight:700}.score-box{width:15%;height:60px;display:flex;justify-content:center;align-items:center;background-color:var(--blue-main)}.score-box span{color:#fff;font-size:40px}.score-separator{width:1px;height:60px;background-color:#fff}.separator-container{display:flex;justify-content:center;align-items:center}.separator-line{width:60%;height:1px;margin:10px;background-color:var(--grey-main)}.point-item-container{display:flex;flex-direction:column;align-items:center;margin-bottom:15px;background-color:#fff;border-radius:8px;box-shadow:0 2px 4px #0000000d}.separator{width:60%;height:1px;margin:10px 0;background-color:var(--grey-main)}.point-header{display:flex;width:100%;justify-content:center;align-items:center;position:relative}.point-index{font-size:20px;color:var(--grey-main);font-weight:700}.delete-button{position:absolute;right:0;top:-10px;width:40px;height:40px;border:none;background:none;cursor:pointer;display:flex;align-items:center;justify-content:center}.point-content{display:flex;flex-direction:column;align-items:center;width:100%}.team-starting{margin-top:10px;font-size:15px;color:var(--dark-green-main);font-weight:700}.team-playing{margin-top:15px;font-size:10px;color:var(--grey-main);font-weight:700}.players-container{display:flex;flex-direction:row;justify-content:center;align-items:center;width:100%;margin:-20px 0}.second-row{margin-top:-30px!important}.player-minia{display:flex;flex-direction:column;align-items:center;padding:5px}.player-number{font-weight:700;color:var(--blue-main)}.player-name{font-size:12px;color:var(--grey-main)}.point-result{display:flex;flex-direction:column;align-items:center;width:100%;margin-bottom:10px}.score-container{padding-top:5px;width:100%;display:flex;justify-content:center;align-items:center}.players-action{display:flex;flex-direction:row;gap:20px}.player-action{display:flex;flex-direction:column;justify-content:center;align-items:center}.score-text{font-size:20px;color:var(--dark-green-main);font-weight:700}.score-display{display:flex;justify-content:center;gap:10px;margin-top:5px;font-size:20px;color:var(--dark-green-main);font-weight:700}.scoring-players{display:flex;gap:20px;margin-top:15px}.player-action span{font-size:10px;color:var(--grey-main);font-weight:700;margin-top:-10px}.player-minia{display:inline-block;transform-origin:center}.player-name{font-family:Arial,sans-serif;-webkit-user-select:none;user-select:none}.player-number{font-family:Arial,sans-serif;font-weight:700;-webkit-user-select:none;user-select:none}.player-minia svg{display:block}.websocket-container{padding:2rem;max-width:800px;margin:0 auto;font-family:Inter,sans-serif}.websocket-title{text-align:center;margin-bottom:2rem;font-family:Montserrat,sans-serif;font-weight:700}.points-page{width:100%;height:calc(100vh - 165px);background-color:var(--white-main)}.points-list{padding:20px;height:calc(100vh - 258px);overflow-y:auto;scroll-behavior:smooth}.points-list::-webkit-scrollbar{width:8px}.points-list::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.points-list::-webkit-scrollbar-thumb{background:#888;border-radius:4px}.points-list::-webkit-scrollbar-thumb:hover{background:#555}.empty-state{text-align:center;padding:40px;color:var(--dark-green-main);font-style:italic;opacity:.4}.connection-status{position:fixed;bottom:60px;right:20px;display:flex;align-items:center;gap:10px;padding:8px;border-radius:20px;z-index:1000}.status-dot{width:12px;height:12px;border-radius:50%;position:relative}.status-dot:after{content:"";position:absolute;top:-4px;left:-4px;right:-4px;bottom:-4px;border-radius:50%;animation:pulse 2s infinite;opacity:.6}.status-dot.connected{background-color:#2ecc71}.status-dot.connected:after{background-color:#2ecc71}.status-dot.disconnected{background-color:#e74c3c}.status-dot.disconnected:after{background-color:#e74c3c}.status-dot.error{background-color:#f1c40f}.status-dot.error:after{background-color:#f1c40f}@keyframes pulse{0%{transform:scale(1);opacity:.6}70%{transform:scale(1.2);opacity:0}to{transform:scale(1);opacity:0}}.livedata-container{padding-top:100px;background-color:var(--white-main)}.tactical-board-container{height:calc(100vh - 145px);background:linear-gradient(135deg,#1a5d1a 0%,#0f3a0f 100%);padding:20px;margin-top:90px;box-sizing:border-box;overflow:hidden}.tactical-board-content{position:relative;height:100%}.zone-materiel{position:absolute;top:20px;right:20px;width:100px;height:460px;background:rgba(255,255,255,.15);border-radius:10px;padding:20px;color:#fff;z-index:5;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);transition:all .3s ease}.zone-supprimer{position:absolute;top:500px;right:20px;width:100px;background:rgba(224,78,51,.15);border-radius:10px;padding:20px;color:#fff;z-index:5;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(224,78,51,.3);transition:all .3s ease;text-align:center}.zone-supprimer.drag-over{background:rgba(224,78,51,.8);border:2px solid #E04E33;box-shadow:0 0 20px #e04e33b3}.zone-materiel h3{margin:0 0 20px;text-align:center;pointer-events:none;-webkit-user-select:none;user-select:none;font-size:14px;font-weight:700;transition:all .3s ease}.zone-supprimer h3{margin:0 0 15px;text-align:center;pointer-events:none;-webkit-user-select:none;user-select:none;font-size:12px;font-weight:700;transition:all .3s ease}.zone-supprimer.drag-over h3{color:#fff;text-shadow:0 0 10px rgba(255,255,255,.8)}.delete-icon{display:flex;justify-content:center;align-items:center;color:#e04e33b3;transition:all .3s ease}.zone-supprimer.drag-over .delete-icon{color:#fff;transform:scale(1.2);filter:drop-shadow(0 0 10px rgba(255,255,255,.8))}.reset-btn{position:absolute;bottom:20px;left:50%;transform:translate(-50%);width:60px;height:40px;padding:8px;background:#E04E33;color:#fff;border:none;border-radius:5px;cursor:pointer;font-weight:700;display:flex;justify-content:center;align-items:center}.reset-btn:hover{background:#c73e1d}.terrain{width:100%;height:100%;border-radius:10px;position:relative;overflow:hidden;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}.terrain:before,.terrain:after{content:"";position:absolute;left:0;width:100%;height:1px;pointer-events:none;background-image:repeating-linear-gradient(to right,rgba(255,255,255,.25) 0 6px,transparent 6px 36px);background-size:36px 1px;background-repeat:repeat-x}.terrain:before{top:0}.terrain:after{bottom:0}.terrain.dragging,.terrain.dragging *{cursor:none!important}.tactical-board-container,.tactical-board-container *{user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}.selected-element svg{filter:drop-shadow(0 0 8px rgba(255,255,0,.9))}.terrain svg{z-index:10}.element-editor{position:absolute;top:20px;right:20px;width:200px;background:rgba(40,40,40,.9);border-radius:10px;padding:20px;color:#fff;z-index:20;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2)}.element-editor h4{margin:0 0 15px;text-align:center}.element-editor .form-group{margin-bottom:15px}.element-editor label{display:block;margin-bottom:5px;font-size:12px}.element-editor input[type=color]{width:100%;height:30px;border:1px solid #555;border-radius:5px;padding:2px}.element-editor input[type=range]{width:100%}.element-editor button{width:100%;padding:8px;margin-top:5px;background:#555;border:none;color:#fff;border-radius:5px;cursor:pointer}.element-editor .close-btn{position:absolute;top:5px;right:10px;background:none;border:none;color:#fff;font-size:20px;width:auto;padding:0;margin:0}*{margin:0;padding:0;box-sizing:border-box}body{margin:0;padding:0;overflow-x:hidden}#root{width:100%;min-height:100vh}.App{display:flex;flex-direction:column;min-height:100vh;text-align:center}.App-logo{height:40vmin;pointer-events:none}@media (prefers-reduced-motion: no-preference){.App-logo{animation:App-logo-spin infinite 20s linear}}.App-header{background-color:#282c34;min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;font-size:calc(10px + 2vmin);color:#fff}.App-link{color:#61dafb}@keyframes App-logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@font-face{font-family:System;src:local("-apple-system"),local("BlinkMacSystemFont"),local("Roboto"),local("Segoe UI"),local("Ubuntu"),local("Cantarell"),local("Noto Sans"),local("sans-serif")}body{font-family:System,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.text-regular{font-weight:400}.text-medium{font-weight:500}.text-bold{font-weight:700}*{box-sizing:border-box;margin:0;padding:0;font-family:System,sans-serif}html,body{height:100%;width:100%}#root{height:100%}button,input{font-family:System,sans-serif}
