*{box-sizing:border-box;margin:0;padding:0}:root{--bg-body:#f8f9fb;--bg-card:#fff;--bg-card-hover:#f0f4f8;--bg-nav:#fff;--bg-nav-active:#f0f7ff;--accent-blue:#e8486a;--accent-gold:#7b35a8;--accent-blue-light:#fde8ef;--accent-gold-light:#f0e5f8;--accent-green:#10b981;--accent-red:#ef4444;--accent-orange:#f59e0b;--text-primary:#1e293b;--text-secondary:#64748b;--text-dim:#94a3b8;--border-card:#e2e8f0;--border-light:#f1f5f9;--shadow-sm:0 1px 3px #0000000f;--shadow-md:0 4px 12px #00000014;--shadow-lg:0 8px 24px #0000001f;--table-row-alt:#f8fafc;--table-row-hover:#f0f7ff;--table-header-bg:#f8fafc;--chart-bg:#fff;--chart-grid:#f1f5f9;--chart-text:#64748b;--chart-tooltip-bg:#fff;--chart-tooltip-border:#e2e8f0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f0f7ff;background:var(--bg-nav-active);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;transition:background .3s ease}.App{display:flex;flex-direction:column;min-height:100vh}.app-body{display:flex;flex:1 1}.page-content{flex:1 1;min-width:0;overflow-x:hidden;padding:20px}.App-header{align-items:center;background:#fff;background:var(--bg-nav);border-bottom:1px solid #f1f5f9;border-bottom:1px solid var(--border-light);box-shadow:0 1px 3px #0000000f;box-shadow:var(--shadow-sm);display:flex;gap:20px;padding:16px 28px;position:-webkit-sticky;position:sticky;top:0;z-index:100}.logo{height:36px}.App-header h1{color:#1e293b;color:var(--text-primary);flex:1 1;font-size:20px;font-weight:600;letter-spacing:-.02em}.controls{background:#fff;background:var(--bg-card);border:1px solid #e2e8f0;border:1px solid var(--border-card);border-radius:10px;box-shadow:0 2px 8px var(--shadow);flex-wrap:wrap;gap:24px;justify-content:center;margin-bottom:20px;padding:16px 20px}.control-group,.controls{align-items:center;display:flex}.control-group{gap:12px}.control-group label{font-weight:600}.control-group button,.control-group label{color:#64748b;color:var(--text-secondary);font-size:14px}.control-group button{background:#fff;background:var(--bg-card);border:1px solid #e2e8f0;border:1px solid var(--border-card);border-radius:8px;cursor:pointer;font-weight:500;padding:10px 18px;transition:all .15s ease}.control-group button:hover{background:#f0f4f8;background:var(--bg-card-hover);border-color:#e8486a;border-color:var(--accent-blue);color:#1e293b;color:var(--text-primary)}.control-group button.active{background:#e8486a;background:var(--accent-blue);border-color:#e8486a;border-color:var(--accent-blue);color:#fff;font-weight:600}.compare-toggle{align-items:center;background:#fff;background:var(--bg-card);border:1px solid #e2e8f0;border:1px solid var(--border-card);border-radius:10px;color:#64748b;color:var(--text-secondary);display:inline-flex;font-weight:600;gap:10px;padding:8px 12px}.compare-toggle input{height:18px;width:18px}.date-select{background:#fff;border:2px solid #e8486a;border:2px solid var(--accent-blue);border-radius:8px;color:#1e293b;color-scheme:light;cursor:pointer;font-size:14px;font-weight:600;padding:10px 16px;transition:all .3s ease}.date-select:hover{background:#f0f4f8}.date-select:focus{border-color:#7b35a8;border-color:var(--accent-gold);outline:none}.date-range{display:flex;flex-direction:column;gap:10px}.date-range-label{color:#64748b;color:var(--text-secondary);font-size:14px;font-weight:600}.date-range-inputs{align-items:center;display:flex;gap:10px}.date-range-sep{color:#64748b;color:var(--text-secondary);font-weight:600}.date-range-presets{display:flex;flex-wrap:wrap;gap:8px}.preset-button{background:#f0f4f8;background:var(--bg-card-hover);border:1px solid #e2e8f0;border:1px solid var(--border-card);border-radius:8px;color:#64748b;color:var(--text-secondary);cursor:pointer;font-size:12px;font-weight:600;padding:6px 10px;transition:all .2s ease}.preset-button:hover{border-color:#e8486a;border-color:var(--accent-blue);color:#e8486a;color:var(--accent-blue)}.compare-panels{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(320px,1fr))}.alert-widget{background:#fff;background:var(--bg-card);border:1px solid #e2e8f0;border:1px solid var(--border-card);border-radius:14px;box-shadow:0 4px 12px var(--shadow);margin:30px 0 40px;padding:24px}.alert-widget-header{align-items:baseline;display:flex;gap:12px;margin-bottom:16px}.alert-widget-header h2{color:#7b35a8;color:var(--accent-gold);margin:0}.alert-subtitle{color:#64748b;color:var(--text-secondary);font-size:13px}.alert-list{grid-gap:10px;display:grid;gap:10px}.alert-item{align-items:center;background:#fff;background:var(--bg-card);border:1px solid #e2e8f0;border:1px solid var(--border-card);border-radius:10px;cursor:pointer;display:flex;gap:12px;padding:14px 16px;transition:all .2s ease}.alert-item:hover{background:#f0f4f8;background:var(--bg-card-hover);border-color:#e8486a;border-color:var(--accent-blue);box-shadow:0 1px 3px #0000000f;box-shadow:var(--shadow-sm)}.alert-item:focus{outline:2px solid #e8486a;outline:2px solid var(--accent-blue);outline-offset:2px}.alert-icon{font-size:20px}.alert-title{color:#1e293b;color:var(--text-primary);font-weight:700}.alert-meta{font-size:12px}.alert-empty,.alert-meta{color:#64748b;color:var(--text-secondary)}.alert-empty{background:#0f1531;border:1px dashed #2a3350;border-radius:10px;padding:14px;text-align:center}.heatmap{grid-gap:6px;display:grid;gap:6px;overflow-x:auto;padding-bottom:10px}.heatmap-row{grid-gap:6px;display:grid;gap:6px;grid-template-columns:140px repeat(auto-fit,minmax(110px,1fr))}.heatmap-cell{background:#1a1f3a;border:1px solid #2a3350;border-radius:6px;color:#1e293b;color:var(--text-primary);font-size:12px;padding:8px 6px;text-align:center}.heatmap-label{background:#0f1531;color:#64748b;color:var(--text-secondary);font-weight:700}.mom-stats{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:30px}.stat-card{background:#fff;background:var(--bg-card);border:1px solid #e2e8f0;border:1px solid var(--border-card);border-radius:12px;box-shadow:0 4px 12px var(--shadow);padding:25px;text-align:center}.stat-card h3{color:#64748b;color:var(--text-secondary);font-size:14px;font-weight:600;letter-spacing:.5px;margin-bottom:12px;text-transform:uppercase}.stat-value{color:#e8486a;color:var(--accent-blue);font-size:36px;font-weight:700}.stat-value.positive{color:#10b981;color:var(--accent-green)}.stat-value.negative{color:#ef4444;color:var(--accent-red)}.chart-container{background:#fff;background:var(--bg-card);border:1px solid #e2e8f0;border:1px solid var(--border-card);border-radius:12px;box-shadow:0 4px 12px #00000014;box-shadow:var(--shadow-md);margin-bottom:24px;max-width:100%;overflow:hidden;padding:32px}.chart-container h2{border-bottom:2px solid #f1f5f9;border-bottom:2px solid var(--border-light);color:#1e293b;color:var(--text-primary);font-size:22px;font-weight:600;margin-bottom:24px;padding-bottom:16px}.data-table{background:#fff;background:var(--bg-card);border:1px solid #e2e8f0;border:1px solid var(--border-card);border-radius:12px;box-shadow:0 4px 12px var(--shadow);overflow-x:auto;padding:30px}.data-table h2{border-bottom:3px solid #7b35a8;border-bottom:3px solid var(--accent-gold);color:#1e293b;color:var(--text-primary);font-size:24px;margin-bottom:25px;padding-bottom:15px}table{border-collapse:collapse;font-size:14px;width:100%}thead tr{background:#f8fafc;background:var(--table-header-bg);border-bottom:2px solid #e2e8f0;border-bottom:2px solid var(--border-card)}th{color:#64748b;color:var(--text-secondary);font-size:13px;font-weight:600;letter-spacing:.5px;padding:14px 16px;text-align:left;text-transform:uppercase}th.sortable{cursor:pointer;transition:color .2s;-webkit-user-select:none;user-select:none}th.sortable:hover{color:#e8486a;color:var(--accent-blue)}th.sortable .sort-arrow{font-size:10px;margin-left:4px;opacity:.5}th.sortable.active .sort-arrow{color:#7b35a8;color:var(--accent-gold);opacity:1}td{border-bottom:1px solid #f1f5f9;border-bottom:1px solid var(--border-light);color:#1e293b;color:var(--text-primary);padding:14px 16px}tbody tr:hover{background:#f0f4f8;background:var(--bg-card-hover)}tbody tr:nth-child(2n){background:#f8fafc;background:var(--table-row-alt)}tbody tr:nth-child(2n):hover{background:#f0f4f8;background:var(--bg-card-hover)}.percentage{color:#64748b;color:var(--text-secondary);display:block;font-size:11px;margin-top:4px}.main-nav{background:#fff;background:var(--bg-nav);border-right:1px solid #f1f5f9;border-right:1px solid var(--border-light);display:flex;flex-direction:column;gap:2px;min-height:calc(100vh - 140px);padding:16px 0;width:240px}.nav-group{margin-bottom:4px}.nav-group-header{align-items:center;background:none;border:none;color:#94a3b8;color:var(--text-dim);cursor:pointer;display:flex;font-size:11px;font-weight:700;justify-content:space-between;letter-spacing:1.2px;padding:10px 20px;text-transform:uppercase;transition:color .2s ease;width:100%}.nav-group-header:hover{color:#64748b;color:var(--text-secondary)}.nav-chevron{font-size:10px;transition:transform .2s ease}.nav-chevron.collapsed{transform:rotate(-90deg)}.nav-group-report{border-top:1px solid #e2e8f0;border-top:1px solid var(--border-card);margin-top:auto;padding-top:12px}.nav-report-link{background:#008ef914!important;border-left:none!important;border-radius:8px;margin:0 12px}.nav-report-link:hover{background:#008ef926!important}.nav-link{align-items:center;border-radius:8px;color:#64748b;color:var(--text-secondary);display:flex;font-size:14px;font-weight:500;gap:12px;margin:0 12px;padding:12px 20px;text-decoration:none;transition:all .15s ease}.nav-icon{flex-shrink:0;font-size:15px;text-align:center;width:20px}.nav-label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.nav-link:hover{background:#f0f4f8;background:var(--bg-card-hover)}.nav-link.active,.nav-link:hover{color:#e8486a;color:var(--accent-blue)}.nav-link.active{background:#fde8ef;background:var(--accent-blue-light);font-weight:600}.nav-link[draggable]{cursor:grab}.nav-link[draggable]:active{cursor:grabbing;opacity:.5}.drag-handle{font-size:13px;margin-right:6px;opacity:.3}.nav-link:hover .drag-handle{opacity:.7}.export-button{background:linear-gradient(135deg,#ffb546,#ff8c42);border:2px solid #ffb546;border-radius:8px;box-shadow:0 2px 8px #ffb5464d;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:10px 24px;transition:all .3s ease}.export-button:hover{box-shadow:0 4px 12px #ffb54680;transform:translateY(-2px)}.modal,.modal-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.modal-content{background:#fff;background:var(--bg-card);border:1px solid #e2e8f0;border:1px solid var(--border-card);border-radius:12px;box-shadow:0 8px 24px #0000001f;box-shadow:var(--shadow-lg);max-height:80vh;max-width:500px;overflow-y:auto;padding:30px;width:90%}.modal-content h2{color:#e8486a;color:var(--accent-blue);font-size:24px;margin-bottom:10px}.modal-content p{color:#64748b;color:var(--text-secondary);margin-bottom:16px}.modal-content input[type=text]{background:#f8f9fb;background:var(--bg-body);border:1px solid #e2e8f0;border:1px solid var(--border-card);border-radius:8px;color:#1e293b;color:var(--text-primary);font-size:14px;margin-bottom:20px;padding:12px 14px;width:100%}.modal-content input[type=text]:focus{border-color:#e8486a;border-color:var(--accent-blue);box-shadow:0 0 0 3px #008ef91a;outline:none}.country-checkbox-list{background:#f0f7ff;background:var(--bg-nav-active);border-radius:8px;display:flex;flex-direction:column;gap:12px;margin:20px 0;max-height:300px;overflow-y:auto;padding:10px}.checkbox-label{align-items:center;background:#fff;background:var(--bg-card);border-radius:6px;color:#1e293b;color:var(--text-primary);cursor:pointer;display:flex;font-size:15px;font-weight:500;gap:12px;padding:12px;transition:all .2s ease}.checkbox-label:hover{background:#f0f4f8;background:var(--bg-card-hover);transform:translateX(4px)}.checkbox-label input[type=checkbox]{accent-color:#e8486a;accent-color:var(--accent-blue);cursor:pointer;height:20px;width:20px}.modal-actions{border-top:1px solid #e2e8f0;border-top:1px solid var(--border-card);display:flex;gap:12px;justify-content:flex-end;margin-top:24px;padding-top:20px}.saved-report-list{display:flex;flex-direction:column;gap:10px;margin-top:14px}.saved-report-item{align-items:center;background:#fff;background:var(--bg-card);border:1px solid #e2e8f0;border:1px solid var(--border-card);border-radius:8px;display:flex;justify-content:space-between;padding:10px 14px}.saved-report-name{color:#1e293b;color:var(--text-primary);font-size:14px;font-weight:600}.saved-report-actions{display:flex;gap:8px}.btn-cancel{background:#0000;border:2px solid #666;border-radius:8px;color:#64748b;color:var(--text-secondary);cursor:pointer;font-size:14px;font-weight:600;padding:10px 24px;transition:all .3s ease}.btn-cancel:hover{background:#f0f4f8;background:var(--bg-card-hover);border-color:#64748b;border-color:var(--text-secondary)}.btn-primary{background:linear-gradient(135deg,#008ef9,#06c);border:none;border-radius:8px;box-shadow:0 2px 8px #008ef94d;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:10px 24px;transition:all .3s ease}.btn-primary:hover:not(:disabled){box-shadow:0 4px 12px #008ef980;transform:translateY(-2px)}.btn-primary:disabled{cursor:not-allowed;opacity:.5}.country-checkbox-list::-webkit-scrollbar{width:8px}.country-checkbox-list::-webkit-scrollbar-track{background:#f0f7ff;background:var(--bg-nav-active);border-radius:4px}.country-checkbox-list::-webkit-scrollbar-thumb{background:#e2e8f0;background:var(--border-card);border-radius:4px}.country-checkbox-list::-webkit-scrollbar-thumb:hover{background:#f0f4f8;background:var(--bg-card-hover)}.dashboard-header{margin-bottom:40px;text-align:center}.kpi-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin-bottom:40px}.kpi-card{background:#fff;background:var(--bg-card);border:1px solid #e2e8f0;border:1px solid var(--border-card);border-radius:12px;box-shadow:0 4px 12px #00000014;box-shadow:var(--shadow-md);overflow:hidden;padding:24px;position:relative;transition:all .2s ease}.kpi-card:before{background:linear-gradient(90deg,#e8486a,#7b35a8);background:linear-gradient(90deg,var(--accent-blue) 0,var(--accent-gold) 100%);content:"";height:3px;left:0;position:absolute;right:0;top:0}.kpi-card:hover{border-color:#e8486a;border-color:var(--accent-blue);box-shadow:0 8px 24px #0000001f;box-shadow:var(--shadow-lg);transform:translateY(-2px)}.kpi-header{align-items:center;display:flex;gap:12px;margin-bottom:16px}.kpi-icon{font-size:28px;line-height:1}.kpi-label{color:#64748b;color:var(--text-secondary);font-size:13px;font-weight:600;letter-spacing:.8px;text-transform:uppercase}.kpi-value{color:#e8486a;color:var(--accent-blue);font-size:42px;font-weight:700;line-height:1;margin-bottom:12px}.kpi-change{align-items:center;display:flex;font-size:15px;font-weight:600;gap:6px;margin-bottom:16px}.kpi-change.positive{color:#10b981;color:var(--accent-green)}.kpi-change.negative{color:#ef4444;color:var(--accent-red)}.change-icon{font-size:18px;font-weight:700}.kpi-subtitle{color:#64748b;color:var(--text-secondary);font-size:14px;font-weight:500;margin-top:8px}.kpi-sparkline{display:flex;justify-content:flex-end;margin-top:12px;opacity:.7}.trend-summary{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:30px}.trend-card{background:linear-gradient(135deg,#1a1f3a,#242949);border:2px solid #2a3350;border-radius:12px;box-shadow:0 4px 12px var(--shadow);display:flex;flex-direction:column;gap:10px;padding:20px;transition:all .3s ease}.trend-card:hover{border-color:#e8486a;border-color:var(--accent-blue);transform:translateY(-2px)}.trend-card.positive{border-color:#10b981;border-color:var(--accent-green)}.trend-card.negative{border-color:#ef4444;border-color:var(--accent-red)}.trend-label{color:#64748b;color:var(--text-secondary);font-size:12px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.trend-value{color:#e8486a;color:var(--accent-blue);font-size:24px;font-weight:700}.trend-card.positive .trend-value{color:#10b981;color:var(--accent-green)}.trend-card.negative .trend-value{color:#ef4444;color:var(--accent-red)}.quick-actions{background:#fff;background:var(--bg-card);border:1px solid #e2e8f0;border:1px solid var(--border-card);border-radius:12px;box-shadow:0 4px 12px var(--shadow);margin-bottom:30px;padding:30px}.quick-actions h2{margin-bottom:20px}.action-buttons{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.action-button{align-items:center;background:#fff;background:var(--bg-card);border:1px solid #e2e8f0;border:1px solid var(--border-card);border-radius:12px;cursor:pointer;display:flex;gap:20px;padding:24px;text-decoration:none;transition:all .2s ease}.action-button:hover{border-color:#e8486a;border-color:var(--accent-blue);box-shadow:0 8px 24px #0000001f;box-shadow:var(--shadow-lg);transform:translateY(-2px)}.action-icon{font-size:40px;line-height:1}.action-title{color:#e8486a;color:var(--accent-blue);font-size:18px;font-weight:700;margin-bottom:4px}.action-subtitle{color:#64748b;color:var(--text-secondary);font-size:13px;font-weight:500}.matrix-container{background:#fff;background:var(--bg-card);border:1px solid #e2e8f0;border:1px solid var(--border-card);border-radius:12px;box-shadow:0 4px 12px var(--shadow);overflow-x:auto;padding:30px}.matrix-legend{margin-bottom:30px}.matrix-legend h3{color:#7b35a8;color:var(--accent-gold);font-size:18px;margin-bottom:15px}.legend-items{display:flex;flex-wrap:wrap;gap:20px}.legend-item{align-items:center;color:#1e293b;color:var(--text-primary);display:flex;font-size:14px;gap:10px}.legend-color{border-radius:4px;height:20px;width:40px}.matrix-table-wrapper{overflow-x:auto}.matrix-table{border-collapse:initial;border-spacing:4px;font-size:14px;width:100%}.matrix-corner{background:#f0f7ff;background:var(--bg-nav-active);border-radius:8px;color:#64748b;color:var(--text-secondary);font-weight:700;left:0;padding:15px;position:-webkit-sticky;position:sticky;text-align:left;z-index:10}.matrix-header-game{background:#008ef9;min-width:120px}.matrix-header-game,.matrix-header-total{border-radius:8px;color:#fff;font-weight:700;padding:15px;text-align:center}.matrix-header-total{background:#ffb546;min-width:100px}.matrix-header-country{background:#f0f4f8;background:var(--bg-card-hover);border-radius:8px;color:#7b35a8;color:var(--accent-gold);font-weight:700;left:0;padding:12px 15px;position:-webkit-sticky;position:sticky;text-align:left;z-index:5}.matrix-cell{border-radius:8px;cursor:pointer;min-width:120px;padding:15px;text-align:center;transition:all .2s ease}.matrix-cell:hover{box-shadow:0 4px 12px #008ef966;transform:scale(1.05);z-index:10}.matrix-cell-value{font-size:15px;font-weight:700}.matrix-total-cell{background:#f0f4f8;background:var(--bg-card-hover);border-radius:8px;color:#7b35a8;color:var(--accent-gold);font-weight:700;padding:12px 15px;text-align:center}.matrix-total-row{background:#0000}.matrix-total-row .matrix-header-country{background:#ffb546;color:#fff}.grand-total{background:linear-gradient(135deg,#008ef9,#ffb546);color:#fff;font-size:16px}.sub-tabs{background:#fff;background:var(--bg-card);border:1px solid #e2e8f0;border:1px solid var(--border-card);border-radius:12px;display:flex;gap:6px;margin-bottom:20px;padding:8px 16px}.sub-tab{background:#0000;border:none;border-radius:8px;color:#64748b;color:var(--text-secondary);cursor:pointer;font-size:13px;font-weight:600;padding:8px 18px;transition:all .2s ease}.sub-tab:hover{background:#f0f4f8;background:var(--bg-card-hover);color:#1e293b;color:var(--text-primary)}.sub-tab.active{background:#e8486a;background:var(--accent-blue);color:#fff}@media (max-width:768px){.App-header{flex-direction:column;text-align:center}.App-header h1{font-size:24px}.main-nav{flex-direction:column;gap:0}.nav-link{border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border-card);text-align:center;width:100%}.controls{flex-direction:column;gap:20px}.control-group{flex-direction:column;width:100%}.control-group button{width:100%}.stat-value{font-size:28px}table{font-size:12px}td,th{padding:8px}}.dropzone{background:#fff;background:var(--bg-card);border:2px dashed #e8486a;border:2px dashed var(--accent-blue);border-radius:16px;box-shadow:0 4px 12px var(--shadow);color:#64748b;color:var(--text-secondary);cursor:pointer;padding:36px;text-align:center;transition:all .3s ease}.dropzone.active{background:#f0f4f8;background:var(--bg-card-hover);border-color:#7b35a8;border-color:var(--accent-gold)}.dropzone-title,.dropzone.active{color:#1e293b;color:var(--text-primary)}.dropzone-title{font-size:18px;font-weight:700;margin-bottom:8px}.dropzone-subtitle{color:#64748b;color:var(--text-secondary);font-size:14px}.dropzone-file{color:#7b35a8;color:var(--accent-gold);font-size:13px;margin-top:12px}.upload-progress{background:#fff;background:var(--bg-card);border:1px solid #e2e8f0;border:1px solid var(--border-card);border-radius:12px;box-shadow:0 4px 12px var(--shadow);margin-top:20px;padding:16px 20px}.progress-label{color:#64748b;color:var(--text-secondary);font-size:13px;margin-bottom:10px}.progress-track{background:#f0f4f8;background:var(--bg-card-hover);border-radius:999px;height:10px;overflow:hidden}.progress-bar{background:linear-gradient(90deg,#e8486a,#7b35a8);background:linear-gradient(90deg,var(--accent-blue),var(--accent-gold));height:100%;transition:width .2s ease;width:0}.status-message{border:1px solid #0000;border-radius:10px;font-weight:600;margin-top:20px;padding:14px 18px}.status-message.success{background:#4caf501f;border-color:#4caf5066;color:#10b981;color:var(--accent-green)}.status-message.error{background:#f443361f;border-color:#f4433666;color:#ef4444;color:var(--accent-red)}.error-list{font-size:12px;list-style:disc;margin-top:10px;padding-left:20px}.error-list,.preview-summary{color:#64748b;color:var(--text-secondary)}.preview-summary{display:flex;flex-wrap:wrap;gap:20px;margin-bottom:20px}.preview-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.preview-card{background:#f0f4f8;background:var(--bg-card-hover);border:1px solid #e2e8f0;border:1px solid var(--border-card);border-radius:12px;color:#64748b;color:var(--text-secondary);padding:18px}.preview-card h3{color:#1e293b;color:var(--text-primary);margin-bottom:10px}.preview-table{font-size:12px;margin-top:12px}.preview-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:20px}.tag-games-header{align-items:center;display:flex;gap:20px;justify-content:space-between;margin-bottom:20px}.tag-games-title{color:#e8486a;color:var(--accent-blue);font-size:28px}.tag-games-subtitle{color:#7b35a8;color:var(--accent-gold);font-weight:600;margin-top:4px}.tag-games-saveall{min-width:190px}.tag-games-filters{background:#fff;background:var(--bg-card);border:1px solid #e2e8f0;border:1px solid var(--border-card);border-radius:12px;box-shadow:0 4px 12px var(--shadow);gap:12px 18px;justify-content:space-between;margin-bottom:16px;padding:16px}.tag-games-filter-group,.tag-games-filters{align-items:center;display:flex;flex-wrap:wrap}.tag-games-filter-group{gap:10px}.tag-games-filter-group button{background:#f0f4f8;background:var(--bg-card-hover);border:1px solid #e2e8f0;border:1px solid var(--border-card);border-radius:8px;color:#64748b;color:var(--text-secondary);cursor:pointer;font-weight:600;padding:8px 14px;transition:all .2s ease}.tag-games-filter-group button.active,.tag-games-filter-group button:hover{background:#e8486a;background:var(--accent-blue);border-color:#e8486a;border-color:var(--accent-blue);color:#fff}.tag-games-search{min-width:220px;padding:10px 12px}.tag-games-search,.tag-games-select{background:#fff;background:var(--bg-card);border:1px solid #e2e8f0;border:1px solid var(--border-card);border-radius:8px;color:#1e293b;color:var(--text-primary)}.tag-games-select{font-weight:600;height:38px;min-width:180px;padding:8px 10px}.tag-games-search:focus,.tag-games-select:focus{border-color:#e8486a;border-color:var(--accent-blue);outline:none}.tag-games-table-wrapper{background:#fff;background:var(--bg-card);border:1px solid #e2e8f0;border:1px solid var(--border-card);border-radius:12px;box-shadow:0 4px 12px var(--shadow);max-height:calc(100vh - 320px);overflow:auto}.tag-games-table{border-collapse:collapse;min-width:920px;width:100%}.tag-games-table thead th{background:#fff;background:var(--bg-card);border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border-card);color:#64748b;color:var(--text-secondary);padding:14px 12px;position:-webkit-sticky;position:sticky;text-align:left;top:0;z-index:2}.tag-games-table tbody tr:nth-child(2n){background:#f8fafc;background:var(--table-row-alt)}.tag-games-table tbody tr:hover{background:#f0f7ff;background:var(--table-row-hover)}.tag-games-table tbody td{border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border-card);color:#1e293b;color:var(--text-primary);padding:12px}.tag-games-name{font-weight:700}.tag-games-actions{text-align:right;width:90px}.tag-games-save{background:#0000;border:1px solid #e8486a;border:1px solid var(--accent-blue);border-radius:8px;color:#e8486a;color:var(--accent-blue);cursor:pointer;padding:6px 8px;transition:all .2s ease}.tag-games-save:hover{background:#e8486a;background:var(--accent-blue);color:#fff}.tag-games-empty,.tag-games-loading{color:#64748b;color:var(--text-secondary);padding:16px}.tag-games-status{color:#7b35a8;color:var(--accent-gold);font-weight:600;margin-top:12px}.tag-games-table tbody tr.row-dirty{background:#ffc5422e}.tag-games-table tbody tr.row-dirty:hover{background:#ffc54247}@media (max-width:900px){.tag-games-table{min-width:720px}.tag-games-saveall{width:100%}}.report-builder{background:var(--bg-main);color:#1e293b;color:var(--text-primary);min-height:100vh}.report-sidebar{background:#fff;background:var(--bg-nav);border-right:1px solid #f1f5f9;border-right:1px solid var(--border-light);bottom:0;display:flex;flex-direction:column;gap:16px;left:0;padding:24px 18px;position:fixed;top:0;width:250px;z-index:5}.report-sidebar-header{color:#64748b;color:var(--text-secondary);font-size:15px;font-weight:700;letter-spacing:.6px;text-transform:uppercase}.report-sidebar-list{display:flex;flex-direction:column;gap:12px;overflow-y:auto;padding-right:4px}.report-sidebar-item{align-items:center;background:#fff;background:var(--bg-card);border:1px solid #e2e8f0;border:1px solid var(--border-card);border-radius:10px;color:#1e293b;color:var(--text-primary);cursor:grab;display:flex;font-size:14px;gap:10px;padding:12px 14px;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease}.report-sidebar-item:hover{border-color:#e8486a;border-color:var(--accent-blue);box-shadow:0 4px 12px #00000014;box-shadow:var(--shadow-md);transform:translateX(4px)}.report-sidebar-item.dragging{opacity:.6}.report-sidebar-icon{font-size:18px}.report-canvas{display:flex;flex-direction:column;gap:24px;margin-left:250px;margin-right:300px;min-height:100vh;padding:32px 36px 40px;transition:margin-right .2s ease}.report-canvas.panel-collapsed{margin-right:48px}.report-canvas-header{align-items:flex-start;display:flex;gap:20px;justify-content:space-between}.report-canvas-header h1{color:#1e293b;color:var(--text-primary);font-size:28px;margin:0}.report-canvas-header p{color:#64748b;color:var(--text-secondary);margin:8px 0 0}.report-actions{align-items:center;display:flex;gap:12px}.report-actions select{background:#fff;background:var(--bg-card);border:1px solid #e2e8f0;border:1px solid var(--border-card);border-radius:8px;color:#1e293b;color:var(--text-primary);font-size:14px;min-width:200px;padding:10px 12px}.report-canvas-body{background:#f8f9fb;background:var(--bg-body);border:2px dashed #e2e8f0;border:2px dashed var(--border-card);border-radius:16px;display:flex;flex-direction:column;gap:12px;max-height:calc(100vh - 320px);min-height:400px;min-width:300px;overflow-y:auto;padding:18px;position:relative;transition:border-color .2s ease,box-shadow .2s ease}.report-canvas-body.drag-over{background:#fde8ef;background:var(--accent-blue-light);border-color:#e8486a;border-color:var(--accent-blue);box-shadow:0 0 0 1px #008ef966}.report-empty{color:#94a3b8;color:var(--text-dim);font-size:16px;left:50%;pointer-events:none;position:absolute;text-align:center;top:50%;transform:translate(-50%,-50%);z-index:0}.report-slide-card{align-items:center;background:#fff;background:var(--bg-card);border:1px solid #e2e8f0;border:1px solid var(--border-card);border-radius:12px;cursor:pointer;display:flex;gap:14px;padding:14px 16px;transition:transform .2s ease,border-color .2s ease,box-shadow .2s ease}.report-slide-card:hover{border-color:#e8486a;border-color:var(--accent-blue);box-shadow:0 8px 24px #0000001f;box-shadow:var(--shadow-lg);transform:translateY(-2px)}.report-slide-card.selected{background:#fde8ef;background:var(--accent-blue-light);border-color:#e8486a;border-color:var(--accent-blue);box-shadow:0 0 0 1px #008ef966}.report-slide-card.dragging{opacity:.6}.report-slide-handle{color:#94a3b8;color:var(--text-dim);cursor:grab;font-size:20px}.report-slide-main{flex:1 1}.report-slide-title{align-items:center;color:#1e293b;color:var(--text-primary);display:flex;font-weight:600;gap:8px}.report-slide-summary{color:#64748b;color:var(--text-secondary);font-size:13px;margin-top:4px}.report-slide-delete{background:#0000;border:none;color:#94a3b8;color:var(--text-dim);cursor:pointer;font-size:20px;padding:4px 8px;transition:color .2s ease}.report-slide-delete:hover{color:#ef4444;color:var(--accent-red)}.report-drag-overlay{align-items:center;background:#fff;background:var(--bg-card);border:1px solid #e2e8f0;border:1px solid var(--border-card);border-radius:10px;box-shadow:0 4px 12px #00000014;box-shadow:var(--shadow-md);box-shadow:0 8px 18px #0006;color:#1e293b;color:var(--text-primary);display:flex;gap:8px;padding:12px 16px}.report-generate{align-items:center;display:flex;gap:16px}.report-status{color:#a0a8c0;font-size:14px}.report-config-panel{background:#fff;background:var(--bg-nav);border-left:1px solid #f1f5f9;border-left:1px solid var(--border-light);bottom:0;display:flex;flex-direction:column;gap:16px;padding:20px;position:fixed;right:0;top:0;transition:width .2s ease;width:300px;z-index:5}.report-config-panel.collapsed{padding:20px 10px;width:48px}.report-config-header{align-items:center;color:#1e293b;color:var(--text-primary);display:flex;font-weight:600;justify-content:space-between}.report-config-toggle{background:#fff;background:var(--bg-card);border:1px solid #e2e8f0;border:1px solid var(--border-card);border-radius:8px;color:#1e293b;color:var(--text-primary);cursor:pointer;height:28px;width:28px}.report-config-body{display:flex;flex-direction:column;gap:18px;overflow-y:auto}.report-config-section label{color:#64748b;color:var(--text-secondary);display:block;font-size:13px;font-weight:500;margin-bottom:8px}.report-config-section select{background:#fff;background:var(--bg-card);border:1px solid #e2e8f0;border:1px solid var(--border-card);border-radius:8px;color:#1e293b;color:var(--text-primary);margin-bottom:14px;padding:10px 12px;width:100%}.report-config-title{font-size:15px;font-weight:600}.report-checkbox,.report-config-title{color:#1e293b;color:var(--text-primary)}.report-checkbox{align-items:center;display:flex;font-size:14px;gap:8px;margin-bottom:8px}.report-config-empty{color:#94a3b8;color:var(--text-dim);font-size:13px;padding:12px 0}@media (max-width:1100px){.report-sidebar{border-right:none;position:static;width:auto}.report-config-panel{border-left:none;position:static;width:auto}.report-canvas{margin:0}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.data-freshness{background:#fde8ef;background:var(--accent-blue-light);border-radius:20px;color:#64748b;color:var(--text-secondary);font-size:12px;font-weight:500;padding:6px 14px;white-space:nowrap}.hamburger-btn{background:#fff;background:var(--bg-card);border:1px solid #e2e8f0;border:1px solid var(--border-card);border-radius:8px;color:#1e293b;color:var(--text-primary);cursor:pointer;display:none;font-size:22px;left:16px;padding:6px 10px;position:fixed;top:14px;z-index:110}.nav-overlay{background:#00000080;display:none;inset:0;position:fixed;z-index:90}@media (max-width:768px){.hamburger-btn,.nav-overlay{display:block}.main-nav{height:100vh;left:0;position:fixed;top:0;transform:translateX(-100%);transition:transform .25s ease;width:240px;z-index:100}.main-nav.nav-open{transform:translateX(0)}.App-header{padding-left:56px}}.searchable-select{min-width:200px;position:relative}.searchable-select-trigger{align-items:center;background:#fff;background:var(--bg-card);border:1px solid #e2e8f0;border:1px solid var(--border-card);border-radius:8px;color:#1e293b;color:var(--text-primary);cursor:pointer;display:flex;font-size:14px;gap:8px;justify-content:space-between;padding:8px 12px;width:100%}.searchable-select-trigger:hover{border-color:#e8486a;border-color:var(--accent-blue)}.searchable-select-chevron{font-size:10px;transition:transform .2s}.searchable-select-chevron.open{transform:rotate(180deg)}.searchable-select-dropdown{background:#fff;background:var(--bg-card);border:1px solid #e2e8f0;border:1px solid var(--border-card);border-radius:8px;box-shadow:0 8px 24px #0006;left:0;margin-top:4px;overflow:hidden;position:absolute;right:0;top:100%;z-index:50}.searchable-select-input{background:#f0f4f8;background:var(--bg-card-hover);border:none;border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border-card);color:#1e293b;color:var(--text-primary);font-size:14px;outline:none;padding:10px 12px;width:100%}.searchable-select-options{max-height:240px;overflow-y:auto}.searchable-select-option{background:none;border:none;color:#64748b;color:var(--text-secondary);cursor:pointer;display:block;font-size:13px;padding:8px 12px;text-align:left;transition:all .15s;width:100%}.searchable-select-option:hover{background:#f0f4f8;background:var(--bg-card-hover);color:#1e293b;color:var(--text-primary)}.searchable-select-option.selected{background:#008ef91a;color:#e8486a;color:var(--accent-blue)}.searchable-select-empty{color:#94a3b8;color:var(--text-dim);font-size:13px;padding:16px;text-align:center}.preset-pill-row{align-items:center;display:flex;flex-wrap:wrap;gap:6px}.preset-pill{background:#0000;border:1px solid #e2e8f0;border:1px solid var(--border-card);border-radius:20px;color:#64748b;color:var(--text-secondary);cursor:pointer;font-size:12px;font-weight:600;padding:5px 14px;transition:all .2s;white-space:nowrap}.preset-pill:hover{color:#e8486a;color:var(--accent-blue)}.preset-pill.active,.preset-pill:hover{border-color:#e8486a;border-color:var(--accent-blue)}.preset-pill.active{background:#e8486a;background:var(--accent-blue);color:#fff}.empty-state{align-items:center;display:flex;flex-direction:column;justify-content:center;padding:60px 20px;text-align:center}.empty-state-icon{font-size:56px;margin-bottom:16px;opacity:.7}.empty-state-title{color:#1e293b;color:var(--text-primary);font-size:20px;font-weight:700;margin-bottom:8px}.empty-state-subtitle{color:#94a3b8;color:var(--text-dim);font-size:14px}@keyframes slideIn{0%{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}@media (max-width:768px){.kpi-grid{gap:12px;grid-template-columns:1fr;margin-bottom:20px}.kpi-card{border-radius:12px;padding:16px 18px}.kpi-value{font-size:26px!important}.kpi-label{font-size:11px}.kpi-change{font-size:12px}.kpi-sparkline{height:30px}.chart-container{-webkit-overflow-scrolling:touch;border-radius:10px;margin-bottom:16px;overflow-x:auto;padding:14px 10px}.chart-container h2{font-size:16px;margin-bottom:12px;padding-bottom:8px}.chart-container .recharts-wrapper{min-width:500px}.recharts-cartesian-axis-tick-value{font-size:10px!important}.recharts-legend-item-text{font-size:11px!important}.data-table{-webkit-overflow-scrolling:touch;border-radius:10px;overflow-x:auto;padding:12px 8px}.data-table h2{font-size:16px;margin-bottom:12px;padding-bottom:8px}table{font-size:12px;min-width:600px}td,th{padding:8px 6px!important;white-space:nowrap}th{font-size:11px}.controls{flex-direction:column;gap:10px;padding:12px}.control-group{flex-wrap:wrap;gap:8px;width:100%}.control-group label{font-size:12px;width:100%}.control-group input[type=month],.control-group input[type=text],.control-group select{font-size:14px;padding:8px 10px;width:100%}.control-group button{font-size:12px;padding:8px 14px}.date-range{width:100%}.date-range-inputs{flex-direction:column;gap:8px}.date-range-presets{flex-wrap:wrap;gap:6px}.date-range-presets button{font-size:11px;padding:4px 8px}.compare-toggle{justify-content:center;width:100%}.page-content{padding:12px 8px}.page-content h1{font-size:20px;margin-bottom:8px}.page-content>p{font-size:12px}.page-content>div[style*=grid]{grid-template-columns:1fr!important}.App-header{gap:8px;padding:10px 12px}.logo{font-size:16px}.user-menu{font-size:12px}.main-nav{width:240px}.data-table table{min-width:800px}.data-table table td,.data-table table th{font-size:10px;padding:4px 5px!important}.data-table table td[style*=sticky],.data-table table th[style*=sticky]{min-width:100px!important}.page-content>div[style*="repeat(3"]{grid-template-columns:1fr!important}.page-content span[style*=borderRadius]{font-size:11px!important}}.game-rankings-table{background:#fff;background:var(--bg-card);border-collapse:collapse;border-radius:8px;overflow:hidden;width:100%}.game-rankings-table thead tr{background:#f8fafc;background:var(--table-header-bg);border-bottom:2px solid #e2e8f0;border-bottom:2px solid var(--border-card)}.game-rankings-table thead th{color:#64748b;color:var(--text-secondary);font-weight:700;padding:15px}.game-rankings-table tbody tr{border-bottom:1px solid #f1f5f9;border-bottom:1px solid var(--border-light)}.game-rankings-table tbody tr:hover{background:#f0f7ff;background:var(--table-row-hover)}.game-rankings-table tbody td{color:#1e293b;color:var(--text-primary);padding:14px 16px}
/*# sourceMappingURL=main.f4cc04ff.css.map*/