.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg)}.login-box{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:48px 40px;width:100%;max-width:380px;display:flex;flex-direction:column;align-items:center;gap:16px;box-shadow:0 8px 32px #0006}.login-logo{width:64px;height:64px;margin-bottom:4px}.login-box h1{font-size:24px;color:var(--accent);letter-spacing:.02em}.login-box p{font-size:13px;color:var(--muted);text-align:center}.btn-google,.btn-outlook{width:100%;padding:12px;border-radius:6px;border:1px solid var(--border);font-size:14px;font-weight:500;cursor:pointer}.btn-google{background:#fff;color:#333;border-color:#ddd}.btn-google:hover{background:#f5f5f5}.btn-outlook{background:#0072c6;color:#fff;border-color:#0072c6}.btn-outlook:hover{background:#005fa3}.dashboard{height:100vh;display:flex;flex-direction:column;background:var(--bg);overflow:hidden}.topbar{display:flex;align-items:center;gap:24px;padding:12px 20px;background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0;flex-wrap:wrap}.topbar-left{display:flex;align-items:center;gap:12px;flex-shrink:0}.topbar-logo{width:32px;height:32px}.topbar-title{font-size:15px;font-weight:700;color:var(--accent)}.topbar-sub{font-size:11px;color:var(--muted)}.topbar-stats{display:flex;gap:32px;flex:1;justify-content:center}.tstat{text-align:center}.tstat-value{font-size:20px;font-weight:700;color:var(--text);line-height:1}.tstat.accent .tstat-value{color:var(--accent)}.tstat-label{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;margin-top:2px}.topbar-right{display:flex;align-items:center;gap:10px;flex-shrink:0}.rate-badge{font-size:13px;color:var(--accent);border:1px dashed var(--accent-dim);border-radius:4px;padding:4px 10px;cursor:pointer}.rate-badge:hover{background:#d4a0171a}.rate-input-top{width:90px;font-size:13px;padding:4px 8px;border-radius:4px}.topbar-email{font-size:11px;color:var(--muted)}.btn-test{background:transparent;color:var(--accent);border:1px solid var(--accent-dim);padding:8px 14px;border-radius:6px;font-size:12px;font-weight:600;cursor:pointer;white-space:nowrap;font-family:var(--font-mono)}.btn-test:hover:not(:disabled){background:#d4a0171a}.btn-test:disabled{opacity:.5;cursor:not-allowed}.btn-pull{background:var(--accent);color:#000;border:none;padding:8px 16px;border-radius:6px;font-size:12px;font-weight:700;cursor:pointer;white-space:nowrap}.btn-pull:hover:not(:disabled){background:var(--accent-dim);color:#fff}.btn-pull:disabled{opacity:.5;cursor:not-allowed}.btn-signout{background:transparent;color:var(--muted);border:1px solid var(--border);padding:8px 14px;border-radius:6px;font-size:12px;cursor:pointer}.btn-signout:hover{border-color:var(--danger);color:var(--danger)}.filter-bar{display:flex;align-items:center;gap:8px;padding:8px 20px;background:#d4a0170f;border-bottom:1px solid var(--border);flex-shrink:0}.filter-chip{font-size:12px;color:var(--accent);background:#d4a0171f;border:1px solid var(--accent-dim);border-radius:4px;padding:3px 8px;display:flex;align-items:center;gap:6px}.filter-chip button{background:none;border:none;color:var(--accent);font-size:14px;line-height:1;cursor:pointer;padding:0}.filter-clear{background:none;border:none;color:var(--muted);font-size:12px;cursor:pointer;margin-left:auto;font-family:var(--font-mono)}.filter-clear:hover{color:var(--text)}.main-columns{display:grid;grid-template-columns:1fr 2fr 1fr;flex:1;overflow:hidden;gap:0}@media (max-width: 1024px){.main-columns{grid-template-columns:1fr 1.6fr}.col-activity{display:none}}@media (max-width: 640px){.dashboard{padding-bottom:56px}.main-columns{grid-template-columns:1fr}.col{border-right:none}.mobile-hidden{display:none}.topbar{flex-wrap:wrap;gap:8px}.topbar-stats{width:100%;justify-content:space-around;order:3}.topbar-email{display:none}}@media (min-width: 641px){.mobile-hidden,.col-activity{display:flex!important}}.col{display:flex;flex-direction:column;border-right:1px solid var(--border);overflow:hidden}.col:last-child{border-right:none}.col-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);border-bottom:1px solid var(--border);flex-shrink:0;background:var(--surface)}.col-header-count{background:var(--border);color:var(--text);font-size:11px;border-radius:10px;padding:1px 7px}.col-header-clear{background:none;border:none;color:var(--muted);font-size:11px;cursor:pointer;font-family:var(--font-mono)}.col-header-clear:hover{color:var(--accent)}.col-scroll{flex:1;overflow-y:auto;padding:8px}.col-scroll::-webkit-scrollbar{width:4px}.col-scroll::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}.empty-msg{text-align:center;color:var(--muted);font-size:12px;padding:32px 16px}.client-row{padding:10px 10px 8px;border-radius:6px;margin-bottom:4px;cursor:pointer;border:1px solid transparent;transition:all .12s}.client-row:hover{background:#ffffff08;border-color:var(--border)}.client-row.active{background:#d4a01714;border-color:var(--accent-dim)}.client-row-top{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:6px}.client-name{font-size:13px;color:var(--text);font-weight:500}.client-rev{font-size:13px;color:var(--accent);font-weight:600}.client-bar-track{height:3px;background:var(--border);border-radius:2px;margin-bottom:6px;overflow:hidden}.client-bar-fill{height:100%;background:var(--accent);border-radius:2px;transition:width .3s}.client-row-bottom{display:flex;justify-content:space-between;align-items:center}.client-hours{font-size:11px;color:var(--muted)}.btn-invoice-sm{background:transparent;border:1px solid var(--accent-dim);color:var(--accent);padding:3px 9px;border-radius:4px;font-size:11px;cursor:pointer;font-family:var(--font-mono)}.btn-invoice-sm:hover{background:var(--accent);color:#000}.add-entry-bar{display:flex;align-items:center;gap:6px;padding:10px 12px;border-top:1px solid var(--border);background:var(--surface);flex-shrink:0}.add-entry-bar input{padding:7px 10px;font-size:12px;border-radius:5px;flex:1;min-width:0}.add-entry-bar input[type=number]{flex:0 0 80px}.add-entry-bar input[type=date]{flex:0 0 130px}.btn-add{background:var(--accent);color:#000;border:none;padding:8px 14px;border-radius:5px;font-size:12px;font-weight:700;cursor:pointer;font-family:var(--font-mono);white-space:nowrap;flex-shrink:0}.btn-add:hover{background:var(--accent-dim);color:#fff}.entry-row{padding:10px 12px;border-radius:6px;margin-bottom:4px;border:1px solid var(--border);background:var(--surface);transition:border-color .12s}.entry-row:hover{border-color:#30363d}.entry-row.invoiced{opacity:.5}.entry-top{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:3px}.entry-client{font-size:13px;font-weight:600;color:var(--text)}.entry-amount{font-size:13px;color:var(--accent);font-weight:600}.entry-desc{font-size:12px;color:var(--muted);margin-bottom:6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.entry-bottom{display:flex;justify-content:space-between;align-items:center}.entry-meta{font-size:11px;color:var(--muted)}.entry-actions{display:flex;gap:4px;align-items:center}.btn-tag{background:transparent;border:1px solid var(--border);color:var(--muted);padding:3px 8px;border-radius:4px;font-size:10px;cursor:pointer;font-family:var(--font-mono)}.btn-tag.tag-green{border-color:var(--success);color:var(--success)}.btn-tag.tag-blue{border-color:var(--blue);color:var(--blue)}.btn-tag:disabled{opacity:.3;cursor:not-allowed}.btn-del{background:transparent;border:1px solid transparent;color:var(--muted);padding:3px 6px;border-radius:4px;font-size:14px;line-height:1;cursor:pointer}.btn-del:hover{color:var(--danger);border-color:var(--danger)}.editable-field{cursor:pointer;border-bottom:1px dashed var(--border);padding-bottom:1px;transition:border-color .12s,color .12s}.editable-field:hover{color:var(--accent);border-color:var(--accent)}.inline-edit{background:var(--bg);border:1px solid var(--accent);color:var(--text);border-radius:3px;padding:1px 5px;font-size:11px;font-family:var(--font-mono);outline:none;width:110px}.inline-edit-hours{width:60px}.inline-edit-matter{width:110px;padding:1px 4px;background:var(--bg);border:1px solid var(--accent);color:var(--text);border-radius:3px;font-size:11px;font-family:var(--font-mono)}.matter-badge{color:var(--muted)}.day-row{padding:10px;border-radius:6px;margin-bottom:4px;cursor:pointer;border:1px solid transparent;transition:all .12s}.day-row:hover{background:#ffffff08;border-color:var(--border)}.day-row.active{background:#d4a01714;border-color:var(--accent-dim)}.day-row-top{display:flex;justify-content:space-between;margin-bottom:4px}.day-date{font-size:12px;color:var(--text)}.day-rev{font-size:12px;color:var(--accent);font-weight:600}.day-row-bottom{display:flex;justify-content:space-between}.day-hours,.day-count{font-size:11px;color:var(--muted)}.mobile-tabs{display:none}@media (max-width: 640px){.mobile-tabs{display:flex;position:fixed;bottom:0;left:0;right:0;height:56px;background:var(--surface);border-top:1px solid var(--border);z-index:100}.mobile-tabs button{flex:1;background:none;border:none;color:var(--muted);font-size:12px;font-family:var(--font-mono);cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;border-top:2px solid transparent;transition:all .12s}.mobile-tabs button.active{color:var(--accent);border-top-color:var(--accent)}.tab-badge{background:var(--border);border-radius:8px;padding:1px 6px;font-size:10px}.mobile-tabs button.active .tab-badge{background:#d4a01733;color:var(--accent)}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0d1117;--surface: #161b22;--border: #21262d;--accent: #d4a017;--accent-dim: #9a7510;--text: #e6edf3;--muted: #8b949e;--success: #3fb950;--danger: #f85149;--blue: #58a6ff;--font-mono: "DM Mono", "Fira Code", "Courier New", monospace;--font-sans: "DM Sans", system-ui, sans-serif}html,body,#root{height:100%}body{background:var(--bg);color:var(--text);font-family:var(--font-mono);-webkit-font-smoothing:antialiased}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}button{font-family:var(--font-mono);cursor:pointer;transition:all .15s}input,select,textarea{font-family:var(--font-mono);background:var(--bg);border:1px solid var(--border);color:var(--text);border-radius:4px;padding:6px 10px;font-size:13px;outline:none}input:focus,select:focus,textarea:focus{border-color:var(--accent)}
