*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
a{color:inherit;text-decoration:none}
:root{
  --cream:#eeddd2;--cream2:#f7f0ea;--cream3:#fdfaf7;--cream4:#e8d4c4;
  --pearl:#f4ece4;--gold:#c9a96e;--gold2:#b8935a;--gold3:#e8d5b0;
  --rose:#d4a0a0;--rose2:#c4847e;--rose3:#f0ddd8;--mink:#8b6f6a;
  --bark:#5c4a3d;--ink:#2c1f1a;--ink2:#4a3530;--white:#fffcf9;
  --shadow:rgba(92,74,61,.12);--shadow2:rgba(92,74,61,.06);
  --serif:'Cormorant Garamond',Georgia,serif;--sans:'DM Sans',system-ui,sans-serif;
  --transition:.3s cubic-bezier(.4,0,.2,1);
  --radius:8px;--radius-sm:4px;--radius-lg:16px;
}
body.dark-mode{
  --cream:#2a1f1a;--cream2:#1e1510;--cream3:#150f0b;--cream4:#3d2e26;
  --pearl:#2e2018;--gold:#c9a96e;--gold2:#b8935a;--gold3:#e8d5b0;
  --rose:#8b4a4a;--rose2:#c4847e;--rose3:#3d2020;--mink:#b09090;
  --bark:#c4a090;--ink:#f0e8e0;--ink2:#d4c4b8;--white:#1a1008;
  --shadow:rgba(0,0,0,.4);--shadow2:rgba(0,0,0,.2);
}
html{scroll-behavior:smooth}
body{font-family:var(--sans);color:var(--ink);background:var(--cream3);overflow-x:hidden}
::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--cream2)}::-webkit-scrollbar-thumb{background:var(--gold);border-radius:3px}

/* ── Visibilidad por dispositivo ── */
.hide-mobile{display:flex!important}
.hide-desktop{display:none!important}
@media(max-width:768px){
  .hide-mobile{display:none!important}
  .hide-desktop{display:flex!important}
}
.reveal{opacity:0;transform:translateY(16px);transition:opacity .4s ease,transform .4s ease}
.reveal.visible{opacity:1;transform:none}
/* Fallback: si JS no carga, los reveals se muestran igual */
.page.active .reveal{animation:revealFallback 0s 1.5s forwards}
@keyframes revealFallback{to{opacity:1;transform:none}}
.reveal-delay-1{transition-delay:.1s}.reveal-delay-2{transition-delay:.2s}.reveal-delay-3{transition-delay:.3s}.reveal-delay-4{transition-delay:.4s}

/* ── Navegación de Páginas ── */
.page {
  display: none;
  contain: layout style;
  content-visibility: auto;
}
.page.active {
  display: block;
  content-visibility: visible;
}

/* ── Secciones Generales ── */
.section {
  max-width: 1320px;
  margin: 0 auto;
  padding: 80px 40px;
}
.section-head {
  text-align: center;
  margin-bottom: 48px;
}
.section-eyebrow {
  display: block;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .15em;
  text-transform: uppercase;
  color: var(--rose2);
  margin-bottom: 12px;
}
.section-title {
  font-family: var(--serif);
  font-size: clamp(32px, 5vw, 48px);
  font-weight: 300;
  font-style: italic;
  color: var(--ink);
  line-height: 1.1;
}
.section-rule {
  width: 60px;
  height: 1px;
  background: var(--gold3);
  margin: 24px auto;
}
.section-sub {
  font-size: 15px;
  color: var(--mink);
  max-width: 500px;
  margin: 0 auto;
  line-height: 1.6;
}

@media (max-width: 768px) {
  .section {
    padding: 60px 20px;
  }
}

/* ── Estilos de la Página de Contacto (legacy — mantenidos por compatibilidad) ── */

/* ════════════════════════════════════════════════
   CONTACTO — Rediseño completo
   ════════════════════════════════════════════════ */

