/* ============================================================
   SHULOS COOL GIFTS — Hoja de estilos
   Rojo de marca extraído del logo: #DA251A
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Baloo+2:wght@500;600;700;800&family=DM+Sans:opsz,wght@9..40,400;9..40,500;9..40,700&family=Kaushan+Script&display=swap');

:root{
  --red:#DA251A;
  --red-600:#C21D13;
  --red-700:#A8160d;
  --black:#0A0A0A;
  --ink:#111111;
  --dot:#242424;
  --white:#FFFFFF;
  --paper:#F6F4F2;
  --yellow:#F2C200;
  --wa:#25D366;
  --mut:#9b9b9b;
  --mut-d:#5e5e5e;
  --line:rgba(255,255,255,.10);
  --r-lg:26px;
  --r-md:18px;
  --r-sm:12px;
  --shadow:0 24px 60px -24px rgba(0,0,0,.6);
  --ease:cubic-bezier(.22,.61,.36,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:'DM Sans',system-ui,sans-serif;
  background:var(--black);
  color:var(--white);
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}

/* ---------- Tipografía ---------- */
h1,h2,h3,h4{font-family:'Baloo 2',cursive;font-weight:700;line-height:1.05;letter-spacing:-.01em}
.script{font-family:'Kaushan Script',cursive;font-weight:400;letter-spacing:.01em}
.eyebrow{
  font-family:'Baloo 2',cursive;font-weight:600;
  text-transform:uppercase;letter-spacing:.22em;font-size:.74rem;
  color:var(--red);display:inline-flex;align-items:center;gap:.6em;
}
.eyebrow.on-red{color:var(--yellow)}
.eyebrow::before{content:"";width:26px;height:2px;background:currentColor;border-radius:2px}

/* ---------- Texturas ---------- */
.dots{
  background-color:var(--black);
  background-image:
    radial-gradient(circle, var(--dot) 3px, transparent 3.4px),
    radial-gradient(circle, var(--dot) 3px, transparent 3.4px);
  background-size:38px 38px,38px 38px;
  background-position:0 0,19px 19px;
}
.dots-red{
  background-color:var(--red);
  background-image:
    radial-gradient(circle, rgba(255,255,255,.14) 3px, transparent 3.4px),
    radial-gradient(circle, rgba(255,255,255,.14) 3px, transparent 3.4px);
  background-size:38px 38px,38px 38px;
  background-position:0 0,19px 19px;
}

/* ---------- Layout ---------- */
.wrap{width:min(1200px,92vw);margin-inline:auto}
section{position:relative}
.pad{padding:clamp(64px,11vw,128px) 0}

/* ============================================================
   HEADER
   ============================================================ */
