*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}

:root{
  --cream-50:#FFF8F0;
  --cream-100:#FBEEDC;
  --cream-200:#F5E0C2;
  --caramel:#D4975A;
  --caramel-dark:#A66A2E;
  --strawberry:#E85A7A;
  --strawberry-light:#FDDCE4;
  --berry:#8B2050;
  --berry-dark:#5A1030;
  --cocoa:#3E2723;
  --mint:#1a9e8f;
  --mint-light:#3CC4B0;
  --pistachio:#C9D6A7;

  --bg:var(--cream-50);
  --surface:#ffffff;
  --text:#2A1B20;
  --muted:#8A6B75;
  --border:rgba(139,32,80,.10);
  --border-strong:rgba(139,32,80,.18);

  --radius:18px;
  --radius-lg:28px;
  --radius-pill:999px;

  --sh1:0 1px 3px rgba(139,32,80,.05),0 1px 2px rgba(139,32,80,.04);
  --sh2:0 4px 16px rgba(139,32,80,.08),0 2px 6px rgba(139,32,80,.04);
  --sh3:0 18px 40px rgba(139,32,80,.12),0 6px 14px rgba(139,32,80,.06);
  --sh4:0 32px 72px rgba(139,32,80,.18);

  --head:'Fraunces',Georgia,serif;
  --body:'Inter',system-ui,sans-serif;
  --mono:'JetBrains Mono',ui-monospace,monospace;

  /* backward-compat aliases */
  --teal:var(--strawberry);
  --teal-dark:var(--berry);
  --teal-deep:var(--berry);
  --teal-light:var(--strawberry-light);
  --teal-bg:var(--cream-50);
  --gold:var(--caramel);
  --gold-light:var(--cream-100);
}

