
:root{
  --bg:#f7f3eb;
  --card:#fffdf8;
  --text:#27241f;
  --muted:#6d675e;
  --accent:#50724f;
  --accent-dark:#365136;
  --line:#ded8ce;
  --soft:#e8efe5;
  --shadow:0 16px 40px rgba(64,52,38,.09);
}
*{box-sizing:border-box}
body{margin:0;background:var(--bg);color:var(--text);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif}
button,input{font:inherit}
button{border:0;border-radius:12px;background:var(--accent);color:white;padding:.8rem 1rem;font-weight:700;cursor:pointer}
button:hover{background:var(--accent-dark)}
.hero{max-width:1100px;margin:auto;padding:3rem 1.25rem 1.5rem;display:flex;justify-content:space-between;gap:1rem;align-items:flex-start}
.hero h1{font-size:clamp(2.2rem,6vw,4.5rem);line-height:.95;margin:.3rem 0 .8rem;letter-spacing:-.05em}
.hero p{margin:0;color:var(--muted)}
.eyebrow{text-transform:uppercase;letter-spacing:.14em;font-size:.75rem;font-weight:800;color:var(--accent)!important}
.ghost,.secondary{background:transparent;color:var(--text);border:1px solid var(--line)}
.ghost:hover,.secondary:hover{background:#fff}
.tabs{position:sticky;top:0;z-index:5;background:rgba(247,243,235,.9);backdrop-filter:blur(12px);display:flex;gap:.5rem;max-width:1100px;margin:auto;padding:1rem 1.25rem}
.tab{background:transparent;color:var(--muted)}
.tab.active{background:var(--text);color:white}
main{max-width:1100px;margin:auto;padding:1rem 1.25rem 4rem}
.view{display:none}.view.active{display:block}
.meal-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1rem}
.day-card{background:var(--card);border:1px solid var(--line);border-radius:22px;padding:1.2rem;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:1rem}
.day-card h2{margin:0;font-size:1.5rem}
.meal-block{border-top:1px solid var(--line);padding-top:.9rem}
.meal-label{text-transform:uppercase;font-size:.7rem;letter-spacing:.12em;font-weight:800;color:var(--accent);margin-bottom:.3rem}
.meal-name{font-size:1.02rem;line-height:1.4}
.meal-image,.recipe-image{display:block;width:100%;max-width:100%;height:auto;aspect-ratio:3/2;object-fit:cover;background:#e8e0d2}
.meal-image{margin-bottom:.8rem;border-radius:14px}
.recipe-image{margin-bottom:1.25rem;border-radius:18px}
.recipe-btn{width:100%;margin-top:auto}
.shopping-toolbar{display:flex;justify-content:space-between;gap:1rem;align-items:center;margin-bottom:1rem}
.shopping-toolbar h2{margin:0 0 .2rem}.shopping-toolbar p{margin:0;color:var(--muted)}
.toolbar-actions{display:flex;gap:.5rem;flex-wrap:wrap}
.shopping-list{display:grid;gap:.55rem}
.shopping-item{display:flex;align-items:center;gap:.8rem;background:var(--card);border:1px solid var(--line);padding:.85rem 1rem;border-radius:14px}
.shopping-item input{width:1.2rem;height:1.2rem;accent-color:var(--accent)}
.shopping-item.checked span{text-decoration:line-through;color:var(--muted)}
.shopping-item .delete{margin-left:auto;background:transparent;color:var(--muted);padding:.25rem .5rem;font-size:1.1rem}
dialog{border:0;border-radius:24px;padding:0;max-width:720px;width:calc(100% - 2rem);box-shadow:0 30px 80px rgba(0,0,0,.25)}
dialog::backdrop{background:rgba(25,23,20,.55);backdrop-filter:blur(4px)}
.dialog-shell{padding:1.5rem;position:relative;background:var(--card);max-height:85vh;overflow:auto}
.dialog-shell.small{max-width:460px}
.dialog-close{position:absolute;right:1rem;top:1rem;width:2.3rem;height:2.3rem;padding:0;border-radius:50%;background:#eee9df;color:var(--text);font-size:1.5rem}
.recipe-meta{display:flex;gap:.5rem;flex-wrap:wrap;margin:.8rem 0 1.2rem}
.badge{background:var(--soft);color:var(--accent-dark);padding:.4rem .7rem;border-radius:999px;font-size:.85rem;font-weight:700}
.recipe-columns{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}
.recipe-columns h3{margin-top:0}
.recipe-columns ul,.recipe-columns ol{padding-left:1.2rem;line-height:1.6}
.add-all{width:100%;margin-top:1rem}
label{display:grid;gap:.4rem;font-weight:700;margin:1rem 0}
input[type="text"],input:not([type]){border:1px solid var(--line);border-radius:12px;padding:.85rem;background:white}
@media(max-width:650px){
  .hero{padding-top:2rem}
  .hero .ghost{display:none}
  .shopping-toolbar{align-items:flex-start;flex-direction:column}
  .recipe-columns{grid-template-columns:1fr}
}
