/* COFFEESHOP.CSS */
body {
  background:var(--bg); padding-bottom:120px;
}

/* Header */
.coffee-header {
  position:relative; width:100%; overflow:hidden;
}
.coffee-header img { width:100%; display:block; border-radius:0 0 20px 20px; }
.coffee-header .overlay {
  position:absolute; inset:0;
  background:linear-gradient(to bottom,rgba(7,16,30,0.3),rgba(7,16,30,0.85));
  border-radius:0 0 20px 20px;
  display:flex; flex-direction:column;
  align-items:center; justify-content:flex-end;
  padding:0 20px 20px;
}
.coffee-header .overlay h1 {
  font-size:26px; font-weight:900; color:#fff;
  text-shadow:0 2px 12px rgba(0,0,0,0.7); margin-bottom:4px;
}
.coffee-header .overlay p {
  font-size:14px; color:rgba(255,255,255,0.7);
}

/* Category tabs */
.cat-tabs {
  display:flex; gap:8px; padding:14px 12px 4px;
  overflow-x:auto; -webkit-overflow-scrolling:touch;
  scrollbar-width:none;
}
.cat-tabs::-webkit-scrollbar { display:none; }
.cat-tab {
  flex-shrink:0; background:rgba(255,255,255,0.06);
  border:1.5px solid rgba(255,255,255,0.12);
  color:var(--muted); font-family:'Tajawal',sans-serif;
  font-size:14px; font-weight:700; padding:7px 18px;
  border-radius:99px; cursor:pointer; transition:all 0.2s;
  white-space:nowrap;
}
.cat-tab.active {
  background:rgba(0,212,255,0.15); border-color:var(--cyan); color:var(--cyan);
}

/* Menu grid */
.menu-grid {
  padding:10px 12px; display:grid;
  grid-template-columns:1fr 1fr; gap:12px;
}

.menu-item {
  background:var(--card-bg); border:1px solid var(--card-border);
  border-radius:16px; overflow:hidden; cursor:pointer;
  transition:transform 0.18s, box-shadow 0.18s;
  position:relative;
}
.menu-item:active { transform:scale(0.97); }
.menu-item.in-cart { border-color:var(--cyan); box-shadow:0 0 14px rgba(0,212,255,0.2); }

.menu-item-img {
  width:100%; aspect-ratio:4/3; object-fit:cover; display:block;
}

.menu-item-body { padding:10px 11px 12px; }
.menu-item-name {
  font-size:15px; font-weight:800; color:var(--text);
  margin-bottom:3px; line-height:1.3;
}
.menu-item-desc {
  font-size:12px; color:var(--muted); margin-bottom:8px;
  line-height:1.4; font-weight:500;
}
.menu-item-footer {
  display:flex; align-items:center; justify-content:space-between;
}
.menu-item-price {
  font-size:16px; font-weight:900; color:var(--gold);
}
.menu-item-price span { font-size:11px; font-weight:600; color:var(--muted); margin-right:2px; }

