*{box-sizing:border-box;margin:0;padding:0}:root{--bg:#f8fafc;--surface:#fff;--text:#1e293b;--text-muted:#64748b;--primary:#3b82f6;--primary-hover:#2563eb;--danger:#ef4444;--danger-hover:#dc2626;--border:#e2e8f0;--radius:8px}body{background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.6}.navbar{background:var(--surface);border-bottom:1px solid var(--border);z-index:100;justify-content:space-between;align-items:center;padding:.75rem 1.5rem;display:flex;position:sticky;top:0}.navbar-brand a{color:var(--primary);align-items:center;gap:.4rem;font-size:1.25rem;font-weight:700;text-decoration:none;display:inline-flex}.navbar-user{align-items:center;gap:1rem;display:flex}.navbar-link{color:var(--text-muted);align-items:center;gap:.35rem;font-size:.875rem;text-decoration:none;display:inline-flex}.navbar-link:hover{color:var(--primary)}.user-info{align-items:center;gap:.5rem;font-size:.875rem;display:flex}.user-avatar{border-radius:50%;width:28px;height:28px}.btn{border-radius:var(--radius);cursor:pointer;border:none;justify-content:center;align-items:center;gap:.35rem;padding:.5rem 1rem;font-size:.875rem;font-weight:500;transition:background-color .15s;display:inline-flex}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-hover)}.btn-secondary{background:var(--border);color:var(--text)}.btn-secondary:hover{background:#cbd5e1}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{background:var(--danger-hover)}.btn:disabled{opacity:.5;cursor:not-allowed}.main-content{max-width:1400px;margin:0 auto;padding:1.5rem}.login-page{justify-content:center;align-items:center;min-height:80vh;display:flex}.login-card{text-align:center;background:var(--surface);border-radius:12px;width:100%;max-width:400px;padding:3rem;box-shadow:0 4px 6px -1px #0000001a}.login-card h1{color:var(--primary);margin-bottom:.25rem;font-size:2rem}.login-card p{color:var(--text-muted);margin-bottom:2rem}.invitation-code-input{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);width:100%;color:var(--text);box-sizing:border-box;margin-bottom:.75rem;padding:.6rem 1rem;font-size:1rem;display:block}.login-error{color:#ef4444;margin-bottom:.75rem;font-size:.875rem}.login-code-prompt{color:var(--text-muted);margin-bottom:1rem}.submit-code-btn{background:var(--primary);color:#fff;border-radius:var(--radius);cursor:pointer;border:none;width:100%;padding:.75rem;font-size:1rem;font-weight:500;transition:opacity .15s;display:block}.submit-code-btn:disabled{opacity:.5;cursor:not-allowed}.auth-input{border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);width:100%;color:var(--text);margin-bottom:.75rem;padding:.65rem .875rem;font-size:1rem}.auth-input:focus{border-color:var(--primary);outline:none}.auth-submit-btn{background:var(--primary);color:#fff;border-radius:var(--radius);cursor:pointer;border:none;width:100%;margin-top:.25rem;padding:.75rem;font-size:1rem;font-weight:600;transition:background .15s}.auth-submit-btn:hover:not(:disabled){background:var(--primary-hover)}.auth-submit-btn:disabled{opacity:.6;cursor:not-allowed}.auth-toggle-btn{color:var(--primary);cursor:pointer;background:0 0;border:none;margin-top:.75rem;padding:0;font-size:.875rem}.auth-toggle-btn:hover{text-decoration:underline}.calendar-layout{gap:1.5rem;display:flex}.calendar-sidebar{flex-shrink:0;width:220px}.calendar-main{flex:1;min-width:0}.family-member-list{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);margin-bottom:1rem;padding:1rem}.family-member-list h3{color:var(--text-muted);margin-bottom:.75rem;font-size:.875rem}.member-toggle{cursor:pointer;align-items:center;gap:.5rem;padding:.375rem 0;font-size:.875rem;display:flex}.member-color-dot{border-radius:50%;flex-shrink:0;width:12px;height:12px}.member-name{flex:1}.member-role{color:var(--text-muted);font-size:.75rem}.sync-btn{width:100%}.modal-overlay{z-index:200;background:#0006;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--surface);border-radius:12px;width:90%;max-width:500px;max-height:90vh;padding:1.5rem;overflow-y:auto}.modal h2,.form-group{margin-bottom:1rem}.form-group label{margin-bottom:.25rem;font-size:.875rem;font-weight:500;display:block}.form-group input,.form-group textarea{border:1px solid var(--border);border-radius:var(--radius);width:100%;padding:.5rem .75rem;font-family:inherit;font-size:.875rem}.form-group input:focus,.form-group textarea:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #3b82f61a}.checkbox-group label{cursor:pointer;align-items:center;gap:.5rem;display:flex}.checkbox-group input[type=checkbox]{width:auto}.form-row{gap:1rem;display:flex}.form-row .form-group{flex:1}.modal-actions{justify-content:space-between;align-items:center;margin-top:1.5rem;display:flex}.modal-actions-right{gap:.5rem;margin-left:auto;display:flex}.settings-page{max-width:600px;margin:0 auto}.settings-page h1{margin-bottom:1.5rem}.family-card{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);padding:1.5rem}.family-card h2{margin-bottom:1rem}.family-card h3{margin-top:1.5rem;margin-bottom:.75rem}.invite-section{margin-bottom:1rem}.invite-section label{margin-bottom:.25rem;font-size:.875rem;font-weight:500;display:block}.invite-code-row{align-items:center;gap:.5rem;display:flex}.invite-code{background:var(--bg);border-radius:var(--radius);letter-spacing:.1em;padding:.5rem 1rem;font-size:1.125rem;font-weight:600}.hint{color:var(--text-muted);margin-top:.5rem;font-size:.75rem}.member-list-settings{list-style:none}.member-item{border-bottom:1px solid var(--border);align-items:center;gap:.5rem;padding:.5rem 0;font-size:.875rem;display:flex}.member-item--weekly{flex-direction:column;align-items:stretch;gap:.4rem;padding:.75rem 0}.member-item__header{align-items:center;gap:.5rem;display:flex}.member-item:last-child{border-bottom:none}.member-role-badge{background:var(--bg);color:var(--text-muted);border-radius:999px;margin-left:auto;padding:.125rem .5rem;font-size:.75rem}.weekly-grid{gap:.25rem;display:flex}.btn-day{border-radius:var(--radius);border:1px solid var(--border);cursor:pointer;background:var(--surface);color:var(--text);flex-direction:column;flex:1;align-items:center;gap:.1rem;padding:.25rem .125rem;font-size:.7rem;transition:background .15s,border-color .15s;display:flex}.btn-day:disabled{cursor:default;opacity:.6}.btn-day--home{background:color-mix(in srgb, var(--primary) 15%, transparent);border-color:var(--primary);color:var(--primary)}.btn-day--away{background:var(--surface);border-color:var(--border);color:var(--text-muted)}.btn-day:not(:disabled):hover.btn-day--home{background:color-mix(in srgb, var(--primary) 25%, transparent)}.btn-day:not(:disabled):hover.btn-day--away{border-color:var(--primary);color:var(--text)}.btn-day__label{font-weight:600}.btn-day__status{font-size:.65rem}.family-setup{flex-direction:column;gap:1.5rem;display:flex}.setup-card{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);padding:1.5rem}.setup-card h2{margin-bottom:1rem;font-size:1.25rem}.setup-divider{text-align:center;color:var(--text-muted);font-size:.875rem}.no-family{text-align:center;padding:4rem 1rem}.no-family h2{margin-bottom:.5rem}.no-family p{color:var(--text-muted);margin-bottom:1.5rem}.loading{min-height:40vh;color:var(--text-muted);justify-content:center;align-items:center;display:flex}.fc{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);padding:1rem}.fc .fc-button-primary{background:var(--primary);border-color:var(--primary)}.fc .fc-button-primary:hover,.fc .fc-button-primary:not(:disabled).fc-button-active{background:var(--primary-hover);border-color:var(--primary-hover)}.fc .fc-event{border-radius:4px;padding:1px 4px;font-size:.8rem}.dinner-summary{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);margin-bottom:1rem;padding:1rem}.dinner-summary h3{color:var(--text-muted);margin-bottom:.75rem;font-size:.875rem}.dinner-list{margin-bottom:.75rem;list-style:none}.dinner-member{align-items:center;gap:.5rem;padding:.25rem 0;font-size:.875rem;display:flex}.dinner-member.not-home{opacity:.4;text-decoration:line-through}.dinner-status-icon{margin-left:auto;font-weight:600}.dinner-member:not(.not-home) .dinner-status-icon{color:#10b981}.dinner-member.not-home .dinner-status-icon{color:var(--danger)}.dinner-toggle{width:100%;padding-top:.75rem;padding-bottom:.75rem}.dinner-page{max-width:900px;margin:0 auto}.dinner-page h1{margin-bottom:1rem}.dinner-default-setting{align-items:center;gap:.75rem;margin-bottom:1.5rem;display:flex}.week-nav{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.week-label{font-weight:600}.dinner-grid{grid-template-columns:repeat(7,1fr);gap:.5rem;display:grid}.dinner-day{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);min-height:120px;padding:.75rem}.dinner-day.is-today{border-color:var(--primary);box-shadow:0 0 0 1px var(--primary)}.dinner-day-header{color:var(--text-muted);justify-content:space-between;margin-bottom:.5rem;font-size:.8rem;font-weight:600;display:flex}.dinner-day-members{list-style:none}.dinner-day-member{border-radius:4px;align-items:center;gap:.375rem;padding:.2rem 0 .2rem .25rem;font-size:.8rem;display:flex}.dinner-day-member.is-me{cursor:pointer}.dinner-day-member.is-me:hover{background:var(--bg)}.dinner-day-member.not-home{opacity:.4;text-decoration:line-through}.dinner-day-member .dinner-status-icon{margin-left:auto;font-size:.75rem;font-weight:600}.dinner-day-member:not(.not-home) .dinner-status-icon{color:#10b981}.dinner-day-member.not-home .dinner-status-icon{color:var(--danger)}.navbar-hamburger{cursor:pointer;background:0 0;border:none;flex-direction:column;justify-content:center;gap:5px;margin-left:auto;padding:.25rem;display:none}.navbar-hamburger span{background:var(--text);border-radius:2px;width:22px;height:2px;transition:background-color .15s;display:block}@media (width<=768px){.navbar{flex-wrap:wrap;gap:.5rem;padding:.5rem 1rem;position:relative}.navbar-brand a{font-size:1.1rem}.navbar-hamburger{display:flex}.navbar-user{background:var(--surface);border-top:1px solid var(--border);flex-direction:column;align-items:flex-start;gap:0;width:100%;padding:.5rem 0;display:none}.navbar-user.is-open{display:flex}.navbar-link{border-bottom:1px solid var(--border);width:100%;padding:.6rem 0;font-size:.95rem}.user-info{border-bottom:1px solid var(--border);width:100%;padding:.6rem 0}.navbar-user .btn{margin-top:.5rem}.btn{padding:.4rem .75rem;font-size:.8rem}.dinner-toggle{padding-top:.85rem;padding-bottom:.85rem}.main-content{padding:.75rem}.calendar-layout{flex-direction:column}.calendar-sidebar{flex-wrap:wrap;gap:.5rem;width:100%;display:flex}.calendar-sidebar>*{flex:1;min-width:150px}.fc{padding:.5rem}.fc .fc-toolbar{flex-direction:column;gap:.5rem}.fc .fc-toolbar-title{font-size:1.1rem}.fc .fc-button{padding:.25rem .5rem;font-size:.75rem}.modal{width:95%;max-height:85vh;padding:1rem}.form-row{flex-direction:column;gap:0}.login-card{margin:0 1rem;padding:2rem 1.5rem}.login-card h1{font-size:1.5rem}.family-card{padding:1rem}.invite-code{font-size:.95rem}.dinner-grid{grid-template-columns:1fr;gap:.75rem}.dinner-day{align-items:center;gap:.75rem;min-height:auto;padding:.75rem 1rem;display:flex}.dinner-day-header{flex-direction:column;align-items:center;min-width:2.5rem;margin-bottom:0}.dinner-day-members{flex-wrap:wrap;flex:1;gap:.5rem;display:flex}.dinner-day-member{background:var(--bg);border-radius:999px;padding:.2rem .5rem}.dinner-day-member.is-me:hover{background:var(--border)}.week-nav{gap:.5rem}.week-label{text-align:center;font-size:.85rem}.no-family{padding:2rem 1rem}}.dashboard-page{max-width:900px;margin:0 auto}.dashboard-greeting{margin-bottom:1.75rem}.dashboard-greeting h1{margin-bottom:.2rem;font-size:1.75rem;font-weight:700}.dashboard-date{color:var(--text-muted);font-size:.95rem}.dashboard-widgets{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.25rem;display:grid}.dashboard-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem}.dashboard-card-header{justify-content:space-between;align-items:baseline;margin-bottom:1rem;display:flex}.dashboard-card-header h2{font-size:1rem;font-weight:600}.dashboard-card-link{color:var(--text-muted);font-size:.8rem;text-decoration:none}.dashboard-card-link:hover{color:var(--primary)}.dashboard-empty{color:var(--text-muted);padding:.5rem 0;font-size:.875rem}.dashboard-task-list{flex-direction:column;gap:.5rem;list-style:none;display:flex}.dashboard-task-item{background:var(--bg);border-radius:var(--radius);cursor:pointer;-webkit-user-select:none;user-select:none;justify-content:space-between;align-items:center;padding:.5rem .6rem;font-size:.875rem;display:flex}.dashboard-task-item:hover{background:var(--border)}.dashboard-task-item.is-completed{background:#10b98114}.dashboard-task-item.is-completed .dashboard-task-name{opacity:.6;-webkit-text-decoration:line-through #10b981;text-decoration:line-through #10b981}.dashboard-task-name{font-weight:500}.dashboard-task-assignee{color:var(--text-muted);align-items:center;gap:.35rem;display:flex}.tasks-page{max-width:1100px;margin:0 auto}.tasks-header{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.tasks-header h1{margin:0}.tasks-empty{text-align:center;color:var(--text-muted);padding:3rem 1rem}.tasks-grid{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);margin-top:1rem;overflow:hidden}.tasks-grid-header,.tasks-grid-row{grid-template-columns:180px repeat(7,1fr);display:grid}.tasks-grid-header{background:var(--bg);border-bottom:2px solid var(--border)}.tasks-grid-label{border-right:1px solid var(--border);justify-content:space-between;align-items:center;gap:.25rem;padding:.6rem .75rem;font-size:.8rem;font-weight:600;display:flex}.tasks-grid-day-header{text-align:center;color:var(--text-muted);border-left:1px solid var(--border);flex-direction:column;align-items:center;gap:.1rem;padding:.5rem .25rem;font-size:.8rem;font-weight:600;display:flex}.tasks-grid-day-header.is-today{color:var(--primary)}.tasks-grid-row{border-top:1px solid var(--border)}.tasks-grid-row:hover{background:var(--bg)}.task-name{text-overflow:ellipsis;white-space:nowrap;font-size:.875rem;font-weight:500;overflow:hidden}.task-actions{flex-shrink:0;gap:.25rem;display:flex}.btn-icon{cursor:pointer;color:var(--text-muted);background:0 0;border:none;border-radius:4px;padding:.1rem .3rem;font-size:.9rem;line-height:1}.btn-icon:hover{background:var(--border);color:var(--text)}.btn-icon-danger:hover{color:var(--danger);background:#fee2e2}.tasks-grid-cell{border-left:1px solid var(--border);justify-content:center;align-items:center;min-height:44px;padding:.5rem .4rem;display:flex}.tasks-grid-cell.is-today{background:#3b82f60a}.tasks-grid-cell.clickable{cursor:pointer}.tasks-grid-cell.clickable:hover{background:var(--bg)}.tasks-grid-cell.is-completed{background:#10b98112}.tasks-grid-cell.is-completed .task-assignee{opacity:.6;text-decoration:line-through}.task-done-check{color:#10b981;margin-right:.15rem;font-weight:700;text-decoration:none;display:inline-block}.task-assignee{align-items:center;gap:.3rem;font-size:.78rem;font-weight:500;display:flex}.task-member-picker{flex-direction:column;gap:.3rem;margin-top:.25rem;list-style:none;display:flex}.task-member-pick-item{border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:.5rem;padding:.4rem .6rem;font-size:.875rem;display:flex}.task-member-pick-item:hover{background:var(--bg)}.task-member-pick-item.selected{border-color:var(--primary);background:#3b82f60f}.task-rotation-order{color:var(--primary);background:#3b82f61a;border-radius:999px;justify-content:center;align-items:center;width:20px;height:20px;margin-left:auto;font-size:.75rem;font-weight:700;display:flex}.tasks-mobile{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);flex-direction:column;margin-top:1rem;display:none;overflow:hidden}.tasks-mobile-header,.tasks-mobile-row{border-bottom:1px solid var(--border);grid-template-columns:60px 1fr 1fr;align-items:center;padding:.5rem .75rem;font-size:.85rem;display:grid}.tasks-mobile-row:last-child{border-bottom:none}.tasks-mobile-header{background:var(--bg);color:var(--text-muted);border-bottom:2px solid var(--border);font-size:.75rem;font-weight:600}.tasks-mobile-row.is-today{outline:2px solid var(--primary);background:#3b82f60a}.tasks-mobile-row.clickable{cursor:pointer}.tasks-mobile-row.clickable:hover{background:var(--bg)}.tasks-mobile-row.is-completed{background:#10b9810f}.tasks-mobile-row.is-completed .tasks-mobile-task-name{opacity:.5;text-decoration:line-through}.tasks-mobile-date{color:var(--text-muted);white-space:nowrap;flex-direction:row;align-items:center;gap:.25rem;font-size:.78rem;font-weight:600;display:flex}.tasks-mobile-task-name{font-weight:500}.tasks-mobile-no-assign{color:var(--text-muted)}@media (width<=768px){.tasks-desktop{display:none}.tasks-mobile{display:flex}}@media (width<=400px){.navbar-link{font-size:.75rem}.fc .fc-toolbar-chunk:last-child{flex-wrap:wrap;gap:2px;display:flex}}.login-policy{color:var(--text-muted);margin-top:1.5rem;font-size:.8rem}.login-policy a{color:var(--text-muted);text-decoration:underline}.login-policy a:hover{color:var(--text)}.policy-page{max-width:760px;margin:2rem auto;padding:0 1rem}.policy-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:2rem}.policy-card h1{margin-bottom:.25rem;font-size:1.75rem;font-weight:700}.policy-subtitle{color:var(--text-muted);margin-bottom:2rem}.policy-card section{margin-bottom:1.75rem}.policy-card h2{margin-bottom:.5rem;font-size:1.1rem;font-weight:600}.policy-card p{color:var(--text-muted);margin-bottom:.5rem}.policy-card ul{color:var(--text-muted);padding-left:1.5rem}.policy-card ul li{margin-bottom:.25rem}
