*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
:root{
  --bg:#0D0A07;
  --surface:#1A1208;
  --surface2:#241A0E;
  --card:#2E1E10;
  --caramel:#D4882A;
  --caramel-light:#F0C06A;
  --caramel-pale:#3D2810;
  --cream:#FDF0DC;
  --cream-dim:#C4A87A;
  --white:#FFFFFF;
  --muted:#8A6F52;
  --border:#3D2A18;
  --border-glow:#6B4520;
  --red:#E05252;
  --green:#52C87A;
  --radius:14px;
  --radius-sm:8px;
}
/* ── LIGHT MODE ── */
body.light-mode{
  --bg:#FAF5EE;
  --surface:#FFF8F0;
  --surface2:#F5EBD8;
  --card:#FFFFFF;
  --caramel:#B8690E;
  --caramel-light:#8B4F0A;
  --caramel-pale:#FDE8C8;
  --cream:#2D1A06;
  --cream-dim:#6B4520;
  --muted:#A08060;
  --border:#E8D5B5;
  --border-glow:#C8A060;
}
body.light-mode .hero{
  background:
    radial-gradient(ellipse 100% 70% at 50% -10%, rgba(255,200,120,0.5) 0%, transparent 65%),
    var(--bg);
}
body.light-mode .menu-card{box-shadow:0 2px 12px rgba(0,0,0,.08)}
body.light-mode .cart-drawer,
body.light-mode .item-modal{background:var(--surface)}
body.light-mode .welcome-modal{background:var(--surface)}
body.light-mode header{background:rgba(250,245,238,.9);border-color:var(--border)}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:'Outfit',sans-serif;
  background:var(--bg);
  color:var(--cream);
  min-height:100vh;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
/* Cegah background scroll saat modal buka — tanpa block scroll dalam modal */
body.modal-open {
  overflow: hidden;
  /* iOS fix: gunakan touch-action bukan overflow */
  position: fixed;
  width: 100%;
}

/* ── GRAIN TEXTURE ── */
body::before{
  content:'';
  position:fixed;inset:0;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.04'/%3E%3C/svg%3E");
  pointer-events:none;z-index:0;opacity:.5;
}

/* ─────────── WELCOME MODAL ─────────── */
.welcome-overlay{
  display:none;
  position:fixed;inset:0;z-index:500;
  background:rgba(0,0,0,.85);
  backdrop-filter:blur(6px);
  align-items:flex-end;justify-content:center;
  animation:fadeIn .25s ease;
}
.welcome-overlay.open{display:flex}
.welcome-modal{
  background:linear-gradient(180deg,#1F1408 0%,var(--surface) 100%);
  border-top:2px solid var(--caramel);
  border-radius:24px 24px 0 0;
  width:100%;max-width:480px;
  padding:28px 22px 32px;
  text-align:center;
  position:relative;
  max-height:92vh;
  overflow-y:auto;
  overflow-x:hidden;
  -webkit-overflow-scrolling:touch;
  overscroll-behavior:contain;
  animation:slideUp .35s cubic-bezier(.4,0,.2,1);
}
.welcome-modal::before{
  content:'';position:absolute;top:10px;left:50%;transform:translateX(-50%);
  width:44px;height:4px;border-radius:2px;background:var(--border-glow);
}
.welcome-emoji{
  font-size:52px;margin-bottom:12px;
  display:block;
  animation:bounce 1s ease infinite;
}
.welcome-badge{
  display:inline-block;
  background:var(--caramel-pale);border:1px solid var(--border-glow);
  color:var(--caramel-light);font-size:11px;font-weight:700;
  letter-spacing:1.5px;text-transform:uppercase;
  padding:5px 14px;border-radius:30px;margin-bottom:14px;
}
.welcome-title{
  font-family:'Fraunces',serif;font-size:32px;font-weight:900;
  color:var(--caramel-light);line-height:1.1;
}
.welcome-title span{color:var(--white)}
.welcome-sub{
  font-size:13px;color:var(--cream-dim);
  margin:8px 0 22px;
}
.how-to-list{
  display:flex;flex-direction:column;gap:10px;
  text-align:left;margin-bottom:22px;
}
.how-step{
  display:flex;align-items:center;gap:12px;
  background:var(--surface2);
  border:1px solid var(--border);
  border-radius:12px;padding:12px 14px;
}
.how-num{
  flex-shrink:0;
  width:32px;height:32px;border-radius:50%;
  background:var(--caramel);color:#1A0D00;
  font-family:'Fraunces',serif;font-weight:900;font-size:16px;
  display:flex;align-items:center;justify-content:center;
}
.how-text{font-size:13.5px;color:var(--cream);line-height:1.45}
.how-text small{font-size:11.5px;color:var(--muted);font-weight:400}
.welcome-cta{
  width:100%;
  background:var(--caramel);color:#1A0D00;
  border:none;border-radius:14px;
  padding:15px;
  font-family:'Outfit',sans-serif;font-size:16px;font-weight:800;
  cursor:pointer;letter-spacing:.3px;
  transition:transform .15s,background .2s;
  box-shadow:0 4px 20px rgba(212,136,42,.35);
}
.welcome-cta:active{transform:scale(.97)}
.outlet-notice{
  background:rgba(212,136,42,0.08);
  border:1px solid rgba(212,136,42,0.25);
  border-radius:10px;padding:10px 12px;
  font-size:11.5px;color:var(--cream-dim);
  line-height:1.6;text-align:left;
  margin-bottom:14px;
}
.cart-notice{
  background:rgba(212,136,42,0.07);
  border:1px solid rgba(212,136,42,0.2);
  border-radius:8px;padding:9px 12px;
  font-size:11px;color:var(--muted);
  line-height:1.6;margin-bottom:10px;
}
.welcome-foot{
  font-size:11px;color:var(--muted);margin-top:14px;
  line-height:1.6;text-align:center;
}
.help-inline{
  display:inline-flex;align-items:center;justify-content:center;
  width:18px;height:18px;border-radius:50%;
  background:var(--caramel-pale);color:var(--caramel);
  font-weight:800;font-size:11px;
  vertical-align:middle;margin:0 1px;
}

@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes slideUp{from{transform:translateY(100%)}to{transform:translateY(0)}}
@keyframes bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}

/* ─────────── HEADER ─────────── */
header{
  background:rgba(13,10,7,0.96);
  backdrop-filter:blur(16px);
  border-bottom:1px solid var(--border);
  padding:11px 14px;
  display:flex;align-items:center;justify-content:space-between;
  position:sticky;top:0;z-index:200;gap:8px;
}
.logo{
  font-family:'Fraunces',serif;
  font-size:16px;font-weight:900;
  color:var(--caramel-light);
  line-height:1.1;
  flex:1;min-width:0;
}
.logo small{
  display:block;font-family:'Outfit',sans-serif;
  font-size:9.5px;font-weight:500;color:var(--muted);
  letter-spacing:1.5px;text-transform:uppercase;margin-top:2px;
}
.header-actions{display:flex;align-items:center;gap:7px;flex-shrink:0}
.help-btn{
  height:34px;padding:0 12px;border-radius:20px;
  background:var(--caramel-pale);border:1px solid var(--border-glow);
  color:var(--caramel);
  font-family:'Outfit',sans-serif;font-weight:700;font-size:11px;
  letter-spacing:.4px;white-space:nowrap;
  cursor:pointer;display:flex;align-items:center;justify-content:center;
  transition:transform .15s,background .2s;
}
.help-btn:active{transform:scale(.95)}
.cart-btn{
  position:relative;
  background:var(--caramel);color:#1A0D00;
  border:none;border-radius:30px;
  padding:8px 14px 8px 12px;
  font-family:'Outfit',sans-serif;font-size:14px;font-weight:700;
  cursor:pointer;display:flex;align-items:center;gap:6px;
  transition:background .2s,transform .15s;
}
.cart-btn:active{transform:scale(.95)}
.cart-btn.bump{animation:cartBump .35s ease}
@keyframes cartBump{
  0%{transform:scale(1)}
  40%{transform:scale(1.18)}
  100%{transform:scale(1)}
}
.cart-count{
  background:#1A0D00;color:var(--caramel-light);
  border-radius:50%;min-width:20px;height:20px;padding:0 5px;
  font-size:11px;font-weight:800;
  display:flex;align-items:center;justify-content:center;
}

/* ─────────── HERO (compact) ─────────── */
.hero{
  position:relative;overflow:hidden;
  padding:36px 20px 32px;
  text-align:center;
  background:
    radial-gradient(ellipse 100% 70% at 50% -10%, rgba(90,40,5,0.9) 0%, transparent 65%),
    radial-gradient(ellipse 60% 40% at 80% 80%, rgba(50,20,2,0.5) 0%, transparent 60%),
    var(--bg);
}
.hero::before{
  content:'';position:absolute;inset:0;
  background:
    radial-gradient(circle 1px at 20% 30%, rgba(212,136,42,.35) 0%, transparent 1px),
    radial-gradient(circle 1px at 75% 20%, rgba(240,192,106,.25) 0%, transparent 1px),
    radial-gradient(circle 1px at 55% 65%, rgba(212,136,42,.2) 0%, transparent 1px),
    radial-gradient(circle 1px at 35% 75%, rgba(240,192,106,.15) 0%, transparent 1px),
    radial-gradient(circle 1px at 88% 55%, rgba(212,136,42,.2) 0%, transparent 1px);
  pointer-events:none;z-index:0;
}
.hero::after{
  content:'';position:absolute;bottom:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--caramel),transparent);
  opacity:.3;
}
.hero-badge{
  display:inline-flex;align-items:center;gap:6px;
  background:linear-gradient(135deg,rgba(212,136,42,.15),rgba(212,136,42,.05));
  border:1px solid rgba(212,136,42,.35);
  color:var(--caramel);
  font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;
  padding:5px 14px;border-radius:30px;margin-bottom:18px;
  box-shadow:0 0 20px rgba(212,136,42,.1),inset 0 1px 0 rgba(255,255,255,.05);
  animation:heroBadgePulse 3s ease-in-out infinite;
}
@keyframes heroBadgePulse{
  0%,100%{box-shadow:0 0 20px rgba(212,136,42,.1),inset 0 1px 0 rgba(255,255,255,.05)}
  50%{box-shadow:0 0 30px rgba(212,136,42,.2),inset 0 1px 0 rgba(255,255,255,.05)}
}
.hero h1{
  font-family:'Fraunces',serif;
  font-size:34px;font-weight:900;
  color:var(--caramel-light);
  line-height:1.02;margin-bottom:12px;
  text-shadow:0 2px 20px rgba(212,136,42,.3);
  letter-spacing:-.5px;
}
.hero h1 span{
  color:var(--white);
  background:linear-gradient(135deg,#fff 30%,var(--caramel-light) 100%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.hero p{font-size:13px;color:var(--cream-dim);max-width:320px;margin:0 auto 18px;line-height:1.65;opacity:.85}
.hero-pills{display:flex;flex-wrap:wrap;gap:7px;justify-content:center}
.pill{
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.1);
  color:var(--cream-dim);font-size:11px;font-weight:500;
  padding:5px 11px;border-radius:20px;
  backdrop-filter:blur(4px);
  transition:border-color .2s,background .2s;
}
.pill:hover{background:rgba(212,136,42,.08);border-color:rgba(212,136,42,.25)}
.pill span{color:var(--caramel);margin-right:3px}

/* ─────────── SEARCH BAR ─────────── */
.search-wrap{
  padding:12px 14px 0;
  position:sticky;top:55px;z-index:160;
  background:var(--bg);
}
.search-box{
  position:relative;
  background:var(--surface2);
  border:1.5px solid var(--border);
  border-radius:12px;
  display:flex;align-items:center;
  transition:border-color .2s;
}
.search-box:focus-within{border-color:var(--caramel)}
.search-ico{
  padding:0 10px 0 14px;
  font-size:14px;opacity:.7;
}
.search-box input{
  flex:1;
  background:transparent;border:none;outline:none;
  padding:11px 0;
  font-family:'Outfit',sans-serif;font-size:14px;
  color:var(--cream);
}
.search-box input::placeholder{color:var(--muted)}
.search-clear{
  display:none;
  background:var(--card);border:none;
  color:var(--muted);
  width:24px;height:24px;border-radius:50%;
  margin-right:8px;
  font-size:11px;font-weight:700;
  cursor:pointer;align-items:center;justify-content:center;
  transition:background .2s,color .2s;
}
.search-clear.visible{display:flex}
.search-clear:active{background:var(--caramel-pale);color:var(--caramel)}

/* ─────────── TABS ─────────── */
.tabs-wrap{
  position:sticky;top:114px;z-index:155;
  background:rgba(13,10,7,0.97);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--border);
  padding:8px 14px 11px;
  margin-top:12px;
}
.tabs-label{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:8px;
}
.tabs-label-text{
  font-size:10.5px;font-weight:700;
  color:var(--muted);letter-spacing:1px;text-transform:uppercase;
}
.tabs-swipe-hint{
  font-size:10px;font-weight:600;color:var(--caramel);
  opacity:.8;
  animation:hintPulse 2s ease-in-out infinite;
}
@keyframes hintPulse{
  0%,100%{opacity:.5;transform:translateX(0)}
  25%{opacity:1;transform:translateX(-3px)}
  75%{opacity:1;transform:translateX(3px)}
}
.tabs{display:flex;gap:6px;overflow-x:auto;scrollbar-width:none;-webkit-overflow-scrolling:touch}
.tabs::-webkit-scrollbar{display:none}
.tab{
  background:none;border:1px solid var(--border);
  border-radius:20px;padding:7px 14px;
  font-family:'Outfit',sans-serif;font-size:12.5px;font-weight:500;
  color:var(--muted);cursor:pointer;white-space:nowrap;
  transition:all .2s;flex-shrink:0;
}
.tab.active{background:var(--caramel);color:#1A0D00;border-color:var(--caramel);font-weight:700}

/* ─────────── QUICK FILTERS ─────────── */
.qfilter-wrap{
  display:flex;gap:6px;overflow-x:auto;scrollbar-width:none;
  padding:10px 14px 6px;-webkit-overflow-scrolling:touch;
}
.qfilter-wrap::-webkit-scrollbar{display:none}
.qfilter{
  background:var(--surface2);border:1px solid var(--border);
  border-radius:16px;padding:5px 12px;
  font-family:'Outfit',sans-serif;font-size:11.5px;font-weight:600;
  color:var(--cream-dim);cursor:pointer;white-space:nowrap;flex-shrink:0;
  transition:all .15s;
}
.qfilter.active{background:var(--caramel-pale);border-color:var(--caramel);color:var(--caramel-light)}

/* ─────────── MENU ─────────── */
.menu-wrap{padding:8px 14px 140px;max-width:900px;margin:0 auto}
.cat-title{
  font-family:'Fraunces',serif;font-size:20px;font-weight:700;
  color:var(--caramel-light);
  margin:24px 0 12px;
  display:flex;align-items:center;gap:10px;
}
.cat-title::after{content:'';flex:1;height:1px;background:linear-gradient(90deg,var(--border-glow),transparent)}

.menu-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:10px;
}

