:root{--color-bg: #faf8f5;--color-text: #2d2a26;--color-muted-bg: #f0ece6;--color-muted-text: #8a8279;--color-border: #e0dbd3;--color-accent: #c47a5a;--color-accent-lt: #e0a882;--color-teal: #5b7e8a;--color-teal-dk: #4a6d78;--color-dark: #3a3631;--color-dark2: #4a4540;--radius: 10px;--font-body: "DM Sans", system-ui, sans-serif;--font-display: "Fraunces", Georgia, serif;--header-h: 56px;--sidebar-w: 256px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{font-family:var(--font-body);background:var(--color-bg);color:var(--color-text);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}.onboarding{min-height:100vh;background:linear-gradient(160deg,var(--color-bg) 0%,var(--color-muted-bg) 100%);display:flex;align-items:center;justify-content:center;padding:24px}.onboarding-card{background:#fff;border-radius:18px;box-shadow:0 4px 32px #0000001a,0 1px 4px #0000000d;border:1px solid var(--color-border);padding:48px 44px;width:100%;max-width:420px}.onboarding-logo{display:flex;align-items:center;justify-content:center;gap:10px;margin-bottom:32px}.onboarding-logo-icon{width:40px;height:40px;background:linear-gradient(135deg,var(--color-accent),var(--color-accent-lt));border-radius:11px;display:flex;align-items:center;justify-content:center;font-size:22px}.onboarding-logo-name{font-family:var(--font-display);font-size:26px;font-weight:700}.onboarding-title{font-family:var(--font-display);font-size:26px;font-weight:700;text-align:center;margin-bottom:8px}.onboarding-sub{font-size:15px;color:var(--color-muted-text);text-align:center;margin-bottom:28px;line-height:1.6}.onboarding-form{display:flex;flex-direction:column;gap:16px}.onboarding-hint{font-size:13px;color:var(--color-muted-text);text-align:center;line-height:1.5}.onboarding-submit{width:100%;padding:13px;background:linear-gradient(135deg,var(--color-teal),var(--color-teal-dk));color:#fff;font-family:var(--font-body);font-size:15px;font-weight:600;border:none;border-radius:var(--radius);cursor:pointer;box-shadow:0 2px 8px #5b7e8a4d;transition:transform .1s,box-shadow .1s,opacity .15s}.onboarding-submit:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 14px #5b7e8a66}.onboarding-submit:disabled{opacity:.5;cursor:not-allowed}.app-shell{display:flex;flex-direction:column;height:100vh;height:100dvh;overflow:hidden}.app-header{height:var(--header-h);background:linear-gradient(135deg,var(--color-dark),var(--color-dark2));color:#faf8f5;display:flex;align-items:center;padding:0 20px;gap:12px;flex-shrink:0;box-shadow:0 2px 8px #00000026}.header-logo{display:flex;align-items:center;gap:8px;font-family:var(--font-display);font-size:18px;font-weight:700;color:#faf8f5;-webkit-user-select:none;user-select:none}.header-logo-icon{width:28px;height:28px;background:linear-gradient(135deg,var(--color-accent),var(--color-accent-lt));border-radius:7px;display:flex;align-items:center;justify-content:center;font-size:15px}.header-spacer{flex:1}.user-menu{position:relative}.user-chip{display:flex;align-items:center;gap:8px;padding:5px 10px 5px 5px;border:none;border-radius:20px;background:#ffffff1a;color:#faf8f5e6;font-family:var(--font-body);font-size:13px;font-weight:500;cursor:pointer;transition:background .15s;-webkit-user-select:none;user-select:none}.user-chip:hover,.user-chip--open{background:#ffffff2e}.user-chip-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:140px}.user-chip-caret{font-size:10px;opacity:.7;margin-left:-2px}.user-avatar{width:24px;height:24px;border-radius:50%;background:linear-gradient(135deg,var(--color-accent),var(--color-accent-lt));font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.user-menu-dropdown{position:absolute;top:calc(100% + 6px);right:0;min-width:160px;background:#fff;color:var(--color-text);border:1px solid var(--color-border);border-radius:10px;box-shadow:0 8px 24px #0000002e;padding:4px;z-index:50;animation:user-menu-in .12s ease}@keyframes user-menu-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.user-menu-item{display:block;width:100%;padding:9px 12px;border:none;border-radius:6px;background:none;text-align:left;font-family:var(--font-body);font-size:13px;font-weight:500;color:inherit;cursor:pointer;transition:background .1s}.user-menu-item:hover{background:var(--color-muted-bg)}.app-body{display:flex;flex:1;overflow:hidden}.sidebar{width:var(--sidebar-w);background:var(--color-muted-bg);border-right:1px solid var(--color-border);overflow-y:auto;flex-shrink:0;display:flex;flex-direction:column}.sidebar-section{padding:20px 16px;border-bottom:1px solid var(--color-border)}.sidebar-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:var(--color-muted-text);margin-bottom:10px}.household-name{font-family:var(--font-display);font-size:16px;font-weight:700}.household-name--editable{display:block;width:100%;text-align:left;background:none;border:1px solid transparent;padding:4px 6px;margin:-4px -6px;border-radius:6px;color:inherit;cursor:text;font:inherit;font-family:var(--font-display);font-size:16px;font-weight:700}.household-name--editable:hover{border-color:var(--color-border);background:var(--color-bg)}.household-name-input{display:block;width:100%;padding:4px 6px;margin:-4px -6px;border:1px solid var(--color-accent);border-radius:6px;background:#fff;color:inherit;font-family:var(--font-display);font-size:16px;font-weight:700;outline:none}.member-list{display:flex;flex-direction:column;gap:4px}.claim-body{font-size:13px;color:var(--color-muted-text);line-height:1.5;margin:0 0 16px}.claim-qr-wrap{display:flex;align-items:center;justify-content:center;min-height:240px;background:#fff;border:1px solid var(--color-border);border-radius:8px;padding:12px;margin-bottom:12px}.claim-qr{display:block}.claim-loading{color:var(--color-muted-text);font-size:13px}.claim-error{color:#b3261e;font-size:13px}.claim-url-row{display:flex;gap:8px;margin-bottom:8px}.claim-url-input{flex:1;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:12px}.claim-notice{display:flex;align-items:center;gap:12px;padding:10px 14px;background:#fef3c7;color:#78350f;border-bottom:1px solid #f59e0b;font-size:13px}.claim-notice-close{margin-left:auto;border:none;background:transparent;font-size:18px;line-height:1;color:inherit;cursor:pointer;padding:0 4px}.member-item{display:flex;align-items:center;gap:10px;width:100%;padding:7px 8px;border:none;border-radius:8px;background:none;font-family:var(--font-body);color:inherit;text-align:left;cursor:pointer;transition:background .1s}.member-item:hover{background:#0000000a}.member-item--active{font-weight:600}.member-avatar{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,var(--color-teal),var(--color-teal-dk));color:#fff;font-size:13px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.member-info{flex:1;min-width:0}.member-name{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.you-tag{font-weight:400;color:var(--color-muted-text);font-size:12px}.role-badge{font-size:10px;font-weight:600;color:var(--color-muted-text);background:var(--color-border);padding:2px 6px;border-radius:4px;flex-shrink:0}.sidebar-hint{font-size:12px;color:var(--color-muted-text);line-height:1.5;margin-top:10px;padding:0 2px}.btn-sidebar-add{display:flex;align-items:center;justify-content:center;width:100%;margin-top:10px;padding:8px;background:none;border:1.5px dashed var(--color-border);border-radius:var(--radius);font-size:13px;font-weight:500;font-family:var(--font-body);color:var(--color-muted-text);cursor:pointer;transition:border-color .15s,color .15s,background .15s}.btn-sidebar-add:hover{border-color:var(--color-teal);color:var(--color-teal);background:#5b7e8a0d}.main-content{flex:1;overflow-y:auto;padding:32px 36px;display:flex;flex-direction:column;gap:28px;background-image:linear-gradient(to right,hsla(var(--member-hue, 200),55%,55%,.16),hsla(var(--member-hue, 200),55%,55%,0) 38%)}.main-header{display:flex;align-items:center;gap:12px}.main-title{font-family:var(--font-display);font-size:22px;font-weight:700;flex:1}.member-filter-bar{display:flex;align-items:center;gap:6px;overflow-x:auto;padding-bottom:4px;-webkit-overflow-scrolling:touch;scrollbar-width:none}.member-filter-bar::-webkit-scrollbar{display:none}.member-filter-btn{display:flex;align-items:center;gap:7px;padding:6px 14px 6px 8px;border-radius:20px;border:1.5px solid var(--color-border);background:#fff;font-size:13px;font-weight:500;font-family:var(--font-body);color:var(--color-muted-text);cursor:pointer;white-space:nowrap;flex-shrink:0;transition:border-color .12s,color .12s,background .12s}.member-filter-btn:first-child{padding:6px 14px}.member-filter-btn:hover{border-color:var(--color-teal);color:var(--color-teal-dk)}.member-filter-btn--add{padding:6px 14px;border-style:dashed;color:var(--color-teal-dk)}.member-filter-btn--active{font-weight:700;box-shadow:0 1px #0000000a}.member-filter-avatar{width:22px;height:22px;border-radius:50%;color:#fff;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.chore-search{position:relative;display:flex}.chore-search-input{flex:1;padding-right:36px}.chore-search-input::-webkit-search-cancel-button{display:none}.chore-search-clear{position:absolute;right:8px;top:50%;transform:translateY(-50%);width:24px;height:24px;border:none;background:transparent;color:var(--color-muted-text);font-size:14px;cursor:pointer;border-radius:50%;display:flex;align-items:center;justify-content:center}.chore-search-clear:hover{background:#0000000f;color:var(--color-text)}.empty-state{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:80px 32px;background:#fff;border:2px dashed var(--color-border);border-radius:14px}.empty-icon{font-size:52px;margin-bottom:16px}.empty-title{font-family:var(--font-display);font-size:20px;font-weight:700;margin-bottom:8px}.empty-body{font-size:14px;color:var(--color-muted-text);max-width:340px;margin:0 auto 24px;line-height:1.6}.task-list{display:flex;flex-direction:column;gap:8px}.chore-scroll{display:contents}.task-section{margin-bottom:24px}.task-section-header{display:flex;align-items:center;gap:8px;margin-bottom:10px;padding-left:2px}.task-section-label{font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--color-muted-text)}.task-section--today .task-section-label{color:var(--color-text)}.task-card--done-today{background:var(--color-muted-bg);border-color:var(--color-border);border-left-color:var(--color-border);color:var(--color-muted-text);box-shadow:none}.task-card--done-today .task-name{color:var(--color-muted-text)}.task-card--done-today:hover{transform:none;box-shadow:0 1px 3px #0000000a}.task-card{background:#fff;border-radius:var(--radius);border:1px solid var(--color-border);border-left:4px solid transparent;padding:13px 16px;display:flex;align-items:center;gap:12px;box-shadow:0 1px 3px #0000000a;transition:transform .1s,box-shadow .1s;cursor:pointer;-webkit-user-select:none;user-select:none;container-type:inline-size}.task-main{flex:1;min-width:0}.task-actions{display:flex;gap:12px;flex-shrink:0}@container (max-width: 480px){.task-actions{flex-direction:column;gap:6px}}.task-card:hover{transform:translateY(-1px);box-shadow:0 4px 12px #00000014}.task-name{font-size:14px;font-weight:600;line-height:1.5}.task-since{margin-top:6px;font-size:11px;font-weight:500;color:var(--color-muted-text);font-variant-numeric:tabular-nums}.task-progress{display:flex;align-items:center;gap:8px;margin-top:14px;font-size:11px;color:var(--color-muted-text);font-variant-numeric:tabular-nums}.task-progress-bound,.task-progress-since{flex-shrink:0;font-weight:500}.task-progress-bar{position:relative;flex:1;min-width:0;height:14px;border-radius:7px;background:var(--color-muted-bg);border:1px solid var(--color-border);display:flex;align-items:center;overflow:visible}.task-progress-fill{position:relative;height:100%;border-radius:7px 0 0 7px;display:flex;align-items:center;padding-left:6px;transition:width .2s ease-out,background .2s}.task-progress-fill--full{border-radius:7px}.task-progress-fill-label{color:#fff;font-size:10px;font-weight:700;text-shadow:0 1px 1px rgba(0,0,0,.25);white-space:nowrap;pointer-events:none}.task-progress-rest-label{margin-left:auto;padding-right:6px;font-size:10px;font-weight:600;color:var(--color-muted-text);white-space:nowrap}.task-snooze-btn{flex-shrink:0;padding:5px 10px;border-radius:6px;border:1px solid var(--color-border);background:#fff;color:var(--color-muted-text);font-size:12px;font-weight:600;cursor:pointer;transition:background .12s,color .12s,border-color .12s}.task-snooze-btn:hover:not(:disabled){background:var(--color-muted-bg);color:var(--color-text);border-color:var(--color-muted-text)}.task-snooze-btn:disabled{opacity:.5;cursor:default}.task-done-btn{flex-shrink:0;padding:5px 13px;border-radius:6px;border:1px solid var(--color-border);background:#fff;color:var(--color-teal);font-size:12px;font-weight:600;cursor:pointer;transition:background .12s,color .12s,border-color .12s}.task-done-btn:hover:not(:disabled){background:var(--color-teal);color:#fff;border-color:var(--color-teal)}.task-done-btn:disabled{opacity:.5;cursor:default}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:var(--radius);font-size:13px;font-weight:600;font-family:var(--font-body);cursor:pointer;border:none;transition:transform .1s,box-shadow .1s,opacity .15s}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,var(--color-teal),var(--color-teal-dk));color:#fff;box-shadow:0 2px 6px #5b7e8a4d}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #5b7e8a66}.btn-secondary{background:#fff;color:var(--color-text);border:1.5px solid var(--color-border)}.btn-secondary:hover{border-color:var(--color-muted-text)}.btn-ghost{background:#ffffff1a;color:#faf8f5d9;border:1.5px solid rgba(255,255,255,.2)}.btn-ghost:hover{background:#ffffff2e;color:#faf8f5}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#2d2a268c;display:flex;align-items:center;justify-content:center;z-index:100;padding:24px}.modal{background:#fff;border-radius:16px;box-shadow:0 24px 64px #0003;width:100%;max-width:420px;padding:32px;animation:modal-in .15s ease;max-height:calc(100dvh - 48px);overflow-y:auto;overscroll-behavior:contain}@keyframes modal-in{0%{opacity:0;transform:scale(.96) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-title{font-family:var(--font-display);font-size:20px;font-weight:700;margin-bottom:24px}.modal-footer{display:flex;align-items:center;gap:10px;justify-content:flex-end;margin-top:24px}.modal-footer-spacer{flex:1}.member-edit-body{display:flex;flex-direction:column;gap:12px}.member-edit-header{display:flex;align-items:center;gap:12px}.member-edit-avatar{width:48px;height:48px;border-radius:50%;color:#fff;font-size:20px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.member-edit-name{font-size:16px;font-weight:600}.member-edit-name--editable{display:block;text-align:left;background:none;border:1px solid transparent;padding:2px 6px;margin:-2px -6px;border-radius:6px;color:inherit;cursor:text;font:inherit;font-size:16px;font-weight:600}.member-edit-name--editable:hover{border-color:var(--color-border);background:var(--color-bg)}.member-edit-name-input{display:block;padding:2px 6px;margin:-2px -6px;border:1px solid var(--color-accent);border-radius:6px;background:#fff;color:inherit;font-size:16px;font-weight:600;outline:none;min-width:160px}.member-edit-role{font-size:13px;color:var(--color-muted-text);margin-top:2px}.member-edit-hint{font-size:13px;color:var(--color-muted-text);line-height:1.5;margin:0}.member-edit-modal{max-width:720px}.member-calendar-loading{font-size:13px;color:var(--color-muted-text);padding:8px 0}.member-calendar{display:flex;flex-direction:column;gap:4px}.member-calendar-header,.member-calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.member-calendar-dow{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.6px;color:var(--color-muted-text);text-align:center}.member-calendar-cell{min-height:64px;padding:6px 6px 4px;border:1px solid var(--color-border, #e5e5e5);border-radius:10px;font-size:11px;line-height:1.3;background:#fff;display:flex;flex-direction:column;gap:3px;transition:background .15s,border-color .15s}.member-calendar-cell--today{border-color:var(--color-teal, #5b7e8a);box-shadow:0 0 0 1px var(--color-teal, #5b7e8a),0 2px 6px #5b7e8a2e}.member-calendar-cell--done{background:#eaf5ed;border-color:#b9dcc4}.member-calendar-cell--progress{background:#fff7e8}.member-calendar-cell--missed{background:#f7eded;border-color:#e6c9c9}.member-calendar-cell-head{display:flex;align-items:center;justify-content:space-between;gap:4px;margin-bottom:1px}.member-calendar-cell-day{font-weight:700;font-size:14px;color:var(--color-text)}.member-calendar-cell-today-tag{font-size:10px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;color:#fff;background:var(--color-teal);padding:2px 6px;border-radius:999px}.member-calendar-cell-check{font-size:13px;color:#2e8b57;font-weight:700;line-height:1}.member-calendar-cell-row{display:flex;align-items:center;gap:5px;font-size:11px;color:var(--color-text)}.member-calendar-cell-row--complete{color:#2e8b57}.member-calendar-cell-text{font-weight:500}.member-calendar-pill{display:inline-flex;align-items:center;justify-content:center;width:14px;height:14px;border-radius:50%;font-size:10px;font-weight:700;line-height:1;color:#fff;flex-shrink:0}.member-calendar-pill--mine{background:var(--color-accent)}.member-calendar-pill--shared{background:var(--color-teal)}.member-calendar-cell-row--complete .member-calendar-pill--mine,.member-calendar-cell-row--complete .member-calendar-pill--shared{background:#5cb27a}.member-calendar-cell-empty{font-size:10px;color:var(--color-muted-text);font-style:italic}.member-calendar-legend{display:flex;gap:16px;margin-top:6px;font-size:11px;color:var(--color-muted-text)}.member-calendar-legend-item{display:inline-flex;align-items:center;gap:6px}.member-chore-list{display:flex;flex-direction:column;gap:4px;margin-top:8px}.member-chore-list-label{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.6px;color:var(--color-muted-text);margin-bottom:2px}.member-chore-list-items{display:flex;flex-direction:column;gap:4px;max-height:240px;overflow-y:auto}.member-chore-item{display:flex;align-items:center;gap:8px;padding:4px 0;font-size:13px}.member-chore-emoji{width:18px;text-align:center}.member-chore-title{flex:1}.member-chore-mode{font-size:10px;font-weight:600;letter-spacing:.3px;padding:2px 8px;border-radius:999px;background:var(--color-muted-bg);color:var(--color-muted-text)}.member-chore-mode--mine{background:#c47a5a24;color:var(--color-accent)}.member-chore-mode--shared{background:#5b7e8a24;color:var(--color-teal-dk)}.link-btn{background:none;border:none;padding:6px 0;font-size:13px;font-weight:600;font-family:var(--font-body);color:var(--color-teal);cursor:pointer;text-decoration:underline;text-underline-offset:3px}.link-btn:hover{color:var(--color-teal-dk)}.link-btn:disabled{opacity:.5;cursor:not-allowed}.link-btn--danger{color:#c62828}.link-btn--danger:hover{color:#8b1d1d}.history-subtitle{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.8px;color:var(--color-muted-text);margin-top:-16px;margin-bottom:16px}.history-error{background:#fdeceb;color:#a23a2c;padding:10px 12px;border-radius:var(--radius);font-size:13px;margin-bottom:12px}.history-list{max-height:60vh;overflow-y:auto;border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-bg);padding:4px 0}.history-day{padding:8px 0}.history-day+.history-day{border-top:1px solid var(--color-border)}.history-day-label{position:sticky;top:0;background:var(--color-bg);padding:6px 14px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--color-muted-text);z-index:1}.history-row{display:flex;align-items:flex-start;gap:10px;padding:8px 14px}.history-avatar{width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:11px;font-weight:700;flex-shrink:0}.history-body{flex:1;min-width:0}.history-line{display:flex;align-items:baseline;gap:8px;justify-content:space-between}.history-name{font-size:13px;font-weight:600;color:var(--color-text)}.history-time{font-size:12px;color:var(--color-muted-text);white-space:nowrap}.history-note{font-size:12px;color:var(--color-muted-text);margin-top:2px;word-wrap:break-word}.history-edit-btn{font-size:12px;align-self:center;flex-shrink:0}.form-fields{display:flex;flex-direction:column;gap:16px}.form-field{display:flex;flex-direction:column;gap:6px}.form-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--color-muted-text)}.form-input,.form-select{padding:10px 12px;border:1.5px solid var(--color-border);border-radius:var(--radius);font-size:14px;font-family:var(--font-body);background:var(--color-bg);color:var(--color-text);outline:none;transition:border-color .15s,box-shadow .15s}.form-input:focus,.form-select:focus{border-color:var(--color-teal);box-shadow:0 0 0 3px #5b7e8a1f}.form-input::placeholder{color:#c0bab3}.edit-starting-input{align-self:flex-start;min-width:180px}.member-toggles{display:flex;flex-wrap:wrap;gap:8px}.member-toggle{display:flex;align-items:center;gap:7px;padding:6px 12px 6px 6px;border-radius:20px;border:1.5px solid var(--color-border);background:#fff;font-size:13px;font-weight:500;font-family:var(--font-body);color:var(--color-text);cursor:pointer;transition:border-color .12s,background .12s,color .12s}.member-toggle:hover{border-color:var(--color-teal);background:#5b7e8a0f}.member-toggle--on{border-color:var(--color-teal);background:#5b7e8a1a;color:var(--color-teal-dk)}.member-toggle--all{padding:6px 12px}.member-toggle-avatar{width:22px;height:22px;border-radius:50%;color:#fff;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.rotation-order{display:flex;flex-direction:column;gap:6px}.rotation-row{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:10px;border:1.5px solid var(--color-border);background:#fff}.rotation-position{font-size:12px;font-weight:600;color:var(--color-muted-text);width:18px;flex-shrink:0;text-align:right}.rotation-avatar{width:28px;height:28px;border-radius:50%;color:#fff;font-size:12px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.rotation-name{flex:1;font-size:14px;font-weight:500;color:var(--color-text)}.rotation-first,.rotation-nudge{width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;border-radius:8px;border:1.5px solid var(--color-border);background:#fff;color:var(--color-text);font-family:var(--font-body);font-size:16px;line-height:1;cursor:pointer;flex-shrink:0;transition:border-color .12s,background .12s,color .12s,transform .1s}.rotation-first:hover:not(:disabled),.rotation-nudge:hover:not(:disabled){border-color:var(--color-teal);background:#5b7e8a0f;transform:translateY(-1px)}.rotation-first:active:not(:disabled),.rotation-nudge:active:not(:disabled){transform:translateY(0)}.rotation-first--on{border-color:var(--color-accent);background:#c47a5a1f;color:var(--color-accent)}.rotation-first--on:hover{border-color:var(--color-accent);background:#c47a5a2e}.form-error{padding:10px 12px;background:#fce4ec;color:#c62828;border:1px solid #ef9a9a;border-radius:var(--radius);font-size:13px}.profile-body{display:flex;flex-direction:column;gap:18px}.profile-preview{display:flex;align-items:center;gap:14px;padding:14px;background:var(--color-muted-bg);border-radius:var(--radius)}.profile-preview-avatar{width:56px;height:56px;border-radius:50%;color:#fff;font-size:28px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.profile-preview-name{font-size:16px;font-weight:600}.profile-preview-sub{font-size:12px;color:var(--color-muted-text);margin-top:2px;word-break:break-all}.profile-emoji-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:6px}.profile-emoji-btn{padding:8px 0;font-size:20px;background:#fff;border:1.5px solid var(--color-border);border-radius:var(--radius);cursor:pointer;transition:border-color .12s,background .12s,transform .1s;line-height:1}.profile-emoji-btn:hover{border-color:var(--color-teal)}.profile-emoji-btn--on{border-color:var(--color-teal);background:#5b7e8a1a;transform:scale(1.04)}.profile-hue-row{display:flex;gap:10px;flex-wrap:wrap}.profile-hue-btn{width:32px;height:32px;border-radius:50%;border:2px solid transparent;cursor:pointer;transition:transform .1s,border-color .12s;padding:0}.profile-hue-btn:hover{transform:scale(1.08)}.profile-hue-btn--on{border-color:var(--color-text);transform:scale(1.08);box-shadow:0 0 0 2px var(--color-bg)}.profile-readonly{padding:9px 12px;background:var(--color-muted-bg);border-radius:var(--radius);font-size:14px;color:var(--color-text);word-break:break-all}.profile-readonly-empty{color:var(--color-muted-text)}.profile-hint{font-size:12px;color:var(--color-muted-text);margin:0;line-height:1.4}.profile-danger{border-top:1px solid var(--color-border);padding-top:14px}.profile-danger-buttons{display:flex;gap:18px;flex-wrap:wrap}.profile-danger-link{background:none;border:none;padding:0;font-family:var(--font-body);font-size:13px;font-weight:500;color:var(--color-muted-text);cursor:pointer;text-decoration:underline;text-underline-offset:2px}.profile-danger-link:hover{color:var(--color-text)}.profile-danger-link--delete{color:#c62828}.profile-danger-link--delete:hover{color:#8e1d1d}.profile-danger-link:disabled{opacity:.5;cursor:not-allowed}.profile-danger-confirm{background:#fff7f0;border:1px solid #f1c9a8;border-radius:var(--radius);padding:14px}.profile-danger-confirm p{margin:0 0 12px;font-size:13px;line-height:1.5;color:var(--color-text)}.profile-danger-actions{display:flex;justify-content:flex-end;gap:8px}.btn-danger{background:#c62828;color:#fff;box-shadow:0 2px 6px #c628284d}.btn-danger:hover:not(:disabled){background:#a31f1f;transform:translateY(-1px);box-shadow:0 4px 12px #c6282866}.wizard-modal{max-width:460px;padding:28px 32px 24px;max-height:90vh;overflow-y:auto}.wizard-progress{display:flex;justify-content:center;gap:7px;margin-bottom:28px}.wizard-dot{width:8px;height:8px;border-radius:50%;background:var(--color-border);transition:background .2s,transform .2s}.wizard-dot--done{background:#5b7e8a73}.wizard-dot--active{background:var(--color-teal);transform:scale(1.3)}.wizard-body{display:flex;flex-direction:column;gap:18px;min-height:180px}.wizard-step-title{font-family:var(--font-display);font-size:20px;font-weight:700}.wizard-step-sub{font-size:13px;color:var(--color-muted-text);margin-top:-10px}.wizard-step-hint{font-size:13px;color:var(--color-teal-dk);background:#5b7e8a1a;border-left:3px solid var(--color-teal);padding:10px 12px;border-radius:6px;margin-top:12px;line-height:1.45}.wizard-name-input{font-size:16px;padding:13px 14px}.wizard-choice-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.wizard-choice-card{display:flex;flex-direction:column;align-items:center;gap:6px;padding:20px 12px;border-radius:12px;border:2px solid var(--color-border);background:#fff;cursor:pointer;font-family:var(--font-body);text-align:center;transition:border-color .12s,background .12s,transform .1s}.wizard-choice-card:hover{border-color:var(--color-teal);background:#5b7e8a0a;transform:translateY(-1px)}.wizard-choice-card--active{border-color:var(--color-teal);background:#5b7e8a14}.wizard-choice-icon{font-size:28px;line-height:1}.wizard-choice-label{font-size:14px;font-weight:700;color:var(--color-text)}.wizard-choice-sub{font-size:11px;color:var(--color-muted-text);line-height:1.4}.wizard-choice-grid--compact{grid-template-columns:1fr 1fr 1fr;gap:8px}.wizard-choice-card--compact{padding:12px 6px;gap:4px}.wizard-choice-card--compact .wizard-choice-icon{font-size:22px}.wizard-choice-card--compact .wizard-choice-label{font-size:12px;line-height:1.2}.wizard-choice-card--compact .wizard-choice-sub{display:none}.wizard-freq-grid{display:flex;flex-wrap:wrap;gap:8px}.wizard-freq-pill{padding:8px 16px;border-radius:20px;border:1.5px solid var(--color-border);background:#fff;font-size:13px;font-weight:500;font-family:var(--font-body);color:var(--color-text);cursor:pointer;transition:border-color .12s,background .12s,color .12s}.wizard-freq-pill:hover{border-color:var(--color-teal)}.wizard-freq-pill--active{border-color:var(--color-teal);background:#5b7e8a1a;color:var(--color-teal-dk);font-weight:600}.wizard-date-section{display:flex;flex-direction:column;gap:8px}.wizard-date-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--color-muted-text)}.wizard-date-opts{display:flex;flex-wrap:wrap;gap:7px}.wizard-date-pill{padding:6px 13px;border-radius:16px;border:1.5px solid var(--color-border);background:#fff;font-size:12px;font-weight:500;font-family:var(--font-body);color:var(--color-text);cursor:pointer;transition:border-color .12s,background .12s,color .12s}.wizard-date-pill:hover{border-color:var(--color-teal)}.wizard-date-pill--active{border-color:var(--color-teal);background:#5b7e8a1a;color:var(--color-teal-dk);font-weight:600}.dow-picker{display:flex;flex-direction:column;gap:8px}.dow-picker-days{display:flex;gap:6px}.dow-day{width:36px;height:36px;border-radius:50%;border:1.5px solid var(--color-border);background:#fff;font-size:13px;font-weight:600;font-family:var(--font-body);color:var(--color-muted-text);cursor:pointer;transition:border-color .12s,background .12s,color .12s}.dow-day:hover{border-color:var(--color-teal)}.dow-day--on{border-color:var(--color-teal);background:var(--color-teal);color:#fff}.freq-picker{display:flex;align-items:center;flex-wrap:wrap;gap:8px}.freq-picker-prefix{font-size:13px;font-weight:500;color:var(--color-text)}.freq-picker-num{width:64px;padding:6px 8px;border-radius:8px;border:1.5px solid var(--color-border);background:#fff;font-size:13px;font-family:var(--font-body);color:var(--color-text);text-align:center}.freq-picker-num:focus{outline:none;border-color:var(--color-teal)}.freq-picker-unit{padding:6px 28px 6px 10px;border-radius:8px;border:1.5px solid var(--color-border);background:#fff;font-size:13px;font-family:var(--font-body);color:var(--color-text);cursor:pointer;-moz-appearance:none;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3e%3cpath fill='none' stroke='%23666' stroke-width='1.5' d='M1 1l4 4 4-4'/%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right 10px center}.freq-picker-unit:focus{outline:none;border-color:var(--color-teal)}.starting-picker{display:flex;flex-direction:column;gap:8px}.starting-picker-value{font-size:14px;font-weight:600;color:var(--color-text)}.month-cal{display:flex;flex-direction:column;gap:4px;padding:8px;border:1px solid var(--color-border);border-radius:10px;background:#fff}.month-cal-nav{display:flex;align-items:center;justify-content:space-between;gap:8px}.month-cal-nav-btn{width:28px;height:28px;border:1px solid var(--color-border);border-radius:8px;background:#fff;font-size:16px;line-height:1;color:var(--color-text);cursor:pointer;transition:border-color .12s,background .12s}.month-cal-nav-btn:hover{border-color:var(--color-teal)}.month-cal-title{font-size:13px;font-weight:700;color:var(--color-text)}.month-cal-header,.month-cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:3px}.month-cal-dow{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--color-muted-text);text-align:center;padding:2px 0}.month-cal-cell{min-height:32px;border:1px solid transparent;border-radius:8px;background:transparent;font-family:var(--font-body);font-size:13px;font-weight:500;color:var(--color-text);cursor:pointer;transition:border-color .12s,background .12s,color .12s}.month-cal-cell:hover:not(:disabled){border-color:var(--color-teal);background:#5b7e8a0f}.month-cal-cell--out{color:var(--color-muted-text);opacity:.45}.month-cal-cell--today{border-color:var(--color-teal)}.month-cal-cell--selected{background:var(--color-teal);color:#fff;border-color:var(--color-teal);font-weight:700}.month-cal-cell--selected:hover:not(:disabled){background:var(--color-teal-dk, var(--color-teal))}.month-cal-cell--disabled{opacity:.25;cursor:not-allowed}.wizard-nav{display:flex;align-items:center;justify-content:space-between;margin-top:24px;padding-top:20px;border-top:1px solid var(--color-border)}.wizard-back{background:none;border:none;font-family:var(--font-body);font-size:13px;font-weight:500;color:var(--color-muted-text);cursor:pointer;padding:6px 0;transition:color .12s}.wizard-back:hover{color:var(--color-text)}.rotation-order{display:flex;flex-direction:column;gap:8px}.rotation-row{display:flex;align-items:center;gap:10px;padding:8px 10px;background:#fff;border:1px solid var(--color-border);border-radius:var(--radius)}.rotation-position{width:18px;flex-shrink:0;font-size:12px;font-weight:700;color:var(--color-muted-text);text-align:right}.rotation-avatar{width:30px;height:30px;border-radius:50%;color:#fff;font-size:13px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.rotation-name{flex:1;min-width:0;font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.rotation-first{background:none;border:none;padding:4px;font-size:18px;line-height:1;color:var(--color-muted-text);cursor:pointer;transition:color .12s}.rotation-first:hover,.rotation-first--on{color:var(--color-accent)}.rotation-nudge{width:28px;height:28px;border-radius:50%;border:1px solid var(--color-border);background:#fff;font-size:13px;font-family:var(--font-body);color:var(--color-text);cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:border-color .12s,color .12s}.rotation-nudge:hover:not(:disabled){border-color:var(--color-teal);color:var(--color-teal)}.rotation-nudge:disabled{opacity:.35;cursor:not-allowed}.splash{height:100%;display:flex;align-items:center;justify-content:center}.splash-logo{font-size:52px;animation:pulse 1.5s ease-in-out infinite}.splash-error{display:flex;flex-direction:column;align-items:center;gap:16px;text-align:center;color:var(--color-muted-text)}.splash-error .splash-logo{animation:none}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.88)}}.coming-soon{text-align:center;padding:32px 0 16px;color:var(--color-muted-text)}.coming-soon-icon{font-size:36px;display:block;margin-bottom:10px}@media(min-width:681px){.member-filter-bar{display:none}}@media(max-width:680px){.sidebar{display:none}.main-content{padding:20px 16px;overflow:hidden;min-height:0;background-image:none;gap:0}.main-content>.main-header{margin-bottom:18px}.member-filter-bar{background:var(--color-bg);flex-wrap:wrap;overflow-x:visible;row-gap:8px;margin:0 -16px;padding:14px 16px;box-shadow:0 4px 8px -6px #0000002e}.chore-scroll{display:flex;flex-direction:column;flex:1;min-height:0;gap:28px;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;margin:0 -16px;padding:14px 16px 0;background-image:linear-gradient(to bottom,hsla(var(--member-hue, 200),55%,55%,.16),hsla(var(--member-hue, 200),55%,55%,0) 220px)}.task-card{padding:11px 12px}.modal-overlay{padding:0;align-items:flex-end}.modal{border-radius:20px 20px 0 0;max-width:100%;padding:24px 20px;animation:sheet-in .2s ease;max-height:90dvh;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}@keyframes sheet-in{0%{transform:translateY(100%)}to{transform:translateY(0)}}.member-toggles{gap:6px}}@media(max-width:480px){.member-calendar-header,.member-calendar-grid{gap:3px}.member-calendar-cell{min-height:56px;padding:4px 3px 3px;gap:2px}.member-calendar-cell-day{font-size:13px}.member-calendar-cell-today-tag{padding:2px 4px;font-size:9px}.member-calendar-cell-row{gap:3px;font-size:10px;line-height:1.15;align-items:flex-start}.member-calendar-cell-text{min-width:0;word-break:break-word}.member-calendar-pill{width:11px;height:11px;font-size:9px;margin-top:1px}}.complete-modal-body{display:flex;flex-direction:column;gap:16px;padding:16px 20px 4px}.complete-modal-sub{font-size:13px;color:var(--color-muted-text)}.complete-modal-choices{display:grid;grid-template-columns:1fr 1fr;gap:14px}.complete-choice{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;min-height:130px;padding:20px 12px;border-radius:14px;border:2px solid var(--color-border);background:#fff;cursor:pointer;font-family:var(--font-body);text-align:center;transition:border-color .12s,background .12s,transform .1s}.complete-choice:hover:not(:disabled){border-color:var(--color-teal);background:#5b7e8a0f;transform:translateY(-1px)}.complete-choice:disabled{opacity:.5;cursor:default}.complete-choice-icon{font-size:40px;line-height:1}.complete-choice-label{font-size:16px;font-weight:700;color:var(--color-text)}.complete-choice--today .complete-choice-icon{color:#2e8b57}.complete-day-picker{display:flex;flex-direction:column;gap:4px}.complete-day-picker-header,.complete-day-picker-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.complete-day-picker-dow{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.6px;color:var(--color-muted-text);text-align:center}.complete-day-cell{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;min-height:52px;padding:4px;border:1px solid var(--color-border, #e5e5e5);border-radius:10px;background:#fff;cursor:pointer;font-family:var(--font-body);transition:border-color .12s,background .12s,transform .1s}.complete-day-cell:hover:not(:disabled){border-color:var(--color-teal);background:#5b7e8a0f;transform:translateY(-1px)}.complete-day-cell--today{border-color:var(--color-teal, #5b7e8a);box-shadow:0 0 0 1px var(--color-teal, #5b7e8a)}.complete-day-cell--future{opacity:.35;cursor:default}.complete-day-cell-num{font-size:15px;font-weight:700;color:var(--color-text)}.complete-day-cell-tag{font-size:9px;font-weight:700;letter-spacing:.4px;text-transform:uppercase;color:var(--color-teal)}.complete-modal-specific{display:flex;flex-direction:column;gap:6px;padding-top:4px;border-top:1px solid var(--color-border)}.complete-modal-specific-label{font-size:12px;font-weight:600;color:var(--color-muted-text)}.complete-modal-specific-row{display:flex;gap:8px;align-items:center}.complete-modal-date-input{flex:1;padding:8px 10px;font-family:var(--font-body);font-size:14px;border:1.5px solid var(--color-border);border-radius:8px;background:#fff;color:var(--color-text)}.complete-choice--cancel .complete-choice-icon{color:var(--color-muted-text)}.complete-choice--snooze .complete-choice-icon{color:var(--color-teal)}.member-stats{display:flex;flex-wrap:wrap;gap:4px 8px;align-items:center;margin-top:2px}.member-stats-count{font-size:11px;font-weight:600;color:var(--color-muted-text);white-space:nowrap}.member-stats-count--done{color:#4a6d2a}.member-stats-bonus{font-size:11px;font-weight:700;color:#8a5a2a;background:#fbe7c6;padding:1px 6px;border-radius:999px;white-space:nowrap}.member-filter-count{font-size:11px;font-weight:700;color:var(--color-muted-text);background:#0000000d;padding:1px 7px;border-radius:999px;margin-left:2px}.member-filter-count--done{background:#d8e8c2;color:#4a6d2a}.member-filter-btn--active .member-filter-count{background:#fff;color:inherit}.member-filter-bonus{font-size:11px;font-weight:700;color:#8a5a2a;background:#fbe7c6;padding:1px 7px;border-radius:999px;margin-left:2px;white-space:nowrap}.task-any-badge{display:inline-flex;align-items:center;vertical-align:middle;gap:4px;font-size:11px;font-weight:700;color:#8a5a2a;background:linear-gradient(135deg,#fff1d6,#fbe7c6);border:1px solid #f0d9a5;padding:2px 8px;border-radius:999px;margin-left:8px;white-space:nowrap}.task-any-badge--muted{filter:grayscale(.6);opacity:.7}.caught-up-banner{display:flex;align-items:center;gap:14px;padding:14px 18px;background:linear-gradient(135deg,#e7f2d4,#d8e8c2);border:1.5px solid #b6cf90;border-radius:14px;animation:caught-up-pop .35s ease-out}.caught-up-broom{font-size:32px;line-height:1;flex-shrink:0;animation:caught-up-wiggle .8s ease-out}.caught-up-text{min-width:0}.caught-up-title{font-family:var(--font-display);font-size:17px;font-weight:700;color:#3a5a1a}.caught-up-sub{font-size:13px;color:#4a6d2a;margin-top:2px}@keyframes caught-up-pop{0%{transform:scale(.96);opacity:0}to{transform:scale(1);opacity:1}}@keyframes caught-up-wiggle{0%{transform:rotate(-18deg) scale(.6)}40%{transform:rotate(14deg) scale(1.15)}70%{transform:rotate(-6deg) scale(1)}to{transform:rotate(0) scale(1)}}.task-section-count,.task-section-hint{font-size:12px;font-weight:600;color:var(--color-muted-text);text-transform:none;letter-spacing:0;margin-left:auto}.task-section-hint{color:#8a5a2a}.celebrate-toast{position:fixed;left:50%;bottom:64px;transform:translate(-50%);display:flex;align-items:center;gap:10px;padding:14px 24px;border-radius:999px;font-family:var(--font-display);font-weight:700;font-size:18px;box-shadow:0 8px 28px #0000002e;pointer-events:none;z-index:9999;animation:celebrate-in .35s cubic-bezier(.18,.89,.32,1.28),celebrate-out .4s ease-in 1.4s forwards}.celebrate-toast--logged{border-radius:18px;animation:celebrate-in .35s cubic-bezier(.18,.89,.32,1.28),celebrate-out .4s ease-in 3.5s forwards}.celebrate-toast--bonus{background:linear-gradient(135deg,#ffd98a,#f5b15a);color:#5a3a10}.celebrate-toast--extra{background:linear-gradient(135deg,#c9e8b0,#9ed179);color:#2a4a10}.celebrate-toast--done{background:linear-gradient(135deg,#d6e9ef,#a8c8d2);color:#1a3a4a}.celebrate-icon{font-size:26px;line-height:1;animation:celebrate-pop .5s ease-out}.celebrate-points{font-size:24px;font-weight:800}.celebrate-label{font-size:18px}.celebrate-text{display:flex;flex-direction:column;align-items:flex-start;line-height:1.15;gap:2px}.celebrate-day{font-size:13px;font-weight:600;opacity:.78}@keyframes celebrate-in{0%{transform:translate(-50%,40px);opacity:0}to{transform:translate(-50%);opacity:1}}@keyframes celebrate-out{0%{transform:translate(-50%);opacity:1}to{transform:translate(-50%,-20px);opacity:0}}@keyframes celebrate-pop{0%{transform:scale(.4) rotate(-12deg)}60%{transform:scale(1.25) rotate(8deg)}to{transform:scale(1) rotate(0)}}@media(max-width:680px){.celebrate-toast{bottom:32px;padding:12px 20px;font-size:16px}.celebrate-icon{font-size:22px}.celebrate-points{font-size:20px}.caught-up-banner{padding:12px 14px;gap:12px}.caught-up-broom{font-size:28px}.caught-up-title{font-size:15px}.caught-up-sub{font-size:12px}}
