*{margin:0;padding:0}body{background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.subject-select .inline-edit{background:var(--bg-tertiary);border-radius:var(--radius-md)}.subject-options::-webkit-scrollbar{width:8px}.subject-options::-webkit-scrollbar-thumb{background:var(--border);border-radius:8px}.todo-table-container{background:var(--bg-elevated);overflow:visible;position:relative}.todo-table{border-collapse:collapse;font-size:14px;width:100%}.todo-table,.todo-table th{background:var(--bg-elevated)}.todo-table th{border-bottom:1px solid var(--border);color:var(--text-muted);font-size:12px;font-weight:600;padding:10px 16px;position:-webkit-sticky;position:sticky;text-align:left;top:0;white-space:nowrap;z-index:10}.todo-table th:first-child{padding-left:24px}.todo-table th:last-child{padding-right:24px;width:40px}.todo-table td{border-bottom:1px solid var(--border-light);height:48px;padding:8px 16px;transition:all var(--transition-fast);vertical-align:middle}.todo-table td:first-child{padding-left:24px}.todo-table td:last-child{padding-right:24px;width:40px}.todo-row{position:relative;transition:all var(--transition-fast)}.todo-row:hover{background:var(--bg-secondary)}.todo-row:hover .row-actions{opacity:1}.todo-row.overdue{background:var(--error-light)}.todo-row.overdue:before{background:var(--error)}.todo-row.due-soon{background:var(--warning-light)}.todo-row.due-soon:before{background:var(--warning)}.status-btn{align-items:center;border:1px solid #0000;border-radius:var(--radius-md);box-shadow:var(--shadow-xs);cursor:pointer;display:inline-flex;font-size:12px;font-weight:500;justify-content:center;min-width:80px;overflow:hidden;padding:6px 10px;position:relative;transition:all var(--transition-fast)}.status-btn:hover{box-shadow:var(--shadow-sm);filter:brightness(1.1);transform:translateY(-1px)}.subject-badge{align-items:center;background-color:#3b82f626;background-color:var(--subject-bg,#3b82f626);border:1px solid #0000;border-color:#3b82f633;border-color:var(--subject-border,#3b82f633);border-radius:var(--radius-md);box-shadow:var(--shadow-xs);color:#3b82f6;color:var(--subject-color,#3b82f6);cursor:pointer;display:inline-flex;font-size:12px;font-weight:500;justify-content:center;min-width:80px;overflow:hidden;padding:4px 10px;position:relative;transition:all var(--transition-fast)}.subject-badge:hover{background-color:#3b82f633;background-color:var(--subject-bg-hover,#3b82f633);border-color:#3b82f64d;border-color:var(--subject-border-hover,#3b82f64d);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.task-title-cell{max-width:400px;min-width:200px}.task-title{align-items:center;border-radius:var(--radius-sm);color:var(--text-primary);cursor:pointer;display:flex;font-size:14px;font-weight:500;line-height:1.4;min-height:20px;padding:4px 8px;transition:all var(--transition-fast);word-break:break-word}.task-title:hover{background:#3b82f60d;color:var(--accent)}.task-title.empty{color:var(--text-muted);font-style:italic}.due-date-cell{border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;font-size:12px;font-weight:400;min-width:120px;padding:4px 8px;transition:all var(--transition-fast);white-space:nowrap}.due-date-cell:hover{background:#3b82f60d;color:var(--accent)}.due-date-text{align-items:center;display:flex;gap:4px}.due-date-text.overdue{color:var(--error)}.due-date-text.due-soon{color:var(--warning)}.no-due-date{color:var(--text-muted);font-style:italic}.row-actions{opacity:0;transition:opacity var(--transition-fast)}.delete-btn,.row-actions{align-items:center;display:flex;justify-content:center}.delete-btn{background:#0000;border:none;border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;height:28px;transition:all var(--transition-fast);width:28px}.delete-btn:hover{background:var(--error-light);color:var(--error)}.inline-edit{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:0 1px 2px #0000000d;color:var(--text-primary);font-family:inherit;font-size:14px;outline:none;padding:6px 12px;transition:all var(--transition-fast);width:100%}.inline-edit:focus{border-color:var(--accent);box-shadow:0 0 0 3px #3b82f61a,0 1px 3px #0000001a;transform:translateY(-1px)}.inline-edit:hover{border-color:var(--border-focus);box-shadow:0 2px 4px #0000001a}select.inline-edit{-webkit-appearance:none;appearance:none;background-image:url('data:image/svg+xml;charset=US-ASCII,<svg xmlns="http://www.w3.org/2000/svg" width="12" height="12" viewBox="0 0 12 12"><path fill="%236b7280" d="M6 9L1.5 4.5h9L6 9z"/></svg>');background-position:right 8px center;background-repeat:no-repeat;cursor:pointer;padding-right:32px}select.inline-edit:focus{background-image:url('data:image/svg+xml;charset=US-ASCII,<svg xmlns="http://www.w3.org/2000/svg" width="12" height="12" viewBox="0 0 12 12"><path fill="%233b82f6" d="M6 9L1.5 4.5h9L6 9z"/></svg>')}.title-edit{font-size:14px;font-weight:500}.date-edit{position:relative;width:140px}input[type=date].inline-edit{cursor:pointer;position:relative}input[type=date].inline-edit::-webkit-calendar-picker-indicator{background:url('data:image/svg+xml;charset=US-ASCII,<svg xmlns="http://www.w3.org/2000/svg" width="16" height="16" viewBox="0 0 24 24" fill="none" stroke="%236b7280" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><rect x="3" y="4" width="18" height="18" rx="2" ry="2"></rect><line x1="16" y1="2" x2="16" y2="6"></line><line x1="8" y1="2" x2="8" y2="6"></line><line x1="3" y1="10" x2="21" y2="10"></line></svg>') no-repeat 50%;background-size:16px;cursor:pointer;height:20px;opacity:.7;-webkit-transition:opacity var(--transition-fast);transition:opacity var(--transition-fast);width:20px}input[type=date].inline-edit:hover::-webkit-calendar-picker-indicator{opacity:1}input[type=date].inline-edit:focus::-webkit-calendar-picker-indicator{background:url('data:image/svg+xml;charset=US-ASCII,<svg xmlns="http://www.w3.org/2000/svg" width="16" height="16" viewBox="0 0 24 24" fill="none" stroke="%233b82f6" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><rect x="3" y="4" width="18" height="18" rx="2" ry="2"></rect><line x1="16" y1="2" x2="16" y2="6"></line><line x1="8" y1="2" x2="8" y2="6"></line><line x1="3" y1="10" x2="21" y2="10"></line></svg>') no-repeat 50%;background-size:16px;opacity:1}.subject-select{position:relative;width:100%;z-index:1000}.subject-options{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:0 12px 20px #0003,0 4px 6px #0000001f;left:0;max-height:220px;min-width:160px;overflow-y:auto;position:absolute;right:0;top:calc(100% + 4px);z-index:2000}.subject-option{align-items:center;background:#0000;border:none;border-left:3px solid #0000;color:var(--text-primary);cursor:pointer;display:flex;font-size:14px;gap:8px;padding:10px 12px;text-align:left;width:100%}.subject-option.highlight,.subject-option:hover{background:#3b82f614;border-left-color:var(--accent)}.subject-dot{border-radius:50%;flex-shrink:0;height:12px;width:12px}.empty-state{background:var(--bg-elevated);padding:48px 24px;text-align:center}.empty-icon{color:var(--text-muted);font-size:48px;margin:0 auto 16px}.empty-state h3{color:var(--text-primary);font-size:18px;font-weight:600;margin:0 0 8px}.empty-state p{color:var(--text-secondary);font-size:14px;line-height:1.4;margin:0}.loading-row{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@media (max-width:1024px){.todo-table td,.todo-table th{padding:6px 12px}.todo-table td:first-child,.todo-table th:first-child{padding-left:16px}.todo-table td:last-child,.todo-table th:last-child{padding-right:16px}}@media (max-width:768px){.todo-table-container{overflow-x:auto}.todo-table{min-width:600px}.todo-table td,.todo-table th{padding:6px 8px}.todo-table td:first-child,.todo-table th:first-child{padding-left:16px}.todo-table td:last-child,.todo-table th:last-child{padding-right:16px}.task-title-cell{min-width:200px}.row-actions{opacity:1}}@media (max-width:480px){.todo-table td,.todo-table th{padding:4px 8px}.todo-table td:first-child,.todo-table th:first-child{padding-left:12px}.todo-table td:last-child,.todo-table th:last-child{padding-right:12px}}.category-manager-overlay{align-items:center;animation:fadeIn .3s ease-out;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0009;bottom:0;display:flex;justify-content:center;left:0;padding:2rem;position:fixed;right:0;top:0;z-index:1000}.category-manager-modal{animation:slideUp .3s cubic-bezier(.34,1.56,.64,1);background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;max-height:80vh;max-width:600px;overflow:hidden;width:100%}.modal-header{align-items:center;background:var(--bg-elevated);border-bottom:1px solid var(--border);display:flex;justify-content:space-between;padding:20px 24px}.modal-header h2{color:var(--text-primary);font-size:20px;font-weight:600;line-height:1.2;margin:0}.close-btn{align-items:center;background:#0000;border:none;border-radius:var(--radius-md);color:var(--text-muted);cursor:pointer;display:flex;height:32px;justify-content:center;transition:all var(--transition-fast);width:32px}.close-btn:hover{background:var(--bg-secondary);color:var(--text-primary)}.modal-content{max-height:calc(80vh - 80px);overflow-y:auto;padding:24px}.modal-content::-webkit-scrollbar{width:6px}.modal-content::-webkit-scrollbar-track{background:var(--bg-secondary)}.modal-content::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.modal-content::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.categories-list{display:flex;flex-direction:column;gap:12px;margin-bottom:20px}.category-item{align-items:center;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);display:flex;justify-content:space-between;padding:16px;transition:all var(--transition-fast)}.category-item:hover{background:var(--bg-secondary);border-color:var(--border-focus)}.category-info{flex:1 1;margin-right:1rem}.category-preview{align-items:center;border:1px solid #0000;border-radius:var(--radius-md);display:inline-flex;font-size:14px;font-weight:500;justify-content:center;min-width:100px;padding:6px 12px;transition:all var(--transition-fast)}.category-actions{display:flex;gap:.75rem}.action-btn{align-items:center;background:#0000;border:none;border-radius:var(--radius-md);cursor:pointer;display:flex;height:32px;justify-content:center;transition:all var(--transition-fast);width:32px}.action-btn:hover{background:var(--bg-secondary)}.action-btn.edit{color:var(--text-muted)}.action-btn.edit:hover{background:#3b82f61a;color:var(--accent)}.action-btn.delete{color:var(--text-muted)}.action-btn.delete:hover{background:#ef44441a;color:var(--error)}.add-category-btn{align-items:center;background:var(--bg-elevated);border:1px dashed var(--border);border-radius:var(--radius-md);color:var(--text-muted);cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:8px;justify-content:center;padding:16px;transition:all var(--transition-fast);width:100%}.add-category-btn:hover{background:var(--bg-secondary);border-color:var(--accent);border-style:solid;color:var(--accent)}.category-edit-form{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);display:flex;flex-direction:column;gap:16px;padding:16px;width:100%}.form-group{gap:.75rem}.edit-input{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-family:inherit;font-size:14px;padding:8px 12px;transition:all var(--transition-fast)}.edit-input::placeholder{color:var(--text-muted)}.edit-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #3b82f61a;outline:none}.color-picker{grid-gap:8px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);display:grid;gap:8px;grid-template-columns:repeat(auto-fill,minmax(32px,1fr));padding:12px}.color-option{border:2px solid #0000;border-radius:var(--radius-md);cursor:pointer;height:32px;position:relative;transition:all var(--transition-fast);width:32px}.color-option.selected{border-color:var(--text-primary);box-shadow:0 0 0 2px var(--bg-elevated),0 0 0 4px var(--accent);transform:scale(1.1)}.color-option:hover{box-shadow:var(--shadow-sm);transform:scale(1.05)}.edit-actions{border-top:1px solid var(--border);display:flex;gap:8px;justify-content:flex-end;padding-top:12px}.cancel-btn,.save-btn{border:none;border-radius:var(--radius-md);cursor:pointer;font-family:inherit;font-size:14px;font-weight:500;padding:8px 16px;transition:all var(--transition-fast)}.save-btn{background:var(--accent);box-shadow:var(--shadow-xs);color:#fff}.save-btn:hover{background:var(--accent-hover);box-shadow:var(--shadow-sm)}.cancel-btn{background:#0000;border:1px solid var(--border);color:var(--text-secondary)}.cancel-btn:hover{background:var(--bg-secondary);border-color:var(--border-focus);color:var(--text-primary)}@media (max-width:768px){.category-manager-overlay{padding:1rem}.modal-header{padding:1.5rem 2rem}.modal-content{padding:2rem}.category-item{align-items:stretch;flex-direction:column;gap:1.25rem;padding:1.25rem}.category-info{margin-bottom:.5rem;margin-right:0}.category-actions,.edit-actions{justify-content:center}.edit-actions{flex-wrap:wrap}.color-picker{grid-template-columns:repeat(auto-fill,minmax(2.5rem,1fr))}.color-option{height:2.5rem;width:2.5rem}}@media (max-width:480px){.modal-header{padding:1.25rem 1.5rem}.modal-content{padding:1.5rem}.category-edit-form{padding:1.25rem}.edit-input{padding:.875rem 1rem}}.auth-container{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh;overflow:hidden;padding:2rem;position:relative}.auth-container:before{animation:float 20s ease-in-out infinite;background:radial-gradient(circle at 20% 50%,#7877c64d 0,#0000 50%),radial-gradient(circle at 80% 20%,#ff77c64d 0,#0000 50%),radial-gradient(circle at 40% 80%,#78dbff4d 0,#0000 50%);bottom:0;content:"";left:0;position:absolute;right:0;top:0}@keyframes float{0%,to{transform:translateY(0) rotate(0deg)}33%{transform:translateY(-20px) rotate(1deg)}66%{transform:translateY(10px) rotate(-1deg)}}.auth-modal{animation:slideUp .5s cubic-bezier(.34,1.56,.64,1);-webkit-backdrop-filter:blur(20px) saturate(180%);backdrop-filter:blur(20px) saturate(180%);background:var(--bg-elevated);border:1px solid #fff3;border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);max-width:420px;padding:2.5rem;position:relative;width:100%;z-index:10}.auth-header{margin-bottom:2.5rem;text-align:center}.auth-header h1{-webkit-text-fill-color:#0000;background:var(--gradient-primary);-webkit-background-clip:text;background-clip:text;color:var(--text-primary);font-size:2.25rem;font-weight:800;letter-spacing:-.04em;margin:0 0 .75rem}.auth-header p{color:var(--text-secondary);font-size:.9375rem;font-weight:500;margin:0}.auth-tabs{background:var(--bg-secondary);border-radius:var(--radius-xl);box-shadow:inset 0 1px 3px 0 #0000000d;display:flex;margin-bottom:2rem;padding:.375rem}.auth-tabs,.tab{position:relative}.tab{background:#0000;border:none;border-radius:var(--radius-lg);color:var(--text-secondary);cursor:pointer;flex:1 1;font-size:.9375rem;font-weight:600;padding:.875rem 1.25rem;transition:all var(--transition-smooth);z-index:2}.tab.active{background:var(--bg-elevated);box-shadow:var(--shadow-sm);color:var(--text-primary);transform:translateY(-1px)}.tab:hover:not(.active){background:#ffffff80;color:var(--text-primary)}.auth-form{gap:1.75rem}.auth-form,.form-group{display:flex;flex-direction:column}.form-group{gap:.625rem}.form-label{align-items:center;display:flex;font-size:.9375rem;font-weight:600;gap:.5rem}.form-input,.form-label{color:var(--text-primary)}.form-input{background:var(--bg-elevated);border:2px solid var(--border);border-radius:var(--radius-xl);font-size:1rem;padding:1rem 1.25rem;position:relative;transition:all var(--transition-smooth)}.form-input::placeholder{color:var(--text-muted)}.form-input:focus{border-color:var(--accent);box-shadow:0 0 0 4px #3b82f61a;outline:none;transform:translateY(-1px)}.error-message{background:var(--error-light);border:1px solid #dc262633;border-radius:var(--radius-lg);color:var(--error);font-size:.9375rem;font-weight:500;padding:1rem 1.25rem;text-align:center}.auth-btn{background:var(--gradient-accent);border:none;border-radius:var(--radius-xl);box-shadow:var(--shadow-md);color:#fff;cursor:pointer;font-size:1rem;font-weight:700;margin-top:.75rem;overflow:hidden;padding:1rem 1.5rem;position:relative;transition:all var(--transition-smooth)}.auth-btn:before{background:linear-gradient(135deg,#fff3,#fff0);bottom:0;content:"";left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity var(--transition-fast)}.auth-btn:hover{box-shadow:var(--shadow-xl);transform:translateY(-2px)}.auth-btn:hover:before{opacity:1}.auth-btn:active{transform:translateY(-1px)}.auth-btn:disabled{cursor:not-allowed;opacity:.6;transform:none}.auth-btn:disabled:hover{box-shadow:var(--shadow-md);transform:none}.auth-footer{border-top:1px solid var(--border);margin-top:2.5rem;padding-top:2rem;position:relative;text-align:center}.auth-footer:before{background:linear-gradient(90deg,#0000,var(--border),#0000);content:"";height:1px;left:50%;position:absolute;top:0;transform:translateX(-50%);width:60px}.auth-footer p{color:var(--text-secondary);font-size:.9375rem;font-weight:500;margin:0}.auth-btn.loading{color:#0000;position:relative}.auth-btn.loading:after{animation:spin 1s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;content:"";height:20px;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);width:20px}@keyframes spin{0%{transform:translate(-50%,-50%) rotate(0deg)}to{transform:translate(-50%,-50%) rotate(1turn)}}.dark .auth-container{background:linear-gradient(135deg,#1e293b,#334155)}.dark .auth-modal{border:1px solid #ffffff1a}.dark .error-message{background:var(--error-light);border:1px solid #f8717133;color:var(--error)}@media (max-width:768px){.auth-container{padding:1.5rem}.auth-modal{max-width:100%;padding:2rem}.auth-header h1{font-size:2rem}}@media (max-width:480px){.auth-container{padding:1rem}.auth-modal{padding:1.5rem}.auth-header h1{font-size:1.75rem}.form-input{padding:.875rem 1rem}.auth-btn{padding:.875rem 1.25rem}}:root{--bg-primary:#fff;--bg-secondary:#fafbfc;--bg-tertiary:#f6f8fa;--bg-elevated:#fff;--text-primary:#0f172a;--text-secondary:#475569;--text-muted:#64748b;--text-accent:#3b82f6;--border:#e1e7ef;--border-light:#f1f5f9;--border-focus:#3b82f6;--accent:#3b82f6;--accent-hover:#2563eb;--accent-light:#eff6ff;--success:#059669;--success-light:#ecfdf5;--warning:#d97706;--warning-light:#fffbeb;--error:#dc2626;--error-light:#fef2f2;--shadow-xs:0 1px 2px 0 #0000000a;--shadow-sm:0 1px 3px 0 #00000014,0 1px 2px -1px #00000014;--shadow-md:0 4px 6px -1px #00000014,0 2px 4px -2px #00000014;--shadow-lg:0 10px 15px -3px #00000014,0 4px 6px -4px #00000014;--shadow-xl:0 20px 25px -5px #00000014,0 8px 10px -6px #00000014;--radius-xs:0.25rem;--radius-sm:0.375rem;--radius-md:0.5rem;--radius-lg:0.75rem;--radius-xl:1rem;--gradient-primary:linear-gradient(135deg,#667eea,#764ba2);--gradient-accent:linear-gradient(135deg,#3b82f6,#1d4ed8);--transition-fast:0.12s cubic-bezier(0.4,0,0.2,1);--transition-smooth:0.22s cubic-bezier(0.4,0,0.2,1)}.dark{--bg-primary:#0f172a;--bg-secondary:#1e293b;--bg-tertiary:#334155;--bg-elevated:#1e293b;--text-primary:#f1f5f9;--text-secondary:#cbd5e1;--text-muted:#94a3b8;--text-accent:#60a5fa;--border:#334155;--border-light:#475569;--border-focus:#60a5fa;--accent:#60a5fa;--accent-hover:#3b82f6;--accent-light:#1e293b;--success:#10b981;--success-light:#064e3b;--warning:#f59e0b;--warning-light:#451a03;--error:#f87171;--error-light:#7f1d1d;--shadow-xs:0 1px 2px 0 #0000004d;--shadow-sm:0 1px 3px 0 #0006,0 1px 2px -1px #0006;--shadow-md:0 4px 6px -1px #0006,0 2px 4px -2px #0006;--shadow-lg:0 10px 15px -3px #0006,0 4px 6px -4px #0006;--shadow-xl:0 20px 25px -5px #0006,0 8px 10px -6px #0006}*{box-sizing:border-box}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}.app,body{background:#fafbfc;background:var(--bg-secondary)}.app{color:#0f172a;color:var(--text-primary);font-size:14px;line-height:1.5;min-height:100vh;transition:all .22s cubic-bezier(.4,0,.2,1);transition:all var(--transition-smooth)}.app-header{-webkit-backdrop-filter:blur(20px) saturate(180%);backdrop-filter:blur(20px) saturate(180%);background:#fff;background:var(--bg-elevated);border-bottom:1px solid #e1e7ef;border-bottom:1px solid var(--border);box-shadow:0 1px 2px 0 #0000000a;box-shadow:var(--shadow-xs);padding:0;position:-webkit-sticky;position:sticky;top:0;z-index:100}.header-content{align-items:center;display:flex;justify-content:space-between;margin:0 auto;max-width:1200px;padding:1.25rem 2rem}.header-left h1{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);background:var(--gradient-primary);-webkit-background-clip:text;background-clip:text;color:#0f172a;color:var(--text-primary);font-size:1.75rem;font-weight:800;letter-spacing:-.04em;margin:0}.header-left p{color:#475569;color:var(--text-secondary);font-size:.875rem;font-weight:500;margin:.25rem 0 0}.header-actions{align-items:center;display:flex;gap:1rem}.user-info{font-size:.875rem;font-weight:500;padding:.5rem 0}.icon-btn,.user-info{color:#475569;color:var(--text-secondary)}.icon-btn{align-items:center;background:#f6f8fa;background:var(--bg-tertiary);border:none;border-radius:.75rem;border-radius:var(--radius-lg);cursor:pointer;display:flex;height:2.25rem;justify-content:center;overflow:hidden;position:relative;transition:all .12s cubic-bezier(.4,0,.2,1);transition:all var(--transition-fast);width:2.25rem}.icon-btn:before{background:#3b82f6;background:var(--accent);bottom:0;content:"";left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity .12s cubic-bezier(.4,0,.2,1);transition:opacity var(--transition-fast);z-index:-1}.icon-btn:hover{background:#eff6ff;background:var(--accent-light);box-shadow:0 4px 6px -1px #00000014,0 2px 4px -2px #00000014;box-shadow:var(--shadow-md);color:#3b82f6;color:var(--accent);transform:translateY(-1px)}.icon-btn:hover:before{opacity:.1}.icon-btn:active{transform:translateY(0)}.logout-btn{align-items:center;background:#f6f8fa;background:var(--bg-tertiary);border:1px solid #e1e7ef;border:1px solid var(--border);border-radius:.75rem;border-radius:var(--radius-lg);color:#475569;color:var(--text-secondary);cursor:pointer;display:flex;font-size:.875rem;font-weight:600;gap:.5rem;overflow:hidden;padding:.625rem 1.25rem;position:relative}.logout-btn,.logout-btn:before{transition:all .12s cubic-bezier(.4,0,.2,1);transition:all var(--transition-fast)}.logout-btn:before{background:#dc2626;background:var(--error);bottom:0;content:"";left:0;opacity:0;position:absolute;right:0;top:0;z-index:-1}.logout-btn:hover{border-color:#dc2626;border-color:var(--error);box-shadow:0 4px 6px -1px #00000014,0 2px 4px -2px #00000014;box-shadow:var(--shadow-md);color:#dc2626;color:var(--error);transform:translateY(-1px)}.logout-btn:hover:before{opacity:.1}.app-main{margin:0 auto;max-width:1200px;padding:2.5rem 2rem}.projects-container{border:1px solid #e1e7ef;border:1px solid var(--border);border-radius:.75rem;border-radius:var(--radius-lg);box-shadow:0 1px 3px 0 #00000014,0 1px 2px -1px #00000014;box-shadow:var(--shadow-sm);overflow:visible}.projects-container,.projects-header{background:#fff;background:var(--bg-elevated)}.projects-header{align-items:center;border-bottom:1px solid #e1e7ef;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;padding:16px 24px}.projects-title{align-items:center;display:flex;gap:12px}.projects-title h1{color:#0f172a;color:var(--text-primary);font-size:20px;font-weight:600;line-height:1.2;margin:0}.projects-count{background:#fafbfc;background:var(--bg-secondary);border:1px solid #e1e7ef;border:1px solid var(--border);border-radius:.375rem;border-radius:var(--radius-sm);color:#64748b;color:var(--text-muted);font-size:14px;padding:2px 8px}.new-task-btn{align-items:center;background:#3b82f6;background:var(--accent);border:none;border-radius:.375rem;border-radius:var(--radius-sm);box-shadow:0 1px 2px 0 #0000000a;box-shadow:var(--shadow-xs);color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:6px;padding:6px 12px;transition:all .12s cubic-bezier(.4,0,.2,1);transition:all var(--transition-fast)}.new-task-btn:hover{background:#2563eb;background:var(--accent-hover);box-shadow:0 1px 3px 0 #00000014,0 1px 2px -1px #00000014;box-shadow:var(--shadow-sm);transform:translateY(-1px)}.new-task-btn:active{box-shadow:0 1px 2px 0 #0000000a;box-shadow:var(--shadow-xs);transform:translateY(0)}.first-time-note{align-items:center;animation:fadeIn .3s ease-out;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.note-content{animation:slideUp .3s ease-out;background:#fff;background:var(--bg-elevated);border:1px solid #e1e7ef;border:1px solid var(--border);border-radius:1rem;border-radius:var(--radius-xl);box-shadow:0 20px 25px -5px #00000014,0 8px 10px -6px #00000014;box-shadow:var(--shadow-xl);margin:2rem;max-width:420px;padding:2.5rem;position:relative;text-align:center}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.note-content h3{color:#0f172a;color:var(--text-primary);font-size:1.5rem;font-weight:700;letter-spacing:-.025em;margin:0 0 1rem}.note-content p{color:#475569;color:var(--text-secondary);font-size:.9375rem;line-height:1.6;margin:0 0 2rem}.note-close{background:linear-gradient(135deg,#3b82f6,#1d4ed8);background:var(--gradient-accent);border:none;border-radius:.75rem;border-radius:var(--radius-lg);box-shadow:0 1px 3px 0 #00000014,0 1px 2px -1px #00000014;box-shadow:var(--shadow-sm);color:#fff;cursor:pointer;font-size:.9375rem;font-weight:600;overflow:hidden;padding:.875rem 2rem;position:relative;transition:all .12s cubic-bezier(.4,0,.2,1);transition:all var(--transition-fast)}.note-close:before{background:linear-gradient(135deg,#fff3,#fff0);bottom:0;content:"";left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity .12s cubic-bezier(.4,0,.2,1);transition:opacity var(--transition-fast)}.note-close:hover{box-shadow:0 10px 15px -3px #00000014,0 4px 6px -4px #00000014;box-shadow:var(--shadow-lg);transform:translateY(-1px)}.note-close:hover:before{opacity:1}@media (max-width:768px){.header-content{padding:1rem 1.5rem}.app-main{padding:1.5rem 1rem}.projects-header{padding:12px 16px}.header-actions{gap:.75rem}.user-info{display:none}.note-content{margin:1rem;padding:2rem}.header-left h1{font-size:1.5rem}}@media (max-width:480px){.header-content{padding:1rem}.app-main{padding:1rem .75rem}.projects-header{padding:12px 16px}.projects-title h1{font-size:18px}}html{scroll-behavior:smooth}:focus-visible{outline:2px solid #3b82f6;outline:2px solid var(--accent);outline-offset:2px}
/*# sourceMappingURL=main.a8dc1a49.css.map*/