:root{--bg:#0f0f1a;--bg-card:#1a1a2e;--bg-card2:#16213e;--accent:#6c63ff;--accent2:#ff6584;--accent-laura:#ff6584;--accent-melvin:#6c63ff;--text:#eaeaea;--text-muted:#888;--border:#ffffff12;--radius:16px;--radius-sm:10px;--shadow:0 4px 24px #0006;--safe-top:env(safe-area-inset-top,0px);--safe-bottom:env(safe-area-inset-bottom,0px)}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent;margin:0;padding:0}html,body{overscroll-behavior:none;height:100%}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:16px;line-height:1.5}#root{flex-direction:column;min-height:100%;display:flex}button{cursor:pointer;font-family:inherit;font-size:inherit;color:inherit;background:0 0;border:none}input,textarea,select{font-family:inherit;font-size:inherit;color:inherit;background:0 0;border:none;outline:none}a{color:inherit;text-decoration:none}.sr-only{clip:rect(0,0,0,0);white-space:nowrap;width:1px;height:1px;position:absolute;overflow:hidden}.who-page{justify-content:center;align-items:center;min-height:100dvh;padding:24px;display:flex;position:relative;overflow:hidden}.who-bg{pointer-events:none;background:radial-gradient(at 20% 20%,#6c63ff40 0%,#0000 60%),radial-gradient(at 80% 80%,#ff658433 0%,#0000 60%);position:absolute;inset:0}.who-card{background:var(--bg-card);border:1px solid var(--border);width:100%;max-width:380px;box-shadow:var(--shadow);text-align:center;border-radius:24px;padding:36px 28px;position:relative}.who-logo{margin-bottom:32px}.who-logo-icon{margin-bottom:12px;font-size:48px;display:block}.who-logo h1{background:linear-gradient(135deg, var(--accent), var(--accent2));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:28px;font-weight:700}.who-logo p{color:var(--text-muted);margin-top:4px;font-size:14px}.who-buttons{flex-direction:column;gap:14px;display:flex}.who-btn{border-radius:var(--radius);border:2px solid var(--border);background:#ffffff08;align-items:center;gap:16px;width:100%;padding:16px 20px;transition:all .2s;display:flex}.who-btn:hover{box-shadow:var(--shadow);transform:translateY(-2px)}.who-btn.laura:hover{background:#ff658414;border-color:#ff6584}.who-btn.melvin:hover{background:#6c63ff14;border-color:#6c63ff}.who-btn:active{transform:scale(.98)}.who-avatar{color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;font-size:20px;font-weight:800;display:flex}.who-name{font-size:18px;font-weight:700}.task-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);cursor:default;align-items:center;gap:14px;padding:14px 16px;transition:opacity .2s,background .2s;display:flex}.task-card.done{opacity:.55;background:#ffffff08}.task-card.upcoming{opacity:.7}.task-check{border:2px solid var(--border);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:26px;height:26px;transition:background .2s,border-color .2s;display:flex}.task-check:not(:disabled):hover{border-color:var(--accent)}.task-check:not(:disabled):active{transform:scale(.9)}.task-check.checked{background:var(--accent);border-color:var(--accent)}.task-check:disabled{cursor:not-allowed;opacity:.4}.task-info{flex:1;min-width:0}.task-name-row{align-items:center;gap:8px;margin-bottom:4px;display:flex}.task-category-icon{flex-shrink:0;font-size:16px}.task-name{white-space:nowrap;text-overflow:ellipsis;font-size:15px;font-weight:600;overflow:hidden}.task-name-done{color:var(--text-muted);text-decoration:line-through}.task-meta{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.task-freq{text-transform:uppercase;letter-spacing:.4px;border-radius:999px;padding:2px 7px;font-size:11px;font-weight:600}.task-freq.daily{color:var(--accent2);background:#ff658426}.task-freq.weekly{color:var(--accent);background:#6c63ff26}.task-freq.biweekly{color:#9b92ff;background:#6c63ff1a}.task-freq.monthly{color:var(--text-muted);background:#ffffff0f}.task-due{color:var(--text-muted);font-size:12px;font-weight:500}.task-assignee{font-size:11px;font-weight:600}.task-both{color:var(--text-muted)!important}.task-done-avatar{color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:12px;font-weight:700;display:flex}.home-page{padding-bottom:24px}@keyframes spin{to{transform:rotate(360deg)}}.home-header{background:linear-gradient(160deg, var(--bg-card2) 0%, var(--bg-card) 100%);border-bottom:1px solid var(--border);padding:20px 20px 24px}.home-header-top{justify-content:space-between;align-items:flex-start;margin-bottom:20px;display:flex}.home-date{color:var(--text-muted);text-transform:capitalize;margin-bottom:4px;font-size:13px}.home-greeting{font-size:22px;font-weight:700}.home-duo{align-items:center;display:flex}.avatar{color:#fff;border:2px solid var(--bg);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:15px;font-weight:700;display:flex}.avatar-offset{border:2px solid var(--bg)}.progress-card{border-radius:var(--radius);background:#6c63ff14;border:1px solid #6c63ff33;padding:16px}.progress-header{justify-content:space-between;align-items:center;margin-bottom:10px;font-size:14px;font-weight:600;display:flex}.progress-count{color:var(--accent);font-weight:700}.progress-bar-bg{background:#ffffff14;border-radius:999px;height:6px;overflow:hidden}.progress-bar-fill{background:linear-gradient(90deg, var(--accent), #9b92ff);border-radius:999px;height:100%;transition:width .5s}.progress-done{color:var(--accent);text-align:center;margin-top:10px;font-size:13px;font-weight:600}.home-section{padding:20px 16px 0}.task-list{flex-direction:column;gap:10px;display:flex}.empty-state{color:var(--text-muted);flex-direction:column;align-items:center;gap:8px;padding:32px;font-size:14px;display:flex}.modal-overlay{z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000b3;align-items:flex-end;display:flex;position:fixed;inset:0}.modal{background:var(--bg-card);border:1px solid var(--border);-webkit-overflow-scrolling:touch;width:100%;max-height:90dvh;padding-bottom:var(--safe-bottom);border-bottom:none;border-radius:24px 24px 0 0;animation:.3s slide-up;overflow-y:auto}@keyframes slide-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}.modal-header{background:var(--bg-card);z-index:1;justify-content:space-between;align-items:center;padding:20px 20px 0;display:flex;position:sticky;top:0}.modal-header h2{font-size:20px;font-weight:700}.modal-close{width:32px;height:32px;color:var(--text-muted);background:#ffffff14;border-radius:50%;justify-content:center;align-items:center;font-size:14px;display:flex}.modal-form{flex-direction:column;gap:20px;padding:20px;display:flex}.field input:focus{border-color:var(--accent);background:#6c63ff14}.icon-grid{grid-template-columns:repeat(4,1fr);gap:8px;display:grid}.icon-btn{border-radius:var(--radius-sm);border:1px solid var(--border);background:0 0;flex-direction:column;align-items:center;gap:4px;padding:10px 6px;transition:all .2s;display:flex}.icon-btn span:first-child{font-size:22px}.icon-btn-label{color:var(--text-muted);text-align:center;font-size:10px;font-weight:600;line-height:1.2}.icon-btn.active{border-color:var(--accent);background:#6c63ff26}.icon-btn.active .icon-btn-label{color:var(--accent)}.select-group{flex-wrap:wrap;gap:8px;display:flex}.select-btn{border:1px solid var(--border);color:var(--text-muted);background:0 0;border-radius:999px;padding:8px 16px;font-size:13px;font-weight:600;transition:all .2s}.select-btn.active{border-color:var(--accent);color:var(--accent);background:#6c63ff26}.modal-actions{gap:12px;padding-top:4px;display:flex}.btn-secondary{border-radius:var(--radius-sm);border:1px solid var(--border);background:#ffffff0f;flex:1;padding:14px;font-size:15px;font-weight:600;transition:background .2s}.btn-primary{background:linear-gradient(135deg, var(--accent), #9b92ff);color:#fff;border-radius:var(--radius-sm);flex:2;justify-content:center;align-items:center;padding:14px;font-size:15px;font-weight:600;transition:opacity .2s;display:flex}.tasks-page{flex-direction:column;min-height:100%;padding-bottom:24px;display:flex}.tasks-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:20px 20px 16px;display:flex}.tasks-header h1{font-size:22px;font-weight:700}.btn-add{background:linear-gradient(135deg, var(--accent), #9b92ff);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:24px;display:flex;box-shadow:0 4px 16px #6c63ff66}.btn-add:active{transform:scale(.93)}.filters{flex-direction:column;gap:10px;padding:14px 16px 0;display:flex}.filter-row{-webkit-overflow-scrolling:touch;scrollbar-width:none;gap:8px;padding-bottom:4px;display:flex;overflow-x:auto}.filter-row::-webkit-scrollbar{display:none}.filter-chip{border:1px solid var(--border);color:var(--text-muted);white-space:nowrap;border-radius:999px;flex-shrink:0;padding:6px 14px;font-size:13px;font-weight:600;transition:all .2s}.filter-chip.active{border-color:var(--accent);color:var(--accent);background:#6c63ff26}.filter-assignee-row .filter-chip{font-size:12px}.tasks-list-section{flex:1;padding:16px 16px 0}.task-list-full{flex-direction:column;gap:10px;display:flex}.swipeable-task{align-items:center;gap:8px;display:flex}.swipeable-task .task-card{flex:1;min-width:0}.task-delete-btn{width:38px;height:38px;color:var(--accent2);background:#ff65841a;border:1px solid #ff658433;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:16px;transition:background .2s;display:flex}.task-delete-btn:hover{background:#ff658440}.empty-state{color:var(--text-muted);flex-direction:column;align-items:center;gap:10px;padding:48px 24px;display:flex}.empty-state span{font-size:36px}.empty-state p{font-size:15px}.btn-primary-sm{background:linear-gradient(135deg, var(--accent), #9b92ff);color:#fff;border-radius:var(--radius-sm);margin-top:4px;padding:10px 20px;font-size:14px;font-weight:600}.profile-page{padding-bottom:40px}.profile-header{border-bottom:1px solid var(--border);padding:20px 20px 16px}.profile-header h1{font-size:22px;font-weight:700}.duo-section{border-bottom:1px solid var(--border);justify-content:center;gap:32px;padding:28px 20px 20px;display:flex}.profile-bubble{flex-direction:column;align-items:center;gap:8px;display:flex;position:relative}.profile-avatar-lg{color:#fff;border-radius:50%;justify-content:center;align-items:center;width:72px;height:72px;font-size:28px;font-weight:800;display:flex}.profile-bubble-name{font-size:15px;font-weight:600}.profile-me-badge{color:var(--accent);background:#6c63ff26;border-radius:999px;padding:2px 8px;font-size:11px;font-weight:700}.stats-section{padding:20px 16px 0}.section-title{text-transform:uppercase;letter-spacing:.8px;color:var(--text-muted);margin-bottom:12px;font-size:13px;font-weight:700}.stats-grid{grid-template-columns:1fr 1fr;gap:10px;display:grid}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:16px}.stat-card.wide{grid-column:1/-1;align-items:center;gap:16px;display:flex}.stat-card.wide .stat-label{margin-top:0}.stat-value{font-size:32px;font-weight:800;line-height:1}.stat-card.wide .stat-value{font-size:28px}.stat-label{color:var(--text-muted);margin-top:4px;font-size:12px;font-weight:600}.profile-form-section{padding:20px 16px 0}.profile-form{flex-direction:column;gap:18px;display:flex}.field{flex-direction:column;gap:10px;display:flex}.field label{text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);font-size:13px;font-weight:700}.field input{border:1px solid var(--border);border-radius:var(--radius-sm);background:#ffffff0d;padding:12px 14px;font-size:16px;transition:border-color .2s}.field input:focus{border-color:var(--accent)}.field input::placeholder{color:#fff3}.color-grid{flex-wrap:wrap;gap:12px;display:flex}.color-dot{border:3px solid #0000;border-radius:50%;width:36px;height:36px;transition:border-color .2s,transform .2s}.color-dot.active{border-color:#fff;transform:scale(1.15)}.btn-primary{background:linear-gradient(135deg, var(--accent), #9b92ff);color:#fff;border-radius:var(--radius-sm);justify-content:center;align-items:center;min-height:50px;padding:14px;font-size:16px;font-weight:600;transition:opacity .2s;display:flex}.btn-primary:disabled{opacity:.6}.btn-spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:20px;height:20px;animation:.7s linear infinite spin}.btn-spinner.small{width:14px;height:14px}.notif-section{padding:20px 16px 0}.notif-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);align-items:center;gap:16px;padding:16px;display:flex}.notif-info{flex:1}.notif-label{margin-bottom:4px;font-size:15px;font-weight:600}.notif-desc{color:var(--text-muted);font-size:12px;line-height:1.4}.toggle-btn{border:1px solid var(--accent);color:var(--accent);background:#6c63ff26;border-radius:999px;flex-shrink:0;align-items:center;padding:8px 16px;font-size:13px;font-weight:700;transition:all .2s;display:flex}.toggle-btn.enabled{color:#4caf50;background:#4caf5026;border-color:#4caf50}.logout-section{padding:24px 16px 0}.btn-logout{border-radius:var(--radius-sm);width:100%;color:var(--accent2);background:#ff658414;border:1px solid #ff658433;padding:14px;font-size:15px;font-weight:600;transition:background .2s}.btn-logout:active{background:#ff658433}.page-loading{justify-content:center;align-items:center;height:60vh;display:flex}.spinner{border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:32px;height:32px;animation:.7s linear infinite spin}.layout{flex-direction:column;height:100dvh;display:flex;overflow:hidden}.layout-main{padding-top:var(--safe-top);-webkit-overflow-scrolling:touch;flex:1;overflow:hidden auto}.layout-nav{background:var(--bg-card);border-top:1px solid var(--border);padding:8px 0;padding-bottom:calc(8px + var(--safe-bottom));z-index:100;flex-shrink:0;justify-content:space-around;align-items:center;display:flex;position:relative}.nav-item{border-radius:var(--radius-sm);color:var(--text-muted);letter-spacing:.3px;flex-direction:column;align-items:center;gap:4px;padding:6px 20px;font-size:11px;font-weight:500;transition:color .2s;display:flex}.nav-item svg{width:22px;height:22px}.nav-item.active{color:var(--accent)}