.hdr{
  position:fixed;inset:0 0 auto 0;z-index:80;
  transition:background .35s var(--ease),backdrop-filter .35s,border-color .35s,padding .35s;
  border-bottom:1px solid transparent;
}
.hdr.scrolled{
  background:rgba(10,10,10,.72);
  backdrop-filter:blur(16px) saturate(1.3);
  -webkit-backdrop-filter:blur(16px) saturate(1.3);
  border-bottom-color:var(--line);
}
.hdr-in{display:flex;align-items:center;justify-content:space-between;gap:24px;height:74px}
.brand{display:flex;align-items:center;gap:10px}
.brand img{height:40px;width:auto;filter:drop-shadow(0 6px 14px rgba(0,0,0,.4))}
.nav{display:flex;align-items:center;gap:6px}
.nav a{
  position:relative;font-weight:500;font-size:.96rem;color:#e9e9e9;
  padding:9px 14px;border-radius:999px;transition:color .2s,background .2s;
}
.nav a::after{
  content:"";position:absolute;left:14px;right:14px;bottom:5px;height:2px;
  background:var(--red);border-radius:2px;transform:scaleX(0);transform-origin:left;
  transition:transform .28s var(--ease);
}
.nav a:hover{color:#fff}
.nav a:hover::after{transform:scaleX(1)}
.hdr-cta{display:flex;align-items:center;gap:12px}
.burger{display:none;width:46px;height:46px;border-radius:12px;align-items:center;justify-content:center;flex-direction:column;gap:5px;background:rgba(255,255,255,.06);border:1px solid var(--line)}
.burger span{width:21px;height:2px;background:#fff;border-radius:2px;transition:.3s var(--ease)}
.burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* Botones */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  font-family:'Baloo 2',cursive;font-weight:600;font-size:1rem;
  padding:13px 24px;border-radius:999px;white-space:nowrap;
  transition:transform .25s var(--ease),box-shadow .25s var(--ease),background .25s,color .25s;
}
.btn:active{transform:scale(.96)}
.btn-red{background:var(--red);color:#fff;box-shadow:0 12px 26px -10px rgba(218,37,26,.7)}
.btn-red:hover{background:var(--red-600);transform:translateY(-2px);box-shadow:0 18px 34px -10px rgba(218,37,26,.85)}
.btn-ghost{background:transparent;color:#fff;border:1.6px solid rgba(255,255,255,.55)}
.btn-ghost:hover{border-color:#fff;background:rgba(255,255,255,.08);transform:translateY(-2px)}
.btn-white{background:#fff;color:var(--red);box-shadow:var(--shadow)}
.btn-white:hover{transform:translateY(-2px)}
.btn-sm{padding:10px 18px;font-size:.92rem}
.btn .ic{width:18px;height:18px;display:block}

/* Menú móvil */
.mnav{
  position:fixed;inset:74px 0 auto 0;z-index:75;
  background:rgba(10,10,10,.97);backdrop-filter:blur(20px);
  border-bottom:1px solid var(--line);
  transform:translateY(-120%);transition:transform .45s var(--ease);
  padding:18px 0 30px;
}
.mnav.open{transform:translateY(0)}
.mnav a{display:block;padding:15px 6vw;font-family:'Baloo 2',cursive;font-weight:600;font-size:1.3rem;border-bottom:1px solid rgba(255,255,255,.06)}
.mnav a:active{color:var(--red)}
.mnav .btn{margin:18px 6vw 0;width:calc(100% - 12vw)}

/* ============================================================
   HERO
   ============================================================ */
.hero{min-height:100svh;display:flex;align-items:center;padding-top:74px;overflow:hidden}
.hero-in{display:grid;gap:30px;justify-items:center;text-align:center;width:100%;position:relative;z-index:2}
.hero-logo{width:min(560px,82vw);filter:drop-shadow(0 30px 60px rgba(218,37,26,.35))}
.hero h1{font-size:clamp(2.5rem,7vw,5.4rem);font-weight:800}
.hero h1 .script{color:var(--red);font-weight:400;display:inline-block}
.hero p.sub{max-width:560px;font-size:clamp(1.05rem,2.4vw,1.3rem);color:#cfcfcf}
.hero-btns{display:flex;flex-wrap:wrap;gap:14px;justify-content:center;margin-top:6px}
.hero-meta{display:flex;flex-wrap:wrap;gap:8px 22px;justify-content:center;margin-top:18px;color:var(--mut);font-size:.9rem}
.hero-meta b{color:#fff;font-weight:600}
.scroll-cue{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);z-index:3;color:var(--mut);font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;display:flex;flex-direction:column;align-items:center;gap:8px}
.scroll-cue .dot{width:6px;height:6px;border-radius:50%;background:var(--red);animation:cue 1.6s var(--ease) infinite}
@keyframes cue{0%{transform:translateY(0);opacity:1}70%{transform:translateY(16px);opacity:0}100%{opacity:0}}

/* Confeti decorativo (formas simples) */
.confetti{position:absolute;inset:0;z-index:1;pointer-events:none;overflow:hidden}
.confetti i{position:absolute;display:block;opacity:.0;animation:floaty 7s ease-in-out infinite}
.cf-dot{width:14px;height:14px;border-radius:50%}
.cf-ring{width:22px;height:22px;border-radius:50%;border:3px solid currentColor}
.cf-diam{width:14px;height:14px;border-radius:3px;transform:rotate(45deg)}
@keyframes floaty{0%,100%{transform:translateY(0) rotate(0);opacity:.0}10%{opacity:.9}50%{transform:translateY(-22px) rotate(20deg);opacity:.9}90%{opacity:.5}}

/* ============================================================
   SECCIONES claras / oscuras
   ============================================================ */
.light{background:var(--paper);color:var(--ink)}
.light .eyebrow{color:var(--red)}
.sec-head{max-width:680px;margin-bottom:clamp(34px,5vw,56px)}
.sec-head.center{margin-inline:auto;text-align:center}
.sec-head h2{font-size:clamp(2rem,5vw,3.3rem);margin:14px 0 12px}
.sec-head p{font-size:1.06rem;color:var(--mut)}
.light .sec-head p{color:#6b6663}

/* ---------- Categorías ---------- */
.cat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.cat{
  position:relative;background:var(--black);border-radius:var(--r-lg);
  padding:30px 26px 26px;overflow:hidden;border:1.5px solid #1c1c1c;
  transition:transform .35s var(--ease),border-color .35s,box-shadow .35s;
  background-image:
    radial-gradient(circle, #1c1c1c 2.6px, transparent 3px),
    radial-gradient(circle, #1c1c1c 2.6px, transparent 3px);
  background-size:28px 28px,28px 28px;
  background-position:0 0,14px 14px;
}
.cat:hover{transform:translateY(-8px);border-color:var(--red);box-shadow:0 26px 46px -22px rgba(218,37,26,.55)}
.cat-ic{
  width:62px;height:62px;border-radius:18px;display:grid;place-items:center;
  background:rgba(218,37,26,.14);color:var(--red);margin-bottom:20px;
  transition:background .35s,transform .35s var(--ease);
}
.cat:hover .cat-ic{background:var(--red);color:#fff;transform:rotate(-6deg) scale(1.05)}
.cat-ic svg{width:30px;height:30px}
.cat h3{color:#fff;font-size:1.4rem;margin-bottom:6px}
.cat p{color:var(--mut);font-size:.94rem;margin-bottom:16px}
.cat .more{font-family:'Baloo 2',cursive;font-weight:600;color:var(--red);font-size:.92rem;display:inline-flex;align-items:center;gap:6px;transition:gap .25s}
.cat:hover .more{gap:11px}
.cat .num{position:absolute;top:18px;right:22px;font-family:'Baloo 2',cursive;font-weight:700;font-size:.85rem;color:#262626}

/* ---------- Productos ---------- */
.prod-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.prod{
  background:#fff;border-radius:var(--r-md);overflow:hidden;color:var(--ink);
  display:flex;flex-direction:column;
  transition:transform .35s var(--ease),box-shadow .35s;
  box-shadow:0 10px 30px -18px rgba(0,0,0,.5);
}
.prod:hover{transform:translateY(-8px);box-shadow:0 30px 50px -24px rgba(0,0,0,.65)}
.ph{position:relative;aspect-ratio:1/1;overflow:hidden;
  background:repeating-linear-gradient(45deg,#efeae5,#efeae5 13px,#e6ded7 13px,#e6ded7 26px);}
.ph .plh{position:absolute;inset:0;display:grid;place-items:center;text-align:center}
.ph .plh span{font-family:'DM Mono',ui-monospace,monospace;font-size:.7rem;color:#8c847c;
  background:rgba(255,255,255,.78);padding:6px 11px;border-radius:7px;letter-spacing:.02em;line-height:1.3}
.ph svg{width:100%;height:100%;display:block}
.ph .tag{position:absolute;top:12px;left:12px;background:var(--red);color:#fff;font-family:'Baloo 2',cursive;font-weight:600;font-size:.72rem;padding:5px 11px;border-radius:999px;letter-spacing:.02em}
.ph .fav{position:absolute;top:11px;right:11px;width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,.92);display:grid;place-items:center;color:var(--red);transition:transform .25s,background .25s}
.ph .fav:hover{transform:scale(1.12);background:#fff}
.ph .fav svg{width:17px;height:17px}
.prod-body{padding:16px 17px 18px;display:flex;flex-direction:column;gap:4px;flex:1}
.prod-body .cat-name{font-size:.72rem;text-transform:uppercase;letter-spacing:.14em;color:var(--mut-d);font-weight:600}
.prod-body h3{font-size:1.16rem;color:var(--ink);line-height:1.15}
.prod-foot{margin-top:auto;display:flex;align-items:center;justify-content:space-between;gap:10px;padding-top:14px}
.price{font-family:'Baloo 2',cursive;font-weight:700;font-size:1.3rem;color:var(--red)}
.price s{font-size:.85rem;color:#b8b2ae;font-weight:500;margin-left:4px}
.prod .btn-red{padding:9px 14px;font-size:.84rem}
.prov{display:inline-flex;align-items:center;gap:7px;font-size:.78rem;color:var(--mut);font-family:'DM Sans';margin-top:18px}
.prov::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--yellow)}

/* ---------- Ocasiones (franja roja) ---------- */
.occ{color:#fff;overflow:hidden}
.occ .sec-head h2{font-size:clamp(2rem,5vw,3.3rem)}
.chips{display:flex;flex-wrap:wrap;gap:14px;margin-top:28px}
.chip{
  display:inline-flex;align-items:center;gap:10px;
  background:rgba(255,255,255,.12);border:1.5px solid rgba(255,255,255,.3);
  padding:13px 22px;border-radius:999px;font-family:'Baloo 2',cursive;font-weight:600;font-size:1.05rem;
  transition:transform .3s var(--ease),background .3s,border-color .3s;
}
.chip:hover{transform:translateY(-4px);background:#fff;color:var(--red);border-color:#fff}
.chip .em{width:22px;height:22px;color:var(--yellow);transition:color .3s}
.chip:hover .em{color:var(--red)}

/* ---------- Por qué Shulos ---------- */
.why-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.why{padding:8px 0}
.why .big{font-family:'Baloo 2',cursive;font-weight:800;font-size:3.4rem;color:var(--red);line-height:1;display:flex;align-items:center;gap:6px}
.why .big .ic{width:34px;height:34px}
.why h3{font-size:1.25rem;margin:14px 0 7px;color:var(--ink)}
.why p{color:#6b6663;font-size:.96rem}
.why .rule{width:46px;height:3px;background:var(--red);border-radius:3px;margin-top:16px;opacity:.25}

/* ---------- Sucursales ---------- */
.suc-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.suc{
  background:#111;border:1.5px solid #1d1d1d;border-radius:var(--r-lg);overflow:hidden;
  transition:transform .35s var(--ease),border-color .35s;
}
.suc:hover{transform:translateY(-6px);border-color:var(--red)}
.map{position:relative;height:190px;background:#0d0d0d;overflow:hidden}
.map svg{width:100%;height:100%}
.map .pin{position:absolute;top:50%;left:50%;transform:translate(-50%,-100%);color:var(--red);filter:drop-shadow(0 8px 10px rgba(0,0,0,.5))}
.map .pin svg{width:40px;height:40px}
.map .maplbl{position:absolute;bottom:10px;left:12px;font-size:.7rem;color:#6a6a6a;font-family:'DM Sans';letter-spacing:.04em}
.suc-body{padding:24px 24px 26px}
.suc-tag{display:inline-block;font-family:'Baloo 2',cursive;font-weight:600;font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--red);margin-bottom:8px}
.suc h3{font-size:1.5rem;color:#fff;margin-bottom:14px}
.suc ul{list-style:none;display:flex;flex-direction:column;gap:11px;margin-bottom:22px}
.suc li{display:flex;gap:12px;align-items:flex-start;color:#cfcfcf;font-size:.96rem}
.suc li .ic{width:19px;height:19px;color:var(--red);flex:none;margin-top:3px}
.suc li b{color:#fff;font-weight:600}
.suc-acts{display:flex;gap:10px;flex-wrap:wrap}

/* ---------- CTA final ---------- */
.cta{color:#fff;text-align:center;overflow:hidden}
.cta-in{position:relative;z-index:2;display:grid;justify-items:center;gap:22px}
.cta h2{font-size:clamp(2.2rem,6vw,4rem);max-width:14ch}
.cta h2 .script{display:block;color:var(--yellow);font-weight:400;font-size:.78em}
.cta p{max-width:520px;font-size:1.1rem;color:rgba(255,255,255,.9)}
.cta-btns{display:flex;flex-wrap:wrap;gap:14px;justify-content:center;margin-top:6px}

/* ---------- Footer ---------- */
.ftr{padding:64px 0 28px}
.ftr-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;padding-bottom:42px;border-bottom:1px solid var(--line)}
.ftr img.logo{height:52px;margin-bottom:18px}
.ftr p.desc{color:var(--mut);max-width:34ch;font-size:.95rem}
.ftr h4{font-family:'Baloo 2',cursive;font-weight:600;color:#fff;font-size:1.05rem;margin-bottom:16px}
.ftr ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.ftr ul a{color:var(--mut);font-size:.95rem;transition:color .2s}
.ftr ul a:hover{color:var(--red)}
.socials{display:flex;gap:12px;margin-top:18px}
.socials a{width:44px;height:44px;border-radius:13px;display:grid;place-items:center;background:rgba(255,255,255,.06);border:1px solid var(--line);color:#cfcfcf;transition:.25s var(--ease)}
.socials a:hover{background:var(--red);color:#fff;border-color:var(--red);transform:translateY(-3px)}
.socials svg{width:20px;height:20px}
.ftr-bot{display:flex;flex-wrap:wrap;justify-content:space-between;gap:12px;padding-top:24px;color:var(--mut-d);font-size:.84rem}
.ftr-bot a{color:var(--mut)}

/* ---------- WhatsApp flotante ---------- */
.wa-float{
  position:fixed;right:20px;bottom:20px;z-index:90;
  width:60px;height:60px;border-radius:50%;background:var(--wa);
  display:grid;place-items:center;color:#fff;
  box-shadow:0 14px 30px -8px rgba(37,211,102,.6);
  transition:transform .3s var(--ease),box-shadow .3s;
  animation:wapulse 2.8s ease-out infinite;
}
.wa-float:hover{transform:scale(1.08)}
.wa-float svg{width:32px;height:32px}
.wa-float .lbl{
  position:absolute;right:72px;white-space:nowrap;background:#fff;color:#0a0a0a;
  font-weight:600;font-size:.86rem;padding:8px 14px;border-radius:10px;
  box-shadow:var(--shadow);opacity:0;transform:translateX(8px);pointer-events:none;transition:.25s var(--ease);
}
.wa-float:hover .lbl{opacity:1;transform:translateX(0)}
@keyframes wapulse{0%{box-shadow:0 14px 30px -8px rgba(37,211,102,.6),0 0 0 0 rgba(37,211,102,.5)}70%{box-shadow:0 14px 30px -8px rgba(37,211,102,.6),0 0 0 16px rgba(37,211,102,0)}100%{box-shadow:0 14px 30px -8px rgba(37,211,102,.6),0 0 0 0 rgba(37,211,102,0)}}

/* ---------- Scroll reveal ---------- */
.reveal{opacity:0;transform:translateY(34px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}.reveal.d4{transition-delay:.32s}.reveal.d5{transition-delay:.4s}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1000px){
  .cat-grid{grid-template-columns:repeat(2,1fr)}
  .prod-grid{grid-template-columns:repeat(2,1fr)}
  .why-grid{grid-template-columns:repeat(2,1fr);gap:30px}
}
@media (max-width:820px){
  .nav,.hdr-cta .btn{display:none}
  .burger{display:flex}
  .suc-grid{grid-template-columns:1fr}
  .ftr-grid{grid-template-columns:1fr 1fr;gap:30px}
  .ftr-brand{grid-column:1/-1}
}
@media (max-width:560px){
  .cat-grid{grid-template-columns:1fr}
  .prod-grid{grid-template-columns:1fr 1fr;gap:14px}
  .why-grid{grid-template-columns:1fr 1fr}
  .ftr-grid{grid-template-columns:1fr}
  .hero-btns .btn{flex:1}
  .prod .btn-red span{display:none}
  .prod .btn-red{padding:9px 12px}
}
@media (max-width:420px){
  .prod-grid{grid-template-columns:1fr}
}
@media (prefers-reduced-motion:reduce){
  *{animation:none!important}
  .reveal{opacity:1;transform:none;transition:none}
  html{scroll-behavior:auto}
}