body{
  font-family:var(--body);
  background:var(--bg);
  color:var(--text);
  min-height:100vh;
  display:flex;flex-direction:column;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
main{flex:1}

/* ─── SPRINKLE BACKGROUND ─── */
.bg-sprinkles{
  position:fixed;inset:0;z-index:-1;pointer-events:none;
  background-image:
    radial-gradient(circle at 15% 12%,var(--strawberry) 1.5px,transparent 2.5px),
    radial-gradient(circle at 85% 28%,var(--caramel) 1.2px,transparent 2.2px),
    radial-gradient(circle at 35% 65%,var(--mint-light) 1px,transparent 2px),
    radial-gradient(circle at 72% 82%,var(--berry) 1.3px,transparent 2.3px),
    radial-gradient(circle at 8% 90%,var(--caramel-dark) 1px,transparent 2px);
  background-size:320px 320px,290px 290px,400px 400px,350px 350px,260px 260px;
  opacity:.12;
}

/* ─── TOPBAR ─── */
.topbar{
  background:var(--cocoa);
  color:rgba(255,248,240,.75);
  text-align:center;
  font-size:12px;
  padding:7px 16px;
  letter-spacing:.4px;
  font-family:var(--mono);
}

/* ─── HEADER ─── */
header{
  background:rgba(255,248,240,.90);
  backdrop-filter:blur(20px) saturate(1.2);
  -webkit-backdrop-filter:blur(20px) saturate(1.2);
  border-bottom:1px solid var(--border);
  position:sticky;top:0;z-index:100;
  box-shadow:var(--sh2);
}
.nav-inner{
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 36px;gap:20px;flex-wrap:wrap;
  max-width:1440px;margin:0 auto;
}
.logo{display:flex;align-items:center;text-decoration:none}
.logo img{
  width:54px;height:54px;border-radius:50%;
  display:block;
  transition:transform .4s cubic-bezier(.34,1.56,.64,1);
  filter:drop-shadow(0 4px 10px rgba(61,196,176,.25));
}
.logo:hover img{transform:rotate(-8deg) scale(1.08)}

/* Search */
.search-wrap{flex:1;max-width:480px;position:relative}
.nav-search{
  display:flex;align-items:center;
  background:var(--surface);
  border:1.5px solid var(--border);
  border-radius:var(--radius-pill);
  padding:0 8px 0 20px;gap:10px;
  transition:all .25s;box-shadow:var(--sh1);
}
.nav-search:focus-within{
  border-color:var(--strawberry);
  box-shadow:0 0 0 4px rgba(232,90,122,.12),var(--sh2);
}
.nav-search input{
  border:none;background:transparent;
  padding:12px 0;font-size:14px;flex:1;outline:none;width:100%;
  font-family:inherit;color:var(--text);
}
.nav-search input::placeholder{color:var(--muted)}
.nav-search button{
  background:var(--berry);color:white;border:none;
  width:38px;height:38px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;transition:all .2s;flex-shrink:0;
}
.nav-search button:hover{background:var(--strawberry);transform:rotate(12deg)}
.search-suggestions{
  position:absolute;top:calc(100% + 8px);left:0;right:0;
  background:white;border:1.5px solid var(--border);
  border-radius:var(--radius);box-shadow:var(--sh3);
  z-index:200;display:none;overflow:hidden;
}
.search-suggestions.open{display:block}
.suggest-item{
  display:flex;align-items:center;gap:10px;
  padding:11px 18px;cursor:pointer;transition:background .15s;font-size:13.5px;
}
.suggest-item:hover{background:var(--cream-100)}
.suggest-name{flex:1;color:var(--text)}
.suggest-price{color:var(--berry);font-weight:700;white-space:nowrap;font-size:13px;font-family:var(--mono)}
.suggest-empty{padding:14px 18px;color:var(--muted);font-size:13px;text-align:center}

/* Nav buttons */
.nav-icons{display:flex;align-items:center;gap:4px}
.nav-actions{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.nav-btn{
  background:transparent;border:1.5px solid transparent;
  border-radius:var(--radius-pill);
  padding:9px 16px;font-size:13px;cursor:pointer;
  color:var(--text);display:flex;align-items:center;gap:7px;
  transition:all .22s;white-space:nowrap;font-weight:600;
  font-family:inherit;text-decoration:none;
}
.nav-btn:hover{background:var(--cream-100);color:var(--berry);transform:translateY(-1px)}
.nav-btn.accent{
  background:linear-gradient(135deg,var(--strawberry),var(--berry));
  color:white;border-color:transparent;
  box-shadow:0 6px 16px rgba(232,90,122,.35);
}
.nav-btn.accent:hover{transform:translateY(-2px);box-shadow:0 10px 24px rgba(232,90,122,.45)}
.nav-profile-avatar{
  width:26px;height:26px;border-radius:50%;
  background:linear-gradient(135deg,var(--berry),var(--berry-dark));
  color:white;font-size:11px;font-weight:800;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  font-family:var(--head);letter-spacing:0;
}
.nav-btn--active{background:var(--strawberry-light);color:var(--berry);border-color:var(--strawberry)}
.cart-count{
  background:var(--caramel);color:white;
  border-radius:50%;width:20px;height:20px;font-size:11px;
  display:flex;align-items:center;justify-content:center;
  font-weight:700;font-family:var(--mono);flex-shrink:0;
}
@keyframes badge-bump{0%{transform:scale(1)}40%{transform:scale(1.5)}100%{transform:scale(1)}}
.cart-count.bump{animation:badge-bump .35s ease}

/* ─── CATBAR ─── */
.catbar{
  border-bottom:1px solid var(--border);
  overflow-x:auto;scrollbar-width:none;
  background:transparent;
}
.catbar::-webkit-scrollbar{display:none}
.catbar-inner{
  display:flex;padding:0 36px;min-width:max-content;gap:2px;
  max-width:1440px;margin:0 auto;
}
.cat-link,.cat-dropdown-btn{
  padding:14px 16px;font-size:13px;color:var(--muted);
  border-bottom:2.5px solid transparent;white-space:nowrap;
  transition:all .22s;cursor:pointer;font-weight:600;
  background:none;border-left:none;border-right:none;border-top:none;
  font-family:inherit;display:flex;align-items:center;gap:6px;
  text-decoration:none;
}
.cat-link:hover,.cat-link.active,.cat-dropdown-btn:hover,.cat-dropdown-btn.active{
  color:var(--berry);border-bottom-color:var(--strawberry);
}
.cat-arrow{transition:transform .35s cubic-bezier(.4,0,.2,1);flex-shrink:0;margin-top:1px}
header.megamenu-open .cat-arrow{transform:rotate(180deg)}

/* ─── MEGAMENU ─── */
.megamenu{
  max-height:0;overflow:hidden;
  transition:max-height .4s cubic-bezier(.4,0,.2,1),opacity .3s ease;
  opacity:0;background:var(--surface);
  border-top:1px solid var(--border);box-shadow:var(--sh4);
  position:relative;z-index:400;
}
header.megamenu-open .megamenu{max-height:540px;opacity:1}
.megamenu-inner{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));
  gap:10px;padding:28px 36px;max-width:1440px;margin:0 auto;
}
.mega-item{
  display:flex;flex-direction:column;align-items:center;text-align:center;
  padding:18px 12px;border-radius:16px;
  background:var(--cream-50);border:1.5px solid var(--border);
  transition:all .25s;gap:8px;cursor:pointer;text-decoration:none;
}
.mega-item:hover,.mega-item.active{
  background:var(--strawberry-light);
  border-color:var(--strawberry);
  transform:translateY(-4px);box-shadow:var(--sh2);
}
.mega-icon{font-size:28px;line-height:1}
.mega-name{font-size:12.5px;font-weight:600;color:var(--text);line-height:1.3}

/* ─── BREADCRUMBS ─── */
.breadcrumbs{
  padding:22px 36px 0;max-width:1440px;margin:0 auto;
  display:flex;align-items:center;gap:8px;font-size:13px;flex-wrap:wrap;
}
.breadcrumbs a{color:var(--muted);transition:color .2s}
.breadcrumbs a:hover{color:var(--berry)}
.breadcrumbs .sep{color:var(--muted);opacity:.4}
.breadcrumbs .current{color:var(--cocoa);font-weight:600}

