.swm-menu-root {
  --swm-text: var(--swm-dark, #241116);
  --swm-muted: #74676a;
  --swm-border: rgba(91, 21, 48, .13);
  --swm-shadow: 0 22px 70px rgba(91, 21, 48, .16);
  --swm-radius: 28px;
  direction: rtl;
  color: var(--swm-text);
  background: linear-gradient(180deg, #fffaf6 0%, #fff 42%, #fff8f1 100%);
  font-family: Tahoma, Arial, sans-serif;
  line-height: 1.5;
  position: relative;
  isolation: isolate;
  overflow-x: clip;
}
.swm-menu-root * { box-sizing: border-box; }
.swm-menu-root button,
.swm-menu-root input,
.swm-menu-root textarea,
.swm-menu-root select { font: inherit; }
.swm-menu-root button { cursor: pointer; }
.swm-container { width: min(100% - 32px, 1180px); margin-inline: auto; }

.swm-header { position: sticky; top: 0; z-index: 60; background: rgba(255, 250, 246, .86); backdrop-filter: blur(16px); border-bottom: 1px solid var(--swm-border); }
.swm-nav { min-height: 82px; display: flex; align-items: center; justify-content: space-between; gap: 18px; }
.swm-brand { display: inline-flex; align-items: center; gap: 12px; text-decoration: none; color: var(--swm-primary); min-width: 0; }
.swm-brand img { width: 60px; height: 60px; object-fit: contain; border-radius: 18px; background: #fff; padding: 6px; box-shadow: 0 10px 25px rgba(0,0,0,.08); }
.swm-brand strong { display: block; font-size: 1.1rem; line-height: 1.2; }
.swm-brand small { color: var(--swm-muted); font-weight: 800; }
.swm-nav-links { display: flex; gap: 8px; }
.swm-nav-links a { text-decoration: none; color: var(--swm-text); font-weight: 900; padding: 10px 12px; border-radius: 999px; }
.swm-nav-links a:hover { background: var(--swm-cream); color: var(--swm-primary); }
.swm-nav-actions { display: flex; align-items: center; gap: 10px; }
.swm-whatsapp-fast,
.swm-cart-open { border: 0; text-decoration: none; display: inline-flex; align-items: center; gap: 8px; min-height: 44px; padding: 0 16px; border-radius: 999px; font-weight: 900; }
.swm-whatsapp-fast { color: #fff; background: #17a34a; }
.swm-cart-open { color: #fff; background: var(--swm-primary); }
.swm-cart-open b { display: inline-grid; place-items: center; min-width: 24px; height: 24px; border-radius: 50%; background: rgba(255,255,255,.22); }

.swm-hero { position: relative; padding: clamp(42px, 7vw, 86px) 0 34px; overflow: hidden; }
.swm-hero::before { content: ''; position: absolute; inset: -160px auto auto -110px; width: 430px; height: 430px; border-radius: 50%; background: radial-gradient(circle, rgba(241,90,36,.20), transparent 68%); z-index: -1; }
.swm-hero-pattern { position: absolute; inset: 0 0 auto auto; width: min(520px, 55vw); opacity: .25; pointer-events: none; z-index: -1; }
.swm-hero-grid { display: grid; grid-template-columns: minmax(0, 1.05fr) minmax(320px, .95fr); gap: 30px; align-items: center; }
.swm-eyebrow { display: inline-flex; color: var(--swm-secondary); background: #fff; border: 1px solid var(--swm-border); border-radius: 999px; padding: 8px 14px; font-weight: 900; box-shadow: 0 12px 28px rgba(91,21,48,.08); }
.swm-hero h1 { margin: 14px 0 12px; color: var(--swm-primary); font-size: clamp(2.25rem, 5vw, 5.2rem); line-height: 1.08; letter-spacing: -1px; }
.swm-hero p { color: var(--swm-muted); font-size: 1.08rem; line-height: 2; max-width: 680px; margin: 0; }
.swm-closed-alert { margin-top: 16px; padding: 14px 16px; border-radius: 18px; color: #8a171d; background: #fff0f0; border: 1px solid #ffd0d0; font-weight: 900; }
.swm-hero-actions { display: flex; gap: 12px; flex-wrap: wrap; margin-top: 24px; }
.swm-btn { border: 0; text-decoration: none; display: inline-flex; align-items: center; justify-content: center; min-height: 50px; padding: 0 22px; border-radius: 999px; font-weight: 900; transition: .22s ease; }
.swm-btn:hover { transform: translateY(-2px); }
.swm-btn-primary { color: #fff; background: linear-gradient(135deg, var(--swm-primary), var(--swm-secondary)); box-shadow: 0 16px 34px rgba(91,21,48,.23); }
.swm-btn-light { color: var(--swm-primary); background: #fff; border: 1px solid var(--swm-border); }
.swm-btn-full { width: 100%; }
.swm-hero-meta { display: flex; gap: 10px; flex-wrap: wrap; margin-top: 18px; color: var(--swm-muted); font-weight: 900; }
.swm-hero-meta span { background: #fff; border: 1px solid var(--swm-border); border-radius: 999px; padding: 9px 12px; }
.swm-hero-card { min-height: 440px; border-radius: 48px; border: 1px solid var(--swm-border); background: radial-gradient(circle at 50% 40%, var(--swm-cream), #fff 54%, rgba(244,185,74,.28)); box-shadow: var(--swm-shadow); position: relative; overflow: hidden; display: grid; place-items: center; }
.swm-hero-card::before { content: ''; position: absolute; width: 270px; height: 270px; border-radius: 50%; background: rgba(241,90,36,.13); filter: blur(8px); }
.swm-food-orb { font-size: 8.5rem; filter: drop-shadow(0 26px 34px rgba(91,21,48,.22)); animation: swmFloat 4s ease-in-out infinite; z-index: 1; }
@keyframes swmFloat { 0%,100% { transform: translateY(0) rotate(0deg); } 50% { transform: translateY(-12px) rotate(-3deg); } }
.swm-hero-card-text { position: absolute; right: 24px; left: 24px; bottom: 24px; padding: 18px; border-radius: 24px; background: rgba(255,255,255,.9); backdrop-filter: blur(12px); }
.swm-hero-card-text b { display: block; color: var(--swm-primary); margin-bottom: 5px; }
.swm-hero-card-text span { color: var(--swm-muted); font-size: .92rem; line-height: 1.7; }

.swm-main { padding: 42px 0 100px; }
.swm-section-head { max-width: 760px; margin-bottom: 22px; }
.swm-section-head span { color: var(--swm-secondary); font-weight: 900; }
.swm-section-head h2 { margin: 8px 0 8px; color: var(--swm-dark); font-size: clamp(1.8rem, 4vw, 3.2rem); }
.swm-section-head p { color: var(--swm-muted); line-height: 1.9; margin: 0; }

.swm-controls { position: sticky; top: 82px; z-index: 42; display: grid; grid-template-columns: 1fr auto auto; gap: 10px; align-items: center; padding: 10px; margin: 0 0 12px; border-radius: 24px; background: rgba(255,255,255,.88); border: 1px solid var(--swm-border); backdrop-filter: blur(14px); box-shadow: 0 14px 34px rgba(91,21,48,.08); }
.swm-controls.is-search-hidden { display: none; }
.swm-search-box { display: grid; gap: 4px; font-weight: 900; color: var(--swm-primary); }
.swm-search-box input { min-height: 48px; border: 1px solid var(--swm-border); border-radius: 18px; padding: 0 16px; outline: 0; background: #fffaf6; }
.swm-control-stats { min-width: 110px; text-align: center; background: var(--swm-cream); border-radius: 18px; padding: 9px 14px; color: var(--swm-primary); font-weight: 900; }
.swm-control-stats b { display: block; font-size: 1.3rem; }
.swm-reset-search { border: 0; border-radius: 18px; min-height: 48px; padding: 0 14px; background: var(--swm-primary); color: #fff; font-weight: 900; }

.swm-categories { position: sticky; top: 168px; z-index: 35; display: flex; gap: 10px; overflow-x: auto; padding: 12px 0; margin-bottom: 22px; scrollbar-width: none; background: linear-gradient(90deg, #fffaf6, rgba(255,255,255,.94)); }
.swm-categories::-webkit-scrollbar { display: none; }
.swm-category-btn { flex: 0 0 auto; border: 1px solid var(--swm-border); background: #fff; color: var(--swm-primary); border-radius: 999px; padding: 9px 15px; font-weight: 900; box-shadow: 0 8px 22px rgba(91,21,48,.06); transition: .22s ease; display: inline-flex; align-items: center; gap: 8px; }
.swm-category-btn img { width: 26px; height: 26px; border-radius: 50%; object-fit: cover; }
.swm-category-btn.is-active,
.swm-category-btn:hover { background: var(--swm-primary); color: #fff; transform: translateY(-1px); }

.swm-menu-group { scroll-margin-top: 220px; margin-bottom: 34px; }
.swm-menu-title { display: flex; justify-content: space-between; align-items: center; gap: 14px; margin-bottom: 16px; }
.swm-menu-title h3 { margin: 0; font-size: 1.35rem; color: var(--swm-primary); }
.swm-menu-title span { color: var(--swm-muted); font-weight: 700; }
.swm-products-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 18px; }
.swm-product-card { background: rgba(255,255,255,.92); border: 1px solid var(--swm-border); border-radius: 30px; overflow: hidden; box-shadow: 0 16px 42px rgba(91,21,48,.08); transition: .25s ease; }
.swm-product-card:hover { transform: translateY(-4px); box-shadow: var(--swm-shadow); }
.swm-product-card[hidden], .swm-menu-group[hidden] { display: none !important; }
.swm-product-media { height: 174px; position: relative; background: linear-gradient(135deg, var(--swm-cream), #fff, rgba(244,185,74,.18)); display: grid; place-items: center; overflow: hidden; }
.swm-product-media img { width: 100%; height: 100%; object-fit: cover; transition: .3s ease; }
.swm-product-card:hover .swm-product-media img { transform: scale(1.04); }
.swm-product-emoji { font-size: 4.2rem; filter: drop-shadow(0 10px 16px rgba(91,21,48,.2)); }
.swm-badge { position: absolute; top: 14px; right: 14px; color: #fff; background: var(--swm-secondary); border-radius: 999px; padding: 6px 10px; font-size: .76rem; font-weight: 900; box-shadow: 0 10px 20px rgba(241,90,36,.25); }
.swm-unavailable { position: absolute; inset: 0; display: grid; place-items: center; background: rgba(36,17,22,.66); color: #fff; font-weight: 900; }
.swm-product-body { padding: 18px; }
.swm-product-top { display: flex; justify-content: space-between; align-items: start; gap: 14px; }
.swm-product-top h4 { margin: 0; color: var(--swm-dark); font-size: 1.05rem; line-height: 1.5; }
.swm-price { color: var(--swm-primary); font-weight: 900; white-space: nowrap; }
.swm-desc { margin: 10px 0 14px; color: var(--swm-muted); line-height: 1.75; font-size: .92rem; min-height: 48px; }
.swm-option-block { margin-top: 12px; }
.swm-option-block > span { display: block; font-weight: 900; color: var(--swm-primary); font-size: .86rem; margin-bottom: 8px; }
.swm-pill-row { display: flex; flex-wrap: wrap; gap: 7px; }
.swm-pill { position: relative; }
.swm-pill input { position: absolute; opacity: 0; pointer-events: none; }
.swm-pill span { display: inline-flex; align-items: center; justify-content: center; min-height: 34px; padding: 7px 10px; border-radius: 999px; border: 1px solid var(--swm-border); background: #fff; color: var(--swm-text); font-size: .82rem; font-weight: 800; transition: .2s ease; }
.swm-pill input:checked + span { background: var(--swm-primary); color: #fff; border-color: var(--swm-primary); }
.swm-note { width: 100%; border: 1px solid var(--swm-border); border-radius: 18px; min-height: 42px; padding: 10px 12px; resize: vertical; outline: none; background: #fff; }
.swm-card-total { display: flex; justify-content: space-between; align-items: center; gap: 12px; margin-top: 14px; padding: 11px 13px; border-radius: 18px; background: var(--swm-cream); color: var(--swm-primary); font-weight: 900; }
.swm-product-actions { display: flex; align-items: center; gap: 10px; margin-top: 15px; }
.swm-qty { display: inline-flex; align-items: center; gap: 8px; background: var(--swm-cream); border-radius: 999px; padding: 6px; }
.swm-qty button { width: 32px; height: 32px; border-radius: 50%; border: 0; color: #fff; background: var(--swm-primary); font-weight: 900; }
.swm-qty span { min-width: 24px; text-align: center; font-weight: 900; color: var(--swm-primary); }
.swm-add { flex: 1; border: 0; min-height: 44px; color: #fff; background: var(--swm-secondary); border-radius: 999px; font-weight: 900; transition: .2s ease; }
.swm-add:hover { transform: translateY(-2px); box-shadow: 0 12px 26px rgba(241,90,36,.24); }
.swm-add:disabled { opacity: .55; cursor: not-allowed; transform: none; box-shadow: none; }

.swm-cart-overlay { position: fixed; inset: 0; background: rgba(20,10,14,.46); z-index: 90; opacity: 0; pointer-events: none; transition: .25s ease; }
.swm-cart { position: fixed; top: 0; bottom: 0; left: 0; width: min(500px, 94vw); z-index: 100; transform: translateX(-105%); transition: .34s cubic-bezier(.2,.8,.2,1); background: #fffdf9; border-right: 1px solid var(--swm-border); box-shadow: 30px 0 80px rgba(0,0,0,.22); display: flex; flex-direction: column; padding: 20px; overflow-y: auto; }
.swm-menu-root.is-cart-open .swm-cart { transform: translateX(0); }
.swm-menu-root.is-cart-open .swm-cart-overlay { opacity: 1; pointer-events: auto; }
.swm-cart-head { display: flex; align-items: center; justify-content: space-between; gap: 14px; padding-bottom: 12px; border-bottom: 1px solid var(--swm-border); }
.swm-cart-head h3 { margin: 0; color: var(--swm-primary); }
.swm-cart-head p { margin: 4px 0 0; color: var(--swm-muted); }
.swm-icon-btn { width: 40px; height: 40px; border-radius: 50%; border: 1px solid var(--swm-border); background: #fff; color: var(--swm-primary); font-size: 1.4rem; }
.swm-checkout-steps { display: grid; grid-template-columns: repeat(3,1fr); gap: 8px; margin: 14px 0 0; }
.swm-checkout-steps span { text-align: center; padding: 9px; border-radius: 999px; background: #f3eee8; color: var(--swm-muted); font-weight: 900; font-size: .82rem; }
.swm-checkout-steps .is-active { background: var(--swm-primary); color: #fff; }
.swm-cart-items { display: grid; gap: 12px; padding: 16px 0; }
.swm-empty { text-align: center; padding: 28px 14px; border: 1px dashed var(--swm-border); border-radius: 22px; color: var(--swm-muted); background: #fff; display: grid; gap: 6px; }
.swm-empty strong { color: var(--swm-primary); }
.swm-cart-item { background: #fff; border: 1px solid var(--swm-border); border-radius: 22px; padding: 14px; box-shadow: 0 10px 24px rgba(91,21,48,.06); }
.swm-cart-line { display: flex; justify-content: space-between; gap: 12px; align-items: start; }
.swm-cart-line h4 { margin: 0; color: var(--swm-dark); }
.swm-cart-line b { color: var(--swm-primary); white-space: nowrap; }
.swm-cart-meta { margin: 8px 0; color: var(--swm-muted); font-size: .86rem; line-height: 1.7; }
.swm-cart-item-actions { display: flex; justify-content: space-between; align-items: center; }
.swm-mini-qty { display: inline-flex; gap: 8px; align-items: center; }
.swm-mini-qty button { width: 30px; height: 30px; border: 0; border-radius: 50%; background: var(--swm-cream); color: var(--swm-primary); font-weight: 900; }
.swm-remove { border: 0; background: transparent; color: #b4232b; font-weight: 900; }
.swm-summary { background: var(--swm-cream); border: 1px solid var(--swm-border); border-radius: 22px; padding: 14px; display: grid; gap: 10px; }
.swm-summary div { display: flex; justify-content: space-between; gap: 12px; }
.swm-total { padding-top: 10px; border-top: 1px solid var(--swm-border); color: var(--swm-primary); font-size: 1.1rem; font-weight: 900; }
.swm-cart-tools { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; margin-top: 10px; }
.swm-cart-tools button { border: 1px solid var(--swm-border); min-height: 40px; border-radius: 14px; background: #fff; color: var(--swm-primary); font-weight: 900; }
.swm-customer-form { display: grid; gap: 12px; margin-top: 16px; }
.swm-customer-form h4 { margin: 0; color: var(--swm-primary); }
.swm-customer-form label { display: grid; gap: 7px; font-weight: 800; color: var(--swm-text); }
.swm-customer-form input,
.swm-customer-form textarea,
.swm-customer-form select { width: 100%; border: 1px solid var(--swm-border); border-radius: 16px; padding: 12px; background: #fff; outline: none; }
.swm-invoice-note { margin: 0; color: var(--swm-muted); font-size: .84rem; line-height: 1.7; text-align: center; }

.swm-mobile-bar { position: fixed; right: 16px; left: 16px; bottom: 16px; z-index: 70; display: none; align-items: center; justify-content: space-between; min-height: 58px; border: 0; border-radius: 999px; color: #fff; background: linear-gradient(135deg,var(--swm-primary),var(--swm-secondary)); padding: 0 18px; font-weight: 900; box-shadow: 0 18px 42px rgba(91,21,48,.28); }
.swm-mobile-bar b { display: inline-grid; place-items: center; min-width: 24px; height: 24px; background: rgba(255,255,255,.18); border-radius: 50%; margin-inline-end: 5px; }
.swm-mobile-bar strong { background: rgba(255,255,255,.18); padding: 7px 12px; border-radius: 999px; }
.swm-toast { position: fixed; right: 50%; transform: translate(50%, 20px); bottom: 88px; z-index: 130; padding: 12px 18px; border-radius: 999px; color: #fff; background: var(--swm-primary); box-shadow: var(--swm-shadow); opacity: 0; pointer-events: none; transition: .25s ease; font-weight: 900; }
.swm-toast.is-show { opacity: 1; transform: translate(50%, 0); }

@media (max-width: 1040px) {
  .swm-products-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .swm-nav-links { display: none; }
}

@media (max-width: 720px) {
  .swm-container { width: min(100% - 24px, 1180px); }
  .swm-nav { min-height: 68px; }
  .swm-brand img { width: 50px; height: 50px; }
  .swm-whatsapp-fast { display: none; }
  .swm-hero-grid { grid-template-columns: 1fr; }
  .swm-hero-card { min-height: 280px; border-radius: 34px; }
  .swm-food-orb { font-size: 5.6rem; }
  .swm-products-grid { grid-template-columns: 1fr; }
  .swm-controls { top: 68px; grid-template-columns: 1fr; border-radius: 20px; margin-inline: -2px; }
  .swm-control-stats { display: none; }
  .swm-categories { top: 154px; margin-inline: -12px; padding-inline: 12px; }
  .swm-menu-group { scroll-margin-top: 220px; }
  .swm-product-card { border-radius: 26px; }
  .swm-cart { width: 100%; top: auto; height: min(90vh, 820px); border-radius: 30px 30px 0 0; transform: translateY(105%); right: 0; left: 0; border-right: 0; border-top: 1px solid var(--swm-border); }
  .swm-menu-root.is-cart-open .swm-cart { transform: translateY(0); }
  .swm-menu-root.has-cart .swm-mobile-bar { display: flex; }
  .swm-main { padding-bottom: 120px; }
  .swm-hero h1 { font-size: clamp(2.1rem, 13vw, 3.3rem); }
}

/* =============================
   SWM v1.2 Creative Premium UX
   ============================= */
.swm-v12 {
  --swm-glass: rgba(255,255,255,.76);
  --swm-soft-shadow: 0 18px 55px rgba(91, 21, 48, .12);
  --swm-glow: 0 0 0 1px rgba(255,255,255,.45), 0 26px 70px rgba(91,21,48,.18);
}
.swm-v12::before,
.swm-v12::after {
  content: '';
  position: absolute;
  border-radius: 999px;
  pointer-events: none;
  z-index: -2;
}
.swm-v12::before {
  width: 520px;
  height: 520px;
  right: -230px;
  top: 160px;
  background: radial-gradient(circle, rgba(244,185,74,.24), transparent 68%);
}
.swm-v12::after {
  width: 460px;
  height: 460px;
  left: -240px;
  top: 690px;
  background: radial-gradient(circle, rgba(241,90,36,.16), transparent 70%);
}
.swm-promo-strip {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  margin-bottom: 18px;
  padding: 10px 14px;
  border: 1px solid rgba(255,255,255,.52);
  border-radius: 999px;
  background: linear-gradient(135deg, rgba(91,21,48,.96), rgba(241,90,36,.88));
  color: #fff;
  box-shadow: 0 16px 40px rgba(91,21,48,.18);
  font-weight: 900;
}
.swm-promo-strip span { opacity: .92; }
.swm-promo-strip strong {
  padding: 7px 12px;
  border-radius: 999px;
  background: rgba(255,255,255,.16);
  white-space: nowrap;
}
.swm-hero-showcase {
  background:
    radial-gradient(circle at 58% 36%, rgba(255,255,255,.95), rgba(255,244,226,.82) 42%, rgba(244,185,74,.25) 70%),
    linear-gradient(145deg, rgba(91,21,48,.06), rgba(241,90,36,.09));
}
.swm-hero-showcase::after {
  content: '';
  position: absolute;
  inset: 22px;
  border-radius: 36px;
  border: 1px dashed rgba(91,21,48,.16);
  pointer-events: none;
}
.swm-floating-ticket {
  position: absolute;
  z-index: 2;
  min-width: 155px;
  padding: 13px 14px;
  border: 1px solid var(--swm-border);
  border-radius: 22px;
  background: rgba(255,255,255,.90);
  box-shadow: var(--swm-soft-shadow);
  backdrop-filter: blur(12px);
}
.swm-floating-ticket b { display: block; color: var(--swm-primary); font-size: .86rem; }
.swm-floating-ticket span { color: var(--swm-muted); font-size: .78rem; font-weight: 800; }
.swm-ticket-one { right: 26px; top: 42px; }
.swm-ticket-two { left: 30px; bottom: 132px; }
.swm-section-head-v12 {
  padding: 22px;
  border: 1px solid var(--swm-border);
  border-radius: 32px;
  background: linear-gradient(135deg, rgba(255,255,255,.92), rgba(255,244,226,.55));
  box-shadow: 0 14px 38px rgba(91,21,48,.07);
}
.swm-featured {
  margin: 24px 0 24px;
  padding: 20px;
  border-radius: 34px;
  background:
    linear-gradient(135deg, rgba(91,21,48,.96), rgba(91,21,48,.86)),
    radial-gradient(circle at top left, rgba(244,185,74,.35), transparent 48%);
  box-shadow: var(--swm-shadow);
  overflow: hidden;
  position: relative;
}
.swm-featured::before {
  content: '';
  position: absolute;
  inset: -80px auto auto -80px;
  width: 230px;
  height: 230px;
  border-radius: 50%;
  background: rgba(241,90,36,.22);
  filter: blur(2px);
}
.swm-featured-head {
  position: relative;
  z-index: 1;
  display: flex;
  justify-content: space-between;
  align-items: end;
  gap: 18px;
  color: #fff;
  margin-bottom: 16px;
}
.swm-featured-head span { color: var(--swm-accent); font-weight: 900; }
.swm-featured-head h3 { margin: 5px 0 6px; font-size: clamp(1.25rem, 3vw, 2rem); }
.swm-featured-head p { margin: 0; color: rgba(255,255,255,.78); line-height: 1.8; }
.swm-featured-head a {
  color: #fff;
  text-decoration: none;
  padding: 10px 14px;
  border-radius: 999px;
  background: rgba(255,255,255,.14);
  font-weight: 900;
  white-space: nowrap;
}
.swm-featured-rail {
  position: relative;
  z-index: 1;
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: minmax(260px, 320px);
  gap: 12px;
  overflow-x: auto;
  scrollbar-width: none;
  padding-bottom: 3px;
}
.swm-featured-rail::-webkit-scrollbar { display: none; }
.swm-feature-card {
  display: grid;
  grid-template-columns: 72px 1fr;
  gap: 12px;
  align-items: center;
  min-height: 124px;
  padding: 12px;
  border: 1px solid rgba(255,255,255,.18);
  border-radius: 26px;
  background: rgba(255,255,255,.12);
  backdrop-filter: blur(14px);
  color: #fff;
}
.swm-feature-media {
  width: 72px;
  height: 72px;
  display: grid;
  place-items: center;
  border-radius: 22px;
  background: rgba(255,255,255,.95);
  overflow: hidden;
}
.swm-feature-media img { width: 100%; height: 100%; object-fit: cover; }
.swm-feature-media span { font-size: 2.4rem; }
.swm-feature-card b { display: block; line-height: 1.5; }
.swm-feature-card small { color: rgba(255,255,255,.74); font-weight: 800; }
.swm-feature-actions {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
}
.swm-feature-actions button {
  border: 0;
  min-height: 38px;
  border-radius: 999px;
  font-weight: 900;
}
.swm-feature-actions button:first-child { background: var(--swm-accent); color: var(--swm-primary); }
.swm-feature-actions button:last-child { background: rgba(255,255,255,.14); color: #fff; }
.swm-smart-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  margin: 0 0 12px;
}
.swm-filter-chips {
  display: flex;
  gap: 8px;
  overflow-x: auto;
  scrollbar-width: none;
  padding: 2px;
}
.swm-filter-chips::-webkit-scrollbar { display: none; }
.swm-filter-chips button,
.swm-view-toggle {
  flex: 0 0 auto;
  min-height: 42px;
  border: 1px solid var(--swm-border);
  border-radius: 999px;
  background: #fff;
  color: var(--swm-primary);
  font-weight: 900;
  padding: 0 14px;
  box-shadow: 0 8px 20px rgba(91,21,48,.06);
}
.swm-filter-chips button.is-active,
.swm-view-toggle:hover {
  background: var(--swm-primary);
  color: #fff;
}
.swm-category-btn small {
  display: inline-grid;
  place-items: center;
  min-width: 24px;
  height: 24px;
  border-radius: 999px;
  background: var(--swm-cream);
  color: var(--swm-primary);
  font-size: .75rem;
}
.swm-category-btn.is-active small,
.swm-category-btn:hover small { background: rgba(255,255,255,.18); color: #fff; }
.swm-product-card {
  position: relative;
  transform-origin: center bottom;
}
.swm-product-card.is-highlighted {
  animation: swmHighlight .95s ease;
}
@keyframes swmHighlight {
  0%,100% { box-shadow: 0 16px 42px rgba(91,21,48,.08); }
  35% { box-shadow: 0 0 0 5px rgba(244,185,74,.62), var(--swm-shadow); }
}
.swm-fav-btn {
  position: absolute;
  top: 14px;
  left: 14px;
  z-index: 2;
  display: grid;
  place-items: center;
  width: 38px;
  height: 38px;
  border: 1px solid rgba(255,255,255,.55);
  border-radius: 50%;
  background: rgba(255,255,255,.88);
  color: var(--swm-primary);
  font-size: 1.25rem;
  box-shadow: 0 10px 22px rgba(91,21,48,.12);
  transition: .2s ease;
}
.swm-fav-btn.is-active {
  background: var(--swm-secondary);
  color: #fff;
  transform: scale(1.04);
}
.swm-category-label {
  display: inline-flex;
  margin-bottom: 4px;
  color: var(--swm-secondary);
  font-weight: 900;
}
.swm-card-mini-actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  margin: 8px 0 12px;
}
.swm-quick-btn {
  border: 1px solid var(--swm-border);
  border-radius: 999px;
  min-height: 34px;
  padding: 0 12px;
  color: var(--swm-primary);
  background: #fff;
  font-weight: 900;
}
.swm-card-mini-actions span {
  color: var(--swm-muted);
  font-size: .78rem;
  font-weight: 800;
}
.swm-card-options {
  transition: .25s ease;
}
.swm-v12.is-compact-mode .swm-card-options,
.swm-v12.is-compact-mode .swm-desc {
  display: none;
}
.swm-v12.is-compact-mode .swm-products-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}
.swm-v12.is-compact-mode .swm-product-media { height: 140px; }
.swm-v12.is-compact-mode .swm-product-card { border-radius: 24px; }
.swm-v12.is-compact-mode .swm-product-body { padding: 14px; }
.swm-upsell {
  margin: 0 0 12px;
  padding: 13px;
  border: 1px solid var(--swm-border);
  border-radius: 20px;
  background: #fff;
}
.swm-upsell > strong { display: block; color: var(--swm-primary); margin-bottom: 9px; }
.swm-upsell div { display: grid; gap: 8px; }
.swm-upsell button {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 8px;
  min-height: 38px;
  border: 0;
  border-radius: 14px;
  padding: 0 12px;
  background: var(--swm-cream);
  color: var(--swm-primary);
  font-weight: 900;
}
.swm-upsell small { color: var(--swm-muted); }
.swm-prep-row { color: var(--swm-primary); font-weight: 900; }
.swm-min-progress {
  display: grid !important;
  gap: 8px !important;
  padding: 10px 0;
  border-top: 1px solid var(--swm-border);
  border-bottom: 1px solid var(--swm-border);
}
.swm-min-progress[hidden] { display: none !important; }
.swm-min-progress span { color: var(--swm-primary); font-size: .86rem; font-weight: 900; }
.swm-min-progress i {
  display: block;
  height: 9px;
  border-radius: 999px;
  background: rgba(91,21,48,.12);
  overflow: hidden;
}
.swm-min-progress em {
  display: block;
  height: 100%;
  width: 0%;
  border-radius: inherit;
  background: linear-gradient(90deg, var(--swm-secondary), var(--swm-accent));
  transition: width .3s ease;
}
.swm-quick-view {
  position: fixed;
  inset: 0;
  z-index: 150;
  display: grid;
  place-items: center;
  padding: 20px;
  opacity: 0;
  pointer-events: none;
  transition: .24s ease;
}
.swm-v12.is-quick-open .swm-quick-view {
  opacity: 1;
  pointer-events: auto;
}
.swm-quick-view-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(20,10,14,.56);
  backdrop-filter: blur(10px);
}
.swm-quick-view-card {
  position: relative;
  width: min(880px, 100%);
  display: grid;
  grid-template-columns: .88fr 1.12fr;
  overflow: hidden;
  border-radius: 34px;
  background: #fffdf9;
  box-shadow: 0 30px 90px rgba(0,0,0,.32);
  transform: translateY(16px) scale(.98);
  transition: .26s ease;
}
.swm-v12.is-quick-open .swm-quick-view-card { transform: translateY(0) scale(1); }
.swm-quick-close { position: absolute; top: 14px; left: 14px; z-index: 2; }
.swm-quick-media {
  min-height: 360px;
  display: grid;
  place-items: center;
  background: radial-gradient(circle, var(--swm-cream), #fff 68%);
}
.swm-quick-media img { width: 100%; height: 100%; object-fit: cover; }
.swm-quick-media span { font-size: 7rem; filter: drop-shadow(0 20px 28px rgba(91,21,48,.25)); }
.swm-quick-body { padding: 34px; display: grid; align-content: center; gap: 14px; }
.swm-quick-body [data-swm-quick-badge] {
  display: inline-flex;
  justify-self: start;
  padding: 7px 12px;
  border-radius: 999px;
  background: var(--swm-cream);
  color: var(--swm-primary);
  font-weight: 900;
}
.swm-quick-body h3 { margin: 0; color: var(--swm-primary); font-size: clamp(1.6rem, 4vw, 2.7rem); }
.swm-quick-body p { margin: 0; color: var(--swm-muted); line-height: 1.9; }
.swm-quick-meta { display: grid; gap: 8px; }
.swm-quick-meta span { padding: 10px 12px; border-radius: 16px; background: #fff; border: 1px solid var(--swm-border); color: var(--swm-text); font-weight: 800; }
.swm-quick-actions { display: flex; gap: 10px; flex-wrap: wrap; margin-top: 5px; }

@media (max-width: 1180px) {
  .swm-v12.is-compact-mode .swm-products-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}
@media (max-width: 920px) {
  .swm-v12.is-compact-mode .swm-products-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .swm-quick-view-card { grid-template-columns: 1fr; max-height: 90vh; overflow-y: auto; }
  .swm-quick-media { min-height: 240px; }
}
@media (max-width: 720px) {
  .swm-promo-strip { border-radius: 22px; align-items: flex-start; flex-direction: column; }
  .swm-featured { margin-inline: -2px; padding: 16px; border-radius: 28px; }
  .swm-featured-head { align-items: start; flex-direction: column; }
  .swm-featured-rail { grid-auto-columns: minmax(240px, 82vw); }
  .swm-smart-row { align-items: stretch; flex-direction: column; }
  .swm-view-toggle { width: 100%; }
  .swm-ticket-one { right: 16px; top: 20px; }
  .swm-ticket-two { left: 16px; bottom: 116px; }
  .swm-floating-ticket { min-width: 132px; padding: 10px 12px; }
  .swm-v12.is-compact-mode .swm-products-grid { grid-template-columns: 1fr; }
  .swm-quick-view { padding: 10px; place-items: end center; }
  .swm-quick-view-card { border-radius: 28px 28px 0 0; width: calc(100% + 20px); }
  .swm-quick-body { padding: 24px; }
}
