.meal-wrapper{max-width:1200px;margin:20px auto;padding:16px;border:1px solid #eee;border-radius:8px;background:#fff;font-family:Arial,sans-serif}
.meal-title{margin:0 0 12px}
.meal-meta{margin-bottom:14px;color:#333}

.meal-meta {
  color: #333;
  font-size: 18px;
}

.meal-wrapper {
  font-family: Arial,sans-serif;
  font-size: 12px;
}


.meal-weeks {
  display: grid;
  grid-template-columns: repeat(4, 1fr); /* 4 kolom desktop */
  gap: 16px;
}
@media(max-width:1024px){
  .meal-weeks { grid-template-columns: repeat(2, 1fr); }
}
@media(max-width:600px){
  .meal-weeks { grid-template-columns: 1fr; }
}

.meal-day {
  border:1px solid #ddd;
  padding:10px;
  border-radius:6px;
  background:#fcfcfc;
}


.meal-day{flex:1 1 30%;min-width:220px;border:1px solid #ddd;padding:10px;border-radius:6px;background:#fcfcfc}
.meal-day h4{margin:0 0 8px;font-size:14px}

.meal-desc{font-size:16px;color:#444;margin-bottom:8px;white-space:pre-wrap; line-height: 16px;}


.meal-variant-select{width:100%;padding:8px;border-radius:6px;border:1px solid #ccc}
.meal-footer{margin-top:16px;display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}
.meal-totals div{margin-bottom:4px;font-weight:600}
.meal-checkout-btn{background:#25D366;color:#fff;border:none;padding:10px 14px;border-radius:6px;cursor:pointer;font-weight:700}
.meal-checkout-btn:hover{opacity:.95}
.meal-day-img{width:100%;margin-bottom:8px;text-align:center}
.meal-day-img img{width:100%;height:auto;object-fit:cover;border-radius:6px;border:0px solid #ddd}


/* ========================
   Checkout Form Styling
   ======================== */
.meal-checkout-wrapper {
  max-width: 700px;
  margin: 30px auto;
  padding: 20px;
  background: #fff;
  border: 1px solid #eee;
  border-radius: 10px;
  box-shadow: 0 2px 8px rgba(0,0,0,0.06);
  font-family: sans-serif;
}

.meal-checkout-wrapper h2 {
  margin-bottom: 15px;
  font-size: 22px;
  border-bottom: 2px solid #f0f0f0;
  padding-bottom: 8px;
}

.meal-checkout-wrapper h3 {
  margin-top: 20px;
  font-size: 18px;
  color: #444;
}

#meal-checkout-form {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

#meal-checkout-form label {
  font-weight: 600;
  margin-bottom: 4px;
  display: block;
}

#meal-checkout-form input[type="text"],
#meal-checkout-form textarea {
  width: 100%;
  padding: 10px;
  border: 1px solid #ddd;
  border-radius: 6px;
  font-size: 14px;
  box-sizing: border-box;
}

#meal-checkout-form textarea {
  min-height: 80px;
  resize: vertical;
}

#meal-order-summary {
  background: #fafafa;
  border: 1px solid #ddd;
  padding: 12px;
  border-radius: 6px;
  font-size: 14px;
  line-height: 1.5;
}

#meal-order-summary ul {
  margin: 8px 0 0 20px;
  padding: 0;
}

#meal-checkout-form button {
  background: #157003;
  color: #fff;
  padding: 12px 20px;
  border: none;
  border-radius: 8px;
  font-size: 16px;
  font-weight: bold;
  cursor: pointer;
  transition: 0.3s;
}

#meal-checkout-form button:hover {
  background: #0e5302;
}

.meal-summary-list {
  margin: 8px 0 0 20px;
  padding: 0;
  list-style-type: decimal;
}
.meal-summary-list li {
  margin: 4px 0;
}



.meal-footer {
  margin-top: 12px;
  padding: 12px;
  border-top: 1px solid #eee;
  background: #fafafa;
  border-radius: 0 0 8px 8px;
}

.meal-totals div {
  font-size: 14px;
  margin: 4px 0;
}

.meal-totals strong {
  font-size: 16px;
  color: #157003;
}

.meal-actions {
  margin-top: 10px;
  text-align: right;
}

.meal-actions .meal-checkout-btn {
  background: #157003;
  color: #fff;
  padding: 8px 16px;
  border: none;
  border-radius: 6px;
  cursor: pointer;
  font-weight: 600;
  transition: 0.3s;
}

.meal-actions .meal-checkout-btn:hover {
  background: #0e5302;
}

/* Summary Box Fixed */
.meal-summary-fixed {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  background: #fff;
  border-top: 2px solid #eee;
  box-shadow: 0 -2px 6px rgba(0,0,0,0.08);
  padding: 10px 16px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  z-index: 9999;
}

.meal-summary-fixed .prices {
  font-size: 14px;
  line-height: 1.4;
}

.meal-summary-fixed .prices strong {
  font-size: 16px;
  color: #157003;
}

.meal-summary-fixed .checkout-btn {
  background: #157003;
  color: #fff;
  padding: 8px 16px;
  border-radius: 6px;
  border: none;
  font-weight: 600;
  cursor: pointer;
}

/* Mobile: ringkas */
@media(max-width:768px){
  .meal-summary-fixed .hide-mobile { display: none; }
}



.meal-grid {
  display: grid;
  gap: 20px;
}

.meal-grid.cols-2 { grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)); }
.meal-grid.cols-3 { grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); }
.meal-grid.cols-4 { grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); }

.meal-card {
  background: #fff;
  border: 1px solid #eee;
  border-radius: 8px;
  overflow: hidden;
  box-shadow: 0 2px 6px rgba(0,0,0,0.05);
  transition: transform .2s;
}
.meal-card:hover { transform: translateY(-3px); }

.meal-card .thumb img {
  width: 100%;
  display: block;
  height: auto;
  object-fit: cover;
}

.meal-card .meal-info {
  padding: 12px;
  text-align: center;
}

.meal-card .meal-info h3 {
  font-size: 16px;
  margin: 8px 0;
}

.meal-card .meal-info .price {
  color: #157003;
  font-weight: bold;
  margin: 6px 0;
}

.meal-card .meal-info .detail-btn {
  display: inline-block;
  margin-top: 8px;
  padding: 6px 14px;
  background: #157003;
  color: #fff;
  border-radius: 4px;
  font-size: 14px;
  text-decoration: none;
  transition: 0.3s;
}
.meal-card .meal-info .detail-btn:hover {
  background: #0e5302;
}