/* ─── SECTION HEADERS ─── */
.section{padding:56px 36px 24px;max-width:1440px;margin:0 auto;position:relative}
.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;flex-wrap:wrap;gap:12px}
.section-title{
  font-family:var(--head);font-size:clamp(28px,3.5vw,44px);
  font-weight:800;color:var(--cocoa);letter-spacing:-1.2px;line-height:1;
  font-variation-settings:"opsz" 144;
}
.section-label{
  display:inline-flex;align-items:center;gap:8px;
  font-size:11.5px;font-weight:700;letter-spacing:2px;
  text-transform:uppercase;color:var(--strawberry);
  margin-bottom:10px;
}
.section-label::before{content:'';width:18px;height:2px;background:var(--strawberry);display:inline-block;border-radius:2px}
.see-all{
  font-size:13px;color:var(--berry);cursor:pointer;
  border:none;background:none;font-weight:700;font-family:inherit;
  display:flex;align-items:center;gap:6px;
  padding:10px 0;transition:gap .25s;text-decoration:none;
}
.see-all:hover{gap:12px}

/* ─── PROMOS ─── */
.promos{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:14px;padding:28px 36px 8px;max-width:1440px;margin:0 auto;
}
.promo{
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--radius);padding:22px;
  display:flex;align-items:center;gap:16px;
  transition:all .35s cubic-bezier(.34,1.56,.64,1);
  box-shadow:var(--sh2);position:relative;overflow:hidden;
}
.promo::before{
  content:'';position:absolute;inset:auto auto -50% -50%;
  width:140px;height:140px;border-radius:50%;
  background:radial-gradient(circle,var(--strawberry-light),transparent 70%);
  opacity:0;transition:opacity .35s;
}
.promo:hover{transform:translateY(-6px);box-shadow:var(--sh3);border-color:var(--strawberry)}
.promo:hover::before{opacity:1}
.promo-icon{
  width:52px;height:52px;
  background:linear-gradient(135deg,var(--cream-100),var(--cream-200));
  border-radius:14px;display:flex;align-items:center;justify-content:center;
  color:var(--berry);flex-shrink:0;
  transition:transform .35s cubic-bezier(.34,1.56,.64,1);
}
.promo:hover .promo-icon{transform:rotate(-8deg) scale(1.1)}
.promo-title{font-size:14.5px;font-weight:700;color:var(--cocoa);font-family:var(--head)}
.promo-desc{font-size:12.5px;color:var(--muted);margin-top:3px;line-height:1.4}

/* ─── PRODUCT CARDS ─── */
.products-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(220px,1fr));
  gap:16px;padding:16px 36px 36px;
  max-width:1440px;margin:0 auto;
}
.product-card{
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--radius-lg);overflow:hidden;
  transition:all .35s cubic-bezier(.22,1,.36,1);
  display:flex;flex-direction:column;
  position:relative;box-shadow:var(--sh1);
}
.product-card:hover{transform:translateY(-6px);box-shadow:var(--sh3);border-color:var(--strawberry)}
.prod-img{
  aspect-ratio:1;
  background:linear-gradient(135deg,var(--cream-100),var(--cream-200));
  display:flex;align-items:center;justify-content:center;
  font-size:56px;position:relative;overflow:hidden;
}
.prod-img::after{
  content:'';position:absolute;inset:0;
  background:repeating-linear-gradient(-45deg,transparent 0 18px,rgba(139,32,80,.04) 18px 19px);
  pointer-events:none;
}
.prod-img img{
  width:100%;height:100%;object-fit:cover;
  position:absolute;inset:0;z-index:1;
  transition:transform .5s cubic-bezier(.4,0,.2,1);
}
.product-card:hover .prod-img img{transform:scale(1.06)}
.prod-badge{
  position:absolute;top:12px;left:12px;z-index:2;
  background:var(--cocoa);color:var(--cream-50);
  padding:5px 12px;border-radius:var(--radius-pill);
  font-size:10.5px;font-weight:700;letter-spacing:.8px;
  text-transform:uppercase;font-family:var(--mono);
}
.prod-badge.new{background:var(--mint)}
.prod-badge.sale{
  background:linear-gradient(100deg,var(--strawberry),var(--berry));
  animation:shimmerBg 2.5s infinite;background-size:200% 100%;
}
@keyframes shimmerBg{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}
.fav-btn{
  position:absolute;top:10px;right:10px;z-index:2;
  background:rgba(255,248,240,.95);backdrop-filter:blur(8px);
  border:none;border-radius:50%;width:36px;height:36px;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;color:var(--cocoa);
  transition:all .25s;box-shadow:var(--sh1);
}
.fav-btn:hover{transform:scale(1.1);color:var(--strawberry)}
.fav-btn.active{color:var(--strawberry);background:white}
.fav-btn.active svg{fill:var(--strawberry);stroke:var(--strawberry)}
.fav-btn svg{transition:all .2s}

