/* ============================================================
   INTELITE — Estilos principales
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Nunito:wght@400;500;600;700;800;900&family=Plus+Jakarta+Sans:wght@400;500;600;700;800&display=swap');

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --red:        #D42B2B;
  --red2:       #B52020;
  --red-light:  #FF4444;
  --red-pale:   #FFF0F0;
  --black:      #111111;
  --gray:       #6B6B6B;
  --gray-light: #F5F5F5;
  --border:     #E8E8E8;
  --white:      #FFFFFF;
  --shadow:     0 2px 12px rgba(0,0,0,0.08);
  --shadow-md:  0 8px 30px rgba(0,0,0,0.14);
  --radius:     12px;
}

html { scroll-behavior: smooth; }
body { font-family: 'Plus Jakarta Sans', sans-serif; background: #f9f9f9; color: var(--black); }

.scroll-reveal {
  opacity: 0;
  transform: translateY(42px) scale(.985);
  filter: blur(6px);
  transition:
    opacity .75s cubic-bezier(.22,1,.36,1),
    transform .75s cubic-bezier(.22,1,.36,1),
    filter .75s cubic-bezier(.22,1,.36,1);
  will-change: opacity, transform, filter;
}
.scroll-reveal.is-visible {
  opacity: 1;
  transform: translateY(0) scale(1);
  filter: blur(0);
}

@media (prefers-reduced-motion: reduce) {
  .scroll-reveal,
  .scroll-reveal.is-visible {
    opacity: 1;
    transform: none;
    filter: none;
    transition: none;
  }
}

/* ── BARRA DE PROGRESO GLOBAL ── */
#topLoader {
  position: fixed;
  top: 0; left: 0;
  height: 3px;
  width: 0%;
  background: var(--red);
  z-index: 9999;
  transition: width .3s ease, opacity .4s ease;
  border-radius: 0 3px 3px 0;
  box-shadow: 0 0 8px rgba(212,43,43,.55);
  pointer-events: none;
}

