@import"https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700&display=swap";:root{--primary: #8a2be2;--primary-hover: #7b24c6;--primary-light: rgba(138, 43, 226, .15);--success: #10b981;--danger: #ef4444;--warning: #f59e0b;--bg-color: #0c0c0e;--surface-color: #1a1a1e;--surface-hover: #25252b;--border-color: #2e2e36;--text-primary: #f8fafc;--text-secondary: #94a3b8;--text-tertiary: #64748b;--font-family: "Outfit", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;--font-xs: .75rem;--font-sm: .875rem;--font-base: 1rem;--font-lg: 1.125rem;--font-xl: 1.25rem;--font-2xl: 1.5rem;--font-3xl: 2rem;--spacing-1: .25rem;--spacing-2: .5rem;--spacing-3: .75rem;--spacing-4: 1rem;--spacing-5: 1.25rem;--spacing-6: 1.5rem;--spacing-8: 2rem;--spacing-12: 3rem;--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-full: 9999px;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--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);--glow-primary: 0 0 15px rgba(138, 43, 226, .4);--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-normal: .25s cubic-bezier(.4, 0, .2, 1);--transition-slow: .4s cubic-bezier(.4, 0, .2, 1)}:root[data-theme=light]{--bg-color: #f8fafc;--surface-color: #ffffff;--surface-hover: #f1f5f9;--border-color: #e2e8f0;--text-primary: #0f172a;--text-secondary: #475569;--text-tertiary: #94a3b8;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .05), 0 2px 4px -2px rgb(0 0 0 / .05);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .05), 0 4px 6px -4px rgb(0 0 0 / .05)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-family);background-color:var(--bg-color);color:var(--text-primary);line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh;transition:background-color var(--transition-normal),color var(--transition-normal)}a{color:var(--primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--primary-hover)}button{font-family:inherit;border:none;background:none;cursor:pointer}input,textarea{font-family:inherit}::selection{background-color:var(--primary);color:#fff}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-color)}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}.app-header{height:64px;display:flex;align-items:center;justify-content:space-between;padding:0 var(--spacing-6);background-color:var(--surface-color);border-bottom:1px solid var(--border-color);position:sticky;top:0;z-index:10}.header-brand{display:flex;align-items:center;gap:var(--spacing-3)}.header-logo{width:32px;height:32px;background:linear-gradient(135deg,var(--primary),#a855f7);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:var(--shadow-sm)}.header-logo svg{width:18px;height:18px}.header-title{font-size:var(--font-xl);font-weight:700;letter-spacing:-.5px;margin:0;background:linear-gradient(to right,var(--text-primary),var(--text-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent}.theme-toggle{width:40px;height:40px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;color:var(--text-secondary);transition:all var(--transition-fast)}.theme-toggle:hover{background-color:var(--surface-hover);color:var(--primary)}.theme-toggle svg{width:20px;height:20px}.ui-button{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-2);border-radius:var(--radius-md);font-weight:500;transition:all var(--transition-short);cursor:pointer;border:1px solid transparent}.ui-button:disabled{opacity:.6;cursor:not-allowed}.ui-button:active:not(:disabled){transform:scale(.97)}.ui-button--sm{padding:var(--spacing-1) var(--spacing-3);font-size:var(--font-sm)}.ui-button--md{padding:var(--spacing-2) var(--spacing-4);font-size:var(--font-base)}.ui-button--lg{padding:var(--spacing-3) var(--spacing-6);font-size:var(--font-lg)}.ui-button--primary{background-color:var(--primary);color:#fff;box-shadow:var(--shadow-sm)}.ui-button--primary:hover:not(:disabled){background-color:var(--primary-hover);box-shadow:var(--glow-primary)}.ui-button--secondary{background-color:var(--surface-hover);color:var(--text-primary);border-color:var(--border-color)}.ui-button--secondary:hover:not(:disabled){background-color:var(--border-color)}.ui-button--danger{background-color:transparent;color:var(--danger);border-color:#ef44444d}.ui-button--danger:hover:not(:disabled){background-color:#ef44441a;border-color:var(--danger)}.ui-button--ghost{background-color:transparent;color:var(--text-secondary)}.ui-button--ghost:hover:not(:disabled){background-color:var(--surface-hover);color:var(--text-primary)}.ui-button--full-width{width:100%}.app-sidebar{width:260px;background-color:var(--surface-color);border-right:1px solid var(--border-color);display:flex;flex-direction:column;height:calc(100vh - 64px);position:sticky;top:64px}.sidebar-nav{padding:var(--spacing-4);display:flex;flex-direction:column;gap:var(--spacing-6);flex:1}.nav-section{display:flex;flex-direction:column;gap:var(--spacing-2)}.nav-section.mt-auto{margin-top:auto}.nav-section-title{font-size:var(--font-xs);font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-tertiary);margin-bottom:var(--spacing-2);padding-left:var(--spacing-2)}.nav-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:2px}.nav-item{margin:0}.nav-link{display:flex;align-items:center;gap:var(--spacing-3);padding:var(--spacing-2) var(--spacing-3);border-radius:var(--radius-md);color:var(--text-secondary);font-weight:500;transition:all var(--transition-fast)}.nav-link:hover{background-color:var(--surface-hover);color:var(--text-primary)}.nav-link.active{background-color:var(--primary-light);color:var(--primary)}.nav-icon{font-size:var(--font-lg);display:flex;align-items:center;justify-content:center;width:24px}.nav-color-dot{width:10px;height:10px;border-radius:var(--radius-full);margin-left:var(--spacing-1)}@media(max-width:768px){.app-sidebar{position:fixed;transform:translate(-100%);z-index:20;transition:transform var(--transition-normal)}.app-sidebar.open{transform:translate(0)}}.app-layout{display:flex;flex-direction:column;min-height:100vh;width:100%}.app-body{display:flex;flex:1;position:relative}.app-main-content{flex:1;padding:var(--spacing-6) var(--spacing-8);overflow-y:auto;background-color:var(--bg-color);max-width:1000px;margin:0 auto;width:100%}@media(max-width:768px){.app-main-content{padding:var(--spacing-4)}}.toast-container{position:fixed;bottom:var(--spacing-6);left:50%;transform:translate(-50%);display:flex;flex-direction:column;gap:var(--spacing-2);z-index:9999;pointer-events:none}.ui-toast{display:flex;align-items:center;gap:var(--spacing-3);padding:var(--spacing-3) var(--spacing-4);background-color:var(--text-primary);color:var(--bg-color);border-radius:var(--radius-full);box-shadow:var(--shadow-lg);pointer-events:auto;animation:slideUpFade .3s cubic-bezier(.175,.885,.32,1.275) forwards}.ui-toast-message{font-size:var(--font-sm);font-weight:500}.ui-toast-action{background:transparent;border:none;color:var(--primary);font-weight:600;font-size:var(--font-sm);cursor:pointer;padding:var(--spacing-1) var(--spacing-2);border-radius:var(--radius-sm);transition:background-color var(--transition-fast)}.ui-toast-action:hover{background-color:#8a2be21a}.ui-toast-close{background:transparent;border:none;color:var(--bg-color);opacity:.6;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;transition:opacity var(--transition-fast)}.ui-toast-close:hover{opacity:1}.ui-toast-close svg{width:16px;height:16px}@keyframes slideUpFade{0%{opacity:0;transform:translateY(20px) scale(.9)}to{opacity:1;transform:translateY(0) scale(1)}}.ui-modal-overlay{position:fixed;inset:0;background-color:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn var(--transition-normal) forwards}.ui-modal-content{background-color:var(--surface-color);border:1px solid var(--border-color);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);width:100%;max-width:500px;max-height:90vh;display:flex;flex-direction:column;animation:slideUp var(--transition-normal) forwards;margin:var(--spacing-4)}.ui-modal-header{padding:var(--spacing-4) var(--spacing-5);border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;align-items:center}.ui-modal-title{font-size:var(--font-lg);font-weight:600;color:var(--text-primary);margin:0}.ui-modal-close{background:transparent;border:none;color:var(--text-tertiary);cursor:pointer;padding:var(--spacing-1);display:flex;align-items:center;justify-content:center;border-radius:var(--radius-full);transition:all var(--transition-fast)}.ui-modal-close svg{width:20px;height:20px}.ui-modal-close:hover{background-color:var(--surface-hover);color:var(--text-primary)}.ui-modal-body{padding:var(--spacing-5);overflow-y:auto}.ui-modal-footer{padding:var(--spacing-4) var(--spacing-5);border-top:1px solid var(--border-color);display:flex;justify-content:flex-end;gap:var(--spacing-3);background-color:var(--surface-hover);border-bottom-left-radius:var(--radius-xl);border-bottom-right-radius:var(--radius-xl)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.ui-input-container{display:flex;flex-direction:column;gap:var(--spacing-1)}.ui-input-container--full-width{width:100%}.ui-input-label{font-size:var(--font-sm);font-weight:500;color:var(--text-secondary)}.ui-input{padding:var(--spacing-2) var(--spacing-3);background-color:var(--surface-color);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:var(--font-base);transition:all var(--transition-fast);outline:none}.ui-input:hover{border-color:var(--text-tertiary)}.ui-input:focus{border-color:var(--primary);box-shadow:0 0 0 2px var(--primary-light)}.ui-input::placeholder{color:var(--text-tertiary)}.ui-input--error{border-color:var(--danger)}.ui-input--error:focus{border-color:var(--danger);box-shadow:0 0 0 2px #ef444426}.ui-input-error-msg{font-size:var(--font-xs);color:var(--danger);margin-top:2px}.task-item{display:flex;align-items:flex-start;padding:var(--spacing-4);background-color:var(--surface-color);border:1px solid var(--border-color);border-radius:var(--radius-lg);margin-bottom:var(--spacing-3);transition:all var(--transition-normal);position:relative;overflow:hidden}.task-item:hover{border-color:var(--text-tertiary);box-shadow:var(--shadow-md);transform:translateY(-2px)}.task-item.completed{opacity:.6;background-color:transparent}.task-item.completed:hover{opacity:.8;transform:none;box-shadow:none;border-color:var(--border-color)}.task-checkbox-wrapper{margin-top:var(--spacing-1);margin-right:var(--spacing-4)}.task-content{flex:1;min-width:0}.task-title{margin:0 0 var(--spacing-1) 0;font-size:var(--font-lg);font-weight:500;color:var(--text-primary);transition:color var(--transition-fast)}.task-item.completed .task-title{text-decoration:line-through;color:var(--text-tertiary)}.task-description{margin:0 0 var(--spacing-3) 0;font-size:var(--font-sm);color:var(--text-secondary);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.task-meta{display:flex;flex-wrap:wrap;gap:var(--spacing-2)}.task-badge{display:inline-flex;align-items:center;gap:var(--spacing-1);padding:2px var(--spacing-2);border-radius:var(--radius-sm);font-size:var(--font-xs);font-weight:600;background-color:var(--surface-hover);color:var(--text-secondary)}.task-badge.danger,.task-badge.priority-high{color:var(--danger);background-color:#ef44441a}.task-badge.priority-medium{color:var(--warning);background-color:#f59e0b1a}.list-dot{width:6px;height:6px;border-radius:var(--radius-full)}.task-actions{display:flex;gap:var(--spacing-1);opacity:0;transform:translate(10px);transition:all var(--transition-normal)}.task-item:hover .task-actions{opacity:1;transform:translate(0)}.task-action-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);color:var(--text-tertiary)}.task-action-btn svg{width:16px;height:16px}.task-action-btn:hover{background-color:var(--surface-hover);color:var(--text-primary)}.task-action-btn.delete:hover{background-color:#ef44441a;color:var(--danger)}@media(max-width:640px){.task-actions{opacity:1;transform:none}}.kanban-board{display:grid;grid-template-columns:repeat(1,1fr);gap:var(--spacing-6);margin-top:var(--spacing-4);animation:fadeIn var(--transition-normal) ease-out}@media(min-width:768px){.kanban-board{grid-template-columns:repeat(3,1fr)}}.kanban-column{display:flex;flex-direction:column;background-color:var(--surface-secondary, rgba(255, 255, 255, .03));border-radius:var(--radius-xl);padding:var(--spacing-4);min-height:400px;border:1px solid var(--border-color)}.kanban-column-title{font-size:var(--font-lg);font-weight:600;margin:0;color:var(--text-primary)}.kanban-column-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-4);padding-bottom:var(--spacing-2);border-bottom:1px solid var(--border-color)}.kanban-count{background-color:var(--surface-color);color:var(--text-secondary);font-size:var(--font-sm);padding:2px 10px;border-radius:var(--radius-full);border:1px solid var(--border-color)}.kanban-column-content{display:flex;flex-direction:column;gap:var(--spacing-2);height:100%}.task-list-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-12) var(--spacing-4);text-align:center;background-color:var(--surface-color);border:1px dashed var(--border-color);border-radius:var(--radius-xl);margin-top:var(--spacing-4)}.empty-icon{font-size:var(--font-3xl);margin-bottom:var(--spacing-4);opacity:.8;animation:float 3s ease-in-out infinite}.empty-text{font-size:var(--font-lg);color:var(--text-secondary);margin:0}@keyframes float{0%{transform:translateY(0)}50%{transform:translateY(-10px)}to{transform:translateY(0)}}.task-form-trigger{display:flex;align-items:center;gap:var(--spacing-3);padding:var(--spacing-3) var(--spacing-4);background-color:var(--surface-color);border:1px dashed var(--border-color);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast);margin-top:var(--spacing-4);color:var(--text-secondary)}.task-form-trigger:hover{background-color:var(--surface-hover);border-color:var(--primary);color:var(--primary)}.plus-icon{font-size:var(--font-lg);font-weight:500;display:flex;align-items:center;justify-content:center;width:24px;height:24px;background-color:var(--primary-light);color:var(--primary);border-radius:var(--radius-full)}.trigger-text{font-size:var(--font-base);font-weight:500}.task-form{display:flex;flex-direction:column;background-color:var(--surface-color);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--spacing-4);margin-top:var(--spacing-4);box-shadow:var(--shadow-md);animation:slideDown var(--transition-normal) forwards}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.task-form-title-input{width:100%;border:none;background:transparent;font-size:var(--font-lg);color:var(--text-primary);outline:none;margin-bottom:var(--spacing-2);font-family:inherit}.task-form-title-input::placeholder{color:var(--text-tertiary)}.task-form-desc-input{width:100%;border:none;background:transparent;font-size:var(--font-sm);color:var(--text-secondary);outline:none;resize:none;font-family:inherit;margin-bottom:var(--spacing-4)}.task-form-desc-input::placeholder{color:var(--text-tertiary)}.task-form-meta-inputs{display:flex;gap:var(--spacing-3);flex-wrap:wrap}.task-form-date,.task-form-select{background-color:var(--surface-hover);color:var(--text-secondary);border:1px solid transparent;padding:var(--spacing-2) var(--spacing-3);border-radius:var(--radius-md);font-size:var(--font-sm);outline:none;cursor:pointer;font-family:inherit;transition:all var(--transition-fast)}.task-form-date:hover,.task-form-date:focus,.task-form-select:hover,.task-form-select:focus{border-color:var(--border-color);background-color:var(--surface-color)}.task-form-footer{display:flex;border-top:1px solid var(--border-color);padding-top:var(--spacing-4)}.task-form-actions{display:flex;gap:var(--spacing-2)}.dashboard-container{animation:fadeIn var(--transition-normal) ease-out}.dashboard-metrics-grid{display:grid;grid-template-columns:repeat(1,1fr);gap:var(--spacing-4);margin-top:var(--spacing-6)}@media(min-width:640px){.dashboard-metrics-grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:1024px){.dashboard-metrics-grid{grid-template-columns:repeat(4,1fr)}}.metric-card{background-color:var(--surface-color);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--spacing-5);display:flex;align-items:center;gap:var(--spacing-4);transition:transform var(--transition-normal),box-shadow var(--transition-normal)}.metric-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--primary-light)}.metric-icon{width:48px;height:48px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;flex-shrink:0}.metric-icon svg{width:24px;height:24px}.metric-content{display:flex;flex-direction:column}.metric-title{margin:0;font-size:var(--font-sm);color:var(--text-secondary);font-weight:500}.metric-value{font-size:var(--font-2xl);font-weight:700;color:var(--text-primary);line-height:1.2}.dashboard-progress-section{margin-top:var(--spacing-8);background-color:var(--surface-color);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--spacing-6)}.dashboard-progress-section h3{margin:0 0 var(--spacing-4) 0;font-size:var(--font-lg);color:var(--text-primary)}.progress-bar-container{width:100%;height:12px;background-color:var(--surface-secondary, rgba(0, 0, 0, .05));border-radius:var(--radius-full);overflow:hidden}.progress-bar-fill{height:100%;background-color:var(--primary);border-radius:var(--radius-full);transition:width 1s ease-out}.progress-text{margin:var(--spacing-2) 0 0 0;font-size:var(--font-sm);color:var(--text-secondary);text-align:right}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--primary-light) 0%,var(--surface-secondary, rgba(238, 242, 255, .4)) 100%);padding:var(--spacing-4);animation:fadeIn var(--transition-slow) ease-out}.login-card{background-color:var(--surface-color);border:1px solid var(--border-color);border-radius:var(--radius-2xl);padding:var(--spacing-8);width:100%;max-width:440px;box-shadow:var(--shadow-xl);display:flex;flex-direction:column;gap:var(--spacing-6)}.login-header{text-align:center}.login-logo{width:64px;height:64px;background-color:var(--primary);color:#fff;border-radius:var(--radius-xl);display:flex;align-items:center;justify-content:center;margin:0 auto var(--spacing-4);box-shadow:0 8px 16px #6366f133}.login-logo svg{width:32px;height:32px}.login-header h1{margin:0 0 var(--spacing-2);font-size:var(--font-2xl);color:var(--text-primary);font-weight:700}.login-header p{margin:0;color:var(--text-secondary);font-size:var(--font-md);line-height:1.5}.login-form{display:flex;flex-direction:column;gap:var(--spacing-4)}
