/* ============================================================
   ÑÁCARU · Sistema de diseño
   Paseo, sillas, mobiliario, puericultura, ropa, zapatos, juguetes
   Marca: azules de Ñácaru + acento coral (de los corazones del logo)
   Estilo: tierno y suave — nubes, redondeces, lunares, tipografía amable
   3 direcciones de diseño via [data-direction]: nube · sereno · boutique
   ============================================================ */

:root{
  /* Azules de marca (del logo) */
  --blue-900:#0a3c7d;
  --blue-700:#1763c7;   /* azul primario (la N) */
  --blue-600:#2274dd;
  --blue-500:#3a8bea;
  --blue-400:#5bb0ee;   /* azul cielo (bacaru) */
  --blue-300:#8fcaf4;
  --blue-200:#c2e2fb;
  --blue-100:#e3f1fd;
  --blue-50:#f1f8fe;

  /* Acento coral (los corazones) */
  --coral-600:#f7706f;
  --coral:#ff8e8e;
  --coral-300:#ffb6b6;
  --coral-100:#ffe2e2;

  /* Acento alternativo (menta) — disponible para tweak */
  --mint:#7fd4bb;
  --mint-100:#e0f5ef;

  /* Acento "vivo" actual (lo controla el tweak de acento) */
  --accent:var(--coral);
  --accent-600:var(--coral-600);
  --accent-100:var(--coral-100);

  /* Neutros cálidos */
  --ink:#27324b;
  --ink-soft:#5b6883;
  --ink-faint:#92a0bb;
  --cloud:#fcfdff;
  --paper:#ffffff;
  --line:#e7eef8;
  --line-soft:#eef4fb;
  --wash:#f4f9fe;        /* fondo de página */

  /* Forma */
  --r-xl:32px;
  --r-lg:26px;
  --r-md:18px;
  --r-sm:12px;
  --pill:999px;

  /* Sombra (tinte azul) */
  --sh-sm:0 2px 8px rgba(23,99,199,.07);
  --sh-md:0 10px 30px -12px rgba(23,99,199,.22);
  --sh-lg:0 26px 60px -22px rgba(23,99,199,.30);
  --sh-coral:0 14px 30px -12px rgba(247,112,111,.45);
  --sh-blue:0 14px 30px -12px rgba(23,99,199,.45);

  /* Tipografía */
  --font-head:"Baloo 2", system-ui, sans-serif;
  --font-body:"Nunito", system-ui, sans-serif;

  /* Decoración (la controla la dirección de diseño) */
  --deco-dots:1;        /* 1 visible / 0 oculto */
  --deco-clouds:1;
  --hero-accent-strength:1;

  --maxw:1240px;
}

/* ---------- Direcciones de diseño ---------- */
/* nube = por defecto (arriba) */

[data-direction="sereno"]{
  --r-xl:22px; --r-lg:18px; --r-md:14px; --r-sm:10px;
  --wash:#f7fafe;
  --deco-dots:0; --deco-clouds:0;
  --sh-md:0 12px 34px -16px rgba(23,99,199,.16);
  --sh-lg:0 24px 60px -26px rgba(23,99,199,.20);
}
[data-direction="boutique"]{
  --r-xl:20px; --r-lg:16px; --r-md:12px; --r-sm:8px;
  --wash:#fbf8f5;
  --ink:#221d22;
  --deco-dots:0; --deco-clouds:0;
}

/* ---------- Reset / base ---------- */
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--wash);
  font-size:16px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
h1,h2,h3,h4{font-family:var(--font-head);font-weight:700;line-height:1.08;margin:0;color:var(--ink);letter-spacing:-.01em}
p{margin:0}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
img{display:block;max-width:100%}
ul{margin:0;padding:0;list-style:none}
input,select,textarea{font-family:inherit;font-size:1rem;color:var(--ink)}
::selection{background:var(--blue-200)}

/* boutique: titulares aún más marcados */
[data-direction="boutique"] h1,
[data-direction="boutique"] h2{font-weight:800;letter-spacing:-.02em}

