/* ═══════════════════════════════════════════════════════════
   STILE HOME CENTER — stylesheet
   Mantiene la identidad visual original: paleta dorada,
   Cormorant Garamond + Montserrat, tema claro/oscuro.
   ═══════════════════════════════════════════════════════════ */

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

/* ── TOKENS ── */
:root{
  --g:#B8952A; --gh:#C9A840; --gp:#F5EDD6; --gb:rgba(184,149,42,0.18);
  --bg:#FAFAF8; --s:#FFFFFF; --s2:#F4F2EE; --br:#EAE6DF;
  --t:#111110; --t2:#3C3A36; --t3:#6B6860; --t4:#9C9A96;
  --product-bg:#FFFFFF;
  --product-bg-hover:#FAFAFA;
}
body.dark{
  --bg:#0C0B0A; --s:#141210; --s2:#1A1815; --br:rgba(184,149,42,0.15);
  --t:#F0EDE6; --t2:#C8C4BC; --t3:#888480; --t4:#504E4B;
}
body{font-family:'Montserrat',sans-serif;background:var(--bg);color:var(--t);transition:background .3s,color .3s; overflow-x:hidden;}

/* ── NAV ── */
nav{
  position:sticky;top:0;z-index:200;
  height:60px;padding:0 48px;
  background:var(--s);border-bottom:1px solid var(--br);
  display:flex;align-items:center;justify-content:space-between;
  transition:background .3s,border-color .3s;
}
.logo{font-family:'Cormorant Garamond',serif;font-size:20px;font-weight:600;color:var(--g);letter-spacing:6px;line-height:1;}
.logo small{display:block;font-family:'Montserrat',sans-serif;font-size:6.5px;letter-spacing:5px;color:var(--t4);font-weight:400;margin-top:2px;}
.nav-links{display:flex;gap:28px;list-style:none;}
.nav-links a{font-size:10px;letter-spacing:2px;color:var(--t3);cursor:pointer;text-transform:uppercase;transition:color .15s;}
.nav-links a.on{color:var(--g);}
.nav-links a:hover{color:var(--g);}
.nav-r{display:flex;gap:10px;align-items:center;}
.nbtn{height:32px;padding:0 16px;font-family:'Montserrat',sans-serif;font-size:9px;letter-spacing:2px;text-transform:uppercase;border:1px solid var(--g);background:transparent;color:var(--g);cursor:pointer;transition:all .15s;}
.nbtn:hover{background:var(--g);color:#fff;}
/* ── THEME TOGGLE (luna ↔ sol) ── */
.tbtn{
  width:32px;height:32px;
  border:1px solid var(--br);
  background:transparent;
  cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  color:var(--t3);
  transition:border-color .2s, color .2s, transform .3s;
  padding:0;
  position:relative;
}
.tbtn:hover{
  border-color:var(--g);
  color:var(--g);
}
.tbtn:active{
  transform:scale(.92);
}

.theme-icon{
  width:14px;
  height:14px;
  stroke-linecap:round;
  stroke-linejoin:round;
  transition:opacity .25s, transform .35s cubic-bezier(.22,1,.36,1), color .2s;
  position:absolute;
}

.theme-icon-moon{
  opacity:1;
  transform:rotate(0deg) scale(1);
}
.theme-icon-sun{
  opacity:0;
  transform:rotate(-90deg) scale(.4);
}

body.dark .theme-icon-moon{
  opacity:0;
  transform:rotate(90deg) scale(.4);
}
body.dark .theme-icon-sun{
  opacity:1;
  transform:rotate(0deg) scale(1);
  color:var(--g);
}

body.dark .tbtn{
  color:var(--g);
}
body.dark .tbtn:hover{
  border-color:var(--gh);
  color:var(--gh);
}

/* search */
.search-wrap{
  position:relative;
  display:flex;
  align-items:center;
}

.search-bar{
  display:flex;
  align-items:center;
  gap:8px;
  height:32px;
  padding:0 12px;
  width:220px;
  background:transparent;
  border:1px solid var(--br);
  transition:border-color .2s, width .25s cubic-bezier(.4,0,.2,1);
}
.search-bar:hover{ border-color:var(--g); }
.search-bar:focus-within{
  border-color:var(--g);
  width:260px;
}

.search-icon{
  width:14px;
  height:14px;
  color:var(--g);
  flex-shrink:0;
  stroke-linecap:round;
  stroke-linejoin:round;
  transition:color .2s;
}
.search-bar:focus-within .search-icon{
  color:var(--gh);
}

.search-input{
  flex:1;
  min-width:0;
  height:100%;
  padding:0;
  border:none;
  background:transparent;
  font-family:'Montserrat',sans-serif;
  font-size:11px;
  letter-spacing:.5px;
  color:var(--t);
  outline:none;
}
.search-input::placeholder{
  color:var(--t4);
  font-weight:300;
  letter-spacing:1px;
}
.search-dropdown{
  position:absolute;top:calc(100% + 8px);right:0;
  width:340px;background:var(--s);border:1px solid var(--br);
  display:none;z-index:500;
  box-shadow:0 8px 32px rgba(0,0,0,.12);
  max-height:420px;overflow-y:auto;
}
.search-wrap.open .search-dropdown{display:block;}
.search-dd-head{padding:12px 16px;font-size:9px;letter-spacing:3px;color:var(--t4);text-transform:uppercase;border-bottom:1px solid var(--br);}
.search-result{
  display:flex;align-items:center;gap:12px;
  padding:12px 16px;cursor:pointer;transition:background .15s;
  border-bottom:1px solid var(--br);
}
.search-result:last-child{border-bottom:none;}
.search-result:hover{background:var(--s2);}
.sr-img{width:44px;height:44px;background:var(--s2);display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden;}
.sr-img img{width:100%;height:100%;object-fit:contain;}
.sr-cat{font-size:8px;letter-spacing:2px;color:var(--g);text-transform:uppercase;margin-bottom:2px;}
.sr-name{font-size:12px;font-weight:500;color:var(--t2);}
.sr-price{font-size:11px;color:var(--t3);margin-top:1px;}
.sr-empty{padding:20px 16px;font-size:11px;color:var(--t4);text-align:center;font-style:italic;}
.search-dd-footer{padding:10px 16px;font-size:9px;letter-spacing:2px;color:var(--g);text-transform:uppercase;cursor:pointer;text-align:center;border-top:1px solid var(--br);}
.search-dd-footer:hover{background:var(--s2);}

/* ── PROMO BANNER (PREMIUM) ── */
.promo-banner{
  height:52px;
  background:var(--g);
  color:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
  font-family:'Cormorant Garamond',serif;
  font-size:13px;
  letter-spacing:3px;
  font-weight:300;
  text-align:center;
  text-transform:uppercase;
  padding:0 48px;
  transition:background .3s;
  position:relative;
}

/* Líneas decorativas antes y después */
.promo-banner::before,
.promo-banner::after{
  content:'';
  position:absolute;
  width:32px;
  height:1px;
  background:rgba(255,255,255,0.6);
}
.promo-banner::before{left:48px;}
.promo-banner::after{right:48px;}

/* Responsive */
@media (max-width:960px){
  .promo-banner{
    font-size:12px;
    letter-spacing:2.5px;
    padding:0 24px;
    height:48px;
  }
  .promo-banner::before,
  .promo-banner::after{
    width:24px;
  }
  .promo-banner::before{left:24px;}
  .promo-banner::after{right:24px;}
}

@media (max-width:560px){
  .promo-banner{
    font-size:11px;
    letter-spacing:2px;
    padding:0 16px;
    height:52px;
  }
  .promo-banner::before,
  .promo-banner::after{
    width:16px;
  }
  .promo-banner::before{left:16px;}
  .promo-banner::after{right:16px;}
}

.pg{display:none;} .pg.on{display:block;}

/* ══ HERO (ORIGINAL) ══ */
.hero{
  display:grid;grid-template-columns:1fr 1fr;
  min-height:540px;
  background:var(--s);
  border-bottom:1px solid var(--br);
  transition:background .3s;
}
.hero-product{
  display:flex;align-items:center;justify-content:center;
  background:#F5F6F6;
  position:relative;overflow:hidden;
  border-right:1px solid var(--br);
  padding:64px;
  transition:background .3s;
}
.hero-product img{
  width:58%;max-width:260px;
  object-fit:contain;
  filter:drop-shadow(0 24px 56px rgba(0,0,0,.18));
  animation:floatIn .9s cubic-bezier(.22,1,.36,1) both;
  transition:opacity .38s ease, transform .45s cubic-bezier(.22,1,.36,1);
}
@keyframes floatIn{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}
.hero-skeleton{
  width:58%;max-width:260px;height:300px;
  background:linear-gradient(110deg, var(--s2) 30%, var(--br) 50%, var(--s2) 70%);
  background-size:200% 100%;
  animation:shimmer 1.6s linear infinite;
}
@keyframes shimmer{from{background-position:200% 0}to{background-position:-200% 0}}
.hero-product-label{
  position:absolute;bottom:32px;left:32px;
  font-size:8px;letter-spacing:3px;color:var(--t4);text-transform:uppercase;
}
.hero-product-badge{
  position:absolute;top:28px;right:28px;
  background:var(--g);color:#fff;
  font-size:8px;letter-spacing:2px;padding:5px 12px;font-weight:600;text-transform:uppercase;
}
.hero-copy{display:flex;flex-direction:column;justify-content:center;padding:72px 60px;}
.hero-eyebrow{font-size:9px;letter-spacing:5px;color:var(--g);text-transform:uppercase;margin-bottom:18px;display:flex;align-items:center;gap:12px;}
.hero-eyebrow::before{content:'';width:24px;height:1px;background:var(--g);}
.hero-h1{font-family:'Cormorant Garamond',serif;font-size:54px;font-weight:300;line-height:1.08;color:var(--t);margin-bottom:24px;}
.hero-h1 i{color:var(--g);font-style:italic;}
.hero-sub{font-size:12px;line-height:1.9;color:var(--t3);margin-bottom:36px;max-width:340px;font-weight:300;}
.hero-btns{display:flex;gap:12px;margin-bottom:44px;}
.btn-fill{height:44px;padding:0 28px;background:var(--g);color:#fff;border:none;font-family:'Montserrat',sans-serif;font-size:9px;letter-spacing:2.5px;text-transform:uppercase;font-weight:600;cursor:pointer;transition:background .15s;}
.btn-fill:hover{background:var(--gh);}
.btn-line{height:44px;padding:0 28px;background:transparent;color:var(--t2);border:1px solid var(--br);font-family:'Montserrat',sans-serif;font-size:9px;letter-spacing:2.5px;text-transform:uppercase;cursor:pointer;transition:all .15s;}
.btn-line:hover{border-color:var(--g);color:var(--g);}
.hero-stats{display:flex;gap:0;border-top:1px solid var(--br);padding-top:28px;}
.hstat{padding-right:28px;margin-right:28px;border-right:1px solid var(--br);}
.hstat:last-child{border-right:none;margin-right:0;}
.hstat-n{font-family:'Cormorant Garamond',serif;font-size:26px;font-weight:300;color:var(--g);}
.hstat-l{font-size:8px;letter-spacing:2.5px;color:var(--t4);text-transform:uppercase;margin-top:3px;}

/* ══ HERO FULLWIDTH (NUEVO) ══ */
.hero-new{
  display:flex;flex-direction:column;gap:48px;
  align-items:stretch;margin-bottom:96px;
}
.hero-new-image{
  position:relative;width:100%;
  height:480px;
  background:var(--s2);border-radius:2px;overflow:hidden;
}
/* ── HERO OVERLAY (LOGO + BOTÓN) ── */
.hero-overlay{
  position:absolute;
  inset:0;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:space-between;
  padding:48px 48px;
  pointer-events:none;
  z-index:5;
}

.hero-logo{
  font-family:'Cormorant Garamond',serif;
  font-size:48px;  /* ← AUMENTÉ DE 32 A 48 */
  font-weight:700;  /* ← AUMENTÉ DE 600 A 700 (más relleno) */
  letter-spacing:3px;  /* ← AUMENTÉ spacing */
  color:#fff;
  text-transform:uppercase;
  line-height:1.3;
  text-shadow:0 2px 8px rgba(0,0,0,0.2);
  text-align:center;
  width:100%;
}


.hero-cta-btn{
  padding:12px 40px;
  background:transparent;
  color:#fff;
  border:1.5px solid #fff;
  cursor:pointer;
  font-size:10px;
  letter-spacing:3px;
  text-transform:uppercase;
  font-weight:400;
  transition:all .3s cubic-bezier(.22,1,.36,1);
  font-family:'Montserrat',sans-serif;
  border-radius:0;
  pointer-events:auto;
}

.hero-cta-btn:hover{
  background:rgba(255,255,255,0.1);
  border-color:#fff;
  transform:scale(1.05);
}

/* ── WATERMARK LOGO ── */
/* ── WATERMARK LOGO (RECTÁNGULO DORADO) ── */
.hero-watermark{
  position:absolute;
  bottom:20px;
  right:20px;
  width:80px;
  height:80px;
  background:var(--g);
  border-radius:4px;
  display:flex;
  align-items:center;
  justify-content:center;
  z-index:4;
  box-shadow:0 4px 12px rgba(0,0,0,0.2);
}

.hero-watermark svg{
  width:100%;
  height:100%;
  filter:drop-shadow(0 2px 4px rgba(0,0,0,0.1));
}

@media (max-width:960px){
  .hero-watermark{
    width:70px;
    height:70px;
    bottom:16px;
    right:16px;
  }
}

@media (max-width:560px){
  .hero-watermark{
    width:60px;
    height:60px;
    bottom:12px;
    right:12px;
  }
}

/* Responsive */
@media (max-width:960px){
  .hero-overlay{
    padding:32px 24px;
  }
  .hero-logo-box{
    padding:12px 24px;
  }
  .hero-logo{
    font-size:36px;
    letter-spacing:2.5px;
  }
  .hero-cta-btn{
    font-size:9px;
    padding:10px 32px;
    letter-spacing:2.5px;
  }
}

@media (max-width:560px){
  .hero-overlay{
    padding:24px 16px;
  }
  .hero-logo-box{
    padding:10px 20px;
  }
  .hero-logo{
    font-size:28px;
    letter-spacing:2px;
  }
  .hero-cta-btn{
    font-size:8px;
    padding:8px 24px;
    letter-spacing:2px;
  }
}

.hero-new-image img{width:100%;height:100%;object-fit:cover;}
.hero-new-copy{
  display:flex;flex-direction:column;gap:24px;
  text-align:center;max-width:700px;margin:0 auto;
  padding:0 48px;
}
.hero-new-copy .hero-eyebrow{
  display:block;
  margin-bottom:16px;
}
.hero-new-copy .hero-eyebrow::before{
  display:none;
}
.hero-new-copy .hero-h1{
  font-size:64px;
  margin-bottom:20px;
}
.hero-new-copy .hero-sub{
  font-size:15px;
  margin-bottom:24px;
  max-width:100%;
}
.hero-new-copy .btn-fill{
  align-self:center;
  height:auto;
  padding:14px 36px;
}

/* ── CATEGORIES SECTION (NUEVO) ── */
.categories-section{
  padding:56px 48px;
  background:var(--s);
  border-bottom:1px solid var(--br);
}
.cat-section-title{
  margin-bottom:48px;
  text-align:center;
}
.cat-eyebrow{
  font-size:9px;
  letter-spacing:4px;
  color:var(--g);
  text-transform:uppercase;
  margin-bottom:8px;
}
.cat-section-h{
  font-family:'Cormorant Garamond',serif;
  font-size:30px;
  font-weight:300;
  color:var(--t);
}
.cats-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:48px;
}
.cat-card{
  cursor:pointer;
  transition:transform .3s;
  position:relative;
}
.cat-card:hover{
  transform:translateY(-8px);
}
.cat-img-wrap{
  width:100%;
  aspect-ratio:1;
  background:var(--s2);
  border-radius:2px;
  overflow:hidden;
  margin-bottom:16px;
}
.cat-img-wrap img{
  width:100%;
  height:100%;
  object-fit:cover;
}
.cat-card-label{
  font-family:'Cormorant Garamond',serif;
  font-size:24px;
  color:var(--t);
  font-weight:300;
  margin-bottom:6px;
}
.cat-card-count{
  font-size:10px;
  color:var(--t4);
  letter-spacing:1px;
}

/* ── EDITORIAL SECTIONS (NUEVO) ── */
.editorial-section{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:64px;
  align-items:center;
  padding:56px 48px;
  background:var(--s);
  border-bottom:1px solid var(--br);
}
.editorial-image{
  width:100%;
  aspect-ratio:1.2;
  background:var(--s2);
  border-radius:2px;
  overflow:hidden;
}
.editorial-image img{
  width:100%;
  height:100%;
  object-fit:cover;
}
.editorial-copy{
  display:flex;
  flex-direction:column;
  gap:16px;
}
.edit-eyebrow{
  font-size:9px;
  letter-spacing:4px;
  color:var(--g);
  text-transform:uppercase;
}
.edit-h{
  font-family:'Cormorant Garamond',serif;
  font-size:36px;
  font-weight:300;
  color:var(--t);
  line-height:1.2;
}
.edit-p{
  font-size:13px;
  color:var(--t3);
  line-height:1.7;
}
.btn-line{
  align-self:flex-start;
  padding:0;
  background:none;
  border:none;
  border-bottom:1px solid var(--g);
  color:var(--g);
  font-size:10px;
  letter-spacing:2px;
  text-transform:uppercase;
  font-weight:600;
  cursor:pointer;
  transition:border-color .2s;
  font-family:'Montserrat',sans-serif;
  padding-bottom:2px;
  height:auto;
}
.btn-line:hover{
  border-bottom-color:var(--gh);
}
.editorial-section-alt-2{
  direction:rtl;
}
.editorial-section-alt-2 > *{
  direction:ltr;
}

/* marquee */
.marquee{background:var(--g);height:38px;overflow:hidden;display:flex;align-items:center; display: none;}
.marquee-track{display:inline-flex;animation:mq 22s linear infinite;white-space:nowrap;}
.marquee-track span{font-size:8px;letter-spacing:4px;color:rgba(255,255,255,.85);text-transform:uppercase;margin:0 28px;}
.marquee-track span.dot{color:rgba(255,255,255,.4);margin:0 4px;font-size:6px;}
@keyframes mq{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ── CATEGORIES BAR ── */
.cats{display:grid;grid-template-columns:repeat(4,1fr);background:var(--s);border-bottom:1px solid var(--br);transition:background .3s;}
.cat{
  padding:22px 28px;border-right:1px solid var(--br);
  cursor:pointer;transition:background .2s;
  display:flex;align-items:center;justify-content:space-between;
}
.cat:last-child{border-right:none;}
.cat:hover{background:var(--gp);}
body.dark .cat:hover{background:rgba(184,149,42,0.07);}
.cat.active .cat-l{color:var(--g);}
.cat.soon{opacity:.55;cursor:not-allowed;}
.cat.soon:hover{background:transparent;}
.cat-l{font-size:11px;font-weight:500;color:var(--t2);}
.cat-n{font-size:9px;letter-spacing:1px;color:var(--t4);margin-top:2px;}
.cat-arr{font-size:12px;color:var(--g);opacity:0;transition:opacity .2s;}
.cat:hover:not(.soon) .cat-arr{opacity:1;}

/* ── SECTION & GRID ── */
.section{padding:56px 48px;}
.section-head{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:36px;}
.sec-ey{font-size:9px;letter-spacing:4px;color:var(--g);text-transform:uppercase;margin-bottom:8px;}
.sec-h{font-family:'Cormorant Garamond',serif;font-size:30px;font-weight:300;color:var(--t);}
.sec-link{font-size:10px;letter-spacing:1.5px;color:var(--t3);cursor:pointer;border-bottom:1px solid var(--br);padding-bottom:2px;transition:color .15s;}
.sec-link:hover{color:var(--g);border-color:var(--g);}

.prod-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--br);border:1px solid var(--br);}
.pc{background:var(--s);cursor:pointer;transition:background .2s;position:relative;overflow:hidden;}
.pc:hover{background:var(--s2);}

