:root {
  --text: #fff7ee;
  --muted: #b7c7e7;
  --primary: #00eaff;
  --primary-strong: #8b5cff;
  --hot: #ff2fb3;
  --gold: #ffe27a;
  --green: #39ff88;
  --danger: #ff4d6d;
  --bg0: #02030a;
  --bg1: #060817;
  --card: rgba(8, 13, 31, 0.78);
  --card2: rgba(11, 18, 44, 0.88);
  --border: rgba(0, 234, 255, 0.28);
  --border-hot: rgba(255, 47, 179, 0.34);
  --hero-bg-image: url("../img/hero-bg.jpg");
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; min-height: 100%; }
html { scroll-behavior: smooth; }
body {
  font-family: "Rajdhani", sans-serif;
  color: var(--text);
  background:
    radial-gradient(circle at 20% 10%, rgba(0, 234, 255, 0.12), transparent 32%),
    radial-gradient(circle at 82% 16%, rgba(255, 47, 179, 0.12), transparent 30%),
    radial-gradient(circle at 55% 96%, rgba(139, 92, 255, 0.12), transparent 38%),
    linear-gradient(180deg, #01020a 0%, #060817 42%, #02030a 100%);
  overflow-x: hidden;
}
body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: -1;
  background-image:
    linear-gradient(rgba(0, 234, 255, 0.045) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255, 47, 179, 0.035) 1px, transparent 1px);
  background-size: 52px 52px;
  mask-image: linear-gradient(to bottom, rgba(0,0,0,.8), transparent 76%);
}
.theme-mu { position: relative; overflow-x: hidden; }
.bg-layer {
  position: fixed;
  inset: 0;
  z-index: -4;
  background:
    linear-gradient(180deg, rgba(2, 3, 10, 0.42) 0%, rgba(2, 3, 10, 0.88) 68%, rgba(2, 3, 10, 0.98) 100%),
    var(--hero-bg-image) center/cover no-repeat fixed;
  filter: saturate(1.35) contrast(1.12);
}
.bg-layer::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 50% 20%, transparent 0 18%, rgba(2, 3, 10, .66) 58%, rgba(2,3,10,.95) 100%),
    linear-gradient(90deg, rgba(0,234,255,.09), transparent 28%, transparent 72%, rgba(255,47,179,.09));
}
.glow { position: fixed; border-radius: 999px; filter: blur(80px); pointer-events: none; z-index: -2; opacity: .95; }
.glow-1 { width: 380px; height: 380px; left: -120px; top: 70px; background: rgba(0, 234, 255, 0.28); }
.glow-2 { width: 440px; height: 440px; right: -150px; top: 260px; background: rgba(255, 47, 179, 0.24); }
.container { width: min(1320px, 94%); margin: 0 auto; }

