:root{--background:#f7f8f4;--surface:#fff;--surface-muted:#eef2e8;--text:#17231f;--muted:#65716c;--border:#dbe2d6;--accent:#245447;--accent-strong:#173f35;--danger:#9d2f28;--shadow:0 10px 30px #17231f14}*{box-sizing:border-box}html{background:var(--background);min-height:100%}body{min-height:100vh;color:var(--text);background:var(--background);margin:0;font-family:Arial,Helvetica Neue,sans-serif}button,input,select{font:inherit}button{color:#fff;background:var(--accent);cursor:pointer;border:0;border-radius:8px;min-height:44px;padding:0 16px;font-size:.95rem;font-weight:700}button:disabled{cursor:not-allowed;opacity:.65}.shell{width:min(720px,100%);min-height:100vh;padding:calc(12px + env(safe-area-inset-top)) 12px calc(24px + env(safe-area-inset-bottom));margin:0 auto}.centered{place-items:center;display:grid}.topbar{justify-content:space-between;align-items:center;gap:16px;margin-bottom:12px;display:flex}.app-name{color:var(--accent);letter-spacing:0;text-transform:uppercase;margin:0 0 4px;font-size:.78rem;font-weight:800}h1,h2,p{margin-top:0}h1{margin-bottom:0;font-size:1.72rem;line-height:1.05}.ghost-button,.icon-button{min-width:44px;color:var(--accent);border:1px solid var(--border);background:0 0}.danger-button{color:#fff;background:var(--danger)}.compact-danger{min-height:38px;padding:0 12px;font-size:.88rem}.quiet-status{color:var(--muted);align-self:center;font-size:.88rem}.status-row{min-height:40px;color:var(--muted);justify-content:space-between;align-items:center;gap:12px;margin-bottom:10px;font-size:.92rem;display:flex}.view-tabs{grid-template-columns:1fr 1fr;gap:8px;margin-bottom:10px;display:grid}.view-tabs button,.topbar button{min-height:40px}.view-tabs button{color:var(--accent);border:1px solid var(--border);background:#fff}.view-tabs button.active{color:#fff;background:var(--accent);border-color:var(--accent)}.quick-add{top:calc(8px + env(safe-area-inset-top));z-index:5;border:1px solid var(--border);background:var(--surface);border-radius:8px;grid-template-columns:minmax(0,1fr) 48px;align-items:center;gap:8px;margin-bottom:10px;padding:8px;display:grid;position:sticky;box-shadow:0 6px 20px #17231f14}.quick-add-field{min-width:0}.quick-add-field input{border:1px solid var(--border);width:100%;min-height:46px;color:var(--text);background:#fff;border-radius:8px;padding:0 12px;font-weight:700}.quick-add-field input:focus{border-color:var(--accent);outline:3px solid #2454472e}.quick-add button{width:48px;min-width:48px;min-height:46px;padding:0;font-size:1.55rem;line-height:1}.visually-hidden{clip:rect(0 0 0 0);white-space:nowrap;width:1px;height:1px;position:absolute;overflow:hidden}.field{min-width:0;color:var(--muted);gap:6px;font-size:.78rem;font-weight:800;display:grid}.field input,.field select{border:1px solid var(--border);width:100%;min-width:0;min-height:46px;color:var(--text);background:#fff;border-radius:8px;padding:0 10px}.field input:focus,.field select:focus{border-color:var(--accent);outline:3px solid #2454472e}.note-field{grid-column:1/-2}.list-actions{justify-content:flex-end;min-height:30px;margin-bottom:8px;display:flex}.notice,.empty-state,.passcode-panel{border:1px solid var(--border);background:var(--surface);box-shadow:var(--shadow);border-radius:8px}.notice{gap:12px;margin-bottom:16px;padding:16px;display:grid}.notice p{margin:0}.notice.error{color:var(--danger);border-color:#9d2f2859}.passcode-panel{gap:18px;width:min(420px,100%);padding:24px;display:grid}.passcode-panel label{color:var(--muted);gap:8px;font-size:.9rem;font-weight:700;display:grid}.passcode-panel input{border:1px solid var(--border);width:100%;min-height:48px;color:var(--text);background:#fff;border-radius:8px;padding:0 12px}.passcode-panel input:focus{border-color:var(--accent);outline:3px solid #2454472e}.form-error{color:var(--danger);margin:0;font-size:.92rem;font-weight:700}.empty-state{text-align:center;padding:28px 18px}.empty-state h2{margin:0 0 6px;font-size:1.2rem}.empty-state p{color:var(--muted);margin:0}.aisle-stack{gap:10px;padding-bottom:20px;display:grid}.aisle-group{border:1px solid var(--border);background:var(--surface);border-radius:8px;overflow:hidden}.aisle-group header{background:var(--surface-muted);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:12px;min-height:38px;padding:7px 11px;display:flex}.aisle-group h2{margin:0;font-size:.96rem}.aisle-group header span{min-width:24px;height:24px;color:var(--accent-strong);background:#fff;border-radius:999px;place-items:center;font-size:.82rem;font-weight:800;display:inline-grid}.aisle-group ul{margin:0;padding:0;list-style:none;display:grid}.aisle-empty{color:var(--muted);margin:0;padding:14px;font-size:.9rem}.aisle-group li{border-bottom:1px solid var(--border);min-height:48px;padding:0}.aisle-group li:last-child{border-bottom:0}.aisle-group li.checked{color:var(--muted);opacity:.78;background:#fbfcfa}.aisle-group li.checked .item-title{text-decoration:line-through}.item-row{grid-template-columns:44px minmax(0,1fr);align-items:stretch;gap:7px;width:100%;padding:5px 9px;display:grid}.check-button{border:2px solid var(--accent);color:var(--accent);width:44px;min-height:44px;background:#fff;border-radius:7px;place-items:center;padding:0;font-size:1.1rem;font-weight:900;display:inline-grid}.checked .check-button{color:#fff;background:var(--accent)}.item-main{min-width:0;min-height:44px;color:inherit;text-align:left;background:0 0;border-radius:7px;align-content:center;justify-items:start;padding:3px 2px;display:grid}.item-title{overflow-wrap:anywhere;max-width:100%;font-weight:800;line-height:1.12}.item-meta{overflow-wrap:anywhere;max-width:100%;color:var(--muted);margin-top:2px;font-size:.8rem;line-height:1.15}.sheet-backdrop{z-index:20;background:#17231f52;align-items:end;display:grid;position:fixed;inset:0}.edit-sheet{width:min(720px,100%);max-height:min(78vh,680px);padding:14px 14px calc(14px + env(safe-area-inset-bottom));background:#fff;border-radius:14px 14px 0 0;margin:0 auto;overflow:auto;box-shadow:0 -18px 38px #17231f2e}.edit-sheet form{gap:12px;display:grid}.edit-sheet header{justify-content:space-between;align-items:center;gap:12px;display:flex}.edit-sheet h2{margin:0;font-size:1.1rem}.sheet-close{min-width:38px;min-height:38px;padding:0;font-size:1.4rem}.edit-actions{flex-wrap:wrap;gap:8px;display:flex}.edit-sheet .edit-actions{grid-template-columns:1fr 1fr;display:grid}.edit-sheet .edit-actions .danger-button{grid-column:1/-1}.recipes-view{gap:14px;display:grid}.recipe-create,.recipe-edit,.ingredient-add,.ingredient-edit-form,.nutrition-form{border:1px solid var(--border);background:var(--surface);border-radius:8px;grid-template-columns:minmax(0,1fr) minmax(82px,.3fr) minmax(82px,.3fr) minmax(130px,.8fr) auto;align-items:end;gap:10px;padding:12px;display:grid}.recipe-layout{grid-template-columns:minmax(150px,.42fr) minmax(0,1fr);align-items:start;gap:14px;display:grid}.ingredient-name-field{min-width:min(180px,100%)}.recipe-list{gap:8px;display:grid}.recipe-list button{min-height:54px;color:var(--text);border:1px solid var(--border);text-align:left;background:#fff;justify-items:start;display:grid}.recipe-list button.active{color:#fff;background:var(--accent);border-color:var(--accent)}.recipe-list small,.ingredient-row small{color:inherit;opacity:.75}.recipe-detail{gap:12px;min-width:0;display:grid}.ingredient-list{gap:8px;display:grid}.ingredient-row{border:1px solid var(--border);background:#fff;border-radius:8px;grid-template-columns:28px minmax(0,1fr) auto;align-items:center;gap:10px;min-width:0;padding:10px;display:grid}.ingredient-actions{flex-wrap:wrap;justify-content:flex-end;gap:8px;display:flex}.ingredient-actions .ghost-button{min-height:38px;padding:0 10px}.ingredient-row input{width:22px;height:22px}.ingredient-row span{overflow-wrap:anywhere;min-width:0;display:grid}.recipe-to-grocery{border:1px solid var(--border);background:var(--surface-muted);border-radius:8px;flex-wrap:wrap;align-items:end;gap:10px;padding:12px;display:flex}.nutrition-panel{border:1px solid var(--border);background:#fff;border-radius:8px}.nutrition-panel summary{min-height:48px;color:var(--accent);cursor:pointer;padding:14px;font-weight:800}.nutrition-form{border:0;border-top:1px solid var(--border);border-radius:0;grid-template-columns:repeat(2,minmax(0,1fr))}.loading-mark{border:4px solid var(--border);border-top-color:var(--accent);border-radius:999px;width:34px;height:34px;animation:.8s linear infinite spin}.muted{color:var(--muted)}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width:420px){.shell{padding-left:10px;padding-right:10px}h1{font-size:1.55rem}.topbar{align-items:flex-start;margin-bottom:8px}.ghost-button{padding:0 12px}.edit-actions button{min-height:44px}.recipe-create,.recipe-edit,.ingredient-add,.ingredient-edit-form,.nutrition-form,.recipe-layout{grid-template-columns:1fr}.ingredient-row{grid-template-columns:28px minmax(0,1fr)}.ingredient-row .ingredient-actions{grid-column:2;justify-content:flex-start;justify-self:start}}
