/* ============================================================
   FighTea — Main Stylesheet v3
   Fully Responsive: Mobile / Tablet / Desktop
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,600;1,400&family=Outfit:wght@300;400;500;600&display=swap');

/* ── DESIGN TOKENS ──────────────────────────────────────── */
:root {
  --cream:#FBF5EA; --beige:#F0E4C8; --beige-mid:#E2C9A0; --sand:#C9A96E;
  --brown:#7C4F2A; --brown-deep:#4A2C0E; --brown-light:#A0693A;
  --blush:#DFA58A; --teal:#2D7268; --teal-light:#4A9990;
  --gold:#C9921A; --ivory:#FEFAF2; --charcoal:#2C1A0E;
  --font-display:'Cormorant Garamond',Georgia,serif;
  --font-body:'Outfit',sans-serif;
  --gap-xs:6px; --gap-sm:12px; --gap-md:20px; --gap-lg:32px; --gap-xl:56px;
  --r-sm:8px; --r-md:14px; --r-lg:22px; --r-xl:32px; --r-pill:999px;
  --shadow-sm:0 2px 8px rgba(76,44,14,.08);
  --shadow-md:0 6px 20px rgba(76,44,14,.12);
  --shadow-lg:0 16px 48px rgba(76,44,14,.16);
  --nav-h:64px;
}

/* ── RESET ──────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--font-body);background:var(--cream);color:var(--charcoal);line-height:1.65;font-size:15px;min-height:100vh}
body.no-scroll{overflow:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{cursor:pointer;font-family:var(--font-body)}
input,select,textarea{font-family:var(--font-body)}
ul{list-style:none}

/* ── TYPOGRAPHY ─────────────────────────────────────────── */
h1,h2,h3{font-family:var(--font-display);font-weight:600;line-height:1.2}
h1{font-size:clamp(28px,5vw,60px)}
h2{font-size:clamp(22px,3.5vw,40px)}
h3{font-size:clamp(16px,2.5vw,24px)}
h4{font-size:16px;font-weight:500}

/* ── LAYOUT ─────────────────────────────────────────────── */
.container{width:100%;max-width:1200px;margin:0 auto;padding:0 var(--gap-lg)}
.section{padding:var(--gap-xl) 0}

