/* styles.css - Optimized spacing and meal cards */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;600;700&display=swap');
:root{
  --g1:#0b7a3d;
  --g2:#34c759;
  --accent:#1bb76a;
  --bg:#f7fff7;
  --card:#ffffff;
  --muted:#6b7a6b;
}
*{box-sizing:border-box;font-family:Inter, system-ui, -apple-system, Roboto, "Helvetica Neue", Arial;}
body{margin:0;background:linear-gradient(180deg,#f0fff4,#ffffff);color:#12391f;}
.hidden{display:none;}
.splash{height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--g1),var(--g2));color:white;text-align:center}
.apple-hero{width:220px;height:220px;border-radius:50%;background:radial-gradient(circle at 30% 25%,#b6f5b7,#2aa84f);position:relative;display:flex;align-items:center;justify-content:center;box-shadow:0 28px 80px rgba(0,0,0,0.25);animation:float 3s ease-in-out infinite}
@keyframes float {0%{transform:translateY(-6px)}50%{transform:translateY(8px)}100%{transform:translateY(-6px)}}
.apple-face{font-size:80px}
.splash h1{margin-top:18px;font-size:24px;opacity:0.98}
.splash p{opacity:0.9;margin-top:6px}

main{padding:20px 24px}
.card{background:var(--card);border-radius:14px;padding:18px;margin-bottom:16px;box-shadow:0 8px 38px rgba(6,30,12,0.06);border:1px solid rgba(10,140,50,0.04)}
.topbar{display:flex;align-items:center;justify-content:space-between;padding:12px;border-radius:12px;background:linear-gradient(90deg,#f9fff9,#f0fff4)}
.container{display:flex;gap:16px;margin-top:18px}
.leftPane{width:28%;display:flex;flex-direction:column;gap:16px}
.centerPane{flex:1;display:flex;flex-direction:column;gap:16px}
.rightPane{width:28%;display:flex;flex-direction:column;gap:16px}

/* meals area */
.mealsCard{padding:12px}
.mealsList{display:flex;flex-direction:column;gap:12px;margin-top:12px}
.mealCard{border-radius:12px;padding:12px;background:linear-gradient(180deg,#f7fff7,#f0fff4);border:1px solid rgba(10,120,40,0.04);display:flex;flex-direction:column;gap:8px}
.mealHeader{display:flex;justify-content:space-between;align-items:center;padding-bottom:6px;border-bottom:1px solid rgba(10,120,40,0.03)}
.mealFoods{display:flex;flex-direction:column;gap:8px;padding-top:6px}
.foodRow{display:flex;justify-content:space-between;align-items:center;padding:6px;border-radius:8px;background:white;border:1px solid #f0fff4}
.foodRow .info{display:flex;flex-direction:column}

/* daily calc */
.smallCard{margin-top:14px;padding:10px}

/* search & food list */
.searchRow{display:flex;gap:8px}
.foodResults{max-height:260px;overflow:auto;border-top:1px solid #eef7ee;padding-top:8px;margin-top:8px}
.foodItem{padding:10px;border-radius:10px;cursor:pointer;display:flex;justify-content:space-between;align-items:center}
.foodItem:hover{background:#f0fff6}

/* water */
.waterCard .cup{width:120px;height:160px;border-radius:18px;border:6px solid #dff6e3;position:relative;overflow:hidden;background:#fff;margin:6px 0}
.waterCard .fill{position:absolute;left:0;right:0;bottom:0;height:0%;background:linear-gradient(#76e08a,#0bb44a);transition:height 600ms ease}

/* others */
.prizesList{display:flex;flex-wrap:wrap;gap:8px}
.prize{padding:8px 12px;border-radius:12px;background:linear-gradient(180deg,#fff8e6,#fff1d0);border:1px solid rgba(0,0,0,0.04)}
.tiny{font-size:12px;color:var(--muted)}
.btn{padding:8px 12px;border-radius:10px;border:none;background:#eefae9;cursor:pointer}
.btn.small{padding:6px 8px;font-size:13px}
.btn.primary{background:linear-gradient(90deg,var(--g2),var(--g1));color:white}
.btn.green{background:linear-gradient(90deg,#2ed06a,#0b8a3c);color:white}
.modal{position:fixed;left:0;right:0;top:0;bottom:0;background:rgba(0,0,0,0.35);display:flex;align-items:center;justify-content:center;z-index:9999}
.modal.hidden{display:none}
.modalCard{background:white;padding:18px;border-radius:12px;width:92%;max-width:920px;max-height:90vh;overflow:auto;position:relative}
.closeBtn{position:absolute;right:14px;top:10px;border:none;background:transparent;font-size:26px;cursor:pointer}

/* responsive */
@media(max-width:980px){
  .container{flex-direction:column}
  .leftPane,.rightPane{width:100%}
}