.add-btn {
  width:32px; height:32px; border-radius:50%;
  background:linear-gradient(135deg,#0099cc,#00d4ff);
  border:none; color:#fff; font-size:20px; line-height:1;
  cursor:pointer; display:flex; align-items:center; justify-content:center;
  box-shadow:0 2px 10px rgba(0,212,255,0.35); transition:transform 0.15s;
  flex-shrink:0;
}
.add-btn:active { transform:scale(0.88); }

/* Qty badge on item */
.qty-badge {
  position:absolute; top:8px; left:8px;
  background:var(--cyan); color:#07101e;
  font-size:13px; font-weight:900;
  width:24px; height:24px; border-radius:50%;
  display:none; align-items:center; justify-content:center;
}
.menu-item.in-cart .qty-badge { display:flex; }

/* ── Cart bar (fixed bottom) ── */
.cart-bar {
  position:fixed; bottom:0; left:50%; transform:translateX(-50%);
  width:100%; max-width:var(--max-w);
  background:rgba(7,16,30,0.97); backdrop-filter:blur(16px);
  border-top:1px solid rgba(0,212,255,0.2);
  padding:14px 16px 20px;
  display:none; /* shown when cart has items */
  z-index:100;
}
.cart-bar.visible { display:block; }

.cart-bar-inner {
  display:flex; align-items:center; justify-content:space-between; gap:12px;
}
.cart-info { display:flex; flex-direction:column; }
.cart-count { font-size:13px; color:var(--muted); font-weight:600; }
.cart-total { font-size:20px; font-weight:900; color:var(--gold); }

.cart-checkout-btn {
  flex-shrink:0;
  background:linear-gradient(135deg,#0099cc,#00d4ff);
  color:#fff; border:none; border-radius:14px;
  font-family:'Tajawal',sans-serif; font-size:16px; font-weight:900;
  padding:13px 22px; cursor:pointer;
  box-shadow:0 4px 18px rgba(0,212,255,0.4);
  transition:transform 0.15s;
}
.cart-checkout-btn:active { transform:scale(0.97); }

/* View cart btn (text link) */
.view-cart-link {
  text-align:center; font-size:13px; color:var(--cyan);
  margin-top:6px; cursor:pointer; font-weight:600;
}

/* ── Cart drawer ── */
.cart-drawer-overlay {
  position:fixed; inset:0; background:rgba(0,0,0,0.6);
  z-index:200; display:none; backdrop-filter:blur(4px);
}
.cart-drawer-overlay.open { display:block; }

.cart-drawer {
  position:fixed; bottom:0; left:50%; transform:translateX(-50%);
  width:100%; max-width:var(--max-w);
  background:#0d1f35; border-radius:22px 22px 0 0;
  border-top:1px solid var(--card-border);
  z-index:201; padding:0 0 34px;
  max-height:80vh; overflow-y:auto;
  animation:slideUp 0.3s ease;
}
@keyframes slideUp {
  from { transform:translateX(-50%) translateY(100%); }
  to   { transform:translateX(-50%) translateY(0); }
}

.drawer-handle {
  width:40px; height:4px; background:rgba(255,255,255,0.2);
  border-radius:99px; margin:12px auto 18px; cursor:pointer;
}

.drawer-title {
  font-size:20px; font-weight:900; color:var(--text);
  padding:0 20px; margin-bottom:14px;
}

.cart-item-row {
  display:flex; align-items:center; gap:12px;
  padding:12px 20px; border-bottom:1px solid rgba(255,255,255,0.06);
}
.cart-item-img {
  width:52px; height:52px; border-radius:10px; object-fit:cover; flex-shrink:0;
}
.cart-item-info { flex:1; }
.cart-item-name { font-size:15px; font-weight:700; color:var(--text); }
.cart-item-unit { font-size:13px; color:var(--muted); }

.qty-control {
  display:flex; align-items:center; gap:8px;
}
.qty-btn {
  width:28px; height:28px; border-radius:50%;
  background:rgba(255,255,255,0.08);
  border:1px solid rgba(255,255,255,0.15);
  color:var(--text); font-size:16px; cursor:pointer;
  display:flex; align-items:center; justify-content:center;
  transition:background 0.15s;
}
.qty-btn:active { background:rgba(255,255,255,0.18); }
.qty-val { font-size:16px; font-weight:700; min-width:20px; text-align:center; }

.cart-item-price { font-size:16px; font-weight:900; color:var(--gold); flex-shrink:0; }

.drawer-footer { padding:18px 20px 0; }
.drawer-total-row {
  display:flex; justify-content:space-between; align-items:center; margin-bottom:16px;
}
.drawer-total-lbl { font-size:15px; font-weight:700; color:var(--muted); }
.drawer-total-val { font-size:22px; font-weight:900; color:var(--gold); }