/* ── TOPBAR ── */
.topbar { background: var(--black); color: rgba(255,255,255,.85); font-size: .78rem; padding: 8px 0; text-align: center; }
.topbar span { color: #fff; font-weight: 600; }
.promo-carousel-store {
  background: #d42b2b;
  color: var(--white);
}
.promo-store-inner {
  max-width: 1400px;
  margin: 0 auto;
  padding: 0 40px;
  min-height: 44px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  align-items: center;
}
.promo-store-fixed {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  border-right: 1px solid rgba(255,255,255,.22);
  padding-right: 18px;
  text-align: center;
}
.promo-store-fixed strong {
  color: var(--white);
  font-size: .9rem;
  font-weight: 800;
}
.promo-store-fixed span {
  color: rgba(255,255,255,.82);
  font-size: .78rem;
}
.promo-store-rotating {
  position: relative;
  min-height: 24px;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
  padding-left: 18px;
}
.promo-store-rotating .promo-c-item {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* ── NAVBAR ── */
nav { position: sticky; top: 0; z-index: 200; background: var(--white); border-bottom: 1px solid var(--border); }
.nav-inner { max-width: 1400px; margin: 0 auto; min-height: 78px; display: flex; align-items: center; gap: 14px; padding: 0 40px; }
.nav-logo { font-family: 'Nunito', sans-serif; font-size: 1.6rem; font-weight: 800; color: var(--black); text-decoration: none; flex-shrink: 0; }
.nav-logo span { color: var(--red); }
.nav-right { display: flex; align-items: center; gap: 8px; flex-shrink: 0; margin-left: auto; }
.nav-search { display: flex; align-items: center; gap: 8px; background: var(--gray-light); border: 1px solid transparent; border-radius: 14px; padding: 12px 16px; transition: all .2s; width: 220px; min-width: 0; }
.nav-search-wide { flex: 1; max-width: 760px; }
.nav-search:focus-within { border-color: var(--red); background: var(--white); box-shadow: 0 0 0 3px rgba(212,43,43,.08); }
.nav-search input { background: none; border: none; outline: none; font-family: 'Plus Jakarta Sans', sans-serif; font-size: .875rem; width: 100%; color: var(--black); }
.nav-search input::placeholder { color: var(--gray); }
.cart-btn { position: relative; background: var(--red); color: var(--white); border: none; cursor: pointer; border-radius: 14px; padding: 12px 18px; font-family: 'Plus Jakarta Sans', sans-serif; font-size: .875rem; font-weight: 600; display: flex; align-items: center; gap: 8px; transition: all .2s; }
.cart-btn:hover { background: var(--red2); transform: translateY(-1px); box-shadow: 0 4px 14px rgba(212,43,43,.35); }
.cart-count { position: absolute; top: -7px; right: -7px; background: var(--red2); color: var(--white); border-radius: 50%; width: 20px; height: 20px; font-size: .65rem; font-weight: 700; display: flex; align-items: center; justify-content: center; border: 2px solid var(--white); }

/* ── HERO ── */

.hero { background: linear-gradient(135deg, var(--red2) 0%, #7a1010 60%, var(--red) 100%); padding: 60px 40px; position: relative; overflow: hidden; }
.hero::before { content: ''; position: absolute; inset: 0; background: url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='%23ffffff' fill-opacity='0.03'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/svg%3E"); }
.hero-inner { max-width: 1400px; margin: 0 auto; display: grid; grid-template-columns: 1fr 1fr; gap: 40px; align-items: center; position: relative; }
.hero-tag { display: inline-block; background: rgba(255,68,68,.2); border: 1px solid rgba(255,68,68,.4); color: #FF8888; font-size: .72rem; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; padding: 5px 12px; border-radius: 4px; margin-bottom: 16px; }
.hero h1 { font-family: 'Nunito', sans-serif; font-size: 1.6rem; font-weight: 700; color: var(--white); font-weight: 800; color: var(--white); line-height: 1.1; margin-bottom: 16px; }.hero h1 em { font-style: normal; color: var(--red-light); }
.hero p { color: rgba(255,255,255,.65); font-size: 1rem; line-height: 1.7; margin-bottom: 28px; max-width: 420px; }
.hero-actions { display: flex; gap: 12px; flex-wrap: wrap; }
.hero-actions .btn-primary { background: var(--red); color: var(--white); padding: 13px 28px; border-radius: 8px; font-weight: 600; font-size: .9rem; text-decoration: none; border: none; cursor: pointer; transition: all .2s; box-shadow: 0 4px 18px rgba(212,43,43,.4); font-family: 'Plus Jakarta Sans', sans-serif; }
.hero-actions .btn-primary:hover { background: var(--red-light); transform: translateY(-2px); }
.hero-actions .btn-ghost { background: transparent; color: var(--white); border: 1px solid rgba(255,255,255,.3); padding: 13px 28px; border-radius: 8px; font-weight: 500; font-size: .9rem; text-decoration: none; transition: all .2s; font-family: 'Plus Jakarta Sans', sans-serif; cursor: pointer; }
.hero-actions .btn-ghost:hover { background: rgba(255,255,255,.1); }
.hero-stats { display: flex; gap: 28px; margin-top: 32px; }
.hero-stat-val { font-family: 'Nunito', sans-serif; font-size: 1.6rem; font-weight: 700; color: var(--white); }
.hero-stat-label { font-size: .75rem; color: rgba(255,255,255,.5); }
.hero-right { display: flex; flex-direction: column; gap: 10px; }
.hero-card { background: rgba(255,255,255,.07); border: 1px solid rgba(255,255,255,.12); border-radius: 12px; padding: 14px 18px; display: flex; align-items: center; gap: 14px; backdrop-filter: blur(10px); transition: all .2s; cursor: pointer; }
.hero-card:hover { background: rgba(255,255,255,.13); transform: translateX(4px); }
.hero-card-ico { width: 44px; height: 44px; border-radius: 10px; background: linear-gradient(135deg, rgba(212,43,43,.4), rgba(212,43,43,.15)); display: flex; align-items: center; justify-content: center; font-size: 1.3rem; flex-shrink: 0; }
.hero-card-name { font-size: .875rem; font-weight: 600; color: var(--white); }
.hero-card-sub { font-size: .72rem; color: rgba(255,255,255,.5); }
.hero-card-price { font-size: .875rem; font-weight: 700; color: var(--red-light); margin-left: auto; flex-shrink: 0; }

/* ── PROMO BAR ── */
.promo-bar { background: var(--red-pale); border-top: 1px solid #ffd0d0; border-bottom: 1px solid #ffd0d0; padding: 10px 40px; }
.promo-bar-inner { max-width: 1400px; margin: 0 auto; display: flex; gap: 32px; overflow-x: auto; }
.promo-item { display: flex; align-items: center; gap: 7px; flex-shrink: 0; font-size: .8rem; }
.promo-item strong { color: var(--red); }

/* ── LAYOUT ── */
.shop-layout  { width: 100%; padding: 32px 0; }
.shop-inner   { max-width: 1400px; margin: 0 auto; padding: 0 40px; display: grid; grid-template-columns: minmax(260px, 260px) minmax(0, 1fr); gap: 28px; align-items: start; }
.shop-inner > main { min-width: 0; }

/* ── SIDEBAR ── */
.sidebar { position: sticky; top: 90px; }
.filter-panel { background: var(--white); border: 1px solid var(--border); border-radius: var(--radius); overflow: hidden; max-height: calc(100vh - 112px); overflow-y: auto; overscroll-behavior: contain; scrollbar-width: thin; }
.filter-panel::-webkit-scrollbar { width: 8px; }
.filter-panel::-webkit-scrollbar-thumb { background: #d7d7d7; border-radius: 999px; }
.filter-panel::-webkit-scrollbar-track { background: transparent; }
.filter-header { padding: 16px 20px; border-bottom: 1px solid var(--border); display: flex; justify-content: space-between; align-items: center; }
.filter-title { font-size: .9rem; font-weight: 700; }
.clear-btn { font-size: .75rem; color: var(--red); background: none; border: none; cursor: pointer; font-family: 'Plus Jakarta Sans', sans-serif; font-weight: 500; }
.clear-btn:hover { text-decoration: underline; }
.filter-section { padding: 16px 20px; border-bottom: 1px solid var(--border); }
.filter-section:last-child { border-bottom: none; }
.filter-section-title { width: 100%; background: none; border: none; font-size: .75rem; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; color: var(--gray); margin-bottom: 12px; display: flex; justify-content: space-between; align-items: center; cursor: pointer; user-select: none; text-align: left; padding: 0; }
.filter-section-title::after { content: '▼'; font-size: .55rem; transition: transform .2s; }
.filter-section-title.collapsed::after { transform: rotate(-90deg); }
.filter-body { display: flex; flex-direction: column; gap: 8px; }
.filter-chip-wrap { display: flex; flex-wrap: wrap; gap: 6px; }
.filter-chip { padding: 5px 11px; border-radius: 6px; border: 1px solid var(--border); font-size: .78rem; font-weight: 500; cursor: pointer; transition: all .15s; background: var(--white); color: var(--black); font-family: 'Plus Jakarta Sans', sans-serif; }
.filter-chip:hover { border-color: var(--red); color: var(--red); }
.cat-ver-mas { border-style: dashed; color: var(--gray); width: 100%; text-align: center; }
.filter-chip.active { background: var(--red); border-color: var(--red); color: var(--white); }
.chip-count { opacity: .6; font-size: .7rem; }
.filter-check { display: flex; align-items: center; gap: 8px; cursor: pointer; font-size: .85rem; }
.filter-check input { width: 15px; height: 15px; accent-color: var(--red); cursor: pointer; }
.filter-check:hover { color: var(--red); }
.price-inputs { display: flex; gap: 6px; align-items: center; margin-bottom: 8px; }
.price-input { flex: 1; min-width: 0; width: 0; border: 1px solid var(--border); border-radius: 6px; padding: 7px 6px; font-family: 'Plus Jakarta Sans', sans-serif; font-size: .82rem; outline: none; transition: border-color .2s; text-align: center; }
.price-input:focus { border-color: var(--red); }
.price-sep { font-size: .75rem; color: var(--gray); flex-shrink: 0; }

/* ── PRODUCTS AREA ── */
.products-toolbar { display: flex; align-items: center; justify-content: space-between; margin-bottom: 16px; padding-bottom: 16px; border-bottom: 1px solid var(--border); }
.products-count { font-size: .875rem; color: var(--gray); }
.products-count strong { color: var(--black); }
.toolbar-right { display: flex; align-items: center; gap: 10px; }
.sort-select { border: 1px solid var(--border); border-radius: 8px; padding: 8px 12px; font-family: 'Plus Jakarta Sans', sans-serif; font-size: .85rem; outline: none; color: var(--black); cursor: pointer; transition: border-color .2s; }
.sort-select:focus { border-color: var(--red); }
.view-btns { display: flex; gap: 4px; }
.view-btn { width: 32px; height: 32px; border: 1px solid var(--border); background: var(--white); border-radius: 6px; cursor: pointer; display: flex; align-items: center; justify-content: center; font-size: .85rem; transition: all .15s; }
.view-btn.active, .view-btn:hover { background: var(--red); border-color: var(--red); color: var(--white); }

/* Active filters */
.active-filters { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 12px; min-height: 4px; }
.af-tag { display: flex; align-items: center; gap: 5px; background: var(--red-pale); border: 1px solid #ffd0d0; color: var(--red); font-size: .75rem; font-weight: 500; padding: 4px 10px; border-radius: 6px; }
.af-remove { cursor: pointer; margin-left: 2px; }

/* Products grid */
.products-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 18px; min-width: 0; }
.products-grid.list-view { grid-template-columns: 1fr; }

/* ── PRODUCT CARD ── */
.p-card { background: var(--white); border: 1px solid var(--border); border-radius: var(--radius); overflow: hidden; transition: all .25s; position: relative; display: flex; flex-direction: column; }
.p-card:hover { box-shadow: var(--shadow-md); transform: translateY(-3px); border-color: transparent; }
.p-card-img-wrap { position: relative; background: var(--white); border-bottom: 1px solid var(--border); padding-top: 72%; overflow: hidden; }
.p-card-img { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; transition: transform .3s; }
.p-card:hover .p-card-img { transform: scale(1.05); }
.p-real-img { width: 100%; height: 100%; object-fit: contain; padding: 12px; }
.p-emoji { font-size: 3.5rem; }
.p-card-badges { position: absolute; top: 10px; left: 10px; display: flex; flex-direction: column; gap: 5px; }
.badge { font-size: .65rem; font-weight: 700; letter-spacing: .8px; text-transform: uppercase; padding: 3px 8px; border-radius: 4px; }
.badge-new  { background: #475569; color: var(--white); }
.badge-sale { background: var(--red);   color: var(--white); }
.badge-hot  { background: #FF8C00;      color: var(--white); }
.badge-out  { background: #999;         color: var(--white); }
.p-wish { position: absolute; top: 10px; right: 10px; width: 32px; height: 32px; border-radius: 50%; background: var(--white); border: 1px solid var(--border); display: flex; align-items: center; justify-content: center; cursor: pointer; font-size: .9rem; transition: all .2s; opacity: 0; box-shadow: var(--shadow); }
.p-card:hover .p-wish { opacity: 1; }
.p-wish:hover, .p-wish.active { background: var(--red-pale); border-color: var(--red); opacity: 1; }
.p-card-body { padding: 14px 16px 16px; display: flex; flex-direction: column; flex: 1; background: #f6f6f6; }
.p-brand { font-size: .7rem; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; color: var(--red); margin-bottom: 4px; }
.p-name { font-size: .875rem; font-weight: 600; line-height: 1.35; margin-bottom: 6px; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.p-prices { display: flex; align-items: center; gap: 7px; margin-bottom: 12px; flex-wrap: wrap; }
.p-price { font-size: 1.05rem; font-weight: 700; }
.p-old-price { font-size: .82rem; color: var(--gray); text-decoration: line-through; }
.p-discount { font-size: .7rem; font-weight: 700; color: var(--red); background: var(--red-pale); padding: 2px 6px; border-radius: 4px; }
.p-add-btn { width: 100%; background: var(--red); color: var(--white); border: none; cursor: pointer; border-radius: 8px; padding: 10px; font-family: 'Plus Jakarta Sans', sans-serif; font-size: .85rem; font-weight: 600; transition: all .2s; margin-top: auto; }
.p-add-btn:hover:not(:disabled) { background: var(--red2); }
.p-add-btn.added { background: #16a34a; }
.p-add-btn:disabled { background: #ccc; cursor: not-allowed; }

/* List view */
.products-grid.list-view .p-card { display: flex; flex-direction: row; }
.products-grid.list-view .p-card-img-wrap { padding-top: 0; width: 180px; flex-shrink: 0; }
.products-grid.list-view .p-card-img { position: static; height: 160px; }
.products-grid.list-view .p-card-body { flex: 1; display: flex; flex-direction: column; padding: 18px 22px; }
.products-grid.list-view .p-name { -webkit-line-clamp: unset; font-size: .95rem; margin-bottom: 10px; }
.products-grid.list-view .p-add-btn { width: auto; padding: 10px 22px; align-self: flex-start; margin-top: auto; }


/* Empty state */
.empty-state { grid-column: 1/-1; text-align: center; padding: 60px 20px; color: var(--gray); }
.empty-state .empty-ico { font-size: 3rem; margin-bottom: 12px; }
.empty-state h3 { font-size: 1rem; font-weight: 600; color: var(--black); margin-bottom: 6px; }
.empty-state p { font-size: .875rem; margin-bottom: 16px; }
.btn-clear { background: var(--red); color: var(--white); border: none; padding: 10px 24px; border-radius: 8px; cursor: pointer; font-family: 'Plus Jakarta Sans', sans-serif; font-weight: 600; }

/* ── PAGINATION ── */
.pagination { display: flex; gap: 6px; margin-top: 32px; justify-content: center; }
.page-btn { min-width: 38px; height: 38px; padding: 0 14px; border: 1px solid var(--border); border-radius: 8px; background: var(--white); cursor: pointer; font-family: 'Plus Jakarta Sans', sans-serif; font-size: .875rem; font-weight: 500; transition: all .15s; display: flex; align-items: center; justify-content: center; white-space: nowrap; }
.page-btn:hover:not(:disabled) { border-color: var(--red); color: var(--red); }
.page-btn.active { background: var(--red); border-color: var(--red); color: var(--white); font-weight: 700; }
.page-btn:disabled { opacity: .4; cursor: not-allowed; }
.page-ellipsis { align-self: center; color: var(--gray); padding: 0 4px; }

/* ── CART DRAWER ── */
.overlay { position: fixed; inset: 0; background: rgba(0,0,0,.45); z-index: 300; opacity: 0; pointer-events: none; transition: opacity .25s; }
.overlay.open { opacity: 1; pointer-events: all; }
.cart-drawer { position: fixed; top: 0; right: 0; bottom: 0; width: 420px; background: linear-gradient(180deg, #ffffff 0%, #fffaf9 100%); z-index: 400; transform: translateX(100%); transition: transform .3s cubic-bezier(.4,0,.2,1); display: flex; flex-direction: column; box-shadow: -18px 0 45px rgba(0,0,0,.16); border-left: 1px solid rgba(0,0,0,.05); }
.cart-drawer.open { transform: translateX(0); }
.cart-head { padding: 20px 24px; border-bottom: 1px solid var(--border); display: flex; align-items: center; justify-content: space-between; background: rgba(255,255,255,.85); backdrop-filter: blur(10px); }
.cart-head-left { display: flex; align-items: center; gap: 10px; }
.cart-head-title { font-family: 'Nunito', sans-serif; font-size: 1.2rem; font-weight: 700; }
.cart-head-count { background: var(--red); color: var(--white); border-radius: 50px; padding: 2px 10px; font-size: .72rem; font-weight: 700; }
.cart-close { width: 34px; height: 34px; border: 1px solid var(--border); border-radius: 8px; background: var(--white); cursor: pointer; font-size: 1rem; display: flex; align-items: center; justify-content: center; transition: all .15s; }
.cart-close:hover { background: var(--gray-light); }
.cart-items { flex: 1; overflow-y: auto; padding: 16px 24px; display: flex; flex-direction: column; gap: 12px; }
.cart-empty { flex: 1; display: flex; flex-direction: column; align-items: center; justify-content: center; color: var(--gray); text-align: center; gap: 10px; padding: 40px; }
.cart-empty .empty-ico { font-size: 3rem; opacity: .3; }
.cart-empty p { font-size: .875rem; }
.cart-item { display: flex; gap: 12px; padding: 14px; border: 1px solid var(--border); border-radius: 18px; background: var(--white); box-shadow: 0 8px 24px rgba(17,17,17,.05); align-items: center; }
.ci-img { width: 72px; height: 72px; background: var(--white); border: 1px solid var(--border); border-radius: 16px; display: flex; align-items: center; justify-content: center; font-size: 1.6rem; flex-shrink: 0; overflow: hidden; }
.ci-img img { width: 100%; height: 100%; object-fit: contain; padding: 4px; }
.ci-info { flex: 1; min-width: 0; }
.ci-name { font-size: .84rem; font-weight: 700; margin-bottom: 2px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; color: var(--black); }
.ci-variant { font-size: .72rem; color: var(--gray); margin-bottom: 8px; }
.ci-row { display: flex; align-items: center; justify-content: space-between; gap: 8px; }
.ci-qty { display: flex; align-items: center; gap: 6px; background: var(--gray-light); padding: 4px; border-radius: 50px; }
.qty-btn { width: 28px; height: 28px; border: 1px solid var(--border); border-radius: 50%; background: var(--white); cursor: pointer; font-size: .85rem; font-weight: 700; display: flex; align-items: center; justify-content: center; transition: all .15s; }
.qty-btn:hover { border-color: var(--red); color: var(--red); }
.qty-val { font-size: .85rem; font-weight: 600; min-width: 18px; text-align: center; }
.ci-price { font-size: .92rem; font-weight: 800; font-family: 'Nunito', sans-serif; color: var(--black); }
.ci-remove { width: 34px; height: 34px; background: var(--white); border: 1px solid var(--border); border-radius: 50%; cursor: pointer; color: var(--gray); font-size: .9rem; padding: 0; transition: all .15s; flex-shrink: 0; }
.ci-remove:hover { color: var(--red); border-color: #f1b8b8; background: var(--red-pale); }
.cart-foot { padding: 16px 24px; border-top: 1px solid var(--border); }
.cart-summary { margin-bottom: 14px; }
.cart-row { display: flex; justify-content: space-between; font-size: .85rem; padding: 5px 0; }
.cart-row.total { font-size: 1rem; font-weight: 700; border-top: 1px solid var(--border); margin-top: 6px; padding-top: 10px; }
.promo-row { display: flex; gap: 8px; margin-bottom: 12px; }
.promo-input { flex: 1; border: 1px solid var(--border); border-radius: 8px; padding: 9px 12px; font-family: 'Plus Jakarta Sans', sans-serif; font-size: .82rem; outline: none; transition: border-color .2s; }
.promo-input:focus { border-color: var(--red); }
.promo-apply { background: var(--red); color: var(--white); border: none; border-radius: 8px; padding: 9px 14px; font-family: 'Plus Jakarta Sans', sans-serif; font-size: .82rem; font-weight: 600; cursor: pointer; transition: background .2s; }
.promo-apply:hover { background: var(--red2); }
.checkout-btn { width: 100%; background: var(--red); color: var(--white); border: none; border-radius: 10px; padding: 14px; font-family: 'Plus Jakarta Sans', sans-serif; font-size: .95rem; font-weight: 700; cursor: pointer; transition: all .2s; }
.checkout-btn:hover { background: var(--red2); box-shadow: 0 4px 18px rgba(212,43,43,.35); }
.continue-btn { width: 100%; background: transparent; color: var(--black); border: 1px solid var(--border); border-radius: 10px; padding: 10px; font-family: 'Plus Jakarta Sans', sans-serif; font-size: .875rem; font-weight: 500; cursor: pointer; transition: all .2s; margin-top: 8px; }
.continue-btn:hover { border-color: var(--red); }
.secure-note { text-align: center; font-size: .72rem; color: var(--gray); margin-top: 10px; display: flex; align-items: center; justify-content: center; gap: 5px; }

.route-loader {
  position: fixed;
  inset: 0;
  background: rgba(255,255,255,.72);
  backdrop-filter: blur(6px);
  z-index: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
}
.route-loader-box {
  display: flex;
  align-items: center;
  gap: 12px;
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: 18px;
  padding: 18px 22px;
  box-shadow: 0 14px 40px rgba(17,17,17,.10);
  font-size: .9rem;
  font-weight: 700;
  color: var(--black);
}
.route-loader-spinner {
  width: 20px;
  height: 20px;
  border-radius: 50%;
  border: 2px solid #f1d0d0;
  border-top-color: var(--red);
  animation: route-spin .7s linear infinite;
}
@keyframes route-spin {
  to { transform: rotate(360deg); }
}

/* ── CHECKOUT MODAL ── */
.modal-overlay { position: fixed; inset: 0; background: rgba(0,0,0,.5); z-index: 500; display: none; align-items: center; justify-content: center; padding: 20px; }
.modal-overlay.open { display: flex; }
.modal { background: var(--white); border-radius: 16px; padding: 32px; width: 100%; max-width: 520px; max-height: 90vh; overflow-y: auto; box-shadow: 0 20px 60px rgba(0,0,0,.25); }
.modal h2 { font-family: 'Nunito', sans-serif; font-size: 1.4rem; margin-bottom: 24px; }
.modal-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.form-group { display: flex; flex-direction: column; gap: 5px; }
.form-group.full { grid-column: 1/-1; }
.form-group label { font-size: .78rem; font-weight: 600; color: var(--gray); text-transform: uppercase; letter-spacing: .8px; }
.form-group input { border: 1px solid var(--border); border-radius: 8px; padding: 10px 12px; font-family: 'Plus Jakarta Sans', sans-serif; font-size: .9rem; outline: none; transition: border-color .2s; }
.form-group input:focus { border-color: var(--red); }
.modal-actions { display: flex; gap: 10px; margin-top: 20px; }
.modal-submit { flex: 1; background: var(--red); color: var(--white); border: none; border-radius: 10px; padding: 14px; font-family: 'Plus Jakarta Sans', sans-serif; font-size: .95rem; font-weight: 700; cursor: pointer; transition: background .2s; }
.modal-submit:hover { background: var(--red2); }
.modal-submit:disabled { background: #ccc; cursor: not-allowed; }
.modal-cancel { background: none; border: 1px solid var(--border); border-radius: 10px; padding: 14px 20px; font-family: 'Plus Jakarta Sans', sans-serif; font-size: .875rem; cursor: pointer; }
.success-modal { text-align: center; }
.success-ico { font-size: 3rem; margin-bottom: 12px; }
.success-modal h2 { margin-bottom: 8px; }
.success-modal p { color: var(--gray); font-size: .9rem; margin-bottom: 20px; }
.order-id { background: var(--gray-light); border-radius: 8px; padding: 10px 16px; font-size: .875rem; margin-bottom: 20px; }
.order-id strong { color: var(--red); }

/* ── TOAST ── */
.toast { position: fixed; bottom: 24px; left: 50%; transform: translateX(-50%) translateY(80px); background: var(--red2); color: var(--white); padding: 12px 20px; border-radius: 10px; font-size: .875rem; font-weight: 500; z-index: 600; transition: transform .3s; white-space: nowrap; display: flex; align-items: center; gap: 8px; box-shadow: 0 4px 20px rgba(212,43,43,.35); }
.toast.show { transform: translateX(-50%) translateY(0); }

/* ── FOOTER ── */
footer { background: var(--gray-light); color: var(--gray); border-top: 1px solid var(--border); }
.footer-top { max-width: 1400px; margin: 0 auto; padding: 48px 40px 32px; display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 40px; }
.f-brand { font-family: 'Nunito', sans-serif; font-size: 1.4rem; font-weight: 700; color: var(--black); margin-bottom: 12px; }
.f-brand span { color: var(--red); }
.f-desc { font-size: .82rem; line-height: 1.7; margin-bottom: 16px; max-width: 260px; }
.f-socials { display: flex; gap: 8px; }
.f-soc { width: 36px; height: 36px; border: 1px solid var(--border); border-radius: 8px; display: flex; align-items: center; justify-content: center; transition: all .2s; cursor: pointer; text-decoration: none; flex-shrink: 0; }
.f-soc:hover { border-color: #bbb; transform: translateY(-2px); box-shadow: 0 4px 10px rgba(0,0,0,.1); }
.f-col h4 { font-size: .72rem; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; color: var(--gray); margin-bottom: 14px; }
.f-col ul { list-style: none; display: flex; flex-direction: column; gap: 8px; }
.f-col a { font-size: .82rem; color: var(--gray); text-decoration: none; transition: color .2s; }
.f-col a:hover { color: var(--red); }
.footer-bottom { border-top: 1px solid var(--border); padding: 16px 40px; max-width: 1400px; margin: 0 auto; display: flex; justify-content: space-between; align-items: center; font-size: .75rem; color: var(--gray); }
.footer-pay { display: flex; gap: 8px; align-items: center; }
.pay-badge { background: var(--white); border: 1px solid var(--border); border-radius: 6px; height: 28px; padding: 0 8px; display: inline-flex; align-items: center; justify-content: center; }

/* ── RESPONSIVE ── */
@media (max-width: 1100px) { .products-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 900px) {
  .shop-layout { padding: 16px 0; }
  .shop-inner  { grid-template-columns: 1fr; padding: 0 16px; }
  .hero { padding: 40px 20px; }
  .hero-inner { grid-template-columns: 1fr; }
  .hero-right { display: none; }
  .footer-top { grid-template-columns: 1fr 1fr; padding: 32px 20px; }
  .footer-bottom { padding: 14px 20px; flex-direction: column; gap: 8px; }
  .cart-drawer { width: 100%; }
  .promo-bar { padding: 10px 20px; }
  .promo-store-inner { grid-template-columns: 1fr; padding: 6px 16px; gap: 6px; }
  .promo-store-fixed {
    border-right: none;
    border-bottom: 1px solid rgba(255,255,255,.18);
    padding: 0 0 6px;
    flex-direction: column;
    gap: 2px;
  }
  .promo-store-rotating { padding-left: 0; min-height: 20px; }

  /* ── Navbar mobile ── */
  nav .nav-inner {
    flex-wrap: wrap;
    height: auto;
    padding: 10px 16px 12px;
    gap: 10px;
  }
  .nav-logo { flex: 1; order: 1; }
  .nav-logo img { height: 36px !important; }
  .nav-links { display: none; }
  .nav-catalog { order: 2; }
  .nav-catalog-btn { min-height: 42px; padding: 0 14px; }
  .nav-right { order: 3; flex-shrink: 0; margin-left: auto; }
  .cart-btn-label { display: none; }
  .cart-btn { padding: 9px 14px; gap: 6px; }

  /* Buscador baja a segunda fila */
  .nav-inner > .nav-search {
    order: 4;
    flex-basis: 100%;
    width: 100%;
    box-sizing: border-box;
  }

  /* Buscador del tienda-header visible en mobile — el del navbar está oculto */
  .tienda-header-search { max-width: 100%; padding: 12px 18px; }
  .tienda-search-input { font-size: .9rem; }

  /* Hero: ocultar botones prev/next en mobile */
  .slider-btn { display: none; }

  /* Sidebar/filtros colapsable en mobile */
  .sidebar {
    position: static;
    display: none;
    width: 100%;
    margin-bottom: 0;
  }
  .filter-panel {
    max-height: none;
    overflow-y: visible;
  }
  .sidebar.open {
    display: block;
    margin-bottom: 16px;
  }
}
@media (max-width: 600px) {
  .products-grid { grid-template-columns: repeat(2, 1fr); }
  .modal-grid { grid-template-columns: 1fr; }
}

/* ══════════════════════════════════════════
   HERO — Servicios
══════════════════════════════════════════ */
.hero-text { display: flex; flex-direction: column; justify-content: center; }
.hero-services { display: flex; flex-direction: column; gap: 10px; min-width: 320px; justify-content: center; }

.hero-srv-card {
  background: rgba(255,255,255,.07);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 14px;
  padding: 14px 18px;
  display: flex;
  align-items: center;
  gap: 14px;
  cursor: pointer;
  transition: all .2s;
  backdrop-filter: blur(10px);
}
.hero-srv-card:hover { background: rgba(255,255,255,.14); transform: translateX(5px); }
.hero-srv-bg {
  width: 46px; height: 46px;
  border-radius: 12px;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.hero-srv-thumb {
  width: 58px;
  height: 58px;
  border-radius: 14px;
  background: rgba(255,255,255,.12);
  border: 1px solid rgba(255,255,255,.16);
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  flex-shrink: 0;
}
.hero-srv-thumb img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  padding: 6px;
}
.hero-srv-ico { font-size: 1.4rem; }
.hero-srv-info { flex: 1; }
.hero-srv-name { font-size: .9rem; font-weight: 700; color: var(--white); }
.hero-srv-sub  { font-size: .72rem; color: rgba(255,255,255,.5); }
.hero-srv-arrow { color: rgba(255,255,255,.4); font-size: 1rem; transition: color .2s; }
.hero-srv-price { font-size: .9rem; font-weight: 800; color: var(--red-light); margin-left: auto; flex-shrink: 0; }
.hero-srv-card:hover .hero-srv-arrow { color: var(--red-light); }

/* ══════════════════════════════════════════
   SECCIÓN CATEGORÍAS VISUAL
══════════════════════════════════════════ */
.cat-showcase {
  background: #f8f8f8;
  padding: 64px 40px;
}
.cat-showcase-inner { max-width: 1400px; margin: 0 auto; }

.cat-showcase-header {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-bottom: 32px;
}
.cat-showcase-label {
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: 2.5px;
  text-transform: uppercase;
  color: var(--red);
  background: var(--red-pale);
  border: 1px solid #ffd0d0;
  padding: 4px 12px;
  border-radius: 50px;
}
.cat-showcase-title {
  font-family: 'Nunito', sans-serif;
  font-size: clamp(1.6rem, 3vw, 2.4rem);
  font-weight: 800;
  color: var(--black);
}

/* Grid: grande izquierda + columna 3 pequeñas derecha */
.cat-showcase-grid {
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: 14px;
  height: 540px;
}

.cat-col {
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.cat-flip-card {
  position: relative;
  display: block;
  width: 100%;
  height: 100%;
  border: none;
  padding: 0;
  background: transparent;
  cursor: pointer;
  perspective: 1400px;
  text-align: left;
}
.cat-flip-card-big {
  min-height: 540px;
}
.cat-flip-card-small {
  flex: 1;
  min-height: 0;
}
.cat-flip-inner {
  position: relative;
  width: 100%;
  height: 100%;
  transform-style: preserve-3d;
  transition: transform .7s cubic-bezier(.2,.8,.2,1);
}
.cat-flip-inner.is-flipped {
  transform: rotateY(180deg);
}
.cat-face {
  position: absolute;
  inset: 0;
  border-radius: 18px;
  overflow: hidden;
  backface-visibility: hidden;
  box-shadow: 0 14px 38px rgba(15, 23, 42, .08);
}
.cat-face-front {
  background: var(--gray-light);
}
.cat-face-back {
  transform: rotateY(180deg);
  background: linear-gradient(135deg, #151515 0%, #751818 100%);
  color: var(--white);
  border: 1px solid rgba(255,255,255,.08);
}
.cat-face-bg {
  position: absolute;
  inset: 0;
  background: var(--gray-light);
}
.cat-face-bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .45s;
}
.cat-small-bg-print img,
.cat-face-bg.cat-small-bg-print img {
  object-position: center center;
}
.cat-flip-card:hover .cat-face-bg img {
  transform: scale(1.05);
}
.cat-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(0,0,0,.82) 0%, rgba(0,0,0,.15) 55%, transparent 100%);
}
.cat-flip-card-small .cat-overlay {
  background: linear-gradient(to top, rgba(180,20,20,.85) 0%, rgba(0,0,0,.2) 100%);
}

.cat-face-content {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  padding: 24px 26px;
  display: flex;
  align-items: flex-end;
  gap: 12px;
}
.cat-face-content h3,
.cat-face-back-body h3 {
  font-family: 'Nunito', sans-serif;
  font-size: 1.5rem;
  font-weight: 800;
  color: var(--white);
  letter-spacing: .5px;
  flex: 1;
  line-height: 1.1;
}
.cat-flip-card-small .cat-face-content h3,
.cat-flip-card-small .cat-face-back-body h3 { font-size: 1.05rem; }
.cat-face-content p {
  font-size: .75rem;
  color: rgba(255,255,255,.65);
  margin-top: 4px;
  font-weight: 400;
}
.cat-face-back-body {
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: 26px;
}
.cat-face-back-kicker {
  display: inline-block;
  margin-bottom: 10px;
  font-size: .68rem;
  font-weight: 700;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: rgba(255,255,255,.55);
}
.cat-face-back-body p {
  font-size: .82rem;
  color: rgba(255,255,255,.74);
  line-height: 1.6;
  margin-top: 10px;
}
.cat-face-back-actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-top: 20px;
}
.cat-face-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 40px;
  padding: 0 16px;
  border-radius: 999px;
  background: var(--white);
  color: var(--black);
  font-size: .8rem;
  font-weight: 700;
  text-decoration: none;
}
.cat-face-hint {
  font-size: .72rem;
  color: rgba(255,255,255,.5);
}

.cat-arrow {
  width: 36px; height: 36px;
  border: 1.5px solid rgba(255,255,255,.4);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  color: var(--white);
  font-size: .9rem;
  flex-shrink: 0;
  transition: all .2s;
}
.cat-flip-card:hover .cat-arrow {
  background: var(--red);
  border-color: var(--red);
}

.cat-flip-card-big .cat-face-content { flex-direction: column; align-items: flex-start; }
.cat-flip-card-small .cat-face-content { flex-direction: row; align-items: flex-end; }
.cat-flip-card-small .cat-face-content > div { flex: 1; }

/* Apply price button */
.apply-price-btn {
  width: 100%;
  background: var(--red);
  color: var(--white);
  border: none;
  border-radius: 6px;
  padding: 8px;
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: .82rem;
  font-weight: 600;
  cursor: pointer;
  margin-bottom: 6px;
  transition: background .2s;
}
.apply-price-btn:hover { background: var(--red); }

/* Responsive cat showcase */
@media (max-width: 900px) {
  .cat-showcase { padding: 40px 20px; }
  .cat-showcase-grid { grid-template-columns: 1fr; height: auto; }
  .cat-flip-card-big { min-height: 280px; }
  .cat-col { flex-direction: column; gap: 10px; }
  .cat-flip-card-small { height: 120px; flex: none; }
  .cat-face-content { padding: 16px 18px; }
  .cat-flip-card-small .cat-face-content h3,
  .cat-flip-card-small .cat-face-back-body h3 { font-size: 1rem; }
  .cat-face-back-body { padding: 18px; }
  .hero-services { display: none; }
}

/* ══════════════════════════════════════════
   SECCIÓN SERVICIOS AMPLIADOS
══════════════════════════════════════════ */
.services-section {
  background: var(--white);
  padding: 72px 40px;
  border-top: 1px solid var(--border);
}
.services-inner { max-width: 1400px; margin: 0 auto; }

.services-header {
  text-align: center;
  margin-bottom: 52px;
}
.services-label {
  display: inline-block;
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: 2.5px;
  text-transform: uppercase;
  color: var(--red);
  background: var(--red-pale);
  border: 1px solid #ffd0d0;
  padding: 4px 14px;
  border-radius: 50px;
  margin-bottom: 12px;
}
.services-title {
  font-family: 'Nunito', sans-serif;
  font-size: clamp(1.8rem, 3vw, 2.6rem);
  font-weight: 800;
  color: var(--black);
  margin-bottom: 10px;
}
.services-sub {
  font-size: .95rem;
  color: var(--gray);
  max-width: 520px;
  margin: 0 auto;
  line-height: 1.6;
}

/* Grid de cards — 2 columnas, último ocupa ancho completo */
.services-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 24px;
}

/* Card individual */
.srv-card {
  border: 1px solid var(--border);
  border-radius: 18px;
  overflow: hidden;
  background: var(--white);
  transition: box-shadow .25s, transform .25s;
}
.srv-card:hover {
  box-shadow: 0 12px 40px rgba(0,0,0,.10);
  transform: translateY(-3px);
}

/* Card ancha (5to servicio) */
.srv-card-wide {
  grid-column: 1 / -1;
}

/* ── Collage de imágenes ── */
.srv-collage {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: 4px;
  height: 220px;
  background: var(--gray-light);
}
.srv-collage-wide {
  grid-template-columns: 1.4fr 1fr 1fr;
  height: 240px;
}
.srv-col-main {
  grid-row: 1 / 3;
  overflow: hidden;
}
.srv-col-main img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform .4s;
}
.srv-card:hover .srv-col-main img { transform: scale(1.05); }

.srv-col-side {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.srv-col-side img {
  flex: 1;
  width: 100%;
  object-fit: cover;
  transition: transform .4s;
}
.srv-card:hover .srv-col-side img { transform: scale(1.06); }

/* ── Cuerpo de la card ── */
.srv-body {
  padding: 24px 26px 26px;
}
.srv-icon {
  font-size: 2rem;
  margin-bottom: 10px;
}
.srv-name {
  font-family: 'Nunito', sans-serif;
  font-size: 1.2rem;
  font-weight: 700;
  color: var(--black);
  margin-bottom: 10px;
  line-height: 1.2;
}
.srv-desc {
  font-size: .875rem;
  color: var(--gray);
  line-height: 1.65;
  margin-bottom: 14px;
}

/* Lista de características */
.srv-features {
  list-style: none;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 5px 12px;
  margin-bottom: 20px;
}
.srv-features li {
  font-size: .8rem;
  color: var(--black);
  font-weight: 500;
}

/* Botón WhatsApp */
.srv-wa-btn {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  background: #25D366;
  color: var(--white);
  text-decoration: none;
  padding: 11px 20px;
  border-radius: 9px;
  font-size: .875rem;
  font-weight: 700;
  font-family: 'Plus Jakarta Sans', sans-serif;
  transition: all .2s;
  box-shadow: 0 3px 12px rgba(37,211,102,.3);
}
.srv-wa-btn:hover {
  background: #1da851;
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(37,211,102,.4);
}
.srv-wa-btn svg {
  width: 18px;
  height: 18px;
  flex-shrink: 0;
}

/* Responsive */
@media (max-width: 900px) {
  .services-section { padding: 48px 20px; }
  .services-grid { grid-template-columns: 1fr; }
  .srv-card-wide { grid-column: 1; }
  .srv-collage-wide { grid-template-columns: 1.4fr 1fr; height: 220px; }
  .srv-collage-wide .srv-col-side:last-child { display: none; }
  .srv-features { grid-template-columns: 1fr; }
}

/* ══════════════════════════════════════════
   AJUSTES TIPOGRÁFICOS — Nunito + Plus Jakarta Sans
══════════════════════════════════════════ */

/* Base */
body { font-family: 'Plus Jakarta Sans', sans-serif; letter-spacing: -0.01em; }

/* Títulos principales con Nunito — más redondo y amigable */
h1, h2, h3,
.hero h1,
.cat-showcase-title,
.services-title,
.cat-big-content h3,
.cat-small-content h3,
.srv-name,
.cart-head-title,
.modal h2 {
  font-family: 'Nunito', sans-serif;
  letter-spacing: -0.02em;
}

/* Hero title — más impacto */
.hero h1 {
  font-size: clamp(2.4rem, 4.5vw, 3.8rem);
  font-weight: 900;
  line-height: 1.05;
  letter-spacing: -0.03em;
  color: var(--white);
}
.hero h1 em {
  font-style: normal;
  font-weight: 900;
}

/* Logo — Nunito redondeado */
.nav-logo {
  font-family: 'Nunito', sans-serif;
  font-weight: 900;
  font-size: 1.65rem;
  letter-spacing: -0.04em;
}

/* Navbar links */
.nav-cats a {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-weight: 600;
  font-size: .82rem;
  letter-spacing: 0;
}

/* Sección categorías */
.cat-showcase-title {
  font-weight: 900;
  letter-spacing: -0.03em;
}
.cat-big-content h3 {
  font-size: 1.8rem;
  font-weight: 900;
  letter-spacing: -0.02em;
}
.cat-small-content h3 {
  font-size: 1.1rem;
  font-weight: 800;
  letter-spacing: -0.01em;
}

/* Tarjetas de productos */
.p-name {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-weight: 600;
  font-size: .9rem;
}
.p-price {
  font-family: 'Nunito', sans-serif;
  font-weight: 800;
  font-size: 1.1rem;
}
.p-brand {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-weight: 700;
  letter-spacing: 1px;
}

/* Botones — más redondeados */
.btn-primary, .btn-ghost,
.p-add-btn, .checkout-btn,
.cart-btn, .srv-wa-btn,
.modal-submit, .filter-chip {
  border-radius: 50px !important;
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-weight: 700;
  letter-spacing: 0;
}

/* Badges redondeados */
.badge, .pay-badge, .hero-tag,
.cat-showcase-label, .services-label {
  border-radius: 50px;
  font-family: 'Plus Jakarta Sans', sans-serif;
}

/* Sidebar títulos */
.filter-title {
  font-family: 'Nunito', sans-serif;
  font-weight: 800;
  font-size: 1rem;
}
.filter-section-title {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-weight: 700;
}

/* Stats del hero */
.hero-stat-val {
  font-family: 'Nunito', sans-serif;
  font-weight: 900;
  font-size: 1.8rem;
  letter-spacing: -0.03em;
}
.hero-stat-label {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-weight: 500;
}

/* Footer */
.f-brand {
  font-family: 'Nunito', sans-serif;
  font-weight: 900;
  letter-spacing: -0.03em;
}
.f-col h4 {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-weight: 700;
}

/* Promo bar */
.promo-item {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-weight: 500;
}

/* Botón agregar al carrito */
.p-add-btn {
  font-size: .82rem;
  font-weight: 700;
}

/* Hero tarjetas */
.hero-srv-name {
  font-family: 'Nunito', sans-serif;
  font-weight: 800;
  font-size: .95rem;
}
.hero-srv-sub {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-weight: 500;
}

/* ══════════════════════════════════════════
   NAVBAR DROPDOWNS
══════════════════════════════════════════ */
.nav-catalog { position: relative; flex-shrink: 0; padding-bottom: 16px; margin-bottom: -16px; }
.nav-catalog-btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  min-height: 48px;
  padding: 0 18px;
  border: 1px solid #f0ddd7;
  border-radius: 14px;
  background: linear-gradient(180deg, #fffaf8 0%, #fff3ef 100%);
  color: var(--black);
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: .92rem;
  font-weight: 700;
  cursor: pointer;
  transition: all .2s;
}
.nav-catalog-btn:hover,
.nav-catalog.open .nav-catalog-btn {
  border-color: #e8c5bb;
  box-shadow: 0 10px 24px rgba(212,43,43,.12);
}
.nav-catalog-ico {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border-radius: 10px;
  background: rgba(212,43,43,.08);
  color: var(--red);
  font-size: 1rem;
}
.dd-arrow { font-size: .6rem; opacity: .6; transition: transform .2s; }
.nav-catalog:hover .dd-arrow,
.nav-catalog.open .dd-arrow { transform: rotate(180deg); }

.dropdown {
  position: absolute;
  top: calc(100% + 2px);
  left: 0;
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: 24px;
  min-width: 260px;
  padding: 10px;
  box-shadow: 0 20px 50px rgba(15, 23, 42, .14);
  opacity: 0;
  pointer-events: none;
  transform: translateY(8px);
  transition: all .2s cubic-bezier(.4,0,.2,1);
  z-index: 500;
}
.nav-catalog:hover .dropdown,
.nav-catalog.open .dropdown {
  opacity: 1;
  pointer-events: all;
  transform: translateY(0);
}
.catalog-menu {
  width: min(840px, calc(100vw - 120px));
  padding: 14px;
}
.catalog-menu-grid {
  display: grid;
  grid-template-columns: minmax(270px, 300px) minmax(0, 1fr);
  gap: 0;
}
.catalog-main-col,
.catalog-sub-col {
  padding: 6px 14px 10px;
}
.catalog-sub-col {
  border-left: 1px solid var(--border);
}
.dd-header {
  font-size: .72rem;
  font-weight: 800;
  letter-spacing: 1.2px;
  text-transform: uppercase;
  color: var(--gray);
  padding: 8px 10px 10px;
  margin-bottom: 6px;
}
.catalog-main-link {
  display: flex;
  align-items: center;
  gap: 12px;
  width: 100%;
  padding: 12px;
  border: none;
  border-radius: 14px;
  background: transparent;
  text-align: left;
  cursor: pointer;
  text-decoration: none;
  transition: all .15s;
  color: var(--black) !important;
  font-family: 'Plus Jakarta Sans', sans-serif;
}
.catalog-main-link:hover,
.catalog-main-link.active {
  background: #fff3f0;
}
.catalog-main-link-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 42px;
  height: 42px;
  border-radius: 14px;
  background: #fff7f4;
  border: 1px solid #f4dfd8;
  font-size: 1.15rem;
  flex-shrink: 0;
}
.catalog-main-link-copy {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.catalog-main-link-copy strong {
  font-size: .92rem;
  font-weight: 700;
}
.catalog-main-link-copy small {
  font-size: .76rem;
  color: var(--gray);
}
.catalog-sub-head {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 8px 10px 16px;
}
.catalog-sub-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 48px;
  height: 48px;
  border-radius: 16px;
  background: linear-gradient(180deg, #fff7f4 0%, #fff0eb 100%);
  border: 1px solid #f2ddd7;
  font-size: 1.25rem;
}
.catalog-sub-title {
  font-size: 1.05rem;
  font-weight: 800;
  color: var(--black);
  padding: 0 10px;
}
.catalog-sub-links {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}
.catalog-sub-link {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  font-size: .92rem;
  font-weight: 500;
  color: var(--black) !important;
  padding: 10px 12px;
  border-radius: 12px;
  transition: all .15s;
  text-decoration: none;
}
.catalog-sub-link::after {
  content: '›';
  font-size: 1rem;
  color: rgba(17, 24, 39, .4);
  transition: transform .15s ease, color .15s ease;
}
.catalog-sub-link:hover {
  background: #fff3f0;
  color: var(--red) !important;
}
.catalog-sub-link:hover::after {
  transform: translateX(2px);
  color: var(--red);
}
.catalog-sub-link.is-placeholder {
  opacity: 1;
}
.catalog-view-all {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin: 18px 10px 0;
  min-height: 42px;
  padding: 0 18px;
  border-radius: 999px;
  background: var(--red);
  color: var(--white) !important;
  font-size: .84rem;
  font-weight: 700;
  text-decoration: none;
}
.catalog-view-all.is-placeholder {
  background: #d1d5db;
  color: #374151 !important;
}


/* ══════════════════════════════════════════
   HERO SLIDER
══════════════════════════════════════════ */
.hero-slider {
  position: relative;
  overflow: hidden;
  height: 560px;
}
.slide {
  position: absolute;
  inset: 0;
  opacity: 0;
  transition: opacity .7s ease;
  pointer-events: none;
}
.slide-active {
  opacity: 1;
  pointer-events: all;
}
.slide-bg {
  position: absolute;
  inset: 0;
}
/* Video de fondo en el hero */
.slide-bg-video video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}
.slide-video-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(17,17,17,.72) 0%, rgba(42,10,10,.60) 60%, rgba(212,43,43,.45) 100%);
}
.slide-inner {
  position: relative;
  max-width: 1400px;
  margin: 0 auto;
  height: 100%;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 40px;
  align-items: stretch;
  padding: 0 40px;
}

/* Slide promo layout */
.slide-promo {
  grid-template-columns: 1fr auto;
  align-items: center;
}
.promo-slide-tag {
  display: inline-block;
  background: rgba(255,255,255,.15);
  border: 1px solid rgba(255,255,255,.3);
  color: rgba(255,255,255,.9);
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  padding: 5px 14px;
  border-radius: 50px;
  margin-bottom: 16px;
}
.promo-slide-title {
  font-family: 'Nunito', sans-serif;
  font-size: clamp(2.2rem, 4vw, 3.4rem);
  font-weight: 900;
  color: var(--white);
  line-height: 1.05;
  letter-spacing: -0.03em;
  margin-bottom: 16px;
}
.promo-slide-title em { font-style: normal; color: #a78bfa; }
.promo-slide-desc {
  color: rgba(255,255,255,.65);
  font-size: .95rem;
  line-height: 1.65;
  margin-bottom: 28px;
  max-width: 440px;
}

/* Badge 31 años */
.years-badge {
  width: 200px;
  height: 200px;
  background: linear-gradient(135deg, var(--red), #ff6b6b);
  border-radius: 50%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  box-shadow: 0 20px 60px rgba(212,43,43,.5);
  animation: float 3s ease-in-out infinite;
}
@keyframes float {
  0%, 100% { transform: translateY(0); }
  50%       { transform: translateY(-12px); }
}
.years-num {
  font-family: 'Nunito', sans-serif;
  font-size: 4.5rem;
  font-weight: 900;
  color: var(--white);
  line-height: 1;
  letter-spacing: -0.04em;
}
.years-text {
  font-size: .8rem;
  font-weight: 700;
  color: rgba(255,255,255,.85);
  text-align: center;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  line-height: 1.4;
}

/* Slider controls */
.slider-btn {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 46px;
  height: 46px;
  border-radius: 50%;
  background: rgba(255,255,255,.15);
  border: 1px solid rgba(255,255,255,.25);
  color: var(--white);
  font-size: 1.4rem;
  cursor: pointer;
  z-index: 10;
  transition: all .2s;
  display: flex;
  align-items: center;
  justify-content: center;
  backdrop-filter: blur(8px);
}
.slider-btn:hover { background: rgba(255,255,255,.28); }
.slider-prev { left: 20px; }
.slider-next { right: 20px; }

.slider-dots {
  position: absolute;
  bottom: 20px;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  gap: 8px;
  z-index: 10;
}
.dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: rgba(255,255,255,.35);
  border: none;
  cursor: pointer;
  transition: all .25s;
  padding: 0;
}
.dot-active {
  background: var(--white);
  width: 24px;
  border-radius: 4px;
}

/* ══════════════════════════════════════════
   PROMO BAR CENTRADA
══════════════════════════════════════════ */
.promo-bar { text-align: center; }
.promo-bar-inner {
  justify-content: center;
  gap: 0;
  flex-wrap: wrap;
}
.promo-divider {
  width: 1px;
  background: #ffd0d0;
  margin: 0 20px;
  flex-shrink: 0;
}

/* ══════════════════════════════════════════
   SECCIÓN SERVICIOS TÉCNICOS
══════════════════════════════════════════ */
.servicios-section {
  background: #f8f8f8;
  padding: 72px 40px;
}
.servicios-inner { max-width: 1400px; margin: 0 auto; }
.servicios-header { text-align: center; margin-bottom: 52px; }
.servicios-header .cat-showcase-label { background: var(--red-pale); border-color: #ffd0d0; color: var(--red); }
.servicios-header .cat-showcase-title { color: var(--black); }
.servicios-sub {
  font-size: .95rem;
  color: var(--gray);
  max-width: 520px;
  margin: 12px auto 0;
  line-height: 1.65;
}

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

.srv2-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: 18px;
  padding: 26px;
  transition: all .25s;
}
.srv2-card:hover {
  border-color: var(--red);
  background: var(--red-pale);
  transform: translateY(-3px);
  box-shadow: 0 12px 40px rgba(212,43,43,.12);
}
.srv2-card-wide { grid-column: 1 / -1; }

.srv2-head {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 18px;
  padding-bottom: 16px;
  border-bottom: 1px solid var(--border);
}
.srv2-ico { font-size: 2.2rem; flex-shrink: 0; }
.srv2-title {
  font-family: 'Nunito', sans-serif;
  font-size: 1.15rem;
  font-weight: 800;
  color: var(--black);
  margin-bottom: 2px;
}
.srv2-sub { font-size: .78rem; color: var(--gray); font-weight: 500; }

.srv2-list {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-bottom: 22px;
}
.srv2-list-wide {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px 24px;
}
.srv2-list li {
  font-size: .85rem;
  color: var(--black);
  padding-left: 16px;
  position: relative;
  line-height: 1.5;
}
.srv2-list li::before {
  content: '→';
  position: absolute;
  left: 0;
  color: var(--red);
  font-size: .75rem;
  font-weight: 700;
}
.srv2-list li em { color: var(--gray); font-style: italic; font-size: .78rem; }

.srv2-wa {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: #25D366;
  color: var(--white);
  text-decoration: none;
  padding: 10px 18px;
  border-radius: 50px;
  font-size: .82rem;
  font-weight: 700;
  font-family: 'Plus Jakarta Sans', sans-serif;
  transition: all .2s;
  box-shadow: 0 3px 14px rgba(37,211,102,.3);
}
.srv2-wa:hover {
  background: #1da851;
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(37,211,102,.4);
}

/* Responsive */
@media (max-width: 900px) {
  .hero-slider { height: auto; min-height: 500px; }
  .slide-inner { grid-template-columns: 1fr; padding: 40px 20px; height: auto; }
  .slide-promo { grid-template-columns: 1fr; }
  .hero-services, .promo-slide-badge { display: none; }
  .servicios-section { padding: 48px 20px; }
  .servicios-grid { grid-template-columns: 1fr; }
  .srv2-card-wide { grid-column: 1; }
  .srv2-list-wide { grid-template-columns: 1fr; }
  .dropdown { min-width: 220px; }
  .catalog-menu { width: min(92vw, 520px); left: 0; }
  .catalog-menu-grid { grid-template-columns: 1fr; }
  .catalog-sub-col {
    border-left: none;
    border-top: 1px solid var(--border);
  }
  .catalog-sub-links { grid-template-columns: 1fr; }
  .promo-divider { display: none; }
  .promo-bar-inner { gap: 16px; }

  /* Slides hero: contenido centrado verticalmente */
  .slide-inner:not(.slide-product) {
    display: flex;
    flex-direction: column;
    justify-content: center;
    height: 100%;
    padding: 32px 20px;
  }
  .hero-actions { margin-top: 24px; }
}

/* ══════════════════════════════════════════
   SERVICIOS — TABS (nuevo diseño)
══════════════════════════════════════════ */
.srv-tabs-wrap {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  margin-bottom: 20px;
  padding-bottom: 4px;
}
.srv-tabs {
  display: flex;
  gap: 8px;
  min-width: max-content;
}
.srv-tab {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  background: var(--white);
  border: 1.5px solid var(--border);
  border-radius: 50px;
  padding: 10px 22px;
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: .875rem;
  font-weight: 600;
  color: var(--gray);
  cursor: pointer;
  transition: all .2s;
  white-space: nowrap;
}
.srv-tab:hover {
  border-color: var(--red);
  color: var(--red);
  background: var(--red-pale);
}
.srv-tab.active {
  background: var(--red);
  border-color: var(--red);
  color: var(--white);
}

/* Panels */
.srv-panels { margin-bottom: 24px; }
.srv-panel {
  display: none;
  background: var(--white);
  border: 1.5px solid var(--border);
  border-radius: 20px;
  overflow: hidden;
}
.srv-panel.active {
  display: grid;
  grid-template-columns: 260px 1fr;
}

/* Left info column */
.srv-panel-left {
  background: var(--red-pale);
  border-right: 1.5px solid #ffd0d0;
  padding: 36px 28px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.srv-panel-ico-big { font-size: 3.2rem; }
.srv-panel-title {
  font-family: 'Nunito', sans-serif;
  font-size: 1.4rem;
  font-weight: 900;
  color: var(--black);
  letter-spacing: -0.02em;
  line-height: 1.15;
}
.srv-panel-desc {
  font-size: .875rem;
  color: var(--gray);
  line-height: 1.65;
}
.srv-panel-badge {
  display: inline-flex;
  align-self: flex-start;
  background: var(--red);
  color: var(--white);
  font-size: .72rem;
  font-weight: 700;
  padding: 4px 12px;
  border-radius: 50px;
  margin-top: 4px;
}

/* Right features column */
.srv-panel-right {
  padding: 36px 32px;
  display: flex;
  align-items: center;
}
.srv-panel-list {
  list-style: none;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px 32px;
  width: 100%;
}
.srv-panel-list li {
  font-size: .9rem;
  color: var(--black);
  font-weight: 500;
  padding-left: 20px;
  position: relative;
  line-height: 1.5;
}
.srv-panel-list li::before {
  content: '→';
  position: absolute;
  left: 0;
  color: var(--red);
  font-weight: 700;
  font-size: .8rem;
}
.srv-panel-list li em {
  color: var(--gray);
  font-style: italic;
  font-size: .82rem;
}

/* CTA bar — único botón WhatsApp */
.srv-cta-bar {
  background: var(--white);
  border: 1.5px solid var(--border);
  border-radius: 16px;
  padding: 22px 28px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
}
.srv-cta-text {
  display: flex;
  flex-direction: column;
  gap: 3px;
}
.srv-cta-text strong {
  font-family: 'Nunito', sans-serif;
  font-size: 1.1rem;
  font-weight: 800;
  color: var(--black);
}
.srv-cta-text span {
  font-size: .85rem;
  color: var(--gray);
}
.srv-wa-main {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  background: #25D366;
  color: var(--white);
  text-decoration: none;
  padding: 13px 28px;
  border-radius: 50px;
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: .9rem;
  font-weight: 700;
  white-space: nowrap;
  flex-shrink: 0;
  transition: all .2s;
  box-shadow: 0 4px 16px rgba(37,211,102,.3);
  margin-top: auto;
  align-self: flex-start;
}
.srv-wa-main:hover {
  background: #1da851;
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(37,211,102,.4);
}

/* Responsive tabs */
@media (max-width: 900px) {
  .srv-panel.active { grid-template-columns: 1fr; }
  .srv-panel-left { border-right: none; border-bottom: 1.5px solid #ffd0d0; padding: 24px; }
  .srv-panel-right { padding: 24px; }
  .srv-panel-list { grid-template-columns: 1fr; }
  .srv-cta-bar { flex-direction: column; align-items: flex-start; }
  .srv-wa-main { width: 100%; justify-content: center; }
}

/* Contenido expandible móvil — oculto en desktop */
.srv-acc-mob-body { display: none; }

/* En desktop: el item activo en srvAccList se oculta (ya está en el panel izquierdo) */
#srvAccList .srv-acc-compact.srv-active { display: none; }

@media (max-width: 900px) {
  /* Ocultar panel izquierdo expandido; mostrar lista completa como accordion */
  #srvAccMain { display: none; }
  #srvAccList {
    display: flex;
    flex-direction: column;
    gap: 10px;
    width: 100%;
  }

  /* Cards en mobile: mantener imagen de fondo con altura fija para el header */
  #srvAccList .srv-acc-compact {
    display: flex;
    flex-direction: column;
    position: relative;
    border-radius: 14px;
    overflow: hidden;
    cursor: pointer;
    transition: border-color .2s, box-shadow .2s;
    height: auto;
    min-height: 90px;
    padding: 0;
    border: none;
    background-size: cover;
    background-position: center;
  }
  #srvAccList .srv-acc-compact.srv-active {
    display: flex; /* sobreescribir el display:none de desktop */
    box-shadow: 0 4px 18px rgba(212,43,43,.20);
  }

  /* Overlay oscuro cubre el card completo incluido el body expandido */
  #srvAccList .srv-acc-compact-overlay {
    display: block;
    position: absolute;
    inset: 0;
    background: rgba(0,0,0,.72);
    z-index: 0;
  }

  /* Header visible del card — texto blanco sobre imagen */
  #srvAccList .srv-acc-compact-info {
    display: flex;
    flex-direction: column;
    gap: 2px;
    padding: 18px 18px 18px 18px;
    flex: 1;
    position: relative;
    z-index: 1;
  }
  #srvAccList .srv-acc-compact-name {
    font-family: 'Nunito', sans-serif;
    font-weight: 800;
    font-size: 1rem;
    color: var(--white);
  }
  #srvAccList .srv-acc-compact-sub {
    font-size: .72rem;
    color: rgba(255,255,255,.75);
  }

  /* Flecha: rota al abrir */
  #srvAccList .srv-acc-compact-arr {
    position: absolute;
    right: 18px;
    top: 18px;
    color: rgba(255,255,255,.8);
    font-size: 1.1rem;
    transition: transform .32s cubic-bezier(.4,0,.2,1), color .2s;
  }
  #srvAccList .srv-acc-compact.srv-active .srv-acc-compact-arr {
    transform: rotate(90deg);
    color: var(--white);
  }

  /* Cuerpo expandible — transparente para que se vea la imagen de fondo */
  .srv-acc-mob-body {
    display: block;
    max-height: 0;
    overflow: hidden;
    transition: max-height .38s cubic-bezier(.4,0,.2,1);
    position: relative;
    z-index: 2;
  }
  #srvAccList .srv-acc-compact.srv-active .srv-acc-mob-body {
    max-height: 600px;
  }

  .srv-mob-desc {
    font-size: .875rem;
    color: rgba(255,255,255,.85);
    line-height: 1.6;
    padding: 0 18px 10px;
  }
  .srv-mob-items {
    list-style: none;
    padding: 0 18px 14px;
    display: flex;
    flex-direction: column;
    gap: 6px;
  }
  .srv-mob-items li {
    font-size: .85rem;
    color: rgba(255,255,255,.9);
    padding-left: 16px;
    position: relative;
  }
  .srv-mob-items li::before {
    content: '→';
    position: absolute;
    left: 0;
    color: #ff6b6b;
    font-size: .75rem;
  }
  .srv-acc-mob-body .srv-wa-main {
    margin: 0 18px 18px;
    width: calc(100% - 36px);
    justify-content: center;
  }
}

/* ══════════════════════════════════════════
   AUTOCOMPLETAR BUSCADOR TIENDA
══════════════════════════════════════════ */
.search-suggestions {
  display: none;
  position: absolute;
  top: calc(100% + 8px);
  left: 0;
  right: 0;
  background: var(--white);
  border: 1.5px solid var(--border);
  border-radius: 14px;
  box-shadow: var(--shadow-md);
  overflow: hidden;
  z-index: 999;
}
.suggest-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 14px;
  cursor: pointer;
  transition: background .15s;
}
.suggest-item:hover { background: var(--gray-light); }
.suggest-img {
  width: 40px;
  height: 40px;
  object-fit: contain;
  border-radius: 8px;
  border: 1px solid var(--border);
  flex-shrink: 0;
}
.suggest-img-placeholder {
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.3rem;
  flex-shrink: 0;
}
.suggest-name {
  flex: 1;
  font-size: .88rem;
  font-weight: 600;
  color: var(--black);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.suggest-price {
  font-family: 'Nunito', sans-serif;
  font-weight: 800;
  font-size: .88rem;
  color: var(--red);
  flex-shrink: 0;
}

/* ══════════════════════════════════════════
   PRODUCTOS DESTACADOS — Landing
══════════════════════════════════════════ */
.featured-section {
  background: #f4f4f4;
  padding: 72px 40px;
}
.featured-inner { max-width: 1400px; margin: 0 auto; }

.featured-header {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  margin-bottom: 36px;
}
.featured-ver-mas {
  font-size: .88rem;
  font-weight: 700;
  color: var(--red);
  text-decoration: none;
  display: flex;
  align-items: center;
  gap: 6px;
  white-space: nowrap;
  transition: gap .2s;
}
.featured-ver-mas:hover { gap: 10px; }

.featured-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
  margin-bottom: 36px;
}

.featured-cta { width: 100%; display: flex; justify-content: center; align-items: center; text-align: center; margin: 0 auto; }
.featured-cta > * { margin-left: auto; margin-right: auto; }
.btn-featured-cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  background: var(--red);
  color: var(--white);
  text-decoration: none;
  padding: 11px 22px;
  border-radius: 12px;
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: .86rem;
  font-weight: 700;
  transition: all .2s;
  border: 1px solid var(--red);
  min-width: 0;
  max-width: 100%;
  margin-left: auto;
  margin-right: auto;
}
.btn-featured-cta:hover {
  background: var(--red2);
  border-color: var(--red2);
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(212,43,43,.3);
}
@media (min-width: 900px) {
  .btn-featured-cta { max-width: 33.33vw; }
}

/* Skeleton loaders */
.skeleton { pointer-events: none; }
.skeleton-img {
  width: 100%; height: 200px;
  background: linear-gradient(90deg, #e0e0e0 25%, #f0f0f0 50%, #e0e0e0 75%);
  background-size: 200% 100%;
  animation: shimmer 1.4s infinite;
  border-radius: 12px 12px 0 0;
}
.skeleton-line {
  height: 12px;
  background: linear-gradient(90deg, #e0e0e0 25%, #f0f0f0 50%, #e0e0e0 75%);
  background-size: 200% 100%;
  animation: shimmer 1.4s infinite;
  border-radius: 6px;
  margin-bottom: 10px;
}
.skeleton-line.short  { width: 40%; }
.skeleton-line.medium { width: 60%; }
.skeleton-btn {
  height: 36px;
  background: linear-gradient(90deg, #e0e0e0 25%, #f0f0f0 50%, #e0e0e0 75%);
  background-size: 200% 100%;
  animation: shimmer 1.4s infinite;
  border-radius: 50px;
  margin-top: 8px;
}
@keyframes shimmer {
  0%   { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}

/* ══════════════════════════════════════════
   TIENDA.HTML — Header y breadcrumb
══════════════════════════════════════════ */
.tienda-header { display: none; }
.tienda-breadcrumb {
  font-size: .82rem;
  color: rgba(255,255,255,.5);
  display: flex;
  align-items: center;
  gap: 8px;
}
.tienda-breadcrumb a {
  color: rgba(255,255,255,.6);
  text-decoration: none;
  transition: color .2s;
}
.tienda-breadcrumb a:hover { color: var(--red-light); }
.tienda-breadcrumb span { color: rgba(255,255,255,.3); }

/* Navbar link especial tienda */
.nav-tienda-link {
  background: var(--red) !important;
  color: var(--white) !important;
  border-radius: 50px;
  padding: 6px 16px !important;
  font-weight: 700 !important;
  transition: all .2s !important;
}
.nav-tienda-link:hover {
  background: #b91c1c !important;
  transform: translateY(-1px);
}

/* Responsive featured */
@media (max-width: 900px) {
  .featured-section { padding: 48px 20px; }
  .featured-grid { grid-template-columns: repeat(2, 1fr); }
  .featured-header { flex-direction: column; align-items: flex-start; gap: 12px; }
  .tienda-header { display: none; }
}
@media (max-width: 500px) {
  .featured-grid { grid-template-columns: 1fr; }
}

/* ══════════════════════════════════════════
   TRUST / BENEFICIOS (estilo Molvu)
══════════════════════════════════════════ */
.trust-section {
  background: var(--white);
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  padding: 0 40px;
}
.trust-inner {
  max-width: 1400px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(5, 1fr);
}
.trust-item {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 24px 20px;
  border-right: 1px solid var(--border);
  transition: background .2s;
}
.trust-item:last-child { border-right: none; }
.trust-item:hover { background: var(--red-pale); }
.trust-ico {
  font-size: 1.7rem;
  flex-shrink: 0;
  line-height: 1;
}
.trust-title {
  display: block;
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: .875rem;
  font-weight: 700;
  color: var(--black);
  margin-bottom: 3px;
}
.trust-sub {
  display: block;
  font-size: .75rem;
  color: var(--gray);
  font-weight: 400;
}

@media (max-width: 900px) {
  .trust-section { padding: 0 20px; }
  .trust-inner { grid-template-columns: repeat(2, 1fr); }
  .trust-item { border-right: none; border-bottom: 1px solid var(--border); padding: 18px 12px; }
  .trust-item:nth-child(odd) { border-right: 1px solid var(--border); }
  .trust-item:last-child { border-bottom: none; grid-column: 1 / -1; }
}

/* ══════════════════════════════════════════
   TESTIMONIOS
══════════════════════════════════════════ */
.testimonios-section {
  background: var(--gray-light);
  padding: 72px 40px;
  border-top: 1px solid var(--border);
}
.testimonios-inner { max-width: 1400px; margin: 0 auto; }
.testimonios-header {
  text-align: center;
  margin-bottom: 40px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
}
.testimonios-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}
.testi-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: 18px;
  padding: 28px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  transition: all .25s;
}
.testi-card:hover {
  border-color: var(--red);
  box-shadow: 0 8px 30px rgba(212,43,43,.08);
  transform: translateY(-3px);
}
.testi-stars {
  color: #FFB800;
  font-size: 1rem;
  letter-spacing: 2px;
}
.testi-text {
  font-size: .9rem;
  color: var(--black);
  line-height: 1.75;
  font-style: italic;
  flex: 1;
}
.testi-author {
  display: flex;
  align-items: center;
  gap: 12px;
  padding-top: 14px;
  border-top: 1px solid var(--border);
}
.testi-avatar {
  width: 42px;
  height: 42px;
  border-radius: 50%;
  background: var(--red);
  color: var(--white);
  font-family: 'Nunito', sans-serif;
  font-size: .82rem;
  font-weight: 800;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.testi-name {
  display: block;
  font-size: .875rem;
  font-weight: 700;
  color: var(--black);
}
.testi-role {
  display: block;
  font-size: .72rem;
  color: var(--gray);
}

@media (max-width: 900px) {
  .testimonios-section { padding: 48px 20px; }
  .testimonios-grid { grid-template-columns: 1fr; }
}

/* ── Mobile filter toggle ── */
.mobile-filter-toggle { display: none; }
@media (max-width: 900px) {
  .mobile-filter-toggle {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    margin: 12px 16px 0;
    padding: 11px 20px;
    background: var(--white);
    border: 1.5px solid var(--border);
    border-radius: 50px;
    font-family: 'Plus Jakarta Sans', sans-serif;
    font-size: .88rem;
    font-weight: 700;
    color: var(--black);
    cursor: pointer;
    width: calc(100% - 32px);
    transition: background .2s, border-color .2s;
  }
  .mobile-filter-toggle:hover { background: var(--gray-light); border-color: #ccc; }
}

/* ══════════════════════════════════════════
   PROMO CAROUSEL — arriba del navbar
══════════════════════════════════════════ */
.promo-carousel {
  background: var(--black);
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  position: relative;
}
.promo-c-item {
  position: absolute;
  color: rgba(255,255,255,.85);
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: .78rem;
  font-weight: 500;
  opacity: 0;
  transform: translateY(14px);
  transition: opacity .45s ease, transform .45s ease;
  white-space: nowrap;
  pointer-events: none;
  letter-spacing: .01em;
}
.promo-c-item.active {
  opacity: 1;
  transform: translateY(0);
  pointer-events: all;
}
.promo-c-item strong { color: #ffffff; font-weight: 700; }

/* ══════════════════════════════════════════
   HERO SLIDER — sticky scroll
══════════════════════════════════════════ */
.hero-slider {
  position: sticky !important;
  top: 70px !important;
  z-index: 1 !important;
}

/* ══════════════════════════════════════════
   CAT SHOWCASE — cubre el hero al hacer scroll
══════════════════════════════════════════ */
.cat-showcase {
  background: var(--white) !important;
  position: relative;
  z-index: 5;
  border-radius: 28px 28px 0 0;
  box-shadow: 0 -16px 50px rgba(0,0,0,.13);
}

/* ══════════════════════════════════════════
   FEATURED — CAROUSEL HORIZONTAL (Promociones del mes)
══════════════════════════════════════════ */
.featured-section {
  background: var(--white) !important;
  position: relative;
  z-index: 5;
}
.featured-carousel-wrap {
  position: relative;
  padding: 0 28px;
  margin-bottom: 36px;
}
.featured-carousel {
  display: flex;
  gap: 20px;
  overflow-x: auto;
  scroll-behavior: smooth;
  scrollbar-width: none;
  -ms-overflow-style: none;
  padding-bottom: 4px;
}
.featured-carousel::-webkit-scrollbar { display: none; }
.featured-carousel .p-card {
  flex: 0 0 240px;
  min-width: 0;
}
.fcar-btn {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: var(--white);
  border: 1.5px solid var(--border);
  font-size: 1.5rem;
  cursor: pointer;
  z-index: 10;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 2px 12px rgba(0,0,0,.1);
  transition: all .2s;
  color: var(--black);
  line-height: 1;
}
.fcar-btn:hover {
  background: var(--red);
  border-color: var(--red);
  color: var(--white);
  box-shadow: 0 4px 16px rgba(212,43,43,.3);
}
.fcar-prev { left: -8px; }
.fcar-next { right: -8px; }
@media (max-width: 900px) {
  .featured-carousel .p-card { flex: 0 0 200px; }
  .featured-carousel-wrap { padding: 0 20px; }
  .fcar-prev { left: -4px; }
  .fcar-next { right: -4px; }
}
@media (max-width: 600px) {
  .featured-carousel .p-card { flex: 0 0 170px; }
}

/* ══════════════════════════════════════════
   SERVICIOS — ACCORDION LAYOUT (1 grande izq + 4 pequeños der)
══════════════════════════════════════════ */
.servicios-section {
  background: var(--white) !important;
  position: relative;
  z-index: 5;
  border-top: 1px solid var(--border);
}
.srv-accordion {
  display: grid;
  grid-template-columns: 1fr 420px;
  gap: 16px;
  align-items: start;
}

/* Tarjeta expandida (izquierda) */
.srv-acc-expanded {
  border-radius: 20px;
  overflow: hidden;
  min-height: 494px;
  position: relative;
  background: #1a1a1a center/cover no-repeat;
}
.srv-acc-exp-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(0,0,0,.82) 0%, rgba(0,0,0,.55) 100%);
}
.srv-acc-exp-content {
  position: relative;
  z-index: 1;
  padding: 36px;
  display: flex;
  flex-direction: column;
  gap: 16px;
  height: 100%;
  min-height: inherit;
}
.srv-acc-exp-head {
  display: flex;
  align-items: flex-start;
  gap: 16px;
}
.srv-acc-exp-title {
  font-family: 'Nunito', sans-serif;
  font-size: 1.7rem;
  font-weight: 900;
  color: var(--white);
  letter-spacing: -0.02em;
  line-height: 1.1;
  margin-bottom: 8px;
}
.srv-acc-exp-badge {
  display: inline-flex;
  background: var(--red);
  color: var(--white);
  font-size: .7rem;
  font-weight: 700;
  padding: 3px 12px;
  border-radius: 50px;
  font-family: 'Plus Jakarta Sans', sans-serif;
}
.srv-acc-exp-desc {
  font-size: .9rem;
  color: rgba(255,255,255,.75);
  line-height: 1.65;
}
.srv-acc-exp-items {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 10px;
  flex: 1;
}
.srv-acc-exp-items li {
  font-size: .88rem;
  color: rgba(255,255,255,.9);
  font-weight: 500;
  padding-left: 22px;
  position: relative;
  line-height: 1.5;
}
.srv-acc-exp-items li::before {
  content: '→';
  position: absolute;
  left: 0;
  color: var(--red);
  font-weight: 700;
  font-size: .8rem;
}

/* Lista compacta (derecha) */
.srv-acc-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.srv-acc-compact {
  border-radius: 14px;
  padding: 20px 18px;
  display: flex;
  align-items: center;
  gap: 12px;
  cursor: pointer;
  transition: all .2s;
  position: relative;
  overflow: hidden;
  background: #1a1a1a center/cover no-repeat;
  min-height: 116px;
}
.srv-acc-compact-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(0,0,0,.72) 0%, rgba(0,0,0,.45) 100%);
  transition: background .2s;
}
.srv-acc-compact:hover .srv-acc-compact-overlay {
  background: linear-gradient(135deg, rgba(180,20,20,.75) 0%, rgba(0,0,0,.45) 100%);
}
.srv-acc-compact:hover { transform: translateX(-4px); }
.srv-acc-compact-info {
  flex: 1;
  min-width: 0;
  position: relative;
  z-index: 1;
}
.srv-acc-compact-name {
  display: block;
  font-family: 'Nunito', sans-serif;
  font-size: 1.05rem;
  font-weight: 800;
  color: var(--white);
  margin-bottom: 2px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.srv-acc-compact-sub {
  display: block;
  font-size: .8rem;
  color: rgba(255,255,255,.65);
  font-weight: 500;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.srv-acc-compact-arr {
  color: rgba(255,255,255,.6);
  font-size: .9rem;
  flex-shrink: 0;
  transition: all .2s;
  position: relative;
  z-index: 1;
}
.srv-acc-compact:hover .srv-acc-compact-arr {
  color: var(--white);
  transform: translateX(3px);
}

/* ══════════════════════════════════════════
   SECCIONES POSTERIORES — z-index sobre hero sticky
══════════════════════════════════════════ */
.testimonios-section {
  position: relative;
  z-index: 5;
  background: var(--white);
}
footer {
  position: relative;
  z-index: 5;
}

/* Responsive servicios accordion */
@media (max-width: 900px) {
  .srv-accordion {
    grid-template-columns: 1fr;
  }
  .srv-acc-compact:hover { transform: none; }
  .srv-acc-list {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
  }
}
@media (max-width: 600px) {
  .srv-acc-list { grid-template-columns: 1fr; }
  .srv-acc-exp-body { grid-template-columns: 1fr; }
  .srv-acc-exp-img { height: 200px; border-left: none; border-top: 1.5px solid var(--border); }
  .srv-acc-exp-content { padding: 24px; }
}

/* ══════════════════════════════════════════
   INSTAGRAM FEED SECTION
══════════════════════════════════════════ */
.ig-section {
  position: relative;
  z-index: 5;
  background: var(--white);
  border-top: 1px solid var(--border);
  padding: 64px 40px;
}
.ig-inner { max-width: 1400px; margin: 0 auto; }

.ig-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 36px;
  gap: 16px;
}
.ig-header-left {
  display: flex;
  align-items: center;
  gap: 16px;
}
.ig-logo-svg {
  width: 48px;
  height: 48px;
  flex-shrink: 0;
  border-radius: 12px;
}
.ig-title {
  font-family: 'Nunito', sans-serif;
  font-size: 1.5rem;
  font-weight: 900;
  color: var(--black);
  letter-spacing: -0.02em;
  line-height: 1.1;
}
.ig-subtitle {
  font-size: .78rem;
  color: var(--gray);
  font-weight: 500;
  margin-top: 2px;
}
.ig-follow-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: linear-gradient(135deg, #f09433, #dc2743, #bc1888);
  color: var(--white);
  text-decoration: none;
  padding: 10px 24px;
  border-radius: 50px;
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: .875rem;
  font-weight: 700;
  white-space: nowrap;
  transition: all .2s;
  box-shadow: 0 4px 16px rgba(188,24,136,.25);
}
.ig-follow-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(188,24,136,.35);
}

/* Fallback card */
.ig-fallback {
  display: flex;
  justify-content: center;
  padding: 20px 0;
}
.ig-fallback-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 18px;
  background: var(--gray-light);
  border: 1px dashed var(--border);
  border-radius: 20px;
  padding: 48px 32px;
  text-align: center;
  max-width: 480px;
  width: 100%;
}
.ig-fallback-text {
  font-size: .9rem;
  color: var(--gray);
  line-height: 1.65;
}
.ig-visit-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: linear-gradient(135deg, #f09433, #dc2743, #bc1888);
  color: var(--white);
  text-decoration: none;
  padding: 12px 28px;
  border-radius: 50px;
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: .875rem;
  font-weight: 700;
  transition: all .2s;
  box-shadow: 0 4px 16px rgba(188,24,136,.25);
}
.ig-visit-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(188,24,136,.35);
}

/* Elfsight widget override */
.elfsight-app-XXXXXXXXX:not(:empty) ~ .ig-fallback { display: none; }

@media (max-width: 900px) {
  .ig-section { padding: 40px 20px; }
  .ig-header { flex-direction: column; align-items: flex-start; }
  .ig-fallback-card { padding: 32px 20px; }
}

/* ══════════════════════════════════════════
   HERO SLIDER — Slide tipo Promo de Producto
   (estilo con foto de producto + precio)
══════════════════════════════════════════ */

/* Foto de fondo semitransparente */
.slide-bg-photo {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: right center;
  opacity: .18;
  pointer-events: none;
}

/* Layout 2 columnas: texto izq + producto der */
.slide-product {
  grid-template-columns: 1fr 1fr;
  gap: 40px;
  align-items: center;
}

/* Columna izquierda */
.slide-prod-left {
  display: flex;
  flex-direction: column;
  gap: 12px;
  justify-content: center;
}

/* Tag superior (pequeña etiqueta) */
.slide-prod-tag {
  display: inline-block;
  background: rgba(255,255,255,.15);
  border: 1px solid rgba(255,255,255,.3);
  color: rgba(255,255,255,.92);
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  padding: 5px 14px;
  border-radius: 50px;
  width: fit-content;
}

/* Píldora de marca (fondo blanco como en el screenshot) */
.slide-prod-brand {
  display: inline-block;
  background: var(--white);
  color: var(--black);
  padding: 5px 20px;
  border-radius: 10px;
  font-family: 'Nunito', sans-serif;
  font-size: 1.05rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  width: fit-content;
  box-shadow: 0 4px 16px rgba(0,0,0,.25);
}

/* Palabra destacada "preventivo" */
.slide-preventivo {
  font-style: italic;
  font-size: 1.22em;
  color: #b0b8c1;
  letter-spacing: -0.01em;
}
.slide-mant-sub {
  font-style: normal;
  font-size: .55em;
  -webkit-text-stroke: 0;
  color: rgba(255,255,255,.75);
  letter-spacing: 0;
  display: block;
  margin-top: 4px;
}

/* Nota de restricciones */
.slide-restricciones {
  font-size: .72rem;
  color: rgba(255,255,255,.45);
  font-style: italic;
  margin-top: -4px;
}

/* Título del slide */
.slide-prod-title {
  font-family: 'Nunito', sans-serif;
  font-size: clamp(1.9rem, 3.2vw, 3rem);
  font-weight: 900;
  color: var(--white);
  line-height: 1.08;
  letter-spacing: -0.03em;
  margin: 2px 0 0;
}

/* Subtítulo */
.slide-prod-sub {
  color: rgba(255,255,255,.65);
  font-size: .95rem;
  line-height: 1.6;
}

/* Precio grande */
.slide-prod-price {
  font-family: 'Nunito', sans-serif;
  font-size: clamp(3rem, 5.5vw, 5rem);
  font-weight: 900;
  line-height: 1;
  letter-spacing: -0.04em;
}

/* Columna derecha — imagen del producto */
.slide-prod-right {
  display: flex;
  align-items: center;
  justify-content: center;
}

.hero-feature-card {
  width: min(100%, 380px);
  background: rgba(255,255,255,.96);
  border: 1px solid rgba(255,255,255,.45);
  border-radius: 24px;
  padding: 22px;
  box-shadow: 0 24px 60px rgba(0,0,0,.26);
  transition: transform .22s ease, box-shadow .22s ease;
  cursor: pointer;
}
.hero-feature-card:hover {
  transform: translateY(-6px) scale(1.02);
  box-shadow: 0 32px 72px rgba(0,0,0,.36);
}
.hero-feature-card-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 14px;
}
.hero-feature-badge,
.hero-feature-category {
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  padding: 0 12px;
  border-radius: 999px;
  font-size: .72rem;
  font-weight: 700;
}
.hero-feature-badge {
  background: #fff1ed;
  color: var(--red);
}
.hero-feature-category {
  background: #f4f4f5;
  color: #3f3f46;
}
.hero-feature-name {
  color: var(--black);
  font-size: 1.05rem;
  font-weight: 800;
  line-height: 1.35;
  margin-bottom: 10px;
}
.hero-feature-media {
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: 18px;
  min-height: 180px;
  padding: 18px;
  margin-bottom: 16px;
}
.hero-feature-media img {
  max-width: 100%;
  max-height: 150px;
  object-fit: contain;
}
.hero-feature-meta {
  color: var(--gray);
  font-size: .88rem;
  line-height: 1.55;
}
.hero-feature-divider {
  height: 1px;
  background: var(--border);
  margin: 18px 0 16px;
}
.hero-feature-bottom {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 14px;
}
.hero-feature-label {
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--gray);
  margin-bottom: 4px;
}
.hero-feature-price {
  color: #6d28d9;
  font-family: 'Nunito', sans-serif;
  font-size: 1.55rem;
  font-weight: 900;
  line-height: 1.1;
}
.hero-feature-price-blue { color: #2563eb; }
.hero-feature-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 42px;
  padding: 0 16px;
  border-radius: 999px;
  background: var(--black);
  color: var(--white);
  font-size: .82rem;
  font-weight: 700;
  text-decoration: none;
  white-space: nowrap;
}
.hero-feature-link:hover {
  background: #1f2937;
}
.hero-mini-card {
  width: min(100%, 290px);
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: 22px;
  overflow: hidden;
  box-shadow: 0 24px 60px rgba(0,0,0,.22);
  transition: transform .22s ease, box-shadow .22s ease;
  cursor: pointer;
}
.hero-mini-card:hover {
  transform: translateY(-6px) scale(1.02);
  box-shadow: 0 32px 72px rgba(0,0,0,.32);
}
.hero-mini-card-img {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 210px;
  padding: 18px;
  background: var(--white);
  border-bottom: 1px solid var(--border);
}
.hero-mini-card-img img {
  max-width: 100%;
  max-height: 170px;
  object-fit: contain;
}
.hero-mini-card-body {
  display: flex;
  flex-direction: column;
  padding: 16px 18px 18px;
}
.hero-mini-card-cat {
  color: var(--red);
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  margin-bottom: 6px;
}
.hero-mini-card-name {
  color: var(--black);
  font-size: .92rem;
  font-weight: 700;
  line-height: 1.4;
  margin-bottom: 6px;
}
.hero-mini-card-meta {
  color: var(--gray);
  font-size: .78rem;
  margin-bottom: 10px;
}
.hero-mini-card-price {
  color: #2563eb;
  font-family: 'Nunito', sans-serif;
  font-size: 1.35rem;
  font-weight: 900;
  line-height: 1.1;
  margin-bottom: 14px;
}
.hero-mini-card-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 40px;
  border-radius: 12px;
  background: var(--red);
  color: var(--white);
  font-size: .84rem;
  font-weight: 700;
  text-decoration: none;
}
.hero-mini-card-link:hover {
  background: var(--red2);
}