.hero { min-height: 48vh; display: grid; align-items: end; padding: 28px 0 46px; position: relative; }
.hero::after {
  content: "";
  position: absolute;
  left: 50%; bottom: 22px;
  width: min(840px, 72vw); height: 1px;
  transform: translateX(-50%);
  background: linear-gradient(90deg, transparent, rgba(0,234,255,.8), rgba(255,47,179,.78), transparent);
  box-shadow: 0 0 22px rgba(0,234,255,.55);
}
.hero-content {
  position: relative;
  overflow: hidden;
  border: 1px solid rgba(0, 234, 255, 0.26);
  border-radius: 30px;
  padding: clamp(22px, 4vw, 42px);
  background:
    linear-gradient(135deg, rgba(2, 8, 26, 0.72), rgba(24, 8, 38, 0.58)),
    linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.015));
  backdrop-filter: blur(14px);
  text-align: center;
  box-shadow:
    0 26px 80px rgba(0,0,0,.55),
    0 0 0 1px rgba(255,47,179,.16) inset,
    0 0 50px rgba(0,234,255,.12);
}
.hero-content::before {
  content: "";
  position: absolute;
  inset: -2px;
  background: linear-gradient(120deg, transparent 10%, rgba(0,234,255,.18), transparent 35%, transparent 65%, rgba(255,47,179,.18), transparent 90%);
  transform: translateX(-60%);
  animation: panelSweep 8s ease-in-out infinite;
  pointer-events: none;
}
.hero-content > * { position: relative; z-index: 1; }
@keyframes panelSweep { 0%, 100% { transform: translateX(-70%); } 50% { transform: translateX(70%); } }
.hero-badge {
  margin: 0 auto 14px;
  width: fit-content;
  border: 1px solid rgba(0, 234, 255, 0.76);
  border-radius: 999px;
  padding: 8px 18px;
  color: #07111f;
  background: linear-gradient(90deg, #00eaff, #7dffdc, #ffe27a);
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
  box-shadow: 0 0 22px rgba(0,234,255,.38), 0 0 28px rgba(255,226,122,.18);
}
.hero h1 {
  margin: 0;
  font-size: clamp(2.7rem, 8vw, 6.2rem);
  line-height: .9;
  letter-spacing: 2px;
  font-family: "Cinzel", serif;
  color: transparent;
  background: linear-gradient(90deg, #fff7ee, #00eaff, #ff2fb3, #ffe27a, #fff7ee);
  background-size: 240% 240%;
  -webkit-background-clip: text;
  background-clip: text;
  text-shadow: 0 0 36px rgba(0, 234, 255, 0.35), 0 0 58px rgba(255, 47, 179, 0.28);
  animation: titleShift 5.5s ease infinite;
  filter: drop-shadow(0 8px 18px rgba(0,0,0,.7));
}
@keyframes titleShift { 0% { background-position: 0% 50%; } 50% { background-position: 100% 50%; } 100% { background-position: 0% 50%; } }
.hero-subtitle { margin: 14px auto 22px; font-size: clamp(1.05rem, 2.4vw, 1.45rem); color: #dcecff; max-width: 780px; text-shadow: 0 0 18px rgba(0,234,255,.20); }
.hero-stats { display: grid; grid-template-columns: repeat(3, minmax(130px, 1fr)); gap: 14px; }
.hero-stat {
  border-radius: 18px;
  border: 1px solid rgba(0, 234, 255, 0.22);
  background: linear-gradient(180deg, rgba(6, 18, 42, 0.82), rgba(9, 9, 26, 0.76));
  padding: 14px 10px;
  text-align: center;
  box-shadow: 0 0 0 1px rgba(255,47,179,.08) inset, 0 14px 30px rgba(0,0,0,.25);
}
.stat-label { display: block; color: #8ac9ff; font-size: .9rem; letter-spacing: .05em; text-transform: uppercase; }
.stat-value { display: block; margin-top: 4px; font-size: 1.25rem; color: #fff; text-shadow: 0 0 14px rgba(0,234,255,.34); }

.shop-layout { display: grid; gap: 24px; padding-bottom: 44px; }
.weekly-offer {
  position: relative;
  overflow: hidden;
  display: grid;
  grid-template-columns: 1.05fr 1fr;
  gap: 20px;
  border: 1px solid rgba(255, 47, 179, 0.34);
  border-radius: 28px;
  padding: 22px;
  background:
    radial-gradient(circle at 14% 20%, rgba(0,234,255,.14), transparent 36%),
    radial-gradient(circle at 88% 36%, rgba(255,47,179,.16), transparent 34%),
    linear-gradient(135deg, rgba(8, 13, 31, 0.92), rgba(17, 7, 31, 0.92));
  box-shadow: 0 24px 65px rgba(0,0,0,.48), 0 0 40px rgba(255,47,179,.12), 0 0 0 1px rgba(0,234,255,.12) inset;
}
.weekly-offer::before { content: "OFERTA"; position: absolute; right: -26px; top: 30px; transform: rotate(18deg); font-size: 4.7rem; font-weight: 900; color: rgba(255,255,255,.035); letter-spacing: .08em; }
.weekly-left { align-self: center; position: relative; z-index: 1; }
.weekly-tag {
  margin: 0 0 12px; width: fit-content; font-weight: 900; letter-spacing: 1px; color: #07111f;
  padding: 8px 14px; border-radius: 999px; background: linear-gradient(90deg, #ff2fb3, #ffe27a); box-shadow: 0 0 25px rgba(255,47,179,.34);
}
.weekly-left h2 { margin: 0; font-family: "Cinzel", serif; font-size: clamp(1.8rem, 4.5vw, 3.2rem); color: #fff; text-shadow: 0 0 28px rgba(255,47,179,.35); }
.weekly-left p { margin: 10px 0 0; color: #d9e8ff; font-size: 1.08rem; }
.weekly-ends { margin-top: 18px !important; font-weight: 800; color: var(--gold) !important; }
.weekly-product {
  position: relative; z-index: 1; border: 1px solid rgba(0, 234, 255, 0.36); border-radius: 24px; overflow: hidden;
  background: linear-gradient(180deg, rgba(7, 18, 42, 0.9), rgba(9, 9, 24, 0.98));
  box-shadow: 0 22px 50px rgba(0,0,0,.45), 0 0 28px rgba(0,234,255,.12);
}
.weekly-image-btn { border: 0; padding: 0; margin: 0; width: 100%; cursor: pointer; background: transparent; }
.weekly-image-btn img { width: 100%; height: 245px; object-fit: cover; display: block; filter: saturate(1.2) contrast(1.08); }
.weekly-body { padding: 16px; }
.weekly-body strong { display: block; font-size: 1.55rem; font-family: "Cinzel", serif; color: #fff; }
.weekly-body p { margin: 7px 0 0; color: var(--muted); }
.weekly-prices { margin-top: 12px; display: flex; align-items: center; gap: 10px; }
.weekly-prices span { color: var(--gold); font-size: 1.48rem; font-weight: 900; text-shadow: 0 0 16px rgba(255,226,122,.2); }
.weekly-prices small { color: #7892bc; text-decoration: line-through; font-size: 1rem; }

.catalog {
  border: 1px solid rgba(0, 234, 255, 0.26);
  border-radius: 28px;
  padding: 20px 22px 10px;
  background:
    linear-gradient(180deg, rgba(8, 13, 31, 0.84), rgba(3, 6, 18, 0.92));
  box-shadow: 0 24px 65px rgba(0,0,0,.42), 0 0 0 1px rgba(255,47,179,.10) inset;
}
.catalog-top { text-align: center; padding: 8px 0 0; }
.catalog-top h2 { margin: 0; font-family: "Cinzel", serif; font-size: clamp(1.8rem, 4.8vw, 3.1rem); color: #fff; text-shadow: 0 0 20px rgba(0,234,255,.32); }
.catalog-top p { margin: 7px 0 0; color: var(--muted); font-size: 1.12rem; }
.filters { margin: 22px 0 24px; display: flex; justify-content: center; flex-wrap: wrap; gap: 10px; }
.chip {
  border: 1px solid rgba(0, 234, 255, 0.26);
  border-radius: 999px;
  background: linear-gradient(180deg, rgba(7, 18, 44, 0.88), rgba(6, 8, 22, 0.86));
  color: #dcecff;
  font-family: inherit;
  font-weight: 800;
  font-size: .96rem;
  padding: 9px 16px;
  cursor: pointer;
  text-transform: uppercase;
  letter-spacing: .03em;
  transition: transform .22s ease, border-color .22s ease, background .22s ease, box-shadow .22s ease, color .22s ease;
}
.chip:hover { transform: translateY(-2px); border-color: rgba(255, 47, 179, 0.62); box-shadow: 0 0 18px rgba(255,47,179,.16); color: #fff; }
.chip.active { color: #02030a; border-color: rgba(255,255,255,.8); background: linear-gradient(90deg, #00eaff, #ff2fb3, #ffe27a); box-shadow: 0 0 28px rgba(0,234,255,.22), 0 0 18px rgba(255,47,179,.20); }

.products-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(270px, 1fr)); gap: 22px; padding-bottom: 28px; }
.card {
  position: relative;
  border-radius: 24px;
  overflow: hidden;
  border: 1px solid rgba(0, 234, 255, 0.24);
  background:
    radial-gradient(circle at 50% 0%, rgba(0,234,255,.10), transparent 42%),
    linear-gradient(180deg, rgba(10, 22, 52, 0.86), rgba(5, 7, 19, 0.95));
  box-shadow: 0 18px 42px rgba(0,0,0,.46), 0 0 0 1px rgba(255,47,179,.10) inset;
  transition: transform .28s ease, box-shadow .28s ease, border-color .28s ease;
}
.card::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(120deg, transparent, rgba(0,234,255,.12), transparent 34%, transparent 66%, rgba(255,47,179,.10), transparent);
  opacity: 0;
  transition: opacity .28s ease;
  pointer-events: none;
}
.card:hover { transform: translateY(-8px) scale(1.015); border-color: rgba(255, 47, 179, 0.56); box-shadow: 0 26px 70px rgba(0,0,0,.60), 0 0 34px rgba(0,234,255,.16), 0 0 22px rgba(255,47,179,.14); }
.card:hover::before { opacity: 1; }
.image-btn { border: 0; margin: 0; padding: 0; width: 100%; background: transparent; cursor: pointer; }
.card-image-wrap { position: relative; height: 230px; overflow: hidden; background: #040713; }
.card-image { width: 100%; height: 100%; object-fit: cover; transition: transform .7s ease, filter .7s ease; filter: saturate(1.18) contrast(1.05); }
.image-btn:hover .card-image { transform: scale(1.1); filter: saturate(1.32) contrast(1.12) brightness(1.08); }
.card-image-wrap::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, transparent 34%, rgba(2,3,10,.72) 100%); pointer-events: none; }
.shine { position: absolute; inset: 0; background: linear-gradient(120deg, transparent 0%, rgba(255,255,255,.24) 45%, transparent 68%); transform: translateX(-120%); transition: transform .8s ease; }
.image-btn:hover .shine { transform: translateX(120%); }
.type-badge {
  position: absolute; top: 13px; left: 13px; z-index: 2;
  border: 1px solid rgba(0,234,255,.66); border-radius: 999px;
  background: rgba(2, 8, 26, 0.78); color: #92f7ff;
  font-size: .76rem; letter-spacing: .08em; padding: 6px 11px; font-weight: 900; text-transform: uppercase;
  box-shadow: 0 0 16px rgba(0,234,255,.22);
}
.card-content { padding: 16px; display: flex; flex-direction: column; min-height: 224px; position: relative; z-index: 2; }
.product-name { margin: 0 0 8px; font-size: 1.35rem; font-family: "Cinzel", serif; color: #fff; text-shadow: 0 0 14px rgba(0,234,255,.18); }
.product-desc { margin: 0 0 14px; color: var(--muted); min-height: 50px; line-height: 1.35; }
.price-row { display: flex; align-items: center; gap: 9px; margin-bottom: 15px; }
.final-price { font-size: 1.35rem; font-weight: 900; color: var(--gold); }
.old-price { color: #7892bc; text-decoration: line-through; }
.discount-pill { margin-left: auto; padding: 5px 10px; border-radius: 999px; background: linear-gradient(90deg, #ff2fb3, #ff4d6d); color: #fff; font-size: .78rem; font-weight: 900; box-shadow: 0 0 16px rgba(255,47,179,.26); }
.btn { border: 0; border-radius: 14px; cursor: pointer; font-family: inherit; }
.btn-buy {
  width: 100%; margin-top: auto; padding: 12px 14px;
  font-weight: 900; color: #02030a; letter-spacing: .08em; text-transform: uppercase;
  background: linear-gradient(90deg, #00eaff, #7dffdc, #ffe27a);
  box-shadow: 0 0 22px rgba(0,234,255,.18);
  transition: transform .2s ease, filter .2s ease, box-shadow .2s ease;
}
.btn-buy:hover { transform: translateY(-2px); filter: brightness(1.08); box-shadow: 0 0 30px rgba(0,234,255,.34), 0 0 18px rgba(255,226,122,.20); }
.empty { grid-column: 1 / -1; border: 1px solid var(--border); border-radius: 18px; text-align: center; color: var(--muted); padding: 28px; background: rgba(5, 10, 28, 0.78); }

.lightbox { position: fixed; inset: 0; display: none; align-items: center; justify-content: center; background: rgba(1,2,8,.88); backdrop-filter: blur(10px); z-index: 30; padding: 20px; gap: 12px; }
.lightbox.open { display: flex; }
.lightbox-panel { width: min(960px, calc(100% - 120px)); border: 1px solid rgba(0,234,255,.42); border-radius: 24px; overflow: hidden; background: linear-gradient(180deg, #07122b, #040713); box-shadow: 0 30px 90px rgba(0,0,0,.72), 0 0 42px rgba(0,234,255,.14); animation: lightboxIn .35s ease; position: relative; }
.lightbox img { width: 100%; max-height: 72vh; object-fit: cover; display: block; filter: saturate(1.22) contrast(1.1); }
.lightbox-meta { display: flex; justify-content: space-between; gap: 14px; align-items: flex-end; padding: 16px 18px 18px; }
.lightbox-meta strong { display: block; font-size: 1.45rem; margin: 0; font-family: "Cinzel", serif; }
#lightboxDesc { margin: 6px 0 0; color: var(--muted); }
.lightbox-side { display: flex; flex-direction: column; text-align: right; gap: 7px; }
#lightboxType { border: 1px solid rgba(255,47,179,.65); border-radius: 999px; padding: 5px 10px; font-size: .84rem; font-weight: 900; color: #ffd9f3; }
#lightboxCounter { color: #9cc9ff; }
.lightbox-close { position: absolute; top: 12px; right: 12px; width: 42px; height: 42px; border: 1px solid rgba(0,234,255,.7); border-radius: 999px; color: #fff; background: rgba(3, 8, 24, 0.78); font-size: 1.5rem; line-height: 1; cursor: pointer; box-shadow: 0 0 18px rgba(0,234,255,.18); }
.lightbox-nav { width: 50px; height: 50px; border: 1px solid rgba(0,234,255,.65); border-radius: 999px; color: #fff; font-size: 2.1rem; line-height: 1; cursor: pointer; background: rgba(4, 10, 28, 0.82); transition: transform .2s ease, filter .2s ease, box-shadow .2s ease; box-shadow: 0 0 20px rgba(0,234,255,.14); }
.lightbox-nav:hover { transform: scale(1.07); filter: brightness(1.12); box-shadow: 0 0 28px rgba(255,47,179,.22); }
@keyframes lightboxIn { from { opacity: 0; transform: translateY(18px) scale(.96); } to { opacity: 1; transform: translateY(0) scale(1); } }

@media (max-width: 980px) { .weekly-offer { grid-template-columns: 1fr; } }
@media (max-width: 760px) {
  .hero { min-height: 42vh; padding: 14px 0 28px; }
  .hero-content { padding: 18px; border-radius: 24px; }
  .hero-stats { grid-template-columns: 1fr; }
  .catalog { padding: 16px 12px 6px; }
  .products-grid { grid-template-columns: 1fr; }
  .card-image-wrap { height: 205px; }
  .lightbox { padding: 12px; gap: 7px; }
  .lightbox-panel { width: calc(100% - 84px); }
  .lightbox-meta { flex-direction: column; align-items: flex-start; }
  .lightbox-side { text-align: left; }
  .lightbox-nav { width: 40px; height: 40px; font-size: 1.65rem; }
}

/* ===== MEGA PRO FEATURES - BUSCADOR, MODAL, CARRUSEL, ADMIN, WHATSAPP ===== */
.glow-3{width:360px;height:360px;left:42%;bottom:-160px;background:rgba(57,255,136,.12)}
.hero-actions{display:flex;justify-content:center;gap:12px;flex-wrap:wrap;margin:0 0 20px}
.hero-action{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;padding:10px 18px;text-decoration:none;font-weight:900;letter-spacing:.06em;text-transform:uppercase;border:1px solid rgba(0,234,255,.38);transition:.22s ease;color:#fff}
.hero-action-primary{background:linear-gradient(90deg,#00eaff,#7dffdc,#ffe27a);color:#02030a;box-shadow:0 0 24px rgba(0,234,255,.22)}
.hero-action-ghost{background:rgba(4,10,28,.62);color:#dcecff}
.hero-action:hover{transform:translateY(-2px);filter:brightness(1.08)}
.catalog-kicker{margin:0 0 8px;color:var(--gold);font-weight:900;letter-spacing:.16em;text-transform:uppercase}
.shop-tools{display:grid;grid-template-columns:1fr 230px;gap:12px;margin:22px 0 18px}
.search-box{display:flex;align-items:center;gap:10px;border:1px solid rgba(0,234,255,.30);border-radius:18px;background:rgba(5,12,32,.82);padding:0 14px;box-shadow:0 0 22px rgba(0,234,255,.08)}
.search-box span{color:#00eaff;font-size:1.25rem;font-weight:900}.search-box input,.sort-select{width:100%;border:0;outline:0;background:transparent;color:#fff;font-family:inherit;font-weight:800;font-size:1rem;padding:14px 4px}.search-box input::placeholder{color:#7d9ac5}.sort-select{border:1px solid rgba(255,47,179,.32);border-radius:18px;background:rgba(5,12,32,.88);padding:14px;color:#fff;cursor:pointer}.sort-select option{background:#060817;color:#fff}
.category-hub{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin:0 0 18px}.category-card{position:relative;overflow:hidden;border:1px solid rgba(0,234,255,.20);border-radius:18px;background:linear-gradient(180deg,rgba(9,20,52,.76),rgba(4,8,24,.92));padding:14px;text-align:left;color:#fff;cursor:pointer;transition:.22s ease;box-shadow:0 16px 34px rgba(0,0,0,.25)}.category-card:before{content:"";position:absolute;inset:0;background:linear-gradient(120deg,transparent,rgba(0,234,255,.12),transparent);opacity:0;transition:.22s}.category-card:hover,.category-card.active{transform:translateY(-3px);border-color:rgba(255,47,179,.55);box-shadow:0 20px 48px rgba(0,0,0,.38),0 0 24px rgba(255,47,179,.12)}.category-card:hover:before,.category-card.active:before{opacity:1}.category-card__icon{display:inline-flex;width:30px;height:30px;align-items:center;justify-content:center;border-radius:12px;background:linear-gradient(90deg,#00eaff,#ff2fb3);color:#02030a;font-weight:900;margin-bottom:8px}.category-card strong{display:block;font-size:1.05rem;position:relative}.category-card small{display:block;color:#9cc9ff;margin-top:4px;position:relative}.filters .chip{display:inline-flex;align-items:center;gap:8px}.filters .chip small{display:inline-flex;align-items:center;justify-content:center;min-width:24px;height:24px;padding:0 7px;border-radius:999px;background:rgba(255,255,255,.10);color:inherit;font-size:.8rem}.section-status{display:flex;justify-content:space-between;align-items:center;gap:12px;margin:0 0 16px;padding:11px 14px;border:1px solid rgba(0,234,255,.18);border-radius:16px;background:rgba(4,10,28,.58);color:#9cc9ff}.section-status strong{color:#fff;font-family:"Cinzel",serif}.section-status span{color:var(--gold);font-weight:900}
.badges-row{display:flex;flex-wrap:wrap;gap:6px;margin:0 0 10px}.badges-row span{display:inline-flex;border:1px solid rgba(0,234,255,.32);border-radius:999px;background:rgba(0,234,255,.08);color:#9ffaff;font-size:.72rem;font-weight:900;padding:4px 8px;letter-spacing:.05em}.discount-corner{position:absolute;right:12px;top:12px;z-index:3;align-items:center;justify-content:center;border-radius:999px;background:linear-gradient(90deg,#ff2fb3,#ff4d6d);color:#fff;font-weight:900;font-size:.78rem;padding:7px 10px;box-shadow:0 0 18px rgba(255,47,179,.35)}.product-appear{animation:productIn .32s ease both}@keyframes productIn{from{opacity:0;transform:translateY(14px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}
.weekly-controls{display:flex;align-items:center;gap:10px;margin-top:18px}.mini-nav{width:38px;height:38px;border-radius:999px;border:1px solid rgba(0,234,255,.42);background:rgba(3,8,24,.76);color:#fff;font-size:1.4rem;cursor:pointer;box-shadow:0 0 18px rgba(0,234,255,.12)}#weeklyCounter{color:#9cc9ff;font-weight:900}.weekly-buy{margin-top:14px}
.whatsapp-float{position:fixed;right:18px;bottom:18px;z-index:20;display:flex;align-items:center;gap:9px;text-decoration:none;border:1px solid rgba(57,255,136,.42);border-radius:999px;background:linear-gradient(90deg,rgba(7,40,25,.92),rgba(8,80,46,.92));color:#eafff2;font-weight:900;padding:12px 16px;box-shadow:0 0 28px rgba(57,255,136,.25);transition:.22s}.whatsapp-float:hover{transform:translateY(-3px);filter:brightness(1.1)}.wa-dot{width:10px;height:10px;border-radius:99px;background:#39ff88;box-shadow:0 0 14px #39ff88}.admin-floating{position:fixed;left:18px;bottom:18px;z-index:20;border:1px solid rgba(255,226,122,.38);border-radius:999px;background:rgba(4,10,28,.88);color:var(--gold);font-family:inherit;font-weight:900;padding:12px 16px;cursor:pointer;box-shadow:0 0 20px rgba(255,226,122,.12)}
.buy-modal,.admin-modal{position:fixed;inset:0;display:none;align-items:center;justify-content:center;padding:20px;background:rgba(1,2,8,.86);backdrop-filter:blur(10px);z-index:40}.buy-modal.open,.admin-modal.open{display:flex}.buy-panel,.admin-panel{position:relative;width:min(760px,96vw);border:1px solid rgba(0,234,255,.36);border-radius:26px;background:linear-gradient(180deg,#07122b,#040713);box-shadow:0 34px 90px rgba(0,0,0,.75),0 0 38px rgba(0,234,255,.15);padding:22px}.buy-kicker{color:var(--gold);font-weight:900;letter-spacing:.14em;text-transform:uppercase}.buy-head h3,.admin-panel h3{font-family:"Cinzel",serif;color:#fff;margin:8px 0 6px;font-size:1.8rem}.buy-head p,.admin-panel p{color:var(--muted);margin:0 0 16px}.buy-body{display:grid;grid-template-columns:270px 1fr;gap:18px;align-items:stretch}.buy-body img{width:100%;height:260px;object-fit:cover;border-radius:20px;border:1px solid rgba(0,234,255,.22)}.buy-info{display:grid;gap:12px;align-content:center}.buy-line{display:flex;justify-content:space-between;gap:12px;border:1px solid rgba(255,255,255,.08);border-radius:14px;background:rgba(255,255,255,.035);padding:12px}.buy-line span{color:#9cc9ff}.buy-line strong{color:#fff}.admin-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin:14px 0}.admin-card{border:1px solid rgba(0,234,255,.20);border-radius:16px;background:rgba(255,255,255,.035);padding:12px}.admin-card span{display:block;color:#9cc9ff}.admin-card strong{font-size:1.5rem;color:#fff}#adminExport{width:100%;height:170px;border:1px solid rgba(0,234,255,.22);border-radius:16px;background:rgba(2,3,10,.72);color:#dcecff;padding:12px;font-family:monospace;resize:vertical;margin-bottom:14px}
@media(max-width:820px){.shop-tools{grid-template-columns:1fr}.buy-body{grid-template-columns:1fr}.buy-body img{height:220px}.admin-grid{grid-template-columns:1fr}.whatsapp-float span:last-child,.admin-floating{font-size:.9rem}.category-hub{grid-template-columns:repeat(2,1fr)}}


/* ===== LIMPIEZA SOLICITADA =====
   - Sin botones duplicados de categoria
   - Sin boton Editor/Admin
*/
.admin-floating, .admin-modal, .filters { display: none !important; }
.category-hub { margin-top: 22px; }
.category-card.active { border-color: rgba(255,47,179,.70); box-shadow: 0 22px 54px rgba(0,0,0,.45), 0 0 30px rgba(255,47,179,.18), 0 0 18px rgba(0,234,255,.12); }
