
:root{
  --red:#d90000;
  --green:#25d366;
  --bg:#ffffff;
  --card:#f5f5f5;
  --muted:#666;
}

*{box-sizing:border-box}
body{margin:0;font-family:Arial,Helvetica,sans-serif;background:var(--bg);color:#111}

.topbar{
  background:#111;color:#fff;
  display:flex;flex-wrap:wrap;gap:10px;
  justify-content:center;align-items:center;
  padding:10px 14px;font-size:14px;text-align:center;
}
.topbar a{color:var(--green);font-weight:800;text-decoration:none}
.topbar span{color:#eee}

.hero{
  display:flex;gap:14px;align-items:center;justify-content:center;flex-wrap:wrap;
  background:var(--red);color:#fff;padding:18px 16px;
}
.logo{max-width:130px;border-radius:12px;background:#fff;padding:6px}
.heroText{text-align:center}
.heroText h1{margin:0;font-size:28px;letter-spacing:.5px}
.heroText p{margin:6px 0 0;opacity:.95}

.layout{display:flex;gap:18px;max-width:1200px;margin:16px auto;padding:0 16px;align-items:flex-start}
.hours{
  width:270px;flex:0 0 270px;
  background:#f3f3f3;border-radius:16px;padding:14px 14px 12px;
  box-shadow:0 6px 16px rgba(0,0,0,.08);
  position:sticky;top:12px;
}
.hours h3{margin:0 0 10px;color:var(--red)}
.hoursBlock{background:#fff;border-radius:14px;padding:10px 10px;margin-bottom:10px;box-shadow:0 2px 8px rgba(0,0,0,.06)}
.hoursTitle{font-weight:900;margin-bottom:6px}
.hoursLine{color:#222;font-size:14px;line-height:1.3}
.hoursNote{color:var(--red);font-weight:900;font-size:13px}

.main{flex:1;min-width:0}

.menu{padding:0}
h2{color:var(--red);margin:22px 0 12px}

.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:16px}

.card{
  background:var(--card);border-radius:16px;overflow:hidden;
  box-shadow:0 6px 16px rgba(0,0,0,.08);
}
.card .img{width:100%;height:130px;object-fit:cover;display:block}
.card .pad{padding:12px}
.card h3{margin:0 0 6px;font-size:16px}
.card p{margin:0 0 10px;color:var(--muted);font-size:13px;line-height:1.25}
.price{font-weight:900;color:var(--red);margin-bottom:10px}

.controls{display:flex;align-items:center;justify-content:space-between;gap:10px}
.qty{display:flex;align-items:center;gap:8px}
.qty button{
  width:32px;height:32px;border:0;border-radius:10px;cursor:pointer;
  background:#fff;box-shadow:0 2px 8px rgba(0,0,0,.08);font-size:16px
}
.qty span{min-width:18px;text-align:center;font-weight:900}

.add{
  flex:1;border:0;border-radius:12px;background:var(--green);color:#fff;
  padding:10px;cursor:pointer;font-weight:900;
}

.extras{display:flex;gap:10px;align-items:center;justify-content:center;margin-top:10px;flex-wrap:wrap}
.extras select{
  font-size:13px;color:#222;background:#fff;border-radius:12px;padding:8px 10px;
  box-shadow:0 2px 8px rgba(0,0,0,.06);
  border:0;
}

.cart{
  margin-top:18px;
  background:#efefef;padding:16px;border-radius:16px;
  box-shadow:0 6px 16px rgba(0,0,0,.08);
}
.cart h2{margin-top:0}

.formGrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:10px;margin-bottom:10px}
input,textarea,select{
  width:100%;padding:10px 12px;border-radius:12px;border:0;outline:none;
  box-shadow:0 2px 8px rgba(0,0,0,.06);
  font-size:14px;
}
textarea{min-height:80px;resize:vertical}
.labelBlock{display:flex;flex-direction:column;gap:6px;font-weight:800;color:#222}
.labelBlock span{font-size:13px;color:#333}

#cartList{list-style:none;padding:0;margin:12px 0 8px}
#cartList li{
  display:flex;justify-content:space-between;gap:10px;align-items:center;
  background:#fff;border-radius:12px;padding:10px 12px;margin-bottom:8px;
  box-shadow:0 2px 8px rgba(0,0,0,.06);
  font-size:14px;
}
.lineLeft{display:flex;flex-direction:column;gap:2px}
.lineName{font-weight:900}
.lineMeta{color:var(--muted);font-size:12px}
.lineBtns{display:flex;gap:6px;align-items:center}
.lineBtns button{
  width:34px;height:34px;border:0;border-radius:10px;cursor:pointer;background:#f3f3f3;
}

.totals{display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap}
#summary,#total{margin:6px 0;font-weight:900}

.whatsapp{
  width:100%;margin-top:10px;border:0;border-radius:14px;background:var(--green);color:#fff;
  padding:14px;font-size:18px;font-weight:900;cursor:pointer;
}

#toast{
  position:fixed;bottom:18px;left:50%;transform:translateX(-50%);
  background:#111;color:#fff;padding:12px 18px;border-radius:999px;
  opacity:0;pointer-events:none;transition:opacity .25s;
  box-shadow:0 10px 24px rgba(0,0,0,.22);z-index:999;
}
#toast.show{opacity:.92}

@media (max-width: 980px){
  .layout{flex-direction:column}
  .hours{width:100%;position:relative;top:auto}
}

.sideCart{
  margin-top:14px;
  background:#ffffff;
  border-radius:16px;
  padding:12px;
  box-shadow:0 6px 16px rgba(0,0,0,.08);
}
.sideCart h3{margin:0 0 10px;color:var(--red)}
.sideCart .whatsapp{margin-top:10px}

@media (max-width: 980px){
  .sideCart{
    margin-top:16px;
  }
}

.sideForm{
  margin-top:14px;
  background:#ffffff;
  border-radius:16px;
  padding:12px;
  box-shadow:0 6px 16px rgba(0,0,0,.08);
}
.sideForm h3{margin:0 0 10px;color:var(--red)}
.sideForm input,
.sideForm textarea,
.sideForm select{margin-bottom:8px}

@media (max-width: 980px){
  .sideForm, .sideCart{
    order:1;
  }
}

/* === CART OVERFLOW FIX === */
.sideCart ul{
  max-width:100%;
  overflow:hidden;
}
#cartList li{
  display:grid;
  grid-template-columns: 1fr auto;
  align-items:center;
  gap:8px;
}
.lineBtns{
  display:flex;
  gap:6px;
  align-items:center;
  flex-wrap:nowrap;
}
.lineBtns div{
  min-width:64px;
  text-align:right;
  white-space:nowrap;
}
.lineLeft{
  overflow:hidden;
}
.lineName{
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}

/* === FULL TEXT IN CART === */
#cartList li{
  grid-template-columns: 1fr auto;
  align-items:flex-start;
}
.lineLeft{
  overflow:visible;
}
.lineName{
  white-space:normal;
  overflow:visible;
  text-overflow:unset;
  word-break:break-word;
}
.lineMeta{
  white-space:normal;
}
.sideCart{
  padding:10px;
}

/* === CART LAYOUT REFINEMENT === */

/* Wider sidebar on desktop */
.hours{
  width:320px;
  flex:0 0 320px;
}

/* Cart typography */
.sideCart{
  font-size:13px;
}

/* Cart item layout */
#cartList li{
  grid-template-columns: 1fr 110px;
  gap:10px;
}

/* Product name readable */
.lineName{
  font-size:13px;
  line-height:1.25;
}

/* Meta smaller */
.lineMeta{
  font-size:12px;
  color:#555;
}

/* Quantity + price column */
.lineBtns{
  flex-direction:column;
  align-items:flex-end;
  gap:4px;
}

/* Buttons compact */
.lineBtns button{
  width:28px;
  height:28px;
  font-size:14px;
}

/* Price */
.lineBtns div{
  font-size:13px;
}

/* Mobile adjustments */
@media (max-width: 980px){
  .hours{
    width:100%;
    flex:1;
  }
  .sideCart{
    font-size:14px;
  }
}
