*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0f1117;--card: #181b24;--border: #262a36;--text: #e2e4e9;--text-dim: #8b8fa3;--accent: #6c8aff;--accent-hover: #8ba3ff;--green: #4ade80;--amber: #fbbf24;--red: #f87171;--radius: 10px}html{font-size:15px}body{font-family:Inter,-apple-system,sans-serif;background:var(--bg);color:var(--text);min-height:100vh;-webkit-font-smoothing:antialiased}.mono{font-family:JetBrains Mono,monospace}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#3a3f50}.login-screen{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:20px}.login-box{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:40px;width:100%;max-width:400px}.login-box h1{font-size:1.5rem;font-weight:600;margin-bottom:6px}.login-box p{color:var(--text-dim);font-size:.875rem;margin-bottom:24px}.login-box .field{margin-bottom:16px}.login-box label{display:block;font-size:.8rem;color:var(--text-dim);margin-bottom:6px;text-transform:uppercase;letter-spacing:.05em}.login-box input{width:100%;padding:10px 14px;background:var(--bg);border:1px solid var(--border);border-radius:6px;color:var(--text);font-size:.95rem;font-family:inherit;outline:none;transition:border-color .2s}.login-box input:focus{border-color:var(--accent)}.login-box .error{color:var(--red);font-size:.85rem;margin-bottom:12px}.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;background:var(--accent);color:#fff;border:none;border-radius:6px;font-size:.9rem;font-weight:500;font-family:inherit;cursor:pointer;transition:background .2s}.btn:hover{background:var(--accent-hover)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-sm{padding:6px 14px;font-size:.8rem}.btn-danger{background:#dc2626}.btn-danger:hover{background:#ef4444}.btn-outline{background:transparent;border:1px solid var(--border);color:var(--text)}.btn-outline:hover{border-color:var(--accent);color:var(--accent)}.header{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;border-bottom:1px solid var(--border);background:var(--card)}.header-left{display:flex;align-items:center;gap:12px}.header h1{font-size:1.1rem;font-weight:600}.header-right{display:flex;align-items:center;gap:12px}.header-meta{font-size:.75rem;color:var(--text-dim)}.header-user{font-size:.8rem;color:var(--text-dim)}.hamburger{display:none;flex-direction:column;justify-content:center;gap:4px;width:32px;height:32px;background:none;border:1px solid var(--border);border-radius:6px;padding:6px;cursor:pointer}.hamburger span{display:block;height:2px;background:var(--text);border-radius:1px}.time-filter{position:relative;margin-left:auto}.time-filter-btn{display:flex;align-items:center;gap:6px;padding:8px 14px;background:var(--bg);border:1px solid var(--border);border-radius:6px;color:var(--text);font-size:.82rem;font-family:inherit;cursor:pointer;white-space:nowrap;transition:border-color .2s}.time-filter-btn:hover{border-color:var(--accent)}.time-filter-caret{font-size:.65rem;color:var(--text-dim)}.time-filter-dropdown{position:absolute;top:calc(100% + 4px);right:0;background:var(--card);border:1px solid var(--border);border-radius:8px;min-width:200px;z-index:50;overflow:hidden;box-shadow:0 8px 24px #0006}.time-filter-option{display:block;width:100%;padding:10px 16px;text-align:left;background:none;border:none;border-bottom:1px solid var(--border);color:var(--text-dim);font-size:.85rem;font-family:inherit;cursor:pointer;transition:all .15s}.time-filter-option:hover{background:var(--bg);color:var(--text)}.time-filter-option.active{color:var(--accent)}.time-filter-option:last-child{border-bottom:none}.time-filter-custom-inputs{display:flex;align-items:center;gap:8px;padding:10px 16px;border-top:1px solid var(--border)}.time-filter-custom-inputs input[type=date]{padding:6px 8px;background:var(--bg);border:1px solid var(--border);border-radius:4px;color:var(--text);font-size:.8rem;font-family:inherit;outline:none;width:130px}.time-filter-custom-inputs input[type=date]:focus{border-color:var(--accent)}.month-groups{display:flex;flex-direction:column;gap:8px}.month-group{border:1px solid var(--border);border-radius:8px;overflow:hidden;background:var(--bg)}.month-header{display:flex;align-items:center;gap:12px;width:100%;padding:12px 16px;background:none;border:none;color:var(--text);font-family:inherit;font-size:.9rem;cursor:pointer;text-align:left;transition:background .15s}.month-header:hover{background:#ffffff08}.month-caret{color:var(--text-dim);font-size:.8rem;width:12px}.month-name{font-weight:600;min-width:140px}.month-stats{display:flex;gap:20px;margin-left:auto;font-size:.82rem;color:var(--text-dim)}.month-stat b{color:var(--text);margin-left:4px}.month-body{padding:0 16px 12px}.month-body table{margin-top:4px}@media(max-width:768px){.month-header{flex-wrap:wrap}.month-stats{margin-left:0;width:100%;gap:12px;font-size:.75rem}}.tabs{display:flex;align-items:center;gap:2px;padding:0 24px;background:var(--card);border-bottom:1px solid var(--border);overflow:visible;position:relative}.tab{padding:12px 18px;font-size:.85rem;font-weight:500;color:var(--text-dim);cursor:pointer;border-bottom:2px solid transparent;transition:all .2s;white-space:nowrap;background:none;border-top:none;border-left:none;border-right:none;font-family:inherit}.tab:hover{color:var(--text)}.tab.active{color:var(--accent);border-bottom-color:var(--accent)}.mobile-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:90}.mobile-menu{display:none;position:fixed;top:0;left:-280px;width:280px;height:100vh;background:var(--card);border-right:1px solid var(--border);z-index:100;transition:left .25s ease;flex-direction:column;overflow-y:auto}.mobile-menu.open{left:0}.mobile-menu-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border);font-weight:600;font-size:.95rem}.mobile-menu-close{background:none;border:none;color:var(--text-dim);font-size:1.5rem;cursor:pointer;line-height:1}.mobile-menu-item{display:block;width:100%;padding:14px 20px;text-align:left;background:none;border:none;border-bottom:1px solid var(--border);color:var(--text-dim);font-size:.9rem;font-family:inherit;cursor:pointer;transition:all .15s}.mobile-menu-item:hover{background:var(--bg);color:var(--text)}.mobile-menu-item.active{color:var(--accent);background:#6c8aff14}.mobile-menu-actions{padding:16px 20px;border-top:1px solid var(--border);margin-top:auto}.content{padding:24px;max-width:1400px;margin:0 auto}@media(max-width:768px){.hamburger{display:flex}.desktop-tabs{display:none}.mobile-overlay{display:block}.mobile-menu{display:flex}.header{padding:12px 16px}.header h1{font-size:.95rem}.header-meta,.header-user{display:none}.header-right{gap:8px}.header-right .desktop-only{display:none}.content{padding:16px}.kpi-grid{grid-template-columns:repeat(2,1fr);gap:10px}.grid-2{grid-template-columns:1fr}}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin-bottom:24px}.kpi-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:20px}.kpi-card .kpi-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-dim);margin-bottom:8px}.kpi-card .kpi-value{font-family:JetBrains Mono,monospace;font-size:1.6rem;font-weight:600}.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:20px;margin-bottom:20px}.card h3{font-size:.95rem;font-weight:600;margin-bottom:16px}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:20px}.grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:20px}@media(max-width:900px){.grid-2,.grid-3{grid-template-columns:1fr}}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:.85rem}th{text-align:left;padding:10px 12px;font-weight:600;font-size:.75rem;text-transform:uppercase;letter-spacing:.04em;color:var(--text-dim);border-bottom:1px solid var(--border);cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap}th:hover{color:var(--text)}th.sorted{color:var(--accent)}td{padding:10px 12px;border-bottom:1px solid var(--border)}tr:last-child td{border-bottom:none}td.mono{font-family:JetBrains Mono,monospace;font-size:.82rem}.ontime-green{color:var(--green)}.ontime-amber{color:var(--amber)}.ontime-red{color:var(--red)}.upload-screen{display:flex;align-items:center;justify-content:center;min-height:calc(100vh - 120px);padding:24px}.upload-box{background:var(--card);border:2px dashed var(--border);border-radius:var(--radius);padding:60px 40px;text-align:center;max-width:500px;width:100%;transition:border-color .2s}.upload-box:hover{border-color:var(--accent)}.upload-box h2{font-size:1.3rem;margin-bottom:8px}.upload-box p{color:var(--text-dim);font-size:.9rem;margin-bottom:24px}.upload-box input[type=file]{display:none}.upload-box .upload-label{display:inline-flex;align-items:center;gap:8px;padding:12px 28px;background:var(--accent);color:#fff;border-radius:6px;font-size:.95rem;font-weight:500;cursor:pointer;transition:background .2s}.upload-box .upload-label:hover{background:var(--accent-hover)}.takeaways{background:var(--card);border:1px solid var(--border);border-left:3px solid var(--accent);border-radius:var(--radius);padding:20px;margin-bottom:20px}.takeaways h3{font-size:.95rem;font-weight:600;margin-bottom:12px}.takeaways ul{list-style:none;padding:0}.takeaways li{padding:6px 0;font-size:.88rem;color:var(--text-dim);line-height:1.5}.takeaways li:before{content:"→ ";color:var(--accent)}.settings-section{max-width:600px}.settings-section h3{margin-bottom:16px}.user-form{display:flex;gap:10px;margin-bottom:20px}.user-form input{flex:1;padding:8px 12px;background:var(--bg);border:1px solid var(--border);border-radius:6px;color:var(--text);font-size:.9rem;font-family:inherit;outline:none}.user-form input:focus{border-color:var(--accent)}.loading{display:flex;align-items:center;justify-content:center;min-height:200px;color:var(--text-dim)}.recharts-cartesian-grid-horizontal line,.recharts-cartesian-grid-vertical line{stroke:var(--border)}.recharts-text{fill:var(--text-dim);font-size:11px}.recharts-tooltip-wrapper .recharts-default-tooltip{background:var(--card)!important;border:1px solid var(--border)!important;border-radius:6px!important}.recharts-tooltip-label{color:var(--text)!important}.recharts-tooltip-item{color:var(--text-dim)!important}
