@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";@import"https://fonts.googleapis.com/css2?family=Orbitron:wght@400;700&display=swap";:root{--font-family: "Inter", sans-serif;--primary: #6366f1;--primary-hover: #4f46e5;--secondary: #ec4899;--accent: #8b5cf6;--bg-gradient-start: #f9fafb;--bg-gradient-end: #f3f4f6;--surface: #ffffff;--surface-glass: rgba(255, 255, 255, .7);--surface-glass-strong: rgba(255, 255, 255, .9);--text-main: #1f2937;--text-secondary: #4b5563;--text-muted: #9ca3af;--border: #e5e7eb;--border-glass: rgba(255, 255, 255, .6);--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-full: 9999px;--transition: all .2s ease-in-out}*{margin:0;padding:0;box-sizing:border-box}html,body{height:100%}body{font-family:var(--font-family);background-image:url(/background.png);background-size:cover;background-position:center;background-repeat:no-repeat;background-attachment:fixed;color:var(--text-main);overflow:hidden;position:relative}body:before{content:"";position:fixed;bottom:0;left:0;right:0;height:40%;background:linear-gradient(to bottom,transparent 0%,white 100%);pointer-events:none;z-index:0}#root{height:100%;display:flex;flex-direction:column;position:relative;z-index:1}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#94a3b8}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--text-muted);gap:.5rem;opacity:.7}.loading-container{height:100vh;width:100%;display:flex;align-items:center;justify-content:center;background:#f9fafb}.spinner{width:3rem;height:3rem;border:3px solid #e5e7eb;border-top-color:var(--primary);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{transform:scale(.95);opacity:0}to{transform:scale(1);opacity:1}}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.app-container{display:flex;flex-direction:column;height:100vh;overflow:hidden}.main-content{flex:1;overflow-y:auto;padding:20px}.dashboard-content{padding:0}.page-header-btn{display:flex;align-items:center;gap:8px;padding:8px 16px;border-radius:8px;background:var(--primary);color:#fff;border:none;cursor:pointer;transition:opacity .2s}.page-header-btn:hover{opacity:.9}.dashboard-layout{display:flex;height:100%}.desktop-toolbar{display:flex;flex-direction:column;justify-content:flex-start;z-index:10}.mobile-appliance-column{display:none}.columns-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;height:100%;flex:1;padding:20px}.task-column{display:flex;flex-direction:column;height:100%;background:#fff6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.6);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);overflow:hidden}.column-header{padding:1rem;border-bottom:1px solid rgba(255,255,255,.5);display:flex;align-items:center;justify-content:space-between;background:#ffffff4d}.header-title{display:flex;align-items:center;gap:.75rem;font-weight:700;color:var(--text-main);font-size:1.125rem;transition:opacity .2s ease}.header-title:hover{opacity:.8}.header-title svg:last-child{margin-left:auto;transition:transform .3s ease}.header-icon{padding:.5rem;border-radius:var(--radius-md);color:#fff;display:flex;align-items:center;justify-content:center}.task-count{background:#fff;padding:.125rem .625rem;border-radius:var(--radius-full);font-size:.875rem;font-weight:700;color:var(--text-secondary);box-shadow:var(--shadow-sm)}.column-content{flex:1;overflow-y:auto;padding:1rem;display:flex;flex-direction:column;gap:.75rem}@media(max-width:768px){.main-content,.column-content{scrollbar-width:none;-ms-overflow-style:none}.main-content{padding:16px}.main-content::-webkit-scrollbar,.column-content::-webkit-scrollbar{display:none}.mobile-column-indicators{display:flex;justify-content:center;gap:.75rem;padding:.5rem;background:transparent;min-height:24px;z-index:10}.column-dot{width:8px;height:8px;border-radius:50%;border:1px solid var(--border);background:#ffffff80;padding:0;cursor:pointer;transition:all .2s ease}.column-dot.active{background:var(--primary);border-color:var(--primary);transform:scale(1.2)}.dashboard-content{overflow:hidden;display:flex;flex-direction:column}.columns-grid{display:flex!important;flex-wrap:nowrap!important;overflow:visible!important;width:100%;height:100%;gap:1rem!important;flex:1;padding:0}.task-column{min-width:100%;max-width:100%;width:100%;flex-shrink:0}.desktop-toolbar{display:none}.mobile-appliance-column{display:flex;flex-direction:column;min-width:100%;max-width:100%;width:100%;flex-shrink:0;height:100%;justify-content:center;align-items:center}.columns-grid[data-active-column=toolbar]{transform:translate(0);transition:transform .3s ease}.columns-grid[data-active-column=todo]{transform:translate(calc(-100% - 1rem));transition:transform .3s ease}.columns-grid[data-active-column=today]{transform:translate(calc(-200% - 2rem));transition:transform .3s ease}.columns-grid[data-active-column=calendar]{transform:translate(calc(-300% - 3rem));transition:transform .3s ease}.column-header{position:sticky;top:0;z-index:5;background:#ffffff4d;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}}@media(min-width:769px){.mobile-column-indicators{display:none}}.btn{padding:.75rem 1.5rem;border-radius:var(--radius-lg);font-weight:600;font-size:.95rem;cursor:pointer;transition:var(--transition);border:none;display:inline-flex;align-items:center;justify-content:center;gap:.5rem;text-decoration:none}.btn:disabled{opacity:.7;cursor:not-allowed;transform:none}.btn-primary{background:var(--primary);color:#fff;box-shadow:var(--shadow-md)}.btn-primary:hover:not(:disabled){background:var(--primary-hover);transform:translateY(-1px);box-shadow:var(--shadow-lg)}.btn-secondary{background:transparent;color:var(--text-secondary);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){background:#0000000d;color:var(--text-main)}.btn-danger{background:#ef4444;color:#fff;box-shadow:var(--shadow-md)}.btn-danger:hover:not(:disabled){background:#dc2626;transform:translateY(-1px);box-shadow:var(--shadow-lg)}.btn-ghost{background:transparent;color:var(--text-secondary);padding:.5rem;border:none}.btn-ghost:hover:not(:disabled){background:#0000000d;color:var(--text-main)}.btn-icon{padding:.5rem;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;line-height:0;background:transparent;border:none;cursor:pointer;transition:var(--transition);color:var(--text-secondary)}.btn-icon:hover:not(:disabled){background:#0000000d;color:var(--text-main)}.btn-icon-danger{color:var(--text-muted)}.btn-icon-danger:hover:not(:disabled){color:#ef4444;background:#fef2f2}.btn-icon-small{padding:.25rem;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;line-height:0;background:transparent;border:none;cursor:pointer;transition:var(--transition);color:var(--primary)}.btn-icon-small:hover:not(:disabled){background:#6366f11a}.btn-danger-ghost{color:#ef4444;background:transparent;border:none;cursor:pointer;padding:.5rem;border-radius:var(--radius-md);transition:var(--transition)}.btn-danger-ghost:hover:not(:disabled){background:#fef2f2}.btn-dashed{width:100%;padding:.75rem;border:1px dashed var(--border);border-radius:var(--radius-md);background:transparent;color:var(--text-secondary);font-size:.9rem;font-weight:500;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.5rem;transition:var(--transition)}.btn-dashed:hover:not(:disabled){border-color:var(--primary);color:var(--primary);background:#6366f10d}.toggle-btn{flex-shrink:0;width:24px;height:24px;border-radius:50%;border:2px solid #d1d5db;background:transparent;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;padding:0;transition:all .2s}.toggle-btn.active{border-color:#10b981;background:#10b981}.action-btn{border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;line-height:0;background:transparent;border:none;cursor:pointer;transition:var(--transition);color:var(--text-secondary)}.action-btn:hover{background:#0000000d;color:var(--text-main)}.action-btn.delete{color:var(--text-muted)}.action-btn.delete:hover{color:#ef4444;background:#fef2f2}.form-group{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}.form-label{font-size:.875rem;font-weight:600;color:var(--text-secondary);display:flex;align-items:center;gap:.5rem}.form-input,.form-textarea,.form-select{width:100%;padding:.75rem;border-radius:var(--radius-md);border:1px solid var(--border);background:#ffffff80;font-family:var(--font-family);font-size:1rem;color:var(--text-main);transition:var(--transition)}.form-input:focus,.form-textarea:focus,.form-select:focus{outline:none;border-color:var(--primary);background:#fff;box-shadow:0 0 0 3px #6366f11a}.form-textarea{resize:vertical;min-height:80px}.checkbox-label{display:flex;align-items:center;gap:.75rem;cursor:pointer;-webkit-user-select:none;user-select:none}.form-checkbox{width:1.25rem;height:1.25rem;border-radius:var(--radius-sm);border:2px solid var(--border);cursor:pointer;transition:var(--transition);accent-color:var(--primary)}.form-checkbox:hover{border-color:var(--primary)}.form-checkbox:checked{background:var(--primary);border-color:var(--primary)}.card{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--border);padding:1rem;transition:var(--transition);display:flex;flex-direction:column}.card:hover{box-shadow:var(--shadow-md)}.card.completed{opacity:.7;background:#fff}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;gap:1rem}.card-title{flex:1;margin:0;font-size:1.1rem;font-weight:600;color:inherit}.card.completed .card-title{text-decoration:line-through}.card-actions{display:flex;gap:8px}.card-content{flex:1;display:flex;flex-direction:column}.card-footer{display:flex;justify-content:space-between;align-items:center;margin-top:16px;padding-top:12px;border-top:1px solid #f3f4f6;font-size:.85rem;color:#9ca3af}.navbar{height:4rem;padding:0 1.5rem;display:flex;align-items:center;justify-content:space-between;background:var(--surface-glass);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border-glass);box-shadow:var(--shadow-sm);z-index:50}.navbar-brand{display:flex;align-items:center;gap:.75rem}.brand-logo{width:3rem;height:3rem;object-fit:contain}.brand-text{height:2.5rem;width:auto;object-fit:contain}.navbar-users{display:flex;align-items:center}.user-avatar{width:3rem;height:3rem;border-radius:var(--radius-full);border:2px solid white;margin-left:-.5rem;position:relative;cursor:pointer;transition:var(--transition);overflow:hidden;display:flex;align-items:center;justify-content:center;color:#fff;font-size:.875rem;font-weight:600;box-shadow:var(--shadow-sm);-webkit-user-select:none;user-select:none}.user-avatar:hover{transform:scale(1.1);z-index:10}.user-avatar.filtered-out{opacity:.4;filter:grayscale(70%)}.user-avatar.filtered-out:hover{opacity:.6;filter:grayscale(50%)}.user-avatar.selected{border-color:var(--primary);box-shadow:0 0 0 2px var(--primary)}.user-avatar img{width:100%;height:100%;object-fit:cover}.add-user-btn{width:2.5rem;height:2.5rem;border-radius:var(--radius-full);border:2px dashed #cbd5e1;margin-left:-.5rem;display:flex;align-items:center;justify-content:center;background:#ffffff80;color:#94a3b8;cursor:pointer;transition:var(--transition)}.add-user-btn:hover{border-color:var(--primary);color:var(--primary);background:#fff}.navbar-actions{display:flex;align-items:center;gap:1rem}.icon-btn{padding:.5rem;border-radius:var(--radius-full);color:var(--text-secondary);border:none;background:transparent;cursor:pointer;transition:var(--transition);display:flex;align-items:center;justify-content:center;position:relative}.icon-btn:hover{background:#0000000d;color:var(--primary)}.notification-dot{position:absolute;top:6px;right:6px;width:8px;height:8px;background-color:#ef4444;border-radius:50%;border:1px solid white}.divider{height:2rem;width:1px;background-color:var(--border)}@media(max-width:768px){.brand-text{display:none!important}.navbar-brand{min-width:auto}.navbar-users{flex:1;justify-content:center}}.dropdown-menu{position:absolute;top:100%;right:0;margin-top:.5rem;min-width:16rem;background:var(--surface-glass-strong);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid var(--border-glass);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:.5rem;z-index:100;animation:fadeIn .2s ease-out}.dropdown-item{width:100%;text-align:left;padding:.75rem 1rem;border-radius:var(--radius-md);border:none;background:transparent;color:var(--text-main);font-size:.875rem;font-weight:500;cursor:pointer;transition:var(--transition);display:flex;align-items:center;gap:.75rem;text-decoration:none}.dropdown-item:hover{background:#6366f11a;color:var(--primary)}.dropdown-item svg{flex-shrink:0;opacity:.7;transition:var(--transition)}.dropdown-item:hover svg{opacity:1}.dropdown-divider{height:1px;background:var(--border);margin:.5rem 0}.dropdown-item.danger{color:#ef4444}.dropdown-item.danger:hover{background:#ef44441a}.task-card{background:#fff;border-radius:var(--radius-lg);padding:.75rem;box-shadow:var(--shadow-sm);position:relative;overflow:hidden;transition:var(--transition);cursor:pointer;-webkit-user-select:none;user-select:none;touch-action:manipulation;flex-shrink:0;-webkit-tap-highlight-color:transparent}.task-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--primary)}.card-status-line{position:absolute;left:0;top:0;bottom:0;width:4px;background-color:var(--primary)}.card-status-line.completed{background-color:#10b981}.card-title{font-weight:600;color:var(--text-main);font-size:.95rem;padding-right:3rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.card-title.completed{text-decoration:line-through;color:var(--text-muted)}.card-content-row{display:flex;align-items:center;justify-content:space-between;gap:.5rem;margin-bottom:.5rem;min-height:2.5rem}.card-desc{font-size:.8rem;color:var(--text-secondary);display:-webkit-box;line-clamp:2;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;margin-bottom:0;flex:1;padding-left:.5rem}.card-desc-placeholder{flex:1}.card-assignees{display:flex;align-items:center;flex-shrink:0;margin-left:auto}.time-tag{background:var(--primary);color:#fff;font-size:.7rem;font-weight:700;padding:.25rem .5rem;box-shadow:var(--shadow-sm);display:flex;align-items:center;justify-content:center;border-top-right-radius:var(--radius-lg);border-bottom-left-radius:var(--radius-md);border-top-left-radius:0;border-bottom-right-radius:0}.view-btn{background:none;border:none;color:var(--text-muted);cursor:pointer;transition:var(--transition);padding:.25rem;border-radius:var(--radius-md);opacity:0;transform:translate(10px)}.task-card:hover .view-btn{opacity:1;transform:translate(0)}.view-btn:hover{color:var(--primary);background:#6366f11a}@media(max-width:768px){.view-btn{display:none}}.progress-bar-container{margin-top:.5rem;height:3px;width:100%;background:#f3f4f6;border-radius:var(--radius-full);overflow:hidden;padding-left:.5rem}.progress-bar{height:100%;background:var(--primary);transition:width .5s ease-out}.mini-avatar-draggable{width:2.5rem;height:2.5rem;border-radius:50%;border:2px solid white;margin-left:-.5rem;background:#e2e8f0;display:flex;align-items:center;justify-content:center;font-size:.875rem;color:var(--text-secondary);overflow:hidden;cursor:grab;transition:transform .2s ease;position:relative;z-index:1;box-shadow:var(--shadow-sm)}.mini-avatar-draggable:hover{transform:scale(1.15);z-index:10}.mini-avatar-draggable img{width:100%;height:100%;object-fit:cover}.time-tag{font-family:Orbitron,sans-serif;letter-spacing:1px}.time-overdue-warning{background-color:#f97316!important;color:#fff}.time-overdue-critical{background-color:#ef4444!important;color:#fff;animation:flash 1s infinite}.time-completed{background-color:#10b981!important;color:#fff}@keyframes flash{0%,to{opacity:1}50%{opacity:.5}}.task-card-dragging{opacity:0}.task-card-over{border-color:var(--primary);background-color:#6366f10d}.dragging-item{cursor:grabbing}.calendar-wrapper{background:#fff;border-radius:var(--radius-lg);padding:1rem;box-shadow:var(--shadow-sm);border:1px solid var(--border);margin-bottom:1rem}.react-calendar{width:100%!important;border:none!important;background:transparent!important;font-family:var(--font-family)!important}.react-calendar__navigation{margin-bottom:1rem!important}.react-calendar__navigation button{min-width:2.5rem;background:none;font-size:1rem;border-radius:var(--radius-md);margin:0 2px}.react-calendar__navigation button:enabled:hover,.react-calendar__navigation button:enabled:focus{background-color:#f3f4f6}.react-calendar__month-view__weekdays{text-transform:uppercase;font-weight:600;font-size:.75rem;color:var(--text-muted);text-decoration:none!important}.react-calendar__month-view__weekdays__weekday{text-align:center}.react-calendar__month-view__days__day{font-size:.9rem;padding:.5rem!important;border-radius:var(--radius-md);border:1px solid #e5e7eb!important;position:relative}.react-calendar__tile:enabled:hover,.react-calendar__tile:enabled:focus{background-color:#e0e7ff!important;color:var(--primary)}.react-calendar__tile--now{background:#fef3c7!important;color:#d97706!important;font-weight:700;border-color:#f59e0b!important}.react-calendar__tile--active{background:var(--primary)!important;color:#fff!important;border-color:var(--primary)!important}.react-calendar__month-view__days__day--weekend{color:inherit;font-weight:600}.react-calendar__month-view__days__day--neighboringMonth{opacity:.3}.react-calendar__tile.past-day{background-color:#f9fafb!important;color:#9ca3af!important}.react-calendar__tile.has-tasks:after{content:"";position:absolute;bottom:4px;left:50%;transform:translate(-50%);width:6px;height:6px;background-color:var(--primary);border-radius:50%}.react-calendar__tile--active.has-tasks:after{background-color:#fff}.react-calendar__tile.has-events:before{content:"";position:absolute;bottom:4px;width:6px;height:6px;background-color:#10b981;border-radius:50%;left:50%;transform:translate(-50%)}.react-calendar__tile.has-tasks.has-events:after{left:40%}.react-calendar__tile.has-tasks.has-events:before{left:60%}.react-calendar__tile--active.has-events:before{background-color:#d1fae5}.calendar-tabs{display:flex;gap:.25rem;margin-bottom:1rem;background:#f3f4f6;padding:.25rem;border-radius:var(--radius-md)}.calendar-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.5rem;border:none;background:transparent;border-radius:var(--radius-sm);font-size:.875rem;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all .2s}.calendar-tab:hover{background:#ffffff80}.calendar-tab.active{background:#fff;color:var(--primary);box-shadow:var(--shadow-sm)}.events-list{display:flex;flex-direction:column;gap:.75rem}.event-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius-md);padding:.75rem;display:flex;gap:.75rem;align-items:flex-start;transition:transform .2s,box-shadow .2s}.event-card:hover{transform:translateY(-1px);box-shadow:var(--shadow-sm)}.event-time{font-size:.875rem;font-weight:600;color:var(--primary);min-width:3rem;padding-top:.1rem;display:flex;flex-direction:column;align-items:center;gap:.125rem}.event-details{flex:1}.event-title{font-weight:500;color:var(--text-primary);margin-bottom:.25rem;font-size:.95rem}.event-description{font-size:.8rem;color:var(--text-secondary);margin-top:.25rem;line-height:1.4}.event-location{font-size:.7rem;color:var(--text-muted);display:flex;align-items:center;justify-content:flex-end;gap:.25rem;margin-top:.25rem;font-style:italic}.event-edit-btn{background:transparent;border:none;color:var(--text-muted);cursor:pointer;padding:.5rem;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;transition:var(--transition);margin-left:auto}.event-edit-btn:hover{color:var(--primary);background:#6366f11a}.calendar-list-content{display:flex;flex-direction:column;gap:.75rem}.event-time.all-day{align-self:center;padding-top:0}.event-date{font-size:.75rem;color:var(--text-muted);margin-bottom:.25rem;text-transform:capitalize;font-weight:500}.event-date-separator{font-size:.875rem;font-weight:600;color:var(--text-primary);text-transform:capitalize;padding:.75rem .5rem .5rem;margin-top:.5rem;border-bottom:2px solid var(--border);top:0;background:var(--bg-secondary);z-index:1}.event-date-separator:first-child{margin-top:0}.modal-overlay{position:fixed;inset:0;background:#0006;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease-out}.modal-container{background:#fff;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-radius:var(--radius-xl);width:90%;max-width:500px;box-shadow:var(--shadow-lg);border:1px solid var(--border-glass);display:flex;flex-direction:column;max-height:90vh;animation:scaleIn .2s ease-out}.modal-header{padding:1.5rem;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.modal-title{font-size:1.25rem;font-weight:700;color:var(--text-main)}.close-btn{background:transparent;border:none;color:var(--text-secondary);cursor:pointer;padding:.25rem;border-radius:var(--radius-full);transition:var(--transition);display:flex;align-items:center;justify-content:center}.close-btn:hover{background:#0000000d;color:var(--text-main)}.modal-form{padding:1.5rem;overflow-y:auto;display:flex;flex-direction:column;gap:1.25rem}.form-row{display:flex;gap:1rem}.users-selection{display:flex;flex-wrap:wrap;gap:.75rem}.user-select-btn{width:3rem;height:3rem;border-radius:50%;border:2px solid transparent;padding:0;cursor:pointer;position:relative;transition:var(--transition);overflow:visible}.user-select-btn img{width:100%;height:100%;border-radius:50%;object-fit:cover;border:2px solid white}.user-select-btn .user-initial{width:100%;height:100%;border-radius:50%;background:#e2e8f0;display:flex;align-items:center;justify-content:center;font-weight:600;color:var(--text-secondary);border:2px solid white}.user-select-btn.selected{transform:scale(1.1);border-color:var(--primary)}.user-select-btn.selected img,.user-select-btn.selected .user-initial{border-color:var(--primary)}.selected-badge{position:absolute;bottom:-2px;right:-2px;background:var(--primary);color:#fff;width:1.25rem;height:1.25rem;border-radius:50%;display:flex;align-items:center;justify-content:center;border:2px solid white}.modal-footer{display:flex;justify-content:flex-end;gap:1rem;padding:1.5rem}.task-detail-modal{max-width:600px}.detail-header-actions{display:flex;align-items:center;gap:1rem}.status-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:var(--radius-full);border:1px solid var(--border);background:#fff;color:var(--text-secondary);font-weight:600;font-size:.875rem;cursor:pointer;transition:var(--transition)}.status-btn:hover{border-color:var(--primary);color:var(--primary)}.status-btn.completed{background:#ecfdf5;border-color:#10b981;color:#10b981}.modal-content{padding:0 1.5rem 1.5rem;overflow-y:auto;display:flex;flex-direction:column;gap:1.5rem}.detail-title{font-size:1.5rem;font-weight:700;color:var(--text-main);line-height:1.3}.detail-title.completed{text-decoration:line-through;color:var(--text-muted)}.detail-section{display:flex;flex-direction:column;gap:.5rem}.section-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);font-weight:600}.detail-description{color:var(--text-secondary);line-height:1.6;white-space:pre-wrap}.detail-meta-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;background:#ffffff80;padding:1rem;border-radius:var(--radius-lg);border:1px solid var(--border-glass)}.detail-meta-item{display:flex;align-items:center;gap:.75rem}.meta-icon{color:var(--primary);padding:.5rem;background:#fff;border-radius:var(--radius-md);box-shadow:var(--shadow-sm);width:2.25rem;height:2.25rem}.meta-label{font-size:.75rem;color:var(--text-muted);display:block}.meta-value{font-weight:600;color:var(--text-main)}.capitalize{text-transform:capitalize}.detail-assignees{display:flex;flex-wrap:wrap;gap:1rem}.detail-assignee{display:flex;align-items:center;gap:.5rem;background:#fff;padding:.25rem .75rem .25rem .25rem;border-radius:var(--radius-full);border:1px solid var(--border);font-weight:500;font-size:.875rem}.detail-footer{justify-content:space-between;padding:1.5rem;border-top:1px solid var(--border);margin-top:auto}@media(max-width:768px){.modal-container{width:100%;height:100%;max-height:100%;border-radius:0}.task-detail-modal{height:100%;max-height:100%;border-radius:0}}.steps-list{display:flex;flex-direction:column;gap:.5rem}.step-input-row{display:flex;align-items:center;gap:.5rem}.detail-steps{display:flex;flex-direction:column;gap:.75rem;background:#ffffff80;padding:1rem;border-radius:var(--radius-lg);border:1px solid var(--border-glass)}.detail-step-item{display:flex;align-items:center;gap:.75rem;color:var(--text-main)}.step-icon{color:var(--text-muted);flex-shrink:0}.step-icon.completed{color:var(--primary)}.step-toggle-btn{background:transparent;border:none;color:var(--text-muted);cursor:pointer;padding:0;display:flex;align-items:center;justify-content:center;transition:var(--transition)}.step-toggle-btn:hover{color:var(--primary);transform:scale(1.1)}.step-toggle-btn.completed{color:var(--primary)}.completed-text{text-decoration:line-through;color:var(--text-muted)}.confirm-modal{max-width:400px}.confirm-modal .modal-header{justify-content:center;position:relative;border-bottom:none;padding-bottom:0}.confirm-icon{width:64px;height:64px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto}.confirm-icon-warning{background:#fef3c7;color:#f59e0b}.confirm-icon-danger{background:#fee2e2;color:#ef4444}.confirm-icon-info{background:#dbeafe;color:#3b82f6}.confirm-modal .close-btn{position:absolute;top:1rem;right:1rem}.confirm-content{text-align:center;padding:1.5rem}.confirm-title{font-size:1.25rem;font-weight:700;color:var(--text-main);margin:0 0 .75rem}.confirm-message{font-size:.95rem;color:var(--text-secondary);margin:0;line-height:1.5}.confirm-modal .modal-footer{justify-content:center}.fab-btn{position:fixed;bottom:2rem;right:2rem;width:3.5rem;height:3.5rem;border-radius:50%;background:var(--primary);color:#fff;border:none;box-shadow:var(--shadow-lg);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:var(--transition);z-index:900}.fab-btn:hover{transform:scale(1.1) rotate(90deg);background:var(--primary-hover)}.fab-btn-secondary{bottom:6.5rem;background:#10b981}.fab-btn-secondary:hover{background:#059669;transform:scale(1.1)}@media(max-width:768px){.fab-btn{bottom:1.5rem;right:1.5rem;width:3rem;height:3rem}.fab-btn-secondary{bottom:5.5rem}}.suggestions-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.suggestions-title{font-size:1.5rem;font-weight:700;color:inherit;background:none;-webkit-background-clip:border-box;background-clip:border-box;-webkit-text-fill-color:currentcolor}.suggestions-list{display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.suggestion-card{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--border);padding:1rem;transition:var(--transition);display:flex;flex-direction:column}.suggestion-card:hover{box-shadow:var(--shadow-md)}.suggestion-card.completed{opacity:.7;background:#fff}.suggestion-header{display:flex;flex:1}.suggestion-card.completed .suggestion-title{text-decoration:line-through;color:#6b7280}.suggestion-description{margin:0;font-size:.9rem;color:#6b7280;line-height:1.4;display:-webkit-box;line-clamp:2;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.delete-btn{background:transparent;border:none;cursor:pointer;padding:.5rem;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;transition:var(--transition);color:#ef4444;margin-left:8px;opacity:1}.delete-btn:hover{background:#fef2f2}.suggestion-footer{display:flex;justify-content:space-between;align-items:center;margin-top:16px;padding-top:12px;border-top:1px solid #f3f4f6;font-size:.85rem;color:#9ca3af}.suggestion-author{display:flex;align-items:center;gap:8px}.suggestion-author span{font-weight:500;color:#4b5563}.author-avatar-container{width:24px;height:24px}.author-selection{display:flex;gap:12px;flex-wrap:wrap}.author-option{width:40px;height:40px;cursor:pointer;border-radius:50%;border:2px solid transparent;padding:2px;transition:all .2s}.author-option.selected{border-color:var(--primary)}@media(max-width:768px){.suggestions-header{flex-wrap:wrap;gap:12px}.suggestions-title{font-size:1.25rem}.page-header-btn span{display:none}.page-header-btn{padding:10px;min-width:44px;justify-content:center}.suggestion-card{padding:12px}}.users-page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.users-page-title{font-size:1.5rem;font-weight:700;margin:0}.users-sections{display:flex;flex-direction:column;gap:32px}.user-section{border-radius:12px;padding:8px;transition:background-color .2s}.user-section.droppable{background-color:#00000005}.user-section-title{font-size:1.2rem;font-weight:600;margin-bottom:16px;color:#374151;border-bottom:1px solid #e5e7eb;padding-bottom:8px}.users-list{display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}.user-card{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--border);padding:1rem;transition:var(--transition);display:flex;flex-direction:column}.user-card:hover{box-shadow:var(--shadow-md)}.user-card.draggable{cursor:grab}.user-card.draggable:active{cursor:grabbing}.user-card:not(.draggable){cursor:default}.user-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px}.user-info{display:flex;align-items:center;gap:12px;flex:1}.user-avatar-wrapper{width:48px;height:48px;flex-shrink:0}.empty-section-msg{color:#9ca3af;font-style:italic;grid-column:1 / -1}.image-preview-container{position:relative;display:inline-block}.image-preview{width:120px;height:120px;border-radius:50%;object-fit:cover;border:2px solid #e5e7eb}.remove-image-btn{position:absolute;top:-8px;right:-8px;background:#ef4444;color:#fff;border:none;border-radius:50%;width:28px;height:28px;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 2px 4px #0003}.upload-label{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;border-radius:8px;border:2px dashed #cbd5e1;cursor:pointer;background:#f9fafb;transition:all .2s}.upload-label:hover{border-color:var(--primary);background:#f0f9ff}.file-info{font-size:.85rem;color:#6b7280;margin-top:8px}@media(max-width:768px){.users-page-header{flex-wrap:wrap;gap:12px}.users-page-title{font-size:1.25rem}.page-header-btn span{display:none}.page-header-btn{padding:10px;min-width:44px;justify-content:center}.users-list{grid-template-columns:1fr}.user-card{padding:12px}}.recurring-tasks-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.recurring-tasks-title{font-size:1.5rem;font-weight:700;margin:0}.recurring-tasks-list{display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.recurring-task-card{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--border);padding:1rem;transition:var(--transition);cursor:default;display:flex;flex-direction:column;gap:12px}.recurring-task-card:hover{box-shadow:var(--shadow-md)}.recurring-task-header{display:flex;justify-content:space-between;align-items:flex-start}.recurring-task-title{margin:0;font-size:1.1rem;font-weight:600}.recurring-task-actions{display:flex;gap:8px}.recurring-task-description{color:#6b7280;font-size:.9rem;line-height:1.4;margin:0}.recurring-task-meta{display:flex;flex-direction:column;gap:8px;font-size:.9rem;color:#4b5563;flex:1}.meta-item{display:flex;align-items:center;gap:8px}.recurring-task-assignees{margin-top:4px;display:flex;gap:4px}.interval-group{display:flex;gap:10px}.interval-input{width:80px}.interval-unit-select{flex:1}@media(max-width:768px){.recurring-tasks-header{flex-wrap:wrap;gap:12px}.recurring-tasks-title{font-size:1.25rem}.page-header-btn span{display:none}.page-header-btn{padding:10px;min-width:44px;justify-content:center}.recurring-tasks-list{grid-template-columns:1fr}.recurring-task-card{padding:12px}}.shopping-list-page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.shopping-list-title{font-size:1.5rem;font-weight:700;margin:0}.shopping-list-container{background:#fff;border-radius:12px;padding:24px;box-shadow:0 1px 3px #0000001a}.list-header{margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid #f3f4f6}.list-header h2{margin:0;font-size:1.1rem;font-weight:600;color:#374151}.add-item-form{margin-bottom:20px;display:flex;gap:12px}.add-item-input{flex:1;padding:10px 14px;border-radius:8px;border:1px solid #e5e7eb;font-size:1rem;font-family:inherit;transition:border-color .2s}.add-item-input:focus{outline:none;border-color:var(--primary)}.add-item-btn{padding:10px 14px;border-radius:8px;border:none;background:var(--primary);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:opacity .2s}.add-item-btn:hover:not(:disabled){opacity:.9}.add-item-btn:disabled{opacity:.5;cursor:not-allowed}.items-list{display:flex;flex-direction:column;gap:8px}.shopping-item{display:flex;align-items:center;gap:12px;padding:12px;background:#f9fafb;border-radius:8px;border:1px solid #f3f4f6;transition:all .2s}.shopping-item:hover{background:#f3f4f6}.shopping-item.purchased{background:#f9fafb;opacity:.6}.check-btn{flex-shrink:0;width:24px;height:24px;border-radius:50%;border:2px solid #d1d5db;background:transparent;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;padding:0}.check-btn:hover{border-color:#10b981}.check-btn.checked{background:#10b981;border-color:#10b981}.item-name{flex:1;color:#1f2937;font-size:1rem}.item-name.purchased{text-decoration:line-through;color:#9ca3af}.delete-item-btn{padding:4px;background:none;border:none;color:#ef4444;cursor:pointer;opacity:.7;transition:opacity .2s}.delete-item-btn:hover{opacity:1}.empty-list-msg{text-align:center;padding:40px 20px;color:#9ca3af;font-style:italic}.create-list-btn{display:inline-flex;align-items:center;gap:8px;padding:12px 24px;border-radius:8px;border:none;background:var(--primary);color:#fff;font-size:1rem;font-weight:500;cursor:pointer;transition:opacity .2s}.create-list-btn:hover:not(:disabled){opacity:.9}.create-list-btn:disabled{opacity:.5;cursor:not-allowed}@media(max-width:768px){.shopping-list-page-header{flex-wrap:wrap;gap:12px}.shopping-list-title{font-size:1.25rem}.page-header-btn span{display:none}.page-header-btn{padding:10px;min-width:44px;justify-content:center}.shopping-list-container{padding:16px}.list-header h2{font-size:1rem}.shopping-item{padding:10px}}.birthday-modal{background:linear-gradient(135deg,#fff,#fff5f5);border:2px solid #ffd700;max-width:400px;width:calc(100% - 2rem);margin:0 1rem;text-align:center;overflow:hidden;position:relative;box-shadow:0 10px 25px -5px #0000001a,0 8px 10px -6px #0000001a;border-radius:1rem}.firework{position:absolute;width:4px;height:4px;border-radius:50%;pointer-events:none;z-index:0}.firework:before,.firework:after{content:"";position:absolute;width:4px;height:4px;border-radius:50%}.firework-1{top:25%;left:20%;animation:explode 2s ease-out infinite}.firework-2{top:40%;left:70%;animation:explode 2s ease-out infinite;animation-delay:.5s}.firework-3{top:65%;left:30%;animation:explode 2s ease-out infinite;animation-delay:1s}.firework-4{top:50%;left:80%;animation:explode 2s ease-out infinite;animation-delay:1.5s}.modal-close{position:absolute;top:1rem;right:1rem;background:#fff;border:1px solid #e5e7eb;border-radius:50%;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#6b7280;transition:all .2s;z-index:10}.modal-close:hover{background:#f3f4f6;color:#1f2937;transform:rotate(90deg)}.birthday-content{padding:2.5rem 1.5rem;display:flex;flex-direction:column;align-items:center;gap:1.5rem;position:relative;z-index:1}.birthday-icon-container{background:#fff0f0;padding:1.5rem;border-radius:50%;color:#ff6b6b;margin-bottom:.5rem;animation:bounce 2s infinite;box-shadow:0 4px 6px -1px #ff6b6b33}.birthday-title{font-size:2rem;font-weight:800;background:linear-gradient(45deg,#ff6b6b,#ffd93d);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent;margin:0;line-height:1.2}.birthday-names{display:flex;flex-direction:column;gap:.5rem;font-size:1.5rem;font-weight:600;color:#4a4a4a}.birthday-message{color:#6b7280;font-size:1.1rem}.birthday-btn{background:linear-gradient(45deg,#ff6b6b,#ff8787)!important;border:none!important;padding:.75rem 2.5rem;font-size:1.1rem;border-radius:2rem;margin-top:1rem;transition:all .2s;color:#fff!important;font-weight:600;box-shadow:0 4px 6px -1px #ff6b6b4d;cursor:pointer}.birthday-btn:hover{transform:scale(1.05)!important;background:linear-gradient(45deg,#ff8787,#ffa3a3)!important;box-shadow:0 6px 12px -1px #ff6b6b80!important}@keyframes explode{0%{box-shadow:0 0 #ff6b6b,0 0 #ff6b6b,0 0 #ff6b6b,0 0 #ff6b6b,0 0 #ffd93d,0 0 #ffd93d,0 0 #6366f1,0 0 #ec4899;opacity:0}10%{opacity:1}20%{box-shadow:20px 0 0 2px #ff6b6b,-20px 0 0 2px #ff6b6b,0 20px 0 2px #ff6b6b,0 -20px 0 2px #ff6b6b,14px 14px 0 2px #ffd93d,-14px -14px 0 2px #ffd93d,14px -14px 0 2px #6366f1,-14px 14px 0 2px #ec4899;opacity:1}40%{box-shadow:40px 0 0 1px #ff6b6b,-40px 0 0 1px #ff6b6b,0 40px 0 1px #ff6b6b,0 -40px 0 1px #ff6b6b,28px 28px 0 1px #ffd93d,-28px -28px 0 1px #ffd93d,28px -28px 0 1px #6366f1,-28px 28px 0 1px #ec4899;opacity:.8}60%{box-shadow:50px 0 #ff6b6b,-50px 0 #ff6b6b,0 50px #ff6b6b,0 -50px #ff6b6b,35px 35px #ffd93d,-35px -35px #ffd93d,35px -35px #6366f1,-35px 35px #ec4899;opacity:.4}to{box-shadow:55px 0 0 0 transparent,-55px 0 0 0 transparent,0 55px 0 0 transparent,0 -55px 0 0 transparent,39px 39px 0 0 transparent,-39px -39px 0 0 transparent,39px -39px 0 0 transparent,-39px 39px 0 0 transparent;opacity:0}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}.react-calendar{width:350px;max-width:100%;background:#fff;border:1px solid #a0a096;font-family:Arial,Helvetica,sans-serif;line-height:1.125em}.react-calendar--doubleView{width:700px}.react-calendar--doubleView .react-calendar__viewContainer{display:flex;margin:-.5em}.react-calendar--doubleView .react-calendar__viewContainer>*{width:50%;margin:.5em}.react-calendar,.react-calendar *,.react-calendar *:before,.react-calendar *:after{-moz-box-sizing:border-box;-webkit-box-sizing:border-box;box-sizing:border-box}.react-calendar button{margin:0;border:0;outline:none}.react-calendar button:enabled:hover{cursor:pointer}.react-calendar__navigation{display:flex;height:44px;margin-bottom:1em}.react-calendar__navigation button{min-width:44px;background:none}.react-calendar__navigation button:disabled{background-color:#f0f0f0}.react-calendar__navigation button:enabled:hover,.react-calendar__navigation button:enabled:focus{background-color:#e6e6e6}.react-calendar__month-view__weekdays{text-align:center;text-transform:uppercase;font:inherit;font-size:.75em;font-weight:700}.react-calendar__month-view__weekdays__weekday{padding:.5em}.react-calendar__month-view__weekNumbers .react-calendar__tile{display:flex;align-items:center;justify-content:center;font:inherit;font-size:.75em;font-weight:700}.react-calendar__month-view__days__day--weekend{color:#d10000}.react-calendar__month-view__days__day--neighboringMonth,.react-calendar__decade-view__years__year--neighboringDecade,.react-calendar__century-view__decades__decade--neighboringCentury{color:#757575}.react-calendar__year-view .react-calendar__tile,.react-calendar__decade-view .react-calendar__tile,.react-calendar__century-view .react-calendar__tile{padding:2em .5em}.react-calendar__tile{max-width:100%;padding:10px 6.6667px;background:none;text-align:center;font:inherit;font-size:.833em}.react-calendar__tile:disabled{background-color:#f0f0f0;color:#ababab}.react-calendar__month-view__days__day--neighboringMonth:disabled,.react-calendar__decade-view__years__year--neighboringDecade:disabled,.react-calendar__century-view__decades__decade--neighboringCentury:disabled{color:#cdcdcd}.react-calendar__tile:enabled:hover,.react-calendar__tile:enabled:focus{background-color:#e6e6e6}.react-calendar__tile--now{background:#ffff76}.react-calendar__tile--now:enabled:hover,.react-calendar__tile--now:enabled:focus{background:#ffffa9}.react-calendar__tile--hasActive{background:#76baff}.react-calendar__tile--hasActive:enabled:hover,.react-calendar__tile--hasActive:enabled:focus{background:#a9d4ff}.react-calendar__tile--active{background:#006edc;color:#fff}.react-calendar__tile--active:enabled:hover,.react-calendar__tile--active:enabled:focus{background:#1087ff}.react-calendar--selectRange .react-calendar__tile--hover{background-color:#e6e6e6}.appliance-toolbar{display:flex;flex-direction:column;align-items:center;padding:1rem .5rem;background:#fff6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.6);border-left:none;border-radius:0 var(--radius-xl) var(--radius-xl) 0;box-shadow:var(--shadow-sm);width:70px;height:100%;min-height:200px}.appliance-buttons{display:flex;flex-direction:column;gap:1rem;width:100%}.appliance-button{width:50px;height:50px;border-radius:50%;border:none;background:#fff;color:var(--text-primary);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 8px #0000001a;position:relative;overflow:hidden}.appliance-button:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,transparent 0%,rgba(99,102,241,.1) 100%);opacity:0;transition:opacity .3s ease}.appliance-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.appliance-button:hover:before{opacity:1}.appliance-button:active{transform:translateY(0);box-shadow:0 2px 6px #0000001a}.appliance-washer{color:#3b82f6}.appliance-washer:hover{background:linear-gradient(135deg,#fff,#dbeafe)}.appliance-dryer{color:#f59e0b}.appliance-dryer:hover{background:linear-gradient(135deg,#fff,#fef3c7)}.appliance-washer:hover svg{animation:spin 2s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.appliance-dryer:hover svg{animation:blow 1.5s ease-in-out infinite}@keyframes blow{0%,to{transform:translate(0)}50%{transform:translate(3px)}}@media(max-width:768px){.appliance-toolbar{width:100%;min-width:100%;max-width:100%;height:100%;padding:1rem;flex-shrink:0;border-left:1px solid rgba(255,255,255,.6);border-radius:var(--radius-xl)}.appliance-buttons{flex-direction:column;align-items:center;gap:1.5rem;padding-top:2rem}.appliance-button{width:60px;height:60px}}@media(min-width:769px)and (max-width:1024px){.appliance-toolbar{width:60px;padding:.75rem .25rem}.appliance-button{width:45px;height:45px}}.morning-stars-container{flex:1;overflow:hidden;border-radius:16px;background:#fff6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.6);box-shadow:0 4px 6px #0000001a;display:flex;flex-direction:column}.header-row{flex:1;display:grid;border-bottom:1px solid rgba(255,255,255,.5);z-index:20}.user-selector-cell{padding:20px;background:#ffffff4d;border-right:1px solid rgba(255,255,255,.5);display:flex;align-items:center;justify-content:center;position:relative}.selector-button{display:flex;align-items:center;justify-content:center;width:100%;padding:12px;border:none;border-radius:12px;background-color:#fffc;cursor:pointer;box-shadow:0 2px 4px #0000000d;color:#475569;font-weight:700;font-size:1.1rem;z-index:101}.selector-menu{position:absolute;top:calc(50% + 30px);left:20px;background-color:#fff;padding:10px;border-radius:8px;box-shadow:0 4px 12px #00000026;z-index:100;display:flex;flex-direction:column;gap:8px;min-width:220px}.selector-menu-item{display:flex;align-items:center;gap:8px;cursor:pointer;padding:8px;border-radius:4px;transition:background-color .2s}.selector-menu-item:hover{background-color:#f1f5f9}.selector-menu-item.selected{background-color:#e0f2fe}.task-header-cell{padding:10px;background:#ffffff4d;border-right:1px solid rgba(255,255,255,.5);display:flex;flex-direction:column;align-items:center;justify-content:center;overflow:hidden}.task-image-wrapper{flex:1;min-height:0;width:100%;display:flex;align-items:center;justify-content:center;margin-bottom:8px}.task-image-container{height:100%;width:100%;border-radius:20px;overflow:hidden;background-color:#fff;box-shadow:0 4px 8px #0000001a;padding:8px;display:flex;align-items:center;justify-content:center}.task-image{max-width:100%;max-height:100%;object-fit:contain}.task-label{font-size:1.2rem;color:#475569;font-weight:700;flex-shrink:0}.body-section{flex:2;display:flex;flex-direction:column;overflow:hidden}.user-row{flex:1;display:grid;border-bottom:1px solid rgba(255,255,255,.5)}.user-info-cell{padding:10px;border-right:1px solid rgba(255,255,255,.5);background:#fff3;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px}.morning-stars-user-avatar{width:80px;height:80px;border-radius:50%;overflow:hidden;border:4px solid white;box-shadow:0 4px 6px #0000001a}.morning-stars-user-name{font-weight:700;color:#334155;font-size:1.3rem}.star-cell{border-right:1px solid rgba(255,255,255,.5);cursor:pointer;display:flex;align-items:center;justify-content:center;position:relative;transition:background-color .2s}.star-cell:hover{background-color:#ffffff4d}.star-placeholder{width:32px;height:32px;border-radius:50%;background-color:#ffffff80;border:2px solid rgba(255,255,255,.8)}@keyframes popIn{0%{transform:scale(0) rotate(-45deg);opacity:0}80%{transform:scale(1.2) rotate(10deg);opacity:1}to{transform:scale(1) rotate(0)}}.star-icon{filter:drop-shadow(0 0 16px rgba(251,191,36,.8));animation:popIn .4s cubic-bezier(.175,.885,.32,1.275)}.login-container{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.login-card{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:20px;padding:3rem;box-shadow:0 20px 60px #0000004d;width:100%;max-width:400px;animation:fadeInUp .5s ease}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.login-header{text-align:center;margin-bottom:2rem}.login-icon{width:80px;height:80px;margin:0 auto 1rem;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:20px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:2.5rem}.login-title{font-size:1.75rem;font-weight:700;color:var(--text-main);margin:0 0 .5rem}.login-logo{height:2.5rem;width:auto;margin:0 0 .5rem;object-fit:contain}.login-subtitle{font-size:.95rem;color:var(--text-secondary);margin:0}.login-form{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-label{font-weight:600;color:var(--text-main);font-size:.9rem}.password-input{padding:.875rem 1rem;border:2px solid rgba(0,0,0,.1);border-radius:12px;font-size:1rem;transition:all .2s ease;background:#fff}.password-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.login-button{padding:1rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 15px #667eea66}.login-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea80}.login-button:active{transform:translateY(0)}.login-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.error-message{background:#fee;border:1px solid #fcc;color:#c33;padding:.75rem 1rem;border-radius:8px;font-size:.9rem;text-align:center;animation:shake .4s ease}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-10px)}75%{transform:translate(10px)}}@media(max-width:480px){.login-card{padding:2rem 1.5rem}.login-title{font-size:1.5rem}.login-logo{height:2rem}.login-icon{width:60px;height:60px;font-size:2rem}}