.prod-body{padding:18px;flex:1;display:flex;flex-direction:column;gap:6px}
.prod-cat{font-size:11px;color:var(--muted);font-weight:600;letter-spacing:.8px;text-transform:uppercase}
.prod-name{
  font-family:var(--head);font-size:16px;color:var(--cocoa);
  line-height:1.3;font-weight:600;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
  min-height:42px;text-decoration:none;
}
.prod-name:hover{color:var(--berry)}
.prod-price{
  font-family:var(--head);font-size:22px;font-weight:800;
  color:var(--berry);letter-spacing:-.5px;
}
.prod-old-price{font-size:13px;color:var(--muted);text-decoration:line-through;font-family:var(--mono)}
.prod-unit{font-size:11px;color:var(--muted);font-family:var(--mono)}
.stock-pill{display:inline-flex;align-items:center;gap:4px;font-size:10.5px;font-weight:700;padding:3px 8px;border-radius:var(--radius-pill);margin-top:3px}
.stock-in{background:#E6F4EA;color:#2D6A4F}
.stock-low{background:#FFF3E0;color:#B45309}
.stock-out{background:#FEE2E2;color:#DC2626}
.qty-wrap{display:flex;align-items:center;gap:8px;margin-top:4px}
.qty-wrap label{font-size:11px;color:var(--muted);font-family:var(--mono)}
.qty-input{
  width:60px;border:1.5px solid var(--border);border-radius:10px;
  padding:6px 8px;font-size:13px;color:var(--cocoa);
  text-align:center;outline:none;font-family:var(--mono);font-weight:700;
  transition:border-color .2s;
}
.qty-input:focus{border-color:var(--strawberry)}

/* === Карточные элементы для весовых товаров (кг) === */
.qty-kg{
  display:flex;flex-direction:column;gap:6px;margin-top:4px;
}
.qty-kg .row{display:flex;align-items:center;gap:6px}
.qty-kg .row label{font-size:11px;color:var(--muted);font-family:var(--mono);white-space:nowrap}
.qty-kg .grams-input{
  flex:1;min-width:0;
  border:1.5px solid var(--border);border-radius:10px;
  padding:6px 8px;font-size:13px;color:var(--cocoa);
  text-align:center;outline:none;font-family:var(--mono);font-weight:700;
  transition:border-color .2s;
  appearance:textfield;-moz-appearance:textfield;
}
.qty-kg .grams-input::-webkit-inner-spin-button,
.qty-kg .grams-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}
.qty-kg .grams-input:focus{border-color:var(--strawberry)}
.qty-kg .grams-unit{font-size:11px;color:var(--muted);font-family:var(--mono);font-weight:700}
.qty-kg .presets{display:flex;gap:4px;flex-wrap:wrap}
.qty-kg .presets button{
  flex:1;min-width:0;
  padding:5px 4px;border-radius:10px;
  border:1.5px solid var(--border);background:#fff;cursor:pointer;
  font-family:inherit;font-size:11px;font-weight:700;color:var(--cocoa);
  transition:all .15s;
}
.qty-kg .presets button:hover,
.qty-kg .presets button:active{
  background:var(--cocoa);color:var(--cream-50);border-color:var(--cocoa);
}
@media (max-width:760px){
  .qty-kg .grams-input{font-size:12px;padding:5px 6px}
  .qty-kg .presets button{font-size:10.5px;padding:5px 2px}
  .qty-kg .row label{display:none}
}
.prod-add{
  margin-top:auto;background:var(--cocoa);color:var(--cream-50);
  border:none;border-radius:var(--radius-pill);
  padding:11px;font-size:13px;cursor:pointer;
  font-family:inherit;font-weight:700;letter-spacing:.4px;
  transition:all .3s cubic-bezier(.34,1.56,.64,1);
  display:flex;align-items:center;justify-content:center;gap:6px;
}
.prod-add:hover{background:var(--berry);transform:translateY(-2px);box-shadow:0 10px 22px rgba(139,32,80,.3)}
.prod-add.added{background:var(--berry)}
.prod-add:disabled{background:#eee;color:#aaa;cursor:not-allowed}

/* ─── PAGINATION ─── */
.pagination{display:flex;justify-content:center;align-items:center;gap:6px;padding:12px 36px 40px}
.page-btn{
  background:var(--surface);border:1.5px solid var(--border);
  border-radius:var(--radius-pill);padding:9px 18px;font-size:13px;
  cursor:pointer;color:var(--cocoa);transition:all .2s;
  text-decoration:none;font-weight:600;font-family:var(--mono);
  display:inline-flex;align-items:center;
}
.page-btn:hover{border-color:var(--strawberry);color:var(--berry)}
.page-btn.active{background:var(--cocoa);color:var(--cream-50);border-color:var(--cocoa)}
.page-btn.disabled{opacity:.4;pointer-events:none}

/* ─── FORM ─── */
.form-field{margin-bottom:16px}
.form-field label{font-size:11px;letter-spacing:1.2px;text-transform:uppercase;color:var(--muted);font-weight:700;display:block;margin-bottom:8px;font-family:var(--mono)}
.form-field input,.form-field textarea,.form-field select{
  width:100%;padding:12px 16px;border:1.5px solid var(--border);
  border-radius:14px;font-family:inherit;font-size:14px;
  background:var(--surface);outline:none;transition:all .2s;color:var(--cocoa);
}
.form-field input:focus,.form-field textarea:focus,.form-field select:focus{
  border-color:var(--strawberry);box-shadow:0 0 0 4px rgba(232,90,122,.12);
}

/* ─── BUTTONS ─── */
.btn-primary{
  background:var(--cocoa);color:var(--cream-50);
  border:none;border-radius:var(--radius-pill);
  padding:14px 28px;font-size:14px;font-weight:700;
  cursor:pointer;font-family:inherit;letter-spacing:.5px;
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  transition:all .3s cubic-bezier(.34,1.56,.64,1);
  box-shadow:0 10px 26px rgba(62,39,35,.28);text-decoration:none;
}
.btn-primary:hover{transform:translateY(-3px) scale(1.02);background:var(--berry);box-shadow:0 18px 40px rgba(139,32,80,.35)}
.btn-ghost{
  background:transparent;color:var(--cocoa);
  border:1.5px solid var(--border-strong);border-radius:var(--radius-pill);
  padding:12px 24px;font-size:13px;font-weight:700;
  cursor:pointer;font-family:inherit;display:inline-flex;align-items:center;gap:8px;
  transition:all .22s;text-decoration:none;
}
.btn-ghost:hover{border-color:var(--strawberry);color:var(--berry);background:var(--strawberry-light)}
/* hero buttons */
.btn-white{
  background:var(--cream-50);color:var(--berry);
  border:2px solid transparent;border-radius:var(--radius-pill);
  padding:14px 32px;font-size:14px;font-weight:700;cursor:pointer;
  transition:all .3s cubic-bezier(.34,1.56,.64,1);display:inline-flex;align-items:center;gap:10px;
  box-shadow:0 6px 20px rgba(62,39,35,.2);text-decoration:none;
}
.btn-white:hover{background:var(--cocoa);color:var(--cream-50);transform:translateY(-3px);box-shadow:0 14px 30px rgba(62,39,35,.3)}
.btn-outline-w{
  background:rgba(255,255,255,.18);color:white;
  border:2px solid rgba(255,255,255,.6);border-radius:var(--radius-pill);
  padding:13px 28px;font-size:14px;cursor:pointer;
  transition:all .2s;display:inline-flex;align-items:center;gap:10px;
  font-weight:600;backdrop-filter:blur(8px);text-decoration:none;
}
.btn-outline-w:hover{background:rgba(255,255,255,.28);border-color:white;transform:translateY(-2px)}

/* ─── CARDS / PANELS ─── */
.panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:32px;box-shadow:var(--sh1)}
.panel h2{font-family:var(--head);font-size:26px;font-weight:800;color:var(--cocoa);letter-spacing:-.6px;margin-bottom:20px}

/* ─── EMPTY STATE ─── */
.empty{text-align:center;padding:80px 20px;max-width:480px;margin:0 auto}
.empty .icon{font-size:80px;margin-bottom:20px;filter:drop-shadow(0 10px 24px rgba(139,32,80,.15))}
.empty h3{font-family:var(--head);font-size:32px;font-weight:800;color:var(--cocoa);margin-bottom:12px;letter-spacing:-.8px}
.empty p{font-size:15px;color:var(--muted);margin-bottom:24px;line-height:1.6}

/* ─── CHIPS ─── */
.chips{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:18px}
.chip{
  padding:8px 16px;border-radius:var(--radius-pill);font-size:13px;font-weight:600;
  border:1.5px solid var(--border-strong);background:var(--surface);color:var(--muted);
  white-space:nowrap;transition:all .22s;cursor:pointer;font-family:inherit;text-decoration:none;
}
.chip:hover,.chip.active{background:var(--cocoa);color:var(--cream-50);border-color:var(--cocoa)}
.chip.sale{color:var(--strawberry);border-color:var(--strawberry)}
.chip.sale.active,.chip.sale:hover{background:var(--strawberry);color:white}

/* ─── TOAST ─── */
.toast{
  position:fixed;bottom:24px;left:50%;
  transform:translateX(-50%) translateY(120px);
  background:var(--cocoa);color:var(--cream-50);
  padding:14px 24px;border-radius:var(--radius-pill);
  font-size:14px;font-weight:600;box-shadow:var(--sh3);
  z-index:999;transition:transform .4s cubic-bezier(.34,1.56,.64,1);
  white-space:nowrap;pointer-events:none;
}
.toast.show{transform:translateX(-50%) translateY(0)}

/* ─── CART OVERLAY ─── */
.cart-overlay{position:fixed;inset:0;background:rgba(62,39,35,.45);backdrop-filter:blur(4px);z-index:200;display:none}
.cart-overlay.open{display:block}

/* ─── CART SIDEBAR ─── */
.cart-sidebar{
  position:fixed;top:0;right:0;width:420px;max-width:100%;height:100%;
  background:var(--surface);z-index:201;
  transform:translateX(100%);
  transition:transform .3s cubic-bezier(.4,0,.2,1);
  display:flex;flex-direction:column;box-shadow:var(--sh4);
}
.cart-sidebar.open{transform:translateX(0)}
.cart-head{
  background:var(--cocoa);color:var(--cream-50);
  padding:20px 24px;display:flex;align-items:center;justify-content:space-between;
}
.cart-head h3{font-family:var(--head);font-size:20px;font-weight:700;display:flex;align-items:center;gap:8px}
.cart-close{
  background:rgba(255,255,255,.12);border:none;
  color:var(--cream-50);font-size:22px;cursor:pointer;
  line-height:1;width:36px;height:36px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;transition:background .2s;
}
.cart-close:hover{background:rgba(255,255,255,.25)}
.cart-body{flex:1;overflow-y:auto;padding:20px}
.cart-empty{text-align:center;color:var(--muted);padding:60px 20px;font-size:14px}
.cart-item{display:flex;gap:12px;padding:14px 0;border-bottom:1px dashed var(--border);align-items:center}
.cart-item-icon{
  font-size:22px;background:var(--cream-100);border-radius:12px;
  width:52px;height:52px;display:flex;align-items:center;justify-content:center;
  flex-shrink:0;overflow:hidden;
}
.cart-item-icon img{width:100%;height:100%;object-fit:cover}
.cart-item-info{flex:1;min-width:0}
.cart-item-name{font-size:12.5px;color:var(--cocoa);margin-bottom:3px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:600;font-family:var(--head)}
.cart-item-price{font-size:14px;font-weight:700;color:var(--berry);font-family:var(--head)}
.cart-item-controls{display:flex;align-items:center;gap:4px;flex-shrink:0}
.qty-btn{
  background:var(--cream-100);border:none;width:28px;height:28px;
  border-radius:50%;cursor:pointer;font-size:15px;color:var(--cocoa);
  display:flex;align-items:center;justify-content:center;
  transition:all .2s;font-weight:700;flex-shrink:0;
}
.qty-btn:hover{background:var(--cocoa);color:var(--cream-50)}
.qty-direct{
  width:40px;border:1.5px solid var(--border);border-radius:8px;
  padding:4px;text-align:center;font-size:13px;outline:none;
  font-family:var(--mono);font-weight:700;transition:border-color .2s;
}
.qty-direct:focus{border-color:var(--strawberry)}
.cart-del{background:none;border:none;color:var(--muted);cursor:pointer;font-size:18px;line-height:1;transition:color .2s;flex-shrink:0}
.cart-del:hover{color:var(--strawberry)}
.cart-foot{padding:20px 24px;border-top:1px solid var(--border)}
.cart-total{display:flex;justify-content:space-between;align-items:baseline;font-family:var(--head);font-size:20px;font-weight:800;color:var(--cocoa);margin-bottom:16px}
.cart-total .amt{color:var(--berry);font-size:24px}
.checkout-btn{
  background:var(--cocoa);color:var(--cream-50);border:none;
  border-radius:var(--radius-pill);padding:14px;font-size:14px;
  width:100%;cursor:pointer;font-weight:700;
  display:block;text-align:center;transition:all .25s;
  text-decoration:none;font-family:inherit;letter-spacing:.5px;
}
.checkout-btn:hover{background:var(--berry);transform:translateY(-2px)}
.wa-btn{
  background:linear-gradient(135deg,#25D366,#128C7E);color:white;
  border:none;border-radius:var(--radius-pill);padding:12px;font-size:13px;
  width:100%;cursor:pointer;margin-top:10px;
  display:flex;align-items:center;justify-content:center;gap:8px;
  font-weight:700;transition:all .2s;
}
.wa-btn:hover{transform:translateY(-2px)}

/* ─── FAVORITES SIDEBAR ─── */
.fav-sidebar{
  position:fixed;top:0;right:0;width:390px;max-width:100%;height:100%;
  background:var(--surface);z-index:201;
  transform:translateX(100%);
  transition:transform .3s cubic-bezier(.4,0,.2,1);
  display:flex;flex-direction:column;box-shadow:var(--sh4);
}
.fav-sidebar.open{transform:translateX(0)}

/* ─── MAP ─── */
.map-section{padding:28px 36px;max-width:1440px;margin:0 auto}
.map-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--sh2)}
.map-header{
  background:linear-gradient(135deg,var(--berry-dark),var(--berry));
  color:white;padding:20px 28px;
  display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;
}
.map-header h3{font-family:var(--head);font-size:17px;font-weight:700;display:flex;align-items:center;gap:8px}
.map-info{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));border-bottom:1px solid var(--border)}
.map-info-item{display:flex;align-items:flex-start;gap:12px;padding:20px 24px;border-right:1px solid var(--border)}
.map-info-item:last-child{border-right:none}
.map-info-icon{width:36px;height:36px;background:var(--cream-100);border-radius:10px;display:flex;align-items:center;justify-content:center;color:var(--berry);flex-shrink:0;margin-top:1px}
.map-info-label{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:1px;font-weight:600}
.map-info-val{font-size:14px;font-weight:600;color:var(--cocoa);margin-top:3px}
.map-iframe-wrap{height:380px}
.map-iframe-wrap iframe{width:100%;height:100%;border:none;display:block}
.map-open-btn{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(255,255,255,.18);color:white;
  border:1.5px solid rgba(255,255,255,.5);border-radius:var(--radius-pill);
  padding:9px 20px;font-size:13px;cursor:pointer;font-weight:600;
  transition:all .2s;backdrop-filter:blur(8px);text-decoration:none;
}
.map-open-btn:hover{background:rgba(255,255,255,.3);border-color:white}

