:root{--bg: #f8fafc;--surface: #ffffff;--surface-2: #f1f5f9;--surface-3: #e2e8f0;--border: #e2e8f0;--border-strong: #cbd5e1;--text: #0f172a;--text-muted: #475569;--text-subtle: #94a3b8;--primary: #6366f1;--primary-hover: #4f46e5;--primary-light: #eef2ff;--primary-text: #4338ca;--success: #10b981;--success-light: #d1fae5;--success-text: #065f46;--warning: #f59e0b;--warning-light: #fef3c7;--danger: #ef4444;--danger-hover: #dc2626;--danger-light: #fee2e2;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow: 0 1px 3px 0 rgb(0 0 0 / .1), 0 1px 2px -1px rgb(0 0 0 / .1);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--radius: 8px;--radius-lg: 12px;--radius-full: 9999px;--font: "Inter", system-ui, -apple-system, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", "Cascadia Code", monospace;--header-h: 56px;--max-w: 1100px}[data-theme=dark]{--bg: #0f172a;--surface: #1e293b;--surface-2: #334155;--surface-3: #475569;--border: #334155;--border-strong: #475569;--text: #f1f5f9;--text-muted: #94a3b8;--text-subtle: #64748b;--primary: #818cf8;--primary-hover: #6366f1;--primary-light: #1e1b4b;--primary-text: #a5b4fc;--success: #34d399;--success-light: #064e3b;--success-text: #6ee7b7;--warning: #fbbf24;--warning-light: #451a03;--danger: #f87171;--danger-hover: #ef4444;--danger-light: #450a0a;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .3);--shadow: 0 1px 3px 0 rgb(0 0 0 / .4);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .4);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .4)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:var(--font);background:var(--bg);color:var(--text);line-height:1.5;min-height:100vh;transition:background .2s,color .2s}button{cursor:pointer;font-family:inherit}input,textarea,select{font-family:inherit;font-size:inherit}a{color:var(--primary)}.app{display:flex;flex-direction:column;min-height:100vh}.header{position:sticky;top:0;z-index:100;height:var(--header-h);background:var(--surface);border-bottom:1px solid var(--border);box-shadow:var(--shadow-sm);display:flex;align-items:center;padding:0 24px;gap:16px}.header-brand{display:flex;align-items:center;gap:10px;font-size:1.1rem;font-weight:700;color:var(--text);text-decoration:none;white-space:nowrap}.header-brand-icon{width:32px;height:32px;background:var(--primary);border-radius:var(--radius);display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}.header-timer-pill{display:flex;align-items:center;gap:10px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-full);padding:6px 14px 6px 10px;font-size:.85rem;flex:1;min-width:0;max-width:480px}.timer-live-dot{width:8px;height:8px;border-radius:50%;background:var(--success);flex-shrink:0;animation:pulse 2s infinite}.timer-pill-label{flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--text-muted);font-size:.83rem}.timer-pill-label strong{color:var(--text);font-weight:600}.timer-pill-elapsed{font-family:var(--font-mono);font-size:.9rem;font-weight:600;color:var(--primary);white-space:nowrap}.header-spacer{flex:1}.header-actions{display:flex;align-items:center;gap:8px}.main{max-width:var(--max-w);margin:0 auto;padding:24px 24px 80px;width:100%;display:flex;flex-direction:column;gap:20px}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:var(--radius);font-size:.875rem;font-weight:500;border:none;transition:background .15s,color .15s,opacity .15s,transform .1s;white-space:nowrap;-webkit-user-select:none;user-select:none}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-hover)}.btn-secondary{background:var(--surface-2);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover{background:var(--surface-3)}.btn-ghost{background:transparent;color:var(--text-muted)}.btn-ghost:hover{background:var(--surface-2);color:var(--text)}.btn-danger{background:var(--danger-light);color:var(--danger)}.btn-danger:hover{background:var(--danger);color:#fff}.btn-success{background:var(--success);color:#fff}.btn-success:hover{background:#059669}.btn-sm{padding:5px 12px;font-size:.8rem}.btn-lg{padding:11px 22px;font-size:.95rem}.btn-icon{padding:7px;border-radius:var(--radius);background:transparent;color:var(--text-muted);border:none;display:flex;align-items:center;justify-content:center;transition:background .15s,color .15s;font-size:1rem}.btn-icon:hover{background:var(--surface-2);color:var(--text)}.form-group{display:flex;flex-direction:column;gap:4px}.form-label{font-size:.8rem;font-weight:600;color:var(--text-muted);letter-spacing:.02em;text-transform:uppercase}input[type=text],input[type=date],input[type=time],input[type=number],textarea,select{width:100%;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:8px 12px;color:var(--text);font-size:.9rem;outline:none;transition:border-color .15s,box-shadow .15s}input:focus,textarea:focus,select:focus{border-color:var(--primary);box-shadow:0 0 0 3px color-mix(in srgb,var(--primary) 20%,transparent)}input[type=date]::-webkit-calendar-picker-indicator,input[type=time]::-webkit-calendar-picker-indicator{filter:invert(var(--icon-invert, 0));opacity:.6;cursor:pointer}[data-theme=dark] input[type=date]::-webkit-calendar-picker-indicator,[data-theme=dark] input[type=time]::-webkit-calendar-picker-indicator{filter:invert(1)}textarea{resize:vertical;min-height:60px}select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%2394a3b8' stroke-width='2'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' d='M19 9l-7 7-7-7'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center;background-size:16px;padding-right:32px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.dashboard{display:grid;grid-template-columns:repeat(3,1fr) auto;gap:12px;align-items:stretch}.dashboard-stat{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px 20px;display:flex;flex-direction:column;gap:4px;box-shadow:var(--shadow-sm)}.dashboard-stat-label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-subtle)}.dashboard-stat-value{font-size:1.75rem;font-weight:700;color:var(--text);line-height:1;font-variant-numeric:tabular-nums}.dashboard-stat-sub{font-size:.78rem;color:var(--text-subtle)}.dashboard-stat.accent{border-color:var(--primary)}.dashboard-stat.accent .dashboard-stat-value{color:var(--primary)}.dashboard-actions{display:flex;flex-direction:column;gap:8px;justify-content:center;align-items:flex-end}.timer-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px 24px;box-shadow:var(--shadow-sm)}.timer-card.running{border-color:var(--primary);box-shadow:0 0 0 1px var(--primary),var(--shadow)}.timer-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;gap:12px}.timer-card-title{font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--text-subtle)}.timer-display{font-family:var(--font-mono);font-size:2.4rem;font-weight:700;letter-spacing:-.02em;color:var(--primary);font-variant-numeric:tabular-nums}.timer-form{display:grid;grid-template-columns:1fr 1fr;gap:10px}.timer-form-full{grid-column:1 / -1}.timer-controls{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-top:12px}.timer-controls-right{margin-left:auto;display:flex;gap:8px}.shortcut-hint{font-size:.72rem;color:var(--text-subtle);display:flex;align-items:center;gap:4px}kbd{background:var(--surface-2);border:1px solid var(--border);border-radius:4px;padding:1px 5px;font-family:var(--font-mono);font-size:.68rem}.tags{display:flex;flex-wrap:wrap;gap:4px}.tag{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:var(--radius-full);font-size:.72rem;font-weight:500;background:var(--primary-light);color:var(--primary-text);white-space:nowrap}.tag-remove{background:none;border:none;padding:0;cursor:pointer;color:inherit;opacity:.7;font-size:.85rem;line-height:1;display:flex;align-items:center}.tag-remove:hover{opacity:1}.tag-input-row{display:flex;flex-wrap:wrap;gap:4px;align-items:center}.tag-input{border:none;outline:none;background:transparent;width:120px;min-width:60px;font-size:.85rem;padding:2px 4px;color:var(--text)}.tag-input-wrapper{display:flex;flex-wrap:wrap;gap:4px;align-items:center;padding:6px 10px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);cursor:text;min-height:38px;transition:border-color .15s,box-shadow .15s}.tag-input-wrapper:focus-within{border-color:var(--primary);box-shadow:0 0 0 3px color-mix(in srgb,var(--primary) 20%,transparent)}.tab-bar{display:flex;align-items:center;border-bottom:1px solid var(--border);gap:0}.tab{padding:10px 20px;font-size:.875rem;font-weight:500;color:var(--text-muted);background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-1px;transition:color .15s,border-color .15s;cursor:pointer}.tab:hover{color:var(--text)}.tab.active{color:var(--primary);border-bottom-color:var(--primary)}.tab-spacer{flex:1}.filter-bar{display:flex;flex-wrap:wrap;gap:8px;align-items:center;padding:12px 16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg)}.filter-bar input,.filter-bar select{width:auto;min-width:0;font-size:.825rem;padding:6px 10px}.filter-bar select{padding-right:28px}.filter-group{display:flex;align-items:center;gap:6px}.filter-label{font-size:.75rem;font-weight:600;color:var(--text-subtle);white-space:nowrap}.filter-sep{width:1px;height:20px;background:var(--border);margin:0 4px}.filter-spacer{flex:1}.segment{display:flex;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.segment-btn{padding:5px 12px;font-size:.8rem;font-weight:500;background:none;border:none;color:var(--text-muted);transition:background .15s,color .15s;cursor:pointer}.segment-btn.active{background:var(--surface);color:var(--text);box-shadow:var(--shadow-sm)}.entry-list{display:flex;flex-direction:column;gap:16px}.entry-group-header{display:flex;align-items:center;justify-content:space-between;padding:8px 0 6px;border-bottom:1px solid var(--border);margin-bottom:2px}.entry-group-date{font-size:.825rem;font-weight:700;color:var(--text-muted);letter-spacing:.01em}.entry-group-total{font-size:.8rem;font-weight:600;color:var(--primary);background:var(--primary-light);padding:2px 8px;border-radius:var(--radius-full)}.entry-row{display:grid;grid-template-columns:90px 1fr 1fr 70px auto auto;align-items:center;gap:12px;padding:10px 12px;border-radius:var(--radius);transition:background .1s;border:1px solid transparent}.entry-row:hover{background:var(--surface-2)}.entry-row.editing{background:var(--surface);border:1px solid var(--primary);box-shadow:var(--shadow);border-radius:var(--radius)}.entry-time{font-family:var(--font-mono);font-size:.8rem;color:var(--text-muted);white-space:nowrap}.entry-task{font-size:.875rem;font-weight:500;color:var(--text);min-width:0}.entry-task-sub{font-size:.78rem;color:var(--text-subtle);margin-top:2px}.entry-project{font-size:.8rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.entry-duration{font-size:.85rem;font-weight:600;color:var(--text);text-align:right;font-variant-numeric:tabular-nums;white-space:nowrap}.entry-tags{display:flex;flex-wrap:wrap;gap:3px}.entry-row-actions{display:flex;gap:4px;opacity:0;transition:opacity .1s}.entry-row:hover .entry-row-actions{opacity:1}.entry-edit-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;padding:12px}.entry-edit-row{grid-column:1 / -1;display:flex;gap:8px}.entry-edit-row>*{flex:1}.entry-edit-actions{display:flex;justify-content:flex-end;gap:6px;padding:0 12px 12px}.total-bar{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;background:var(--surface-2);border-radius:var(--radius);font-size:.875rem}.total-bar-label{color:var(--text-muted)}.total-bar-value{font-weight:700;color:var(--text);font-variant-numeric:tabular-nums}.empty-state{display:flex;flex-direction:column;align-items:center;gap:12px;padding:64px 32px;text-align:center;color:var(--text-subtle)}.empty-state-icon{font-size:3rem;opacity:.4}.empty-state-title{font-size:1rem;font-weight:600;color:var(--text-muted)}.empty-state-body{font-size:.875rem;max-width:300px;line-height:1.6}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:200;display:flex;align-items:flex-end;justify-content:center;padding:16px;animation:fadeIn .15s ease}@media (min-width: 640px){.modal-overlay{align-items:center}}.modal{background:var(--surface);border-radius:var(--radius-lg) var(--radius-lg) 0 0;width:100%;max-width:560px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg);animation:slideUp .2s ease}@media (min-width: 640px){.modal{border-radius:var(--radius-lg);animation:scaleIn .15s ease}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 16px;border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--surface);z-index:1}.modal-title{font-size:1rem;font-weight:700}.modal-body{padding:20px 24px;display:flex;flex-direction:column;gap:14px}.modal-footer{padding:16px 24px;border-top:1px solid var(--border);display:flex;justify-content:space-between;gap:8px}.modal-footer-actions{display:flex;gap:8px;margin-left:auto}.time-input-group{display:flex;gap:8px;align-items:flex-end}.time-input-group>*{flex:1}.toggle-row{display:flex;align-items:center;gap:8px;font-size:.8rem;color:var(--text-muted);cursor:pointer}.toggle-switch{width:28px;height:16px;background:var(--surface-3);border-radius:var(--radius-full);position:relative;transition:background .15s;flex-shrink:0}.toggle-switch.on{background:var(--primary)}.toggle-knob{position:absolute;top:2px;left:2px;width:12px;height:12px;background:#fff;border-radius:50%;transition:transform .15s;box-shadow:var(--shadow-sm)}.toggle-switch.on .toggle-knob{transform:translate(12px)}.charts-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}.chart-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px}.chart-title{font-size:.825rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-subtle);margin-bottom:16px}.chart-svg{width:100%;overflow:visible}.chart-bar{transition:opacity .15s}.chart-bar:hover{opacity:.8}.chart-label{font-size:10px;fill:var(--text-muted)}.chart-value{font-size:10px;fill:var(--text-muted);font-family:var(--font-mono)}.chart-gridline{stroke:var(--border);stroke-dasharray:4 2}.chart-legend{display:flex;flex-wrap:wrap;gap:10px;margin-top:12px}.chart-legend-item{display:flex;align-items:center;gap:5px;font-size:.78rem;color:var(--text-muted)}.chart-legend-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.idle-modal{text-align:center}.idle-modal .modal-body{align-items:center}.idle-timer-big{font-size:2.5rem;font-family:var(--font-mono);font-weight:700;color:var(--warning)}.idle-actions{display:flex;flex-direction:column;gap:8px;width:100%}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(32px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes scaleIn{0%{transform:scale(.97);opacity:0}to{transform:scale(1);opacity:1}}.source-badge{display:inline-flex;align-items:center;gap:3px;font-size:.68rem;font-weight:600;padding:1px 6px;border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.04em}.source-tracked{background:var(--success-light);color:var(--success-text)}.source-manual{background:var(--surface-2);color:var(--text-subtle);border:1px solid var(--border)}.divider{height:1px;background:var(--border)}.toast-container{position:fixed;bottom:24px;right:24px;z-index:300;display:flex;flex-direction:column;gap:8px}.toast{background:var(--text);color:var(--bg);padding:10px 16px;border-radius:var(--radius);font-size:.875rem;font-weight:500;box-shadow:var(--shadow-md);animation:slideUp .2s ease;display:flex;align-items:center;gap:8px;max-width:320px}@media (max-width: 900px){.dashboard{grid-template-columns:repeat(3,1fr)}.dashboard-actions{flex-direction:row;align-items:center;grid-column:1 / -1}.charts-grid{grid-template-columns:1fr}}@media (max-width: 700px){.header{padding:0 16px}.main{padding:16px 16px 80px;gap:16px}.dashboard{grid-template-columns:1fr 1fr}.timer-form{grid-template-columns:1fr}.timer-display{font-size:1.8rem}.entry-row{grid-template-columns:80px 1fr auto;grid-template-rows:auto auto}.entry-row-project{grid-column:2;grid-row:2}.entry-row-duration{grid-column:3;grid-row:1}.entry-row-actions{grid-column:3;grid-row:2;opacity:1}.entry-tags{display:none}.filter-bar{gap:6px}.header-timer-pill{display:none}}@media (max-width: 480px){.dashboard{grid-template-columns:1fr}.entry-row{grid-template-columns:1fr auto}}