.pc-img{
  height:220px;
  background:var(--product-bg);
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;
  border-bottom:1px solid var(--br);
  transition:background .2s;
}
.pc:hover .pc-img{ background:var(--product-bg-hover); }

body.dark .pc-img,
body.dark .hero-product,
body.dark .modal-gallery,
body.dark .mg-thumb{
  background:var(--product-bg);
}

.pc-img img{
  height:78%;width:78%;object-fit:contain;
  transition:transform .4s cubic-bezier(.22,1,.36,1);
}
.pc:hover .pc-img img{transform:scale(1.08) translateY(-4px);}
.pc-img .pc-noimg{
  font-family:'Cormorant Garamond',serif;font-style:italic;
  color:var(--t4);font-size:14px;letter-spacing:1px;
}
.pc-badge{position:absolute;top:12px;left:12px;font-size:7px;letter-spacing:2px;padding:3px 9px;font-weight:600;font-family:'Montserrat',sans-serif;text-transform:uppercase;z-index:2;}
.badge-new{background:var(--t);color:#fff;}
body.dark .badge-new{background:var(--g);color:#111;}
.badge-top{background:var(--g);color:#fff;}
.badge-out{background:transparent;color:var(--t4);border:1px solid var(--br);}
.pc-body{padding:18px 20px 22px;}
.pc-cat{font-size:8px;letter-spacing:2.5px;color:var(--g);margin-bottom:5px;text-transform:uppercase;font-weight:500;}
.pc-name{font-family:'Cormorant Garamond',serif;font-size:19px;color:var(--t);margin-bottom:10px;line-height:1.2;min-height:46px;}
.pc-foot{display:flex;align-items:center;justify-content:space-between;padding-top:12px;border-top:1px solid var(--br);}
.pc-price{font-size:14px;font-weight:600;color:var(--t2);font-family:'Montserrat',sans-serif;}
.pc-btn{font-size:8px;letter-spacing:1.5px;padding:6px 12px;border:1px solid var(--br);background:transparent;color:var(--g);cursor:pointer;font-family:'Montserrat',sans-serif;text-transform:uppercase;transition:all .15s;}
.pc-btn:hover{background:var(--g);color:#fff;border-color:var(--g);}

/* skeleton de product card */
.pc.skeleton .pc-img,
.pc.skeleton .pc-name,
.pc.skeleton .pc-cat,
.pc.skeleton .pc-price{
  background:linear-gradient(110deg, #F5F5F5 30%, #E8E8E8 50%, #F5F5F5 70%);
  background-size:200% 100%;
  animation:shimmer 1.6s linear infinite;
  color:transparent;border-radius:2px;
}
.pc.skeleton .pc-img{height:220px;}
.pc.skeleton .pc-name{height:22px;margin-bottom:10px;}
.pc.skeleton .pc-cat{height:10px;width:60%;}
.pc.skeleton .pc-price{height:16px;width:40%;}

/* ══ CATALOG PAGE ══ */
.cat-pg-header{
  padding:32px 48px 24px;background:var(--s);
  border-bottom:1px solid var(--br);
  display:flex;align-items:flex-end;justify-content:space-between;
  transition:background .3s;
}
.breadcrumb{font-size:10px;color:var(--t4);margin-bottom:12px;}
.breadcrumb a{color:var(--t3);cursor:pointer;}
.breadcrumb a:hover{color:var(--g);}
.catalog-meta{font-size:10px;letter-spacing:2px;color:var(--t4);text-transform:uppercase;}

.cat-layout{display:grid;grid-template-columns:240px 1fr;}
.sidebar{
  background:var(--s);border-right:1px solid var(--br);
  padding:28px 22px;min-height:600px;
  transition:background .3s;
}
.sb-grp{margin-bottom:22px;}
.sb-title{font-size:9px;letter-spacing:2.5px;text-transform:uppercase;font-weight:600;color:var(--t2);margin-bottom:12px;}
.sb-search,.sb-select{
  width:100%;height:34px;padding:0 10px;
  background:var(--bg);border:1px solid var(--br);
  font-family:'Montserrat',sans-serif;font-size:11px;color:var(--t);
  outline:none;
}
.sb-search:focus,.sb-select:focus{border-color:var(--g);}
.sb-row{display:flex;align-items:center;justify-content:space-between;padding:5px 0;}
.sb-row label{display:flex;align-items:center;gap:8px;font-size:11px;color:var(--t3);cursor:pointer;}
.sb-row input{accent-color:var(--g);width:13px;height:13px;}
.sb-sep{height:1px;background:var(--br);margin:0 0 22px;}
.cat-main{background:var(--bg);padding:24px 32px;transition:background .3s;}
.cat-main .prod-grid{grid-template-columns:repeat(3,1fr);}

/* ── ABOUT ── */
.about-wrap{max-width:760px;margin:0 auto;padding:80px 48px;}
.about-h{font-family:'Cormorant Garamond',serif;font-size:44px;font-weight:300;line-height:1.15;color:var(--t);margin:16px 0 24px;}
.about-h::after{content:'';display:block;width:48px;height:2px;background:var(--g);margin-top:24px;}
.about-p{font-size:13px;line-height:1.9;color:var(--t3);font-weight:300;}

/* ── FOOTER ── */
footer{
  background:var(--s);border-top:1px solid var(--br);
  padding:30px 48px;
  display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:18px;
  transition:background .3s;
}
.flogo{font-family:'Cormorant Garamond',serif;font-size:18px;letter-spacing:6px;color:var(--g);font-weight:600;}
.fcopy{font-size:10px;color:var(--t4);letter-spacing:1px;}
.flinks{display:flex;gap:22px;}
.flinks a{font-size:9px;letter-spacing:2px;text-transform:uppercase;color:var(--t3);cursor:pointer;}
.flinks a:hover{color:var(--g);}

/* ═══════════════════════════════════════════════════════════
   MODAL — galería de producto con carrusel (7 imágenes)
   ═══════════════════════════════════════════════════════════ */
.modal{
  position:fixed;inset:0;z-index:1000;
  display:none;align-items:center;justify-content:center;
  padding:24px;
}
.modal.open{display:flex;}
.modal-backdrop{
  position:absolute;inset:0;
  background:rgba(12,11,10,0.72);
  backdrop-filter:blur(8px);
  animation:fade .25s ease both;
}
@keyframes fade{from{opacity:0}to{opacity:1}}
.modal-card{
  position:relative;z-index:1;
  width:min(1080px, 100%);
  max-height:90vh;
  min-height:520px;
  background:var(--s);border:1px solid var(--br);
  display:grid;grid-template-columns:1.3fr 1fr;
  overflow:hidden;
  animation:lift .35s cubic-bezier(.22,1,.36,1) both;
}
@keyframes lift{from{opacity:0;transform:translateY(20px) scale(.98)}to{opacity:1;transform:none}}
.modal-close{
  position:absolute;top:12px;right:12px;z-index:5;
  width:36px;height:36px;border:1px solid var(--br);background:var(--s);
  font-size:22px;cursor:pointer;color:var(--t2);
  display:flex;align-items:center;justify-content:center;
  transition:all .15s;
}
.modal-close:hover{background:var(--g);color:#fff;border-color:var(--g);}

/* gallery */
.modal-gallery{display:flex;flex-direction:column;background:#F5F5F5;border-right:1px solid var(--br);}
.mg-main{
  position:relative;flex:1;
  display:flex;align-items:center;justify-content:center;
  min-height:380px;
  max-height:560px;
  padding:32px;
}
.mg-stage{
  width:100%;
  height:380px;
  display:flex;
  align-items:center;
  justify-content:center;
}
.mg-stage img{
  max-width:100%;
  max-height:100%;
  width:auto;
  height:auto;
  object-fit:contain;
  animation:swap .3s ease both;
}
@keyframes swap{from{opacity:0;transform:scale(.97)}to{opacity:1;transform:none}}
.mg-arrow{
  position:absolute;top:50%;transform:translateY(-50%);
  width:40px;height:40px;border-radius:50%;
  background:var(--s);border:1px solid var(--br);
  font-size:20px;cursor:pointer;color:var(--t2);
  display:flex;align-items:center;justify-content:center;
  transition:all .15s;z-index:2;
}
.mg-arrow:hover{background:var(--g);color:#fff;border-color:var(--g);}
.mg-prev{left:16px;}
.mg-next{right:16px;}
.mg-counter{
  position:absolute;bottom:16px;right:16px;
  font-size:10px;letter-spacing:3px;color:var(--t4);
  background:var(--s);padding:4px 10px;border:1px solid var(--br);
}
.mg-thumbs{
  display:flex;gap:6px;padding:14px 16px;
  background:var(--s);border-top:1px solid var(--br);
  overflow-x:auto;
}

.mg-thumb{
  flex-shrink:0;width:60px;height:60px;
  background:var(--product-bg);
  border:1px solid var(--br);
  cursor:pointer;padding:4px;
  transition:all .15s;
}

.mg-thumb img{width:100%;height:100%;object-fit:contain;}
.mg-thumb.on{border-color:var(--g);}
.mg-thumb:hover{border-color:var(--g);}

/* info */
.modal-info{padding:36px 36px 32px;display:flex;flex-direction:column;overflow-y:auto;}
.mi-cat{font-size:9px;letter-spacing:3px;color:var(--g);text-transform:uppercase;margin-bottom:10px;}
.mi-name{font-family:'Cormorant Garamond',serif;font-size:30px;font-weight:300;line-height:1.15;color:var(--t);margin-bottom:8px;}
.mi-sku{font-size:10px;letter-spacing:2px;color:var(--t4);text-transform:uppercase;margin-bottom:24px;}
.mi-price{font-family:'Cormorant Garamond',serif;font-size:36px;font-weight:400;color:var(--g);margin-bottom:6px;}
.mi-stock{font-size:10px;letter-spacing:2px;text-transform:uppercase;margin-bottom:24px;}
.mi-stock.in{color:#3a8a3a;}
.mi-stock.out{color:var(--t4);}
.mi-desc{
  font-size:12px;
  line-height:1.9;
  color:var(--t3);
  font-weight:300;
  margin-bottom:28px;
  max-width:95%;
}
.mi-btns{display:flex;gap:10px;}
.mi-cart-zone{
  margin-top:28px;
  padding-top:22px;
  border-top:1px solid var(--br);
}

.mi-cart-info{
  font-size:10px;
  letter-spacing:1.5px;
  text-transform:uppercase;
  color:var(--t4);
  margin-bottom:14px;
}

.mi-cart-actions {
  display: flex;
  flex-direction: row;
  gap: 10px;
  align-items: stretch;
}

.mi-cart-actions button{
  flex:1;
  height:52px;
}

.mi-cart-actions .nbtn,
.mi-cart-actions button {
  flex: 1;
  min-width: 0;
  white-space: nowrap;
  font-size: 11px;
  padding: 0 12px;
}

.mi-btn-secondary{
  min-width:170px;
  height:48px;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:0 22px;
  background:var(--s);
  color:var(--t2);
  border:1px solid var(--br);
  font-size:11px;
  letter-spacing:2px;
  text-transform:uppercase;
  font-weight:500;
  cursor:pointer;
  transition:all .18s;
}

.mi-btn-secondary:hover{
  border-color:var(--g);
  color:var(--g);
  background:#faf7f0;
}

.mi-btn-primary.added{
  transform:scale(1.02);
  opacity:.92;
}

.mi-btn-primary,
.mi-btn-secondary{
  transition:all .18s;
}

/* ── empty / error states ── */
.empty-state{
  grid-column:1/-1;
  padding:80px 24px;text-align:center;
  color:var(--t4);background:var(--s);
}
.empty-state h3{font-family:'Cormorant Garamond',serif;font-size:24px;font-weight:300;color:var(--t2);margin-bottom:8px;}
.empty-state p{font-size:11px;letter-spacing:1px;}

/* ── responsive ── */

@media (max-width: 960px){
  .hero{grid-template-columns:1fr;}
  .hero-product{border-right:none;border-bottom:1px solid var(--br);}
  .hero-h1{font-size:42px;}

  .hero-new{gap:32px;margin-bottom:64px;}
  .hero-new-image{height:400px;}
  .hero-new-copy{padding:0 24px;}
  .hero-new-copy .hero-h1{font-size:48px;}

  .categories-section{padding:40px 24px;}
  .cats-grid{grid-template-columns:repeat(2,1fr);gap:32px;}

  .editorial-section{
    grid-template-columns:1fr;
    gap:32px;
    padding:40px 24px;
  }

  .prod-grid,
  .cat-main .prod-grid{grid-template-columns:repeat(2,1fr);}

  .cats{grid-template-columns:repeat(2,1fr);}

  .cat-layout{grid-template-columns:1fr;}
  .sidebar{
    min-height:auto;
    border-right:none;
    border-bottom:1px solid var(--br);
  }

  nav{padding:0 20px;}
  .nav-links{display:none;}
  .section{padding:40px 20px;}
  .tabs{padding:0 20px;overflow-x:auto;}

  .nav-r{gap:6px;}
  .nbtn{
    font-size:8px;
    padding:0 10px;
    line-height:1.2;
    height:auto;
    min-height:32px;
    white-space:normal;
    max-width:90px;
  }

  .hero-product{
    padding:48px 20px;
    min-height:320px;
  }
  .hero-product img{
    width:auto;
    max-width:70%;
    max-height:280px;
  }
  .hero-product-label{bottom:16px;left:20px;}
  .hero-product-badge{top:16px;right:16px;}

  .hero-copy{padding:48px 24px;}
  .hero-sub{max-width:100%;}

  .hero-stats{
    flex-wrap:wrap;
    gap:16px 0;
  }
  .hstat{
    padding-right:16px;
    margin-right:16px;
  }

  .modal{
    padding:0 !important;
    align-items:flex-start !important;
    overflow-y:auto !important;
  }
  .modal-card{
    width:100vw !important;
    max-width:100vw !important;
    min-width:0 !important;
    min-height:0 !important;
    height:auto !important;
    max-height:none !important;
    grid-template-columns:1fr !important;
    grid-template-rows:auto auto !important;
    overflow:visible !important;
    border:none !important;
  }
  .modal-gallery{
    width:100% !important;
    max-width:100% !important;
    overflow:visible !important;
  }
  .mg-main{
    padding:48px 56px 16px !important;
    width:100% !important;
    min-height:0 !important;
    max-height:none !important;
    box-sizing:border-box !important;
  }
  .mg-stage{
    width:100% !important;
    height:auto !important;
    min-height:auto !important;
    max-height:none !important;
    overflow:visible !important;
    display:flex !important;
    align-items:center !important;
    justify-content:center !important;
  }
  .mg-stage img{
    width:auto !important;
    height:auto !important;
    max-width:90% !important;
    max-height:50vh !important;
    object-fit:contain !important;
    display:block !important;
  }

  .mg-thumbs{
    width:100% !important;
    max-width:100vw !important;
    box-sizing:border-box !important;
    overflow-x:auto !important;
    -webkit-overflow-scrolling:touch !important;
    flex-wrap:nowrap !important;
  }
  .mg-thumb{
    flex-shrink:0 !important;
    width:54px !important;
    height:54px !important;
  }

  .modal-close{
    width:40px;height:40px;
    top:10px;right:10px;
    font-size:24px;
  }
  .mg-arrow{
    width:38px;height:38px;
  }
  .mg-prev{left:6px;}
  .mg-next{right:6px;}

  .modal-info{
    padding:24px 20px 28px !important;
    width:100% !important;
    max-width:100% !important;
    box-sizing:border-box !important;
    overflow:visible !important;
  }
  .mi-name{font-size:24px;}
  .mi-price{font-size:30px;}
  .mi-btns button{flex:1;}

  .search-bar{
    width:160px;
    padding:0 10px;
  }
  .search-bar:focus-within{
    width:200px;
  }

  .mi-cart-actions {
    flex-direction: row !important;
  }
  .mi-cart-actions .nbtn,
  .mi-cart-actions button {
    font-size: 10px;
    letter-spacing: 1px;
    padding: 0 8px;
  }

  .mi-btn-primary,
  .mi-btn-secondary{
    width:100%;
  }
}

@media (max-width: 560px){
  .prod-grid,
  .cat-main .prod-grid{grid-template-columns:1fr;}
  .hero-copy{padding:48px 28px;}
  .hero-h1{font-size:36px;}

  .hero-new-image{height:280px;}
  .hero-new-copy{padding:0 16px;}
  .hero-new-copy .hero-h1{font-size:32px;}

  .categories-section{padding:24px 16px;}
  .cats-grid{grid-template-columns:1fr;gap:16px;}
  .cat-section-h{font-size:24px;}

  .editorial-section{
    grid-template-columns:1fr;
    gap:24px;
    padding:24px 16px;
  }
  .editorial-section-alt-2{direction:ltr;}

  .search-bar{
    width:140px;
  }
  .search-bar:focus-within{
    width:160px;
  }
}

/* ── CATEGORY TABS (catálogo) ── */
.cat-tabs{
  display:flex;gap:0;
  background:var(--s);border-bottom:1px solid var(--br);
  padding:0 48px;overflow-x:auto;
}
.cat-tab{
  font-size:10px;letter-spacing:2.5px;text-transform:uppercase;
  padding:16px 22px;color:var(--t4);cursor:pointer;
  border-bottom:2px solid transparent;
  transition:all .2s;font-weight:500;flex-shrink:0;
}
.cat-tab:hover{color:var(--t2);}
.cat-tab.on{color:var(--g);border-bottom-color:var(--g);}

/* ── LOGO (imagen Stile) ── */
.logo-link{
  display:inline-flex;align-items:center;
  height:100%;
  text-decoration:none;
  transition:opacity .2s;
}
.logo-link:hover{opacity:0.8;}

.logo-img{
  height:42px;
  width:auto;
  display:block;
  object-fit:contain;
  filter:drop-shadow(0 1px 2px rgba(0,0,0,.08));
  transition:filter .3s;
}

body.dark .logo-img{
  filter:drop-shadow(0 1px 3px rgba(0,0,0,.4)) brightness(1.15);
}

.mg-thumbs::-webkit-scrollbar{display:none;}
.mg-thumbs{scrollbar-width:none;}

@media (max-width: 560px){
  .logo-img{height:34px;}
}

/* ══════════════════════════════════════
   MOBILE NAV  (≤ 768px)
══════════════════════════════════════ */
@media (max-width: 768px) {

  nav {
    padding: 0 16px;
    height: 56px;
    position: sticky; top: 0; z-index: 200;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
  }
  .nav-links    { display: none; }
  .auth-buttons { display: none; }
  #guestButtons { display: none !important; }
  #userMenu     { display: none !important; }

  .nav-r {
    display: flex;
    align-items: center;
    gap: 4px;
    flex: 1;
    justify-content: flex-end;
  }

  .search-wrap {
    flex: 1;
    position: relative;
    max-width: 100%;
  }

  .search-bar {
    display: flex;
    align-items: center;
    height: 34px;
    border: 1px solid var(--br);
    padding: 0 10px;
    gap: 6px;
    background: var(--s);
  }

  .search-input {
    flex: 1;
    border: none;
    background: none;
    font-size: 10px;
    letter-spacing: 1px;
    color: var(--t);
    outline: none;
  }

  .search-icon {
    width: 14px; height: 14px;
    color: var(--t3);
    flex-shrink: 0;
  }

  .cart-trigger,
  .tbtn {
    flex-shrink: 0;
  }

  .hamburger {
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 5px;
    width: 36px; height: 36px;
    background: none;
    border: none;
    cursor: pointer;
    padding: 6px;
    flex-shrink: 0;
  }
  .hamburger span {
    display: block;
    height: 1.5px;
    background: var(--t);
    border-radius: 2px;
    transition: transform .3s, opacity .3s;
  }
  .hamburger.open span:nth-child(1) { transform: translateY(6.5px) rotate(45deg); }
  .hamburger.open span:nth-child(2) { opacity: 0; }
  .hamburger.open span:nth-child(3) { transform: translateY(-6.5px) rotate(-45deg); }

  .mobile-drawer {
    position: fixed;
    top: 56px; left: 0; right: 0; bottom: 0;
    background: var(--s);
    border-top: 1px solid var(--br);
    display: flex;
    flex-direction: column;
    padding: 0;
    gap: 0;
    z-index: 199;
    transform: translateX(100%);
    transition: transform .3s cubic-bezier(.4,0,.2,1);
    overflow-y: auto;
  }
  .mobile-drawer.open { transform: translateX(0); }

  .mobile-drawer .drawer-link {
    font-family: 'Montserrat', sans-serif;
    font-size: 11px;
    letter-spacing: 3px;
    text-transform: uppercase;
    color: var(--t3);
    text-decoration: none;
    padding: 20px 24px;
    border-bottom: 1px solid var(--br);
    border-top: none; border-left: none; border-right: none;
    background: none;
    cursor: pointer;
    text-align: left;
    width: 100%;
    white-space: nowrap;
    transition: color .15s, padding-left .15s;
  }
  .mobile-drawer .drawer-link:hover,
  .mobile-drawer .drawer-link.on { color: var(--g); padding-left: 30px; }

  .drawer-sep {
    display: none;
  }

  .drawer-auth {
    display: flex;
    flex-direction: row;
    gap: 10px;
    padding: 20px 16px;
  }
  .drawer-auth .nbtn {
    display: flex !important;
    align-items: center;
    justify-content: center;
    flex: 1;
    height: 44px;
    font-size: 8px;
    letter-spacing: 1.5px;
    padding: 0 8px;
    white-space: nowrap;
    text-decoration: none;
    box-sizing: border-box;
  }

  .drawer-overlay {
    display: none;
    position: fixed;
    inset: 56px 0 0 0;
    background: rgba(0,0,0,.35);
    z-index: 198;
  }
  .drawer-overlay.open { display: block; }
}

@media (min-width: 769px) {
  .hamburger      { display: none; }
  .mobile-drawer  { display: none; }
  .drawer-overlay { display: none; }
}

@media (max-width: 768px) {
  .search-wrap {
    position: static;
  }

  .search-dropdown {
    position: fixed;
    top: 56px;
    left: 0;
    right: 0;
    width: 100%;
    box-sizing: border-box;
    border-radius: 0;
  }
}

@media (max-width: 768px) {
  .modal { padding: 0; }

  .modal-card {
    grid-template-columns: 1fr;
    grid-template-rows: auto 1fr;
    width: 100%;
    height: 100%;
    max-height: 100dvh;
    min-height: unset;
    border-radius: 0;
  }

  .modal-gallery { border-right: none; border-bottom: 1px solid var(--br); }
  .mg-main { min-height: 220px; max-height: 260px; padding: 16px; }
  .mg-stage { height: 220px; }

  .modal-info { padding: 20px 20px 32px; }
  .mi-name { font-size: 22px; }
  .mi-price { font-size: 28px; }

  .mi-cart-actions {
    flex-direction: row;
    gap: 8px;
  }

  .mi-cart-actions .nbtn,
  .mi-cart-actions button {
    flex: 1;
    min-width: 0;
    max-width: none !important;
    width: auto;
    height: 46px;
    font-size: 9px;
    letter-spacing: 1.5px;
    padding: 0 10px;
    white-space: nowrap !important;
    box-sizing: border-box;
  }
}

.drawer-user-profile {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 20px 24px;
  border-bottom: 1px solid var(--br);
}

.drawer-avatar {
  width: 40px; height: 40px;
  border-radius: 50%;
  background: var(--g);
  color: #fff;
  font-family: 'Montserrat', sans-serif;
  font-size: 14px;
  font-weight: 600;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.drawer-user-info {
  display: flex;
  flex-direction: column;
  gap: 3px;
}

.drawer-user-name {
  font-family: 'Montserrat', sans-serif;
  font-size: 11px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--t);
}

.drawer-user-email {
  font-size: 10px;
  color: var(--t4);
  letter-spacing: 0.5px;
}

.drawer-logout {
  color: #c0392b !important;
}
.drawer-logout:hover {
  color: #e74c3c !important;
  padding-left: 30px;
}

/* Estado disabled del botón del modal */
#miAddToCart:disabled {
  cursor: not-allowed;
  opacity: 0.9;
  background: var(--s2);
  border-color: var(--br);
  color: var(--t4);
}

/* ═══════════════════════════════════════════════════════════
   PRICELIST EN MODAL — precio especial
   ═══════════════════════════════════════════════════════════ */
.mi-price-container{
  margin-bottom:24px;
}

/* Precio tachado (cuando hay descuento) */
.mi-price.mi-price-old{
  font-size:22px;
  color:#a0a0a0;
  font-weight:300;
  text-decoration:line-through;
  text-decoration-thickness:1.5px;
  margin-bottom:8px;
}

/* Fila del precio nuevo + badge */
.mi-pricelist-row{
  display:flex;
  align-items:center;
  gap:14px;
  flex-wrap:wrap;
}

.mi-price-new{
  font-family:'Cormorant Garamond',serif;
  font-size:36px;
  font-weight:400;
  color:var(--g);
  line-height:1;
}

.mi-price-badge{
  display:inline-block;
  padding:6px 14px;
  background:var(--g);
  color:#fff;
  font-size:9px;
  letter-spacing:2.5px;
  font-weight:600;
  text-transform:uppercase;
  font-family:'Montserrat',sans-serif;
  border-radius:2px;
}

/* Responsive */
@media (max-width:768px){
  .mi-price.mi-price-old{
    font-size:18px;
  }
  .mi-price-new{
    font-size:30px;
  }
  .mi-price-badge{
    font-size:8px;
    padding:5px 12px;
    letter-spacing:2px;
  }
}

@media (max-width:560px){
  .mi-pricelist-row{
    gap:10px;
  }
  .mi-price.mi-price-old{
    font-size:16px;
  }
  .mi-price-new{
    font-size:26px;
  }
  .mi-price-badge{
    font-size:8px;
    padding:4px 10px;
  }
}

/* ═══════════════════════════════════════════════════════════
   PRECIO CON PRICELIST EN CARDS
   ═══════════════════════════════════════════════════════════ */
.pc-price-wrap{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  gap:2px;
  line-height:1;
}

.pc-price-old{
  font-size:11px;
  color:#a0a0a0;
  text-decoration:line-through;
  font-weight:300;
  font-family:'Cormorant Garamond',serif;
}

.pc-price-new{
  color:var(--g);
  font-weight:500;
}

/* Responsive */
@media (max-width:560px){
  .pc-price-old{
    font-size:10px;
  }
}