@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";:root{--bg-base:#0d0d17;--bg-surface:#13131f;--bg-card:#1a1a2e;--bg-hover:#1f1f36;--bg-modal:#16162a;--border:#ffffff12;--border-focus:#8b5cf699;--accent:#8b5cf6;--accent-light:#a78bfa;--accent-glow:#8b5cf640;--accent-grad:linear-gradient(135deg, #8b5cf6 0%, #6366f1 100%);--text-primary:#f1f0ff;--text-secondary:#9896b8;--text-muted:#5e5c7a;--green:#4ade80;--yellow:#fbbf24;--red:#f87171;--blue:#60a5fa;--orange:#fb923c;--radius:12px;--radius-lg:18px;--radius-sm:8px;--shadow-card:0 4px 24px #0006;--shadow-glow:0 0 30px #8b5cf626}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{background:var(--bg-base);color:var(--text-primary);-webkit-font-smoothing:antialiased;min-height:100vh;font-family:Inter,system-ui,sans-serif;line-height:1.6}a{color:var(--accent-light);text-decoration:none}a:hover{text-decoration:underline}button{cursor:pointer;font-family:inherit}input,select,textarea{font-family:inherit}.splash-loader{min-height:100vh;color:var(--text-secondary);flex-direction:column;justify-content:center;align-items:center;gap:16px;display:flex}.spinner,.btn-spinner{border:2px solid #ffffff26;border-top-color:#fff;border-radius:50%;width:20px;height:20px;animation:.7s linear infinite spin;display:inline-block}.btn-spinner{width:16px;height:16px}@keyframes spin{to{transform:rotate(360deg)}}.spin{animation:1.2s linear infinite spin}.auth-page{grid-template-columns:1fr 1fr;min-height:100vh;display:grid}.auth-left{background:var(--accent-grad);justify-content:center;align-items:center;padding:60px 48px;display:flex;position:relative;overflow:hidden}.auth-left:before{content:"";background:radial-gradient(at 20% 20%,#ffffff14 0%,#0000 60%),radial-gradient(at 80% 80%,#0003 0%,#0000 60%);position:absolute;inset:0}.auth-hero{z-index:1;color:#fff;max-width:400px;position:relative}.hero-icon-wrap{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffff26;border:1px solid #fff3;border-radius:20px;justify-content:center;align-items:center;width:80px;height:80px;margin-bottom:28px;display:flex}.auth-hero h1{letter-spacing:-.5px;margin-bottom:16px;font-size:2.4rem;font-weight:800}.auth-hero p{opacity:.88;margin-bottom:32px;font-size:1.05rem;line-height:1.7}.hero-features{flex-direction:column;gap:12px;list-style:none;display:flex}.hero-features li{opacity:.9;align-items:center;gap:10px;font-size:.95rem;display:flex}.dot{background:#ffffffb3;border-radius:50%;flex-shrink:0;width:8px;height:8px}.auth-right{background:var(--bg-surface);justify-content:center;align-items:center;padding:40px 48px;display:flex;overflow-y:auto}.auth-card{width:100%;max-width:420px}.auth-card-header{margin-bottom:32px}.auth-card-header h2{color:var(--text-primary);margin-bottom:6px;font-size:1.8rem;font-weight:700}.auth-card-header p{color:var(--text-secondary);font-size:.95rem}.auth-form{flex-direction:column;gap:20px;display:flex}.form-group{flex-direction:column;gap:7px;display:flex}.form-group label{color:var(--text-secondary);font-size:.875rem;font-weight:500}.input-wrap{align-items:center;display:flex;position:relative}.input-icon{color:var(--text-muted);pointer-events:none;flex-shrink:0;position:absolute;left:14px}.input-wrap input,.form-group input,.form-group select,.form-group textarea{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text-primary);outline:none;padding:11px 14px;font-size:.925rem;transition:border-color .2s,box-shadow .2s}.input-wrap input{padding-left:42px}.input-wrap input:has(+.eye-btn){padding-right:42px}.form-group input:focus,.form-group select:focus,.form-group textarea:focus,.input-wrap input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.form-group select{appearance:none;cursor:pointer}.form-group textarea{resize:vertical;min-height:80px}.form-group.has-error input,.form-group.has-error select,.form-group.has-error textarea{border-color:var(--red)}.form-group.has-error input:focus{box-shadow:0 0 0 3px #f8717133}.field-error{color:var(--red);align-items:center;gap:4px;font-size:.8rem;display:flex}.form-error-banner{border-radius:var(--radius-sm);color:var(--red);border-radius:var(--radius-sm);background:#f871711a;border:1px solid #f871714d;padding:10px 14px;font-size:.875rem}.eye-btn{color:var(--text-muted);background:0 0;border:none;align-items:center;padding:4px;transition:color .2s;display:flex;position:absolute;right:12px}.eye-btn:hover{color:var(--text-primary)}.strength-bar-wrap{align-items:center;gap:10px;margin-top:4px;display:flex}.strength-bar{flex:1;gap:4px;display:flex}.bar-seg{background:var(--bg-hover);border-radius:4px;flex:1;height:4px;transition:background .3s}.bar-seg.weak{background:var(--red)}.bar-seg.fair{background:var(--orange)}.bar-seg.good{background:var(--yellow)}.bar-seg.strong{background:var(--green)}.bar-seg.very-strong{background:var(--accent)}.strength-label{text-align:right;min-width:68px;font-size:.75rem;font-weight:600}.strength-label.weak{color:var(--red)}.strength-label.fair{color:var(--orange)}.strength-label.good{color:var(--yellow)}.strength-label.strong{color:var(--green)}.strength-label.very-strong{color:var(--accent)}.auth-switch{text-align:center;color:var(--text-secondary);margin-top:24px;font-size:.9rem}.auth-switch a{color:var(--accent-light);font-weight:600}.auth-switch a:hover{text-decoration:underline}.required{color:var(--red)}.optional{color:var(--text-muted);font-size:.8rem;font-weight:400}.btn-primary{background:var(--accent-grad);border-radius:var(--radius-sm);color:#fff;border:none;justify-content:center;align-items:center;gap:8px;width:100%;padding:12px 22px;font-size:.925rem;font-weight:600;transition:opacity .2s,transform .15s,box-shadow .2s;display:flex;box-shadow:0 4px 16px #8b5cf659}.btn-primary:hover:not(:disabled){opacity:.9;transform:translateY(-1px);box-shadow:0 6px 22px #8b5cf673}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-secondary{border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);background:0 0;justify-content:center;align-items:center;gap:8px;padding:11px 22px;font-size:.925rem;font-weight:500;transition:all .2s;display:flex}.btn-secondary:hover{background:var(--bg-hover);color:var(--text-primary);border-color:#ffffff26}.navbar{z-index:100;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-bottom:1px solid var(--border);background:#0d0d17d9;position:sticky;top:0}.navbar-inner{justify-content:space-between;align-items:center;max-width:1100px;height:60px;margin:0 auto;padding:0 24px;display:flex}.navbar-brand{color:var(--text-primary);align-items:center;gap:10px;font-size:1.15rem;font-weight:700;text-decoration:none;display:flex}.brand-icon{color:var(--accent-light)}.navbar-right{align-items:center;gap:12px;display:flex}.user-pill{background:var(--bg-card);border:1px solid var(--border);color:var(--text-secondary);border-radius:99px;align-items:center;gap:7px;padding:6px 14px;font-size:.85rem;display:flex}.btn-logout{border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);background:0 0;align-items:center;gap:6px;padding:7px 14px;font-size:.85rem;transition:all .2s;display:flex}.btn-logout:hover{color:var(--red);background:#f871711a;border-color:#f8717166}.dashboard-page{background:radial-gradient(ellipse at 10% 0%, #8b5cf614 0%, transparent 50%), radial-gradient(ellipse at 90% 100%, #6366f10f 0%, transparent 50%), var(--bg-base);min-height:100vh}.dashboard-main{flex-direction:column;gap:28px;max-width:1100px;margin:0 auto;padding:32px 24px 80px;display:flex}.dash-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:16px;display:flex}.dash-header h1{color:var(--text-primary);letter-spacing:-.3px;font-size:1.75rem;font-weight:700}.dash-header p{color:var(--text-secondary);font-size:.95rem}.dash-header .btn-primary{width:auto}.stats-row{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:16px;display:grid}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);align-items:center;gap:16px;padding:20px;transition:transform .2s,box-shadow .2s;display:flex}.stat-card:hover{box-shadow:var(--shadow-card);transform:translateY(-2px)}.stat-card svg{flex-shrink:0}.stat-card.total svg{color:var(--accent-light)}.stat-card.pending svg{color:var(--yellow)}.stat-card.completed svg{color:var(--green)}.stat-card>div{flex-direction:column;gap:2px;display:flex}.stat-num{font-size:1.8rem;font-weight:700;line-height:1}.stat-label{color:var(--text-secondary);font-size:.8rem}.stat-card.progress-card{flex-direction:column;align-items:stretch;gap:10px}.progress-label{color:var(--text-secondary);justify-content:space-between;font-size:.85rem;display:flex}.progress-label strong{color:var(--accent-light)}.progress-track{background:var(--bg-hover);border-radius:99px;height:6px;overflow:hidden}.progress-fill{background:var(--accent-grad);border-radius:99px;height:100%;transition:width .5s}.filter-bar{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);flex-wrap:wrap;align-items:center;gap:12px;padding:14px 18px;display:flex}.search-wrap{flex:1;min-width:180px;position:relative}.search-icon{color:var(--text-muted);pointer-events:none;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.search-input{background:var(--bg-hover);border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text-primary);outline:none;padding:9px 36px;font-size:.875rem;transition:border-color .2s}.search-input:focus{border-color:var(--accent)}.search-input::placeholder{color:var(--text-muted)}.clear-search{color:var(--text-muted);background:0 0;border:none;align-items:center;padding:2px;display:flex;position:absolute;top:50%;right:10px;transform:translateY(-50%)}.clear-search:hover{color:var(--text-primary)}.filter-pills{gap:6px;display:flex}.pill{border:1px solid var(--border);color:var(--text-secondary);background:0 0;border-radius:99px;padding:7px 16px;font-size:.85rem;font-weight:500;transition:all .2s}.pill:hover{background:var(--bg-hover);color:var(--text-primary)}.pill.active{background:var(--accent-glow);border-color:var(--accent);color:var(--accent-light)}.sort-wrap{color:var(--text-muted);align-items:center;gap:6px;display:flex;position:relative}.sort-select{appearance:none;background:var(--bg-hover);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;outline:none;padding:8px 32px 8px 12px;font-size:.85rem;transition:border-color .2s}.sort-select:focus{border-color:var(--accent)}.select-arrow{pointer-events:none;color:var(--text-muted);position:absolute;right:8px}.task-list{flex-direction:column;gap:12px;display:flex}.task-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);align-items:flex-start;gap:14px;padding:18px 18px 18px 12px;transition:transform .2s,box-shadow .2s,opacity .25s;animation:.25s slideIn;display:flex;position:relative;overflow:hidden}@keyframes slideIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.task-card:hover{box-shadow:var(--shadow-card);transform:translateY(-2px)}.task-card.task-completed{opacity:.65}.task-card.task-overdue{border-color:#f8717159}.accent-bar{border-radius:12px 0 0 12px;width:4px;position:absolute;top:0;bottom:0;left:0}.accent-bar.priority-high{background:var(--red)}.accent-bar.priority-medium{background:var(--yellow)}.accent-bar.priority-low{background:var(--green)}.task-checkbox{border:2px solid var(--text-muted);color:#fff;background:0 0;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;margin-top:2px;transition:all .2s;display:flex}.task-checkbox:hover{border-color:var(--accent);background:var(--accent-glow)}.task-checkbox.checked{background:var(--green);border-color:var(--green)}.task-body{flex:1;min-width:0}.task-title{color:var(--text-primary);word-break:break-word;margin-bottom:4px;font-size:.975rem;font-weight:500}.task-title.line-through{color:var(--text-muted);text-decoration:line-through}.task-desc{color:var(--text-secondary);word-break:break-word;margin-bottom:10px;font-size:.85rem}.task-meta{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.badge{white-space:nowrap;border-radius:6px;align-items:center;gap:4px;padding:3px 8px;font-size:.75rem;font-weight:500;display:inline-flex}.badge.priority-high{color:var(--red);background:#f871711f;border:1px solid #f8717140}.badge.priority-medium{color:var(--yellow);background:#fbbf241f;border:1px solid #fbbf2440}.badge.priority-low{color:var(--green);background:#4ade801f;border:1px solid #4ade8040}.badge-due{color:var(--blue);background:#60a5fa1a;border:1px solid #60a5fa40}.badge-overdue{color:var(--red);background:#f871711f;border:1px solid #f8717140}.badge-done{color:var(--green);background:#4ade801f;border:1px solid #4ade8040}.badge-pending{color:var(--yellow);background:#fbbf241a;border:1px solid #fbbf2433}.task-actions{flex-shrink:0;align-items:center;gap:6px;display:flex}.icon-btn{border-radius:var(--radius-sm);border:1px solid var(--border);background:0 0;justify-content:center;align-items:center;width:34px;height:34px;transition:all .2s;display:flex}.edit-btn{color:var(--text-muted)}.edit-btn:hover{border-color:var(--accent);color:var(--accent-light);background:#8b5cf61f}.delete-btn{color:var(--text-muted)}.delete-btn:hover{color:var(--red);background:#f871711a;border-color:#f8717166}.delete-btn.loading{opacity:.5;cursor:not-allowed}.empty-state{background:var(--bg-card);border:1px dashed var(--border);border-radius:var(--radius-lg);color:var(--text-secondary);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:64px 24px;display:flex}.empty-state svg{color:var(--text-muted)}.empty-state h3{color:var(--text-primary);font-size:1.1rem;font-weight:600}.empty-state p{font-size:.9rem}.modal-overlay{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:200;background:#000000a6;justify-content:center;align-items:center;padding:24px;animation:.2s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-card{background:var(--bg-modal);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;max-width:480px;box-shadow:0 24px 80px #0009, var(--shadow-glow);animation:.25s slideUp}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}.modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:22px 24px 20px;display:flex}.modal-header h3{font-size:1.1rem;font-weight:600}.modal-close{background:var(--bg-hover);width:32px;height:32px;color:var(--text-secondary);border:none;border-radius:8px;justify-content:center;align-items:center;transition:all .2s;display:flex}.modal-close:hover{color:var(--red);background:#f871711f}.modal-form{flex-direction:column;gap:18px;padding:24px;display:flex}.form-row{grid-template-columns:1fr 1fr;gap:14px;display:grid}.modal-actions{gap:10px;margin-top:4px;display:flex}.modal-actions .btn-secondary{flex:1}.modal-actions .btn-primary{flex:2}@media (width<=768px){.auth-page{grid-template-columns:1fr}.auth-left{display:none}.auth-right{min-height:100vh;padding:32px 24px}.dash-header{flex-direction:column;align-items:flex-start}.dash-header .btn-primary{width:100%}.filter-bar{flex-direction:column;align-items:stretch}.filter-pills{overflow-x:auto}.sort-wrap{justify-content:flex-end}.form-row{grid-template-columns:1fr}.task-card{flex-wrap:wrap}.task-actions{justify-content:flex-end;width:100%}.navbar-right .user-pill span,.btn-logout span{display:none}}@media (width<=480px){.stats-row{grid-template-columns:1fr 1fr}.stat-card.progress-card{grid-column:span 2}}
