:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;font-family:system-ui,-apple-system,Segoe UI,sans-serif}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}*{box-sizing:border-box}body{color:var(--lightningcss-light,#111)var(--lightningcss-dark,#f0f0f0);background:var(--lightningcss-light,#f7f7f9)var(--lightningcss-dark,#16171c);margin:0}.app-shell{grid-template-columns:260px 1fr;min-height:100vh;display:grid}.sidebar{background:var(--lightningcss-light,#fff)var(--lightningcss-dark,#1a1b21);border-right:1px solid var(--lightningcss-light,#e6e6ea)var(--lightningcss-dark,#2a2b32);flex-direction:column;gap:1.25rem;padding:1rem;display:flex;overflow-y:auto}.sidebar-brand{padding:.25rem .5rem;font-size:1.05rem;font-weight:700}.sidebar-section{flex-direction:column;gap:.35rem;display:flex}.sidebar-heading{text-transform:uppercase;letter-spacing:.08em;color:var(--lightningcss-light,#888)var(--lightningcss-dark,#888);padding:0 .5rem;font-size:.68rem;font-weight:600}.sidebar-heading-row{justify-content:space-between;align-items:center;padding-right:.25rem;display:flex}.sidebar-add{color:#fff;border:none;border-radius:50%;place-items:center;width:26px;height:26px;padding:0;display:inline-grid}.sidebar-add svg{display:block}.sidebar-empty{color:var(--lightningcss-light,#888)var(--lightningcss-dark,#888);margin:0 .5rem;font-size:.85em}.sidebar-links{flex-direction:column;gap:.1rem;margin:0;padding:0;list-style:none;display:flex}.sidebar-links a{color:inherit;border-radius:6px;justify-content:space-between;align-items:center;gap:.5rem;padding:.45rem .6rem;font-size:.95rem;text-decoration:none;display:flex}.sidebar-links a:hover{background:var(--lightningcss-light,#f0f1f5)var(--lightningcss-dark,#26272e)}.sidebar-links a.active{color:var(--lightningcss-light,#2456d9)var(--lightningcss-dark,#c0d2ff);background:var(--lightningcss-light,#e4ecff)var(--lightningcss-dark,#2d3855);font-weight:500}.sidebar-list-item{align-items:center;gap:.15rem;display:flex}.sidebar-list-item a{flex:1;justify-content:flex-start;min-width:0}.sidebar-list-name{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.sidebar-list-online{color:var(--lightningcss-light,#2f8f5b)var(--lightningcss-dark,#5bd399);flex-shrink:0;align-items:center;margin-left:.3rem;display:inline-flex}.sidebar-forget{color:var(--lightningcss-light,#999)var(--lightningcss-dark,#888);background:0 0;border:none;border-radius:6px;padding:.25rem .45rem;font-size:1.1rem;line-height:1}.sidebar-forget:hover{color:#c44;background:var(--lightningcss-light,#f0f1f5)var(--lightningcss-dark,#2a2b32)}.sidebar-backdrop{z-index:90;background:#0006;position:fixed;inset:0}.main-pane{flex-direction:column;min-width:0;display:flex;position:relative}.sidebar-toggle{z-index:80;color:inherit;background:var(--lightningcss-light,#fff)var(--lightningcss-dark,#22232a);border:1px solid var(--lightningcss-light,#d3d4da)var(--lightningcss-dark,#3a3b42);width:40px;height:40px;padding:0;font-size:1.1rem;display:none;position:fixed;top:.5rem;left:.5rem}@media (width<=900px){.app-shell{grid-template-columns:1fr}.sidebar{z-index:100;width:80%;max-width:300px;transition:transform .2s;position:fixed;top:0;bottom:0;left:0;transform:translate(-100%);box-shadow:2px 0 12px #0003}.app-shell[data-sidebar-open=true] .sidebar{transform:translate(0)}.sidebar-toggle{justify-content:center;align-items:center;display:inline-flex}.page{padding-top:3.5rem}}.page{width:100%;max-width:720px;margin:0 auto;padding:1rem 1rem 6rem}h1{margin:.5rem 0 0;font-size:1.75rem}h2{margin:0 0 .75rem;font-size:1.15rem}.muted{color:var(--lightningcss-light,#777)var(--lightningcss-dark,#999);font-size:.9em}.error{color:#c44}.card{background:var(--lightningcss-light,#fff)var(--lightningcss-dark,#22232a);border-radius:12px;flex-direction:column;gap:.75rem;margin-top:1rem;padding:1rem;display:flex;box-shadow:0 1px 2px #0000000d}.card label{color:var(--lightningcss-light,#555)var(--lightningcss-dark,#aaa);flex-direction:column;gap:.25rem;font-size:.85em;display:flex}input,select,button,.button{font:inherit;color:inherit;background:var(--lightningcss-light,#fff)var(--lightningcss-dark,#2b2c34);border:1px solid var(--lightningcss-light,#ccc)var(--lightningcss-dark,#3a3b42);border-radius:8px;padding:.55rem .75rem}input:focus,select:focus{outline-offset:-1px;outline:2px solid #5b8def}button,.button{cursor:pointer;color:#fff;text-align:center;background:#5b8def;border-color:#5b8def;font-weight:500;text-decoration:none}button:disabled{opacity:.5;cursor:not-allowed}button.ghost{color:var(--lightningcss-light,#777)var(--lightningcss-dark,#aaa);background:0 0;border-color:#0000;padding:.25rem .5rem}button.secondary{color:var(--lightningcss-light,#333)var(--lightningcss-dark,#ddd);background:0 0;border-color:var(--lightningcss-light,#ccc)var(--lightningcss-dark,#3a3b42)}button.danger{background:#c44;border-color:#c44}button.link{color:#5b8def;background:0 0;border:none;padding:0;font-size:.9em}.list-collection{flex-direction:column;gap:.25rem;margin:0;padding:0;list-style:none;display:flex}.list-collection li{align-items:center;gap:.5rem;display:flex}.list-collection a{color:inherit;background:var(--lightningcss-light,#f0f1f5)var(--lightningcss-dark,#2b2c34);border-radius:8px;flex:1;justify-content:space-between;padding:.6rem .75rem;text-decoration:none;display:flex}.list-page-header{justify-content:space-between;align-items:center;gap:.5rem;margin:.25rem 0 1rem;display:flex}.list-title{text-overflow:ellipsis;white-space:nowrap;min-width:0;margin:0;font-size:1.5rem;overflow:hidden}.list-title-actions{flex-shrink:0;gap:.35rem;display:flex}.icon-button{color:inherit;background:0 0;border:1px solid var(--lightningcss-light,#d3d4da)var(--lightningcss-dark,#3a3b42);border-radius:8px;justify-content:center;align-items:center;min-width:38px;padding:.4rem .6rem;font-size:1rem;line-height:1;display:inline-flex}.icon-button:hover{background:var(--lightningcss-light,#f0f1f5)var(--lightningcss-dark,#2b2c34)}.list-tabs{border-bottom:1px solid var(--lightningcss-light,#e6e6ea)var(--lightningcss-dark,#2a2b32);gap:.25rem;margin-bottom:1rem;display:flex;overflow-x:auto}.list-tabs .tab{color:var(--lightningcss-light,#666)var(--lightningcss-dark,#aaa);white-space:nowrap;background:0 0;border:none;border-bottom:2px solid #0000;border-radius:0;padding:.6rem .9rem;font-weight:500;text-decoration:none}.list-tabs .tab:hover{color:inherit}.list-tabs .tab.active{color:#5b8def;border-bottom-color:#5b8def}.add-item{gap:.5rem;margin-bottom:1rem;display:flex}.add-item input{flex:1}.add-item input.quantity{flex:0 0 110px}.items{flex-direction:column;gap:.25rem;margin:0;padding:0;list-style:none;display:flex}.item{background:var(--lightningcss-light,#fff)var(--lightningcss-dark,#22232a);border-radius:8px;align-items:center;gap:.5rem;padding:.5rem .75rem;display:flex}.item>input[type=checkbox]{margin:0}.item-body{color:inherit;text-align:left;cursor:text;font:inherit;background:0 0;border:none;flex:1;align-items:center;gap:.75rem;padding:.25rem 0;display:flex}.item.editing{padding:.35rem .5rem}.item.editing input{flex:1}.item.editing input.quantity{flex:0 0 110px}.item.done .item-text{color:var(--lightningcss-light,#999)var(--lightningcss-dark,#666);text-decoration:line-through}.item-qty{color:var(--lightningcss-light,#666)var(--lightningcss-dark,#aaa);background:var(--lightningcss-light,#f0f1f5)var(--lightningcss-dark,#2b2c34);border-radius:4px;padding:.1rem .4rem;font-size:.85em}.item-source{color:var(--lightningcss-light,#777)var(--lightningcss-dark,#999);font-size:.85em;font-style:italic}.add-ingredient-list{flex-direction:column;gap:.25rem;max-height:50vh;margin:.5rem 0 .75rem;padding:0;list-style:none;display:flex;overflow-y:auto}.add-ingredient-row{cursor:pointer;border-radius:6px;align-items:center;gap:.6rem;padding:.4rem .5rem;display:flex}.add-ingredient-row:hover{background:var(--lightningcss-light,#f0f1f5)var(--lightningcss-dark,#2a2b32)}.add-ingredient-row input[type=checkbox]{margin:0;transform:scale(1.15)}.add-ingredient-text{flex:1}.add-ingredient-qty{color:var(--lightningcss-light,#666)var(--lightningcss-dark,#aaa);background:var(--lightningcss-light,#f0f1f5)var(--lightningcss-dark,#2b2c34);border-radius:4px;padding:.1rem .4rem;font-size:.85em}.section-divider{color:var(--lightningcss-light,#777)var(--lightningcss-dark,#888);justify-content:space-between;align-items:center;margin:1.25rem 0 .5rem;font-size:.85em;display:flex}.dishes{flex-direction:column;gap:.5rem;margin:0;padding:0;list-style:none;display:flex}.dish{background:var(--lightningcss-light,#fff)var(--lightningcss-dark,#22232a);border-radius:10px;padding:.5rem .75rem}.dish-header{justify-content:space-between;align-items:center;gap:.5rem;display:flex}.dish-toggle{color:inherit;text-align:left;background:0 0;border:none;flex:1;padding:.25rem}.dish-actions{gap:.25rem;display:flex}.dish-body{border-top:1px solid var(--lightningcss-light,#eee)var(--lightningcss-dark,#31323a);margin-top:.5rem;padding-top:.5rem}.ingredients{flex-direction:column;gap:.25rem;margin:0 0 .5rem;padding:0;list-style:none;display:flex}.ingredients li{align-items:center;gap:.5rem;padding:.25rem 0;display:flex}.ingredients li span:first-child{flex:1}.ingredient-body{color:inherit;text-align:left;cursor:text;font:inherit;background:0 0;border:none;flex:1;align-items:center;gap:.5rem;padding:.15rem 0;display:flex}.ingredient-body span:first-child{flex:1}.ingredient.editing{gap:.35rem}.ingredient.editing input{flex:1}.ingredient.editing input.quantity{flex:0 0 100px}.dish-name-input{flex:1;font-weight:600}.add-ingredient{gap:.5rem;display:flex}.add-ingredient input{flex:1}.add-ingredient input.quantity{flex:0 0 110px}.admin-actions{flex-direction:column;gap:.5rem;width:100%;display:flex}.modal-overlay{z-index:1000;background:#00000080;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.modal{background:var(--lightningcss-light,#fff)var(--lightningcss-dark,#22232a);border-radius:12px;flex-direction:column;align-items:center;gap:1rem;width:100%;max-width:400px;padding:1.5rem;display:flex}.modal-wide{max-width:460px}.modal .tabs{border-bottom:1px solid var(--lightningcss-light,#e6e6ea)var(--lightningcss-dark,#2a2b32);gap:.25rem;width:100%;display:flex}.modal .tab{color:var(--lightningcss-light,#666)var(--lightningcss-dark,#aaa);background:0 0;border:none;border-bottom:2px solid #0000;border-radius:0;flex:1;padding:.55rem .5rem;font-weight:500}.modal .tab.active{color:#5b8def;border-bottom-color:#5b8def}.modal-form{flex-direction:column;gap:.75rem;width:100%;display:flex}.modal-form label{color:var(--lightningcss-light,#555)var(--lightningcss-dark,#aaa);flex-direction:column;gap:.25rem;font-size:.85em;display:flex}.qr-img{background:#fff;border-radius:8px;width:240px;height:240px;padding:8px}.share-header{flex-direction:column;align-items:center;gap:.25rem;width:100%;margin-bottom:.5rem;display:flex}.share-title{align-items:center;gap:.5rem;font-size:1.2rem;font-weight:600;display:flex}.share-emoji{font-size:1.3rem;line-height:1}.share-subtitle{color:var(--lightningcss-light,#555)var(--lightningcss-dark,#aaa);font-size:.9rem}.share-copy{text-align:left}.invite-mode{align-items:center;gap:.5rem;display:flex}.invite-mode label{color:inherit;flex:0 0 120px;align-items:center;gap:.4rem;font-size:.95em;display:flex}.invite-mode select,.invite-mode input{flex:1}.invite-created{background:var(--lightningcss-light,#eef4ff)var(--lightningcss-dark,#263050);border-radius:8px;flex-direction:column;align-items:center;gap:.5rem;width:100%;padding:.75rem;display:flex}.invite-list{width:100%}.invite-list h3{margin:0 0 .5rem;font-size:.95rem}.invites{flex-direction:column;gap:.35rem;margin:0;padding:0;list-style:none;display:flex}.invite-row{background:var(--lightningcss-light,#f0f1f5)var(--lightningcss-dark,#2b2c34);border-radius:8px;justify-content:space-between;align-items:center;gap:.5rem;padding:.5rem .6rem;display:flex}.invite-info{flex-direction:column;flex:1;gap:.15rem;min-width:0;display:flex}.invite-info code{font-family:ui-monospace,Menlo,Consolas,monospace;font-size:.85em}.invite-actions{flex-shrink:0;gap:.35rem;display:flex}.invite-actions button{padding:.35rem .6rem;font-size:.85em}.share-link{gap:.5rem;width:100%;display:flex}.share-link input{flex:1;min-width:0}.qr-scan-overlay{z-index:1100;background:#000000d9;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.qr-scan-frame{background:var(--lightningcss-light,#fff)var(--lightningcss-dark,#22232a);border-radius:12px;flex-direction:column;gap:1rem;width:100%;max-width:400px;padding:1rem;display:flex}.manual-entry{flex-direction:column;gap:.5rem;display:flex}.manual-entry label{color:var(--lightningcss-light,#555)var(--lightningcss-dark,#aaa);flex-direction:column;gap:.25rem;font-size:.85em;display:flex}.weekday-picker-wrap{display:inline-block;position:relative}.weekday-picker{z-index:10;background:var(--lightningcss-light,#fff)var(--lightningcss-dark,#1f1f23);border:1px solid var(--lightningcss-light,#ddd)var(--lightningcss-dark,#333);border-radius:6px;gap:2px;padding:4px;display:flex;position:absolute;top:calc(100% + 4px);right:0;box-shadow:0 4px 12px #00000026}.weekday-picker-day{min-width:32px;padding:4px 8px;font-size:.85em}.meal-plan{flex-direction:column;gap:1rem;display:flex}.meal-plan-grid{grid-template-columns:repeat(7,minmax(140px,1fr));gap:.75rem;display:grid}.meal-day{background:var(--lightningcss-light,#f7f7f8)var(--lightningcss-dark,#1a1a1e);border:1px solid var(--lightningcss-light,#e4e4e8)var(--lightningcss-dark,#2a2a2f);border-radius:8px;flex-direction:column;gap:.5rem;min-height:120px;padding:.6rem;transition:border-color .12s,background .12s;display:flex}.meal-day-over{background:var(--lightningcss-light,#eef3ff)var(--lightningcss-dark,#1d2236);border-color:var(--lightningcss-light,#8ab4ff)var(--lightningcss-dark,#6b90ff)}.meal-day-header{justify-content:space-between;align-items:center;display:flex}.meal-day-header h3{margin:0;font-size:.95em}.meal-list{flex-direction:column;gap:.35rem;min-height:40px;margin:0;padding:0;list-style:none;display:flex}.meal-card{background:var(--lightningcss-light,#fff)var(--lightningcss-dark,#26262b);border:1px solid var(--lightningcss-light,#e0e0e4)var(--lightningcss-dark,#353539);border-radius:6px;align-items:center;gap:.3rem;padding:.35rem .5rem;font-size:.9em;display:flex}.meal-card-dragging{cursor:grabbing;box-shadow:0 6px 18px #00000040}.meal-drag-handle{cursor:grab;color:var(--lightningcss-light,#888)var(--lightningcss-dark,#888);-webkit-user-select:none;user-select:none;touch-action:none;font-size:.9em}.meal-label{text-align:left;color:inherit;font:inherit;cursor:text;background:0 0;border:none;flex:1;padding:2px 0}.meal-label-input{font:inherit;flex:1;padding:2px 4px}.meal-empty{text-align:center;padding:.3rem;font-size:.85em}.meal-add{gap:.25rem;display:flex}.meal-add input{flex:1;min-width:0;padding:.3rem .4rem;font-size:.9em}@media (width<=900px){.meal-plan-grid{grid-template-columns:1fr}}.meal-plan-stack{flex-direction:column;gap:.75rem;display:flex}.meal-recipe-link{width:26px;height:26px;color:inherit;border-radius:6px;justify-content:center;align-items:center;padding:0;font-size:1rem;text-decoration:none;display:inline-flex}.meal-recipe-link:hover{background:var(--lightningcss-light,#f0f1f5)var(--lightningcss-dark,#2a2b32)}.dish-recipe-link{text-decoration:none}.emoji-picker{display:inline-block;position:relative}.emoji-button{cursor:pointer;background:var(--lightningcss-light,#fff)var(--lightningcss-dark,#26262b);border:1px solid var(--lightningcss-light,#d3d4da)var(--lightningcss-dark,#3a3b42);border-radius:8px;place-items:center;min-width:38px;min-height:38px;padding:.4rem .55rem;font-size:1.2rem;line-height:1;display:inline-grid}.emoji-button.emoji-placeholder{color:var(--lightningcss-light,#888)var(--lightningcss-dark,#666);border-style:dashed}.emoji-popover{z-index:50;box-sizing:border-box;background:var(--lightningcss-light,#fff)var(--lightningcss-dark,#1f2026);border:1px solid var(--lightningcss-light,#d3d4da)var(--lightningcss-dark,#3a3b42);border-radius:10px;width:304px;max-width:calc(100vw - 2rem);padding:.5rem;position:absolute;top:calc(100% + 4px);left:0;overflow:hidden;box-shadow:0 8px 24px #0000002e}.emoji-grid{grid-template-columns:repeat(8,1fr);gap:2px;display:grid}.emoji-grid-item{cursor:pointer;aspect-ratio:1;background:0 0;border:none;border-radius:4px;place-items:center;padding:4px;font-size:1.2rem;line-height:1;display:inline-grid}.emoji-grid-item:hover{background:var(--lightningcss-light,#f0f1f5)var(--lightningcss-dark,#2a2b32)}.emoji-actions{justify-content:flex-end;gap:.4rem;margin-top:.5rem;display:flex}.name-with-emoji{align-items:stretch;gap:.5rem;display:flex}.name-with-emoji input{flex:1;min-width:0}.kind-description{color:var(--lightningcss-light,#555)var(--lightningcss-dark,#aaa);margin:.25rem 0 0;font-size:.9em}.list-emoji{margin-right:.4rem;font-size:1em;display:inline-block}.sidebar-list-emoji{margin-right:.35rem;font-size:1em;display:inline-block}.sidebar-list-drag-preview{background:var(--lightningcss-light,#fff)var(--lightningcss-dark,#26262b);border:1px solid var(--lightningcss-light,#cfd0d4)var(--lightningcss-dark,#3a3b42);border-radius:8px;align-items:center;gap:.4rem;padding:.4rem .7rem;font-size:.95rem;display:inline-flex;box-shadow:0 8px 22px #0003}.sidebar-list-item{position:relative}.sidebar-list-item.drop-before:before,.sidebar-list-item.drop-after:after{content:"";pointer-events:none;background:#5b8def;border-radius:1px;height:2px;position:absolute;left:0;right:0}.sidebar-list-item.drop-before:before{top:-2px}.sidebar-list-item.drop-after:after{bottom:-2px}.modal-actions{justify-content:flex-end;gap:.5rem;margin-top:1rem;display:flex}.settings-row{border-bottom:1px solid var(--lightningcss-light,#eee)var(--lightningcss-dark,#2a2a2f);align-items:center;gap:.75rem;padding:.4rem 0;display:flex}.settings-label{color:var(--lightningcss-light,#555)var(--lightningcss-dark,#bbb);min-width:80px;font-weight:500}.settings-value{color:inherit}.ingredients.readonly li{padding:.2rem 0}.ingredient-readonly{align-items:center;gap:.5rem;width:100%;display:flex}.ingredient-readonly span:first-child{flex:1}.dish-edit-modal{align-items:stretch;gap:.6rem;max-width:480px}.dish-edit-modal h3{align-self:flex-start;margin:0}.dish-edit-modal .field-label{color:var(--lightningcss-light,#555)var(--lightningcss-dark,#aaa);margin-top:.25rem;font-size:.85em}.dish-edit-modal .field-row{gap:.4rem;display:flex}.dish-edit-modal .field-row input{flex:1;min-width:0}.dish-edit-modal .ingredients{max-height:260px;overflow-y:auto}.dish-edit-modal .modal-actions{justify-content:space-between;width:100%}.recipe-url-editor{flex-direction:column;gap:.3rem;margin-bottom:.5rem;display:flex}.recipe-url-label{color:var(--lightningcss-light,#555)var(--lightningcss-dark,#aaa);font-size:.85em}.recipe-url-row{gap:.4rem;display:flex}.recipe-url-row input{flex:1;min-width:0}.add-dish{gap:.4rem;margin-bottom:.75rem;display:flex}.add-dish input{flex:1;min-width:0}.add-dish input[type=url]{flex:1.5}.join-preview{text-align:center;max-width:480px;margin:1rem auto}.join-preview-card{background:var(--lightningcss-light,#f7f7f8)var(--lightningcss-dark,#1a1a1e);border:1px solid var(--lightningcss-light,#e4e4e8)var(--lightningcss-dark,#2a2a2f);border-radius:10px;margin:1rem 0;padding:1rem}.join-preview-name{justify-content:center;align-items:center;gap:.4rem;font-size:1.3rem;font-weight:500;display:flex}.join-preview-kind{margin-top:.4rem;font-size:.9em}.add-task{flex-wrap:wrap;gap:.4rem;margin-bottom:.75rem;display:flex}.add-task input[type=text],.add-task input:not([type]){flex:1;min-width:140px}.add-task input[type=date]{min-width:150px}.assignee-select{flex:0 200px;min-width:160px}.assignee-new{flex:0 240px;gap:.3rem;min-width:200px;display:inline-flex}.assignee-new input{flex:1;min-width:0}.assignee-new .error{flex-basis:100%}.tasks .task{background:var(--lightningcss-light,#fff)var(--lightningcss-dark,#26262b);border:1px solid var(--lightningcss-light,#e0e0e4)var(--lightningcss-dark,#353539);border-radius:8px;align-items:center;gap:.5rem;padding:.5rem .6rem;display:flex}.task.completed .task-text{color:var(--lightningcss-light,#888)var(--lightningcss-dark,#888);text-decoration:line-through}.task-check input{transform:scale(1.2)}.task-main{text-align:left;color:inherit;font:inherit;cursor:text;background:0 0;border:none;flex-direction:column;flex:1;gap:2px;min-width:0;padding:2px 0;display:flex}.task-text{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.task-meta{color:var(--lightningcss-light,#666)var(--lightningcss-dark,#999);gap:.6rem;font-size:.8em;display:flex}.task-editing{flex-wrap:wrap}.task-editing input{flex:1;min-width:120px}
