*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--bg-primary: hsl(260, 35%, 6%);--bg-secondary: hsl(245, 28%, 10%);--bg-gradient: linear-gradient(160deg, var(--bg-primary), var(--bg-secondary));--surface: rgba(255, 255, 255, .04);--surface-hover: rgba(255, 255, 255, .08);--glass-bg: rgba(255, 255, 255, .06);--glass-border: rgba(255, 255, 255, .1);--glass-blur: 20px;--accent: hsl(270, 80%, 65%);--accent-light: hsl(270, 80%, 75%);--accent-glow: hsla(270, 80%, 65%, .35);--accent-surface: hsla(270, 80%, 65%, .12);--text-primary: rgba(255, 255, 255, .95);--text-secondary: rgba(255, 255, 255, .55);--text-muted: rgba(255, 255, 255, .3);--success: #22c55e;--success-surface: rgba(34, 197, 94, .12);--warning: #f59e0b;--warning-surface: rgba(245, 158, 11, .12);--danger: #ef4444;--danger-surface: rgba(239, 68, 68, .12);--cat-general: #8b8bf5;--cat-kitchen: #f59e0b;--cat-bathroom: #06b6d4;--cat-bedroom: #a78bfa;--cat-yard: #22c55e;--cat-garage: #ef4444;--cat-living_room: #f472b6;--cat-laundry: #60a5fa;--cat-shopping: #fb923c;--cat-theodore: #818cf8;--cat-eleonora: #fb7185;--radius-sm: 8px;--radius-md: 14px;--radius-lg: 20px;--radius-xl: 28px;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--ease-out: cubic-bezier(.16, 1, .3, 1);--ease-spring: cubic-bezier(.34, 1.56, .64, 1);--duration-fast: .15s;--duration-normal: .25s;--duration-slow: .4s;--safe-top: env(safe-area-inset-top, 0px);--safe-bottom: env(safe-area-inset-bottom, 0px)}html,body{height:100%;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;background:var(--bg-gradient);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden}body{min-height:100dvh}.hidden{display:none!important}.glass{background:var(--glass-bg);backdrop-filter:blur(var(--glass-blur));-webkit-backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border)}.screen{min-height:100dvh}.app-container{width:100%}.auth-container{min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:var(--spacing-lg);background:radial-gradient(ellipse at 20% 80%,hsla(270,80%,40%,.15) 0%,transparent 50%),radial-gradient(ellipse at 80% 20%,hsla(220,80%,40%,.1) 0%,transparent 50%),var(--bg-gradient)}.auth-card{width:100%;max-width:400px;border-radius:var(--radius-xl);padding:var(--spacing-xl) var(--spacing-lg);animation:slideUp .6s var(--ease-out)}.auth-header{text-align:center;margin-bottom:var(--spacing-xl)}.auth-icon{font-size:48px;margin-bottom:var(--spacing-sm);filter:drop-shadow(0 0 20px var(--accent-glow))}.auth-header h1{font-size:1.75rem;font-weight:700;background:linear-gradient(135deg,var(--text-primary),var(--accent-light));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.auth-subtitle{color:var(--text-secondary);font-size:.875rem;margin-top:var(--spacing-xs)}.form-group{margin-bottom:var(--spacing-md)}.form-group label{display:block;font-size:.8rem;font-weight:500;color:var(--text-secondary);margin-bottom:6px;text-transform:uppercase;letter-spacing:.5px}.form-group input,.form-group select{width:100%;padding:12px 16px;background:var(--surface);border:1px solid var(--glass-border);border-radius:var(--radius-md);color:var(--text-primary);font-family:inherit;font-size:1rem;transition:border-color var(--duration-fast),box-shadow var(--duration-fast);outline:none}.form-group input::placeholder{color:var(--text-muted)}.form-group input:focus,.form-group select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.form-group select{-moz-appearance:none;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='12' height='8' viewBox='0 0 12 8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1L6 6L11 1' stroke='rgba(255,255,255,0.4)' stroke-width='2' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:40px;cursor:pointer}.form-group select option{background:#1b1a2e;color:var(--text-primary)}.form-row{display:flex;gap:var(--spacing-md)}.form-half{flex:1;min-width:0}.btn-primary{width:100%;padding:14px;background:linear-gradient(135deg,var(--accent),hsl(280,70%,55%));color:#fff;border:none;border-radius:var(--radius-md);font-family:inherit;font-size:1rem;font-weight:600;cursor:pointer;transition:transform var(--duration-fast) var(--ease-spring),box-shadow var(--duration-normal);position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm)}.btn-primary:active{transform:scale(.97)}.btn-primary:hover{box-shadow:0 4px 20px var(--accent-glow)}.btn-secondary{padding:10px 20px;background:var(--surface);color:var(--text-primary);border:1px solid var(--glass-border);border-radius:var(--radius-md);font-family:inherit;font-size:.9rem;font-weight:500;cursor:pointer;transition:background var(--duration-fast)}.btn-secondary:hover{background:var(--surface-hover)}.btn-danger{padding:10px 20px;background:var(--danger);color:#fff;border:none;border-radius:var(--radius-md);font-family:inherit;font-size:.9rem;font-weight:600;cursor:pointer;transition:transform var(--duration-fast) var(--ease-spring)}.btn-danger:active{transform:scale(.97)}.btn-icon{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:8px;border-radius:var(--radius-sm);transition:color var(--duration-fast),background var(--duration-fast);display:flex;align-items:center;justify-content:center}.btn-icon:hover{color:var(--text-primary);background:var(--surface-hover)}#btn-notifications.active{color:var(--primary)}#btn-notifications.active svg{fill:currentColor}.auth-toggle{text-align:center;margin-top:var(--spacing-md);font-size:.85rem;color:var(--text-secondary)}.auth-toggle a{color:var(--accent-light);text-decoration:none;font-weight:500;margin-left:4px}.auth-toggle a:hover{text-decoration:underline}.error-text{color:var(--danger);font-size:.85rem;text-align:center;margin-top:var(--spacing-md);padding:10px;background:var(--danger-surface);border-radius:var(--radius-sm);animation:shake .4s ease}.spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}#app-screen{padding-bottom:calc(100px + var(--safe-bottom))}.top-bar{position:sticky;top:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:calc(var(--safe-top) + 12px) var(--spacing-lg) 12px;border-bottom:1px solid var(--glass-border);border-radius:0}.top-bar-left{display:flex;align-items:center;gap:var(--spacing-sm)}.top-bar-left h1{font-size:1.15rem;font-weight:700;background:linear-gradient(135deg,var(--text-primary),var(--accent-light));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.app-logo{font-size:1.4rem}.top-bar-right{display:flex;align-items:center;gap:var(--spacing-sm)}.avatar{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:700;color:#fff;text-transform:uppercase;flex-shrink:0}.avatar-sm{width:26px;height:26px;font-size:.7rem}.greeting{padding:var(--spacing-lg) var(--spacing-lg) var(--spacing-md)}.greeting h2{font-size:1.5rem;font-weight:700}.task-summary{color:var(--text-secondary);font-size:.9rem;margin-top:4px}.category-filter{display:flex;gap:var(--spacing-sm);padding:0 var(--spacing-lg) var(--spacing-md);overflow-x:auto;scrollbar-width:none;-webkit-overflow-scrolling:touch}.category-filter::-webkit-scrollbar{display:none}.category-pill{flex-shrink:0;padding:8px 16px;border-radius:100px;border:1px solid var(--glass-border);background:var(--surface);color:var(--text-secondary);font-family:inherit;font-size:.8rem;font-weight:500;cursor:pointer;transition:all var(--duration-fast) var(--ease-out);white-space:nowrap}.category-pill:hover{background:var(--surface-hover);color:var(--text-primary)}.category-pill.active{background:var(--accent-surface);border-color:var(--accent);color:var(--accent-light)}.task-list-container{padding:0 var(--spacing-lg)}.task-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.task-card{display:flex;align-items:flex-start;gap:12px;padding:14px 16px;border-radius:var(--radius-md);background:var(--glass-bg);border:1px solid var(--glass-border);animation:slideIn var(--duration-slow) var(--ease-out);transition:transform var(--duration-fast),background var(--duration-fast);position:relative}.task-card:active{transform:scale(.99);background:var(--surface-hover)}.task-checkbox{width:22px;height:22px;min-width:22px;border-radius:50%;border:2px solid var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--duration-normal) var(--ease-spring);margin-top:2px}.task-checkbox:hover{border-color:var(--accent)}.task-checkbox.checked{background:var(--success);border-color:var(--success);animation:checkBounce .4s var(--ease-spring)}.task-checkbox.checked svg{opacity:1;transform:scale(1)}.task-checkbox svg{opacity:0;transform:scale(.5);transition:all var(--duration-normal) var(--ease-spring)}.task-info{flex:1;min-width:0;cursor:pointer}.task-title{font-size:.95rem;font-weight:500;line-height:1.3;word-break:break-word;transition:color var(--duration-normal),text-decoration var(--duration-normal)}.task-card.completed .task-title{color:var(--text-muted);text-decoration:line-through}.task-meta{display:flex;align-items:center;gap:var(--spacing-sm);margin-top:6px;flex-wrap:wrap}.task-category-badge{font-size:.7rem;font-weight:600;padding:2px 8px;border-radius:100px;text-transform:uppercase;letter-spacing:.3px}.task-category-badge[data-cat=general]{background:#8b8bf526;color:var(--cat-general)}.task-category-badge[data-cat=kitchen]{background:#f59e0b26;color:var(--cat-kitchen)}.task-category-badge[data-cat=bathroom]{background:#06b6d426;color:var(--cat-bathroom)}.task-category-badge[data-cat=bedroom]{background:#a78bfa26;color:var(--cat-bedroom)}.task-category-badge[data-cat=yard]{background:#22c55e26;color:var(--cat-yard)}.task-category-badge[data-cat=garage]{background:#ef444426;color:var(--cat-garage)}.task-category-badge[data-cat=living_room]{background:#f472b626;color:var(--cat-living_room)}.task-category-badge[data-cat=laundry]{background:#60a5fa26;color:var(--cat-laundry)}.task-category-badge[data-cat=shopping]{background:#fb923c26;color:var(--cat-shopping)}.task-category-badge[data-cat=theodore]{background:#818cf826;color:var(--cat-theodore)}.task-category-badge[data-cat=eleonora]{background:#fb718526;color:var(--cat-eleonora)}.task-due{font-size:.75rem;color:var(--text-secondary);display:flex;align-items:center;gap:4px}.task-due.overdue{color:var(--danger);font-weight:600}.task-due.today{color:var(--warning);font-weight:600}.task-due.soon{color:var(--warning)}.task-right{display:flex;flex-direction:column;align-items:flex-end;gap:6px;flex-shrink:0}.task-delete{opacity:0;transition:opacity var(--duration-fast)}.task-card:hover .task-delete,.task-card:focus-within .task-delete{opacity:1}@media(hover:none){.task-delete{opacity:.6}}.completed-section{margin-top:var(--spacing-lg)}.completed-header{display:flex;align-items:center;gap:var(--spacing-sm);width:100%;padding:12px 0;background:none;border:none;color:var(--text-secondary);font-family:inherit;font-size:.85rem;font-weight:600;cursor:pointer;text-transform:uppercase;letter-spacing:.5px}.completed-badge{background:var(--surface);border-radius:100px;padding:2px 8px;font-size:.75rem}.completed-header .chevron{margin-left:auto;transition:transform var(--duration-normal) var(--ease-out)}.completed-header[aria-expanded=true] .chevron{transform:rotate(180deg)}.completed-list{display:flex;flex-direction:column;gap:var(--spacing-sm);overflow:hidden;max-height:0;opacity:0;transition:max-height var(--duration-slow) var(--ease-out),opacity var(--duration-normal) var(--ease-out)}.completed-list.expanded{max-height:2000px;opacity:1}.completed-list .task-card{opacity:.6}.empty-state{text-align:center;padding:var(--spacing-xl) var(--spacing-lg);animation:fadeIn var(--duration-slow) var(--ease-out)}.empty-icon{font-size:48px;margin-bottom:var(--spacing-md)}.empty-state h3{font-size:1.1rem;font-weight:600;margin-bottom:var(--spacing-xs)}.empty-state p{color:var(--text-secondary);font-size:.9rem}.fab{position:fixed;bottom:calc(28px + var(--safe-bottom));right:24px;width:60px;height:60px;border-radius:50%;background:linear-gradient(135deg,var(--accent),hsl(280,70%,55%));color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 24px var(--accent-glow),0 0 0 0 var(--accent-glow);transition:transform var(--duration-fast) var(--ease-spring),box-shadow var(--duration-normal);z-index:90;animation:fabEntrance .5s .3s var(--ease-spring) both}.fab:hover{transform:scale(1.08);box-shadow:0 6px 32px var(--accent-glow)}.fab:active{transform:scale(.95)}.modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;display:flex;align-items:flex-end;justify-content:center}.modal-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#0009;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);animation:fadeIn var(--duration-normal) var(--ease-out)}.modal-content{position:relative;width:100%;max-width:480px;max-height:90dvh;overflow-y:auto;border-radius:var(--radius-xl) var(--radius-xl) 0 0;padding:var(--spacing-lg);padding-bottom:calc(var(--spacing-lg) + var(--safe-bottom));animation:slideUp var(--duration-slow) var(--ease-out)}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-lg)}.modal-header h3{font-size:1.2rem;font-weight:700}.confirm-dialog-content{border-radius:var(--radius-xl);text-align:center;max-width:340px;margin:auto;animation:scaleIn var(--duration-normal) var(--ease-spring)}.confirm-dialog-content h3{font-size:1.1rem;font-weight:600;margin-bottom:var(--spacing-sm)}.confirm-task-name{color:var(--text-secondary);font-size:.9rem;margin-bottom:var(--spacing-lg)}.confirm-actions{display:flex;gap:var(--spacing-sm);justify-content:center}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes checkBounce{0%{transform:scale(1)}40%{transform:scale(1.3)}to{transform:scale(1)}}@keyframes fabEntrance{0%{opacity:0;transform:scale(0) rotate(-90deg)}to{opacity:1;transform:scale(1) rotate(0)}}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-6px)}50%{transform:translate(6px)}75%{transform:translate(-4px)}}@keyframes spin{to{transform:rotate(360deg)}}.leaderboard-card{margin:var(--spacing-md);padding:var(--spacing-md);border-radius:var(--radius-lg);border:1px solid var(--glass-border);box-shadow:0 8px 32px #0003}.leaderboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md)}.leaderboard-header h3{font-size:1.1rem;font-weight:600;letter-spacing:-.01em;color:var(--text-primary);display:flex;align-items:center;gap:var(--spacing-sm)}.leaderboard-toggle{display:flex;background:#ffffff0d;padding:3px;border-radius:var(--radius-sm);border:1px solid rgba(255,255,255,.05)}.leaderboard-toggle .toggle-btn{background:none;border:none;color:var(--text-secondary);font-family:inherit;font-size:.75rem;font-weight:500;padding:5px 10px;border-radius:5px;cursor:pointer;transition:all var(--duration-fast) var(--ease-out)}.leaderboard-toggle .toggle-btn.active{background:#ffffff1f;color:var(--text-primary);box-shadow:0 2px 8px #00000026}.leaderboard-content{display:flex;flex-direction:column;gap:var(--spacing-sm)}.leaderboard-row{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-md);padding:var(--spacing-xs) 0;animation:fadeIn var(--duration-normal) var(--ease-out)}.leaderboard-user{display:flex;align-items:center;gap:var(--spacing-sm);width:130px;flex-shrink:0}.leaderboard-avatar{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:600;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.2);border:1px solid rgba(255,255,255,.1)}.leaderboard-name{font-size:.85rem;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.leaderboard-bar-container{flex-grow:1;height:6px;background:#ffffff0d;border-radius:3px;overflow:hidden}.leaderboard-bar{height:100%;border-radius:3px;width:0;transition:width var(--duration-slow) var(--ease-spring)}.leaderboard-count{font-size:.8rem;font-weight:600;color:var(--text-secondary);width:65px;text-align:right;flex-shrink:0}.empty-leaderboard{font-size:.85rem;color:var(--text-muted);text-align:center;padding:var(--spacing-sm) 0}.task-section-header{display:flex;align-items:center;gap:var(--spacing-sm);font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);margin:var(--spacing-md) 0 var(--spacing-sm) 0;padding:0 var(--spacing-sm)}.task-section-header.margin-top{margin-top:var(--spacing-lg)}.task-section-badge{background:#ffffff14;color:var(--text-primary);font-size:.7rem;font-weight:700;padding:1px 6px;border-radius:10px;border:1px solid rgba(255,255,255,.05)}.task-section-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.btn-google{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);width:100%;padding:12px 16px;background:#fff;border:1px solid rgba(255,255,255,.2);border-radius:var(--radius-md);color:#1e1e1e;font-family:inherit;font-size:.95rem;font-weight:600;cursor:pointer;transition:transform var(--duration-fast) var(--ease-spring),background var(--duration-fast),box-shadow var(--duration-fast);box-shadow:0 4px 12px #0000001a;margin-top:var(--spacing-md)}.btn-google:hover{background:#f5f5f5;transform:translateY(-1px);box-shadow:0 6px 16px #00000026}.btn-google:active{transform:translateY(1px);box-shadow:0 2px 8px #00000014}.google-icon{flex-shrink:0}@media(min-width:600px){.modal-content{border-radius:var(--radius-xl);margin-bottom:var(--spacing-xl)}.modal{align-items:center}.confirm-dialog-content{margin:auto}}@media(min-width:768px){.app-container{max-width:640px;margin:0 auto}.greeting,.category-filter,.task-list-container{padding-left:0;padding-right:0}.leaderboard-card{margin-left:0;margin-right:0}}