/* ─────────── MENU CARD ─────────── */
.menu-card{
  background:var(--card);
  border:1.5px solid var(--border);
  border-radius:var(--radius);
  overflow:hidden;
  transition:transform .18s cubic-bezier(.2,0,.2,1),border-color .18s,background .18s,box-shadow .18s;
  position:relative;
  display:flex;flex-direction:column;
  box-shadow:0 2px 8px rgba(0,0,0,.25);
}
.menu-card:active{
  transform:scale(.97);
}
.menu-card.selected{
  border-color:var(--caramel);
  background:rgba(61,40,16,0.7);
  box-shadow:0 0 0 1px var(--caramel), 0 4px 16px rgba(212,136,42,.15);
}
.menu-card.selected::after{
  content:'✓';
  position:absolute;top:8px;right:8px;
  background:var(--caramel);color:#1A0D00;
  width:20px;height:20px;border-radius:50%;
  font-size:11px;font-weight:900;
  display:flex;align-items:center;justify-content:center;
  z-index:3;
  box-shadow:0 2px 6px rgba(212,136,42,.4);
}
.card-emoji{
  height:135px;
  display:flex;align-items:center;justify-content:center;
  font-size:42px;
  background:linear-gradient(160deg, var(--surface2) 0%, rgba(18,10,4,0.9) 100%);
  border-bottom:1px solid var(--border);
  position:relative;overflow:hidden;
}
.card-emoji::after{
  content:'';
  position:absolute;inset:0;
  background:linear-gradient(to bottom, transparent 50%, rgba(0,0,0,0.3) 100%);
  pointer-events:none;
}
.menu-card.selected .card-emoji{background:linear-gradient(160deg,rgba(61,40,16,.9) 0%,rgba(30,15,5,.9) 100%)}
.signature-tag{
  position:absolute;top:8px;left:8px;
  background:linear-gradient(135deg,#D4882A,#F0A93A);
  color:#1A0D00;
  font-size:8.5px;font-weight:900;letter-spacing:.6px;
  padding:3px 8px;border-radius:20px;
  text-transform:uppercase;z-index:2;
  box-shadow:0 2px 8px rgba(212,136,42,.45);
}
.new-tag{
  position:absolute;top:7px;right:7px;
  background:linear-gradient(135deg,#52C87A,#2D8F4F);
  color:white;
  font-size:9px;font-weight:800;letter-spacing:.5px;
  padding:2px 7px 2px 6px;border-radius:10px;
  text-transform:uppercase;z-index:2;
  box-shadow:0 2px 6px rgba(45,143,79,0.4);
  animation:newPulse 2s ease-in-out infinite;
  display:inline-flex;align-items:center;gap:3.5px;
}
.new-tag svg{
  width:9px;height:9px;flex-shrink:0;
}
@keyframes newPulse{
  0%,100%{transform:scale(1)}
  50%{transform:scale(1.08)}
}
.menu-card.selected .new-tag{
  /* tetap visible ketika selected, tapi geser sedikit biar gak ketabrak ✓ */
  right:34px;
}
/* Sparkle star icon di tab "Menu Baru" & section header "Menu Baru" */
.tab-newicon{
  width:11px;height:11px;
  vertical-align:-1px;
  color:#52C87A;
  margin-right:2px;
}
.tab.active .tab-newicon{
  color:#1A0D00;
}
.cat-newicon{
  width:18px;height:18px;
  vertical-align:-3px;
  color:#52C87A;
  margin-right:4px;
}

/* Highlight section Menu Baru */
.new-section .cat-title{
  background:linear-gradient(135deg, rgba(82,200,122,0.15), transparent);
  padding:8px 12px;border-radius:10px;
  border-left:3px solid var(--green);
}
.card-body{padding:10px 10px 11px;flex:1;display:flex;flex-direction:column;gap:6px}
.card-name{
  font-size:12.5px;font-weight:700;
  color:var(--cream);line-height:1.3;
  min-height:32px;
}
.size-badge{
  display:inline-flex;align-items:center;gap:3px;
  font-size:9px;font-weight:700;
  color:var(--cream-dim);
  background:rgba(255,255,255,.04);
  border:1px solid var(--border);
  padding:2px 7px;border-radius:20px;
  letter-spacing:.3px;
  align-self:flex-start;
  text-transform:uppercase;
}
.size-badge-large{
  background:rgba(212,136,42,0.08);
  border-color:rgba(212,136,42,0.3);
  color:var(--caramel-light);
}
.price-row{display:flex;align-items:baseline;gap:6px;flex-wrap:wrap;margin-top:auto}
.price-normal{
  font-size:10px;color:var(--muted);
  text-decoration:line-through;
}
.price-disc{
  font-size:14.5px;font-weight:800;
  color:var(--caramel);
  letter-spacing:-.2px;
}
.card-add-btn{
  margin-top:7px;
  background:linear-gradient(135deg, var(--caramel-pale), rgba(61,40,16,0.5));
  border:1px solid rgba(212,136,42,0.25);
  color:var(--caramel-light);
  font-family:'Outfit',sans-serif;font-size:11.5px;font-weight:700;
  padding:7px 6px;border-radius:9px;
  cursor:pointer;
  transition:all .15s cubic-bezier(.2,0,.2,1);
  letter-spacing:.2px;
}
.card-add-btn:active{
  background:var(--caramel);
  color:#1A0D00;
  transform:scale(.95);
  box-shadow:0 2px 8px rgba(212,136,42,.3);
}
.menu-card.selected .card-add-btn{
  background:var(--caramel);color:#1A0D00;
  border-color:var(--caramel);
  box-shadow:0 2px 8px rgba(212,136,42,.2);
}

/* ─────────── ITEM MODAL (bottom sheet) ─────────── */
.item-modal-overlay{
  display:none;
  position:fixed;inset:0;z-index:520;
  background:rgba(0,0,0,.75);
  backdrop-filter:blur(6px);
  align-items:flex-end;justify-content:center;
  animation:fadeIn .2s ease;
}
.item-modal-overlay.open{display:flex}
.item-modal{
  background:var(--surface);
  border-top:2px solid var(--caramel);
  border-radius:24px 24px 0 0;
  width:100%;max-width:480px;
  max-height:90vh;overflow-y:auto;
  animation:slideUp .3s cubic-bezier(.4,0,.2,1);
  position:relative;
  -webkit-overflow-scrolling:touch;
}
.item-modal::-webkit-scrollbar{width:4px}
.item-modal::-webkit-scrollbar-thumb{background:var(--border-glow);border-radius:2px}
.item-modal::before{
  content:'';position:absolute;top:8px;left:50%;transform:translateX(-50%);
  width:44px;height:4px;border-radius:2px;background:var(--border-glow);
  z-index:2;
}
.item-modal-close{
  position:absolute;top:12px;right:12px;
  width:38px;height:38px;border-radius:50%;
  background:var(--red);
  color:white;
  font-size:18px;font-weight:900;
  cursor:pointer;display:flex;align-items:center;justify-content:center;
  z-index:5;
  box-shadow:0 4px 12px rgba(224,82,82,0.5);
  border:2px solid rgba(255,255,255,0.15);
  transition:transform .15s, background .2s;
}
.item-modal-close:active{
  transform:scale(.92);
  background:#C04040;
}

.modal-image{
  width:100%;height:200px;
  background:var(--surface2);
  position:relative;overflow:hidden;
  border-bottom:1px solid var(--border);
}
.modal-body{padding:18px 18px 12px}
.modal-title{
  font-family:'Fraunces',serif;font-size:22px;font-weight:700;
  color:var(--caramel-light);line-height:1.2;
  margin-bottom:6px;
}
.modal-price-row{display:flex;align-items:baseline;gap:10px;margin-bottom:18px}
.modal-price-old{
  font-size:12px;color:var(--muted);
  text-decoration:line-through;
}
.modal-price-new{
  font-size:20px;font-weight:800;
  color:var(--caramel);font-family:'Fraunces',serif;
}
.modal-section{margin-bottom:18px}
.modal-label{
  font-size:11px;font-weight:700;
  color:var(--cream-dim);
  letter-spacing:.5px;text-transform:uppercase;
  margin-bottom:8px;
}
.modal-options{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.modal-options-3{grid-template-columns:repeat(3,1fr)}
.modal-opt{
  background:var(--card);
  border:1.5px solid var(--border);
  border-radius:10px;
  padding:10px 8px;
  cursor:pointer;
  transition:all .15s;
  font-family:'Outfit',sans-serif;
  text-align:center;
}
.modal-opt:active{transform:scale(.97)}
.modal-opt.active{
  background:var(--caramel-pale);
  border-color:var(--caramel);
}
.modal-opt .opt-main{
  font-size:13px;font-weight:700;color:var(--cream);
}
.modal-opt.active .opt-main{color:var(--caramel-light)}
.modal-opt .opt-sub{
  font-size:10.5px;color:var(--muted);margin-top:2px;
}
.modal-opt.active .opt-sub{color:var(--caramel)}

.modal-fixed-size{
  background:var(--surface2);
  border:1px dashed var(--border-glow);
  border-radius:10px;padding:12px;
  text-align:center;
  font-size:13px;font-weight:600;
  color:var(--cream-dim);
}

.modal-qty-row{
  display:flex;align-items:center;justify-content:center;gap:18px;
  background:var(--surface2);
  border:1px solid var(--border);
  border-radius:12px;padding:8px;
}
.modal-qty-btn{
  width:38px;height:38px;border-radius:50%;
  background:var(--caramel);
  border:none;color:#1A0D00;
  font-size:20px;font-weight:700;
  cursor:pointer;display:flex;align-items:center;justify-content:center;
  transition:transform .15s;
}
.modal-qty-btn:active{transform:scale(.92)}
.modal-qty-num{
  font-family:'Fraunces',serif;
  font-size:24px;font-weight:800;color:var(--caramel-light);
  min-width:48px;text-align:center;
}

.modal-footer{
  position:sticky;bottom:0;
  padding:14px 18px 20px;
  background:linear-gradient(180deg, transparent 0%, var(--surface) 20%);
  z-index:2;
}
.modal-add-cart{
  width:100%;
  background:var(--caramel);color:#1A0D00;
  border:none;border-radius:14px;
  padding:15px;
  font-family:'Outfit',sans-serif;font-size:15px;font-weight:800;
  cursor:pointer;letter-spacing:.3px;
  transition:transform .15s;
  box-shadow:0 6px 20px rgba(212,136,42,.4);
  display:flex;align-items:center;justify-content:center;gap:6px;
}
.modal-add-cart:active{transform:scale(.98)}

/* SIZE selector */
.size-row{display:flex;gap:4px;margin-bottom:6px}
.size-btn{
  flex:1;padding:5px 4px;
  border:1px solid var(--border);border-radius:7px;
  background:var(--surface);color:var(--muted);
  font-family:'Outfit',sans-serif;font-size:10.5px;font-weight:600;
  cursor:pointer;transition:all .15s;text-align:center;
}
.size-btn.active{background:var(--caramel);color:#1A0D00;border-color:var(--caramel)}

/* Fixed (non-interactive) size label */
.size-fixed{
  flex:1;padding:5px 8px;
  border:1px dashed var(--border-glow);border-radius:7px;
  background:var(--surface2);
  color:var(--cream-dim);
  font-family:'Outfit',sans-serif;font-size:10px;font-weight:600;
  text-align:center;
  letter-spacing:.3px;
}

/* PER-ITEM SUGAR / ICE chips */
.opt-row{
  display:flex;flex-direction:column;gap:5px;
  padding:6px 0;margin-bottom:4px;
  border-top:1px dashed var(--border);
}
.opt-line{display:flex;align-items:center;gap:5px;flex-wrap:nowrap}
.opt-icon{font-size:11px;width:14px;text-align:center;flex-shrink:0}
.opt-chips{display:flex;gap:3px;flex:1}
.opt-chip{
  flex:1;padding:3px 4px;
  border:1px solid var(--border);border-radius:6px;
  background:var(--surface);color:var(--muted);
  font-family:'Outfit',sans-serif;font-size:9.5px;font-weight:600;
  cursor:pointer;transition:all .15s;text-align:center;
  white-space:nowrap;
}
.opt-chip.active{background:var(--caramel);color:#1A0D00;border-color:var(--caramel)}

/* QTY */
.qty-row{display:flex;align-items:center;justify-content:space-between;gap:4px;margin-top:4px}
.qty-btn{
  width:28px;height:28px;border-radius:50%;
  border:1px solid var(--border);background:var(--surface);
  color:var(--cream);font-size:15px;font-weight:700;
  cursor:pointer;display:flex;align-items:center;justify-content:center;
  transition:all .15s;flex-shrink:0;
}
.qty-btn:active{background:var(--caramel);color:#1A0D00;border-color:var(--caramel);transform:scale(.92)}
.qty-btn.add{
  background:var(--caramel);color:#1A0D00;border-color:var(--caramel);
}
.qty-num{font-size:13px;font-weight:800;color:var(--caramel)}

/* ─────────── CART DRAWER ─────────── */
.overlay{
  display:none;position:fixed;inset:0;
  background:rgba(0,0,0,.7);z-index:299;
  backdrop-filter:blur(3px);
}
.overlay.open{display:block}
.cart-drawer{
  position:fixed;right:0;top:0;bottom:0;
  width:min(420px,100vw);
  background:var(--surface);
  border-left:1px solid var(--border);
  z-index:300;
  display:flex;flex-direction:column;
  transform:translateX(100%);transition:transform .3s cubic-bezier(.4,0,.2,1);
}
.cart-drawer.open{transform:translateX(0)}
.drawer-head{
  padding:16px 18px;
  border-bottom:1px solid var(--border);
  display:flex;align-items:center;justify-content:space-between;
}
.drawer-title{
  font-family:'Fraunces',serif;font-size:19px;font-weight:700;color:var(--caramel-light);
}
.close-btn{
  background:var(--card);border:1px solid var(--border);
  color:var(--cream);width:34px;height:34px;border-radius:50%;
  font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;
}

.drawer-body{flex:1;overflow-y:auto;padding:14px 18px;-webkit-overflow-scrolling:touch}
.cart-item{
  background:var(--card);border:1px solid var(--border);
  border-radius:var(--radius-sm);padding:11px;
  margin-bottom:8px;
  display:flex;justify-content:space-between;align-items:center;gap:8px;
  animation:cartItemIn .25s ease;
  transition:transform .15s,background .15s,border-color .15s;
}
@keyframes cartItemIn{from{opacity:0;transform:translateX(20px)}to{opacity:1;transform:translateX(0)}}
.ci-left{flex:1;min-width:0}
.ci-name{font-size:13px;font-weight:700;color:var(--cream);margin-bottom:3px}
.ci-meta{font-size:10.5px;color:var(--muted);line-height:1.4}
.ci-meta .pipe{margin:0 4px;opacity:.5}
.ci-price{font-size:12px;color:var(--caramel);font-weight:700;margin-top:5px}
.ci-right{display:flex;flex-direction:column;align-items:flex-end;gap:6px;flex-shrink:0}
.ci-qty{display:flex;align-items:center;gap:4px;background:var(--surface2);border-radius:14px;padding:2px}
.ci-q-btn{
  width:24px;height:24px;border-radius:50%;
  border:none;background:transparent;
  color:var(--cream);font-size:13px;font-weight:700;
  cursor:pointer;display:flex;align-items:center;justify-content:center;
}
.ci-q-btn:active{background:var(--caramel);color:#1A0D00}
.ci-qty span{font-size:12px;font-weight:700;color:var(--caramel);min-width:16px;text-align:center}
.ci-del{
  background:none;border:none;color:var(--muted);font-size:11px;
  cursor:pointer;padding:2px 4px;
}
.ci-del:active{color:var(--red)}

.cart-empty{text-align:center;padding:36px 20px 20px;color:var(--muted)}
.cart-empty .emo{font-size:48px;margin-bottom:12px}
.cart-empty p{font-size:14px}

/* ORDER FORM */
.order-form{
  padding:14px 18px;
  border-top:1px solid var(--border);
  background:var(--surface);
}
.form-group{margin-bottom:10px}
.form-label{
  font-size:11px;font-weight:600;color:var(--cream-dim);
  letter-spacing:.5px;text-transform:uppercase;
  display:block;margin-bottom:5px;
}
.form-input{
  width:100%;
  background:var(--card);
  border:1.5px solid var(--border);
  border-radius:var(--radius-sm);
  padding:9px 12px;
  font-family:'Outfit',sans-serif;font-size:14px;
  color:var(--cream);
  transition:border-color .2s;
  outline:none;
}
.form-input:focus{border-color:var(--caramel)}
.form-input::placeholder{color:var(--muted)}

.total-row{
  display:flex;justify-content:space-between;align-items:center;
  padding:10px 0;margin-bottom:10px;
  border-top:1px solid var(--border);border-bottom:1px solid var(--border);
}
.total-label{font-size:13px;color:var(--cream-dim)}
.total-price{font-size:20px;font-weight:800;color:var(--caramel);font-family:'Fraunces',serif}

.cart-actions{display:flex;gap:8px}
.reset-btn{
  background:var(--surface2);
  color:var(--cream-dim);
  border:1px solid var(--border);border-radius:var(--radius);
  padding:13px 14px;
  font-family:'Outfit',sans-serif;font-size:13px;font-weight:700;
  cursor:pointer;transition:all .2s;
  flex-shrink:0;
}
.reset-btn:active:not(:disabled){background:var(--card);color:var(--red);border-color:var(--red)}
.reset-btn:disabled{opacity:.4;cursor:not-allowed}

.send-btn{
  flex:1;
  background:linear-gradient(135deg,#25D366,#128C7E);
  color:white;border:none;border-radius:var(--radius);
  padding:13px;
  font-family:'Outfit',sans-serif;font-size:14.5px;font-weight:700;
  cursor:pointer;display:flex;align-items:center;justify-content:center;gap:7px;
  transition:opacity .2s,transform .15s;
  letter-spacing:.3px;
}
.send-btn:active{transform:scale(.98)}
.send-btn:disabled{opacity:.4;cursor:not-allowed;transform:none}
.send-btn svg{width:18px;height:18px;fill:white}

/* ─────────── TOAST ─────────── */
.toast{
  position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(80px);
  background:var(--caramel);color:#1A0D00;
  padding:10px 20px;border-radius:30px;
  font-size:13px;font-weight:700;
  transition:transform .3s;z-index:400;white-space:nowrap;
  box-shadow:0 4px 20px rgba(0,0,0,.4);
}
.toast.show{transform:translateX(-50%) translateY(0)}

/* ─────────── FLOAT CART HINT ─────────── */
.float-hint{
  display:none;
  position:fixed;bottom:18px;left:50%;transform:translateX(-50%);
  background:var(--caramel);color:#1A0D00;
  border-radius:30px;padding:12px 22px;
  font-size:14px;font-weight:700;
  cursor:pointer;z-index:180;
  box-shadow:0 6px 24px rgba(212,136,42,.45);
  align-items:center;gap:8px;
  max-width:calc(100vw - 24px);
}
.float-hint.visible{display:flex;animation:slideUpIn .3s ease}
@keyframes slideUpIn{from{transform:translateX(-50%) translateY(20px);opacity:0}to{transform:translateX(-50%) translateY(0);opacity:1}}
.float-hint:active{transform:translateX(-50%) scale(.96)}
/* Badge "Hemat Rp..." di samping harga total */
.float-savings{
  display:inline-block;
  background:#1A0D00;color:#52C87A;
  font-size:10.5px;font-weight:800;letter-spacing:.3px;
  padding:3px 8px;border-radius:14px;
  margin-left:4px;
  animation:savingsPulse 2.2s ease-in-out infinite;
}
@keyframes savingsPulse{
  0%,100%{transform:scale(1)}
  50%{transform:scale(1.06)}
}

/* ─────────── FLY ANIMATION ─────────── */
.fly-item{
  position:fixed;
  width:40px;height:40px;border-radius:50%;
  background:var(--caramel);color:#1A0D00;
  display:flex;align-items:center;justify-content:center;
  font-size:18px;font-weight:800;
  z-index:350;pointer-events:none;
  opacity:0;
  box-shadow:0 4px 16px rgba(212,136,42,.5);
}

/* ─────────── CATEGORY SECTIONS ─────────── */
.cat-section{scroll-margin-top:200px}
.cat-section.hidden{display:none}

/* ─────────── NO RESULTS ─────────── */
.no-results{
  text-align:center;padding:60px 20px 40px;color:var(--muted);
}
.no-results .emo{font-size:48px;margin-bottom:12px;opacity:.6}
.no-results p{font-size:14px;line-height:1.6}
.no-results small{font-size:12px;color:var(--muted);opacity:.8}

.no-results-suggestions{
  margin-top:20px;
  display:flex;flex-direction:column;align-items:center;gap:10px;
}
.no-results-label{
  font-size:11px;font-weight:600;color:var(--cream-dim);
  text-transform:uppercase;letter-spacing:1px;
  opacity:.7;
}
.no-results-chips{
  display:flex;flex-wrap:wrap;justify-content:center;gap:6px;
  max-width:340px;
}
.no-results-chip{
  background:var(--surface2);border:1px solid var(--border);
  border-radius:14px;padding:6px 12px;
  font-family:'Outfit',sans-serif;font-size:12px;font-weight:600;
  color:var(--caramel-light);cursor:pointer;
  transition:all .15s;
}
.no-results-chip:hover,.no-results-chip:active{
  background:var(--caramel-pale);border-color:var(--caramel);color:var(--cream);
  transform:translateY(-1px);
}
.no-results-reset{
  margin-top:8px;
  background:transparent;border:1px solid var(--caramel);
  border-radius:18px;padding:8px 18px;
  font-family:'Outfit',sans-serif;font-size:12px;font-weight:700;
  color:var(--caramel);cursor:pointer;letter-spacing:.3px;
  transition:all .15s;
}
.no-results-reset:hover,.no-results-reset:active{
  background:var(--caramel);color:#1A0D00;
}

/* ─────────── CONFIRM MODAL ─────────── */
.confirm-overlay{
  display:none;
  position:fixed;inset:0;z-index:450;
  background:rgba(0,0,0,.75);backdrop-filter:blur(4px);
  align-items:center;justify-content:center;padding:20px;
  animation:fadeIn .2s ease;
}
.confirm-overlay.open{display:flex}
.confirm-modal{
  background:var(--surface);border:1px solid var(--border);
  border-radius:18px;padding:24px 22px 18px;
  max-width:340px;width:100%;text-align:center;
  animation:scaleIn .25s ease;
}
@keyframes scaleIn{from{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}
.confirm-emoji{font-size:42px;margin-bottom:10px}
.confirm-title{
  font-family:'Fraunces',serif;font-size:20px;font-weight:700;
  color:var(--caramel-light);margin-bottom:6px;
}
.confirm-text{font-size:13px;color:var(--cream-dim);margin-bottom:18px}
.confirm-actions{display:flex;gap:8px}
.confirm-no, .confirm-yes{
  flex:1;padding:12px;border-radius:10px;
  font-family:'Outfit',sans-serif;font-size:13.5px;font-weight:700;
  cursor:pointer;border:none;
}
.confirm-no{background:var(--card);color:var(--cream);border:1px solid var(--border)}
.confirm-yes{background:var(--red);color:white}
.confirm-no:active{background:var(--surface2)}
.confirm-yes:active{opacity:.8}

.success-modal .confirm-title{color:var(--green)}
.success-tips{
  display:flex;flex-direction:column;gap:6px;
  margin-bottom:14px;text-align:left;
}
.success-tip{
  background:var(--surface2);border:1px solid var(--border);
  border-radius:8px;padding:8px 12px;
  font-size:12.5px;color:var(--cream-dim);
}
/* Fallback WA block */
.success-fallback{
  background:rgba(212,136,42,.06);
  border:1px solid rgba(212,136,42,.2);
  border-radius:10px;padding:12px 14px;
  margin-bottom:14px;text-align:left;
}
.success-fallback-title{
  font-size:12px;font-weight:800;color:var(--caramel);
  margin-bottom:4px;letter-spacing:.2px;
}
.success-fallback-text{
  font-size:11.5px;color:var(--cream-dim);margin-bottom:10px;
}
.success-fallback-options{
  display:flex;flex-direction:column;gap:8px;
}
.success-fallback-btn{
  display:inline-flex;align-items:center;justify-content:center;gap:7px;
  background:linear-gradient(135deg,#25D366,#128C7E);
  color:#fff;font-size:12.5px;font-weight:700;
  padding:9px 16px;border-radius:9px;
  text-decoration:none;
  transition:opacity .15s;
}
.success-fallback-btn:active{opacity:.8}
.success-fallback-or{
  text-align:center;font-size:11px;
  color:var(--muted);letter-spacing:.5px;
}
.success-fallback-manual{
  font-size:12px;color:var(--cream-dim);
  line-height:1.7;
}
.success-fallback-link{
  color:var(--caramel);font-weight:700;
  text-decoration:none;border-bottom:1px dashed rgba(212,136,42,.4);
}

/* ─────────── BOTTOM SHEET CART (mobile) ─────────── */
@media(max-width:600px){
  .cart-drawer{
    right:0;left:0;top:auto;bottom:0;
    width:100%;max-height:92vh;
    border-left:none;border-top:1px solid var(--border);
    border-radius:20px 20px 0 0;
    transform:translateY(100%);
  }
  .cart-drawer.open{transform:translateY(0)}
  .drawer-head{position:relative}
  .drawer-head::before{
    content:'';display:block;
    position:absolute;top:8px;left:50%;transform:translateX(-50%);
    width:40px;height:4px;border-radius:2px;
    background:var(--border-glow);
  }
}

/* ─────────── BIGGER SCREENS ─────────── */
@media(min-width:600px){
  .menu-grid{grid-template-columns:repeat(3,1fr)}
  .hero h1{font-size:42px}
  .hero{padding:42px 24px 36px}
  .card-emoji{height:140px}
}
@media(min-width:900px){
  .menu-grid{grid-template-columns:repeat(4,1fr)}
}

/* ─────────── SOCIAL MEDIA FOOTER ─────────── */
.socmed-footer{
  padding:28px 18px 36px;
  max-width:900px;margin:0 auto;
  border-top:1px solid var(--border);
  text-align:center;
}
.socmed-title{
  font-size:12.5px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;
  color:var(--muted);margin-bottom:14px;
}
.socmed-links{display:flex;flex-direction:column;gap:9px;max-width:360px;margin:0 auto}
.socmed-btn{
  display:flex;align-items:center;gap:10px;
  background:var(--card);border:1.5px solid var(--border);
  border-radius:var(--radius);padding:12px 16px;
  color:var(--cream);text-decoration:none;
  font-size:14px;font-weight:600;
  transition:border-color .2s,background .2s;
}
.socmed-btn svg{width:18px;height:18px;flex-shrink:0;color:var(--caramel)}
.socmed-btn:active{background:var(--caramel-pale)}
.socmed-wa svg{color:#25D366}
.socmed-tag{
  margin-left:auto;
  font-size:10px;font-weight:700;letter-spacing:.7px;text-transform:uppercase;
  background:var(--caramel-pale);color:var(--caramel);
  padding:3px 8px;border-radius:10px;
}
.socmed-wa .socmed-tag{background:rgba(37,211,102,0.12);color:#25D366}

/* ─────────── BUKTI ORDER SECTION ─────────── */
.testi-section{
  padding:40px 0 28px;
  border-top:1px solid var(--border);
  overflow:hidden;
  background:linear-gradient(180deg, transparent 0%, rgba(212,136,42,0.03) 100%);
}
.testi-head{text-align:center;padding:0 20px;margin-bottom:18px}
.testi-badge{
  display:inline-block;
  background:var(--caramel-pale);border:1px solid var(--border-glow);
  color:var(--caramel);font-size:10.5px;font-weight:700;
  letter-spacing:1.5px;padding:5px 14px;border-radius:30px;
  margin-bottom:12px;
}
.testi-title{
  font-family:'Fraunces',serif;font-size:22px;font-weight:700;
  color:var(--caramel-light);margin-bottom:6px;line-height:1.2;
}
.testi-sub{font-size:12.5px;color:var(--cream-dim)}
.testi-sub a{color:var(--caramel);text-decoration:none;font-weight:600}
.testi-sub a:active{opacity:.7}

/* Stats row */
.proof-stats{
  display:flex;justify-content:center;align-items:stretch;
  gap:0;padding:0 14px;margin-bottom:20px;
  max-width:480px;margin-left:auto;margin-right:auto;
}
.proof-stat{
  flex:1;text-align:center;padding:6px 4px;
  position:relative;
}
.proof-stat:not(:last-child)::after{
  content:'';position:absolute;right:0;top:20%;bottom:20%;
  width:1px;background:var(--border);
}
.proof-num{
  font-family:'Fraunces',serif;font-weight:900;
  font-size:30px;line-height:1;color:var(--caramel);
  margin-bottom:4px;
}
.proof-num span{font-size:20px;color:var(--caramel-light)}
.proof-lbl{
  font-size:10.5px;font-weight:600;
  color:var(--cream-dim);letter-spacing:.4px;
  line-height:1.3;
}

/* Carousel track */
.testi-track{
  display:flex;gap:12px;
  padding:0 14px 6px;
  overflow-x:auto;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:none;
}
.testi-track::-webkit-scrollbar{display:none}

/* Receipt-style order proof card */
.testi-card{
  flex-shrink:0;
  width:200px;
  background:linear-gradient(180deg, #FDF8F0 0%, #F5EDD9 100%);
  color:#2A1A08;
  border:1.5px solid var(--border);
  border-radius:14px;padding:14px 14px 12px;
  display:flex;flex-direction:column;gap:8px;
  position:relative;
  box-shadow:0 4px 14px rgba(0,0,0,0.25);
}
.testi-card::before{
  content:'';
  position:absolute;left:0;right:0;top:8px;
  height:3px;
  background:repeating-linear-gradient(90deg, var(--caramel) 0 6px, transparent 6px 10px);
  opacity:.4;
}
.proof-status{
  display:flex;align-items:center;gap:6px;
  font-size:10px;font-weight:700;letter-spacing:.5px;
  color:#2D8F4F;text-transform:uppercase;
  padding-top:8px;
}
.proof-status::before{
  content:'';width:7px;height:7px;border-radius:50%;
  background:#2D8F4F;
  box-shadow:0 0 0 3px rgba(45,143,79,0.2);
}
.proof-orderlbl{
  font-size:9.5px;font-weight:700;
  color:#7A5A3A;letter-spacing:1.2px;
  text-transform:uppercase;
}
.proof-ordernum{
  font-family:'Fraunces',serif;font-weight:900;
  font-size:36px;line-height:.95;
  color:#2A1A08;letter-spacing:1px;
}
.proof-name{
  font-size:11px;color:#5C4528;
  padding-top:8px;
  border-top:1px dashed rgba(122,90,58,0.3);
}
.proof-name b{color:#2A1A08;font-weight:700;text-transform:capitalize}
.proof-foot{
  display:flex;justify-content:space-between;align-items:center;
  font-size:9.5px;color:#7A5A3A;font-weight:600;
}
.proof-foot .check{color:#2D8F4F;font-weight:700}

/* CTA */
.proof-cta-wrap{text-align:center;padding:18px 20px 0}
.proof-cta{
  display:inline-block;
  background:transparent;border:1.5px solid var(--caramel);
  color:var(--caramel);
  font-family:'Outfit',sans-serif;font-size:12.5px;font-weight:700;
  padding:10px 22px;border-radius:30px;
  text-decoration:none;letter-spacing:.3px;
  transition:all .2s;
}
.proof-cta:active{background:var(--caramel-pale)}

/* ─────────── PREVIEW MODAL ─────────── */
.preview-modal{
  max-width:380px;
  padding:20px 18px 16px;
}
.preview-head{text-align:center;margin-bottom:14px}
.preview-head .confirm-title{margin-bottom:4px}
.preview-sub{font-size:12px;color:var(--cream-dim)}
.preview-body{
  background:var(--surface2);
  border:1px solid var(--border);
  border-radius:10px;
  padding:12px 14px;
  margin-bottom:14px;
  text-align:left;
  max-height:50vh;
  overflow-y:auto;
  font-family:'Outfit',sans-serif;
  font-size:12px;line-height:1.65;
  color:var(--cream-dim);
}
.preview-body::-webkit-scrollbar{width:4px}
.preview-body::-webkit-scrollbar-thumb{background:var(--border-glow);border-radius:2px}
.preview-row{display:flex;gap:6px;margin-bottom:3px}
.preview-row.pv-divider{
  border-top:1px dashed var(--border);
  margin:8px 0;padding-top:0;
}
.preview-label{color:var(--muted);font-weight:600;flex-shrink:0}
.preview-val{color:var(--cream);font-weight:500}
.pv-item{margin:8px 0;padding-left:4px;border-left:2px solid var(--caramel);padding-left:10px}
.pv-item-name{color:var(--cream);font-weight:700;font-size:12.5px;margin-bottom:2px}
.pv-item-detail{font-size:11px;color:var(--cream-dim)}
.pv-item-price{color:var(--caramel);font-weight:700;font-size:11.5px;margin-top:3px}
.pv-total{
  margin-top:10px;padding-top:10px;
  border-top:1px solid var(--border);
  display:flex;justify-content:space-between;align-items:baseline;
}
.pv-total-label{color:var(--cream-dim);font-size:12px}
.pv-total-price{
  color:var(--caramel);font-weight:800;
  font-size:17px;font-family:'Fraunces',serif;
}

.preview-actions{display:flex;gap:8px}
.preview-actions .confirm-no, .preview-actions .confirm-yes{
  flex:1;padding:13px 8px;font-size:13px;
  display:flex;align-items:center;justify-content:center;gap:7px;
}
.preview-send-btn{
  background:linear-gradient(135deg,#25D366,#128C7E);
  color:white;border:none;
}

/* ─────────── CONFETTI ─────────── */
.confetti-piece{
  position:fixed;
  width:8px;height:14px;
  top:-20px;
  z-index:500;
  pointer-events:none;
  border-radius:2px;
  animation:confettiFall 2.4s linear forwards;
}
@keyframes confettiFall{
  0%{transform:translateY(0) rotate(0deg);opacity:1}
  100%{transform:translateY(110vh) rotate(720deg);opacity:0}
}

/* ─────────── STAGGERED FADE-IN ─────────── */
.menu-card{
  opacity:0;
  transform:translateY(20px);
  transition:opacity .45s ease, transform .45s ease, border-color .2s, background .2s;
}
.menu-card.fade-in{
  opacity:1;
  transform:translateY(0);
}

/* ─────────── COPYRIGHT ─────────── */
.copyright{
  padding:16px 20px 28px;
  text-align:center;
  border-top:1px solid var(--border);
}
.copyright-inner{
  display:flex;align-items:center;justify-content:center;
  flex-wrap:wrap;gap:6px;
  font-size:12px;color:var(--muted);margin-bottom:6px;
}
.copyright-logo{
  font-family:'Fraunces',serif;font-weight:700;
  color:var(--caramel);font-size:13px;
}
.copyright-divider{color:var(--border-glow)}
.copyright-note{
  font-size:10.5px;color:var(--muted);opacity:.6;line-height:1.5;
}

/* ─────────── BRAND SWITCHER ─────────── */
/* Catatan: ga di-sticky-in karena di HP bikin header-stack kepanjangan
   (header + brand-switcher + search + tabs = nutupin menu). User ga sering
   ganti brand, jadi cukup scroll ke atas dikit kalau mau pindah. */
.brand-switcher-wrap{
  padding:14px 14px 0;
}
.brand-switcher-label{
  font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;
  color:var(--muted);margin-bottom:8px;
}
.brand-switcher{
  display:flex;gap:8px;
  overflow-x:auto;padding-bottom:2px;
  scrollbar-width:none;
}
.brand-switcher::-webkit-scrollbar{display:none}
.brand-btn{
  display:flex;align-items:center;gap:7px;
  padding:9px 14px;border-radius:30px;
  background:var(--surface2);border:1.5px solid var(--border);
  color:var(--cream-dim);font-family:'Outfit',sans-serif;
  font-size:12.5px;font-weight:600;
  cursor:pointer;white-space:nowrap;flex-shrink:0;
  transition:all .2s;
}
.brand-btn.active{
  background:var(--caramel);border-color:var(--caramel);
  color:#1A0D00;
}
.brand-btn:not(.active):hover{
  border-color:var(--border-glow);color:var(--cream);
}
.brand-btn-emoji{font-size:14px}
.brand-btn-name{font-weight:700}

/* ─────────── PROMO PAGE ─────────── */
.brand-page{padding:0 14px 80px;}

.promo-page-hero{
  text-align:center;padding:28px 0 22px;
}
.promo-page-badge{
  display:inline-block;
  background:var(--caramel-pale);border:1px solid var(--border-glow);
  color:var(--caramel-light);font-size:11px;font-weight:700;
  letter-spacing:1.2px;text-transform:uppercase;
  padding:5px 14px;border-radius:30px;margin-bottom:12px;
}
.promo-page-title{
  font-family:'Fraunces',serif;font-size:30px;font-weight:900;
  color:var(--cream);line-height:1.1;margin-bottom:6px;
}
.promo-page-title span{color:var(--caramel-light)}
.promo-page-sub{font-size:12.5px;color:var(--muted);}

/* ─────────── PROMO CARDS ─────────── */
.promo-cards{display:flex;flex-direction:column;gap:14px;margin-bottom:24px;}

.promo-card{
  background:var(--surface);
  border:1.5px solid var(--border);
  border-radius:18px;overflow:hidden;
}

.promo-card-header{
  padding:18px 18px 16px;
  position:relative;
}
/* Tomoro B1G1 */
.tomoro-b1g1{
  background:linear-gradient(135deg,#3D2700 0%,#6B3D00 100%);
  border-bottom:1px solid rgba(212,136,42,0.3);
}
/* Tomoro 50% */
.tomoro-50{
  background:linear-gradient(135deg,#1A2A00 0%,#2E4A00 100%);
  border-bottom:1px solid rgba(100,180,50,0.3);
}
/* Fore 35% */
.fore-35{
  background:linear-gradient(135deg,#002A1A 0%,#004A2E 100%);
  border-bottom:1px solid rgba(50,200,120,0.3);
}
/* Fore 25% */
.fore-25{
  background:linear-gradient(135deg,#001A2E 0%,#002E4A 100%);
  border-bottom:1px solid rgba(50,150,220,0.3);
}
/* Fore B1G1 */
.fore-b1g1{
  background:linear-gradient(135deg,#1A001A 0%,#3A0050 100%);
  border-bottom:1px solid rgba(180,80,220,0.3);
}

.promo-tag{
  display:inline-block;
  font-size:9.5px;font-weight:800;letter-spacing:1.5px;
  color:rgba(255,255,255,0.5);margin-bottom:6px;
}
.promo-card-title{
  font-family:'Fraunces',serif;font-size:26px;font-weight:900;
  color:#FFFFFF;line-height:1.05;margin-bottom:4px;
}
.promo-card-sub{
  font-size:12.5px;color:rgba(255,255,255,0.55);font-weight:400;
}

.promo-card-body{
  padding:14px 18px 18px;
  display:flex;flex-direction:column;gap:12px;
}

.promo-fee-row{
  display:flex;align-items:center;justify-content:space-between;
  background:var(--caramel-pale);border:1px solid var(--border-glow);
  border-radius:10px;padding:10px 14px;
}
.promo-fee-label{font-size:12px;font-weight:600;color:var(--cream-dim);}
.promo-fee-val{font-size:14px;font-weight:800;color:var(--caramel-light);}

.promo-scope{
  background:rgba(82,200,122,0.07);
  border:1px solid rgba(82,200,122,0.2);
  border-radius:10px;padding:10px 14px;
}
.promo-scope-title{font-size:11px;font-weight:700;color:#52C87A;margin-bottom:4px;letter-spacing:.5px;}
.promo-scope-val{font-size:13px;color:var(--cream);font-weight:500;}

.promo-exclude{
  background:rgba(224,82,82,0.07);
  border:1px solid rgba(224,82,82,0.2);
  border-radius:10px;padding:10px 14px;
}
.promo-exclude-title{font-size:11px;font-weight:700;color:#E05252;margin-bottom:6px;letter-spacing:.5px;}
.promo-exclude-list{
  list-style:none;display:flex;flex-direction:column;gap:3px;
}
.promo-exclude-list li{
  font-size:12.5px;color:var(--cream-dim);padding-left:14px;position:relative;
}
.promo-exclude-list li::before{
  content:'·';position:absolute;left:4px;color:var(--red);
}

/* ─────────── ORDER CTA ─────────── */
.promo-order-cta{
  text-align:center;padding:10px 0 0;
}
.promo-order-text{
  font-size:13px;color:var(--muted);margin-bottom:12px;
}
.promo-wa-btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  background:linear-gradient(135deg,#25D366,#128C7E);
  color:#fff;border-radius:14px;
  padding:13px 24px;
  font-family:'Outfit',sans-serif;font-size:14px;font-weight:700;
  text-decoration:none;
  box-shadow:0 4px 16px rgba(37,211,102,.3);
  transition:transform .15s,box-shadow .15s;
}
.promo-wa-btn:active{transform:scale(.97)}

/* ═══════════════════════════════════════
   TOMORO COFFEE BRAND THEME
   Brand color: #FFCC00 (kuning khas Tomoro)
   ═══════════════════════════════════════ */
.tomoro-theme{ background:transparent; }

.tomoro-hero{
  background:linear-gradient(180deg,rgba(255,204,0,0.08) 0%,transparent 100%);
  border-bottom:1px solid rgba(255,204,0,0.15);
  padding:28px 0 22px;
  text-align:center;
}
.brand-logo-wrap{
  display:inline-flex;flex-direction:column;align-items:center;
  margin-bottom:10px;
}
.tomoro-logo-wrap{
  background:#FFCC00;border-radius:16px;
  padding:12px 24px 10px;
  box-shadow:0 4px 24px rgba(255,204,0,0.35);
}
.tomoro-logo-text{
  font-family:'Outfit',sans-serif;
  font-size:28px;font-weight:900;letter-spacing:3px;
  color:#000000;line-height:1;
  text-transform:uppercase;
}
.brand-logo-sub{
  font-family:'Outfit',sans-serif;
  font-size:10px;font-weight:700;letter-spacing:3px;
  text-transform:uppercase;
  color:#000;opacity:.6;margin-top:2px;
}

.tomoro-card{border-color:rgba(255,204,0,0.2);}
.tomoro-card:hover{border-color:rgba(255,204,0,0.4);}

/* override header gradients for Tomoro */
.tomoro-b1g1{
  background:linear-gradient(135deg,#1A1000 0%,#3D2E00 100%);
  border-bottom:1px solid rgba(255,204,0,0.35);
}
.tomoro-50{
  background:linear-gradient(135deg,#1A1000 0%,#332500 100%);
  border-bottom:1px solid rgba(255,204,0,0.25);
}
.tomoro-tag{color:rgba(255,204,0,0.55);}
.tomoro-title{color:#FFCC00 !important;}

.tomoro-fee-row{
  background:rgba(255,204,0,0.08);
  border:1px solid rgba(255,204,0,0.25);
}
.tomoro-fee-val{color:#FFCC00 !important;}

.tomoro-toggle{
  background:rgba(255,204,0,0.08);
  border:1px solid rgba(255,204,0,0.25);
  color:#FFCC00;
}
.tomoro-toggle:hover{background:rgba(255,204,0,0.14);}

.tomoro-copy-btn{
  background:#FFCC00;color:#1A1000;
}
.tomoro-copy-btn:hover{background:#FFD633;}
.tomoro-copy-btn.copied{background:#52C87A;color:#fff;}

.tomoro-wa-btn{
  background:linear-gradient(135deg,#25D366,#128C7E);
  box-shadow:0 4px 16px rgba(37,211,102,.3);
}

/* Tomoro banner */
.tomoro-banner{
  border-color:rgba(255,204,0,0.25);
  background:linear-gradient(135deg,rgba(255,204,0,0.06),rgba(255,204,0,0.02));
}
.tomoro-banner-btn{
  background:#FFCC00;color:#1A1000;
  font-weight:800;
}

/* brand switcher active state for tomoro */
.brand-btn[data-brand="tomoro"].active{
  background:#FFCC00;border-color:#FFCC00;color:#1A1000;
}

/* ═══════════════════════════════════════
   FORE COFFEE BRAND THEME
   Brand color: #00C882 (hijau signature Fore)
   ═══════════════════════════════════════ */
.fore-theme{ background:transparent; }

.fore-hero{
  background:linear-gradient(180deg,rgba(0,200,130,0.08) 0%,transparent 100%);
  border-bottom:1px solid rgba(0,200,130,0.15);
  padding:28px 0 22px;
  text-align:center;
}
.fore-logo-wrap{
  background:linear-gradient(135deg,#00C882,#009E68);
  border-radius:18px;
  padding:14px 28px 12px;
  box-shadow:0 6px 28px rgba(0,200,130,0.4);
  display:inline-flex;flex-direction:column;align-items:center;
}
.fore-logo-text{
  font-family:'Fraunces',serif;
  font-size:36px;font-weight:900;
  color:#FFFFFF;line-height:1;
  letter-spacing:1px;
  text-transform:none;
}
.fore-logo-sub{
  font-family:'Outfit',sans-serif;
  font-size:11px;font-weight:600;letter-spacing:4px;
  color:rgba(255,255,255,0.7) !important;
  text-transform:uppercase;margin-top:1px;
}

.fore-card{border-color:rgba(0,200,130,0.2);}
.fore-card:hover{border-color:rgba(0,200,130,0.4);}

/* override header gradients for Fore */
.fore-35{
  background:linear-gradient(135deg,#001A0E 0%,#003822 100%);
  border-bottom:1px solid rgba(0,200,130,0.3);
}
.fore-25{
  background:linear-gradient(135deg,#001A12 0%,#002E1E 100%);
  border-bottom:1px solid rgba(0,200,130,0.2);
}
.fore-b1g1{
  background:linear-gradient(135deg,#001208 0%,#002614 100%);
  border-bottom:1px solid rgba(0,200,130,0.25);
}
.fore-tag{color:rgba(0,200,130,0.55);}
.fore-title{color:#00C882 !important;}

.fore-fee-row{
  background:rgba(0,200,130,0.07);
  border:1px solid rgba(0,200,130,0.25);
}
.fore-fee-val{color:#00C882 !important;}

.fore-toggle{
  background:rgba(0,200,130,0.08);
  border:1px solid rgba(0,200,130,0.25);
  color:#00C882;
}
.fore-toggle:hover{background:rgba(0,200,130,0.14);}

.fore-copy-btn{
  background:#00C882;color:#001A0E;
}
.fore-copy-btn:hover{background:#00DC90;}
.fore-copy-btn.copied{background:#52C87A;color:#fff;}

.fore-wa-btn{
  background:linear-gradient(135deg,#25D366,#128C7E);
  box-shadow:0 4px 16px rgba(37,211,102,.3);
}

/* Fore banner */
.fore-banner{
  border-color:rgba(0,200,130,0.25);
  background:linear-gradient(135deg,rgba(0,200,130,0.06),rgba(0,200,130,0.02));
}
.fore-banner-btn{
  background:#00C882;color:#001A0E;
  font-weight:800;
}

/* brand switcher active state for fore */
.brand-btn[data-brand="fore"].active{
  background:#00C882;border-color:#00C882;color:#001A0E;
}

/* ═══════════════════════════════════════
   CONTACT BANNER
   ═══════════════════════════════════════ */
.contact-banner{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  border:1.5px solid;border-radius:14px;
  padding:13px 14px;margin-bottom:16px;
}
.contact-banner-text{
  display:flex;align-items:center;gap:10px;
}
.contact-banner-icon{font-size:22px;flex-shrink:0;}
.contact-banner-title{
  font-size:13.5px;font-weight:700;color:var(--cream);
  margin-bottom:2px;
}
.contact-banner-sub{
  font-size:11px;color:var(--muted);
}
.contact-banner-btn{
  flex-shrink:0;
  padding:9px 16px;border-radius:30px;
  font-family:'Outfit',sans-serif;font-size:12px;font-weight:800;
  text-decoration:none;white-space:nowrap;
  transition:transform .15s,opacity .2s;
}
.contact-banner-btn:active{transform:scale(.95);}

/* ═══════════════════════════════════════
   WA TEMPLATE ACCORDION
   ═══════════════════════════════════════ */
.wa-template-wrap{margin-top:4px;}

.wa-template-toggle{
  width:100%;display:flex;align-items:center;justify-content:space-between;
  padding:11px 14px;border-radius:10px;
  font-family:'Outfit',sans-serif;font-size:12.5px;font-weight:700;
  border:1.5px solid;cursor:pointer;
  transition:background .2s;
}
.toggle-arrow{
  font-size:10px;
  transition:transform .25s;
}
.wa-template-toggle.open .toggle-arrow{transform:rotate(180deg);}

.wa-template-box{
  margin-top:8px;
  background:rgba(0,0,0,0.3);
  border:1px solid var(--border);
  border-radius:10px;overflow:hidden;
}
.wa-template-label{
  padding:8px 12px 4px;
  font-size:10.5px;font-weight:700;letter-spacing:.5px;
  color:var(--muted);text-transform:uppercase;
}
.wa-template-text{
  display:block;
  padding:10px 12px 12px;
  font-family:'Outfit',monospace;
  font-size:12px;line-height:1.7;
  color:var(--cream);
  white-space:pre-wrap;word-break:break-word;
  border:none;background:transparent;
}
.wa-copy-btn{
  display:block;width:calc(100% - 24px);
  margin:0 12px 12px;
  padding:10px;border-radius:8px;
  font-family:'Outfit',sans-serif;font-size:12.5px;font-weight:700;
  border:none;cursor:pointer;
  transition:background .2s,transform .15s;
}
.wa-copy-btn:active{transform:scale(.97);}

/* ─────────── BRAND LOGO IMAGES ─────────── */

/* Logo di brand switcher button */
.brand-btn-logo{
  width:26px;height:26px;
  object-fit:contain;
  border-radius:6px;
  mix-blend-mode:screen;   /* biar background hitam jadi transparan */
  flex-shrink:0;
}

/* Logo besar di hero Tomoro & Fore */
.brand-hero-logo{
  width:90px;height:90px;
  object-fit:contain;
  mix-blend-mode:screen;
  filter:drop-shadow(0 4px 16px rgba(255,255,255,0.15));
  margin-bottom:8px;
}

/* Override logo-wrap jadi kolom biasa tanpa background pill */
.tomoro-logo-wrap,
.fore-logo-wrap{
  background:transparent !important;
  box-shadow:none !important;
  padding:0 !important;
  border-radius:0 !important;
  display:inline-flex;
  flex-direction:column;
  align-items:center;
  gap:2px;
}

/* Nama brand di bawah logo hero */
.brand-hero-name{
  font-family:'Outfit',sans-serif;
  font-size:13px;font-weight:700;
  letter-spacing:2px;text-transform:uppercase;
  opacity:0.5;
}
.tomoro-hero-name{ color:#FFCC00; }
.fore-hero-name  { color:#00C882; }

/* Pastikan tomoro-hero-logo scale shadow sesuai warna */
.tomoro-hero-logo{ filter:drop-shadow(0 4px 20px rgba(255,204,0,0.4)); }
.fore-hero-logo  { filter:drop-shadow(0 4px 20px rgba(0,200,130,0.4)); }

/* ─────────── BRAND INTRO GRID (di welcome modal) ─────────── */
.brand-intro-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:8px;
  margin:18px 0 20px;
}
.brand-intro-item{
  background:var(--surface2);border:1px solid var(--border);
  border-radius:12px;padding:12px 6px 10px;
  display:flex;flex-direction:column;align-items:center;gap:4px;
  text-align:center;
}
.brand-intro-item img{
  width:44px;height:44px;object-fit:contain;
  margin-bottom:2px;
}
.brand-intro-item span{
  font-size:11.5px;font-weight:700;color:var(--cream);
  line-height:1.2;
}
.brand-intro-item small{
  font-size:9.5px;color:var(--muted);font-weight:500;
}

/* ── Brand intro clickable ── */
.brand-intro-hint{
  text-align:center;font-size:11px;color:var(--gold);
  opacity:0.7;margin:-6px 0 4px;font-style:italic;
}
.brand-intro-clickable{
  cursor:pointer;
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease;
  border:1.5px solid var(--border) !important;
  padding-bottom:8px !important;
  user-select:none;
  -webkit-tap-highlight-color:transparent;
}
.brand-intro-clickable:hover{
  transform:translateY(-3px) scale(1.04);
  box-shadow:0 8px 22px rgba(212,160,73,.22);
  border-color:rgba(212,160,73,.55) !important;
}
.brand-intro-clickable:active{
  transform:scale(0.95);
  box-shadow:0 2px 8px rgba(212,160,73,.15);
}
.brand-intro-tap{
  font-size:9px;font-weight:700;letter-spacing:.04em;
  color:var(--gold);margin-top:3px;
  opacity:0;transition:opacity .18s;
  text-transform:uppercase;
}
.brand-intro-clickable:hover .brand-intro-tap{
  opacity:1;
}
/* On mobile, always show the tap hint */
@media(hover:none){
  .brand-intro-tap{ opacity:.8; }
}

/* ── Cara Order label ── */
.how-to-label{
  font-size:13px;font-weight:800;letter-spacing:.1em;
  text-transform:uppercase;color:var(--gold);
  opacity:.85;margin-bottom:10px;padding-top:4px;
  display:flex;align-items:center;justify-content:center;gap:6px;
}

/* ─────────── BRAND SWITCHER ENHANCEMENT ─────────── */
.brand-switcher-label{
  display:flex;align-items:center;justify-content:space-between;
  padding:0 4px;margin-bottom:10px;
  gap:8px;
}
.brand-switcher-label > span:first-child{
  font-family:'Outfit',sans-serif;
  font-size:11px;font-weight:700;letter-spacing:1px;
  color:var(--muted);text-transform:uppercase;
  display:inline-flex;align-items:center;gap:8px;
  flex:1;min-width:0;
}
/* Hint "geser →" di samping label — animasi pulse biar user notice */
.brand-swipe-hint{
  font-size:10px;font-weight:600;color:var(--caramel);
  letter-spacing:0.3px;text-transform:none;
  opacity:.8;
  animation:hintPulse 2s ease-in-out infinite;
  flex-shrink:0;
}
.brand-switcher-hint{
  font-size:10px;font-weight:600;
  color:var(--caramel);
  background:var(--caramel-pale);
  padding:3px 9px;border-radius:20px;
  border:1px solid var(--border-glow);
  flex-shrink:0;
}

/* tag di tiap brand button */
.brand-btn{
  position:relative;
  padding-bottom:22px !important;
}
.brand-btn-tag{
  position:absolute;bottom:6px;left:50%;transform:translateX(-50%);
  font-size:8.5px;font-weight:700;letter-spacing:.4px;
  padding:2px 8px;border-radius:10px;
  white-space:nowrap;text-transform:uppercase;
}
.brand-tag-full{
  background:rgba(82,200,122,0.15);
  color:#52C87A;
  border:1px solid rgba(82,200,122,0.3);
}
.brand-tag-promo{
  background:rgba(212,136,42,0.15);
  color:var(--caramel-light);
  border:1px solid rgba(212,136,42,0.3);
}
.brand-btn.active .brand-btn-tag{
  filter:brightness(1.2);
}


/* ═══════════════════════════════════════════════════════
   🔥 ENHANCEMENT v4 — All upgrades
   ═══════════════════════════════════════════════════════ */

/* ── 1. Welcome Modal: Spring slide-up + grain texture ── */
@keyframes welcomeSpringUp {
  0%   { transform: translateY(110%) scale(.96); opacity:0; }
  55%  { transform: translateY(-8px) scale(1.01); opacity:1; }
  75%  { transform: translateY(4px) scale(.995); }
  90%  { transform: translateY(-2px) scale(1.003); }
  100% { transform: translateY(0) scale(1); opacity:1; }
}
@keyframes welcomeFadeIn {
  from { opacity:0; }
  to   { opacity:1; }
}
.welcome-overlay.open {
  display: flex;
  animation: welcomeFadeIn .2s ease forwards;
}
.welcome-overlay.open .welcome-modal {
  animation: welcomeSpringUp .55s cubic-bezier(.22,1,.36,1) forwards;
}
/* Grain texture overlay on modal — FIX: position absolute (was fixed + touch-action:none → blocked scroll on mobile) */
.welcome-modal::after {
  content:'';
  position:absolute;
  inset:0;
  border-radius:24px 24px 0 0;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");
  background-size: 180px 180px;
  pointer-events:none;
  z-index:0;opacity:.55;
}
.welcome-modal > * { position:relative;z-index:1; }

/* Coffee ring watermark — NOTE: Jangan pakai overflow:hidden di modal!
   Itu akan mematikan kemampuan scroll. Ring decoration di-clip via mask di pseudo-element. */
.welcome-modal .coffee-ring {
  position:absolute;
  width:160px;height:160px;
  border-radius:50%;
  border:18px solid rgba(212,136,42,.05);
  top:-40px;right:-40px;
  pointer-events:none;z-index:0;
}
.welcome-modal .coffee-ring-2 {
  position:absolute;
  width:90px;height:90px;
  border-radius:50%;
  border:12px solid rgba(212,136,42,.04);
  bottom:60px;left:-20px;
  pointer-events:none;z-index:0;
}

/* ── 2. Welcome emoji: Steam animation ── */
.welcome-emoji {
  position:relative;display:inline-block;
}
.steam-wrap {
  position:absolute;
  top:-22px;left:50%;transform:translateX(-50%);
  display:flex;gap:5px;
  pointer-events:none;
}
.steam {
  width:4px;height:18px;
  border-radius:4px;
  background:rgba(212,136,42,.35);
  animation:steamRise 1.6s ease-in-out infinite;
  transform-origin:bottom center;
}
.steam:nth-child(2){ animation-delay:.35s; height:14px; }
.steam:nth-child(3){ animation-delay:.7s; height:16px; }
@keyframes steamRise {
  0%   { transform:scaleX(1) translateY(0); opacity:.6; }
  50%  { transform:scaleX(1.5) translateY(-10px); opacity:.3; }
  100% { transform:scaleX(.8) translateY(-20px); opacity:0; }
}

/* ── 3. Brand card glow per brand ── */
.brand-btn[data-brand="kopken"].active,
.brand-btn[data-brand="kopken"]:hover:not(.active) {
  box-shadow: 0 0 14px rgba(220,50,50,.25);
}
.brand-btn[data-brand="tomoro"].active,
.brand-btn[data-brand="tomoro"]:hover:not(.active) {
  box-shadow: 0 0 14px rgba(255,200,0,.22);
}
.brand-btn[data-brand="fore"].active,
.brand-btn[data-brand="fore"]:hover:not(.active) {
  box-shadow: 0 0 14px rgba(0,200,130,.2);
}

/* Brand intro clickable glow per brand */
.brand-intro-clickable[onclick*="kopken"]:hover {
  box-shadow: 0 8px 22px rgba(220,50,50,.2) !important;
  border-color: rgba(220,50,50,.5) !important;
}
.brand-intro-clickable[onclick*="tomoro"]:hover {
  box-shadow: 0 8px 22px rgba(255,200,0,.2) !important;
  border-color: rgba(255,200,0,.5) !important;
}
.brand-intro-clickable[onclick*="fore"]:hover {
  box-shadow: 0 8px 22px rgba(0,200,130,.2) !important;
  border-color: rgba(0,200,130,.45) !important;
}

/* ── 4. Brand page slide transition ── */
.brand-page, #page-kopken {
  animation: none;
}
.brand-page.page-enter-left {
  animation: slideFromLeft .32s cubic-bezier(.4,0,.2,1) forwards;
}
.brand-page.page-enter-right {
  animation: slideFromRight .32s cubic-bezier(.4,0,.2,1) forwards;
}
#page-kopken.page-enter-left {
  animation: slideFromLeft .32s cubic-bezier(.4,0,.2,1) forwards;
}
#page-kopken.page-enter-right {
  animation: slideFromRight .32s cubic-bezier(.4,0,.2,1) forwards;
}
@keyframes slideFromLeft {
  from { opacity:0; transform:translateX(-28px); }
  to   { opacity:1; transform:translateX(0); }
}
@keyframes slideFromRight {
  from { opacity:0; transform:translateX(28px); }
  to   { opacity:1; transform:translateX(0); }
}

/* ── 5. Ripple on menu card ── */
.menu-card {
  overflow: hidden;
}
.ripple-effect {
  position:absolute;
  border-radius:50%;
  background:rgba(212,136,42,.18);
  transform:scale(0);
  animation:rippleAnim .55s linear;
  pointer-events:none;
}
@keyframes rippleAnim {
  to { transform:scale(4); opacity:0; }
}

/* ── 6. Cart count pop/bounce ── */
@keyframes cartCountPop {
  0%   { transform:scale(1); }
  40%  { transform:scale(1.55) rotate(-8deg); }
  65%  { transform:scale(.88) rotate(4deg); }
  85%  { transform:scale(1.12); }
  100% { transform:scale(1); }
}
.cart-count.pop {
  animation: cartCountPop .45s cubic-bezier(.22,1,.36,1);
}


/* ── 7. (Removed: brand-switcher scrolled compact mode)
   Brand-switcher tidak lagi sticky → ga butuh compact mode. ── */

/* ── 8. Empty cart animation ── */
.cart-empty {
  position:relative;
}
.cart-empty .emo {
  display:block;
  animation: emptyFloat 2.4s ease-in-out infinite;
}
@keyframes emptyFloat {
  0%,100% { transform:translateY(0) rotate(-3deg); }
  50%     { transform:translateY(-10px) rotate(4deg); }
}
/* Shadow di-anchor ke posisi emoji (top area), bukan bottom — biar
   ga overlap dengan suggestion list di bawah */
.cart-empty::before {
  content:'';
  position:absolute;
  top:78px;left:50%;transform:translateX(-50%);
  width:60px;height:10px;border-radius:50%;
  background:rgba(212,136,42,.12);
  animation:shadowPulse 2.4s ease-in-out infinite;
}
@keyframes shadowPulse {
  0%,100% { transform:translateX(-50%) scaleX(1); opacity:.4; }
  50%     { transform:translateX(-50%) scaleX(.6); opacity:.15; }
}
/* ── Suggestion menu di empty cart ── */
.cart-empty-sugg{
  margin-top:24px;
  padding-top:18px;
  border-top:1px dashed var(--border);
}
.cart-empty-sugg-label{
  font-size:11px;font-weight:700;letter-spacing:1px;
  color:var(--caramel-light);text-transform:uppercase;
  margin-bottom:12px;
}
.cart-empty-sugg-list{
  display:flex;flex-direction:column;gap:8px;
  text-align:left;
}
.sugg-item{
  display:flex;align-items:center;gap:10px;
  background:var(--surface2);
  border:1px solid var(--border);
  border-radius:12px;
  padding:8px 10px 8px 8px;
  cursor:pointer;
  transition:transform .15s ease, border-color .2s, background .2s;
  -webkit-tap-highlight-color:transparent;
}
.sugg-item:active{
  transform:scale(.97);
  background:var(--caramel-pale);
  border-color:var(--border-glow);
}
.sugg-item-img{
  width:42px;height:42px;border-radius:8px;
  object-fit:cover;flex-shrink:0;
  background:var(--card);
}
.sugg-item-info{
  flex:1;min-width:0;
}
.sugg-item-name{
  font-size:12.5px;font-weight:600;color:var(--cream);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  margin-bottom:2px;
}
.sugg-item-price{
  display:flex;align-items:center;gap:6px;
  font-size:11px;
}
.sugg-item-price-old{
  color:var(--muted);text-decoration:line-through;
  font-size:10.5px;
}
.sugg-item-price-new{
  color:var(--caramel-light);font-weight:700;
}
.sugg-item-arrow{
  color:var(--caramel);font-size:14px;flex-shrink:0;
  opacity:.6;
}

/* ── 9. Hero section: floating coffee emojis ── */
.hero-floaters {
  position:absolute;inset:0;pointer-events:none;overflow:hidden;
  z-index:0;
}
.hero-floater {
  position:absolute;font-size:22px;opacity:0;
  animation:floatUp 8s ease-in-out infinite;
}
.hero-floater:nth-child(1) { left:8%;  animation-delay:0s;   animation-duration:7s; }
.hero-floater:nth-child(2) { left:22%; animation-delay:1.5s; animation-duration:9s; font-size:16px; }
.hero-floater:nth-child(3) { left:70%; animation-delay:0.8s; animation-duration:8s; }
.hero-floater:nth-child(4) { left:85%; animation-delay:2.5s; animation-duration:10s; font-size:14px; }
.hero-floater:nth-child(5) { left:45%; animation-delay:3.5s; animation-duration:7.5s; font-size:18px; }
@keyframes floatUp {
  0%   { transform:translateY(60px) rotate(-10deg); opacity:0; }
  15%  { opacity:.25; }
  80%  { opacity:.15; }
  100% { transform:translateY(-80px) rotate(15deg); opacity:0; }
}
.hero { position:relative; }
.hero > *:not(.hero-floaters) { position:relative;z-index:1; }

/* ── 10. Pop-up swipe indicator ── */
.welcome-swipe-hint {
  position:absolute;bottom:14px;left:50%;transform:translateX(-50%);
  font-size:10px;color:rgba(212,136,42,.45);
  display:flex;flex-direction:column;align-items:center;gap:3px;
  animation:swipeHintPulse 2s ease-in-out infinite;
  pointer-events:none;
  letter-spacing:.08em;
  font-weight:600;
}
.swipe-arrow {
  font-size:14px;animation:swipeArrowBounce 1.2s ease-in-out infinite;
}
@keyframes swipeHintPulse {
  0%,100% { opacity:.5; }
  50% { opacity:1; }
}
@keyframes swipeArrowBounce {
  0%,100% { transform:translateY(0); }
  50% { transform:translateY(4px); }
}

/* ── Progress dots for welcome modal ── */
.welcome-progress {
  display:flex;gap:6px;justify-content:center;
  margin:10px 0 0;
}
.wp-dot {
  width:6px;height:6px;border-radius:3px;
  background:var(--border);
  transition:all .3s;
}
.wp-dot.active {
  width:20px;background:var(--caramel);
}

/* ═══════════════════════════════════════════════════════
   BRAND ORDER MODAL (Tomoro & Fore)
   ═══════════════════════════════════════════════════════ */

.brand-order-overlay {
  z-index: 1500;
}

/* Brand preview harus di atas brand order modal */
#brandPreviewOverlay {
  z-index: 1600;
}
.brand-order-modal {
  width: 92%;
  max-width: 480px;
  max-height: 90vh;
  padding: 0;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  border-radius: 18px;
}

/* HEADER -- warna nyesuain brand via inline style */
.brand-order-head {
  position: relative;
  padding: 22px 20px 18px;
  text-align: center;
  color: #fff;
}
.brand-order-head.tomoro-head {
  background: linear-gradient(135deg, #3D2700 0%, #6B3D00 50%, #FFCC00 100%);
}
.brand-order-head.fore-head {
  background: linear-gradient(135deg, #002A1A 0%, #006B4D 50%, #00C882 100%);
}
.brand-order-close {
  position: absolute;
  top: 10px; right: 12px;
  width: 30px; height: 30px;
  border: none; border-radius: 50%;
  background: rgba(255,255,255,0.25);
  color: #fff;
  font-size: 22px;
  font-weight: 700;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
  transition: background .2s;
}
.brand-order-close:hover {
  background: rgba(255,255,255,0.4);
}
.brand-order-logo {
  width: 60px; height: 60px;
  object-fit: contain;
  border-radius: 14px;
  background: #fff;
  padding: 6px;
  margin: 0 auto 8px;
  display: block;
  box-shadow: 0 2px 8px rgba(0,0,0,0.15);
}
.brand-order-title {
  margin: 4px 0 4px;
  font-size: 19px;
  font-weight: 800;
  letter-spacing: 0.3px;
  text-shadow: 0 1px 4px rgba(0,0,0,0.4);
}
.brand-order-sub {
  margin: 0;
  font-size: 13px;
  opacity: 0.92;
  text-shadow: 0 1px 3px rgba(0,0,0,0.3);
}

/* STEP CONTAINER (scrollable body) */
.brand-order-step {
  padding: 18px 18px 16px;
  overflow-y: auto;
  flex: 1;
}
.brand-step-label {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 14px;
  font-size: 14px;
  font-weight: 700;
  color: var(--text);
}
.brand-step-num {
  width: 22px; height: 22px;
  border-radius: 50%;
  background: var(--caramel);
  color: #1a0f06;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  font-weight: 800;
}

/* PROMO CARDS (vertical list, tap-to-select) */
.brand-promo-cards {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.brand-promo-card {
  border: 2px solid var(--border);
  border-radius: 14px;
  padding: 14px;
  cursor: pointer;
  transition: all .2s;
  background: var(--card-bg);
  color: #f5e9d8;
  text-align: left;
  width: 100%;
  font-family: inherit;
  position: relative;
  overflow: hidden;
}
.brand-promo-card:hover, .brand-promo-card:active {
  transform: translateY(-2px);
  box-shadow: 0 4px 14px rgba(0,0,0,0.25);
}
.brand-promo-card.tomoro-card-pick {
  border-color: rgba(255,122,0,0.35);
}
.brand-promo-card.tomoro-card-pick:hover {
  border-color: #ff7a00;
  background: rgba(255,122,0,0.08);
}
.brand-promo-card.fore-card-pick {
  border-color: rgba(0,168,107,0.35);
}
.brand-promo-card.fore-card-pick:hover {
  border-color: #00a86b;
  background: rgba(0,168,107,0.08);
}

.brand-promo-card-tag {
  display: inline-block;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.5px;
  padding: 3px 8px;
  border-radius: 10px;
  margin-bottom: 6px;
}
.tomoro-card-pick .brand-promo-card-tag {
  background: rgba(255,122,0,0.18);
  color: #ff9a3d;
}
.fore-card-pick .brand-promo-card-tag {
  background: rgba(0,168,107,0.18);
  color: #2dd49a;
}
.brand-promo-card-title {
  font-size: 17px;
  font-weight: 800;
  color: #f5e9d8 !important;
  margin: 0 0 4px;
}
.tomoro-card-pick .brand-promo-card-title {
  color: #FFCC00 !important;
}
.fore-card-pick .brand-promo-card-title {
  color: #00C882 !important;
}
.brand-promo-card-desc {
  font-size: 12.5px;
  color: rgba(245,233,216,0.7) !important;
  margin: 0 0 8px;
  line-height: 1.4;
}
.brand-promo-card-fee {
  display: inline-block;
  font-size: 12px;
  font-weight: 700;
  padding: 4px 10px;
  border-radius: 8px;
  margin-bottom: 8px;
}
.tomoro-card-pick .brand-promo-card-fee {
  background: linear-gradient(135deg, #ff7a00, #ff5500);
  color: #fff;
}
.fore-card-pick .brand-promo-card-fee {
  background: linear-gradient(135deg, #00a86b, #007a4d);
  color: #fff;
}
.brand-promo-card-excl {
  font-size: 11.5px;
  color: rgba(245,233,216,0.75) !important;
  background: rgba(255,255,255,0.04);
  border-radius: 8px;
  padding: 6px 10px;
  margin-top: 4px;
  border-left: 2px solid rgba(255,255,255,0.15);
}
.brand-promo-card-excl b {
  color: #f5e9d8 !important;
  font-weight: 700;
}

/* "Pertanyaan Lain" card - special muted style */
.brand-promo-card.brand-question-card {
  border-style: dashed;
  border-color: rgba(255,255,255,0.2);
  background: rgba(255,255,255,0.02);
}
.brand-promo-card.brand-question-card:hover {
  border-color: var(--caramel);
  background: rgba(212,142,84,0.08);
}
.brand-promo-card.brand-question-card .brand-promo-card-title {
  display: flex;
  align-items: center;
  gap: 8px;
}

/* SELECTED PROMO BADGE (di step 2) */
.brand-selected-promo {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  border-radius: 10px;
  background: rgba(212,142,84,0.1);
  border: 1px solid rgba(212,142,84,0.3);
  margin-bottom: 14px;
  font-size: 13px;
}
.brand-selected-promo-icon {
  font-size: 18px;
}
.brand-selected-promo-text {
  flex: 1;
  color: var(--text);
}
.brand-selected-promo-text b {
  display: block;
  font-size: 14px;
  margin-bottom: 2px;
}

/* FORM */
.brand-form {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.brand-form-row {
  display: flex;
  flex-direction: column;
  gap: 5px;
}
.brand-form-label {
  font-size: 12.5px;
  font-weight: 700;
  color: var(--text-dim);
}
.brand-form-label .req {
  color: #ff5252;
}
.brand-form-input {
  width: 100%;
  padding: 10px 12px;
  border: 1px solid var(--border);
  border-radius: 9px;
  background: var(--input-bg, rgba(255,255,255,0.03));
  color: var(--text);
  font-size: 14px;
  font-family: inherit;
  transition: border-color .2s;
  box-sizing: border-box;
}
.brand-form-input:focus {
  outline: none;
  border-color: var(--caramel);
}
.brand-form-textarea {
  resize: vertical;
  min-height: 80px;
  line-height: 1.45;
}
.brand-form-hint {
  font-size: 11px;
  color: var(--text-dim);
  opacity: 0.75;
  margin-top: 2px;
}

/* FORM ACTIONS */
.brand-form-actions {
  display: flex;
  gap: 8px;
  padding: 12px 18px 16px;
  border-top: 1px solid var(--border);
  background: var(--card-bg);
}
.brand-btn-back {
  flex: 0 0 auto;
  padding: 11px 14px;
  border: 1px solid var(--border);
  border-radius: 10px;
  background: transparent;
  color: var(--text-dim);
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  font-family: inherit;
  transition: all .2s;
}
.brand-btn-back:hover {
  background: rgba(255,255,255,0.05);
  color: var(--text);
}
.brand-btn-send {
  flex: 1;
  padding: 11px;
  border: none;
  border-radius: 10px;
  background: linear-gradient(135deg, #25D366, #128C7E);
  color: #fff;
  font-size: 14px;
  font-weight: 700;
  cursor: pointer;
  font-family: inherit;
  transition: transform .15s, box-shadow .15s;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
}
.brand-btn-send:hover {
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(37,211,102,0.35);
}
.brand-btn-send:active {
  transform: translateY(0);
}


/* ─────────── CARD IMAGE SKELETON ─────────── */
.card-emoji img{
  transition:opacity .3s ease;
  opacity:0;
}
.card-emoji img.loaded{
  opacity:1;
}
/* Skeleton shimmer while image loading */
.card-emoji::before{
  content:'';
  position:absolute;inset:0;
  background:linear-gradient(90deg,
    transparent 0%,
    rgba(255,255,255,.04) 50%,
    transparent 100%);
  background-size:200% 100%;
  animation:shimmerCard 1.6s ease-in-out infinite;
  z-index:1;
  pointer-events:none;
}
@keyframes shimmerCard{
  0%{background-position:200% center}
  100%{background-position:-200% center}
}

/* ─────────── FLOAT HINT UPGRADE ─────────── */
.float-savings{
  color:#52C87A;
  font-size:.8em;
  font-weight:700;
  margin-left:2px;
}

/* ─────────── CART ITEM SIZE UPGRADE ─────────── */
.ci-meta:empty{display:none}

/* ─────────── DESKTOP HOVER ─────────── */
@media(hover:hover){
  .menu-card:hover{
    transform:translateY(-3px);
    border-color:var(--border-glow);
    box-shadow:0 8px 24px rgba(0,0,0,.4), 0 0 0 1px rgba(212,136,42,.12);
  }
  .menu-card.selected:hover{
    border-color:var(--caramel);
  }
  .card-add-btn:hover{
    background:rgba(212,136,42,0.2);
    border-color:rgba(212,136,42,0.45);
    color:var(--caramel);
    transform:translateY(-1px);
  }
  .menu-card.selected .card-add-btn:hover{
    background:rgba(212,136,42,0.85);
    color:#1A0D00;
  }
}


/* ─────────── THEME TOGGLE BUTTON ─────────── */
.theme-toggle{
  background:var(--surface2);
  border:1px solid var(--border);
  color:var(--cream-dim);
  font-size:15px;
  width:34px;height:34px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;
  transition:all .2s;
  flex-shrink:0;
}
.theme-toggle:active{transform:scale(.88);background:var(--caramel-pale)}

/* ─────────── DRAG REORDER CART ─────────── */
.cart-item{
  touch-action:pan-y;
  user-select:none;
  align-items:center;
}
.cart-item.dragging{
  opacity:.5;
  background:var(--caramel-pale) !important;
  border-color:var(--caramel) !important;
  transform:scale(1.02);
  z-index:999;
  transition:none;
}
.cart-item.drag-over{
  border-top:2px solid var(--caramel) !important;
}
.ci-drag-handle{
  color:var(--muted);
  font-size:16px;
  cursor:grab;
  padding:0 6px 0 0;
  flex-shrink:0;
  touch-action:none;
  line-height:1;
}
.ci-drag-handle:active{cursor:grabbing}

/* ─────────── COUNTER ANIMATION ─────────── */
.proof-num{
  font-family:'Fraunces',serif;font-weight:900;
  font-size:30px;line-height:1;color:var(--caramel);
  margin-bottom:4px;
  transition:color .3s;
}
.proof-num.counting{color:var(--caramel-light)}

/* ─────────── SWIPE INDICATOR ─────────── */
.brand-swipe-overlay{
  position:fixed;inset:0;pointer-events:none;z-index:9999;
  display:flex;align-items:center;justify-content:center;
  opacity:0;transition:opacity .2s;
}
.brand-swipe-overlay.show{opacity:1}
.brand-swipe-label{
  background:rgba(212,136,42,.92);color:#1A0D00;
  font-size:13px;font-weight:800;letter-spacing:.5px;
  padding:10px 24px;border-radius:30px;
  box-shadow:0 4px 20px rgba(212,136,42,.4);
}

/* ═══════════════════════════════════════════════════════════════
   V7 UX/UI POLISH ADDITIONS
   1. Skeleton Loading + Haptic
   2. Confetti Upgrade + Success Pop
   3. Bottom Nav Bar
   4. Image Lazy-Load + Blur Placeholder
   5. Onboarding Tour
   6. Pull-to-Refresh Indicator
   ═══════════════════════════════════════════════════════════════ */

/* ─────────── 1. SKELETON LOADING ─────────── */
.skeleton-wrap{
  display:none;
  padding:0 16px;
}
.skeleton-wrap.show{display:block}
.skeleton-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:12px;
  margin-top:12px;
}
@media(min-width:600px){
  .skeleton-grid{grid-template-columns:repeat(3,1fr)}
}
.skeleton-card{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  overflow:hidden;
  position:relative;
}
.skeleton-img{
  width:100%;
  aspect-ratio:1/1;
  background:linear-gradient(90deg,var(--surface) 0%,var(--surface2) 50%,var(--surface) 100%);
  background-size:200% 100%;
  animation:shimmer 1.4s infinite linear;
}
.skeleton-body{padding:10px 12px}
.skeleton-line{
  height:11px;
  background:linear-gradient(90deg,var(--surface) 0%,var(--surface2) 50%,var(--surface) 100%);
  background-size:200% 100%;
  animation:shimmer 1.4s infinite linear;
  border-radius:6px;
  margin-bottom:8px;
}
.skeleton-line.w-70{width:70%}
.skeleton-line.w-40{width:40%}
.skeleton-line.w-90{width:90%}
.skeleton-line.tall{height:30px;margin-top:10px}
@keyframes shimmer{
  0%{background-position:200% 0}
  100%{background-position:-200% 0}
}

/* Splash overlay (initial paint) */
.splash-overlay{
  position:fixed;inset:0;
  background:var(--bg);
  z-index:99999;
  display:flex;align-items:center;justify-content:center;
  flex-direction:column;
  transition:opacity .4s ease, visibility .4s ease;
}
.splash-overlay.hide{opacity:0;visibility:hidden;pointer-events:none}
.splash-cup{
  font-size:64px;
  animation:cupBob 1.4s ease-in-out infinite;
  filter:drop-shadow(0 6px 14px rgba(212,136,42,.5));
}
.splash-steam{
  position:absolute;
  top:calc(50% - 60px);
  left:50%;
  transform:translateX(-50%);
  display:flex;gap:6px;
}
.splash-steam span{
  display:block;width:5px;height:22px;
  background:linear-gradient(to top,rgba(212,136,42,.5),transparent);
  border-radius:50%;
  animation:steamRise 1.6s ease-in-out infinite;
}
.splash-steam span:nth-child(2){animation-delay:.3s}
.splash-steam span:nth-child(3){animation-delay:.6s}
@keyframes steamRise{
  0%{transform:translateY(0) scaleY(1);opacity:.5}
  60%{opacity:.3}
  100%{transform:translateY(-30px) scaleY(.4);opacity:0}
}
@keyframes cupBob{
  0%,100%{transform:translateY(0) rotate(-2deg)}
  50%{transform:translateY(-6px) rotate(2deg)}
}
.splash-text{
  margin-top:20px;
  font-family:'Fraunces',serif;
  font-weight:900;
  font-size:22px;
  color:var(--caramel);
  letter-spacing:1px;
}
.splash-sub{
  margin-top:6px;
  font-size:12px;
  color:var(--cream-dim);
  letter-spacing:.5px;
}
.splash-dots{
  margin-top:18px;
  display:flex;gap:6px;
}
.splash-dots span{
  width:8px;height:8px;border-radius:50%;
  background:var(--caramel);
  animation:dotPulse 1.4s ease-in-out infinite;
  opacity:.4;
}
.splash-dots span:nth-child(2){animation-delay:.2s}
.splash-dots span:nth-child(3){animation-delay:.4s}
@keyframes dotPulse{
  0%,80%,100%{transform:scale(.7);opacity:.4}
  40%{transform:scale(1);opacity:1}
}

/* ─────────── 2. CONFETTI UPGRADE + SUCCESS POP ─────────── */
.confetti-piece{
  position:fixed;
  top:-20px;
  z-index:99998;
  border-radius:2px;
  pointer-events:none;
  animation:confettiFall linear forwards;
  will-change:transform,opacity;
}
.confetti-piece.circle{border-radius:50%}
.confetti-piece.star{
  background:transparent !important;
  font-size:18px;
  display:flex;align-items:center;justify-content:center;
  color:#FFD93D;
}
@keyframes confettiFall{
  0%{transform:translateY(0) rotate(0deg) scale(1);opacity:1}
  80%{opacity:1}
  100%{transform:translateY(110vh) rotate(720deg) scale(.5);opacity:0}
}

/* Success modal pop */
.success-modal{
  animation:successPop .5s cubic-bezier(.34,1.56,.64,1) backwards !important;
}
@keyframes successPop{
  0%{transform:scale(.5) translateY(20px);opacity:0}
  60%{transform:scale(1.05) translateY(-4px);opacity:1}
  100%{transform:scale(1) translateY(0);opacity:1}
}
.confirm-emoji{
  display:inline-block;
  animation:emojiBounce .8s ease-out;
  animation-delay:.2s;
  animation-fill-mode:backwards;
}
@keyframes emojiBounce{
  0%{transform:scale(0) rotate(-180deg)}
  50%{transform:scale(1.3) rotate(15deg)}
  75%{transform:scale(.95) rotate(-8deg)}
  100%{transform:scale(1) rotate(0deg)}
}

/* Sparkle burst di belakang emoji */
.success-sparkles{
  position:absolute;
  top:30px;left:50%;
  transform:translateX(-50%);
  pointer-events:none;
  width:120px;height:120px;
}
.success-sparkles span{
  position:absolute;
  top:50%;left:50%;
  width:6px;height:6px;
  border-radius:50%;
  background:#FFD93D;
  animation:sparkleBurst .9s ease-out forwards;
  animation-delay:.3s;
}
.success-sparkles span:nth-child(1){--ang:0deg;background:#FFD93D}
.success-sparkles span:nth-child(2){--ang:45deg;background:#25D366}
.success-sparkles span:nth-child(3){--ang:90deg;background:#D4882A}
.success-sparkles span:nth-child(4){--ang:135deg;background:#F0C06A}
.success-sparkles span:nth-child(5){--ang:180deg;background:#FFD93D}
.success-sparkles span:nth-child(6){--ang:225deg;background:#25D366}
.success-sparkles span:nth-child(7){--ang:270deg;background:#D4882A}
.success-sparkles span:nth-child(8){--ang:315deg;background:#F0C06A}
@keyframes sparkleBurst{
  0%{transform:rotate(var(--ang)) translateX(0) scale(1);opacity:1}
  100%{transform:rotate(var(--ang)) translateX(60px) scale(0);opacity:0}
}

/* ─────────── 3. BOTTOM NAV BAR ─────────── */
.bottom-nav{
  position:fixed;
  bottom:0;left:0;right:0;
  background:var(--surface);
  border-top:1px solid var(--border);
  display:flex;
  z-index:50;
  padding:6px 4px 10px;
  padding-bottom:max(10px, env(safe-area-inset-bottom));
  box-shadow:0 -4px 20px rgba(0,0,0,.25);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  background:color-mix(in srgb, var(--surface) 92%, transparent);
}
body.light-mode .bottom-nav{
  background:color-mix(in srgb, #FFF8F0 92%, transparent);
  box-shadow:0 -4px 20px rgba(0,0,0,.08);
}
.bottom-nav-item{
  flex:1;
  background:none;
  border:none;
  color:var(--cream-dim);
  font-family:inherit;
  font-size:10.5px;
  font-weight:600;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:3px;
  padding:6px 4px;
  cursor:pointer;
  position:relative;
  transition:color .2s, transform .15s;
  -webkit-tap-highlight-color:transparent;
}
.bottom-nav-item:active{transform:scale(.92)}
.bottom-nav-icon{
  font-size:22px;
  line-height:1;
  transition:transform .25s cubic-bezier(.34,1.56,.64,1);
}
.bottom-nav-item.active{color:var(--caramel)}
.bottom-nav-item.active .bottom-nav-icon{transform:translateY(-2px) scale(1.15)}
.bottom-nav-item.active::before{
  content:"";
  position:absolute;
  top:0;left:50%;transform:translateX(-50%);
  width:28px;height:3px;
  background:var(--caramel);
  border-radius:0 0 4px 4px;
}
.bottom-nav-badge{
  position:absolute;
  top:2px;
  right:calc(50% - 22px);
  background:var(--red);
  color:white;
  font-size:9px;
  font-weight:800;
  min-width:16px;height:16px;
  border-radius:8px;
  padding:0 4px;
  display:flex;align-items:center;justify-content:center;
  border:2px solid var(--surface);
}
.bottom-nav-badge.hidden{display:none}

/* Push body content up biar gak ketutup nav */
body.with-bottom-nav{
  padding-bottom:74px;
  padding-bottom:calc(74px + env(safe-area-inset-bottom));
}
/* Float hint cart bar tetap aktif sebagai CTA utama, posisi di atas bottom nav */
body.with-bottom-nav .float-hint{
  bottom:calc(74px + 14px) !important;
  bottom:calc(74px + 14px + env(safe-area-inset-bottom)) !important;
}

/* ─────────── 4. IMAGE LAZY-LOAD + BLUR PLACEHOLDER ─────────── */
.menu-card .card-emoji{
  position:relative;
  background:linear-gradient(135deg, var(--caramel-pale), var(--surface2));
  overflow:hidden;
}
.menu-card .card-emoji::before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(110deg,
    transparent 30%,
    color-mix(in srgb, var(--caramel) 18%, transparent) 50%,
    transparent 70%);
  background-size:200% 100%;
  animation:shimmer 2s infinite linear;
  z-index:0;
  opacity:1;
  transition:opacity .35s;
  pointer-events:none;
}
.menu-card .card-emoji.img-loaded::before{opacity:0}
.menu-card .card-emoji img{
  position:relative;
  z-index:1;
  opacity:0;
  filter:blur(10px);
  transform:scale(1.05);
  transition:opacity .4s ease, filter .4s ease, transform .4s ease;
}
.menu-card .card-emoji.img-loaded img{
  opacity:1;
  filter:blur(0);
  transform:scale(1);
}
.menu-card .card-emoji span{position:relative;z-index:1}

/* ─────────── 5. ONBOARDING TOUR ─────────── */
.tour-overlay{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,.7);
  z-index:9990;
  display:none;
  backdrop-filter:blur(2px);
}
.tour-overlay.show{display:block}
.tour-spotlight{
  position:absolute;
  border-radius:14px;
  box-shadow:0 0 0 9999px rgba(0,0,0,.7), 0 0 0 4px var(--caramel);
  transition:all .4s cubic-bezier(.4,0,.2,1);
  pointer-events:none;
  animation:spotlightPulse 2s ease-in-out infinite;
}
@keyframes spotlightPulse{
  0%,100%{box-shadow:0 0 0 9999px rgba(0,0,0,.7), 0 0 0 4px var(--caramel), 0 0 0 4px rgba(212,136,42,.4)}
  50%{box-shadow:0 0 0 9999px rgba(0,0,0,.7), 0 0 0 4px var(--caramel), 0 0 0 12px rgba(212,136,42,.2)}
}
.tour-tooltip{
  position:absolute;
  background:var(--surface);
  border:1px solid var(--caramel);
  border-radius:var(--radius);
  padding:16px 18px;
  width:calc(100vw - 40px);
  max-width:300px;
  box-shadow:0 8px 30px rgba(0,0,0,.5);
  animation:tooltipIn .4s ease both;
  z-index:9991;
}
@keyframes tooltipIn{
  from{opacity:0;transform:translateY(8px)}
  to{opacity:1;transform:translateY(0)}
}
.tour-tooltip-title{
  font-family:'Fraunces',serif;
  font-size:18px;
  font-weight:900;
  color:var(--caramel);
  margin-bottom:6px;
  display:flex;align-items:center;gap:6px;
}
.tour-tooltip-text{
  font-size:13px;
  color:var(--cream);
  line-height:1.5;
  margin-bottom:14px;
}
.tour-progress{
  display:flex;
  gap:5px;
  margin-bottom:12px;
}
.tour-dot{
  flex:1;
  height:4px;
  border-radius:2px;
  background:var(--border);
  transition:background .3s;
}
.tour-dot.active{background:var(--caramel)}
.tour-dot.done{background:var(--caramel);opacity:.5}
.tour-actions{
  display:flex;
  gap:8px;
  align-items:center;
  justify-content:space-between;
}
.tour-skip{
  background:none;
  border:none;
  color:var(--muted);
  font-family:inherit;
  font-size:12px;
  cursor:pointer;
  padding:8px 4px;
  text-decoration:underline;
}
.tour-next{
  background:linear-gradient(135deg,var(--caramel),var(--caramel-light));
  color:#1A0D00;
  border:none;
  font-family:inherit;
  font-weight:800;
  font-size:13px;
  padding:9px 18px;
  border-radius:8px;
  cursor:pointer;
  transition:transform .15s;
}
.tour-next:active{transform:scale(.95)}
.tour-tooltip-arrow{
  position:absolute;
  width:0;height:0;
  border:8px solid transparent;
}
.tour-tooltip-arrow.top{
  top:-15px;
  left:30px;
  border-bottom-color:var(--caramel);
}
.tour-tooltip-arrow.bottom{
  bottom:-15px;
  left:30px;
  border-top-color:var(--caramel);
}

/* ─────────── 6. PULL-TO-REFRESH ─────────── */
.ptr-indicator{
  position:fixed;
  top:0;left:50%;
  transform:translate(-50%, -60px);
  background:var(--surface);
  border:1px solid var(--caramel);
  border-radius:30px;
  padding:8px 16px;
  display:flex;align-items:center;gap:8px;
  font-size:12px;
  font-weight:700;
  color:var(--caramel);
  z-index:9995;
  box-shadow:0 4px 16px rgba(0,0,0,.3);
  transition:transform .25s ease, opacity .25s;
  opacity:0;
  pointer-events:none;
}
.ptr-indicator.pulling{
  opacity:1;
}
.ptr-indicator.refreshing{
  transform:translate(-50%, 16px);
  opacity:1;
}
.ptr-icon{
  font-size:16px;
  display:inline-block;
  transition:transform .2s;
}
.ptr-indicator.pulling .ptr-icon{
  transform:rotate(var(--ptr-rot, 0deg));
}
.ptr-indicator.refreshing .ptr-icon{
  animation:ptrSpin 1s linear infinite;
}
@keyframes ptrSpin{
  to{transform:rotate(360deg)}
}

/* ─────────── ACCESSIBILITY: Reduce motion ─────────── */
@media (prefers-reduced-motion: reduce){
  .splash-cup, .splash-steam span, .splash-dots span,
  .skeleton-img, .skeleton-line,
  .confetti-piece, .success-sparkles span, .confirm-emoji,
  .tour-spotlight, .ptr-icon{
    animation:none !important;
  }
  .menu-card .card-emoji::before{animation:none !important}
}

/* ─────────── V7 FIX: FAVORITES BOTTOM SHEET (proper) ─────────── */
.fav-backdrop{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,.55);
  backdrop-filter:blur(3px);
  -webkit-backdrop-filter:blur(3px);
  z-index:400;
  opacity:0;
  pointer-events:none;
  transition:opacity .3s ease;
}
.fav-backdrop.open{
  opacity:1;
  pointer-events:auto;
}
.fav-sheet{
  position:fixed;
  left:0;right:0;
  bottom:0;
  background:var(--surface);
  border-top:1px solid var(--border);
  border-radius:20px 20px 0 0;
  z-index:401;
  height:88vh;
  max-height:88vh;
  display:flex;
  flex-direction:column;
  transform:translateY(100%);
  transition:transform .35s cubic-bezier(.4,0,.2,1);
  box-shadow:0 -10px 40px rgba(0,0,0,.5);
  overflow:hidden;
}
body.light-mode .fav-sheet{
  box-shadow:0 -10px 40px rgba(0,0,0,.15);
}
.fav-sheet.open{
  transform:translateY(0);
}
@media(min-width:600px){
  .fav-sheet{
    left:auto;
    right:0;
    top:0;bottom:0;
    width:min(420px, 100vw);
    height:100vh;
    max-height:100vh;
    border-radius:0;
    border-left:1px solid var(--border);
    border-top:none;
    transform:translateX(100%);
  }
  .fav-sheet.open{ transform:translateX(0); }
}
.fav-sheet-handle{
  width:42px;
  height:4px;
  border-radius:2px;
  background:var(--border-glow);
  margin:8px auto 0;
  flex-shrink:0;
  opacity:.7;
}
@media(min-width:600px){
  .fav-sheet-handle{ display:none; }
}
.fav-sheet-head{
  padding:12px 18px 14px;
  border-bottom:1px solid var(--border);
  display:flex;
  align-items:center;
  justify-content:space-between;
  flex-shrink:0;
}
.fav-sheet-title{
  font-family:'Fraunces', serif;
  font-size:19px;
  font-weight:800;
  color:var(--caramel-light);
}
.fav-sheet-close{
  background:var(--card);
  border:1px solid var(--border);
  color:var(--cream);
  width:34px;
  height:34px;
  border-radius:50%;
  font-size:18px;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  -webkit-tap-highlight-color:transparent;
  transition:transform .15s;
}
.fav-sheet-close:active{ transform:scale(.9); }
.fav-sheet-body{
  flex:1;
  overflow-y:auto;
  -webkit-overflow-scrolling:touch;
  padding:14px 16px 24px;
  padding-bottom:calc(24px + env(safe-area-inset-bottom));
}
.fav-list{
  display:flex;
  flex-direction:column;
  gap:10px;
}
.fav-item{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:14px;
  padding:12px;
  display:flex;
  gap:12px;
  align-items:center;
  cursor:pointer;
  transition:transform .15s ease, border-color .2s;
  -webkit-tap-highlight-color:transparent;
  position:relative;
}
.fav-item:active{
  transform:scale(.98);
  border-color:var(--caramel);
}
.fav-item-img{
  width:64px;
  height:64px;
  border-radius:10px;
  background:linear-gradient(135deg, var(--caramel-pale), var(--surface2));
  overflow:hidden;
  flex-shrink:0;
  display:flex;
  align-items:center;
  justify-content:center;
}
.fav-item-img img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.fav-item-body{
  flex:1;
  min-width:0;
}
.fav-item-name{
  font-size:14px;
  font-weight:700;
  color:var(--cream);
  margin-bottom:4px;
  line-height:1.3;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.fav-item-price{
  display:flex;
  gap:6px;
  align-items:baseline;
  margin-bottom:2px;
}
.fav-item-disc{
  color:var(--caramel);
  font-weight:800;
  font-size:14px;
}
.fav-item-normal{
  color:var(--muted);
  font-size:11px;
  text-decoration:line-through;
}
.fav-item-tap{
  font-size:10px;
  color:var(--caramel-light);
  opacity:.7;
  font-weight:600;
}
.fav-item-remove{
  background:rgba(224,82,82,.12);
  border:1px solid rgba(224,82,82,.3);
  color:var(--red);
  width:30px;
  height:30px;
  border-radius:50%;
  font-size:18px;
  font-weight:700;
  line-height:1;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
  transition:transform .15s;
  -webkit-tap-highlight-color:transparent;
}
.fav-item-remove:active{ transform:scale(.85); }
.fav-empty{
  text-align:center;
  padding:50px 20px 30px;
}
.fav-empty-emo{
  font-size:54px;
  margin-bottom:14px;
}
.fav-empty-title{
  font-family:'Fraunces', serif;
  font-size:18px;
  font-weight:700;
  color:var(--cream);
  margin-bottom:6px;
}
.fav-empty-sub{
  font-size:13px;
  color:var(--cream-dim);
  line-height:1.5;
  margin-bottom:20px;
}
.fav-empty-cta{
  background:linear-gradient(135deg, var(--caramel), var(--caramel-light));
  color:#1A0D00;
  border:none;
  font-family:inherit;
  font-weight:800;
  font-size:14px;
  padding:11px 24px;
  border-radius:10px;
  cursor:pointer;
  transition:transform .15s;
}
.fav-empty-cta:active{ transform:scale(.95); }