/* Hero */
.cp-hero{
  background:linear-gradient(150deg,#1a1008 0%,#2e1e14 50%,#3d2820 100%);
  padding:52px 40px 44px;text-align:center;position:relative;overflow:hidden;
}
.cp-hero-orb1{
  position:absolute;top:-60px;right:-40px;width:400px;height:400px;border-radius:50%;
  background:radial-gradient(circle,rgba(201,169,110,.08) 0%,transparent 65%);pointer-events:none;
}
.cp-hero-orb2{
  position:absolute;bottom:-80px;left:-60px;width:350px;height:350px;border-radius:50%;
  background:radial-gradient(circle,rgba(196,132,126,.07) 0%,transparent 65%);pointer-events:none;
}
.cp-hero-inner{position:relative;z-index:1;max-width:560px;margin:0 auto}
.cp-eyebrow{
  display:inline-block;font-size:11px;font-weight:700;letter-spacing:.16em;
  text-transform:uppercase;color:rgba(201,169,110,.7);margin-bottom:14px;
}
.cp-title{
  font-family:var(--serif);font-size:clamp(30px,5vw,52px);font-weight:300;
  font-style:italic;color:#e8d5b0;line-height:1.1;margin-bottom:12px;
}
.cp-title em{font-style:normal;color:#d4a0a0}
.cp-sub{font-size:13px;color:rgba(255,255,255,.4);letter-spacing:.02em}

/* Body layout */
.cp-body{
  display:grid;grid-template-columns:1fr 1fr;gap:0;
  max-width:1000px;margin:0 auto;padding:40px 32px 60px;gap:32px;
}

/* ── Columna izquierda ── */
.cp-left{display:flex;flex-direction:column;gap:20px}

/* Botón WA grande */
.cp-wa-btn{
  display:flex;align-items:center;gap:14px;
  background:#25d366;border-radius:16px;padding:18px 20px;
  text-decoration:none;color:#fff;
  box-shadow:0 8px 28px rgba(37,211,102,.3);
  transition:all .25s cubic-bezier(.34,1.3,.64,1);
}
.cp-wa-btn:hover{transform:translateY(-3px);box-shadow:0 14px 36px rgba(37,211,102,.4)}
.cp-wa-icon{font-size:28px;flex-shrink:0;line-height:1}
.cp-wa-text{flex:1;min-width:0}
.cp-wa-label{display:block;font-size:14px;font-weight:700;color:#fff}
.cp-wa-sub{display:block;font-size:11px;color:rgba(255,255,255,.75);margin-top:2px}
.cp-wa-arrow{font-size:18px;color:rgba(255,255,255,.7);flex-shrink:0}

/* Sociales */
.cp-socials{display:flex;flex-direction:column;gap:8px}
.cp-social-row{
  display:flex;align-items:center;gap:12px;
  background:var(--white);border:1.5px solid var(--cream4);border-radius:12px;
  padding:12px 14px;text-decoration:none;color:var(--ink);
  transition:all .2s;
}
.cp-social-row:hover{border-color:var(--gold);transform:translateX(4px)}
.cp-social-icon{font-size:20px;flex-shrink:0;line-height:1}
.cp-social-info{flex:1;min-width:0}
.cp-social-name{display:block;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--mink)}
.cp-social-val{display:block;font-size:13px;font-weight:700;color:var(--ink)}
.cp-social-tag{font-size:11px;color:var(--mink);background:var(--cream2);border:1px solid var(--cream4);border-radius:20px;padding:3px 10px;white-space:nowrap;flex-shrink:0}

/* Info list */
.cp-info-list{
  background:var(--white);border:1.5px solid var(--cream4);border-radius:14px;
  overflow:hidden;
}
.cp-info-row{
  display:flex;align-items:flex-start;gap:12px;padding:14px 16px;
  border-bottom:1px solid var(--cream4);
}
.cp-info-row:last-child{border-bottom:none}
.cp-info-icon{font-size:18px;flex-shrink:0;margin-top:1px;line-height:1}
.cp-info-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--mink);margin-bottom:2px}
.cp-info-val{font-size:13px;color:var(--ink);font-weight:500}

/* FAQ en columna izquierda */
.cp-faq{display:flex;flex-direction:column;gap:10px}
.cp-faq-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--mink)}

/* ── Columna derecha: formulario ── */
.cp-form-card{
  background:var(--white);border:1.5px solid var(--cream4);border-radius:20px;
  padding:28px;box-shadow:0 8px 40px rgba(92,74,61,.1);
  position:sticky;top:90px;
}
.cp-form-head{display:flex;align-items:center;gap:12px;margin-bottom:22px;padding-bottom:18px;border-bottom:1px solid var(--cream4)}
.cp-form-emoji{font-size:28px;line-height:1;flex-shrink:0}
.cp-form-title{font-family:var(--serif);font-size:20px;font-weight:400;font-style:italic;color:var(--ink);line-height:1.2}
.cp-form-sub{font-size:11px;color:var(--mink);margin-top:2px}

.cp-field{margin-bottom:14px}
.cp-field label{
  display:block;font-size:11px;font-weight:700;text-transform:uppercase;
  letter-spacing:.08em;color:var(--ink2);margin-bottom:6px;
}
.cp-field input,.cp-field textarea{
  width:100%;padding:11px 14px;background:var(--cream3);
  border:1.5px solid var(--cream4);border-radius:10px;
  font-family:var(--sans);font-size:13px;color:var(--ink);
  outline:none;transition:all .2s;
}
.cp-field input:focus,.cp-field textarea:focus{
  border-color:var(--gold);background:var(--white);
  box-shadow:0 0 0 3px rgba(201,169,110,.12);
}
.cp-field textarea{resize:none}
.req-star{color:var(--rose2)}

.cp-topic-row{display:flex;flex-wrap:wrap;gap:6px;margin-top:4px}
.cp-topic-btn{
  padding:7px 12px;border:1.5px solid var(--cream4);background:var(--cream2);
  border-radius:20px;font-size:11px;font-weight:700;color:var(--mink);
  cursor:pointer;font-family:var(--sans);transition:all .2s;
  -webkit-tap-highlight-color:transparent;
}
.cp-topic-btn:hover{border-color:var(--gold);color:var(--ink)}
.cp-topic-btn.active{background:var(--rose3);border-color:var(--rose2);color:var(--rose2)}

.cp-submit-btn{
  width:100%;display:flex;align-items:center;justify-content:center;gap:8px;
  background:#25d366;color:#fff;border:none;
  padding:15px;border-radius:12px;font-size:14px;font-weight:700;
  cursor:pointer;font-family:var(--sans);margin-top:4px;
  box-shadow:0 6px 20px rgba(37,211,102,.3);
  transition:all .25s cubic-bezier(.34,1.3,.64,1);
}
.cp-submit-btn:hover{transform:translateY(-2px);box-shadow:0 10px 28px rgba(37,211,102,.4)}
.cp-form-note{font-size:11px;color:var(--mink);text-align:center;margin-top:8px}