/* ─── FOOTER ─── */
footer{
  background:var(--cocoa);
  color:rgba(255,248,240,.7);
  padding:48px 36px 24px;
  position:relative;overflow:hidden;
  margin-top:auto;
}
footer::before{
  content:'';position:absolute;top:-1px;left:0;right:0;height:50px;
  background:var(--bg);
  -webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1440 50' preserveAspectRatio='none'%3E%3Cpath d='M0 0 L0 30 Q 120 50 240 20 T 480 30 T 720 20 T 960 30 T 1200 20 T 1440 25 L1440 0 Z' fill='black'/%3E%3C/svg%3E");
  mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1440 50' preserveAspectRatio='none'%3E%3Cpath d='M0 0 L0 30 Q 120 50 240 20 T 480 30 T 720 20 T 960 30 T 1200 20 T 1440 25 L1440 0 Z' fill='black'/%3E%3C/svg%3E");
  -webkit-mask-size:100% 100%;mask-size:100% 100%;
  -webkit-mask-repeat:no-repeat;mask-repeat:no-repeat;
}
.footer-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));
  gap:32px;max-width:1440px;margin:0 auto;
  padding:40px 0 32px;border-bottom:1px solid rgba(255,255,255,.08);
}
.footer-col h4{
  font-family:var(--head);color:white;font-size:17px;font-weight:700;
  margin-bottom:16px;letter-spacing:-.3px;
  position:relative;padding-bottom:12px;
}
.footer-col h4::after{
  content:'';position:absolute;bottom:0;left:0;
  width:28px;height:2px;
  background:linear-gradient(90deg,var(--strawberry),var(--caramel));
  border-radius:2px;
}
.footer-col a,.footer-col p{
  display:block;font-size:13.5px;color:rgba(255,248,240,.55);
  margin-bottom:9px;transition:color .2s;text-decoration:none;
}
.footer-col a:hover{color:rgba(255,248,240,.95)}
.footer-bottom{
  max-width:1440px;margin:0 auto;padding-top:24px;
  text-align:center;font-size:12px;color:rgba(255,255,255,.3);
  font-family:var(--mono);letter-spacing:.5px;
}

