:root{font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.45;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:#101828;background:#f4f6f6}*{box-sizing:border-box}body{margin:0;min-width:320px}#root{width:100%}.layout{display:grid;grid-template-columns:236px 1fr;min-height:100vh}.sidebar{border-right:1px solid #eaecf0;background:#fff;padding:1.4rem 1rem}.brand{margin:0;font-size:1.6rem;letter-spacing:-.03em;text-align:center}.brand-subtitle{margin:.25rem 0 1.4rem;color:#667085;font-size:.9rem;text-align:center}.menu{display:flex;flex-direction:column;gap:.2rem}.menu-item{text-decoration:none;color:#344054;border-radius:10px;padding:.6rem .7rem;font-size:.96rem;border:none;background:none;cursor:pointer;width:100%;text-align:left}.menu-item:hover{background:#f2f4f7}.menu-item.active{background:#eff4f2;color:#1f2937;font-weight:600}.app-shell{width:min(1320px,100%);margin:0 auto;padding:2rem 2rem 3rem}.hero{text-align:center;max-width:860px;margin:0 auto 1.25rem}.hero h1{margin:0;font-size:clamp(2.1rem,4vw,3rem);font-family:Georgia,Times New Roman,serif;letter-spacing:-.02em}.hero p{margin:.6rem 0 0;color:#667085;font-size:1.05rem}.panel{background:#fff;border:1px solid #eaecf0;border-radius:16px;padding:1.25rem 1.35rem}.search-panel{width:100%;margin:0 0 1rem}.search-row{display:grid;gap:.55rem;grid-template-columns:1fr 48px 160px;align-items:center}.search-input{border:1px solid #d0d5dd;border-radius:12px;height:48px;padding:0 .95rem;font:inherit}.search-input:focus{outline:none;border-color:#86efac;box-shadow:0 0 0 3px #dcfce7}button{border:1px solid #d0d5dd;border-radius:10px;padding:.6rem .9rem;background:#fff;cursor:pointer;font:inherit}button:disabled{opacity:.55;cursor:not-allowed}.add-circle-button{width:48px;height:48px;aspect-ratio:1 / 1;border-radius:50%;padding:0;font-size:1.1rem;font-weight:700;line-height:1;display:inline-flex;align-items:center;justify-content:center;background:#1f8b67;color:#fff;border-color:#1f8b67}.compare-button{background:#2f8f6a;border-color:#2f8f6a;color:#fff;font-weight:600;height:48px;min-height:48px;width:100%}.chip-row{margin-top:.7rem;display:flex;gap:.45rem;flex-wrap:wrap}.item-chip{border-radius:999px;background:#f2f4f7;border-color:#eaecf0;color:#344054;padding:.35rem .6rem;font-size:.88rem}.item-chip span{opacity:.65;margin-left:.18rem}.store-selector-wrap{margin-top:.75rem}.store-selector{border:none;padding:0;margin:0;display:flex;gap:.45rem;flex-wrap:wrap}.store-pill{border-radius:999px;padding:.36rem .68rem;background:#f8fafc;border-color:#d0d5dd;color:#344054}.store-pill.selected{border-color:#70e4b5;background:#ecfdf3;color:#067647;font-weight:600}.error-banner{margin-top:.75rem;background:#fef3f2;border:1px solid #fecdca;color:#b42318;padding:.65rem .75rem;border-radius:10px;font-size:.93rem}.results-header{display:flex;justify-content:space-between;align-items:center;gap:.9rem;margin-bottom:.3rem}.results-header h2{margin:0;font-size:2rem;font-family:Georgia,Times New Roman,serif}.results-subtitle{margin:0 0 .95rem;color:#667085}.savings-pill{margin:0;border-radius:999px;padding:.45rem .8rem;background:#eafaf2;color:#1a7f5a;font-weight:600;font-size:.93rem;border:1px solid #ccefdc}.comparison-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(318px,1fr));gap:.9rem}.compare-card{border:1px solid #eaecf0;border-radius:14px;padding:.85rem;background:#fff;width:100%;text-align:left;cursor:default;transition:border-color .18s ease,box-shadow .18s ease}.compare-card:hover{border-color:#c9d2de}.compare-card.expanded{border-color:#9ed7bf;box-shadow:0 6px 16px #10182814}.compare-card-header{display:flex;justify-content:space-between;align-items:center;gap:.75rem;margin-bottom:.55rem}.compare-card h3{margin:0;font-size:1.1rem;font-family:Georgia,Times New Roman,serif}.best-badge{border-radius:999px;background:#eafaf2;color:#1a7f5a;border:1px solid #ccefdc;font-size:.78rem;font-weight:700;padding:.2rem .45rem}.match-list{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:.38rem}.match-row{border-radius:10px;padding:.58rem .65rem;border:1px solid #eaecf0;display:flex;justify-content:space-between;align-items:baseline;gap:.55rem;font-size:.95rem;color:#344054}.match-row.best-row{background:#edf7f3;border-color:#cbe8db}.match-row.missing{background:#fcfcfd;color:#667085}.price{color:#11644a;font-weight:700}.price small{color:#98a2b3;font-weight:500}.images-row{margin-top:.7rem;padding-top:.65rem;border-top:1px solid #eaecf0;display:grid;gap:.6rem;grid-template-columns:repeat(2,minmax(0,1fr))}.image-tile{border:1px solid #eaecf0;border-radius:10px;padding:.5rem;background:#fcfcfd;display:flex;flex-direction:column;gap:.45rem}.image-tile.best-store{border-color:#9ed7bf;background:#f3fbf7}.image-tile.missing{background:#fcfcfd}.image-tile-head{display:flex;align-items:center;justify-content:space-between;gap:.4rem}.image-tile-label{font-size:.83rem;color:#344054;text-align:left;font-weight:600}.image-tile-best{border-radius:999px;background:#eafaf2;color:#1a7f5a;border:1px solid #ccefdc;font-size:.7rem;font-weight:700;padding:.12rem .38rem}.image-tile img,.image-placeholder{width:100%;height:104px;border-radius:8px}.image-tile img{object-fit:cover;display:block;background:#fff}.image-placeholder{display:flex;align-items:center;justify-content:center;font-size:.8rem;color:#98a2b3;border:1px dashed #d0d5dd;background:#f9fafb}.image-tile-price{font-size:.92rem;font-weight:700;color:#11644a}.image-tile-price small{color:#98a2b3;font-weight:500}.image-tile-price.missing{color:#98a2b3}.meal-input-wrap{display:grid;gap:.55rem;grid-template-columns:1fr auto;align-items:center}.meal-input{width:100%}.meal-plan-button{background:#2f8f6a;border-color:#2f8f6a;color:#fff;font-weight:600;height:48px;white-space:nowrap;padding:0 1.2rem}.meal-suggestions{margin-top:.7rem;display:flex;gap:.45rem;flex-wrap:wrap}.ingredient-chip{cursor:default;pointer-events:none;background:#edf7f3;border-color:#cbe8db;color:#0d6e4a}.meal-loading-panel{margin-top:1rem;text-align:center;display:grid;gap:.5rem;justify-items:center;padding-block:2rem}.meal-loading-panel h2{margin:0;font-size:1.2rem}.meal-loading-step{margin:0;color:#11644a;font-weight:600}.meal-loading-note{margin:0;color:#667085;max-width:520px;font-size:.94rem}.meal-loading-spinner{width:28px;height:28px;border-radius:50%;border:3px solid #d1fae5;border-top-color:#2f8f6a;animation:meal-spin .9s linear infinite}.ingredients-panel{margin-top:1rem;margin-bottom:0}.ingredients-heading{margin:0 0 .75rem;font-size:1.15rem;font-family:Georgia,Times New Roman,serif;font-weight:600}.ingredients-heading em{font-style:italic;color:#1f8b67}.totals-section{margin-top:1rem}.empty-state{margin-top:1rem;text-align:center}.empty-state h2{margin:0;font-size:1.2rem}.empty-state p{margin:.4rem 0 0;color:#667085}@media(max-width:980px){.layout{grid-template-columns:1fr}.sidebar{border-right:none;border-bottom:1px solid #eaecf0}.menu{flex-direction:row;overflow-x:auto}.app-shell{padding:1.4rem 1rem 2rem}}@media(max-width:640px){.search-row,.meal-input-wrap{grid-template-columns:1fr}.add-circle-button{min-height:42px;border-radius:10px}.results-header{flex-direction:column;align-items:flex-start}.results-header h2{font-size:1.55rem}.comparison-grid,.images-row{grid-template-columns:1fr}}.section-header{display:flex;justify-content:space-between;align-items:center;gap:.75rem}.meta{margin:.2rem 0;color:#667085;font-size:.9rem}.totals-grid{display:grid;gap:.8rem;grid-template-columns:repeat(auto-fit,minmax(170px,1fr))}.total-card{border:1px solid #eaecf0;border-radius:12px;padding:.8rem}.total-card.best{border-color:#84caaf;background:#eefbf3}.total-price{font-size:1.3rem;font-weight:700;margin-bottom:.4rem}@keyframes meal-spin{to{transform:rotate(360deg)}}