/* ── Responsive ── */
@media(max-width:860px){
  .cp-body{grid-template-columns:1fr;gap:24px;padding:28px 20px 48px}
  .cp-form-card{position:static}
}
@media(max-width:480px){
  .cp-hero{padding:36px 16px 32px}
  .cp-title{font-size:clamp(26px,7vw,38px)}
  .cp-body{padding:20px 14px 40px;gap:20px}
  .cp-form-card{padding:20px}
  .cp-wa-btn{padding:14px 16px}
  .cp-wa-icon{font-size:22px}
}

/* ── Dark mode ── */
body.dark-mode .cp-hero{background:linear-gradient(150deg,#0e0a07 0%,#1a1008 50%,#2a1a10 100%)}
body.dark-mode .cp-wa-btn{box-shadow:0 8px 28px rgba(37,211,102,.2)}
body.dark-mode .cp-social-row{background:var(--cream2);border-color:var(--cream4);color:var(--ink)}
body.dark-mode .cp-social-row:hover{border-color:var(--gold)}
body.dark-mode .cp-social-name{color:var(--mink)}
body.dark-mode .cp-social-val{color:var(--ink)}
body.dark-mode .cp-social-tag{background:var(--cream4);border-color:var(--cream4);color:var(--mink)}
body.dark-mode .cp-info-list{background:var(--cream2);border-color:var(--cream4)}
body.dark-mode .cp-info-row{border-color:var(--cream4)}
body.dark-mode .cp-info-label{color:var(--mink)}
body.dark-mode .cp-info-val{color:var(--ink)}
body.dark-mode .cp-form-card{background:var(--cream2);border-color:var(--cream4);box-shadow:0 8px 40px rgba(0,0,0,.3)}
body.dark-mode .cp-form-head{border-color:var(--cream4)}
body.dark-mode .cp-form-title{color:var(--ink)}
body.dark-mode .cp-form-sub{color:var(--mink)}
body.dark-mode .cp-field input,body.dark-mode .cp-field textarea{background:var(--cream3);border-color:var(--cream4);color:var(--ink)}
body.dark-mode .cp-field input:focus,body.dark-mode .cp-field textarea:focus{background:var(--cream2);border-color:var(--gold)}
body.dark-mode .cp-topic-btn{background:var(--cream4);border-color:var(--cream4);color:var(--mink)}
body.dark-mode .cp-topic-btn:hover{border-color:var(--gold);color:var(--ink)}
body.dark-mode .cp-topic-btn.active{background:var(--rose3);border-color:var(--rose2);color:var(--rose2)}
body.dark-mode .cp-faq-title{color:var(--mink)}


/* ── FAQ styles ── */
.faq-list{display:flex;flex-direction:column;gap:8px}
.faq-item{border:1.5px solid var(--cream4);border-radius:12px;overflow:hidden;transition:border-color .2s}
.faq-item.open{border-color:var(--gold)}
.faq-q{
  width:100%;display:flex;align-items:center;justify-content:space-between;
  padding:14px 16px;background:var(--white);border:none;cursor:pointer;
  font-family:var(--sans);font-size:13px;font-weight:600;color:var(--ink);
  text-align:left;transition:background .2s;-webkit-tap-highlight-color:transparent;
}
.faq-q:hover{background:var(--cream2)}
.faq-arrow{font-size:12px;color:var(--mink);transition:transform .25s;flex-shrink:0;margin-left:8px}
.faq-item.open .faq-arrow{transform:rotate(180deg)}
.faq-a{
  max-height:0;overflow:hidden;padding:0 16px;
  font-size:13px;color:var(--mink);line-height:1.6;
  transition:max-height .3s cubic-bezier(.4,0,.2,1),padding .3s;
  background:var(--cream3);
}
.faq-item.open .faq-a{max-height:200px;padding:12px 16px}
body.dark-mode .faq-q{background:var(--cream2);color:var(--ink)}
body.dark-mode .faq-q:hover{background:var(--cream4)}
body.dark-mode .faq-item{border-color:var(--cream4)}
body.dark-mode .faq-item.open{border-color:var(--gold)}
body.dark-mode .faq-a{background:var(--cream3);color:var(--mink)}

/* ── Tap highlight global ── */
a,button{-webkit-tap-highlight-color:transparent}

/* ── Prevent horizontal overflow ── */
img,video{max-width:100%;height:auto}

/* ════════════════════════════════════════════════
   DARK MODE OVERRIDES — elementos con colores hardcodeados
   ════════════════════════════════════════════════ */

/* Header */
body.dark-mode header { background: rgba(21,15,11,.97); border-color: var(--cream4); }
body.dark-mode .hamburger { background: var(--cream2); border-color: var(--cream4); }
body.dark-mode .hamburger span { background: var(--ink); }
body.dark-mode nav a:hover, body.dark-mode nav a.active { background: var(--cream2); border-color: var(--cream4); color: var(--ink); }
body.dark-mode .search-wrap { background: var(--cream2); border-color: var(--cream4); }
body.dark-mode .search-input { color: var(--ink); }
body.dark-mode .search-input::placeholder { color: var(--mink); }
body.dark-mode .action-btn { color: var(--ink2); border-color: var(--cream4); }
body.dark-mode .action-btn:hover { background: var(--cream2); border-color: var(--gold); }

/* Ann bar */
body.dark-mode .ann-bar { background: var(--cream4); color: var(--ink); }
body.dark-mode .ann-dot { color: var(--gold2); }

/* Hero buttons */
body.dark-mode .btn-gold { background: var(--gold); color: #1a0e08; }
body.dark-mode .btn-gold:hover { background: var(--gold2); box-shadow: 0 8px 24px rgba(201,169,110,.25); }
body.dark-mode .btn-outline { background: transparent; color: var(--ink); border-color: rgba(201,169,110,.4); }
body.dark-mode .btn-outline:hover { border-color: var(--gold); color: var(--gold2); }

/* Hero widgets */
body.dark-mode .hwidget { background: rgba(42,31,26,.88); border-color: rgba(61,46,38,.8); box-shadow: 0 4px 24px rgba(0,0,0,.3); }
/* festivo y clima: el JS asigna el color dinámico, solo ajustamos el base */
body.dark-mode .hpd-bg { background: linear-gradient(145deg,#2a1f1a,#1e1510,#3d2020); border-color: rgba(196,132,126,.2); }
body.dark-mode .hpd-title { color: var(--gold2); }
body.dark-mode .hpd-price { color: var(--gold3); }
body.dark-mode .hpd-btn { background: var(--gold); color: #1a0e08; }
body.dark-mode .hpd-btn:hover { background: var(--gold2); }
body.dark-mode .wf-chip { background: rgba(201,169,110,.12); border-color: rgba(201,169,110,.25); color: var(--gold2); }
body.dark-mode .wf-chip-season { background: rgba(100,160,220,.1); border-color: rgba(100,160,220,.2); color: var(--ink2); }

/* Live sales & chat bubble */
body.dark-mode .live-sale-notif { background: rgba(42,31,26,.97); border-color: rgba(196,132,126,.25); }
body.dark-mode .ls-name { color: var(--ink); }
body.dark-mode #chat-bubble { background: rgba(42,31,26,.97); border-color: rgba(196,132,126,.22); }
body.dark-mode #chat-bubble-name { color: var(--ink); }
body.dark-mode #chat-bubble-msg { color: var(--mink); }

/* Why cards */
body.dark-mode .why-card { background: var(--cream2); }
body.dark-mode .why-card:hover { background: var(--cream4); }
body.dark-mode .why-card h4 { color: var(--ink); }
body.dark-mode .why-card p { color: var(--mink); }
body.dark-mode .why-card:hover h4 { color: var(--gold3); }
body.dark-mode .why-card:hover p { color: var(--ink2); }

/* Moment cards */
body.dark-mode .moment-card { background: var(--cream2); box-shadow: 0 10px 30px rgba(0,0,0,.4); }
body.dark-mode .moment-caption { color: var(--mink); }

/* Videos section */
body.dark-mode .videos-section { background: var(--cream2); }
body.dark-mode .video-card { background: var(--cream2); }
body.dark-mode .video-play-icon { background: var(--cream3); color: var(--ink); }

/* Autoscroll */
body.dark-mode .autoscroll-section { background: var(--cream2); }
body.dark-mode .autoscroll-item { background: var(--cream2); box-shadow: 0 2px 12px rgba(0,0,0,.25); }
body.dark-mode .autoscroll-item-name { color: var(--ink); }
body.dark-mode .autoscroll-price { color: var(--mink); }

/* Clientas gallery fades */
body.dark-mode .clientas-gallery::before { background: linear-gradient(to right, var(--cream3), transparent); }
body.dark-mode .clientas-gallery::after  { background: linear-gradient(to left,  var(--cream3), transparent); }

/* Festivo sticker */
body.dark-mode .festivo-sticker { background: rgba(42,31,26,.9); border-color: rgba(201,169,110,.3); color: var(--ink); }

/* FAQ */
body.dark-mode .faq-q { background: var(--cream2); color: var(--ink); }
body.dark-mode .faq-q:hover { background: var(--cream4); }
body.dark-mode .faq-item { border-color: var(--cream4); }

/* Inputs & forms globales */
body.dark-mode input,
body.dark-mode textarea,
body.dark-mode select { background: var(--cream2); border-color: var(--cream4); color: var(--ink); }
body.dark-mode input:focus,
body.dark-mode textarea:focus,
body.dark-mode select:focus { border-color: var(--gold); background: var(--cream3); }
body.dark-mode input::placeholder,
body.dark-mode textarea::placeholder { color: var(--mink); }
body.dark-mode .form-input,
body.dark-mode .form-textarea { background: var(--cream2); border-color: var(--cream4); color: var(--ink); }
body.dark-mode .form-input:focus,
body.dark-mode .form-textarea:focus { background: var(--cream3); border-color: var(--gold); }
body.dark-mode .contact-form { background: var(--cream2); border-color: var(--cream4); }

/* Catalog cards */
body.dark-mode .pack-card { background: var(--cream2); border-color: var(--cream4); }
body.dark-mode .pack-card-img { background: linear-gradient(145deg,var(--cream4),var(--cream2)); }
body.dark-mode .pack-card-name { color: var(--ink); }
body.dark-mode .pack-card-wish { background: rgba(255,255,255,.12); border-color: rgba(255,255,255,.2); color: var(--gold3); }
body.dark-mode .cat-card { background: var(--cream2); border-color: var(--cream4); }
body.dark-mode .cat-card-img { background: linear-gradient(145deg,var(--cream4),var(--cream2)); }
body.dark-mode .card-wish { background: rgba(255,255,255,.12); border-color: rgba(255,255,255,.2); color: var(--gold3); }
body.dark-mode .product-card { background: var(--cream2); border-color: var(--cream4); }
body.dark-mode .filt-btn { background: var(--cream2); border-color: var(--cream4); color: var(--mink); }
body.dark-mode .filt-btn:hover, body.dark-mode .filt-btn.active { background: var(--ink); color: var(--gold3); border-color: var(--ink); }
body.dark-mode .filt-price-btn { background: var(--cream2); border-color: var(--cream4); color: var(--mink); }
body.dark-mode .filt-price-btn:hover, body.dark-mode .filt-price-btn.active { background: var(--gold3); color: var(--ink); border-color: var(--gold3); }
body.dark-mode .search-res-item { background: var(--cream2); border-color: var(--cream4); }
body.dark-mode .search-res-item:hover { background: var(--cream4); }

/* Search results dropdown */
body.dark-mode .search-results { background: var(--cream2); border-color: var(--cream4); }
body.dark-mode .search-results-header { border-color: var(--cream4); }
body.dark-mode .search-trend-chip { background: var(--cream4); border-color: var(--cream4); color: var(--mink); }
body.dark-mode .search-trend-chip:hover { background: var(--ink); color: var(--gold3); border-color: var(--ink); }
body.dark-mode .search-result-item { border-color: var(--cream4); }
body.dark-mode .search-result-item:hover { background: var(--cream4); }
body.dark-mode .search-result-name { color: var(--ink); }

/* Modales */
body.dark-mode .cart-sidebar { background: var(--cream2); border-color: var(--cream4); }
body.dark-mode .cart-header { border-color: var(--cream4); }
body.dark-mode .cart-header h2 { color: var(--ink); }
body.dark-mode .cart-footer { border-color: var(--cream4); background: var(--cream2); }
body.dark-mode .cart-empty { color: var(--mink); }
body.dark-mode .cart-empty-icon { opacity: .4; filter: grayscale(.3); }
body.dark-mode .cart-empty p { color: var(--ink); }
body.dark-mode .cart-empty small { color: var(--mink); }
body.dark-mode .cart-item { border-color: var(--cream4); }
body.dark-mode .cart-item-img { background: var(--cream4); }
body.dark-mode .qty-btn { background: var(--cream2); border-color: var(--cream4); color: var(--ink); }
body.dark-mode .qty-btn:hover { background: var(--gold); border-color: var(--gold); color: #1a0e08; }
body.dark-mode .shipping-bar { background: var(--cream3); border-color: var(--cream4); }
body.dark-mode .shipping-bar-top { color: var(--mink); }
body.dark-mode .shipping-bar-track { background: var(--cream4); }
body.dark-mode .cart-total-row { color: var(--mink); }
body.dark-mode .cart-total-row.main { border-color: var(--cream4); color: var(--ink); }
body.dark-mode .cart-close { color: var(--mink); }
body.dark-mode .cart-close:hover { color: var(--ink); }
body.dark-mode .order-modal { background: var(--cream2); }
body.dark-mode .order-type-btn { background: var(--cream2); border-color: var(--cream4); }
body.dark-mode .order-type-btn:hover { background: var(--cream4); border-color: var(--gold2); }
body.dark-mode .order-type-btn.active { background: var(--cream4); border-color: var(--gold); }
body.dark-mode .order-field input,
body.dark-mode .order-field select,
body.dark-mode .order-field textarea { background: var(--cream3); border-color: var(--cream4); color: var(--ink); }
body.dark-mode .order-field input:focus,
body.dark-mode .order-field select:focus { background: var(--cream2); border-color: var(--gold); }
body.dark-mode .prov-search-input { background: var(--cream3); border-color: var(--cream4); color: var(--ink); }
body.dark-mode .prov-search-input:focus { background: var(--cream2); border-color: var(--gold); }
body.dark-mode .prov-dropdown { background: var(--cream2); border-color: var(--cream4); }
body.dark-mode .prov-item:hover { background: var(--cream4); }
body.dark-mode .photo-upload-section { background: var(--cream3); border-color: var(--cream4); }
body.dark-mode .photo-slot { background: var(--cream2); border-color: var(--cream4); }
body.dark-mode .photo-slot:hover { background: var(--cream4); border-color: var(--gold); }
body.dark-mode .photo-upload-counter { background: var(--cream3); border-color: var(--cream4); color: var(--mink); }
body.dark-mode .wish-panel { background: var(--cream2); border-color: var(--cream4); }
body.dark-mode .wish-panel-header, body.dark-mode .wish-header { border-color: var(--cream4); }
body.dark-mode .mobile-menu-panel { background: var(--cream2); box-shadow: 8px 0 40px rgba(0,0,0,.5); }
body.dark-mode .mobile-menu-header { border-color: var(--cream4); }
body.dark-mode .mobile-nav a { border-color: var(--cream4); color: var(--ink2); }
body.dark-mode .mobile-nav a:hover, body.dark-mode .mobile-nav a.active { background: var(--cream4); color: var(--ink); }
body.dark-mode .mobile-search-wrap { background: var(--cream3); border-color: var(--cream4); }
body.dark-mode .mobile-search-input { color: var(--ink); }
body.dark-mode .info-modal { background: var(--cream2); }
body.dark-mode .wa-menu { background: var(--cream2); border-color: var(--cream4); }
body.dark-mode .wa-menu-option { border-color: var(--cream4); }
body.dark-mode .wa-menu-option:hover { background: var(--cream4); }
body.dark-mode .wa-menu-option-text { color: var(--ink); }
body.dark-mode .agotado-modal { background: var(--cream2); }
body.dark-mode .welcome-popup-box { background: var(--cream2); }
body.dark-mode .wizard-box { background: var(--cream2); }
body.dark-mode .wizard-option { background: var(--cream2); border-color: var(--cream4); }
body.dark-mode .wizard-option:hover { background: var(--cream4); border-color: var(--gold); }
body.dark-mode .wizard-option.active { background: var(--rose3); border-color: var(--rose2); }
body.dark-mode .wizard-btn-back { border-color: var(--cream4); color: var(--mink); }
body.dark-mode .wizard-btn-back:hover { border-color: var(--gold); color: var(--ink); }
body.dark-mode .compare-box { background: var(--cream2); }
body.dark-mode .compare-card { border-color: var(--cream4); }
body.dark-mode .compare-card-img { background: var(--cream4); }
body.dark-mode .rain-card { background: var(--cream2); border-color: var(--cream4); }
body.dark-mode .collar-type-tab, body.dark-mode .anillo-type-tab { background: var(--cream2); border-color: var(--cream4); color: var(--mink); }
body.dark-mode .collar-type-tab:hover, body.dark-mode .anillo-type-tab:hover { border-color: var(--gold); }
body.dark-mode .collar-type-tab.active, body.dark-mode .anillo-type-tab.active { background: var(--rose3); border-color: var(--rose2); color: var(--rose2); }

/* Detail page */
body.dark-mode .detail-main-img { background: linear-gradient(145deg,var(--cream4),var(--cream2)); border-color: var(--cream4); }
body.dark-mode .detail-thumb { background: var(--cream4); border-color: var(--cream4); }
body.dark-mode .detail-thumb:hover, body.dark-mode .detail-thumb.active { border-color: var(--rose2); }
body.dark-mode .breadcrumb { background: var(--cream2); border-color: var(--cream4); }
body.dark-mode .btn-back { background: var(--cream3); border-color: var(--cream4); color: var(--ink2); }
body.dark-mode .detail-desc { border-color: var(--cream4); }
body.dark-mode .chip { background: var(--cream2); border-color: var(--cream4); color: var(--mink); }
body.dark-mode .chip:hover { background: var(--cream4); border-color: var(--gold); }
body.dark-mode .chip.active { background: var(--rose3); border-color: var(--rose2); color: var(--rose2); }
body.dark-mode .peluche-card-opt { background: var(--cream2); border-color: var(--cream4); }
body.dark-mode .peluche-card-opt:hover { border-color: var(--gold); }
body.dark-mode .peluche-card-opt.active { background: var(--rose3); border-color: var(--rose2); }
body.dark-mode .peluche-card-img { background: var(--cream4); }
body.dark-mode .dedica-card-opt { border-color: var(--cream4); }
body.dark-mode .dedica-input { background: var(--cream2); border-color: var(--cream4); color: var(--ink); }
body.dark-mode .dedica-input:focus { border-color: var(--gold); }
body.dark-mode .detail-dedica-section { background: var(--cream3); border-color: var(--cream4); }
body.dark-mode .detail-dedica-input,
body.dark-mode .detail-dedica-textarea { background: var(--cream2); border-color: var(--cream4); color: var(--ink); }
body.dark-mode .detail-dedica-input:focus,
body.dark-mode .detail-dedica-textarea:focus { border-color: var(--gold); }
body.dark-mode .detail-opt-btn { background: var(--cream2); border-color: var(--cream4); color: var(--mink); }
body.dark-mode .detail-opt-btn:hover { background: var(--cream4); border-color: var(--gold); }
body.dark-mode .detail-opt-btn.active { background: var(--rose3); border-color: var(--rose2); color: var(--rose2); }
body.dark-mode .detail-opt-img-btn { background: var(--cream2); border-color: var(--cream4); color: var(--mink); }
body.dark-mode .detail-opt-img-btn:hover { border-color: var(--gold); box-shadow: 0 4px 14px rgba(0,0,0,.2); }
body.dark-mode .detail-opt-img-btn.active { background: var(--rose3); border-color: var(--rose2); color: var(--rose2); }
body.dark-mode .detail-collar-type-label { color: var(--mink); }
body.dark-mode .detail-collar-type-label::after { background: var(--cream4); }
body.dark-mode .detail-trust { border-color: var(--cream4); }
body.dark-mode .btn-add-detail { background: var(--cream2); color: var(--gold3); box-shadow: 0 4px 20px rgba(0,0,0,.3); }
body.dark-mode .btn-add-detail:hover { background: var(--cream4); }
body.dark-mode .btn-share-wa { border-color: var(--cream4); color: var(--mink); }
body.dark-mode .btn-share-wa:hover { background: var(--cream4); border-color: var(--gold); color: var(--ink); }
body.dark-mode .detail-reviews-summary { background: var(--cream2); border-color: var(--cream4); }
body.dark-mode .review-item { background: var(--cream2); border-color: var(--cream4); }
body.dark-mode .review-item:hover { box-shadow: 0 4px 20px rgba(0,0,0,.4); }
body.dark-mode .review-avatar { background: var(--rose3); color: var(--rose2); }
body.dark-mode .review-photo { border-color: var(--cream4); }
body.dark-mode .reviews-bar-track { background: var(--cream4); }
body.dark-mode .related-item { background: var(--cream2); border-color: var(--cream4); }
body.dark-mode .related-img { background: var(--cream4); }
body.dark-mode .related-section { border-color: var(--cream4); }
body.dark-mode .recently-section { background: var(--cream2); }
body.dark-mode .recently-img { background: var(--cream3); border-color: var(--cream4); }
body.dark-mode .detail-float-bar { background: var(--cream2); border-color: var(--cream4); }
body.dark-mode .urgency-bar,
body.dark-mode .detail-urgency-bar { background: var(--rose3); border-color: var(--rose); }

/* Gallery card (autoscroll legacy) */
body.dark-mode .gallery-card { background: var(--cream2); }
body.dark-mode .gallery-card-name { color: var(--ink); }

/* ════════════════════════════════════════════════
   BOTTOM NAV MOBILE
   ════════════════════════════════════════════════ */
.bottom-nav{
  display:none;
  position:fixed;bottom:0;left:0;right:0;z-index:800;
  background:rgba(253,250,247,.97);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border-top:1px solid var(--cream4);
  padding:6px 0 max(6px, env(safe-area-inset-bottom));
  box-shadow:0 -4px 24px rgba(92,74,61,.1);
}
.bottom-nav .bn-item{
  flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:3px;padding:4px 2px;text-decoration:none;cursor:pointer;
  background:none;border:none;font-family:var(--sans);
  -webkit-tap-highlight-color:transparent;transition:transform .18s;
}
.bottom-nav .bn-item:active{transform:scale(.88)}
.bn-icon{font-size:20px;line-height:1;position:relative;display:inline-block}
.bn-label{font-size:10px;font-weight:600;letter-spacing:.04em;color:var(--mink);transition:color .2s}
.bn-item.active .bn-label{color:var(--rose2)}
.bn-item.active .bn-icon{filter:drop-shadow(0 2px 6px rgba(196,132,126,.4))}
.bn-wa .bn-icon{font-size:22px}
.bn-wa .bn-label{color:#25d366;font-weight:700}
.bn-badge{
  position:absolute;top:-4px;right:-6px;
  background:var(--rose2);color:#fff;font-size:9px;font-weight:700;
  min-width:15px;height:15px;border-radius:8px;
  display:inline-flex;align-items:center;justify-content:center;padding:0 3px;
}
@media(max-width:768px){
  .bottom-nav{display:flex}
  /* Dar espacio al contenido para que no quede tapado por el bottom nav */
  body{padding-bottom:64px}
  /* Ocultar hamburger cuando hay bottom nav */
  .hamburger{display:none!important}
}
body.dark-mode .bottom-nav{background:rgba(21,15,11,.97);border-color:var(--cream4)}
body.dark-mode .bn-label{color:var(--mink)}
body.dark-mode .bn-item.active .bn-label{color:var(--rose2)}

/* ════════════════════════════════════════════════
   HERO CATEGORÍAS GRID
   ════════════════════════════════════════════════ */
.hero-cats-grid{
  display:flex;gap:10px;justify-content:center;flex-wrap:wrap;
  margin-top:28px;
}
.hero-cat-btn{
  display:flex;flex-direction:column;align-items:center;gap:4px;
  background:rgba(255,255,255,.82);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  border:1.5px solid rgba(255,255,255,.9);border-radius:18px;
  padding:14px 20px;cursor:pointer;font-family:var(--sans);
  box-shadow:0 4px 20px rgba(92,74,61,.08);
  transition:transform .28s cubic-bezier(.34,1.4,.64,1),box-shadow .28s,border-color .2s;
  min-width:90px;
}
.hero-cat-btn:hover{
  transform:translateY(-5px) scale(1.04);
  box-shadow:0 12px 32px rgba(92,74,61,.15);
  border-color:rgba(196,132,126,.4);
}
.hero-cat-btn:active{transform:scale(.94)}
.hero-cat-icon{font-size:28px;line-height:1}
.hero-cat-name{font-size:12px;font-weight:700;color:var(--ink);letter-spacing:.04em}
.hero-cat-price{font-size:10px;color:var(--rose2);font-weight:600}
@media(max-width:600px){
  .hero-cats-grid{gap:8px;margin-top:20px}
  .hero-cat-btn{padding:10px 14px;min-width:72px;border-radius:14px}
  .hero-cat-icon{font-size:22px}
  .hero-cat-name{font-size:11px}
  .hero-cat-price{font-size:9px}
}
body.dark-mode .hero-cat-btn{background:rgba(42,31,26,.85);border-color:rgba(61,46,38,.8)}
body.dark-mode .hero-cat-name{color:var(--ink)}

/* Footer — fondo fijo oscuro, no usa --ink para no invertirse */
body.dark-mode footer{background:#0e0a07}

/* Botones de acción generales en dark mode — dorado sobre oscuro */
body.dark-mode .toast{background:#2a1f1a;color:var(--gold3)}
body.dark-mode .toast.success{background:#1a2a1a;border-left-color:#22c55e}
body.dark-mode .back-top{background:var(--gold);color:#1a0e08}
body.dark-mode .back-top:hover{background:var(--gold2)}
body.dark-mode .cookie-banner{background:#1a1008}
body.dark-mode .compare-bar{background:#1a1008}
body.dark-mode .btn-agotado-ver{background:var(--gold);color:#1a0e08}
body.dark-mode .btn-agotado-ver:hover{background:var(--gold2)}
body.dark-mode .welcome-popup-btn{background:var(--gold);color:#1a0e08}
body.dark-mode .welcome-popup-btn:hover{background:var(--gold2)}
body.dark-mode .wizard-btn-next,.dark-mode .wizard-next{background:var(--gold);color:#1a0e08}
body.dark-mode .info-modal-tab:hover,body.dark-mode .info-modal-tab.active{background:var(--gold);color:#1a0e08;border-color:var(--gold)}
body.dark-mode .qty-btn:hover{background:var(--gold);border-color:var(--gold);color:#1a0e08}
body.dark-mode .compare-card-btn{background:var(--gold);color:#1a0e08}

/* ════════════════════════════════════════════════
   BLUR PLACEHOLDER — imágenes lazy
   ════════════════════════════════════════════════ */
.img-wrap{
  position:relative;overflow:hidden;
  background:linear-gradient(135deg,var(--cream2),var(--pearl));
}
.img-wrap img{
  transition:opacity .35s ease;
}
.img-wrap img[data-loaded="false"]{opacity:0}
.img-wrap img[data-loaded="true"]{opacity:1}

/* ════════════════════════════════════════════════
   ESPACIADO UNIFORME DE SECCIONES
   ════════════════════════════════════════════════ */
.section{padding:72px 40px}
@media(max-width:768px){.section{padding:56px 20px}}
@media(max-width:480px){.section{padding:44px 14px}}

/* ════════════════════════════════════════════════
   EXIT INTENT POPUP
   ════════════════════════════════════════════════ */
.exit-overlay{
  position:fixed;inset:0;background:rgba(44,31,26,.6);
  backdrop-filter:blur(6px);z-index:9500;
  display:flex;align-items:center;justify-content:center;
  opacity:0;pointer-events:none;transition:opacity .3s;
}
.exit-overlay.open{opacity:1;pointer-events:all}
.exit-box{
  background:var(--white);border-radius:24px;padding:40px 36px;
  max-width:420px;width:90%;text-align:center;position:relative;
  box-shadow:0 24px 80px rgba(44,31,26,.3);
  transform:scale(.9) translateY(20px);transition:transform .35s cubic-bezier(.34,1.2,.64,1);
}
.exit-overlay.open .exit-box{transform:scale(1) translateY(0)}
.exit-close{
  position:absolute;top:14px;right:16px;background:none;border:none;
  font-size:18px;cursor:pointer;color:var(--mink);transition:color .2s;
  line-height:1;padding:4px;
}
.exit-close:hover{color:var(--ink)}
.exit-emoji{font-size:52px;display:block;margin-bottom:12px;animation:exitBounce .6s cubic-bezier(.34,1.4,.64,1) .2s both}
@keyframes exitBounce{from{transform:scale(0) rotate(-15deg)}to{transform:scale(1) rotate(0)}}
.exit-title{
  font-family:var(--serif);font-size:28px;font-weight:300;font-style:italic;
  color:var(--ink);line-height:1.2;margin-bottom:8px;
}
.exit-sub{font-size:14px;color:var(--mink);line-height:1.6;margin-bottom:20px}
.exit-offer{
  background:var(--rose3);border:1.5px dashed var(--rose2);border-radius:12px;
  padding:14px 20px;margin-bottom:24px;
}
.exit-offer-code{
  font-family:var(--serif);font-size:22px;font-style:italic;color:var(--rose2);
  font-weight:400;letter-spacing:.05em;
}
.exit-offer-desc{font-size:12px;color:var(--mink);margin-top:4px}
.exit-btn-wa{
  display:flex;align-items:center;justify-content:center;gap:10px;
  background:#25d366;color:#fff;border:none;width:100%;
  padding:15px;border-radius:12px;font-size:14px;font-weight:700;
  cursor:pointer;font-family:var(--sans);
  box-shadow:0 6px 20px rgba(37,211,102,.35);
  transition:all .25s;margin-bottom:10px;
}
.exit-btn-wa:hover{transform:translateY(-2px);box-shadow:0 10px 28px rgba(37,211,102,.45)}
.exit-btn-skip{
  background:none;border:none;color:var(--mink);font-size:12px;
  cursor:pointer;font-family:var(--sans);transition:color .2s;
}
.exit-btn-skip:hover{color:var(--ink)}
body.dark-mode .exit-box{background:var(--cream2)}
body.dark-mode .exit-offer{background:var(--rose3);border-color:var(--rose2)}

/* ════════════════════════════════════════════════
   SEARCH BY BUDGET — slider en buscador
   ════════════════════════════════════════════════ */
.search-budget-row{
  padding:12px 14px 8px;border-top:1px solid var(--cream4);
}
.search-budget-label{
  font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  color:var(--mink);margin-bottom:8px;display:block;
}
.search-budget-chips{display:flex;gap:6px;flex-wrap:wrap}
.search-budget-chip{
  padding:5px 12px;border:1.5px solid var(--cream4);background:var(--cream2);
  border-radius:20px;font-size:11px;font-weight:600;color:var(--mink);
  cursor:pointer;font-family:var(--sans);transition:all .2s;
}
.search-budget-chip:hover,.search-budget-chip.active{
  background:var(--gold3);color:var(--ink);border-color:var(--gold3);
}
body.dark-mode .search-budget-row{border-color:var(--cream4)}
body.dark-mode .search-budget-chip{background:var(--cream4);border-color:var(--cream4);color:var(--mink)}
body.dark-mode .search-budget-chip:hover,body.dark-mode .search-budget-chip.active{background:var(--gold3);color:var(--ink)}

/* ════════════════════════════════════════════════
   RECORDATORIO — banner de regreso
   ════════════════════════════════════════════════ */
.return-banner{
  position:fixed;top:80px;left:50%;transform:translateX(-50%) translateY(-120%);
  z-index:8000;background:var(--ink);color:var(--gold3);
  border-radius:40px;padding:12px 24px;
  display:flex;align-items:center;gap:12px;
  box-shadow:0 8px 32px rgba(44,31,26,.3);
  font-size:13px;font-weight:600;white-space:nowrap;
  transition:transform .4s cubic-bezier(.34,1.3,.64,1);
  max-width:90vw;
}
.return-banner.show{transform:translateX(-50%) translateY(0)}
.return-banner-close{
  background:none;border:none;color:rgba(232,213,176,.6);
  font-size:14px;cursor:pointer;padding:0;margin-left:4px;
  transition:color .2s;line-height:1;
}
.return-banner-close:hover{color:var(--gold3)}
body.dark-mode .return-banner{background:var(--cream4);color:var(--ink)}
