
/* ─── RESET & VARS ─────────────────────────────────── */
*{box-sizing:border-box;margin:0;padding:0;}
:root{
  --gold:#c8a84b;
  --gold-bright:#f5d97e;
  --gold-dark:#7a5e1a;
  --gold-glow:rgba(200,168,75,.35);
  --ink:#080503;
  --ink2:#110d06;
  --card-bg:#13100a;
  --text:#f2e4bc;
  --muted:#9a7d45;
  --wa:#25D366;
  --red:#b02020;
}
html{scroll-behavior:smooth}
body{
  background:var(--ink);
  color:var(--text);
  font-family:'Lato',sans-serif;
  overflow-x:hidden;
  cursor:default;
}

/* ─── NOISE OVERLAY ──────────────────────────────── */
body::before{
  content:'';
  position:fixed;inset:0;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.04'/%3E%3C/svg%3E");
  pointer-events:none;z-index:0;opacity:.5;
}

/* ─── NAV ────────────────────────────────────────── */
nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:.9rem 2rem;
  background:linear-gradient(180deg,rgba(8,5,3,.95) 0%,transparent 100%);
  backdrop-filter:blur(4px);
}
.nav-logo{
  font-family:'Cinzel Decorative',serif;
  font-size:1.1rem;
  color:var(--gold-bright);
  letter-spacing:3px;
  text-shadow:0 0 20px var(--gold-glow);
}
.nav-links{display:flex;gap:1.5rem;}
.nav-links a{
  font-family:'Cinzel',serif;
  font-size:.7rem;
  letter-spacing:2px;
  color:var(--muted);
  text-decoration:none;
  text-transform:uppercase;
  transition:color .2s;
}
.nav-links a:hover{color:var(--gold-bright);}
@media(max-width:600px){.nav-links{display:none}}

/* ─── HERO ───────────────────────────────────────── */
#hero{
  min-height:100vh;
  display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  text-align:center;
  position:relative;
  padding:6rem 1.5rem 4rem;
  background:
    radial-gradient(ellipse 80% 60% at 50% 30%,rgba(120,70,10,.35) 0%,transparent 70%),
    radial-gradient(ellipse 60% 80% at 80% 80%,rgba(80,20,5,.3) 0%,transparent 60%),
    var(--ink);
  overflow:hidden;
}

/* Decorative floral/catrina SVG pattern rings */
#hero::before{
  content:'';
  position:absolute;
  width:min(600px,90vw);height:min(600px,90vw);
  border-radius:50%;
  border:1px solid rgba(200,168,75,.12);
  top:50%;left:50%;transform:translate(-50%,-50%);
  box-shadow:
    0 0 0 40px rgba(200,168,75,.04),
    0 0 0 80px rgba(200,168,75,.03),
    0 0 0 130px rgba(200,168,75,.02);
  animation:pulse 6s ease-in-out infinite;
}
@keyframes pulse{0%,100%{opacity:.6;transform:translate(-50%,-50%) scale(1)}50%{opacity:1;transform:translate(-50%,-50%) scale(1.03)}}

.hero-eyebrow{
  font-family:'Cinzel',serif;
  font-size:.72rem;
  letter-spacing:6px;
  color:var(--gold-dark);
  text-transform:uppercase;
  margin-bottom:1.2rem;
  animation:fadeUp .8s ease both;
}

/* Big skull/catrina SVG illustration */
.logo-catrina{
  width:min(250px,70vw);
  margin-bottom:1.5rem;
  filter:drop-shadow(0 0 30px rgba(200,168,75,.5));
  animation:fadeUp .9s .1s ease both, float 4s 1s ease-in-out infinite;
}

.catrina-svg{
  width:min(200px,45vw);
  margin-bottom:1.5rem;
  filter:drop-shadow(0 0 30px rgba(200,168,75,.5));
  animation:fadeUp .9s .1s ease both, float 4s 1s ease-in-out infinite;
}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}