/* ── BUTTONS ────────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--gap-xs);padding:11px 24px;border-radius:var(--r-pill);font-size:14px;font-weight:500;border:2px solid transparent;transition:all .2s ease;white-space:nowrap}
.btn-primary{background:var(--brown);color:var(--ivory);border-color:var(--brown)}
.btn-primary:hover{background:var(--brown-deep);border-color:var(--brown-deep);transform:translateY(-1px);box-shadow:var(--shadow-md)}
.btn-outline{background:transparent;color:var(--brown);border-color:var(--brown)}
.btn-outline:hover{background:var(--brown);color:var(--ivory);transform:translateY(-1px)}
.btn-teal{background:var(--teal);color:var(--ivory);border-color:var(--teal)}
.btn-teal:hover{background:var(--teal-light);transform:translateY(-1px)}
.btn-blush{background:var(--blush);color:var(--brown-deep);border-color:var(--blush)}
.btn-blush:hover{filter:brightness(.95)}
.btn-ghost{background:transparent;color:var(--brown-light);border-color:transparent;padding:8px 12px}
.btn-ghost:hover{background:var(--beige)}
.btn-danger{background:#FFEBEE;color:#C62828;border-color:#FFCDD2}
.btn-danger:hover{background:#FFCDD2}
.btn-sm{padding:7px 16px;font-size:13px}
.btn-lg{padding:14px 36px;font-size:16px}
.btn-full{width:100%}
.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}

/* ── ICONS ─────────────────────────────────────────────── */
.ui-icon{width:18px;height:18px;display:inline-block;vertical-align:-.18em;fill:none;stroke:currentColor;stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0}
.ui-icon-lg{width:34px;height:34px;stroke-width:1.7}
.btn .ui-icon,.cart-btn .ui-icon,.gcash-open-btn .ui-icon{width:16px;height:16px;stroke-width:2}
.section-head h2 .ui-icon{width:25px;height:25px;color:var(--blush);margin-right:6px}
.feature-icon{width:52px;height:52px;border-radius:50%;margin:0 auto 14px;display:flex;align-items:center;justify-content:center;color:var(--blush);background:rgba(223,165,138,.12);border:1px solid rgba(223,165,138,.28)}
.feature-icon .ui-icon{width:24px;height:24px;stroke-width:1.8}
.icon-bell{--icon:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M10.3 21a1.94 1.94 0 0 0 3.4 0'/%3E%3Cpath d='M18 8A6 6 0 0 0 6 8c0 7-3 7-3 9h18c0-2-3-2-3-9'/%3E%3C/svg%3E")}
.icon-cart{--icon:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='8' cy='21' r='1'/%3E%3Ccircle cx='19' cy='21' r='1'/%3E%3Cpath d='M2.05 2.05h2l2.66 12.42a2 2 0 0 0 2 1.58h9.78a2 2 0 0 0 1.95-1.57l1.65-7.43H5.12'/%3E%3C/svg%3E")}
.icon-home{--icon:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m3 10 9-7 9 7'/%3E%3Cpath d='M5 10v10h14V10'/%3E%3Cpath d='M9 20v-6h6v6'/%3E%3C/svg%3E")}
.icon-info{--icon:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='10'/%3E%3Cpath d='M12 16v-4'/%3E%3Cpath d='M12 8h.01'/%3E%3C/svg%3E")}
.icon-cup{--icon:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M7 8h10l-1 13H8L7 8Z'/%3E%3Cpath d='M9 8 8 3h8l-1 5'/%3E%3Cpath d='M8 13h8'/%3E%3C/svg%3E")}
.icon-wallet{--icon:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M19 7V5a2 2 0 0 0-2-2H5a2 2 0 0 0 0 4h15a2 2 0 0 1 2 2v8a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2V5'/%3E%3Cpath d='M16 12h.01'/%3E%3C/svg%3E")}
.icon-edit{--icon:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 20h9'/%3E%3Cpath d='M16.5 3.5a2.12 2.12 0 0 1 3 3L7 19l-4 1 1-4Z'/%3E%3C/svg%3E")}
.icon-users{--icon:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M16 21v-2a4 4 0 0 0-4-4H6a4 4 0 0 0-4 4v2'/%3E%3Ccircle cx='9' cy='7' r='4'/%3E%3Cpath d='M22 21v-2a4 4 0 0 0-3-3.87'/%3E%3Cpath d='M16 3.13a4 4 0 0 1 0 7.75'/%3E%3C/svg%3E")}
.icon-card{--icon:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect width='20' height='14' x='2' y='5' rx='2'/%3E%3Cpath d='M2 10h20'/%3E%3C/svg%3E")}
.icon-dashboard{--icon:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect width='7' height='9' x='3' y='3' rx='1'/%3E%3Crect width='7' height='5' x='14' y='3' rx='1'/%3E%3Crect width='7' height='9' x='14' y='12' rx='1'/%3E%3Crect width='7' height='5' x='3' y='16' rx='1'/%3E%3C/svg%3E")}
.icon-log-out{--icon:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M9 21H5a2 2 0 0 1-2-2V5a2 2 0 0 1 2-2h4'/%3E%3Cpath d='M16 17l5-5-5-5'/%3E%3Cpath d='M21 12H9'/%3E%3C/svg%3E")}
.icon-list{--icon:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M8 6h13'/%3E%3Cpath d='M8 12h13'/%3E%3Cpath d='M8 18h13'/%3E%3Cpath d='M3 6h.01'/%3E%3Cpath d='M3 12h.01'/%3E%3Cpath d='M3 18h.01'/%3E%3C/svg%3E")}
.icon-tag{--icon:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20.59 13.41 13.41 20.59a2 2 0 0 1-2.82 0L2 12V2h10l8.59 8.59a2 2 0 0 1 0 2.82Z'/%3E%3Cpath d='M7 7h.01'/%3E%3C/svg%3E")}
.icon-chart{--icon:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M3 3v18h18'/%3E%3Cpath d='m19 9-5 5-4-4-3 3'/%3E%3C/svg%3E")}
.icon-settings{--icon:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12.22 2h-.44a2 2 0 0 0-2 2v.18a2 2 0 0 1-1 1.73l-.43.25a2 2 0 0 1-2 0l-.15-.08a2 2 0 0 0-2.73.73l-.22.38a2 2 0 0 0 .73 2.73l.15.1a2 2 0 0 1 1 1.72v.52a2 2 0 0 1-1 1.72l-.15.1a2 2 0 0 0-.73 2.73l.22.38a2 2 0 0 0 2.73.73l.15-.08a2 2 0 0 1 2 0l.43.25a2 2 0 0 1 1 1.73V20a2 2 0 0 0 2 2h.44a2 2 0 0 0 2-2v-.18a2 2 0 0 1 1-1.73l.43-.25a2 2 0 0 1 2 0l.15.08a2 2 0 0 0 2.73-.73l.22-.38a2 2 0 0 0-.73-2.73l-.15-.1a2 2 0 0 1-1-1.72v-.52a2 2 0 0 1 1-1.72l.15-.1a2 2 0 0 0 .73-2.73l-.22-.38a2 2 0 0 0-2.73-.73l-.15.08a2 2 0 0 1-2 0l-.43-.25a2 2 0 0 1-1-1.73V4a2 2 0 0 0-2-2Z'/%3E%3Ccircle cx='12' cy='12' r='3'/%3E%3C/svg%3E")}
.icon-upload{--icon:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M21 15v4a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2v-4'/%3E%3Cpath d='m17 8-5-5-5 5'/%3E%3Cpath d='M12 3v12'/%3E%3C/svg%3E")}

/* ── FORMS ──────────────────────────────────────────────── */
.form-group{display:flex;flex-direction:column;gap:6px}
.form-label{font-size:12px;font-weight:500;color:var(--brown);text-transform:uppercase;letter-spacing:.7px}
.form-input,.form-select{padding:11px 16px;background:var(--ivory);border:1.5px solid var(--beige-mid);border-radius:var(--r-sm);font-size:14px;color:var(--charcoal);transition:border-color .2s,box-shadow .2s;outline:none;width:100%}
.form-input:focus,.form-select:focus{border-color:var(--brown);box-shadow:0 0 0 3px rgba(124,79,42,.12)}
.form-input::placeholder{color:#BBA882}

/* ── BADGES ─────────────────────────────────────────────── */
.badge{display:inline-block;padding:3px 10px;border-radius:var(--r-pill);font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:.5px}
.badge-pending{background:#FFF3E0;color:#E65100}
.badge-preparing{background:#E3F2FD;color:#1565C0}
.badge-ready{background:#E8F5E9;color:#2E7D32}
.badge-completed{background:#F3E5F5;color:#6A1B9A}
.badge-cancelled{background:#FFEBEE;color:#C62828}
.badge-owner{background:#F3E5F5;color:#6A1B9A}
.badge-admin{background:#E8EAF6;color:#283593}
.badge-cashier{background:#E3F2FD;color:#1565C0}
.badge-chef{background:#E0F2F1;color:#00695C}
.badge-customer{background:#FFF8E1;color:#F57F17}

/* ── NAVBAR ─────────────────────────────────────────────── */
.navbar{position:sticky;top:0;z-index:200;background:rgba(251,245,234,.97);backdrop-filter:blur(12px);border-bottom:1px solid var(--beige);height:var(--nav-h)}
.navbar-inner{display:flex;align-items:center;justify-content:space-between;padding:0 var(--gap-lg);height:100%;max-width:1200px;margin:0 auto}
.navbar-logo{font-family:var(--font-display);font-size:28px;color:var(--brown-deep);font-weight:600;letter-spacing:.5px;background:none;border:none;cursor:pointer;flex-shrink:0}
.navbar-logo span{color:var(--blush)}
.navbar-links{display:flex;align-items:center;gap:var(--gap-md)}
.navbar-link{font-size:14px;font-weight:400;color:var(--brown-light);transition:color .2s;background:none;border:none;padding:4px 0;white-space:nowrap}
.navbar-link:hover{color:var(--brown-deep)}
.cart-btn{background:var(--brown);color:var(--ivory);border:none;padding:9px 20px;border-radius:var(--r-pill);font-size:14px;font-weight:500;display:flex;align-items:center;gap:8px;transition:all .2s;white-space:nowrap}
.cart-btn .ui-icon{color:var(--ivory)}
.cart-btn:hover{background:var(--brown-deep)}
.cart-count{background:var(--blush);color:var(--brown-deep);font-size:11px;font-weight:600;padding:1px 7px;border-radius:var(--r-pill);min-width:20px;text-align:center}

/* Hamburger */
.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;padding:6px;cursor:pointer;flex-shrink:0}
.hamburger span{display:block;width:22px;height:2px;background:var(--brown-deep);border-radius:2px;transition:all .3s}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* Mobile nav drawer */
.mobile-nav{display:none;position:fixed;top:var(--nav-h);left:0;right:0;bottom:0;background:var(--ivory);z-index:190;padding:var(--gap-md) var(--gap-lg);flex-direction:column;gap:4px;overflow-y:auto;border-top:1px solid var(--beige)}
.mobile-nav.open{display:flex}
.mobile-nav-link{display:flex;align-items:center;gap:10px;padding:14px 16px;font-size:15px;font-weight:400;color:var(--charcoal);background:none;border:none;text-align:left;border-radius:var(--r-sm);transition:background .15s,color .15s;border-bottom:1px solid rgba(201,169,110,.15)}
.mobile-nav-link .ui-icon{width:18px;height:18px;color:var(--brown-light)}
.mobile-nav-link-danger,.mobile-nav-link-danger .ui-icon{color:#C62828}
.mobile-nav-link:last-child{border-bottom:none}
.mobile-nav-link:hover{background:var(--beige);color:var(--brown-deep)}
.mobile-nav-link:hover .ui-icon{color:var(--brown)}
.mobile-nav-link-danger:hover,.mobile-nav-link-danger:hover .ui-icon{color:#B71C1C}
.mobile-nav-divider{height:1px;background:var(--beige);margin:8px 0}
.mobile-nav-auth{display:flex;flex-direction:column;gap:10px;margin-top:12px}

/* ── HERO ───────────────────────────────────────────────── */
.hero{background:var(--brown-deep);min-height:520px;display:flex;align-items:center;position:relative;overflow:hidden;padding:60px 0}
.hero::before{content:'';position:absolute;top:-100px;right:-100px;width:600px;height:600px;background:radial-gradient(circle,rgba(223,165,138,.18) 0%,transparent 65%);border-radius:50%}
.hero-content{position:relative;z-index:1;max-width:560px}
.hero-tag{display:inline-flex;align-items:center;gap:8px;background:rgba(223,165,138,.15);border:1px solid rgba(223,165,138,.3);color:var(--blush);padding:6px 16px;border-radius:var(--r-pill);font-size:12px;font-weight:500;letter-spacing:.8px;text-transform:uppercase;margin-bottom:20px}
.hero h1{color:var(--beige);margin-bottom:18px}
.hero h1 em{color:var(--blush);font-style:italic}
.hero p{color:rgba(240,228,200,.65);font-size:16px;font-weight:300;margin-bottom:32px;max-width:440px}
.hero-actions{display:flex;gap:var(--gap-sm);flex-wrap:wrap}

/* ── SECTION ────────────────────────────────────────────── */
.section-head{text-align:center;margin-bottom:var(--gap-lg)}
.section-head h2{color:var(--brown-deep);margin-bottom:10px}
.section-head p{color:var(--brown-light);font-size:15px;max-width:500px;margin:0 auto}
.section-divider{width:48px;height:2px;background:var(--sand);margin:14px auto 0;border-radius:var(--r-pill)}

/* ── CATEGORY PILLS ─────────────────────────────────────── */
.cat-pills{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;margin-bottom:var(--gap-md)}
.cat-pill{background:var(--ivory);border:1.5px solid var(--beige-mid);color:var(--brown-light);padding:8px 20px;border-radius:var(--r-pill);font-size:13px;font-weight:500;transition:all .2s;white-space:nowrap}
.cat-pill:hover,.cat-pill.active{background:var(--brown);color:var(--ivory);border-color:var(--brown)}

/* ── MENU GRID ──────────────────────────────────────────── */
.menu-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:var(--gap-md)}
.menu-card{background:var(--ivory);border-radius:var(--r-lg);border:1px solid rgba(201,169,110,.2);overflow:hidden;transition:all .25s ease;cursor:pointer}
.menu-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-md);border-color:var(--sand)}
.menu-card.unavailable{opacity:.7}
.menu-card-thumb{height:140px;background:var(--beige);display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}
.menu-card-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .3s}
.menu-card:hover .menu-card-thumb img{transform:scale(1.05)}
.menu-card-thumb .drink-img-svg{width:100%;height:100%}
.bestseller-ribbon{position:absolute;top:10px;left:10px;background:var(--gold);color:var(--ivory);font-size:10px;font-weight:600;padding:3px 10px;border-radius:var(--r-pill);text-transform:uppercase;letter-spacing:.5px;z-index:1}
.unavail-tag{position:absolute;top:10px;right:10px;background:rgba(74,44,14,.7);color:var(--beige);font-size:10px;font-weight:600;padding:3px 10px;border-radius:var(--r-pill);text-transform:uppercase;z-index:1}
.menu-card-body{padding:16px}
.menu-card-body h4{color:var(--brown-deep);margin-bottom:4px;font-size:15px}
.menu-card-body p{font-size:12px;color:#9A7A5A;margin-bottom:14px;line-height:1.5}
.menu-option-preview{display:none;flex-wrap:wrap;gap:6px;margin:0 0 14px}
.menu-option-preview span{display:inline-flex;align-items:center;min-height:24px;padding:3px 8px;border-radius:var(--r-pill);background:var(--cream);border:1px solid rgba(201,169,110,.35);color:var(--brown-light);font-size:11px;line-height:1.2}
.menu-card-footer{display:flex;align-items:center;justify-content:space-between}
.menu-price{font-size:17px;font-weight:600;color:var(--brown)}
.menu-add-btn{background:var(--brown);color:var(--ivory);border:none;width:34px;height:34px;border-radius:50%;font-size:22px;display:flex;align-items:center;justify-content:center;transition:background .2s,transform .15s;line-height:1;flex-shrink:0}
.menu-add-btn:hover{background:var(--teal);transform:scale(1.1)}
.menu-add-btn:disabled{background:#ccc;cursor:not-allowed;transform:none}
@media (min-width:768px){
  .menu-option-preview{display:flex}
}

/* ── CART DRAWER ────────────────────────────────────────── */
.cart-backdrop{position:fixed;inset:0;background:rgba(44,26,14,.45);z-index:300;opacity:0;pointer-events:none;transition:opacity .3s}
.cart-backdrop.open{opacity:1;pointer-events:all}
.cart-drawer{position:fixed;top:0;right:0;height:100vh;height:100dvh;width:400px;max-width:100vw;background:var(--ivory);box-shadow:-8px 0 32px rgba(76,44,14,.18);z-index:310;display:flex;flex-direction:column;transform:translateX(100%);transition:transform .3s ease;min-height:0}
.cart-drawer.open{transform:translateX(0)}
.cart-drawer-header{padding:var(--gap-md) var(--gap-lg);border-bottom:1px solid var(--beige);display:flex;align-items:center;justify-content:space-between;background:var(--ivory);flex-shrink:0}
.cart-drawer-body{flex:1;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:var(--gap-md) var(--gap-lg);background:var(--ivory)}
.cart-drawer-footer{padding:var(--gap-md) var(--gap-lg);border-top:1px solid var(--beige);background:var(--cream);flex-shrink:0}
.cart-item{display:flex;gap:var(--gap-sm);padding:14px 0;border-bottom:1px solid rgba(201,169,110,.15)}
.cart-item-emoji{font-size:32px;flex-shrink:0;line-height:1.2}
.cart-item-img{width:48px;height:48px;border-radius:var(--r-sm);overflow:hidden;flex-shrink:0;background:var(--beige)}
.cart-item-img img{width:100%;height:100%;object-fit:cover}
.cart-item-info{flex:1;min-width:0}
.cart-item-info h5{font-size:14px;font-weight:500;margin-bottom:3px;color:var(--brown-deep);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cart-item-info p{font-size:11px;color:#9A7A5A;line-height:1.4}
.cart-item-price{font-size:15px;font-weight:600;color:var(--brown);flex-shrink:0}
.cart-remove-btn{background:none;border:none;color:#ccc;font-size:16px;padding:2px;transition:color .15s;line-height:1}
.cart-remove-btn:hover{color:#E53935}
.cart-total-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--gap-sm)}
.cart-total-label{font-size:14px;color:var(--brown-light)}
.cart-total-val{font-size:20px;font-weight:600;color:var(--brown-deep)}

/* ── MODALS ─────────────────────────────────────────────── */
.modal-overlay{position:fixed;inset:0;background:rgba(44,26,14,.5);z-index:400;display:flex;align-items:flex-start;justify-content:center;padding:var(--gap-md);opacity:0;pointer-events:none;transition:opacity .25s;overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch}
.modal-overlay.open{opacity:1;pointer-events:all}
.modal-box{background:var(--ivory);border-radius:var(--r-xl);padding:var(--gap-lg);max-width:520px;width:min(100%,520px);max-height:calc(100vh - (var(--gap-md) * 2));max-height:calc(100dvh - (var(--gap-md) * 2));overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;transform:translateY(20px);transition:transform .25s;box-shadow:var(--shadow-lg);margin:auto 0;min-height:0}
.modal-overlay.open .modal-box{transform:translateY(0)}
.modal-box-lg{max-width:680px;width:min(100%,680px)}
.modal-box > *{box-sizing:border-box;max-width:100%;min-width:0}
.modal-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--gap-md)}
.modal-close{background:var(--beige);border:none;width:32px;height:32px;border-radius:50%;font-size:16px;display:flex;align-items:center;justify-content:center;color:var(--brown);transition:background .2s;flex-shrink:0}
.modal-close:hover{background:var(--beige-mid)}

/* ── CUSTOMIZE MODAL DRINK PREVIEW ──────────────────────── */
.modal-drink-thumb{width:80px;height:80px;border-radius:var(--r-md);overflow:hidden;background:var(--beige);flex-shrink:0}
.modal-drink-thumb img{width:100%;height:100%;object-fit:cover}
.modal-drink-header{display:flex;gap:14px;align-items:flex-start;margin-bottom:var(--gap-md)}

/* ── OPTION CHIPS ───────────────────────────────────────── */
.option-section{margin-bottom:20px}
.option-title{font-size:11px;font-weight:600;color:var(--brown);text-transform:uppercase;letter-spacing:.8px;margin-bottom:10px}
.options-row{display:flex;flex-wrap:wrap;gap:8px}
.opt-chip{background:var(--cream);border:1.5px solid var(--beige-mid);color:var(--charcoal);padding:8px 16px;border-radius:var(--r-md);font-size:13px;transition:all .15s;cursor:pointer;display:inline-flex;align-items:center;gap:8px;min-height:38px}
.opt-chip:hover{border-color:var(--brown)}
.opt-chip.active{background:var(--brown);color:var(--ivory);border-color:var(--brown)}
.option-recommended{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.4px;padding:2px 6px;border-radius:var(--r-pill);background:rgba(45,114,104,.12);color:var(--teal);line-height:1.2}
.opt-chip.active .option-recommended{background:rgba(240,228,200,.18);color:var(--beige)}
.topping-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.topping-chip{background:var(--cream);border:1.5px solid var(--beige-mid);color:var(--charcoal);padding:10px 14px;border-radius:var(--r-sm);font-size:13px;display:flex;align-items:center;gap:8px;transition:all .15s;text-align:left;cursor:pointer}
.topping-chip.active{background:var(--teal);color:var(--ivory);border-color:var(--teal)}
.topping-emoji{margin-right:6px}
.qty-control{display:flex;align-items:center;gap:14px}
.qty-btn{background:var(--beige);border:1px solid var(--beige-mid);width:36px;height:36px;border-radius:50%;font-size:18px;display:flex;align-items:center;justify-content:center;transition:background .15s;color:var(--brown-deep);cursor:pointer}
.qty-btn:hover{background:var(--beige-mid)}
.qty-val{font-size:20px;font-weight:600;min-width:28px;text-align:center;color:var(--brown-deep)}
.price-preview{font-size:22px;font-weight:600;color:var(--brown)}

/* ── PAYMENT ────────────────────────────────────────────── */
.payment-methods{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:var(--gap-md)}
.payment-card{background:var(--cream);border:2px solid var(--beige-mid);border-radius:var(--r-md);padding:16px;text-align:center;cursor:pointer;transition:all .2s}
.payment-card:hover{border-color:var(--brown)}
.payment-card.active{border-color:var(--brown);background:rgba(124,79,42,.06)}
.payment-icon{color:var(--brown-light);margin-bottom:8px;display:flex;align-items:center;justify-content:center}
.payment-icon .ui-icon{width:32px;height:32px;stroke-width:1.7}
.payment-card.active .payment-icon{color:var(--brown-deep)}
.payment-label{font-size:14px;font-weight:500;color:var(--brown-deep)}
.gcash-box{background:linear-gradient(135deg,#0070C9,#0093E9);color:#fff;border-radius:var(--r-md);padding:16px;margin-bottom:14px}
.gcash-box .gcash-number{font-size:20px;font-weight:700;letter-spacing:2px;margin:6px 0}
.gcash-box p{font-size:12px;opacity:.85}
.gcash-open-btn{display:flex;align-items:center;justify-content:center;gap:8px;background:#fff;color:#0070C9;border:none;padding:11px 20px;border-radius:var(--r-sm);font-weight:600;font-size:14px;width:100%;margin-top:10px;cursor:pointer;font-family:var(--font-body);transition:background .2s}
.gcash-open-btn:hover{background:#E3F2FD}

/* ── AUTH ───────────────────────────────────────────────── */
.auth-page{min-height:100vh;min-height:100dvh;display:flex;align-items:center;justify-content:center;background:var(--brown-deep);padding:var(--gap-lg);position:relative;overflow-y:auto;overflow-x:hidden}
.auth-page::before{content:'';position:absolute;width:260px;height:260px;opacity:.04;top:-40px;right:-40px;border:32px solid var(--brown);border-radius:50%}
.auth-card{background:var(--ivory);border-radius:var(--r-xl);padding:40px;width:100%;max-width:420px;box-shadow:var(--shadow-lg);position:relative;z-index:1}
.auth-logo{font-family:var(--font-display);font-size:32px;color:var(--brown-deep);text-align:center;margin-bottom:6px}
.auth-logo span{color:var(--blush)}
.auth-subtitle{font-size:13px;color:var(--brown-light);text-align:center;margin-bottom:28px}
.auth-tabs{display:grid;grid-template-columns:1fr 1fr;background:var(--beige);border-radius:var(--r-sm);padding:4px;gap:4px;margin-bottom:24px}
.auth-tab{background:transparent;border:none;padding:9px;border-radius:calc(var(--r-sm) - 2px);font-size:14px;font-weight:500;color:var(--brown-light);transition:all .2s;cursor:pointer}
.auth-tab.active{background:var(--ivory);color:var(--brown-deep);box-shadow:var(--shadow-sm)}

/* ── ADMIN LAYOUT ───────────────────────────────────────── */
.admin-wrapper{display:flex;min-height:100vh}
.admin-sidebar{width:240px;background:var(--brown-deep);flex-shrink:0;display:flex;flex-direction:column;position:sticky;top:0;height:100vh;overflow-y:auto}
.admin-sidebar-logo{font-family:var(--font-display);font-size:24px;color:var(--beige);padding:24px 24px 20px;border-bottom:1px solid rgba(255,255,255,.08);margin-bottom:12px;letter-spacing:.5px;flex-shrink:0}
.admin-sidebar-logo span{color:var(--blush)}
.admin-nav{flex:1;padding:8px 0;overflow-y:auto}
.admin-nav-item{display:flex;align-items:center;gap:12px;padding:12px 24px;color:rgba(240,228,200,.55);font-size:14px;font-weight:400;border:none;background:transparent;width:100%;text-align:left;cursor:pointer;border-left:3px solid transparent;transition:all .15s}
.admin-nav-item:hover{color:var(--beige);background:rgba(255,255,255,.05)}
.admin-nav-item.active{color:var(--blush);border-left-color:var(--blush);background:rgba(223,165,138,.08)}
.admin-nav-item.locked{opacity:.35;cursor:not-allowed;pointer-events:none}
.admin-nav-icon{width:18px;height:18px;color:rgba(240,228,200,.48);stroke-width:1.9}
.admin-nav-item:hover .admin-nav-icon{color:var(--beige)}
.admin-nav-item.active .admin-nav-icon{color:var(--blush)}
.admin-sidebar-footer .admin-nav-icon{color:#EF9A9A}
.admin-sidebar-footer{padding:16px 24px;border-top:1px solid rgba(255,255,255,.08);flex-shrink:0}
.admin-main{flex:1;background:var(--cream);overflow-y:auto;min-width:0}
.admin-topbar{background:var(--ivory);border-bottom:1px solid var(--beige);padding:0 var(--gap-lg);height:var(--nav-h);display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100}
.admin-topbar h2{font-family:var(--font-display);font-size:22px;color:var(--brown-deep)}
.admin-topbar-right{display:flex;align-items:center;gap:12px}
.admin-content{padding:var(--gap-lg)}
.admin-tab-panel{display:none}
.admin-tab-panel.active{display:block}

/* Mobile admin top bar */
.admin-menu-toggle{display:none;background:var(--brown-deep);color:var(--beige);border:none;padding:8px 12px;border-radius:var(--r-sm);font-size:13px;align-items:center;gap:6px;cursor:pointer}

/* Mobile admin drawer */
.admin-mobile-drawer{display:none;position:fixed;top:0;left:0;bottom:0;width:260px;background:var(--brown-deep);z-index:500;flex-direction:column;transform:translateX(-100%);transition:transform .3s ease;box-shadow:4px 0 24px rgba(0,0,0,.3)}
.admin-mobile-drawer.open{transform:translateX(0)}
.admin-mobile-backdrop{display:none;position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:499}
.admin-mobile-backdrop.open{display:block}

/* ── STATS ──────────────────────────────────────────────── */
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:16px;margin-bottom:var(--gap-lg)}
.stat-card{background:var(--ivory);border-radius:var(--r-md);padding:20px;border:1px solid rgba(201,169,110,.2)}
.stat-label{font-size:11px;font-weight:600;color:var(--sand);text-transform:uppercase;letter-spacing:.7px;margin-bottom:8px}
.stat-value{font-size:clamp(22px,3vw,30px);font-weight:600;font-family:var(--font-display);color:var(--brown-deep);line-height:1}
.stat-sub{font-size:12px;color:var(--teal);margin-top:5px}
.stat-card.accent{background:var(--brown-deep)}
.stat-card.accent .stat-label{color:rgba(240,228,200,.55)}
.stat-card.accent .stat-value{color:var(--beige)}
.stat-card.accent .stat-sub{color:var(--blush)}

/* ── QUEUE ──────────────────────────────────────────────── */
.queue-filters{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:var(--gap-md)}
.queue-filter{padding:7px 16px;background:var(--ivory);border:1.5px solid var(--beige-mid);color:var(--brown-light);border-radius:var(--r-pill);font-size:13px;font-weight:500;transition:all .15s;cursor:pointer;white-space:nowrap}
.queue-filter.active,.queue-filter:hover{background:var(--brown);color:var(--ivory);border-color:var(--brown)}
.queue-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px}
.order-card{background:var(--ivory);border-radius:var(--r-md);border:1px solid rgba(201,169,110,.2);padding:18px;display:flex;flex-direction:column;gap:12px;transition:box-shadow .2s}
.order-card:hover{box-shadow:var(--shadow-md)}
.order-card-head{display:flex;justify-content:space-between;align-items:flex-start}
.order-card-num{font-size:13px;font-weight:600;color:var(--brown)}
.order-card-time{font-size:11px;color:#BBA882}
.order-card-name{font-size:16px;font-weight:500;color:var(--brown-deep)}
.order-card-items{font-size:12px;color:#9A7A5A;line-height:1.7}
.order-card-total{font-size:15px;font-weight:600;color:var(--brown)}
.order-card-actions{display:flex;gap:6px;flex-wrap:wrap}
.act-btn{flex:1;min-width:60px;padding:8px 0;border:none;border-radius:var(--r-sm);font-size:12px;font-weight:500;transition:opacity .15s,transform .1s;font-family:var(--font-body);cursor:pointer}
.act-btn:hover{opacity:.85;transform:translateY(-1px)}
.act-prepare{background:var(--brown);color:var(--ivory)}
.act-ready{background:var(--teal);color:var(--ivory)}
.act-complete{background:#7B1FA2;color:#fff}
.act-cancel{background:#FFEBEE;color:#C62828}
.act-edit{background:var(--beige);color:var(--brown-deep)}

/* ── TABLE ──────────────────────────────────────────────── */
.table-wrapper{background:var(--ivory);border-radius:var(--r-md);border:1px solid rgba(201,169,110,.2);overflow:hidden;overflow-x:auto}
.data-table{width:100%;border-collapse:collapse;font-size:14px;min-width:500px}
.data-table th{background:var(--beige);color:var(--brown);font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.7px;padding:12px 16px;text-align:left;border-bottom:2px solid var(--beige-mid);white-space:nowrap}
.data-table td{padding:13px 16px;border-bottom:1px solid rgba(201,169,110,.15);color:var(--charcoal);vertical-align:middle}
.data-table tr:last-child td{border-bottom:none}
.data-table tr:hover td{background:rgba(201,169,110,.05)}

/* ── FILTER BAR ─────────────────────────────────────────── */
.filter-bar{display:flex;gap:12px;align-items:center;flex-wrap:wrap;margin-bottom:var(--gap-md)}
.search-wrap{position:relative;flex:1;min-width:180px}
.search-input{width:100%;padding:10px 16px 10px 40px;background:var(--ivory);border:1.5px solid var(--beige-mid);border-radius:var(--r-pill);font-size:14px;outline:none;transition:border-color .2s}
.search-input:focus{border-color:var(--brown)}
.search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:#BBA882;font-size:14px;pointer-events:none}

/* ── PRODUCT ADMIN CARDS ────────────────────────────────── */
.product-admin-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:var(--gap-md)}
.product-admin-card{background:var(--ivory);border-radius:var(--r-md);border:1px solid rgba(201,169,110,.2);overflow:hidden;transition:box-shadow .2s}
.product-admin-card:hover{box-shadow:var(--shadow-sm)}
.product-admin-thumb{height:120px;background:var(--beige);display:flex;align-items:center;justify-content:center;overflow:hidden}
.product-admin-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .3s}
.product-admin-card:hover .product-admin-thumb img{transform:scale(1.05)}
.product-admin-body{padding:14px}
.product-admin-body h4{font-size:14px;margin-bottom:2px;color:var(--brown-deep)}
.product-admin-body .price{font-weight:600;color:var(--brown);font-size:15px;margin:4px 0 8px}
.product-admin-actions{display:flex;gap:6px;margin-top:10px}

/* Image upload area */
.img-upload-area{border:2px dashed var(--beige-mid);border-radius:var(--r-md);padding:20px;text-align:center;cursor:pointer;transition:border-color .2s;background:var(--cream);position:relative;overflow:hidden}
.img-upload-area:hover{border-color:var(--brown)}
.img-upload-area input[type=file]{position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%}
.img-upload-preview{width:100%;height:120px;object-fit:cover;border-radius:var(--r-sm);margin-top:8px;display:none}

/* ── TOGGLE ─────────────────────────────────────────────── */
.availability-toggle{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--brown-light);margin-top:6px}
.toggle-switch{position:relative;width:36px;height:20px;cursor:pointer;display:inline-block;flex-shrink:0}
.toggle-switch input{display:none}
.toggle-track{position:absolute;inset:0;background:var(--beige-mid);border-radius:10px;transition:background .2s}
.toggle-switch input:checked+.toggle-track{background:var(--teal)}
.toggle-thumb{position:absolute;width:14px;height:14px;background:#fff;border-radius:50%;top:3px;left:3px;transition:transform .2s;box-shadow:0 1px 3px rgba(0,0,0,.2)}
.toggle-switch input:checked~.toggle-thumb{transform:translateX(16px)}

/* ── ANALYTICS ──────────────────────────────────────────── */
.top-items-list{list-style:none}
.top-item{display:flex;align-items:center;gap:14px;padding:12px 0;border-bottom:1px solid rgba(201,169,110,.12)}
.top-item:last-child{border-bottom:none}
.top-item-rank{width:28px;height:28px;background:var(--beige);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600;color:var(--brown);flex-shrink:0}
.top-item-rank.gold{background:var(--gold);color:#fff}
.top-item-name{flex:1;font-size:14px}
.top-item-count{font-size:13px;font-weight:600;color:var(--teal)}
.gcash-badge{display:inline-flex;align-items:center;gap:6px;background:#E3F2FD;color:#1565C0;padding:4px 10px;border-radius:var(--r-pill);font-size:12px;font-weight:500}
.cash-badge{display:inline-flex;align-items:center;gap:6px;background:#F1F8E9;color:#33691E;padding:4px 10px;border-radius:var(--r-pill);font-size:12px;font-weight:500}
.perm-notice{background:#FFF3E0;border:1px solid #FFE0B2;border-radius:var(--r-sm);padding:12px 16px;font-size:13px;color:#E65100;margin-bottom:20px;display:flex;align-items:center;gap:8px}

/* ── TOAST ──────────────────────────────────────────────── */
.toast-container{position:fixed;bottom:28px;right:28px;z-index:9999;display:flex;flex-direction:column;gap:10px;pointer-events:none;max-width:calc(100vw - 56px)}
.toast{background:var(--brown-deep);color:var(--beige);padding:12px 20px;border-radius:var(--r-md);font-size:13px;box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:10px;animation:toastIn .3s ease forwards;max-width:320px;word-break:break-word}
.toast.success::before{content:'✓';color:#80CBC4;font-weight:700;flex-shrink:0}
.toast.error::before{content:'✕';color:#EF9A9A;font-weight:700;flex-shrink:0}
.toast.info::before{content:'i';color:var(--sand);font-weight:700;font-style:italic;flex-shrink:0}
@keyframes toastIn{from{opacity:0;transform:translateX(20px)}to{opacity:1;transform:translateX(0)}}

/* ── MISC ───────────────────────────────────────────────── */
.empty-state{text-align:center;padding:60px 20px}
.empty-state-icon{font-size:56px;margin-bottom:16px;opacity:.4}
.empty-state h4{font-size:18px;color:var(--brown-light);margin-bottom:8px}
.empty-state p{font-size:14px;color:#BBA882}
.view{display:none}
.view.active{display:block}
.footer{background:var(--brown-deep);color:rgba(240,228,200,.55);text-align:center;padding:var(--gap-lg);font-size:13px}
.footer strong{color:var(--blush)}
::-webkit-scrollbar{width:6px;height:6px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--beige-mid);border-radius:10px}
@keyframes fadeSlideUp{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}
.animate-in{animation:fadeSlideUp .4s ease forwards}

/* ══════════════════════════════════════════════════════════
   RESPONSIVE BREAKPOINTS
   ════════════════════════════════════════════════════════ */

/* ── LARGE DESKTOP (1200px+) ─────────────── already base ─ */

/* ── TABLET (768px – 1199px) ──────────────────────────── */
@media(max-width:1199px){
  .container{padding:0 var(--gap-md)}
  .menu-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .admin-sidebar{width:200px}
}

/* ── TABLET PORTRAIT / LARGE PHONE (600px – 767px) ───── */
@media(max-width:767px){
  :root{--gap-xl:40px;--gap-lg:24px;--gap-md:16px}

  /* Navbar: hide desktop links, show hamburger */
  .navbar-links{display:none}
  .hamburger{display:flex}
  .navbar-inner{padding:0 var(--gap-md)}

  /* Hero */
  .hero{min-height:420px;padding:48px 0}
  .hero p{font-size:14px}
  .hero-actions{gap:10px}
  .btn-lg{padding:12px 24px;font-size:14px}

  /* Menu */
  .menu-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px}
  .menu-card-thumb{height:120px}
  .cat-pills{gap:8px}
  .cat-pill{padding:6px 14px;font-size:12px}

  /* Admin: hide sidebar, show mobile controls */
  .admin-sidebar{display:none}
  .admin-menu-toggle{display:flex}
  .admin-mobile-drawer{display:flex}
  .admin-content{padding:var(--gap-md)}
  .stats-grid{grid-template-columns:repeat(2,1fr);gap:12px}
  .stat-card{padding:14px}
  .queue-grid{grid-template-columns:1fr}
  .admin-topbar{padding:0 var(--gap-md)}

  /* Cart */
  .cart-drawer{width:100%;max-width:100vw}

  /* Modals */
  .modal-overlay{padding:10px;align-items:flex-start}
  .modal-box{width:100%;max-height:calc(100vh - 20px);max-height:calc(100dvh - 20px);padding:var(--gap-md);border-radius:var(--r-lg);margin:auto 0}
  .modal-box-lg{max-width:100%;width:100%}
  .modal-box [style*="grid-template-columns:1fr 1fr"],
  .modal-box [style*="grid-template-columns:2fr 1fr"]{grid-template-columns:1fr!important}
  .modal-box [style*="display:flex;gap:10px"]{flex-wrap:wrap}
  .modal-box [style*="flex-shrink:0"]{flex-shrink:1!important}
  .img-upload-area{padding:16px}
  .img-upload-preview{height:96px}
  #receipt-preview-img{max-height:160px!important}

  /* Analytics grid */
  #analytics-content .stats-grid{grid-template-columns:1fr 1fr}
  #analytics-content > div[style*="grid-template-columns:1fr 1fr"]{grid-template-columns:1fr!important}

  /* Tables */
  .data-table th,.data-table td{padding:10px 12px;font-size:12px}

  /* Topping grid */
  .topping-grid{grid-template-columns:1fr}

  /* Auth */
  .auth-card{padding:28px 20px}

  /* Filter bar */
  .filter-bar{gap:8px}
  .filter-bar .btn{font-size:12px;padding:7px 14px}

  /* Product admin */
  .product-admin-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px}
}

/* ── SMALL PHONE (below 480px) ──────────────────────────── */
@media(max-width:479px){
  .menu-grid{grid-template-columns:1fr 1fr}
  .menu-card-thumb{height:110px}
  .menu-card-body{padding:12px}
  .menu-price{font-size:15px}
  .hero h1{font-size:26px}
  .stats-grid{grid-template-columns:1fr 1fr}
  .stat-value{font-size:20px}
  .queue-filters{gap:6px}
  .queue-filter{padding:6px 12px;font-size:12px}
  .product-admin-grid{grid-template-columns:1fr 1fr}
  .payment-methods{grid-template-columns:1fr 1fr}
  .options-row{gap:6px}
  .opt-chip{padding:7px 12px;font-size:12px}
  .topping-chip{padding:8px 10px;font-size:12px}
  .modal-drink-header{flex-direction:column;gap:10px}
  .modal-drink-thumb{width:60px;height:60px}
  .auth-card{padding:24px 16px;border-radius:var(--r-lg)}
  .toast-container{bottom:16px;right:16px;left:16px}
  .toast{max-width:100%}
  .cart-drawer-header,.cart-drawer-body,.cart-drawer-footer{padding-left:var(--gap-md);padding-right:var(--gap-md)}
  .admin-content{padding:12px}
}

/* ── MANAGE LIST (categories & toppings) ────────────────── */
.manage-list{display:flex;flex-direction:column;gap:8px}
.manage-row{display:flex;align-items:center;gap:12px;background:var(--ivory);border:1px solid rgba(201,169,110,.2);border-radius:var(--r-sm);padding:12px 16px}
.manage-row-emoji{font-size:20px;width:28px;text-align:center;flex-shrink:0}
.manage-row-name{flex:1;font-size:14px;font-weight:500;color:var(--brown-deep)}
.manage-row-price{font-size:13px;color:var(--brown);font-weight:500;margin-right:8px;flex-shrink:0}
.manage-row-actions{display:flex;gap:6px;flex-shrink:0}

/* ── LOGO ─────────────────────────────────────────────────── */
.navbar-logo-img{background:none;border:none;cursor:pointer;padding:4px;display:flex;align-items:center;flex-shrink:0}
.site-logo-img{height:42px;width:auto;object-fit:contain}
.auth-logo-container{text-align:center;margin-bottom:6px}
.auth-logo-img{height:64px;width:auto;object-fit:contain;margin:0 auto}
.admin-sidebar-logo-img{padding:20px 20px 16px;border-bottom:1px solid rgba(255,255,255,.08);margin-bottom:12px;display:flex;align-items:center}

/* ── PROMO RIBBON ─────────────────────────────────────────── */
.promo-ribbon{position:absolute;top:10px;right:10px;background:var(--teal);color:#fff;font-size:10px;font-weight:700;padding:3px 10px;border-radius:var(--r-pill);text-transform:uppercase;letter-spacing:.5px;z-index:2}

/* ── VARIETY ROWS (item form) ─────────────────────────────── */
.variety-row{display:flex;align-items:center;gap:8px;padding:8px;background:var(--cream);border:1px solid var(--beige-mid);border-radius:var(--r-sm)}
.variety-row input{font-family:var(--font-body);font-size:14px;padding:8px 12px;border:1.5px solid var(--beige-mid);border-radius:var(--r-sm);outline:none;background:var(--ivory);color:var(--charcoal);min-width:0}
.variety-row input:focus{border-color:var(--brown)}

@media(max-width:767px){
  .variety-row{flex-wrap:wrap}
  .variety-row input[type="text"]{flex:1 1 180px}
  .variety-row input[type="number"]{flex:1 1 120px}
  .variety-row .btn{flex:0 0 auto}
}


/* ═══════════════════════════════════════════════════════════
   NOTIFICATION BELL
   ════════════════════════════════════════════════════════ */

/* Bell button in navbar */
.notif-bell {
  position: relative;
  background: none;
  border: none;
  cursor: pointer;
  width: 36px;
  height: 36px;
  padding: 0;
  border-radius: var(--r-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background .2s;
  flex-shrink: 0;
}
.notif-bell:hover { background: var(--beige); }
.notif-bell-icon{width:19px;height:19px;color:var(--brown)}
.notif-bell:hover .notif-bell-icon{color:var(--brown-deep)}

/* Red badge on the bell */
#notif-badge {
  position: absolute;
  top: 2px;
  right: 2px;
  background: #E53935;
  color: #fff;
  font-size: 10px;
  font-weight: 700;
  min-width: 18px;
  height: 18px;
  border-radius: var(--r-pill);
  display: none;           /* shown by JS when count > 0 */
  align-items: center;
  justify-content: center;
  padding: 0 4px;
  line-height: 1;
  border: 2px solid var(--ivory);
  pointer-events: none;
}

@keyframes badgePulse {
  0%,100% { transform: scale(1); }
  40%     { transform: scale(1.4); }
  70%     { transform: scale(0.9); }
}
.notif-badge-pulse { animation: badgePulse .5s ease-out; }

/* ─── Notification Panel (dropdown from bell) ─────────── */
#notif-panel {
  position: fixed;
  top: calc(var(--nav-h) + 8px);
  right: 16px;
  width: min(360px, calc(100vw - 32px));
  background: var(--ivory);
  border: 1px solid var(--beige-mid);
  border-radius: var(--r-lg);
  box-shadow: 0 8px 32px rgba(44,26,14,.18);
  z-index: 8500;
  overflow: hidden;
  display: none;          /* toggled by JS */
  flex-direction: column;
  max-height: 70vh;
}
#notif-panel.open { display: flex; }

.notif-panel-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 16px 10px;
  border-bottom: 1px solid var(--beige);
  flex-shrink: 0;
}
.notif-panel-title {
  font-family: var(--font-display);
  font-size: 16px;
  font-weight: 600;
  color: var(--brown-deep);
}
.notif-panel-close {
  background: var(--beige);
  border: none;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  font-size: 14px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--brown);
  transition: background .15s;
}
.notif-panel-close:hover { background: var(--beige-mid); }

.notif-panel-body {
  overflow-y: auto;
  flex: 1;
  padding: 8px 0;
}

.notif-item {
  display: flex;
  gap: 12px;
  align-items: flex-start;
  padding: 12px 16px;
  border-bottom: 1px solid rgba(201,169,110,.12);
  transition: background .15s;
}
.notif-item:last-child  { border-bottom: none; }
.notif-item:hover       { background: rgba(201,169,110,.08); }
.notif-item.unread      { background: rgba(45,114,104,.05); }

.notif-item-icon {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: var(--teal);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 16px;
  flex-shrink: 0;
}
.notif-item-body { flex: 1; min-width: 0; }
.notif-item-title {
  font-size: 13px;
  font-weight: 600;
  color: var(--brown-deep);
  margin-bottom: 2px;
}
.notif-item-sub {
  font-size: 12px;
  color: var(--brown-light);
  line-height: 1.4;
}
.notif-item-time {
  font-size: 11px;
  color: #BBA882;
  margin-top: 4px;
}

.notif-panel-empty {
  text-align: center;
  padding: 28px 16px;
  color: #BBA882;
  font-size: 13px;
}
.notif-panel-footer {
  padding: 10px 16px;
  border-top: 1px solid var(--beige);
  flex-shrink: 0;
}
.notif-panel-clear {
  background: none;
  border: none;
  color: var(--brown-light);
  font-size: 12px;
  cursor: pointer;
  width: 100%;
  text-align: center;
  padding: 4px;
  transition: color .15s;
}
.notif-panel-clear:hover { color: var(--brown-deep); }

/* ═══════════════════════════════════════════════════════════
   ORDER READY NOTIFICATION — Corner Toast (NON-BLOCKING)
   Displayed in the bottom-right corner.
   No blur, no full-screen overlay, no page blocking.
   ════════════════════════════════════════════════════════ */

/* Container anchored to bottom-right corner */
#order-ready-popup {
  position: fixed;
  bottom: 24px;
  right: 24px;
  z-index: 9000;
  width: min(380px, calc(100vw - 48px));
  pointer-events: none;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

/* Individual notification card */
.orpop-card {
  background: var(--ivory);
  border-radius: var(--r-lg);
  border: 1px solid rgba(45,114,104,.25);
  box-shadow:
    0 4px 6px rgba(44,26,14,.04),
    0 10px 24px rgba(44,26,14,.10),
    0 0 0 1px rgba(45,114,104,.08);
  padding: 0;
  overflow: hidden;
  pointer-events: all;
  /* Slide-in animation */
  transform: translateX(calc(100% + 32px));
  opacity: 0;
  transition: transform .4s cubic-bezier(.34,1.4,.64,1), opacity .3s ease;
}
.orpop-card.orpop-in {
  transform: translateX(0);
  opacity: 1;
}
.orpop-card.orpop-out {
  transform: translateX(calc(100% + 32px));
  opacity: 0;
  transition: transform .3s ease, opacity .25s ease;
}

/* Green progress bar at the top showing auto-dismiss countdown */
.orpop-progress {
  height: 3px;
  background: var(--teal);
  transform-origin: left;
  animation: orpopProgress var(--orpop-duration, 30s) linear forwards;
}
@keyframes orpopProgress {
  from { transform: scaleX(1); }
  to   { transform: scaleX(0); }
}

/* Card inner content */
.orpop-inner {
  padding: 16px 16px 14px;
  display: flex;
  gap: 12px;
  align-items: flex-start;
}

.orpop-icon-wrap {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: var(--teal);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  box-shadow: 0 4px 12px rgba(45,114,104,.35);
  animation: orpopIconBounce .5s .15s cubic-bezier(.34,1.56,.64,1) both;
}
@keyframes orpopIconBounce {
  from { transform: scale(0); }
  to   { transform: scale(1); }
}
.orpop-check {
  font-size: 20px;
  font-weight: 700;
  color: #fff;
  line-height: 1;
}

.orpop-content { flex: 1; min-width: 0; }

.orpop-title {
  font-family: var(--font-display);
  font-size: 16px;
  font-weight: 600;
  color: var(--teal);
  margin-bottom: 2px;
  line-height: 1.2;
}
.orpop-order-num {
  font-size: 18px;
  font-weight: 700;
  font-family: var(--font-display);
  color: var(--brown-deep);
  letter-spacing: .5px;
  margin-bottom: 4px;
}
.orpop-subtitle {
  font-size: 12px;
  color: var(--brown-light);
  line-height: 1.4;
  margin-bottom: 8px;
}
.orpop-pay-note {
  font-size: 11px;
  color: var(--brown-light);
  line-height: 1.4;
  padding: 6px 8px;
  background: rgba(201,169,110,.12);
  border-radius: var(--r-sm);
  border-left: 2px solid var(--sand);
  margin-bottom: 10px;
}

.orpop-close {
  background: none;
  border: none;
  color: #BBA882;
  font-size: 16px;
  cursor: pointer;
  padding: 2px;
  line-height: 1;
  flex-shrink: 0;
  transition: color .15s;
  align-self: flex-start;
}
.orpop-close:hover { color: var(--brown-deep); }

/* Footer CTA */
.orpop-footer {
  padding: 0 16px 14px;
  display: flex;
  gap: 8px;
}
.orpop-cta {
  flex: 1;
  background: var(--teal);
  color: #fff;
  border: none;
  border-radius: var(--r-pill);
  padding: 9px 16px;
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  transition: background .2s, transform .15s;
  box-shadow: 0 2px 8px rgba(45,114,104,.3);
}
.orpop-cta:hover  { background: var(--teal-light); transform: translateY(-1px); }
.orpop-cta:active { transform: translateY(0); }

/* ─── Responsive tweaks ─────────────────────────────────── */

/* Tablet: move to top-right, tighter padding */
@media (max-width: 767px) {
  #order-ready-popup {
    top: calc(var(--nav-h) + 12px);
    bottom: auto;
    right: 12px;
    width: min(340px, calc(100vw - 24px));
  }
  .orpop-inner { padding: 14px 14px 12px; }
  .orpop-footer { padding: 0 14px 12px; }
  #notif-panel {
    top: calc(var(--nav-h) + 6px);
    right: 8px;
    width: calc(100vw - 16px);
    max-height: 60vh;
  }
}

/* Phone: compact card, full width */
@media (max-width: 479px) {
  #order-ready-popup {
    right: 8px;
    left: 8px;
    width: auto;
  }
  .orpop-icon-wrap  { width: 38px; height: 38px; }
  .orpop-check      { font-size: 17px; }
  .orpop-title      { font-size: 15px; }
  .orpop-order-num  { font-size: 16px; }
  .orpop-subtitle   { font-size: 11px; }
}

/* ── QUEUE FILTER DANGER BUTTON ─────────────────────────── */
.queue-filter-danger {
  background: #FFF5F5;
  color: #C62828;
  border-color: rgba(198,40,40,.25);
  margin-left: auto;
}
.queue-filter-danger:hover {
  background: #FFEBEE;
  border-color: #C62828;
}

/* ── TEXTAREA RESIZE FIX ─────────────────────────────────── */
/* Only allow vertical resize — never horizontal overflow */
textarea.form-input {
  resize:    vertical;
  width:     100%;
  max-width: 100%;
  box-sizing: border-box;
  min-height: 60px;
  max-height: 300px;
}
/* Keep modal children within the scrollable modal pane. */
.modal-box > * { box-sizing: border-box; max-width: 100%; min-width: 0; }
.modal-box img { max-width: 100%; }

/* ── TRUSTED CUSTOMER BADGE ──────────────────────────────── */
.trusted-badge {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  font-size: 11px;
  font-weight: 700;
  color: #7B5800;
  background: linear-gradient(135deg, #FFF8E1, #FFECB3);
  border: 1px solid #FFD54F;
  border-radius: var(--r-pill);
  padding: 2px 8px;
  margin-left: 6px;
  white-space: nowrap;
  vertical-align: middle;
}

/* Smaller version for order cards */
.trusted-badge-sm {
  display: inline-flex;
  align-items: center;
  font-size: 10px;
  font-weight: 700;
  color: #7B5800;
  background: linear-gradient(135deg, #FFF8E1, #FFECB3);
  border: 1px solid #FFD54F;
  border-radius: var(--r-pill);
  padding: 1px 7px;
  margin-left: 6px;
  white-space: nowrap;
  vertical-align: middle;
}
