:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}input,select{color:#000}body{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;margin:0;padding:0;background-color:#f0f2f5;color:#333}#root,.app-container{min-height:100vh;width:100%;display:flex;flex-direction:column}.main-content{flex:1;width:100%;padding:2rem;box-sizing:border-box}.dashboard-page h1{color:#2c3e50;text-align:center;margin-bottom:2rem}.dashboard-filters-form{background-color:#fff;padding:1.5rem;border-radius:8px;box-shadow:0 4px 6px #0000001a;margin-bottom:2rem;display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem}.dashboard-filters-form div{display:flex;flex-direction:column}.dashboard-filters-form label{margin-bottom:.5rem;font-weight:500;color:#34495e}.dashboard-filters-form input[type=text],.dashboard-filters-form input[type=number],.dashboard-filters-form input[type=date],.dashboard-filters-form select{padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem;background-color:#f9f9f9}.dashboard-filters-form input[type=checkbox]{margin-right:.5rem}.dashboard-filters-form fieldset{border:1px solid #ddd;border-radius:4px;padding:1rem;margin-top:1rem;grid-column:1 / -1}.dashboard-filters-form fieldset legend{font-weight:600;color:#2c3e50;padding:0 .5rem}.dashboard-filters-form fieldset div{flex-direction:row;align-items:center;margin-bottom:.5rem}.dashboard-filters-form fieldset div label{margin-bottom:0;font-weight:400}.dashboard-filters-form button[type=submit]{background-color:#3498db;color:#fff;padding:.75rem 1.5rem;border:none;border-radius:4px;font-size:1rem;cursor:pointer;transition:background-color .2s ease-in-out;grid-column:1 / -1;justify-self:start;margin-top:1rem}.dashboard-filters-form button[type=submit]:hover{background-color:#2980b9}.dashboard-filters-form button[type=submit]:disabled{background-color:#bdc3c7;cursor:not-allowed}.charts-container{margin-top:2rem}.charts-container h2{color:#2c3e50;margin-bottom:1.5rem;border-bottom:2px solid #ecf0f1;padding-bottom:.5rem}.charts-container section{background-color:#fff;padding:1.5rem;border-radius:8px;box-shadow:0 4px 6px #0000001a;margin-bottom:2rem}.charts-container section h3{color:#34495e;margin-top:0;margin-bottom:1rem}.chart-container h3{text-align:center;margin-bottom:1rem;color:#34495e}.error-message{color:#e74c3c;background-color:#fdd;padding:1rem;border-radius:4px;border:1px solid #e74c3c;margin-top:1rem}.loading-message{font-size:1.2rem;color:#3498db;text-align:center;padding:2rem}.data-table-container{margin-top:20px;overflow-x:auto;background-color:#f9f9f9;padding:15px;border-radius:8px;box-shadow:0 2px 4px #0000001a}.data-table-container h3,.comparison-data-table-container h3{margin-top:0;margin-bottom:10px;font-size:1.2em;color:#333}.data-table{width:100%;border-collapse:collapse;margin-bottom:20px;background-color:#fff;box-shadow:0 1px 3px #0000001a;border-radius:8px;overflow:hidden}.data-table th,.data-table td{border:1px solid #e0e0e0;padding:6px 10px;text-align:left;font-size:12px}.data-table th{background-color:#f7f7f7;font-weight:600;color:#555;font-size:12px}.data-table tbody tr:nth-child(2n){background-color:#fdfdfd}.data-table tbody tr:hover{background-color:#f0f5ff}.data-table tr.metric-group-end td{border-bottom:2px solid #adb5bd}.data-table tr.section-group-end td{border-bottom:3px solid #495057}.comparison-data-table th:first-child,.comparison-data-table td:first-child{width:1%;white-space:nowrap;font-weight:500}.comparison-data-table td{white-space:nowrap}.chart-container{width:100%;min-height:300px;margin-bottom:3.5rem}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease-in}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background-color:#fff;border-radius:8px;padding:0;max-width:450px;width:90%;box-shadow:0 4px 20px #00000026;animation:slideIn .3s ease-out}@keyframes slideIn{0%{transform:translateY(-50px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #e5e7eb}.modal-header h2{margin:0;font-size:1.5rem;color:#1f2937}.modal-close-button{background:none;border:none;font-size:2rem;color:#6b7280;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background-color .2s,color .2s}.modal-close-button:hover:not(:disabled){background-color:#f3f4f6;color:#1f2937}.modal-close-button:disabled{opacity:.5;cursor:not-allowed}.login-form{padding:24px}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:6px;font-weight:500;color:#374151;font-size:.95rem}.form-group input{width:100%;padding:10px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:1rem;transition:border-color .2s,box-shadow .2s;box-sizing:border-box}.form-group input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.form-group input:disabled{background-color:#f9fafb;cursor:not-allowed;opacity:.6}.error-message{background-color:#fef2f2;border:1px solid #fecaca;color:#dc2626;padding:12px;border-radius:6px;margin-bottom:20px;font-size:.95rem}.modal-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:24px;padding-top:20px;border-top:1px solid #e5e7eb}.btn-primary,.btn-secondary{padding:10px 20px;border:none;border-radius:6px;font-size:1rem;font-weight:500;cursor:pointer;transition:background-color .2s,transform .1s}.btn-primary{background-color:#3b82f6;color:#fff}.btn-primary:hover:not(:disabled){background-color:#2563eb}.btn-primary:active:not(:disabled){transform:scale(.98)}.btn-primary:disabled{background-color:#9ca3af;cursor:not-allowed}.btn-secondary{background-color:#f3f4f6;color:#374151}.btn-secondary:hover:not(:disabled){background-color:#e5e7eb}.btn-secondary:active:not(:disabled){transform:scale(.98)}.btn-secondary:disabled{opacity:.5;cursor:not-allowed}.app-header{background-color:#1f2937;color:#fff;box-shadow:0 2px 4px #0000001a;position:sticky;top:0;z-index:100}.header-content{width:100%;padding:0 2rem;display:flex;justify-content:space-between;align-items:center;height:64px;box-sizing:border-box}.header-left h1{margin:0;font-size:1.5rem;font-weight:600;color:#fff}.header-right{display:flex;align-items:center}.auth-controls{display:flex;align-items:center;gap:16px}.auth-status{display:flex;align-items:center;gap:8px;font-size:.95rem;color:#d1d5db}.status-dot{width:8px;height:8px;background-color:#10b981;border-radius:50%;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.btn-login,.btn-logout{padding:8px 20px;border:none;border-radius:6px;font-size:.95rem;font-weight:500;cursor:pointer;transition:background-color .2s,transform .1s}.btn-login{background-color:#3b82f6;color:#fff}.btn-login:hover{background-color:#2563eb}.btn-login:active{transform:scale(.98)}.btn-logout{background-color:transparent;color:#d1d5db;border:1px solid #4b5563}.btn-logout:hover{background-color:#374151;color:#fff;border-color:#6b7280}.btn-logout:active{transform:scale(.98)}