.hero-title{
  font-family:'Cinzel Decorative',serif;
  font-size:clamp(2.4rem,8vw,5.5rem);
  line-height:1;
  color:var(--gold-bright);
  text-shadow:0 0 60px var(--gold-glow),0 4px 8px rgba(0,0,0,.8);
  letter-spacing:4px;
  animation:fadeUp 1s .2s ease both;
}
.hero-sub{
  font-family:'EB Garamond',serif;
  font-size:clamp(1rem,3vw,1.5rem);
  color:var(--muted);
  letter-spacing:4px;
  margin-top:.6rem;
  font-style:italic;
  animation:fadeUp 1s .35s ease both;
}
.hero-divider{
  width:200px;height:1px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);
  margin:1.8rem auto;
  animation:fadeUp 1s .4s ease both;
}
.hero-phone{
  font-family:'Cinzel Decorative',serif;
  font-size:clamp(1.2rem,4vw,2rem);
  color:var(--ink);
  background:linear-gradient(135deg,var(--gold-dark),var(--gold-bright),var(--gold-dark));
  padding:.5rem 2.5rem;
  border-radius:4px;
  box-shadow:0 8px 30px var(--gold-glow);
  letter-spacing:3px;
  animation:fadeUp 1s .5s ease both;
}
.hero-cta{
  display:flex;gap:1rem;flex-wrap:wrap;justify-content:center;
  margin-top:2rem;
  animation:fadeUp 1s .65s ease both;
}
.btn-outline{
  font-family:'Cinzel',serif;
  font-size:.75rem;letter-spacing:2px;
  border:1px solid var(--gold);
  color:var(--gold);
  padding:.65rem 2rem;
  border-radius:3px;
  text-decoration:none;
  transition:background .25s,color .25s;
  text-transform:uppercase;
}
.btn-outline:hover{background:var(--gold);color:var(--ink);}
.btn-wa-hero{
  font-family:'Cinzel',serif;
  font-size:.75rem;letter-spacing:2px;
  background:linear-gradient(135deg,#1a9e4a,var(--wa));
  color:#fff;
  padding:.65rem 2rem;
  border-radius:3px;
  text-decoration:none;
  display:flex;align-items:center;gap:.5rem;
  transition:filter .2s;
  text-transform:uppercase;
}
.btn-wa-hero:hover{filter:brightness(1.15);}

@keyframes fadeUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}

/* ─── SECTION SHARED ─────────────────────────────── */
section{position:relative;z-index:1;}
.section-header{
  text-align:center;
  padding:3.5rem 1rem 1rem;
}
.section-tag{
  font-family:'Cinzel',serif;
  font-size:.65rem;letter-spacing:5px;
  color:var(--gold-dark);
  text-transform:uppercase;
  display:block;margin-bottom:.6rem;
}
.section-title{
  font-family:'Cinzel Decorative',serif;
  font-size:clamp(1.4rem,4vw,2.4rem);
  color:var(--gold-bright);
  text-shadow:0 0 30px var(--gold-glow);
  letter-spacing:2px;
}
.divider{
  display:flex;align-items:center;gap:1rem;
  max-width:700px;margin:1.2rem auto 2rem;
  padding:0 1rem;
}
.divider::before,.divider::after{
  content:'';flex:1;height:1px;
  background:linear-gradient(90deg,transparent,var(--gold-dark),transparent);
}
.divider span{
  font-size:.6rem;color:var(--gold-dark);letter-spacing:3px;white-space:nowrap;
}

