@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=Outfit:wght@400;500;600;700;800&family=JetBrains+Mono:wght@400;500;600;700&display=swap";
:root{--bg-primary:#0a0a0f;--bg-secondary:#12121a;--bg-tertiary:#1a1a2e;--bg-glass:#ffffff0a;--bg-glass-hover:#ffffff14;--bg-glass-active:#ffffff1f;--accent:#f59e0b;--accent-light:#fbbf24;--accent-dark:#d97706;--accent-glow:#f59e0b40;--accent-subtle:#f59e0b14;--text-primary:#f1f5f9;--text-secondary:#94a3b8;--text-muted:#64748b;--success:#10b981;--success-glow:#10b98140;--danger:#ef4444;--danger-glow:#ef444440;--info:#3b82f6;--warning:#f59e0b;--border:#ffffff14;--border-hover:#ffffff26;--shadow-sm:0 1px 3px #0006;--shadow-md:0 4px 12px #00000080;--shadow-lg:0 8px 30px #0009;--shadow-glow:0 0 20px var(--accent-glow);--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--radius-xl:24px;--radius-full:9999px;--font-body:"Inter", -apple-system, sans-serif;--font-heading:"Outfit", -apple-system, sans-serif;--font-mono:"JetBrains Mono", monospace;--transition-fast:.15s cubic-bezier(.4, 0, .2, 1);--transition-base:.25s cubic-bezier(.4, 0, .2, 1);--transition-slow:.4s cubic-bezier(.4, 0, .2, 1);--sidebar-width:260px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;font-size:16px}body{font-family:var(--font-body);background:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh;line-height:1.6}a{color:inherit;text-decoration:none}button{cursor:pointer;font:inherit;color:inherit;background:0 0;border:none}input,select,textarea{font:inherit;color:inherit}ul,ol{list-style:none}img{max-width:100%;display:block}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);font-weight:600;line-height:1.2}.app-layout{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-width);background:var(--bg-secondary);border-right:1px solid var(--border);z-index:50;transition:transform var(--transition-base);flex-direction:column;display:flex;position:fixed;top:0;bottom:0;left:0}.sidebar-logo{border-bottom:1px solid var(--border);align-items:center;gap:12px;padding:24px 20px;display:flex}.sidebar-logo h1{letter-spacing:2px;background:linear-gradient(135deg, var(--accent), var(--accent-light));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:1.5rem;font-weight:800}.sidebar-logo-icon{border-radius:var(--radius-md);background:linear-gradient(135deg, var(--accent), var(--accent-dark));width:36px;height:36px;box-shadow:var(--shadow-glow);justify-content:center;align-items:center;font-size:1.2rem;display:flex}.sidebar-nav{flex-direction:column;flex:1;gap:4px;padding:16px 12px;display:flex}.sidebar-link{border-radius:var(--radius-md);color:var(--text-secondary);transition:all var(--transition-fast);align-items:center;gap:12px;padding:10px 14px;font-size:.9rem;font-weight:500;display:flex}.sidebar-link:hover{background:var(--bg-glass-hover);color:var(--text-primary)}.sidebar-link.active{background:var(--accent-subtle);color:var(--accent);box-shadow:inset 3px 0 0 var(--accent)}.sidebar-link svg,.sidebar-link .icon{flex-shrink:0;width:20px;height:20px}.sidebar-section{text-transform:uppercase;letter-spacing:1.5px;color:var(--text-muted);padding:16px 14px 8px;font-size:.7rem;font-weight:600}.sidebar-user{border-top:1px solid var(--border);align-items:center;gap:12px;padding:16px;display:flex}.sidebar-user-avatar{border-radius:var(--radius-full);background:var(--bg-tertiary);border:2px solid var(--border);justify-content:center;align-items:center;width:36px;height:36px;font-size:.85rem;font-weight:600;display:flex}.sidebar-user-info{flex:1;min-width:0}.sidebar-user-name{white-space:nowrap;text-overflow:ellipsis;font-size:.85rem;font-weight:600;overflow:hidden}.sidebar-user-email{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;font-size:.72rem;overflow:hidden}.main-content{margin-left:var(--sidebar-width);flex:1;min-height:100vh}.page-container{padding:32px 40px}.page-header{margin-bottom:32px}.page-title{margin-bottom:4px;font-size:1.8rem;font-weight:700}.page-subtitle{color:var(--text-secondary);font-size:.95rem}.card{background:var(--bg-glass);-webkit-backdrop-filter:blur(20px);border:1px solid var(--border);border-radius:var(--radius-lg);transition:all var(--transition-base);padding:24px}.card:hover{border-color:var(--border-hover)}.card-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.card-title{font-size:1rem;font-weight:600}.card-subtitle{color:var(--text-muted);margin-top:2px;font-size:.8rem}.card-glow{box-shadow:var(--shadow-glow);border-color:#f59e0b26}.btn{border-radius:var(--radius-md);transition:all var(--transition-fast);white-space:nowrap;border:1px solid #0000;justify-content:center;align-items:center;gap:8px;padding:10px 20px;font-size:.875rem;font-weight:500;display:inline-flex}.btn-primary{background:linear-gradient(135deg, var(--accent), var(--accent-dark));color:#0a0a0f;font-weight:600}.btn-primary:hover{box-shadow:var(--shadow-glow);transform:translateY(-1px)}.btn-secondary{background:var(--bg-glass);border-color:var(--border);color:var(--text-primary)}.btn-secondary:hover{background:var(--bg-glass-hover);border-color:var(--border-hover)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{box-shadow:0 0 20px var(--danger-glow)}.btn-ghost{color:var(--text-secondary)}.btn-ghost:hover{background:var(--bg-glass);color:var(--text-primary)}.btn-sm{border-radius:var(--radius-sm);padding:6px 12px;font-size:.8rem}.btn-lg{border-radius:var(--radius-lg);padding:14px 28px;font-size:1rem}.btn-icon{border-radius:var(--radius-md);padding:8px}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.input-group{flex-direction:column;gap:6px;display:flex}.input-label{color:var(--text-secondary);font-size:.8rem;font-weight:500}.input{background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);transition:all var(--transition-fast);outline:none;padding:10px 14px;font-size:.9rem}.input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.input::placeholder{color:var(--text-muted)}.select{background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);transition:all var(--transition-fast);appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;outline:none;padding:10px 36px 10px 14px;font-size:.9rem}.select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.badge{border-radius:var(--radius-full);letter-spacing:.3px;align-items:center;gap:4px;padding:3px 10px;font-size:.72rem;font-weight:600;display:inline-flex}.badge-accent{background:var(--accent-subtle);color:var(--accent)}.badge-success{color:var(--success);background:#10b9811f}.badge-danger{color:var(--danger);background:#ef44441f}.badge-info{color:var(--info);background:#3b82f61f}.badge-manual{color:#a78bfa;background:#8b5cf61f}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;animation:fadeIn var(--transition-fast);background:#000000b3;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-xl);width:90%;max-width:520px;box-shadow:var(--shadow-lg);animation:slideUp var(--transition-base);padding:32px}.modal-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.modal-title{font-size:1.2rem;font-weight:700}.modal-close{border-radius:var(--radius-full);width:32px;height:32px;transition:background var(--transition-fast);justify-content:center;align-items:center;display:flex}.modal-close:hover{background:var(--bg-glass-hover)}.modal-body{flex-direction:column;gap:16px;display:flex}.modal-footer{justify-content:flex-end;gap:12px;margin-top:24px;display:flex}.table-container{border-radius:var(--radius-lg);border:1px solid var(--border);overflow-x:auto}.table{border-collapse:collapse;width:100%}.table th{text-align:left;text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);background:var(--bg-tertiary);border-bottom:1px solid var(--border);padding:12px 16px;font-size:.75rem;font-weight:600}.table td{border-bottom:1px solid var(--border);transition:background var(--transition-fast);padding:12px 16px;font-size:.875rem}.table tr:hover td{background:var(--bg-glass)}.table tr:last-child td{border-bottom:none}.stopwatch{text-align:center}.stopwatch-display{font-family:var(--font-mono);letter-spacing:4px;background:linear-gradient(135deg, var(--text-primary), var(--text-secondary));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin:24px 0;font-size:4rem;font-weight:700}.stopwatch-display.running{background:linear-gradient(135deg, var(--success), #34d399);-webkit-background-clip:text;background-clip:text;animation:2s ease-in-out infinite pulse-text}.stopwatch-controls{justify-content:center;gap:16px;margin-bottom:24px;display:flex}.stopwatch-btn{border-radius:var(--radius-full);width:64px;height:64px;transition:all var(--transition-fast);justify-content:center;align-items:center;font-size:1.5rem;font-weight:700;display:flex}.stopwatch-btn-start{background:linear-gradient(135deg, var(--success), #059669);color:#fff;box-shadow:0 4px 20px var(--success-glow)}.stopwatch-btn-start:hover{box-shadow:0 6px 30px var(--success-glow);transform:scale(1.08)}.stopwatch-btn-stop{background:linear-gradient(135deg, var(--danger), #dc2626);color:#fff;box-shadow:0 4px 20px var(--danger-glow)}.stopwatch-btn-stop:hover{box-shadow:0 6px 30px var(--danger-glow);transform:scale(1.08)}.stopwatch-meta{flex-wrap:wrap;justify-content:center;gap:12px;display:flex}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;display:grid}.stat-card{padding:20px}.stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;font-size:.78rem;font-weight:500}.stat-value{font-size:1.8rem;font-weight:700;font-family:var(--font-heading)}.stat-change{margin-top:4px;font-size:.75rem}.stat-change.positive{color:var(--success)}.stat-change.negative{color:var(--danger)}.cal{border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--bg-glass);overflow:hidden}.cal-header{background:var(--bg-tertiary);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.cal-header-left{flex-direction:column;gap:4px;display:flex}.cal-week-label{font-size:1.15rem;font-weight:700;font-family:var(--font-heading)}.cal-week-total{color:var(--accent);font-size:.8rem;font-weight:500}.cal-header-right{align-items:center;gap:6px;display:flex}.cal-header-right .btn{padding:6px 10px;font-size:1.1rem}.cal-columns-header{border-bottom:1px solid var(--border);background:var(--bg-secondary);grid-template-columns:repeat(7,1fr);display:grid}.cal-col-header{flex-direction:column;align-items:center;gap:4px;padding:12px 4px 10px;display:flex}.cal-col-day{text-transform:uppercase;letter-spacing:1.5px;color:var(--text-muted);font-size:.7rem;font-weight:600}.cal-col-header.today .cal-col-day{color:var(--accent)}.cal-col-num{color:var(--text-primary);border-radius:var(--radius-full);width:36px;height:36px;transition:all var(--transition-fast);justify-content:center;align-items:center;font-size:1.15rem;font-weight:700;display:flex}.cal-col-num.today{background:var(--accent);color:var(--bg-primary)}.cal-columns-body{grid-template-columns:repeat(7,1fr);min-height:420px;display:grid}.cal-column{border-right:1px solid var(--border);min-height:380px;transition:background var(--transition-fast);flex-direction:column;gap:6px;padding:10px 6px 14px;display:flex}.cal-column:last-child{border-right:none}.cal-column:hover{background:var(--bg-glass)}.cal-column.today{background:#f59e0b08}.cal-column.past{opacity:.7}.cal-loading{grid-column:1/-1;justify-content:center;align-items:center;padding:60px;display:flex}.cal-empty-day{color:var(--text-muted);text-align:center;opacity:.4;padding:20px 0;font-size:.75rem}.cal-event{border-radius:var(--radius-sm);background:color-mix(in srgb, var(--event-color) 10%, transparent);border-left:3px solid var(--event-color);cursor:pointer;transition:all var(--transition-fast);text-align:left;align-items:flex-start;gap:8px;width:100%;padding:8px 10px;display:flex}.cal-event:hover{background:color-mix(in srgb, var(--event-color) 18%, transparent);transform:translateY(-1px);box-shadow:0 2px 8px #0003}.cal-event-dot{border-radius:var(--radius-full);background:var(--event-color);flex-shrink:0;width:7px;height:7px;margin-top:4px}.cal-event-content{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.cal-event-project{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:.75rem;font-weight:600;overflow:hidden}.cal-event-time{color:var(--text-muted);font-size:.65rem;font-family:var(--font-mono)}.cal-event-duration{color:var(--event-color);font-size:.68rem;font-weight:600}.cal-day-total{text-align:center;color:var(--accent);font-size:.72rem;font-weight:700;font-family:var(--font-mono);background:var(--accent-subtle);border-radius:var(--radius-sm);margin-top:auto;padding:6px 8px}.cal-modal-project{background:var(--bg-tertiary);border-radius:var(--radius-md);align-items:center;gap:12px;padding:16px;display:flex}.cal-modal-section{margin-bottom:4px}.cal-modal-label{text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);margin-bottom:6px;font-size:.72rem;font-weight:600}.cal-modal-value{color:var(--text-primary);font-size:.95rem;line-height:1.5}.cal-modal-row{gap:16px;display:flex}.cal-modal-duration{font-size:1.6rem;font-weight:700;font-family:var(--font-mono);color:var(--accent)}@media (max-width:900px){.cal-columns-header,.cal-columns-body{grid-template-columns:repeat(7,1fr)}.cal-column{min-height:280px;padding:6px 4px}.cal-event{gap:4px;padding:5px 6px}.cal-event-time{display:none}.cal-col-day{font-size:.6rem}.cal-col-num{width:28px;height:28px;font-size:.95rem}}@media (max-width:640px){.cal-columns-body{grid-template-columns:1fr;min-height:auto}.cal-columns-header{display:none}.cal-column{border-right:none;border-bottom:1px solid var(--border);min-height:auto;padding:12px 16px}.cal-column:before{content:attr(data-label);color:var(--text-secondary);margin-bottom:8px;font-size:.8rem;font-weight:600;display:block}}.color-picker-grid{flex-wrap:wrap;gap:8px;display:flex}.color-swatch{border-radius:var(--radius-md);cursor:pointer;width:32px;height:32px;transition:all var(--transition-fast);border:2px solid #0000}.color-swatch:hover{transform:scale(1.15)}.color-swatch.selected{border-color:var(--text-primary);box-shadow:0 0 0 2px var(--bg-primary)}.project-dot{border-radius:var(--radius-full);flex-shrink:0;width:10px;height:10px}.filter-bar{background:var(--bg-glass);border:1px solid var(--border);border-radius:var(--radius-lg);flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:24px;padding:16px 20px;display:flex}.filter-bar .select,.filter-bar .input{background:var(--bg-primary);padding:8px 12px;font-size:.85rem}.entry-item{border-bottom:1px solid var(--border);transition:background var(--transition-fast);align-items:center;gap:16px;padding:14px 16px;display:flex}.entry-item:last-child{border-bottom:none}.entry-item:hover{background:var(--bg-glass)}.entry-project{align-items:center;gap:8px;min-width:120px;display:flex}.entry-desc{color:var(--text-secondary);text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-size:.875rem;overflow:hidden}.entry-time{font-family:var(--font-mono);color:var(--text-primary);white-space:nowrap;font-size:.85rem;font-weight:500}.entry-period{color:var(--text-muted);white-space:nowrap;font-size:.75rem}.entry-actions{gap:4px;display:flex}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse-text{0%,to{opacity:1}50%{opacity:.7}}@keyframes pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.5)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.animate-fade{animation:fadeIn var(--transition-base)}.animate-slide{animation:slideUp var(--transition-base)}.login-page{background:var(--bg-primary);background-image:radial-gradient(at 50% 0,#f59e0b14 0%,#0000 60%);justify-content:center;align-items:center;min-height:100vh;display:flex}.login-card{text-align:center;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-xl);width:90%;max-width:420px;box-shadow:var(--shadow-lg);padding:48px}.login-logo{letter-spacing:4px;background:linear-gradient(135deg, var(--accent), var(--accent-light));-webkit-text-fill-color:transparent;font-size:3rem;font-weight:800;font-family:var(--font-heading);-webkit-background-clip:text;background-clip:text;margin-bottom:8px}.login-subtitle{color:var(--text-secondary);margin-bottom:36px;font-size:.9rem}.login-btn{border-radius:var(--radius-lg);background:linear-gradient(135deg, var(--accent), var(--accent-dark));color:#0a0a0f;width:100%;transition:all var(--transition-fast);justify-content:center;align-items:center;gap:10px;padding:14px 24px;font-size:1rem;font-weight:700;display:flex}.login-btn:hover{box-shadow:var(--shadow-glow);transform:translateY(-2px)}.empty-state{text-align:center;color:var(--text-muted);padding:48px 24px}.empty-state-icon{opacity:.5;margin-bottom:16px;font-size:3rem}.empty-state-text{font-size:.95rem}.spinner{border:3px solid var(--border);border-top-color:var(--accent);border-radius:var(--radius-full);width:24px;height:24px;animation:.7s linear infinite spin}@media (max-width:768px){:root{--sidebar-width:0px}.sidebar{transform:translate(-100%)}.sidebar.open{width:260px;transform:translate(0)}.page-container{padding:20px 16px}.stopwatch-display{font-size:2.5rem}.stats-grid{grid-template-columns:1fr 1fr}.calendar-grid{grid-template-columns:1fr}.filter-bar{flex-direction:column}}@media (max-width:480px){.stats-grid{grid-template-columns:1fr}.stopwatch-display{font-size:2rem}}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--border-hover)}.grid-2{grid-template-columns:1fr 1fr;gap:24px;display:grid}.grid-3{grid-template-columns:repeat(3,1fr);gap:24px;display:grid}.dashboard-grid{grid-template-columns:1fr 1fr;gap:24px;margin-top:24px;display:grid}@media (max-width:900px){.grid-2,.grid-3,.dashboard-grid{grid-template-columns:1fr}}.tooltip-container{position:relative}.recharts-tooltip-wrapper{z-index:10!important}.custom-tooltip{background:var(--bg-secondary)!important;border:1px solid var(--border)!important;border-radius:var(--radius-md)!important;box-shadow:var(--shadow-md)!important;padding:12px 16px!important}.custom-tooltip .label{color:var(--text-primary);margin-bottom:6px;font-weight:600}.custom-tooltip .value{color:var(--text-secondary);font-size:.85rem}.tabs{border-bottom:1px solid var(--border);gap:4px;margin-bottom:24px;display:flex}.tab{color:var(--text-secondary);transition:all var(--transition-fast);border-bottom:2px solid #0000;margin-bottom:-1px;padding:10px 20px;font-size:.875rem;font-weight:500}.tab:hover{color:var(--text-primary)}.tab.active{color:var(--accent);border-bottom-color:var(--accent)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-8{gap:8px}.gap-12{gap:12px}.gap-16{gap:16px}.gap-24{gap:24px}.mt-16{margin-top:16px}.mt-24{margin-top:24px}.mb-16{margin-bottom:16px}.mb-24{margin-bottom:24px}.w-full{width:100%}.text-right{text-align:right}.text-center{text-align:center}.truncate{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.user-chart-grid{flex-direction:column;gap:16px;display:flex}.user-chart-item{align-items:center;gap:16px;padding:8px 0;display:flex}.user-chart-avatar{border-radius:var(--radius-full);border:2px solid var(--border);object-fit:cover;flex-shrink:0;width:48px;height:48px}.user-chart-bar-container{background:var(--bg-tertiary);border-radius:var(--radius-md);flex:1;height:28px;position:relative;overflow:hidden}.user-chart-bar{background:linear-gradient(90deg, var(--accent-dark), var(--accent-light));border-radius:var(--radius-md);height:100%;transition:width var(--transition-slow);min-width:4px}.user-chart-info{text-align:right;flex-direction:column;gap:2px;min-width:110px;display:flex}.user-chart-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:.85rem;font-weight:600;overflow:hidden}.user-chart-hours{color:var(--accent);font-size:.95rem;font-weight:700;font-family:var(--font-mono)}.user-chart-entries{color:var(--text-muted);font-size:.7rem}.modal-tabs{background:var(--bg-tertiary);border-radius:var(--radius-md);gap:4px;padding:4px;display:flex}.modal-tab{border-radius:var(--radius-sm);color:var(--text-secondary);transition:all var(--transition-fast);text-align:center;flex:1;padding:8px 16px;font-size:.85rem;font-weight:500}.modal-tab:hover{color:var(--text-primary)}.modal-tab.active{background:var(--accent-subtle);color:var(--accent);font-weight:600}.entry-user{min-width:120px;max-width:150px;color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;font-size:.82rem;font-weight:500;overflow:hidden}.entry-project-name{white-space:nowrap;text-overflow:ellipsis;font-size:.85rem;font-weight:500;overflow:hidden}.filter-bar .select,.filter-bar .input{background:var(--bg-primary);min-width:0;padding:8px 12px;font-size:.82rem}.filter-bar .select{padding-right:32px}@media (max-width:768px){.filter-bar{flex-direction:column}.filter-bar .select,.filter-bar .input{width:100%}}
