*{box-sizing:border-box;margin:0;padding:0}body{color:#1a1a2e;background:#f0f2f5;min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.loading{color:#6b7280;justify-content:center;align-items:center;height:100vh;font-size:1.2rem;display:flex}.auth-container{justify-content:center;align-items:center;min-height:100vh;padding:1rem;display:flex}.auth-card{background:#fff;border-radius:12px;width:100%;max-width:400px;padding:2.5rem;box-shadow:0 4px 24px #0000001a}.auth-card h1{text-align:center;color:#1a1a2e;margin-bottom:1.5rem}.auth-card form{flex-direction:column;gap:1rem;display:flex}.auth-card input{border:2px solid #e5e7eb;border-radius:8px;padding:.75rem 1rem;font-size:1rem;transition:border-color .2s}.auth-card input:focus{border-color:#4f46e5;outline:none}.auth-card button{color:#fff;cursor:pointer;background:#4f46e5;border:none;border-radius:8px;padding:.75rem;font-size:1rem;font-weight:600;transition:background .2s}.auth-card button:hover{background:#4338ca}.auth-card p{text-align:center;color:#6b7280;margin-top:1rem}.auth-card a{color:#4f46e5;font-weight:600;text-decoration:none}.error-msg{color:#dc2626;text-align:center;background:#fef2f2;border-radius:8px;margin-bottom:.5rem;padding:.75rem}.dashboard{max-width:800px;margin:0 auto;padding:1.5rem}header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.5rem;display:flex}.header-left h1{font-size:1.8rem}.welcome{color:#6b7280;font-size:.9rem}.header-right{gap:.5rem;display:flex}.btn-primary{color:#fff;cursor:pointer;background:#4f46e5;border:none;border-radius:8px;padding:.6rem 1.2rem;font-size:.9rem;font-weight:600;transition:background .2s}.btn-primary:hover{background:#4338ca}.btn-logout{color:#374151;cursor:pointer;background:#f3f4f6;border:none;border-radius:8px;padding:.6rem 1.2rem;font-size:.9rem}.btn-logout:hover{background:#e5e7eb}.filters{flex-wrap:wrap;gap:.5rem;margin-bottom:1.5rem;display:flex}.filter-btn{cursor:pointer;background:#fff;border:2px solid #e5e7eb;border-radius:20px;padding:.5rem 1rem;font-size:.85rem;transition:all .2s}.filter-btn.active{color:#fff;background:#4f46e5;border-color:#4f46e5}.task-form-overlay{z-index:100;background:#0006;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.task-form{background:#fff;border-radius:12px;width:100%;max-width:500px;padding:2rem;box-shadow:0 8px 32px #0003}.task-form h2{margin-bottom:1rem}.task-form input,.task-form textarea,.task-form select{border:2px solid #e5e7eb;border-radius:8px;width:100%;margin-bottom:.75rem;padding:.7rem;font-family:inherit;font-size:.95rem}.task-form input:focus,.task-form textarea:focus,.task-form select:focus{border-color:#4f46e5;outline:none}.form-row{gap:1rem;display:flex}.form-row label{color:#374151;flex:1;font-size:.9rem;font-weight:500}.form-row select{margin-top:.25rem}.form-actions{gap:.75rem;margin-top:.5rem;display:flex}.btn-cancel{color:#374151;cursor:pointer;background:#f3f4f6;border:none;border-radius:8px;padding:.6rem 1.2rem;font-size:.9rem}.task-list{flex-direction:column;gap:.75rem;display:flex}.task-card{background:#fff;border-radius:10px;padding:1.25rem;transition:box-shadow .2s;box-shadow:0 1px 4px #00000014}.task-card:hover{box-shadow:0 4px 12px #0000001f}.task-card.done{opacity:.7}.task-card.done h3{text-decoration:line-through}.task-header{justify-content:space-between;align-items:flex-start;gap:.75rem;margin-bottom:.5rem;display:flex}.task-header h3{flex:1;font-size:1.05rem}.task-badges{flex-shrink:0;gap:.4rem;display:flex}.badge{color:#fff;white-space:nowrap;border-radius:12px;padding:.2rem .6rem;font-size:.75rem;font-weight:600}.badge.status{cursor:pointer}.task-desc{color:#6b7280;margin-bottom:.75rem;font-size:.9rem;line-height:1.4}.task-actions{gap:.5rem;display:flex}.task-actions button{cursor:pointer;background:#fff;border:1px solid #e5e7eb;border-radius:6px;padding:.35rem .8rem;font-size:.8rem;transition:all .2s}.task-actions button:hover{background:#f3f4f6}.btn-delete{color:#dc2626!important;border-color:#fecaca!important}.btn-delete:hover{background:#fef2f2!important}.empty{text-align:center;color:#9ca3af;padding:3rem 1rem;font-size:1.1rem}