/* ─── PROMOS SECTION ─────────────────────────────── */
#promos{
  background:linear-gradient(180deg,var(--ink) 0%,var(--ink2) 100%);
  padding-bottom:3rem;
}
.promo-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:1.5rem;
  max-width:900px;
  margin:0 auto;
  padding:0 1.2rem;
}
.promo-card{
  background:linear-gradient(145deg,#1c1408,#0f0b05);
  border:1px solid rgba(200,168,75,.25);
  border-radius:12px;
  overflow:hidden;
  display:flex;flex-direction:column;
  transition:transform .3s,border-color .3s,box-shadow .3s;
}
.promo-card:hover{
  transform:translateY(-5px);
  border-color:rgba(200,168,75,.6);
  box-shadow:0 16px 40px rgba(0,0,0,.7),0 0 30px var(--gold-glow);
}
.promo-badge{
  background:linear-gradient(90deg,var(--red),#8a1515);
  font-family:'Cinzel',serif;
  font-size:.6rem;letter-spacing:3px;
  color:#fff;text-align:center;
  padding:.3rem;text-transform:uppercase;
}
.promo-inner{padding:1.5rem;}
.promo-name{
  font-family:'Cinzel',serif;
  font-size:1.05rem;
  color:var(--gold-bright);
  margin-bottom:.4rem;
  line-height:1.3;
}
.promo-detail{
  font-size:.8rem;color:var(--muted);
  margin-bottom:.3rem;
  font-family:'EB Garamond',serif;font-style:italic;
}
.promo-price{
  font-family:'Cinzel Decorative',serif;
  font-size:1.6rem;color:var(--gold);
  margin:.6rem 0;
}
.promo-bullets{
  list-style:none;margin-top:.4rem;
}
.promo-bullets li{
  font-size:.78rem;color:var(--text);
  padding:.15rem 0;
  display:flex;align-items:center;gap:.5rem;
}
.promo-bullets li::before{content:'◆';color:var(--gold-dark);font-size:.5rem;}
.promo-img{
  width:100%;height:220px;object-fit:contain;
  background:linear-gradient(180deg,#2a1800,#0a0600);
  padding:1rem;
}
.btn-wa-promo{
  display:flex;align-items:center;justify-content:center;gap:.5rem;
  background:linear-gradient(135deg,#1a9e4a,var(--wa));
  color:#fff;font-family:'Lato',sans-serif;font-weight:700;
  font-size:.82rem;letter-spacing:.5px;
  border:none;border-radius:0 0 12px 12px;
  padding:.8rem 1rem;
  cursor:pointer;text-decoration:none;
  transition:filter .2s;
  margin-top:auto;
}
.btn-wa-promo:hover{filter:brightness(1.1);}

/* ─── CATALOG SECTION ────────────────────────────── */
#catalogo{
  background:var(--ink);
  padding-bottom:4rem;
}
.filter-bar{
  display:flex;flex-wrap:wrap;gap:.6rem;justify-content:center;
  padding:0 1rem 1.5rem;
}
.filter-btn{
  background:transparent;
  border:1px solid var(--gold-dark);
  color:var(--muted);
  font-family:'Cinzel',serif;
  font-size:.65rem;letter-spacing:2px;
  padding:.35rem 1.2rem;border-radius:20px;
  cursor:pointer;text-transform:uppercase;
  transition:all .2s;
}
.filter-btn:hover,.filter-btn.active{
  background:var(--gold);border-color:var(--gold);
  color:var(--ink);font-weight:700;
}
.cat-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(210px,1fr));
  gap:1rem;
  max-width:1050px;
  margin:0 auto;
  padding:0 1rem;
}
.cat-card{
  background:linear-gradient(160deg,#1a1208,#0f0b05);
  border:1px solid rgba(200,168,75,.18);
  border-radius:10px;overflow:hidden;
  display:flex;flex-direction:column;
  transition:transform .25s,border-color .25s,box-shadow .25s;
}
.cat-card:hover{
  transform:translateY(-4px);
  border-color:rgba(200,168,75,.55);
  box-shadow:0 12px 35px rgba(0,0,0,.6),0 0 18px var(--gold-glow);
}
.cat-img-wrap{
  height:160px;
  background:linear-gradient(180deg,#2a1800,#0a0600);
  display:flex;align-items:center;justify-content:center;overflow:hidden;
}
.cat-img-wrap img{
  width:100%;height:160px;object-fit:contain;padding:.8rem;
  transition:transform .3s;

  max-width: 220px;

  object-fit: cover;
}
.cat-card:hover .cat-img-wrap img{transform:scale(1.06);}
.cat-img-wrap .emoji{font-size:2.8rem;}
.cat-body{
  padding:.85rem .9rem;flex:1;display:flex;flex-direction:column;gap:.3rem;
}
.cat-tag{
  font-size:.58rem;letter-spacing:2px;
  color:var(--gold-dark);text-transform:uppercase;
  font-family:'Cinzel',serif;
}
.cat-name{
  font-family:'Cinzel',serif;
  font-size:.88rem;color:var(--gold-bright);line-height:1.3;font-weight:600;
}
.cat-present{font-size:.68rem;color:var(--muted);}
.cat-price{
  font-family:'Cinzel Decorative',serif;
  font-size:1rem;color:var(--gold);
  margin-top:auto;padding-top:.4rem;
}
.btn-wa-cat{
  display:flex;align-items:center;justify-content:center;gap:.4rem;
  background:linear-gradient(135deg,#1a9e4a,var(--wa));
  color:#fff;font-family:'Lato',sans-serif;font-weight:700;
  font-size:.75rem;letter-spacing:.4px;
  border:none;border-radius:0 0 10px 10px;
  padding:.65rem .8rem;cursor:pointer;text-decoration:none;
  transition:filter .2s;
}
.btn-wa-cat:hover{filter:brightness(1.1);}
.btn-wa-cat svg,.btn-wa-promo svg{width:16px;height:16px;flex-shrink:0;}

/* ─── CONTACT / FOOTER ───────────────────────────── */
#contacto{
  background:linear-gradient(180deg,var(--ink2),#000);
  padding:3rem 1.5rem;
  text-align:center;
  border-top:1px solid var(--gold-dark);
}
.contact-logo{
  font-family:'Cinzel Decorative',serif;
  font-size:clamp(1.4rem,5vw,2.5rem);
  color:var(--gold-bright);
  letter-spacing:4px;
  text-shadow:0 0 40px var(--gold-glow);
  margin-bottom:.4rem;
}
.contact-sub{
  font-family:'EB Garamond',serif;
  font-style:italic;color:var(--muted);
  font-size:1rem;letter-spacing:2px;margin-bottom:1.5rem;
}
.contact-info{
  display:flex;flex-wrap:wrap;gap:1.2rem;justify-content:center;
  margin-bottom:2rem;
}
.contact-pill{
  background:rgba(200,168,75,.08);
  border:1px solid rgba(200,168,75,.25);
  border-radius:40px;
  padding:.5rem 1.5rem;
  font-family:'Cinzel',serif;
  font-size:.8rem;letter-spacing:1px;color:var(--text);
  display:flex;align-items:center;gap:.5rem;
}
.contact-wa-big{
  display:inline-flex;align-items:center;gap:.7rem;
  background:linear-gradient(135deg,#1a9e4a,var(--wa));
  color:#fff;font-family:'Cinzel',serif;
  font-size:1rem;letter-spacing:2px;
  padding:.9rem 3rem;border-radius:5px;
  text-decoration:none;
  box-shadow:0 8px 25px rgba(37,211,102,.3);
  transition:filter .2s,transform .2s;
  text-transform:uppercase;
}
.contact-wa-big:hover{filter:brightness(1.1);transform:scale(1.03);}
footer{
  text-align:center;
  padding:1.2rem;
  font-size:.7rem;letter-spacing:1px;color:var(--gold-dark);
  font-family:'Cinzel',serif;
}

/* ─── SCROLL REVEAL ──────────────────────────────── */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .6s ease,transform .6s ease;}
.reveal.visible{opacity:1;transform:translateY(0);}