/* ---------- Utilidades de layout ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.app{min-height:100vh;display:flex;flex-direction:column}
.app-main{flex:1}
.stack{display:flex;flex-direction:column}
.row{display:flex;align-items:center}
.muted{color:var(--ink-soft)}
.faint{color:var(--ink-faint)}
.center{text-align:center}

/* eyebrow / kicker */
.kicker{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--font-head);font-weight:600;
  font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--blue-700);
}
.kicker .dot{width:7px;height:7px;border-radius:50%;background:var(--accent)}

.section{padding-top:64px;padding-bottom:64px}
.section-head{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;margin-bottom:32px}
.section-head h2{font-size:clamp(1.7rem,3.2vw,2.5rem)}
.section-head .sub{color:var(--ink-soft);margin-top:6px;max-width:46ch}
.see-all{display:inline-flex;align-items:center;gap:6px;font-weight:700;color:var(--blue-700);white-space:nowrap}
.see-all:hover{gap:10px}

/* ---------- Botones ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  font-family:var(--font-head);font-weight:600;
  border-radius:var(--pill);
  padding:13px 24px;font-size:1rem;line-height:1;
  transition:transform .15s ease, box-shadow .2s ease, background .2s ease;
  white-space:nowrap;
}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--blue-700);color:#fff;box-shadow:var(--sh-blue)}
.btn-primary:hover{background:var(--blue-600);transform:translateY(-2px)}
.btn-accent{background:var(--accent);color:#fff;box-shadow:var(--sh-coral)}
.btn-accent:hover{background:var(--accent-600);transform:translateY(-2px)}
.btn-ghost{background:#fff;color:var(--blue-700);box-shadow:inset 0 0 0 2px var(--blue-200)}
.btn-ghost:hover{box-shadow:inset 0 0 0 2px var(--blue-400);background:var(--blue-50)}
.btn-soft{background:var(--blue-100);color:var(--blue-700)}
.btn-soft:hover{background:var(--blue-200)}
.btn-lg{padding:16px 30px;font-size:1.08rem}
.btn-block{width:100%}
.btn-wa{background:#25D366;color:#fff}
.btn-wa:hover{background:#1fbe5b;transform:translateY(-2px)}

/* ---------- Píldoras / badges ---------- */
.pill{display:inline-flex;align-items:center;gap:6px;border-radius:var(--pill);padding:6px 13px;font-weight:700;font-size:.8rem}
.pill-blue{background:var(--blue-100);color:var(--blue-700)}
.pill-coral{background:var(--accent-100);color:var(--accent-600)}
.pill-mint{background:var(--mint-100);color:#1f8f72}
.badge-sale{
  background:var(--accent);color:#fff;font-family:var(--font-head);font-weight:700;
  border-radius:var(--pill);padding:5px 12px;font-size:.82rem;box-shadow:var(--sh-coral);
}

/* ---------- Iconos ---------- */
.ic{width:22px;height:22px;flex:none;stroke:currentColor;fill:none;stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round}
.ic-sm{width:18px;height:18px}
.ic-lg{width:28px;height:28px}

/* ---------- Decoración: lunares y nube ---------- */
.dots{
  position:absolute;inset:0;pointer-events:none;z-index:0;
  opacity:var(--deco-dots);
  background-image:radial-gradient(var(--blue-200) 2.2px, transparent 2.3px);
  background-size:26px 26px;
  -webkit-mask-image:radial-gradient(120% 120% at 50% 0,#000 40%,transparent 78%);
          mask-image:radial-gradient(120% 120% at 50% 0,#000 40%,transparent 78%);
}
.cloud-edge{display:block;width:100%;height:auto;color:var(--wash)}
[style*="--on-blue"] .cloud-edge{color:inherit}

/* card base */
.card{
  background:var(--paper);border-radius:var(--r-lg);
  box-shadow:var(--sh-sm);border:1px solid var(--line-soft);
  transition:transform .2s ease, box-shadow .25s ease;
  position:relative;
}

/* placeholder de imagen (fallback) */
.imgph{
  width:100%;height:100%;
  background:
    repeating-linear-gradient(135deg,var(--blue-50),var(--blue-50) 11px,var(--blue-100) 11px,var(--blue-100) 22px);
  display:flex;align-items:center;justify-content:center;
  color:var(--blue-400);font-family:ui-monospace,Menlo,monospace;font-size:.72rem;
  letter-spacing:.04em;text-align:center;padding:10px;
}

/* scrollbar sutil */
*::-webkit-scrollbar{height:10px;width:10px}
*::-webkit-scrollbar-thumb{background:var(--blue-200);border-radius:999px;border:3px solid transparent;background-clip:content-box}
*::-webkit-scrollbar-thumb:hover{background:var(--blue-300);background-clip:content-box}

/* ============================================================
   Tarjeta de producto
   ============================================================ */
.pcard{display:flex;flex-direction:column;overflow:hidden;cursor:pointer}
.pcard:hover{transform:translateY(-5px);box-shadow:var(--sh-md)}
.pcard-media{position:relative;padding:14px 14px 0}
.pcard-img{
  aspect-ratio:1/1;border-radius:var(--r-md);overflow:hidden;
  background:var(--blue-50);display:flex;align-items:center;justify-content:center;
}
.pcard-img img{padding:8px}
.pcard-badges{position:absolute;top:22px;left:22px;z-index:2;display:flex;flex-direction:column;gap:6px;align-items:flex-start}
.wish{
  position:absolute;top:22px;right:22px;z-index:2;
  width:38px;height:38px;border-radius:50%;background:#fff;color:var(--ink-faint);
  display:grid;place-items:center;box-shadow:var(--sh-sm);transition:.18s;
}
.wish:hover{color:var(--accent);transform:scale(1.08)}
.wish.on{color:#fff;background:var(--accent)}
/* fila de acciones: Añadir + WhatsApp */
.pcard-actions{
  position:absolute;left:14px;right:14px;bottom:8px;z-index:2;
  display:flex;gap:8px;opacity:0;transform:translateY(8px);transition:.2s ease;
}
.pcard:hover .pcard-actions{opacity:1;transform:translateY(0)}
.pcard-add{
  flex:1;
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  background:var(--blue-700);color:#fff;font-family:var(--font-head);font-weight:600;
  border-radius:var(--pill);padding:11px;
  transition:.2s ease;box-shadow:var(--sh-blue);
}
.pcard-add:hover{background:var(--blue-600)}
.pcard-wa-btn{
  flex:0 0 auto;width:44px;border-radius:var(--pill);background:#25d366;color:#fff;
  display:grid;place-items:center;box-shadow:0 6px 16px -4px rgba(37,211,102,.6);transition:.18s;
}
.pcard-wa-btn:hover{background:#1fbe5a;transform:translateY(-1px)}
.pcard-wa-btn .ic-solid{width:20px;height:20px}
.pcard-body{padding:16px 18px 18px;display:flex;flex-direction:column;gap:7px;flex:1}
.pcard-brand{font-size:.74rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--blue-400)}
.pcard-name{font-size:1.02rem;font-weight:700;line-height:1.2;font-family:var(--font-head)}
.pcard-foot{margin-top:auto;display:flex;align-items:center;justify-content:space-between;gap:10px;padding-top:6px}
.swatches{display:inline-flex;gap:5px}
.sw{width:15px;height:15px;border-radius:50%;box-shadow:inset 0 0 0 1.5px rgba(0,0,0,.08)}
.instore{display:inline-flex;align-items:center;gap:4px;font-size:.76rem;font-weight:700;color:var(--blue-700);white-space:nowrap}
.instore .ic{stroke-width:2}

/* grid de productos */
.pgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
@media (max-width:1100px){.pgrid{grid-template-columns:repeat(3,1fr)}}
@media (max-width:760px){.pgrid{grid-template-columns:repeat(2,1fr);gap:14px}}

/* en móvil, mostrar siempre la fila de acciones */
@media (max-width:760px){
  .pcard-actions{position:static;opacity:1;transform:none;margin-top:10px}
  .pcard-add{box-shadow:none;padding:9px}
  .pcard-media{padding-bottom:0}
  .pcard-name{font-size:.92rem}
}

/* ============================================================
   Cabecera
   ============================================================ */
.hd{position:sticky;top:0;z-index:60;background:var(--paper);box-shadow:0 1px 0 var(--line);transition:transform .3s cubic-bezier(.3,.7,.2,1),box-shadow .2s}
.hd-scrolled{box-shadow:var(--sh-md)}

/* barra superior */
.hd-top{background:var(--blue-700);color:#fff;font-weight:700;font-size:.82rem}
[data-direction="boutique"] .hd-top{background:var(--ink)}
.hd-top-in{display:flex;align-items:center;gap:14px;height:38px}
.hd-top-item{display:inline-flex;align-items:center;gap:6px;color:#fff;opacity:.95;cursor:pointer;white-space:nowrap}
.hd-top-item:hover{opacity:1;text-decoration:underline}
.hd-top-sep{width:1px;height:16px;background:rgba(255,255,255,.3)}
.hd-top-mid{margin-left:auto;margin-right:auto;display:inline-flex;align-items:center;gap:7px;opacity:.95;font-weight:600}
.hd-top-mid .ic{color:var(--blue-200)}

/* fila principal */
.hd-main{display:flex;align-items:center;gap:22px;padding:15px 24px;transition:padding .2s}
.hd-scrolled .hd-main{padding:10px 24px}
.hd-burger{display:none;color:var(--blue-700)}
.hd-search{
  flex:1;max-width:640px;display:flex;align-items:center;gap:10px;
  background:var(--blue-50);border:2px solid var(--blue-100);border-radius:var(--pill);
  padding:6px 6px 6px 18px;color:var(--ink-faint);transition:.18s;
}
.hd-search:focus-within{border-color:var(--blue-400);background:#fff;box-shadow:0 0 0 4px var(--blue-100)}
.hd-search input{flex:1;border:none;background:none;outline:none;padding:8px 0;color:var(--ink)}
.hd-search input::placeholder{color:var(--ink-faint)}
.hd-search-btn{
  background:var(--blue-700);color:#fff;font-family:var(--font-head);font-weight:600;
  border-radius:var(--pill);padding:10px 22px;transition:.18s;
}
.hd-search-btn:hover{background:var(--blue-600)}
.hd-search-mobile{display:none}

.hd-actions{display:flex;align-items:center;gap:6px;margin-left:auto}
.hd-act{display:flex;flex-direction:column;align-items:center;gap:3px;padding:6px 12px;border-radius:var(--r-sm);color:var(--ink);transition:.15s}
.hd-act:hover{background:var(--blue-50);color:var(--blue-700)}
.hd-act-ic{position:relative;display:grid;place-items:center}
.hd-act-ic em{
  position:absolute;top:-7px;right:-9px;background:var(--accent);color:#fff;
  font-style:normal;font-weight:800;font-size:.66rem;min-width:17px;height:17px;border-radius:999px;
  display:grid;place-items:center;padding:0 4px;box-shadow:0 2px 6px rgba(247,112,111,.5);
}
.hd-act-lbl{font-size:.72rem;font-weight:700}
.hd-act-cart{background:var(--accent-100);color:var(--accent-600)}
.hd-act-cart:hover{background:var(--accent-100)}
.hd-act-cart .hd-act-ic em{background:var(--accent-600)}

/* navegación */
.hd-nav{position:relative;border-top:1px solid var(--line-soft)}
.hd-nav-in{display:flex;align-items:center;gap:0;height:52px}
.hd-navitem{height:100%}
.hd-navbtn{
  height:100%;display:inline-flex;align-items:center;gap:6px;padding:0 13px;
  font-family:var(--font-head);font-weight:600;font-size:.94rem;color:var(--ink);
  border-bottom:3px solid transparent;transition:.15s;white-space:nowrap;
}
.hd-navbtn .ic{color:var(--blue-400)}
.hd-navbtn:hover,.hd-navbtn.active{color:var(--blue-700);border-bottom-color:var(--blue-400)}
.hd-navbtn:hover .ic,.hd-navbtn.active .ic{color:var(--blue-700)}
.hd-navchev{width:14px;height:14px;opacity:.5;transition:.2s}
.hd-navbtn.active .hd-navchev{transform:rotate(180deg)}
.hd-navbtn.accent{color:var(--accent-600)}
.hd-navbtn.accent .ic{color:var(--accent)}
.hd-navbtn.accent:hover,.hd-navbtn.accent.active{border-bottom-color:var(--accent)}
.hd-nav-spacer{flex:1}
.hd-navlink{display:inline-flex;align-items:center;gap:6px;font-weight:700;color:var(--accent-600);padding:0 12px}
.hd-navlink .ic{color:var(--accent)}

/* megamenú */
.megapanel{
  position:absolute;left:0;right:0;top:100%;background:#fff;
  box-shadow:var(--sh-lg);border-top:1px solid var(--line-soft);
  border-radius:0 0 var(--r-lg) var(--r-lg);z-index:55;
  animation:megaIn .2s ease both;
}
@keyframes megaIn{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:none}}
.megapanel-in{display:grid;grid-template-columns:1fr 300px;gap:34px;padding:30px 24px 34px}
.mega-cols{display:grid;gap:30px}
.mega-col h4{font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;color:var(--blue-400);margin-bottom:14px;font-family:var(--font-head)}
.mega-col ul{display:flex;flex-direction:column;gap:9px}
.mega-col a{color:var(--ink-soft);font-weight:600;cursor:pointer;transition:.13s;display:inline-block}
.mega-col a:hover{color:var(--blue-700);transform:translateX(3px)}
.mega-promo{
  position:relative;overflow:hidden;text-align:left;
  background:linear-gradient(160deg,var(--blue-100),var(--blue-50));
  border-radius:var(--r-lg);padding:24px;display:flex;align-items:flex-end;min-height:200px;
}
.mega-promo-deco{position:absolute;inset:0}
.mega-promo-body{position:relative;z-index:1}
.mega-promo-body p{color:var(--ink);font-weight:700;font-family:var(--font-head);font-size:1.05rem;margin:10px 0 14px;line-height:1.25}
.mega-promo .see-all{color:var(--blue-700)}
.mega-promo:hover .see-all{gap:10px}

/* ---------- Drawer móvil ---------- */
.drawer{position:fixed;inset:0;z-index:100;background:rgba(20,40,80,.4);opacity:0;visibility:hidden;transition:.25s}
.drawer.open{opacity:1;visibility:visible}
.drawer-panel{
  position:absolute;left:0;top:0;bottom:0;width:min(88vw,380px);background:#fff;
  display:flex;flex-direction:column;transform:translateX(-100%);transition:transform .28s cubic-bezier(.3,.7,.2,1);
}
.drawer.open .drawer-panel{transform:none}
.drawer-head{display:flex;align-items:center;justify-content:space-between;padding:16px 18px;border-bottom:1px solid var(--line)}
.drawer-x{width:40px;height:40px;border-radius:50%;background:var(--blue-50);color:var(--blue-700);display:grid;place-items:center}
.drawer-scroll{flex:1;overflow-y:auto;padding:8px 0}
.drawer-cat-head{
  width:100%;display:flex;align-items:center;justify-content:space-between;
  padding:15px 20px;font-family:var(--font-head);font-weight:600;font-size:1.05rem;color:var(--ink);
}
.drawer-cat-head .ic:first-child{color:var(--blue-400);margin-right:4px}
.drawer-cat-head .rot{transform:rotate(180deg)}
.drawer-cat.accent .drawer-cat-head{color:var(--accent-600)}
.drawer-cat.accent .drawer-cat-head .ic:first-child{color:var(--accent)}
.drawer-sub{padding:0 20px 14px 24px;display:flex;flex-direction:column;gap:14px;animation:screenIn .25s ease both}
.drawer-all{align-self:flex-start;background:var(--blue-100);color:var(--blue-700);font-weight:700;border-radius:var(--pill);padding:8px 16px;font-size:.85rem}
.drawer-subcol{display:flex;flex-direction:column;gap:4px}
.drawer-subcol strong{font-size:.74rem;letter-spacing:.08em;text-transform:uppercase;color:var(--blue-400)}
.drawer-subcol a{color:var(--ink-soft);font-weight:600;padding:5px 0;cursor:pointer}
.drawer-subcol a:active{color:var(--blue-700)}
.drawer-foot{padding:16px 18px;border-top:1px solid var(--line);display:flex;flex-direction:column;gap:6px}
.drawer-foot-link{display:flex;align-items:center;gap:9px;padding:11px 10px;font-weight:700;color:var(--ink-soft);border-radius:var(--r-sm)}
.drawer-foot-link:hover{background:var(--blue-50);color:var(--blue-700)}

/* ---------- responsive cabecera ---------- */
@media (max-width:980px){
  .hd-top-mid{display:none}
  .hd-act-lbl{display:none}
  .hd-nav{display:none}
}
@media (max-width:760px){
  .hd-burger{display:grid;place-items:center}
  .hd-search{display:none}
  .hd-search-mobile{display:flex;margin:0 16px 12px}
  .hd-main{gap:14px;padding:12px 16px}
  .hd-hide-sm{display:none !important}
  .hd-actions{gap:2px}
  /* barra superior más fina en móvil */
  .hd-top-in{height:32px;gap:10px;font-size:.78rem}
  /* el header se desliza fuera de vista al bajar y reaparece al subir */
  .hd-hidden{transform:translateY(-100%)}
}

/* ============================================================
   HOME
   ============================================================ */
/* hero */
.hero{position:relative;background:linear-gradient(180deg,var(--blue-50),var(--blue-100));padding:56px 0 0;overflow:hidden}
[data-direction="boutique"] .hero{background:linear-gradient(180deg,#fbf8f5,var(--blue-50))}
.hero-in{position:relative;z-index:1;display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center;padding-bottom:64px}
.hero-copy .kicker{margin-bottom:18px}
.hero-title{font-size:clamp(2.4rem,5vw,4rem);line-height:1.02}
.hero-title .hl{color:var(--blue-700)}
.hero-title .hl::after{content:"";display:inline-block;width:.42em;height:.42em;margin-left:.12em;border-radius:50%;background:var(--accent)}
.hero-sub{font-size:1.12rem;color:var(--ink-soft);max-width:46ch;margin:22px 0 28px;line-height:1.6}
.hero-cta{display:flex;gap:12px;flex-wrap:wrap}
.hero-cta .btn{white-space:nowrap}
.hero-cta .btn-lg{padding:15px 22px}
.hero-chips{display:flex;gap:10px;flex-wrap:wrap;margin-top:26px}
.hero-chip{display:inline-flex;align-items:center;gap:7px;background:rgba(255,255,255,.7);color:var(--ink-soft);font-weight:700;font-size:.85rem;padding:8px 14px;border-radius:var(--pill)}
.hero-chip .ic{color:var(--blue-500);stroke-width:2.4}

.hero-visual{position:relative;padding-bottom:46px}
.hero-cloud{
  position:relative;background:#fff;border-radius:50% 50% 46% 54%/58% 58% 42% 42%;
  padding:34px;box-shadow:var(--sh-lg);border:3px solid var(--blue-100);overflow:hidden;
}
[data-direction="sereno"] .hero-cloud,[data-direction="boutique"] .hero-cloud{border-radius:var(--r-xl)}
.hero-cloud-img{aspect-ratio:1/1;display:flex;align-items:center;justify-content:center;position:relative;z-index:1}
.hero-cloud-img img{max-height:100%;object-fit:contain}
.hero-prodcard{
  position:absolute;left:8%;right:8%;bottom:0;z-index:4;
  background:rgba(255,255,255,.96);backdrop-filter:blur(6px);
  border-radius:var(--r-md);padding:14px 16px;display:flex;align-items:center;gap:12px;
  box-shadow:var(--sh-md);text-align:left;border:1px solid var(--line);transition:.18s;
}
.hero-prodcard:hover{transform:translateY(-3px)}
.hero-prodcard-info{flex:1;min-width:0}
.hero-prodcard-brand{font-size:.7rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--blue-400)}
.hero-prodcard-info strong{display:block;font-family:var(--font-head);font-size:1rem;line-height:1.2;margin:1px 0 3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.hero-prodcard-go{width:40px;height:40px;flex:none;border-radius:50%;background:var(--blue-700);color:#fff;display:grid;place-items:center}
.hero-flag{position:absolute;top:18px;left:18px;z-index:6;font-size:1rem;padding:7px 14px}
.hero-heart,.hero-spark{position:absolute;display:grid;place-items:center;border-radius:50%;color:#fff;z-index:5;box-shadow:var(--sh-md)}
.hero-heart{width:62px;height:62px;background:var(--accent);top:-14px;right:8%;}
.hero-heart .ic{width:30px;height:30px;fill:#fff;stroke:#fff}
.hero-spark{width:46px;height:46px;background:var(--blue-400);top:38%;left:-14px}
.hero-spark .ic{fill:#fff;stroke:#fff}
[data-direction="sereno"] .hero-heart,[data-direction="sereno"] .hero-spark{display:none}

/* confianza */
.trust-band{background:var(--paper)}
.trust-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;padding:8px 24px 36px}
.trust-item{display:flex;gap:14px;align-items:flex-start;padding:18px;border-radius:var(--r-lg);background:var(--blue-50);transition:.18s}
.trust-item:hover{background:var(--blue-100)}
.trust-ic{width:50px;height:50px;flex:none;border-radius:var(--r-md);background:#fff;color:var(--blue-700);display:grid;place-items:center;box-shadow:var(--sh-sm)}
.trust-item strong{font-family:var(--font-head);font-size:1.02rem;display:block;margin-bottom:3px}
.trust-item p{font-size:.86rem;color:var(--ink-soft);line-height:1.4}

/* categorías */
.catgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.catcard{
  position:relative;display:flex;align-items:center;gap:14px;text-align:left;
  background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:20px 22px;transition:.18s;overflow:hidden;
}
.catcard:hover{transform:translateY(-4px);box-shadow:var(--sh-md);border-color:var(--blue-200)}
.catcard-ic{width:54px;height:54px;flex:none;border-radius:var(--r-md);background:var(--blue-50);color:var(--blue-700);display:grid;place-items:center;transition:.18s}
.catcard:hover .catcard-ic{background:var(--blue-700);color:#fff}
.catcard-label{flex:1;font-family:var(--font-head);font-weight:700;font-size:1.12rem}
.catcard-go{color:var(--blue-300);transition:.18s}
.catcard:hover .catcard-go{color:var(--blue-700);transform:translateX(3px)}
.catcard.accent{background:linear-gradient(150deg,var(--accent-100),#fff)}
.catcard.accent .catcard-ic{background:var(--accent);color:#fff}
.catcard.accent .catcard-label{color:var(--accent-600)}

/* outlet banner */
.outlet-band{
  position:relative;overflow:hidden;border-radius:var(--r-xl);
  background:linear-gradient(130deg,var(--accent),var(--coral-600));color:#fff;
  display:grid;grid-template-columns:1.1fr 1fr;gap:24px;align-items:center;padding:44px 44px;
  box-shadow:var(--sh-coral);
}
.outlet-band .dots{opacity:.5;background-image:radial-gradient(rgba(255,255,255,.4) 2.2px,transparent 2.3px)}
.outlet-copy{position:relative;z-index:1}
.outlet-copy h2{color:#fff;font-size:clamp(1.8rem,3.4vw,2.7rem);margin:14px 0 10px}
.outlet-big{font-size:1.25em}
.outlet-copy p{color:rgba(255,255,255,.92);margin-bottom:22px;max-width:38ch}
.outlet-products{position:relative;z-index:1;display:grid;grid-template-columns:1fr 1fr;gap:14px}
.outlet-mini{position:relative;background:#fff;border-radius:var(--r-md);padding:10px;aspect-ratio:1/1;transition:.18s}
.outlet-mini:hover{transform:translateY(-4px)}
.outlet-mini-img{width:100%;height:100%;display:flex;align-items:center;justify-content:center;overflow:hidden;border-radius:var(--r-sm)}
.outlet-mini .badge-sale{position:absolute;top:8px;left:8px}

/* tienda en Oviedo */
.store-feature{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.store-photo{position:relative}
.store-photo .imgph{aspect-ratio:4/3;font-size:.8rem}
.store-photo-img{width:100%;aspect-ratio:16/9;object-fit:cover;object-position:center;border-radius:var(--r-xl);box-shadow:var(--sh-md)}
.store-photo-badge{
  position:absolute;bottom:-18px;left:24px;background:#fff;border-radius:var(--r-md);
  padding:13px 18px 13px 13px;display:flex;align-items:center;gap:12px;box-shadow:var(--sh-md);
}
.store-photo-heart{width:42px;height:42px;border-radius:50%;background:var(--accent-100);color:var(--accent-600);display:grid;place-items:center}
.store-photo-heart .ic{fill:var(--accent-600);stroke:var(--accent-600)}
.store-photo-badge strong{display:block;font-family:var(--font-head);font-size:.98rem}
.store-photo-badge span{font-size:.8rem;color:var(--ink-soft)}
.store-text h2{font-size:clamp(1.9rem,3.6vw,2.7rem);margin:14px 0 16px}
.store-text>p{color:var(--ink-soft);font-size:1.05rem;line-height:1.6;max-width:48ch}
.store-list{margin:22px 0;display:flex;flex-direction:column}
.store-list li{display:flex;align-items:center;gap:12px;padding:13px 0;border-top:1px solid var(--line)}
.store-list li:last-child{border-bottom:1px solid var(--line)}
.store-list li .ic{color:var(--blue-400)}
.store-list li span{flex:1;font-weight:700}
.store-list li b{font-family:var(--font-head);color:var(--ink-soft);font-weight:600}
.store-actions{display:flex;gap:12px;flex-wrap:wrap}

/* newsletter */
.news-band{position:relative;overflow:hidden;border-radius:var(--r-xl);background:linear-gradient(130deg,var(--blue-700),var(--blue-500));padding:48px;box-shadow:var(--sh-lg)}
.news-band .dots{
  opacity:.5;
  background-image:radial-gradient(rgba(255,255,255,.3) 2px,transparent 2.1px);
  -webkit-mask-image:linear-gradient(100deg,transparent 0,transparent 56%,#000 82%);
          mask-image:linear-gradient(100deg,transparent 0,transparent 56%,#000 82%);
}
.news-in{position:relative;z-index:1;display:grid;grid-template-columns:1.2fr 1fr;gap:32px;align-items:center}
.news-in h2{font-size:clamp(1.6rem,3vw,2.2rem)}
.news-form{display:flex;gap:10px;background:#fff;padding:8px;border-radius:var(--pill);box-shadow:var(--sh-md)}
.news-form input{flex:1;border:none;outline:none;background:none;padding:12px 18px;border-radius:var(--pill)}
.news-form .btn{white-space:nowrap}

/* responsive home */
@media (max-width:980px){
  .hero-in{grid-template-columns:1fr;gap:36px;padding-bottom:48px}
  .hero-visual{max-width:460px;margin:0 auto;width:100%}
  .trust-grid{grid-template-columns:repeat(2,1fr)}
  .catgrid{grid-template-columns:repeat(2,1fr)}
  .store-feature{grid-template-columns:1fr;gap:40px}
  .outlet-band{grid-template-columns:1fr;gap:28px;padding:34px}
  .news-in{grid-template-columns:1fr;gap:22px}
}
@media (max-width:760px){
  .hero{padding-top:32px}
  .hero-cta .btn{flex:1}
  .trust-grid{gap:10px}
  .trust-item{padding:14px;flex-direction:column;gap:10px}
  .catgrid{grid-template-columns:1fr 1fr;gap:12px}
  .catcard{padding:15px 14px;gap:11px}
  .catcard-ic{width:42px;height:42px;border-radius:var(--r-sm)}
  .catcard-label{font-size:.92rem;min-width:0;line-height:1.15}
  .catcard-go{display:none}
  .section{padding-top:44px;padding-bottom:44px}
  .news-form{flex-direction:column;border-radius:var(--r-lg)}
  .news-form .btn{width:100%}
  .outlet-products{grid-template-columns:1fr 1fr}
}

/* fade-in al cambiar de pantalla */
@keyframes screenIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.screen-in{animation:screenIn .42s cubic-bezier(.2,.7,.2,1) both}
@media (prefers-reduced-motion:reduce){.screen-in{animation:none}}