/* ─── SCROLL REVEAL ─── */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .75s ease,transform .75s cubic-bezier(.22,1,.36,1)}
.reveal.in{opacity:1;transform:none}

/* ─── SCROLLBAR ─── */
::-webkit-scrollbar{width:6px;height:6px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:rgba(139,32,80,.2);border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:rgba(139,32,80,.4)}

/* ─── SKELETON ─── */
@keyframes shimmer{0%{background-position:-800px 0}100%{background-position:800px 0}}
.skeleton{background:linear-gradient(90deg,var(--cream-100) 25%,var(--cream-200) 50%,var(--cream-100) 75%);background-size:800px 100%;animation:shimmer 1.4s infinite linear;border-radius:6px}
.skel-card{background:white;border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;display:flex;flex-direction:column}
.skel-img{aspect-ratio:1;background:var(--cream-100)}
.skel-body{padding:14px;display:flex;flex-direction:column;gap:8px}

/* ─── MOBILE ─── */
@media(max-width:768px){
  .topbar{font-size:10.5px;padding:5px 12px;line-height:1.5;white-space:normal;word-break:break-word}
  .nav-inner{padding:9px 14px;gap:6px;align-items:center;flex-wrap:wrap}
  .logo{flex-shrink:0}
  .logo img{width:42px;height:42px}
  .nav-icons{display:none}
  .nav-actions{order:2;flex-basis:auto;margin-left:auto;gap:6px;flex-wrap:nowrap}
  .nav-actions .nav-btn:not(.accent):not(.nav-btn-about){display:none}
  .nav-actions .nav-btn.accent{padding:8px 14px;font-size:12.5px}
  .nav-actions .nav-btn.nav-btn-about{padding:8px 12px;font-size:12.5px}
  .nav-actions .nav-label{display:inline}
  .search-wrap{order:3;flex-basis:100%;max-width:100%}
  .nav-search input{font-size:16px}
  .catbar-inner{padding:0 12px;gap:0}
  .cat-link,.cat-dropdown-btn{padding:10px 12px;font-size:12px}
  .section{padding:28px 14px 14px}
  .section-title{font-size:clamp(20px,6vw,32px);letter-spacing:-.6px}
  .breadcrumbs{padding:10px 14px 0;font-size:12px;gap:5px}
  .promos{padding:14px;grid-template-columns:1fr 1fr;gap:10px}
  .promo{padding:14px 12px;gap:10px}
  .promo-icon{width:42px;height:42px;border-radius:12px}
  .promo-title{font-size:13px}
  .promo-desc{font-size:11px;margin-top:2px}
  .products-grid{grid-template-columns:repeat(2,1fr);padding:10px 14px 20px;gap:10px}
  .prod-body{padding:12px;gap:4px}
  .prod-name{font-size:14px;min-height:36px}
  .prod-price{font-size:18px}
  .prod-old-price{font-size:12px}
  .prod-unit{font-size:10px}
  .qty-wrap{gap:5px}
  .qty-input{width:48px;font-size:12px;padding:5px 6px}
  .prod-add{padding:10px 8px;font-size:12px}
  .pagination{padding:10px 14px 28px;gap:4px}
  .page-btn{padding:8px 14px;font-size:12px}
  .chips{gap:6px}
  .chip{padding:7px 12px;font-size:12px}
  .form-field input,.form-field textarea,.form-field select{font-size:16px}
  .cart-sidebar,.fav-sidebar{width:100%}
  .map-section{padding:12px}
  .map-card{border-radius:14px}
  .map-header{padding:14px 16px;flex-direction:column;align-items:flex-start;gap:8px}
  .map-header h3{font-size:14px}
  .map-header>div>p{font-size:12px;margin-top:2px}
  .map-open-btn{font-size:11.5px;padding:7px 14px;align-self:flex-start}
  .map-info{grid-template-columns:1fr 1fr}
  .map-info-item{padding:11px 12px;gap:8px;border-right:none;border-bottom:1px solid var(--border)}
  .map-info-icon{width:28px;height:28px;border-radius:8px;flex-shrink:0}
  .map-info-label{font-size:9px;letter-spacing:.5px}
  .map-info-val{font-size:12px;margin-top:2px;word-break:break-word;line-height:1.3}
  .map-iframe-wrap{height:200px}
  footer{padding:28px 14px 18px}
  .footer-grid{gap:16px;grid-template-columns:1fr 1fr}
  .footer-col h4{font-size:15px;margin-bottom:12px}
  .footer-col a,.footer-col p{font-size:12.5px;margin-bottom:7px}
  .megamenu-inner{padding:16px 14px;grid-template-columns:repeat(auto-fill,minmax(90px,1fr));gap:8px}
  .mega-item{padding:12px 8px;gap:6px}
  .mega-icon{font-size:22px}
  .mega-name{font-size:11px}
  .panel{padding:20px}
  .toast{font-size:13px;padding:12px 20px;white-space:normal;max-width:88vw;text-align:center;bottom:16px}
  .empty{padding:50px 16px}
  .empty h3{font-size:24px}
  .empty .icon{font-size:60px}
}
@media(max-width:480px){
  .promos{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .products-grid{gap:8px}
}
@media(max-width:360px){
  .products-grid{grid-template-columns:repeat(2,1fr);gap:6px;padding:8px 10px 16px}
  .prod-body{padding:9px;gap:3px}
  .prod-name{font-size:12.5px;min-height:32px}
  .prod-price{font-size:15px}
  .prod-add{font-size:11px;padding:8px 6px}
  .qty-wrap{display:none}
  .nav-inner{padding:8px 10px}
  .logo img{width:38px;height:38px}
  .map-info{grid-template-columns:1fr}
}

/* ─── MOBILE WHATSAPP BUTTON ─── */
@keyframes pulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.6);opacity:.4}}
.mobile-call-btn{
  display:none;
  position:fixed;
  right:16px;
  bottom:calc(76px + env(safe-area-inset-bottom,0));
  z-index:301;
  width:58px;height:58px;border-radius:50%;
  background:linear-gradient(135deg,#25D366 0%,#128C7E 100%);
  color:#fff;
  align-items:center;justify-content:center;
  box-shadow:0 6px 20px rgba(37,211,102,.45), 0 2px 6px rgba(18,140,126,.3);
  -webkit-tap-highlight-color:transparent;
  text-decoration:none;
  transition:transform .2s cubic-bezier(.34,1.56,.64,1), box-shadow .2s;
}
.mobile-call-btn:active{
  transform:scale(.92);
  box-shadow:0 3px 10px rgba(18,140,126,.5);
}
.mcb-ring{
  position:absolute;inset:0;border-radius:50%;
  background:#25D366;
  opacity:.35;
  animation:mcb-pulse 2.2s cubic-bezier(.4,0,.6,1) infinite;
  pointer-events:none;
}
@keyframes mcb-pulse{
  0%{transform:scale(1);opacity:.5}
  70%{transform:scale(1.55);opacity:0}
  100%{transform:scale(1.55);opacity:0}
}
@media(max-width:768px){
  .mobile-call-btn{display:flex}
}

/* ─── BOTTOM NAV ─── */
.bottom-nav{
  display:none;
  position:fixed;bottom:0;left:0;right:0;z-index:300;
  background:rgba(255,248,240,.95);
  backdrop-filter:blur(16px) saturate(1.4);
  -webkit-backdrop-filter:blur(16px) saturate(1.4);
  border-top:1px solid var(--border);
  box-shadow:0 -4px 20px rgba(139,32,80,.08);
  padding:0 4px env(safe-area-inset-bottom,0);
}
@media(max-width:768px){
  .bottom-nav{display:flex;align-items:stretch}
  body{padding-bottom:calc(64px + env(safe-area-inset-bottom,0))}
}
.bnav-item{
  flex:1;display:flex;flex-direction:column;align-items:center;
  justify-content:center;gap:3px;padding:8px 4px 10px;
  text-decoration:none;color:var(--muted);
  font-size:10px;font-weight:600;font-family:inherit;
  letter-spacing:.2px;transition:color .2s;
  -webkit-tap-highlight-color:transparent;
}
.bnav-item:hover,.bnav-active{color:var(--berry)}
.bnav-active svg{stroke:var(--berry)}
.bnav-center{justify-content:flex-end;padding-bottom:6px}
.bnav-center-btn{
  width:52px;height:52px;border-radius:50%;
  background:linear-gradient(135deg,var(--berry),var(--berry-dark));
  display:flex;align-items:center;justify-content:center;
  color:white;position:relative;margin-bottom:2px;
  box-shadow:0 6px 20px rgba(139,32,80,.4);
  transform:translateY(-10px);
  transition:transform .25s cubic-bezier(.34,1.56,.64,1);
}
.bnav-center:hover .bnav-center-btn,.bnav-center.bnav-active .bnav-center-btn{
  transform:translateY(-14px);
}
.bnav-badge{
  position:absolute;top:-4px;right:-4px;
  background:var(--caramel);color:white;
  border-radius:50%;min-width:18px;height:18px;
  font-size:10px;font-weight:700;font-family:var(--mono);
  display:flex;align-items:center;justify-content:center;
  padding:0 3px;border:2px solid var(--bg);
}
.bnav-badge:empty,.bnav-badge[data-zero="true"]{display:none}
