*,*:before,*:after{box-sizing:border-box}:root{font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.5;font-weight:400;color-scheme:light;color:#1e293b;background-color:#f1f5f9;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh}#root{min-height:100vh}a{font-weight:500;color:#3b82f6;text-decoration:none}a:hover{color:#2563eb}h1,h2,h3,h4,h5,h6{margin:0;line-height:1.2}p{margin:0}button{font-family:inherit;cursor:pointer}input,select{font-family:inherit}svg{display:block}.dashboard{min-height:100vh;display:flex;flex-direction:column;background:#f1f5f9}.dashboard-content{flex:1;padding:1.5rem;max-width:1600px;margin:0 auto;width:100%}.kpi-row{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1.5rem}@media(max-width:1024px){.kpi-row{grid-template-columns:repeat(2,1fr)}}@media(max-width:640px){.kpi-row{grid-template-columns:1fr}}.charts-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem;margin-bottom:1.5rem}@media(max-width:1024px){.charts-grid{grid-template-columns:1fr}}.advanced-charts{display:flex;flex-direction:column;gap:1.5rem}.advanced-charts .chart-card-content{min-height:400px}.secondary-charts-grid{margin-top:1.5rem}.dashboard-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;background:#f1f5f9;gap:1rem}.loading-spinner{width:48px;height:48px;border:4px solid #e2e8f0;border-top-color:#3b82f6;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.dashboard-loading p{color:#64748b;font-size:1rem}.dashboard-error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;background:#f1f5f9;gap:.5rem;padding:2rem;text-align:center}.dashboard-error h2{color:#dc2626;margin:0}.dashboard-error p{color:#64748b;margin:0}.dashboard-footer{padding:1.5rem;background:#1e293b;text-align:center}.dashboard-footer p{margin:0;color:#94a3b8;font-size:.875rem}.dashboard-footer .footer-note{margin-top:.5rem;font-size:.75rem;color:#64748b}.time-animation-controls{display:flex;align-items:center;gap:.75rem}.time-animation-controls.compact{position:absolute;bottom:.5rem;left:.5rem;z-index:10}.time-animation-controls.expanded{position:absolute;bottom:0;left:2.5rem;right:2.5rem;padding:.125rem .5rem;background:#fffffff2;border-top:1px solid #f1f5f9;z-index:10;gap:.375rem}.time-animation-controls.expanded .time-animation-button{width:20px;height:20px}.time-animation-controls.expanded .time-animation-year-display{font-size:.75rem;font-weight:600}.time-animation-controls.expanded .time-animation-slider-container{height:3px}.time-animation-controls.expanded .time-animation-slider::-webkit-slider-runnable-track{height:3px}.time-animation-controls.expanded .time-animation-slider::-webkit-slider-thumb{width:10px;height:10px;margin-top:-3.5px}.time-animation-controls.expanded .time-animation-slider::-moz-range-track{height:3px}.time-animation-controls.expanded .time-animation-slider::-moz-range-thumb{width:10px;height:10px}.time-animation-controls.expanded .time-animation-progress{height:3px}.time-animation-controls.expanded .time-animation-speed-select{padding:.125rem .25rem;font-size:.75rem}.time-animation-button{display:flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;border:1px solid #cbd5e1;border-radius:6px;background:#fff;color:#475569;cursor:pointer;transition:all .15s ease}.time-animation-button:hover{background:#f1f5f9;border-color:#94a3b8}.time-animation-button.play-button.compact{width:24px;height:24px;border-color:#e2e8f0;color:#94a3b8;opacity:.7;transition:all .15s ease}.time-animation-button.play-button.compact:hover{opacity:1;color:#3b82f6;border-color:#3b82f6}.time-animation-button.play-button.playing{background:#3b82f6;border-color:#3b82f6;color:#fff}.time-animation-button.play-button.playing:hover{background:#2563eb;border-color:#2563eb}.time-animation-year-display{font-size:1.125rem;font-weight:700;color:#1e293b;min-width:4ch;text-align:center;font-variant-numeric:tabular-nums}.time-animation-slider-container{position:relative;flex:1;min-width:100px;height:6px}.time-animation-slider{position:absolute;top:0;left:0;width:100%;height:100%;margin:0;cursor:pointer;-webkit-appearance:none;appearance:none;background:transparent;z-index:2}.time-animation-slider::-webkit-slider-runnable-track{width:100%;height:6px;background:#e2e8f0;border-radius:3px}.time-animation-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:14px;height:14px;margin-top:-4px;background:#3b82f6;border:2px solid #ffffff;border-radius:50%;box-shadow:0 1px 3px #0003;cursor:pointer;transition:transform .15s ease}.time-animation-slider::-webkit-slider-thumb:hover{transform:scale(1.1)}.time-animation-slider::-moz-range-track{width:100%;height:6px;background:#e2e8f0;border-radius:3px}.time-animation-slider::-moz-range-thumb{width:14px;height:14px;background:#3b82f6;border:2px solid #ffffff;border-radius:50%;box-shadow:0 1px 3px #0003;cursor:pointer}.time-animation-progress{position:absolute;top:0;left:0;height:6px;background:#3b82f6;border-radius:3px;pointer-events:none;z-index:1;transition:width .1s ease-out}.time-animation-speed-select{padding:.375rem .5rem;font-size:.75rem;font-weight:500;border:1px solid #cbd5e1;border-radius:6px;background:#fff;color:#475569;cursor:pointer;transition:all .15s ease}.time-animation-speed-select:hover{background:#f1f5f9;border-color:#94a3b8}.time-animation-speed-select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}@media(max-width:480px){.time-animation-controls{flex-wrap:wrap;gap:.5rem}.time-animation-slider-container{order:10;flex-basis:100%;margin-top:.25rem}}.chart-tooltip{position:fixed;z-index:1000;pointer-events:none;background:#0f172af2;color:#fff;padding:.75rem 1rem;border-radius:8px;font-size:.875rem;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;transform:translate(-50%,calc(-100% - 10px));max-width:250px}.chart-tooltip:after{content:"";position:absolute;bottom:-6px;left:50%;transform:translate(-50%);border-left:6px solid transparent;border-right:6px solid transparent;border-top:6px solid rgba(15,23,42,.95)}.tooltip-content{display:flex;flex-direction:column;gap:.25rem}.tooltip-header{display:flex;align-items:center;gap:.5rem}.tooltip-color{width:10px;height:10px;border-radius:2px;flex-shrink:0}.tooltip-label{font-weight:500;color:#e2e8f0}.tooltip-value{color:#fff}.tooltip-value strong{font-size:1rem}.tooltip-percentage{margin-left:.5rem;color:#94a3b8}.chart-container{width:100%;height:100%;min-height:250px;position:relative}.treemap-container{min-height:300px}.heatmap-container{min-height:500px}.wordcloud-container{min-height:300px}.wordcloud-word{font-weight:600;transition:opacity .15s ease}.wordcloud-word:hover{opacity:.7}.chart-empty{display:flex;align-items:center;justify-content:center;height:100%;color:#94a3b8;font-size:.875rem}.axis-label{font-size:.75rem;fill:#64748b}.bar-label{font-size:.75rem;fill:#475569}.bar-value{font-size:.75rem;font-weight:600;fill:#64748b}.chart-bar{cursor:pointer;transition:opacity .15s ease}.chart-bar:hover{opacity:.8}.histogram-bar{cursor:default;transition:opacity .15s ease}.histogram-bar:hover{opacity:.85}.animated-bar-chart{position:relative;width:100%;height:100%;padding-right:2.5rem}.animated-bar-chart .chart-bar{transition:opacity .15s ease,width .25s ease-out}.animated-bar-chart .bar-label,.animated-bar-chart .bar-value{transition:opacity .3s ease-out}.animated-bar-chart .bar-group{transition:transform .4s ease-out}.chart-point{cursor:pointer;transition:r .15s ease}.chart-point:hover{r:7}.point-label{font-size:.75rem;font-weight:600;fill:#64748b;pointer-events:none}.point-label-angled{font-size:.6rem;font-weight:600;fill:#64748b;pointer-events:none}.chart-arc{cursor:pointer;transition:opacity .15s ease}.chart-arc:hover{opacity:.85}.treemap-node{cursor:pointer}.treemap-node rect{transition:opacity .15s ease}.treemap-node:hover rect{opacity:.85}.treemap-label{fill:#fff;font-weight:600;pointer-events:none}.treemap-value{fill:#fffc;font-size:.75rem;pointer-events:none}.donut-center-value{font-size:1.5rem;font-weight:700;fill:#1e293b}.donut-center-label{font-size:.75rem;fill:#64748b}.donut-arc-label{font-size:.75rem;font-weight:600;fill:#fff;pointer-events:none;text-shadow:0 1px 2px rgba(0,0,0,.3)}.donut-legend{position:absolute;right:.5rem;top:50%;transform:translateY(-50%);display:flex;flex-direction:column;align-items:flex-start;gap:.5rem;padding:.5rem}.legend-item{display:flex;align-items:center;gap:.375rem}.legend-color{width:12px;height:12px;border-radius:2px;flex-shrink:0}.legend-label{font-size:.75rem;color:#475569;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:120px}.stacked-legend{position:absolute;bottom:0;left:0;right:0;display:flex;flex-wrap:wrap;justify-content:center;gap:.75rem;padding:.5rem;background:#ffffffe6}.heatmap-cell{cursor:pointer;transition:opacity .15s ease}.heatmap-cell:hover{opacity:.8;stroke:#1e293b;stroke-width:2}.heatmap-x-label,.heatmap-y-label{font-size:.65rem;fill:#475569}.heatmap-cell-label{font-size:.65rem;font-weight:600;pointer-events:none}.sankey-link{fill:none;stroke-opacity:.4;transition:stroke-opacity .15s ease}.sankey-link:hover{stroke-opacity:.7}.sankey-node{cursor:pointer}.sankey-node rect{transition:opacity .15s ease}.sankey-node:hover rect{opacity:.8}.sankey-label{font-size:.7rem;fill:#1e293b;pointer-events:none}.scatter-dot{cursor:pointer;transition:opacity .15s ease}.scatter-dot:hover{opacity:1;stroke:#1e293b;stroke-width:1.5}.scatter-legend{position:absolute;right:.5rem;top:50%;transform:translateY(-50%);display:flex;flex-direction:column;gap:.5rem;padding:.5rem}.scatter-tooltip{display:flex;flex-direction:column;gap:.25rem}.scatter-tooltip-row{display:flex;align-items:center;gap:.375rem;font-weight:500}.scatter-tooltip-color{width:10px;height:10px;border-radius:50%;flex-shrink:0}.scatter-tooltip-label{color:#e2e8f0}.scatter-tooltip-value{font-size:.875rem;color:#fff}.scatter-tooltip-value span{color:#94a3b8}.axis-title{font-size:.75rem;fill:#475569;font-weight:500}.scatter-brush .selection{fill:#3b82f6;fill-opacity:.2;stroke:#3b82f6;stroke-width:1}.scatter-brush .overlay{cursor:crosshair}.scatter-brush .handle{fill:#3b82f6;fill-opacity:.5}.scatter-reset-button{position:absolute;top:.5rem;right:5.5rem;padding:.375rem .75rem;font-size:.75rem;font-weight:500;color:#3b82f6;background:#eff6ff;border:1px solid #bfdbfe;border-radius:4px;cursor:pointer;transition:all .15s ease;z-index:10}.scatter-reset-button:hover{background:#dbeafe;border-color:#93c5fd}.scatter-reset-button:active{background:#bfdbfe}.timeseries-legend{position:absolute;bottom:2rem;right:.5rem;display:flex;flex-direction:column;gap:.375rem;padding:.5rem;background:#ffffffe6;border-radius:4px;font-size:.75rem}.legend-line{width:20px;height:3px;border-radius:1px;flex-shrink:0}.legend-line-dashed{background:repeating-linear-gradient(90deg,currentColor 0px,currentColor 6px,transparent 6px,transparent 10px)}.tooltip-ma-value{display:flex;align-items:center;gap:.375rem;margin-top:.25rem;padding-top:.25rem;border-top:1px solid rgba(255,255,255,.2)}.grouped-bar-legend{position:absolute;bottom:.5rem;left:50%;transform:translate(-50%);display:flex;gap:1rem;padding:.5rem;background:#ffffffe6;border-radius:4px}.bubble-dot{cursor:pointer;transition:opacity .15s ease}.bubble-dot:hover{opacity:1;stroke-width:3}.bubble-legend{position:absolute;right:.5rem;top:50%;transform:translateY(-50%);display:flex;flex-direction:column;gap:.5rem;padding:.5rem}.sparkline-grid-container{min-height:400px}.sparkline-label{font-size:.7rem;fill:#475569;font-weight:500}.sparkline-trend{font-size:.875rem;font-weight:600}.sparkline-total{font-size:.65rem;fill:#94a3b8}.sparkline-hover-point{cursor:pointer}.sparkline-hover-point:hover{fill:#0000001a}.radar-axis-label{font-size:.7rem;fill:#475569;font-weight:500}.radar-point{cursor:pointer;transition:r .15s ease}.radar-point:hover{r:7}.radar-legend{position:absolute;right:.5rem;top:50%;transform:translateY(-50%);display:flex;flex-direction:column;gap:.5rem;padding:.5rem;background:#ffffffe6;border-radius:4px}.data-table-wrapper{display:flex;flex-direction:column}.data-table{width:100%;border-collapse:collapse;font-size:.875rem}.data-table th,.data-table td{padding:.75rem 1rem;text-align:left;white-space:nowrap}.data-table th{background:#f8fafc;font-weight:600;color:#475569;border-bottom:2px solid #e2e8f0;position:sticky;top:0}.data-table td{border-bottom:1px solid #e2e8f0;color:#1e293b}.data-table tbody tr:hover{background:#f8fafc}.data-table-virtualized{display:flex;flex-direction:column;font-size:.875rem}.data-table-header-container{overflow:hidden;position:sticky;top:0;z-index:1;background:#f8fafc;border-bottom:2px solid #e2e8f0}.data-table-header-cell{padding:.75rem 1rem;font-weight:600;color:#475569;text-align:left;box-sizing:border-box;display:flex;align-items:center;overflow:hidden;word-wrap:break-word}.data-table-cell{padding:.75rem 1rem;color:#1e293b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;box-sizing:border-box;border-bottom:1px solid #e2e8f0}.data-table-cell.even{background:#fafafa}.data-table-cell.odd{background:#fff}.data-table-cell.even:hover,.data-table-cell.odd:hover{background:#f1f5f9}.data-table-empty{text-align:center;padding:2rem;color:#64748b}.data-table-toolbar{display:flex;justify-content:flex-start;padding:0 0 .75rem}.data-table-export-button{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.875rem;font-weight:500;color:#1e293b;background:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;cursor:pointer;transition:background .15s ease,border-color .15s ease}.data-table-export-button:hover{background:#f1f5f9;border-color:#cbd5e1}.data-table-export-button:focus{outline:none;box-shadow:0 0 0 3px #3b82f633;border-color:#3b82f6}.data-table-export-button svg{width:16px;height:16px}.export-button{display:flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;border:1px solid #e2e8f0;border-radius:6px;background:#fff;color:#64748b;cursor:pointer;transition:all .15s ease}.export-button:hover:not(:disabled){background:#f8fafc;border-color:#cbd5e1;color:#475569}.export-button:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.export-button:disabled{cursor:not-allowed;opacity:.6}.export-button svg{width:16px;height:16px}.export-button-spinner{animation:export-spin 1s linear infinite}@keyframes export-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.kpi-card{background:#fff;border-radius:12px;padding:1.25rem;box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f;border-left:4px solid #3b82f6;display:flex;align-items:center;gap:1rem}.kpi-icon{width:40px;height:40px;flex-shrink:0;opacity:.8}.kpi-icon svg{width:100%;height:100%}.kpi-content{flex:1;min-width:0}.kpi-title{margin:0;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#64748b}.kpi-value-row{display:flex;align-items:baseline;gap:.75rem;margin-top:.25rem}.kpi-value{font-size:1.75rem;font-weight:700;line-height:1.2;color:#1e293b}.kpi-trend{font-size:.875rem;font-weight:600;padding:.125rem .5rem;border-radius:4px}.kpi-trend.trend-up{background:#fef2f2;color:#dc2626}.kpi-trend.trend-down{background:#f0fdf4;color:#16a34a}.kpi-info{margin:.5rem 0 0;font-size:.65rem;font-style:italic;color:#94a3b8;text-align:right}@media(max-width:640px){.kpi-card{padding:1rem}.kpi-icon{width:32px;height:32px}.kpi-value{font-size:1.5rem}.kpi-info{font-size:.6rem;margin-top:.375rem}}.modal-backdrop{position:fixed;inset:0;z-index:1000;background:#0f172a99;display:flex;align-items:center;justify-content:center;padding:2rem}.modal-container{background:#fff;border-radius:12px;box-shadow:0 25px 50px -12px #00000040;max-width:90vw;max-height:80vh;width:1000px;display:flex;flex-direction:column;overflow:hidden}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid #e2e8f0;flex-shrink:0}.modal-title{font-size:1.25rem;font-weight:600;color:#1e293b;margin:0}.modal-close-button{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:6px;color:#64748b;cursor:pointer;transition:background .15s ease,color .15s ease}.modal-close-button:hover{background:#f1f5f9;color:#1e293b}.modal-close-button svg{width:20px;height:20px}.modal-content{flex:1;overflow:hidden;padding:1.5rem}.chart-card{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f;overflow:hidden;display:flex;flex-direction:column}.chart-card.full-width{grid-column:1 / -1}.chart-card-header{padding:1rem 1.25rem;border-bottom:1px solid #f1f5f9;display:flex;align-items:flex-start;justify-content:space-between;gap:1rem}.chart-card-header-text{display:flex;flex-direction:column}.chart-card-header-actions{display:flex;align-items:center;gap:.5rem}.chart-card-title{margin:0;font-size:1rem;font-weight:600;color:#1e293b}button.chart-card-title{background:none;border:none;padding:0;font:inherit;text-align:left}.chart-card-title-clickable{cursor:pointer;transition:color .15s ease}.chart-card-title-clickable:hover{color:#3b82f6}.chart-card-title-clickable:focus{outline:2px solid #3b82f6;outline-offset:2px;border-radius:2px}.chart-card-subtitle{margin:.25rem 0 0;font-size:.75rem;color:#64748b}.chart-card-control{display:flex;flex-direction:column;gap:.25rem}.chart-card-control-label{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#64748b}.chart-card-select{min-width:130px;padding:.4rem .75rem;font-size:.875rem;border:1px solid #cbd5e1;border-radius:6px;background:#fff;color:#1e293b}.chart-card-select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.chart-card-content{flex:1;padding:1rem;min-height:250px;display:flex;align-items:center;justify-content:center}.filter-panel{display:flex;flex-wrap:wrap;align-items:flex-end;gap:1.5rem;padding:1rem 1.5rem;background:#f8fafc;border-bottom:1px solid #e2e8f0}.filter-group{display:flex;flex-direction:column;gap:.5rem}.filter-label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#64748b}.year-range-inputs{display:flex;align-items:center;gap:.5rem}.year-input{width:80px;padding:.5rem .75rem;font-size:.875rem;border:1px solid #cbd5e1;border-radius:6px;background:#fff;color:#1e293b}.year-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.year-separator{color:#64748b;font-size:.875rem}.search-input{min-width:200px;padding:.5rem .75rem;font-size:.875rem;border:1px solid #cbd5e1;border-radius:6px;background:#fff;color:#1e293b}.search-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.search-input::placeholder{color:#94a3b8}.filter-buttons{display:flex;gap:.5rem}.material-buttons{flex-wrap:wrap}.filter-button{padding:.5rem 1rem;font-size:.875rem;font-weight:500;border:1px solid #cbd5e1;border-radius:6px;background:#fff;color:#475569;cursor:pointer;transition:all .15s ease}.filter-button:hover{background:#f1f5f9;border-color:#94a3b8}.filter-button.active{background:#3b82f6;border-color:#3b82f6;color:#fff}.filter-button.tier-button.tier-1.active{background:#dc2626;border-color:#dc2626}.filter-button.tier-button.tier-2.active{background:#f97316;border-color:#f97316}.reset-button{margin-left:auto;padding:.5rem 1rem;font-size:.875rem;font-weight:500;border:1px solid #e2e8f0;border-radius:6px;background:#fff;color:#64748b;cursor:pointer;transition:all .15s ease}.reset-button:hover{background:#f1f5f9;color:#475569}@media(max-width:768px){.filter-panel{flex-direction:column;align-items:stretch}.reset-button{margin-left:0;margin-top:.5rem}}.dashboard-header{display:flex;align-items:center;gap:1.5rem;padding:1rem 1.5rem;background:linear-gradient(135deg,#1e3a5f,#0f172a);border-bottom:3px solid #3b82f6}.header-logo{flex-shrink:0}.logo-image{height:48px;width:auto}.header-title h1{margin:0;font-size:1.5rem;font-weight:600;color:#fff;letter-spacing:-.025em}.header-subtitle{margin:.25rem 0 0;font-size:.875rem;color:#94a3b8}
