.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:2000;padding:1rem;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:var(--surface);border:1px solid var(--border);border-radius:8px;max-width:500px;width:100%;max-height:90vh;overflow-y:auto;animation:slideUp .2s ease-out;box-shadow:0 20px 25px -5px #0000004d}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-warning{border-left:4px solid var(--warning)}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid var(--border)}.modal-header h3{margin:0;font-size:1.25rem;font-weight:600}.modal-close{background:transparent;border:none;font-size:2rem;line-height:1;color:var(--text-dim);padding:0;width:2rem;height:2rem;cursor:pointer;transition:color .2s}.modal-close:hover{color:var(--text);background:transparent}.modal-body{padding:1.5rem}.modal-body p{margin:0 0 1rem;line-height:1.6;color:var(--text)}.modal-body p:last-child{margin-bottom:0}.modal-input{margin-top:1rem;width:100%;padding:.75rem;font-size:1rem}.modal-actions{display:flex;justify-content:flex-end;gap:.75rem;padding:1.5rem;border-top:1px solid var(--border)}.modal-actions button{min-width:100px}.home{display:flex;flex-direction:column;gap:2rem}.home-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem}.timer-card{text-align:center}.timer{font-size:3rem;font-weight:700;margin:2rem 0;color:var(--primary);font-variant-numeric:tabular-nums}.timer-card button{width:100%;padding:1rem;font-size:1.125rem;font-weight:600}.flex-card{text-align:center}.flex-value{font-size:2rem;font-weight:700;margin:2rem 0;font-variant-numeric:tabular-nums}.flex-value.positive{color:var(--success)}.flex-value.negative{color:var(--danger)}.favorites-card h3{margin-bottom:1rem}.favorites{display:flex;flex-wrap:wrap;gap:.5rem}.pill{padding:.5rem 1rem;border-radius:20px;font-size:.875rem;background:var(--surface);border:1px solid var(--border)}.pill:hover:not(:disabled){border-color:var(--primary)}.pill.active{background:var(--primary);color:#fff;border-color:var(--primary)}.pill:disabled{opacity:.5;cursor:not-allowed}.history h1{margin-bottom:2rem}.history-header{display:flex;align-items:center;justify-content:center;gap:1rem;margin-bottom:2rem}.month-year-display{font-size:1.5rem;font-weight:600;min-width:250px;text-align:center}.nav-arrow{width:3rem;height:3rem;font-size:1.5rem;display:flex;align-items:center;justify-content:center;padding:0}.today-btn{margin-left:auto}.calendar-day.outside-month{opacity:.3;pointer-events:none}.calendar{display:flex;flex-direction:column;gap:1px;background:var(--border);border:1px solid var(--border);border-radius:8px;overflow:hidden}.calendar-header{display:grid;grid-template-columns:repeat(7,1fr);background:var(--surface);gap:1px}.calendar-day-name{padding:.75rem;text-align:center;font-weight:600;font-size:.875rem;background:var(--surface)}.calendar-week{display:grid;grid-template-columns:repeat(7,1fr);gap:1px}.calendar-day{aspect-ratio:1;padding:.5rem;background:var(--surface);cursor:pointer;display:flex;flex-direction:column;justify-content:space-between;transition:opacity .2s}.calendar-day:hover{opacity:.8}.calendar-day.status-workday{border-left:3px solid var(--workday)}.calendar-day.status-weekend{border-left:3px solid var(--weekend)}.calendar-day.status-vacation{border-left:3px solid var(--vacation)}.calendar-day.status-sick{border-left:3px solid var(--sick)}.calendar-day.status-not_worked{border-left:3px solid var(--not-worked)}.day-number{font-weight:600;font-size:.875rem}.day-progress{width:100%;height:4px;background:var(--border);border-radius:2px;overflow:hidden}.drawer-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.drawer-header button{font-size:2rem;padding:0;width:2.5rem;height:2.5rem;background:transparent;border:none}.drawer-content{display:flex;flex-direction:column;gap:2rem}.day-summary{display:flex;justify-content:space-between;padding:1rem;background:var(--bg);border-radius:4px}.summary-item{display:flex;flex-direction:column;gap:.25rem}.summary-item span{font-size:.875rem;color:var(--text-dim)}.section h3{margin-bottom:1rem}.status-buttons{display:flex;flex-wrap:wrap;gap:.5rem}.status-btn{padding:.5rem 1rem;border-radius:4px;font-size:.875rem;text-transform:capitalize}.status-btn.status-workday{border-color:var(--workday)}.status-btn.status-workday.active{background:var(--workday);color:#fff}.status-btn.status-weekend{border-color:var(--weekend)}.status-btn.status-weekend.active{background:var(--weekend);color:#fff}.status-btn.status-vacation{border-color:var(--vacation)}.status-btn.status-vacation.active{background:var(--vacation);color:#fff}.status-btn.status-sick{border-color:var(--sick)}.status-btn.status-sick.active{background:var(--sick);color:#fff}.status-btn.status-not_worked{border-color:var(--not-worked)}.status-btn.status-not_worked.active{background:var(--not-worked);color:#fff}.sessions-list{display:flex;flex-direction:column;gap:.5rem}.session-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background:var(--bg);border-radius:4px}.empty-text{color:var(--text-dim);font-size:.875rem}.add-session-form{display:flex;flex-direction:column;gap:1rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-row label{display:block;margin-bottom:.5rem;font-size:.875rem;color:var(--text-dim)}.stats{display:flex;flex-direction:column;gap:2rem}.stats h1{margin:0}.tabs{display:flex;gap:.5rem;border-bottom:2px solid var(--border);padding-bottom:.5rem}.tab{padding:.75rem 1.5rem;background:transparent;border:none;border-bottom:2px solid transparent;font-size:1rem;font-weight:500;color:var(--text-dim);cursor:pointer;transition:all .2s;margin-bottom:-.5rem}.tab:hover{color:var(--text);background:transparent}.tab.active{color:var(--primary);border-bottom-color:var(--primary)}.current-period-card{background:linear-gradient(135deg,var(--surface) 0%,#252525 100%)}.current-period-card h2{margin-bottom:1.5rem;font-size:1.25rem}.period-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:2rem}.stat-item{text-align:center}.stat-value{font-size:2.5rem;font-weight:700;color:var(--primary);font-variant-numeric:tabular-nums}.stat-label{font-size:.875rem;color:var(--text-dim);margin-top:.5rem;text-transform:uppercase;letter-spacing:.05em}.chart-card h3{margin-bottom:1.5rem;font-size:1.125rem}.empty-chart{height:400px;display:flex;align-items:center;justify-content:center}.empty-chart p{color:var(--text-dim);font-size:1rem}.tasks-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.info-banner{background:var(--surface);border:1px solid var(--border);border-left:3px solid var(--warning);padding:1rem;border-radius:4px;margin-bottom:2rem;color:var(--text-dim)}.tasks-list{display:flex;flex-direction:column;gap:1rem}.task-card{padding:1.5rem}.task-header{display:flex;justify-content:space-between;align-items:start;margin-bottom:1rem}.task-header h3{margin-bottom:.25rem}.task-description{font-size:.875rem;color:var(--text-dim);margin:0}.task-badges{display:flex;gap:.5rem}.favorite-badge{background:var(--warning);color:#fff}.today-badge{background:var(--primary);color:#fff}.task-actions{display:flex;gap:.5rem;flex-wrap:wrap}.task-actions button{flex:1;min-width:120px}@media (max-width: 768px){.task-actions button{flex:1 1 100%}}.settings h1{margin-bottom:2rem}.settings-form{display:flex;flex-direction:column;gap:2rem}.section h2{margin-bottom:1.5rem;font-size:1.25rem}.form-group{margin-bottom:1.5rem}.form-group:last-child{margin-bottom:0}.form-group label{display:block;margin-bottom:.5rem;font-weight:500}.form-group small{display:block;margin-top:.25rem;font-size:.875rem;color:var(--text-dim)}.info-box{background:var(--bg);padding:1rem;border-radius:4px;border-left:3px solid var(--primary);margin-top:1rem}.info-box strong{display:block;margin-bottom:.5rem}.info-box p{margin:.5rem 0;font-size:.875rem}.info-box ul{margin:.5rem 0;padding-left:1.5rem;font-size:.875rem}.info-box code{background:var(--surface);padding:.125rem .375rem;border-radius:2px;font-family:Courier New,monospace;font-size:.875rem}.save-button{width:100%;padding:1rem;font-size:1.125rem;font-weight:600}.danger-zone{margin-top:2rem;border-color:var(--danger)}.danger-zone h2{color:var(--danger)}.danger-zone button:disabled{opacity:.5;cursor:not-allowed}.auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;background:var(--bg)}.auth-card{width:100%;max-width:400px;background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:2.5rem}.auth-card h1{text-align:center;margin-bottom:.5rem;color:var(--primary);font-size:2rem}.auth-card h2{text-align:center;margin-bottom:2rem;font-size:1.25rem;color:var(--text-dim);font-weight:500}.auth-form{display:flex;flex-direction:column;gap:1.5rem}.auth-form .form-group{display:flex;flex-direction:column;gap:.5rem}.auth-form label{font-size:.875rem;font-weight:500;color:var(--text)}.auth-form input{padding:.75rem;font-size:1rem;border:1px solid var(--border);border-radius:4px;background:var(--bg);color:var(--text)}.auth-form input:focus{outline:none;border-color:var(--primary)}.auth-form small{font-size:.75rem;color:var(--text-dim)}.auth-button{width:100%;padding:.875rem;font-size:1rem;font-weight:600;margin-top:.5rem}.auth-button:disabled{opacity:.6;cursor:not-allowed}.auth-link{text-align:center;margin-top:1.5rem;font-size:.875rem;color:var(--text-dim)}.auth-link a{color:var(--primary);text-decoration:none;font-weight:500}.auth-link a:hover{text-decoration:underline}.app{display:flex;flex-direction:column;min-height:100vh}.nav{background:var(--surface);border-bottom:1px solid var(--border);padding:0 2rem;display:flex;justify-content:space-between;align-items:center;gap:2rem;position:sticky;top:0;z-index:100}.nav-links{display:flex;gap:2rem}.nav-user{display:flex;align-items:center;gap:1rem}.user-email{font-size:.875rem;color:var(--text-dim)}.logout-btn{padding:.5rem 1rem;font-size:.875rem;background:transparent;border:1px solid var(--border);color:var(--text);cursor:pointer;transition:all .2s;border-radius:4px}.logout-btn:hover{background:var(--danger);border-color:var(--danger);color:#fff}.nav a{color:var(--text-dim);text-decoration:none;padding:1rem 0;border-bottom:2px solid transparent;transition:all .2s;font-weight:500}.nav a:hover{color:var(--text)}.nav a.active{color:var(--primary);border-bottom-color:var(--primary)}.main{flex:1;padding:2rem;max-width:1200px;width:100%;margin:0 auto}.main-auth{flex:1;width:100%}@media (max-width: 768px){.nav{gap:1rem;padding:0 1rem}.main{padding:1rem}}*{margin:0;padding:0;box-sizing:border-box}:root{--bg: #0a0a0a;--surface: #1a1a1a;--border: #333;--text: #e0e0e0;--text-dim: #888;--primary: #3b82f6;--primary-hover: #2563eb;--success: #10b981;--warning: #f59e0b;--danger: #ef4444;--workday: #3b82f6;--weekend: #6366f1;--vacation: #10b981;--sick: #f59e0b;--not-worked: #ef4444}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;background:var(--bg);color:var(--text);line-height:1.5}#root{min-height:100vh}button{font-family:inherit;cursor:pointer;border:none;outline:none;background:var(--surface);color:var(--text);padding:.5rem 1rem;border-radius:4px;border:1px solid var(--border);transition:all .2s}button:hover{background:var(--border)}button.primary{background:var(--primary);color:#fff;border-color:var(--primary)}button.primary:hover{background:var(--primary-hover);border-color:var(--primary-hover)}button.danger{background:var(--danger);color:#fff;border-color:var(--danger)}button.danger:hover{opacity:.9}input,select,textarea{font-family:inherit;background:var(--surface);color:var(--text);border:1px solid var(--border);padding:.5rem;border-radius:4px;width:100%}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--primary)}.card{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:1.5rem}.badge{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.875rem;font-weight:500}.progress-bar{width:100%;height:8px;background:var(--border);border-radius:4px;overflow:hidden}.progress-fill{height:100%;background:var(--primary);transition:width .3s}.modal{position:fixed;top:0;right:0;bottom:0;left:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-content{background:var(--surface);border:1px solid var(--border);border-radius:8px;max-width:500px;width:100%;max-height:90vh;overflow-y:auto}.drawer{position:fixed;right:-400px;top:0;bottom:0;width:400px;background:var(--surface);border-left:1px solid var(--border);transition:right .3s;z-index:1000;overflow-y:auto;padding:2rem}.drawer.open{right:0}.drawer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:999;opacity:0;pointer-events:none;transition:opacity .3s}.drawer-overlay.visible{opacity:1;pointer-events:all}