/* Imagen real del producto */
.slide-prod-img {
  max-height: 400px;
  max-width: 100%;
  object-fit: contain;
  filter: drop-shadow(0 24px 60px rgba(0,0,0,.55));
  animation: float 3.5s ease-in-out infinite;
}

/* Placeholder cuando no hay imagen de producto */
.slide-prod-placeholder {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 10px;
  width: 280px;
  height: 320px;
  background: rgba(255,255,255,.07);
  border: 2px dashed rgba(255,255,255,.22);
  border-radius: 24px;
  text-align: center;
  padding: 28px;
  animation: float 3.5s ease-in-out infinite;
  cursor: default;
}
.slide-prod-placeholder span:first-child { font-size: 4rem; }
.slide-prod-placeholder b {
  font-family: 'Nunito', sans-serif;
  font-size: 1.1rem;
  font-weight: 900;
  color: var(--white);
  letter-spacing: .06em;
  display: block;
}
.slide-prod-placeholder span:last-child {
  font-size: .8rem;
  color: rgba(255,255,255,.55);
  font-weight: 500;
  line-height: 1.5;
}

/* ── Hero Slide Product Card ── */
.slide-pcard {
  display: flex;
  flex-direction: column;
  background: rgba(255,255,255,.1);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border: 1px solid rgba(255,255,255,.18);
  border-radius: 20px;
  overflow: hidden;
  width: 220px;
  text-decoration: none;
  color: var(--white);
  transition: transform .2s, box-shadow .2s;
  box-shadow: 0 8px 32px rgba(0,0,0,.3);
}
.slide-pcard:hover {
  transform: translateY(-4px);
  box-shadow: 0 16px 48px rgba(0,0,0,.4);
}
.slide-pcard-img {
  width: 100%;
  height: 160px;
  background: rgba(255,255,255,.08);
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}
.slide-pcard-body {
  padding: 14px 16px 16px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.slide-pcard-name {
  font-size: .82rem;
  font-weight: 600;
  line-height: 1.3;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.slide-pcard-price {
  font-size: 1.1rem;
  font-weight: 800;
}
.slide-pcard-btn {
  margin-top: 4px;
  background: rgba(255,255,255,.2);
  border-radius: 8px;
  padding: 7px 10px;
  font-size: .78rem;
  font-weight: 600;
  text-align: center;
}

/* Responsive */
@media (max-width: 900px) {
  .slide-product { grid-template-columns: 1fr !important; }
  .slide-prod-right { display: none; }
  .slide-prod-title { font-size: clamp(1.6rem, 6vw, 2.4rem); }
  .slide-prod-price { font-size: clamp(2.5rem, 8vw, 3.5rem); }
}
