/* ═══════════════════════════════════════════════════════════════
   style.css v2 — Warung DIY: dengan dukungan foto menu
   Font: Fraunces + DM Sans
═══════════════════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,wght@0,700;0,900;1,600&family=DM+Sans:wght@300;400;500;600&display=swap');

/* ─── TEMA ──────────────────────────────────────────────────── */
[data-tema="coklat"] {
  --bg: #f9f0e1; --paper: #fffdf8;
  --primary: #2c1a0e; --primary-2: #5c3d1e;
  --accent: #e8922a; --accent-lt: #f5b65a;
  --text: #2c1a0e; --text-lt: #9a6b3c;
  --hero-grad: linear-gradient(135deg,#2c1a0e,#5c3d1e);
  --card-bg: linear-gradient(135deg,#f9f0e1,#fffdf8);
}
[data-tema="hijau"] {
  --bg: #f0f7f2; --paper: #f8fdf9;
  --primary: #1a3d24; --primary-2: #2d6e42;
  --accent: #3aaa5c; --accent-lt: #7dd49a;
  --text: #1a3d24; --text-lt: #4a8c5c;
  --hero-grad: linear-gradient(135deg,#1a3d24,#2d6e42);
  --card-bg: linear-gradient(135deg,#f0f7f2,#f8fdf9);
}
[data-tema="merah"] {
  --bg: #fdf0f0; --paper: #fffafa;
  --primary: #3d0a0a; --primary-2: #8b1a1a;
  --accent: #e53935; --accent-lt: #ef9a9a;
  --text: #3d0a0a; --text-lt: #a03030;
  --hero-grad: linear-gradient(135deg,#3d0a0a,#8b1a1a);
  --card-bg: linear-gradient(135deg,#fdf0f0,#fffafa);
}
[data-tema="biru"] {
  --bg: #f0f4fb; --paper: #f8faff;
  --primary: #0a1f3d; --primary-2: #1a3a7a;
  --accent: #2563eb; --accent-lt: #93c5fd;
  --text: #0a1f3d; --text-lt: #3b5ea6;
  --hero-grad: linear-gradient(135deg,#0a1f3d,#1a3a7a);
  --card-bg: linear-gradient(135deg,#f0f4fb,#f8faff);
}
[data-tema="ungu"] {
  --bg: #f5f0fb; --paper: #fdfaff;
  --primary: #1e0a3d; --primary-2: #4a1a7a;
  --accent: #7c3aed; --accent-lt: #c4b5fd;
  --text: #1e0a3d; --text-lt: #6d3ab0;
  --hero-grad: linear-gradient(135deg,#1e0a3d,#4a1a7a);
  --card-bg: linear-gradient(135deg,#f5f0fb,#fdfaff);
}
[data-tema="orange"] {
  --bg: #fef4ec; --paper: #fffaf6;
  --primary: #3d1a00; --primary-2: #c45000;
  --accent: #f97316; --accent-lt: #fdba74;
  --text: #3d1a00; --text-lt: #b05a20;
  --hero-grad: linear-gradient(135deg,#3d1a00,#c45000);
  --card-bg: linear-gradient(135deg,#fef4ec,#fffaf6);
}

/* ─── BASE ──────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  font-family: 'DM Sans', sans-serif;
  background: var(--bg); color: var(--text);
  min-height: 100vh; -webkit-font-smoothing: antialiased;
}
button { font-family: inherit; cursor: pointer; border: none; background: none; }

/* ─── HEADER ────────────────────────────────────────────────── */
.header {
  background: var(--primary); color: #fff;
  padding: 0 1.25rem;
  position: sticky; top: 0; z-index: 100;
  box-shadow: 0 2px 16px rgba(0,0,0,.25);
}
.header-inner {
  max-width: 1080px; margin: 0 auto;
  display: flex; align-items: center; justify-content: space-between;
  height: 60px; gap: 1rem;
}
.brand { display: flex; align-items: center; gap: .55rem; }
.brand-icon { font-size: 1.5rem; line-height: 1; }
.brand-name { font-family: 'Fraunces', serif; font-size: 1.2rem; font-weight: 900; }
.brand-tag  { font-size: .68rem; opacity: .55; letter-spacing: .1em; text-transform: uppercase; }

.cart-btn {
  display: flex; align-items: center; gap: .45rem;
  background: var(--accent); color: #fff;
  padding: .5rem 1rem; border-radius: 30px;
  font-weight: 600; font-size: .88rem;
  transition: filter .2s, transform .2s; white-space: nowrap;
}
.cart-btn:hover { filter: brightness(1.1); transform: scale(1.03); }
.cart-count {
  background: #fff; color: var(--accent);
  border-radius: 50%; width: 20px; height: 20px;
  font-size: .72rem; font-weight: 700;
  display: flex; align-items: center; justify-content: center;
}
.cart-count.pop { animation: pop .28s; }
@keyframes pop { 50% { transform: scale(1.5); } }

/* ─── HERO ──────────────────────────────────────────────────── */
.hero {
  background: var(--hero-grad); color: #fff;
  text-align: center; padding: 3rem 1.5rem 2.8rem;
  position: relative; overflow: hidden;
}
.hero::after {
  content: ''; position: absolute; inset: 0;
  background: radial-gradient(ellipse at 70% 50%, rgba(255,255,255,.06), transparent 70%);
  pointer-events: none;
}
.hero-icon { font-size: 3.2rem; display: block; margin-bottom: .7rem; }
.hero h1 {
  font-family: 'Fraunces', serif;
  font-size: clamp(1.7rem, 5vw, 2.6rem);
  font-weight: 900; line-height: 1.15; margin-bottom: .5rem;
}
.hero h1 em { color: var(--accent-lt); font-style: italic; font-weight: 600; }
.hero p { opacity: .7; font-size: .92rem; max-width: 340px; margin: 0 auto; }

/* ─── FILTER ────────────────────────────────────────────────── */
.filter-bar {
  background: var(--paper);
  border-bottom: 1px solid rgba(0,0,0,.07);
  position: sticky; top: 60px; z-index: 90;
  overflow-x: auto; scrollbar-width: none;
}
.filter-bar::-webkit-scrollbar { display: none; }
.filter-inner {
  max-width: 1080px; margin: 0 auto;
  display: flex; gap: .25rem; padding: .65rem 1.2rem;
}
.ftab {
  padding: .38rem .85rem; border-radius: 20px;
  font-size: .83rem; font-weight: 500;
  color: var(--text-lt); white-space: nowrap;
  border: 1.5px solid transparent; transition: all .18s;
}
.ftab:hover { color: var(--text); background: var(--bg); }
.ftab.on { background: var(--primary); color: #fff; border-color: var(--primary); }

/* ─── LAYOUT ────────────────────────────────────────────────── */
.wrap { max-width: 1080px; margin: 0 auto; padding: 1.5rem 1rem 7rem; }

.cat-section { margin-bottom: 2.2rem; }
.cat-title {
  font-family: 'Fraunces', serif;
  font-size: 1.15rem; font-weight: 700; color: var(--primary-2);
  margin-bottom: .9rem; padding-bottom: .45rem;
  border-bottom: 2.5px solid var(--accent-lt);
  display: flex; align-items: center; gap: .4rem;
}

/* ─── GRID ──────────────────────────────────────────────────── */
.grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(195px, 1fr));
  gap: .9rem;
}

/* ─── CARD ──────────────────────────────────────────────────── */
.card {
  background: var(--paper);
  border-radius: 14px;
  box-shadow: 0 2px 10px rgba(0,0,0,.07);
  overflow: hidden;
  display: flex; flex-direction: column;
  transition: transform .2s, box-shadow .2s;
  position: relative;
}
.card:hover { transform: translateY(-3px); box-shadow: 0 8px 28px rgba(0,0,0,.13); }
.card.sold  { opacity: .52; pointer-events: none; }

/* ── Thumbnail area: foto atau emoji, rasio 4:3 konsisten ── */
.card-thumb {
  width: 100%;
  aspect-ratio: 4 / 3;
  overflow: hidden;
  position: relative;
  background: var(--card-bg);
  flex-shrink: 0;
}

/* Foto */
.card-thumb img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .35s ease;
}
.card:hover .card-thumb img { transform: scale(1.05); }

/* Fallback emoji — centered di dalam thumb */
.card-thumb .emoji-wrap {
  width: 100%; height: 100%;
  display: flex; align-items: center; justify-content: center;
  font-size: 3rem; line-height: 1;
}

/* Badge gambar error — tulis inisial kalau foto 404 */
.card-thumb .img-err {
  width: 100%; height: 100%;
  display: none;                      /* ditampilkan via JS onerror */
  align-items: center; justify-content: center; flex-direction: column;
  gap: .3rem; background: var(--card-bg);
}
.card-thumb .img-err span {
  font-size: 2rem; font-weight: 900;
  color: var(--accent); font-family: 'Fraunces', serif;
  line-height: 1;
}
.card-thumb .img-err small {
  font-size: .65rem; color: var(--text-lt);
  text-transform: uppercase; letter-spacing: .06em;
}

/* ── Body ── */
.card-body { padding: .8rem .9rem; flex: 1; display: flex; flex-direction: column; }
.card-name  { font-weight: 600; font-size: .92rem; line-height: 1.3; margin-bottom: .25rem; }
.card-price { color: var(--accent); font-weight: 700; font-size: 1rem; margin-bottom: .7rem; }
.card-footer { margin-top: auto; }

.btn-order {
  width: 100%; padding: .48rem;
  background: var(--primary); color: #fff;
  border-radius: 8px; font-size: .83rem; font-weight: 600;
  display: flex; align-items: center; justify-content: center; gap: .35rem;
  transition: background .18s;
}
.btn-order:hover { background: var(--primary-2); }
.btn-order:active { transform: scale(.97); }

.badge-sold {
  position: absolute; top: .5rem; right: .5rem; z-index: 2;
  background: #c0392b; color: #fff;
  font-size: .62rem; font-weight: 700;
  padding: .12rem .4rem; border-radius: 20px;
  text-transform: uppercase; letter-spacing: .05em;
}

/* ─── CART OVERLAY ──────────────────────────────────────────── */
.overlay {
  position: fixed; inset: 0;
  background: rgba(0,0,0,.45); z-index: 200;
  opacity: 0; pointer-events: none; transition: opacity .25s;
}
.overlay.on { opacity: 1; pointer-events: all; }

/* ─── CART DRAWER ───────────────────────────────────────────── */
.drawer {
  position: fixed; right: 0; top: 0; bottom: 0;
  width: min(400px, 100vw);
  background: var(--paper); z-index: 201;
  transform: translateX(100%);
  transition: transform .28s cubic-bezier(.4,0,.2,1);
  display: flex; flex-direction: column;
  box-shadow: -4px 0 30px rgba(0,0,0,.15);
}
.drawer.on { transform: translateX(0); }

.drawer-head {
  background: var(--primary); color: #fff;
  padding: 1.1rem 1.4rem;
  display: flex; align-items: center; justify-content: space-between;
}
.drawer-head h2 { font-family: 'Fraunces', serif; font-size: 1.1rem; }
.drawer-close { font-size: 1.3rem; opacity: .7; color: #fff; transition: opacity .15s; }
.drawer-close:hover { opacity: 1; }

.drawer-body { flex: 1; overflow-y: auto; padding: 1rem 1.4rem; }

.empty-state { text-align: center; padding: 3rem 1rem; color: var(--text-lt); }
.empty-state span { font-size: 3rem; display: block; margin-bottom: .8rem; }

.ci {
  display: grid; grid-template-columns: 1fr auto;
  gap: .4rem; align-items: center;
  padding: .75rem 0; border-bottom: 1px solid rgba(0,0,0,.06);
  animation: fadein .2s;
}
@keyframes fadein { from { opacity:0; transform:translateX(12px); } }
.ci-name { font-weight: 500; font-size: .88rem; }
.ci-sub  { font-size: .78rem; color: var(--text-lt); margin-top: .12rem; }
.ci-ctrl { display: flex; align-items: center; gap: .35rem; }
.qbtn {
  width: 26px; height: 26px; border-radius: 50%;
  background: var(--bg); border: 1px solid rgba(0,0,0,.1);
  font-size: .95rem; font-weight: 700;
  display: flex; align-items: center; justify-content: center;
  transition: background .15s;
}
.qbtn:hover { background: var(--accent-lt); }
.qnum { min-width: 20px; text-align: center; font-weight: 600; font-size: .88rem; }

.drawer-foot {
  padding: 1.1rem 1.4rem;
  border-top: 2px solid rgba(0,0,0,.08);
  background: var(--bg);
}
.row-sub   { display:flex; justify-content:space-between; font-size:.85rem; color:var(--text-lt); margin-bottom:.25rem; }
.row-total { display:flex; justify-content:space-between; font-size:1.05rem; font-weight:700; margin-bottom:1rem; padding-top:.35rem; border-top:1px dashed rgba(0,0,0,.15); }

.form { display:flex; flex-direction:column; gap:.5rem; margin-bottom:.9rem; }
.form label { font-size:.73rem; font-weight:600; color:var(--text-lt); text-transform:uppercase; letter-spacing:.06em; display:block; margin-bottom:.18rem; }
.form input, .form textarea {
  width:100%; padding:.55rem .8rem;
  border:1.5px solid rgba(0,0,0,.13); border-radius:8px;
  font-family:inherit; font-size:.88rem;
  background:var(--paper); color:var(--text);
  transition:border-color .15s; resize:none;
}
.form input:focus,.form textarea:focus { outline:none; border-color:var(--accent); }

.btn-wa {
  width:100%; padding:.8rem;
  background:#25D366; color:#fff;
  border-radius:9px; font-size:.97rem; font-weight:700;
  display:flex; align-items:center; justify-content:center; gap:.55rem;
  transition:background .18s, transform .18s;
  box-shadow:0 4px 14px rgba(37,211,102,.3);
}
.btn-wa:hover { background:#1ebe5d; transform:translateY(-1px); }
.btn-wa svg { width:20px; height:20px; fill:#fff; flex-shrink:0; }

/* ─── TOAST ─────────────────────────────────────────────────── */
.toast {
  position:fixed; bottom:1.4rem; left:50%;
  transform:translateX(-50%) translateY(60px);
  background:var(--primary); color:#fff;
  padding:.6rem 1.2rem; border-radius:30px;
  font-size:.86rem; font-weight:500;
  pointer-events:none; opacity:0; z-index:999;
  transition:transform .28s, opacity .28s; white-space:nowrap;
  box-shadow:0 4px 18px rgba(0,0,0,.2);
}
.toast.on { transform:translateX(-50%) translateY(0); opacity:1; }

/* ─── FOOTER ─────────────────────────────────────────────────── */
.footer {
  text-align:center; padding:1.4rem;
  font-size:.78rem; color:var(--text-lt);
  border-top:1px solid rgba(0,0,0,.07); background:var(--paper);
}

/* ─── RESPONSIVE ─────────────────────────────────────────────── */
@media (max-width: 480px) {
  .grid { grid-template-columns: repeat(2, 1fr); gap:.7rem; }
  .wrap { padding:1rem .75rem 7rem; }
}
