:root{color:#1f2933;--font-size-base:13px;background:#f7f2ea;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}*{box-sizing:border-box}body{font-size:var(--font-size-base);margin:0;line-height:1.4}button,input,select{font:inherit}button{cursor:pointer}.app-shell{max-width:1400px;min-height:100vh;margin:0 auto;padding:12px 20px}.top-bar,.inventory-strip,.panel{background:#fff;border:1px solid #3d2a1c1a;border-radius:8px;box-shadow:0 2px 4px #0000000d}.top-bar{justify-content:space-between;align-items:center;gap:16px;margin-bottom:12px;padding:8px 16px;display:flex}.top-bar-branding{min-width:0}.brand-title-line{align-items:center;gap:14px;min-width:0;display:flex}.brand-name-stack{flex:none;justify-items:center;gap:1px;display:grid}.brand-name-stack h1{color:#7c2d12;margin:0;font-size:1.25rem;line-height:1.05}.brand-name-stack strong{color:#292524;font-size:.82rem;font-weight:800;line-height:1.05}.top-bar-branding p,.top-bar-branding .eyebrow{color:#666;margin:0;font-size:.74rem;line-height:1.2}.settings-bar{align-self:flex-start;align-items:flex-start;gap:8px;display:flex}.settings-bar label{align-items:center;gap:4px;font-size:.8rem;display:flex}.settings-bar select,.settings-bar button{border-radius:4px;min-height:28px;padding:2px 8px;font-size:.8rem}.settings-bar>label{display:none}.language-toggle{align-items:center;gap:3px;font-weight:800;display:inline-flex}.language-toggle span{color:#78716c}.language-toggle .active{color:#7c2d12}.language-divider{color:#d6d3d1}.contact-modal textarea{resize:vertical;min-height:110px}.contact-status{color:#57534e;margin:8px 0 0;font-size:.82rem}.inventory-strip{margin-bottom:12px;padding:12px 16px}.inventory-strip .section-heading{grid-template-columns:minmax(0,2fr) minmax(220px,1fr);align-items:center;gap:12px;min-height:32px;margin-bottom:12px;display:grid;position:relative}.inventory-heading-main{align-items:center;min-width:0;display:flex;position:relative}.inventory-heading-side{justify-content:flex-end;align-items:center;min-width:0;height:28px;display:flex;position:absolute;top:50%;right:0;transform:translateY(-50%)}.inventory-heading-side .text-button{justify-content:center;align-items:center;min-height:28px;line-height:1;display:inline-flex}.inventory-strip h2{color:#333;margin:0;font-size:.95rem}.inventory-random-note{color:#78716c;margin-left:6px;font-size:.76rem;font-weight:600}.section-index{color:#0f766e;min-width:1.35rem;margin-right:.25rem;font-family:Georgia,Times New Roman,serif;font-weight:800;display:inline-block}.guest-limit-note{color:#78716c;white-space:nowrap;pointer-events:none;font-size:.76rem;font-weight:700;line-height:1.2;position:absolute;left:50%;transform:translate(-50%)}.inventory-library-layout{grid-template-columns:minmax(0,2fr) minmax(220px,1fr);align-items:start;gap:12px;display:grid}.inventory-lanes{gap:4px;min-width:0;display:grid}.category-row{align-items:stretch;gap:8px;min-height:34px;display:flex}.category-row h3{color:#4b5563;text-transform:uppercase;background:#f9fafb;border:1px solid #e5e7eb;border-radius:4px;flex:0 0 100px;width:100px;margin:0;padding:7px 8px;font-size:.72rem;font-weight:700;line-height:1.2}.category-drop-zone{background:#fff;border:1px solid #d1d5db;border-radius:4px;flex-wrap:wrap;flex:1;align-items:flex-start;gap:5px;min-height:34px;padding:4px 6px;transition:border-color .15s,background .15s;display:flex}.category-drop-zone.over{background:#fff7ed;border-color:#7c2d12}.chip-wrapper{min-height:24px;display:inline-flex;position:relative}.chip{white-space:nowrap;background:#fffaf2;border:1px solid #d6b98c;border-radius:4px;min-height:24px;padding:2px 22px 2px 7px;font-size:.75rem;line-height:1.2;transition:all .2s}.chip.selected{color:#fff;background:#7c2d12;border-color:#7c2d12}.chip-wrapper .delete-btn{color:#fff;cursor:pointer;z-index:50;pointer-events:auto;background:#ef4444;border:2px solid #fff;border-radius:50%;justify-content:center;align-items:center;width:18px;height:18px;padding:0;font-size:11px;font-weight:700;display:flex;position:absolute;top:0;right:0;box-shadow:0 1px 3px #0000004d}.text-button{color:#7c2d12;background:0 0;border:0;padding:2px 6px;font-size:.8rem;text-decoration:underline}.inline-form{gap:6px;max-width:600px;display:flex}.inline-form input{min-height:28px;padding:4px 8px;font-size:.8rem}.content-grid{grid-template-columns:240px 1fr 260px;align-items:stretch;gap:12px;margin-top:16px;display:grid}.panel{flex-direction:column;min-height:70vh;padding:12px;display:flex}.panel h2{color:#333;margin:0 0 10px;font-size:.95rem}.settings-panel{grid-template-columns:1fr;grid-auto-rows:max-content;align-content:start;gap:10px;display:grid}.settings-panel label{gap:2px;font-weight:600;display:grid}.settings-panel input,.settings-panel select{width:100%;min-height:30px;padding:2px 6px}.switch-row{justify-content:flex-start;align-items:center;gap:8px;margin:12px 0;display:flex}.switch-row input[type=checkbox]{cursor:pointer;width:16px;height:16px;margin:0}.switch-row label{cursor:pointer;-webkit-user-select:none;user-select:none;margin:0;font-size:.85rem;font-weight:400}.primary-action{color:#fff;background:#7c2d12;border:0;border-radius:6px;width:100%;margin-top:12px;padding:10px;font-size:.9rem}.primary-action:disabled{color:#f5f5f4;cursor:not-allowed;opacity:.8;background:#a8a29e}.generation-status{color:#57534e;background:#fafaf9;border:1px solid #e7e5e4;border-radius:4px;min-height:30px;margin-top:6px;padding:7px 9px;font-size:.78rem;line-height:1.3}.compact-generate-controls{gap:6px;margin-top:4px;display:grid}.compact-help-text{color:#78716c;font-size:.72rem;line-height:1.25}.compact-switch-row{white-space:nowrap;align-items:flex-start;gap:5px;min-height:22px;font-size:.7rem;line-height:1.2;display:flex}.compact-switch-row input{flex:none;width:14px;height:14px;margin:1px 0 0}.compact-switch-row label{white-space:nowrap;flex:auto;margin:0;font-weight:500}.compact-number-row{justify-content:space-between;align-items:center;min-height:28px;font-size:.78rem;grid-template-columns:none!important;gap:8px!important;display:flex!important}.compact-number-row span{font-weight:600}.compact-number-row input{text-align:center;width:64px!important;min-height:26px!important;padding:2px 6px!important}.compact-generate-button{margin-top:2px;padding:8px;font-size:.82rem}.results-area{flex:1;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:10px;margin-top:10px;display:grid}.placeholder-text{color:#94a3b8;text-align:center;grid-column:1/-1;margin-top:40px;font-style:italic}.recommendation-card{background:#fff;border:1px solid #e2e8f0;border-radius:6px;flex-direction:column;gap:9px;padding:28px 14px 14px;display:flex;position:relative}.recommendation-card h3{color:#292524;text-align:center;margin:0;font-size:1.02rem;line-height:1.25}.recipe-number{color:#7c2d12;letter-spacing:0;align-self:center;font-family:Georgia,Times New Roman,serif;font-size:1.65rem;font-weight:700;line-height:1}.recipe-tags{flex-wrap:wrap;justify-content:center;align-items:center;gap:5px;display:flex}.recipe-tags span{color:#854d0e;background:#fefce8;border-radius:999px;padding:3px 7px;font-size:.7rem;line-height:1.2}.icon-tags{flex-wrap:nowrap;gap:6px;font-size:.62rem}.icon-tags span{text-align:center;min-width:auto}.text-tag{color:#475569;white-space:nowrap;background:#f8fafc;border-radius:5px;justify-content:center;align-items:center;gap:3px;min-height:20px;padding:2px 5px;line-height:1.1;display:inline-flex}.text-tag strong{color:#1f2937;font-weight:700}.calorie-row{text-align:center;color:#854d0e;font-size:.72rem;line-height:1.2}.score-block{background:#fbfaf8;border:1px solid #e7e5e4;border-radius:6px;justify-items:center;gap:5px;width:100%;padding:7px 8px;display:grid}.favorite-action{color:#7c2d12;background:#fffaf2;border:1px solid #d6b98c;border-radius:5px;justify-self:start;min-height:26px;padding:3px 8px;font-size:.72rem;font-weight:700}.corner-favorite{position:absolute;top:8px;left:8px}.total-score{color:#7c2d12;justify-content:center;align-items:baseline;gap:3px;line-height:1;display:flex}.total-score span{color:#78716c;font-size:.68rem;font-weight:600;line-height:1.1}.total-score strong{font-size:1.55rem;font-weight:800}.total-score small{color:#78716c;font-size:.72rem;font-weight:700}.dimension-scores{grid-template-columns:repeat(4,minmax(0,1fr));gap:4px 6px;width:100%;display:grid}.dimension-scores span{color:#57534e;text-align:center;overflow-wrap:anywhere;padding:0;font-size:.64rem;line-height:1.25}.dimension-scores span:nth-child(5):last-child{grid-column:2/4}.select-recipe{color:#475569;background:#f8fafc;border:1px solid #d1d5db;border-radius:5px;min-height:28px;font-size:.74rem;font-weight:700}.select-recipe.no-leftovers{opacity:.75}.select-recipe.selected{color:#7c2d12;background:#fff7ed;border-color:#7c2d12}.no-leftovers-section{border-radius:5px;transition:color .12s,background .12s,box-shadow .12s}.no-leftovers-section.flash{animation:.42s ease-in-out 2 no-leftovers-flash}@keyframes no-leftovers-flash{0%,to{color:#44403c;box-shadow:none;background:0 0}45%{color:#b91c1c;background:#fee2e2;box-shadow:inset 0 0 0 1px #fecaca}}.leftover-action:disabled{opacity:.45}.leftover-results{margin-top:12px}.food-library{background:#fff;border:1px solid #f1f5f9;border-radius:6px;flex-direction:column;min-width:0;min-height:0;padding:8px;display:flex;overflow:hidden}.food-library-toggle{color:#7c2d12;background:0 0;border:0;align-items:center;gap:3px;width:100%;padding:2px 0;font-size:.78rem;font-weight:800;display:flex}.food-library-toggle span{width:14px;display:inline-block}.food-library-body{flex:1;gap:6px;min-height:0;margin-top:6px;display:grid;overflow:auto}.food-library-group h4{color:#57534e;text-transform:uppercase;margin:0 0 4px;font-size:.68rem}.food-library-items{flex-wrap:wrap;gap:5px;min-width:0;display:flex}.food-library-item{align-items:center;gap:2px;display:inline-flex}.food-library-item button{color:#374151;white-space:normal;overflow-wrap:anywhere;text-align:left;background:#fff;border:1px solid #e5e7eb;border-radius:4px;min-height:24px;padding:2px 6px;font-size:.72rem}.food-library-item .mini-delete{color:#b91c1c;width:14px;min-width:14px;min-height:16px;padding:0;font-size:.62rem;line-height:1}.inventory-help{color:#78716c;white-space:pre-line;margin:6px 0 10px;font-size:.84rem;line-height:1.45}.food-share-consent{color:#44403c;align-items:center;gap:6px;margin-top:7px;font-size:.76rem;font-weight:700;display:flex}.food-share-consent input{width:14px;height:14px;margin:0}.food-share-consent small{color:#78716c;font-size:.76rem;font-weight:400;line-height:1.25}.recipe-section{gap:4px;display:grid}.recipe-section h4{color:#57534e;text-transform:uppercase;margin:0;font-size:.74rem}.recipe-section p{color:#44403c;margin:0}.recipe-section ul,.recipe-section ol{color:#44403c;margin:0;padding-left:18px}.recipe-section li+li{margin-top:3px}.history-panel{max-height:calc(100vh - 180px);overflow-y:auto}.history-item{border-bottom:1px solid #f1f5f9;padding:6px 0}.modal-backdrop{z-index:1000;background:#0006;justify-content:center;align-items:center;width:100vw;height:100vh;display:flex;position:fixed;top:0;left:0}.modal{background:#fff;border-radius:12px;width:90%;max-width:400px;padding:20px;box-shadow:0 10px 25px #0000001a}.settings-modal{flex-direction:column;max-width:560px;max-height:min(86vh,760px);display:flex;overflow-y:auto}.modal-title-row{justify-content:space-between;align-items:center;gap:12px;margin-bottom:2px;display:flex}.modal-title-row h2{margin:0}.modal-close-button{color:#57534e;background:#fff;border:1px solid #e7e5e4;border-radius:6px;flex:none;width:30px;height:30px;font-size:1.25rem;line-height:1}.modal-close-button:hover{color:#292524;background:#fafaf9}.settings-section{background:#fff;border:1px solid #e7e5e4;border-radius:8px;gap:10px;margin-top:14px;padding:12px;display:grid}.settings-section-heading{justify-content:space-between;align-items:center;gap:8px;display:flex}.settings-section h3,.settings-section-heading h3{color:#292524;margin:0;font-size:.9rem}.settings-inline-form{max-width:100%}.settings-scroll-list{border:1px solid #eee;border-radius:6px;max-height:170px;padding:8px;overflow:auto}.settings-limit-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;display:grid}.settings-limit-grid label{gap:4px;margin:0;display:grid}.modal .auth-tabs{background:#f3f4f6;border-radius:8px;gap:4px;margin-bottom:20px;padding:4px;display:flex}.modal .auth-tab{color:#6b7280;background:0 0;border:0;border-radius:6px;flex:1;padding:6px 12px;font-size:.85rem}.modal .auth-tab.active{color:#111827;background:#fff;box-shadow:0 1px 3px #0000001a}.modal .form-grid{flex-direction:column;gap:15px;margin:15px 0;display:flex}.modal label{margin-bottom:4px;font-weight:700;display:block}.modal input{border:1px solid #ddd;border-radius:4px;width:100%;min-height:36px;padding:8px;display:block}.password-field{grid-template-columns:1fr auto;align-items:stretch;display:grid}.password-field input{border-radius:4px 0 0 4px}.password-field button{color:#57534e;background:#fafaf9;border:1px solid #ddd;border-left:0;border-radius:0 4px 4px 0;min-width:54px;font-size:.76rem}.captcha-question{color:#57534e;background:#fafaf9;border:1px solid #e7e5e4;border-radius:4px;margin:4px 0;padding:3px 7px;font-size:.78rem;display:inline-block}.modal-actions{justify-content:flex-end;gap:10px;margin-top:15px;display:flex}.admin-only{color:#7c2d12;font-size:.75rem;font-weight:700}.category-settings-row{border-bottom:1px solid #f9f9f9;justify-content:space-between;align-items:center;gap:8px;padding:4px 0;font-size:.8rem;display:flex}.category-settings-row .text-button:disabled{color:#9ca3af;cursor:not-allowed;text-decoration:none}.settings-note-editor{gap:8px;display:grid}.settings-note-editor h3{margin:0}.settings-note-editor textarea{resize:vertical;width:100%;min-height:54px;font:inherit;border:1px solid #ddd;border-radius:4px;padding:8px;font-size:.78rem}.invite-code-latest{color:#7c2d12;background:#fffaf2;border:1px solid #d6b98c;border-radius:6px;gap:3px;margin-top:10px;padding:8px;display:grid}.invite-code-latest span{color:#78716c;font-size:.72rem}.invite-code-latest strong{letter-spacing:.04em;font-size:1.05rem}.invite-code-list{border:1px solid #eee;gap:4px;max-height:200px;margin-top:12px;padding:8px;display:grid;overflow:auto}.invite-code-row{border-bottom:1px solid #f9f9f9;grid-template-columns:1fr auto auto;align-items:center;gap:8px;font-size:.76rem;display:grid}.invite-code-empty{color:#78716c;font-size:.76rem}@media (width<=1000px){.content-grid{grid-template-columns:240px 1fr}.history-panel{grid-column:span 2;max-height:none}}@media (width<=700px){.content-grid{grid-template-columns:1fr}.inventory-strip .section-heading{grid-template-columns:1fr;align-items:start;gap:7px;min-height:0}.inventory-heading-main{gap:4px;display:grid}.inventory-heading-side{justify-content:flex-start;height:auto;position:static;transform:none}.guest-limit-note{white-space:normal;margin-left:0;position:static;transform:none}.inventory-library-layout{grid-template-columns:1fr}.history-panel{grid-column:span 1}.top-bar{flex-direction:column;align-items:flex-start}.brand-title-line{flex-wrap:wrap;gap:6px 12px}}
