:root{--gap:12px;--card-bg:#fff;--accent:#2b7a78}
*{box-sizing:border-box;font-family:Inter,system-ui,Segoe UI,Arial,sans-serif}
body{margin:0;background:#f6f7f8;color:#111}
.header-left{display:flex;align-items:center;gap:12px}
header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;background:var(--accent);color:#fff}
.controls{display:flex;align-items:center;gap:12px}
.status{display:flex;gap:8px;align-items:center}
.status .badge{background:rgba(255,255,255,0.18);padding:6px 8px;border-radius:6px;font-size:13px;color:#fff;border:1px solid rgba(255,255,255,0.06)}
.controls button{margin-left:8px;padding:8px 12px;border-radius:6px;border:none;background:rgba(255,255,255,0.12);color:#fff}
.grid{display:grid;grid-template-columns:repeat(7,1fr);gap:var(--gap);padding:20px}
.card{background:var(--card-bg);padding:12px;border-radius:8px;box-shadow:0 1px 3px rgba(0,0,0,.08)}
.card h3{margin:0 0 8px;font-size:16px}
.card p{margin:0;color:#444}
.card .notes{margin-top:8px;font-size:13px;color:#666}
.card.editable{cursor:pointer;border:2px dashed #e6e6e6}
/* Visual separation for meal slots inside each day card */
.meal-slot{border:1px solid rgba(0,0,0,0.06);background:#fff;padding:10px;border-radius:8px;margin-bottom:10px}
.meal-slot strong{display:block;margin-bottom:6px;color:#222;font-weight:600}
.meal-slot .notes{margin-top:6px;color:#666;font-size:13px}

/* Edit-mode input styles */
.meal-input-name{width:100%;padding:8px;border:1px solid rgba(0,0,0,0.08);border-radius:6px;font-size:14px}
.meal-input-notes{width:100%;padding:8px;border:1px solid rgba(0,0,0,0.06);border-radius:6px;font-size:13px;margin-top:6px;min-height:44px}
.modal{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.35)}
.modal.hidden{display:none}
.modal-content{background:#fff;padding:16px;border-radius:8px;max-width:420px;width:100%}
.modal-actions{display:flex;gap:8px;margin-top:12px}
@media (max-width:1200px){
	.grid{grid-template-columns:repeat(4,1fr)}
}

@media (max-width:800px){
	/* switch to horizontal, scrollable row on small screens so all 7 days remain reachable */
	.grid{display:flex;overflow-x:auto;padding:12px;gap:var(--gap);-webkit-overflow-scrolling:touch}
	.card{min-width:220px;flex:0 0 220px}
}

@media (max-width:420px){
	.card{min-width:180px;flex:0 0 180px}
}
