/* ============================================================
   DECOLOUNGE — site.css
   Estilos de páginas interiores (espejo del sitio).
   Complementa styles.css (tokens, nav base, footer, botones, wa-dock).
   ============================================================ */

/* ---------- NAV: menús desplegables ---------- */
.nav-group{position:relative;display:flex;align-items:center}
.nav-grp-btn{
  background:none;border:0;color:var(--ink);font-family:var(--sans);
  font-size:12.5px;letter-spacing:.16em;text-transform:uppercase;
  opacity:.82;display:inline-flex;align-items:center;gap:7px;padding:6px 0;
  transition:opacity .3s;
}
.nav-grp-btn:hover{opacity:1}
.nav-grp-btn svg{width:12px;height:12px;transition:transform .3s var(--ease)}
.nav-sub{
  position:absolute;top:100%;left:50%;transform:translate(-50%,12px);
  margin-top:10px;min-width:230px;
  background:rgba(13,11,23,.97);backdrop-filter:blur(18px) saturate(140%);
  -webkit-backdrop-filter:blur(18px) saturate(140%);
  border:1px solid var(--line);border-radius:16px;padding:20px;
  display:flex;gap:30px;opacity:0;visibility:hidden;pointer-events:none;
  transition:opacity .3s var(--ease),transform .3s var(--ease);
  box-shadow:0 30px 70px -30px rgba(0,0,0,.85);z-index:60;
}
.nav-sub::before{content:"";position:absolute;top:-12px;left:0;right:0;height:14px}
.nav-group.wide .nav-sub{left:0;transform:translate(0,12px)}
.nav-group:hover .nav-sub,.nav-group:focus-within .nav-sub{opacity:1;visibility:visible;pointer-events:auto;transform:translate(-50%,0)}
.nav-group.wide:hover .nav-sub,.nav-group.wide:focus-within .nav-sub{transform:translate(0,0)}
.nav-group:hover .nav-grp-btn svg,.nav-group:focus-within .nav-grp-btn svg{transform:rotate(180deg)}
.nav-col{display:flex;flex-direction:column;gap:10px;min-width:168px}
.nav-col-h{font-size:10px;letter-spacing:.24em;text-transform:uppercase;color:var(--orquidea);margin-bottom:4px}
.nav-sub a{font-size:13px;letter-spacing:.02em;text-transform:none;color:rgba(236,231,244,.82);opacity:1;padding:2px 0}
.nav-sub a::after{display:none}
.nav-sub a:hover{color:var(--rosa);opacity:1}

@media (max-width:920px){
  .nav-links{justify-content:flex-start;overflow-y:auto;padding-top:96px;padding-bottom:48px;gap:16px}
  .nav-group{flex-direction:column;align-items:flex-start;width:100%}
  .nav-grp-btn{font-size:18px;letter-spacing:.06em;justify-content:space-between;width:100%}
  .nav-sub{
    position:static;transform:none !important;opacity:1;visibility:hidden;pointer-events:auto;
    display:none;flex-direction:column;gap:16px;min-width:0;margin:6px 0 0;
    background:none;border:0;box-shadow:none;backdrop-filter:none;padding:4px 0 4px 14px;
    border-left:1px solid var(--line);
  }
  .nav-group.exp .nav-sub{display:flex;visibility:visible}
  .nav-group.exp .nav-grp-btn svg{transform:rotate(180deg)}
  .nav-sub a{font-size:15px}
  .nav-col{gap:12px;min-width:0}
}

/* ---------- Página interior: base ---------- */
body.interior{min-height:100vh}
main{position:relative;z-index:2}

.phero{
  position:relative;overflow:hidden;
  padding:calc(96px + 7vh) 0 clamp(40px,7vh,72px);
  border-bottom:1px solid var(--line);
}
.phero.has-img{padding-top:calc(120px + 9vh);padding-bottom:clamp(48px,9vh,90px)}
.phero-media{position:absolute;inset:0;z-index:0}
.phero-media img{width:100%;height:100%;object-fit:cover;transform:scale(1.05)}
.phero-scrim{position:absolute;inset:0;z-index:1;background:
  linear-gradient(180deg,rgba(9,8,15,.62) 0%,rgba(9,8,15,.42) 40%,rgba(9,8,15,.86) 100%),
  radial-gradient(60% 80% at 15% 30%,rgba(226,0,205,.12),transparent 60%)}
.phero .wrap{position:relative;z-index:2}
.phero h1{font-size:clamp(34px,6.2vw,78px);max-width:18ch;margin-top:8px;line-height:1.02}
.phero .sub{color:var(--muted);max-width:62ch;margin-top:22px;font-size:clamp(15px,1.6vw,18px);line-height:1.6}
.phero.has-img .sub{color:rgba(236,231,244,.86)}

.crumbs{font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);
  display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin-bottom:24px}
.crumbs a{color:var(--muted);transition:color .3s}
.crumbs a:hover{color:var(--ink)}
.crumbs b{color:var(--champan);font-weight:500}
.crumbs span{opacity:.4}

.psection{padding:clamp(46px,8vh,92px) 0;position:relative}
.psection .shead{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:end;margin-bottom:36px}
@media (max-width:820px){.psection .shead{grid-template-columns:1fr;gap:18px}}

/* ---------- Prosa / artículos / legales ---------- */
.prose{max-width:72ch;color:rgba(236,231,244,.85);font-size:17px;line-height:1.75}
.prose h2{font-size:clamp(24px,3.4vw,40px);margin:34px 0 14px}
.prose h2:first-child{margin-top:0}
.prose h3{font-size:clamp(19px,2.2vw,26px);margin:26px 0 10px;color:var(--champan)}
.prose p{margin:0 0 18px}
.prose ul{padding-left:20px;margin:0 0 18px}
.prose li{margin:0 0 9px}
.prose a{color:var(--rosa);text-decoration:underline;text-underline-offset:3px}
.legal{max-width:78ch}

/* ---------- Marcadores provisionales ---------- */
.prov{
  display:inline-flex;gap:8px;align-items:center;
  font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:#FFD27A;
  border:1px dashed rgba(255,210,122,.45);background:rgba(255,210,122,.06);
  padding:7px 13px;border-radius:100px;margin-bottom:20px;
}

/* ---------- Grillas de tarjetas (categorías / productos / blog) ---------- */
.cardgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(238px,1fr));gap:18px;margin-top:6px}
.pcard{
  position:relative;display:flex;flex-direction:column;overflow:hidden;
  border:1px solid var(--line);border-radius:18px;background:var(--surface);
  transition:transform .45s var(--ease),border-color .45s,box-shadow .45s;
}
.pcard:hover{transform:translateY(-4px);border-color:var(--line-strong);box-shadow:0 30px 60px -34px rgba(0,0,0,.8)}
.pcard .media{display:block;aspect-ratio:1/1;overflow:hidden;background:var(--surface-2);position:relative}
.pcard .media img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease)}
.pcard .media::after{content:"";position:absolute;inset:0;background:url(assets/logo.png) center / 32% no-repeat;opacity:.1;pointer-events:none}
.pcard:hover .media img{transform:scale(1.06)}
.pcard .media-grad{background:linear-gradient(150deg,var(--orquidea),var(--purpura) 55%,var(--cobalto))}
.pcard .b{display:flex;flex-direction:column;gap:7px;padding:16px 18px 18px}
.pcard .k{font-size:10.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--orquidea)}
.pcard .pcard-t{font-size:19px;line-height:1.15}
.pcard .pcard-go{margin-top:6px;font-size:12px;letter-spacing:.04em;color:var(--muted);display:inline-flex;align-items:center;gap:7px;transition:color .3s}
.pcard .pcard-go svg{width:15px;height:15px;transition:transform .35s var(--ease)}
.pcard:hover .pcard-go{color:var(--ink)}
.pcard:hover .pcard-go svg{transform:translateX(4px)}
.pcard-prov{position:absolute;bottom:12px;left:12px;z-index:3;font-size:9.5px;letter-spacing:.14em;text-transform:uppercase;
  color:#FFD27A;background:rgba(12,11,22,.7);border:1px dashed rgba(255,210,122,.5);padding:4px 9px;border-radius:100px}

/* ---------- Bloque de marca / pilares en interiores ---------- */
.brandband .about{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
@media (max-width:880px){.brandband .about{grid-template-columns:1fr;gap:30px}}

/* ---------- Producto: detalle ---------- */
.product-grid{display:grid;grid-template-columns:1.05fr 1fr;gap:clamp(28px,5vw,60px);align-items:start}
@media (max-width:880px){.product-grid{grid-template-columns:1fr;gap:28px}}
.product-media{position:relative;border:1px solid var(--line);border-radius:22px;overflow:hidden;background:var(--surface-2)}
.product-media img{width:100%;aspect-ratio:1/1;object-fit:cover}
.product-media::after{content:"";position:absolute;inset:0;background:url(assets/logo.png) center / 22% no-repeat;opacity:.1;pointer-events:none}
.product-media .prov{position:absolute;left:14px;bottom:14px;margin:0}
.product-info h2{font-size:clamp(26px,4vw,46px)}
.product-info .lead{margin:14px 0 6px}

/* ---------- CTA band ---------- */
.ctaband{
  text-align:center;border:1px solid var(--line);border-radius:26px;
  padding:clamp(36px,6vw,64px) clamp(24px,5vw,60px);
  background:
    radial-gradient(70% 120% at 50% -10%,rgba(226,0,205,.16),transparent 60%),
    radial-gradient(60% 120% at 100% 120%,rgba(27,52,216,.16),transparent 60%),
    var(--surface);
}
.ctaband .eyebrow{justify-content:center}
.ctaband h2{font-size:clamp(26px,4.4vw,52px);margin:14px 0 12px}
.ctaband p{color:var(--muted);max-width:54ch;margin:0 auto 26px}
.ctaband-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.center-actions{margin-top:30px;display:flex;justify-content:center}

/* el dock de WhatsApp ya es fixed; nada que reposicionar en interiores */

/* ============================================================
   TARJETAS: enlace estirado + botón "Añadir a mi evento"
   ============================================================ */
.pcard-link{position:absolute;inset:0;z-index:1;border-radius:18px}
.pcard-add{
  position:absolute;top:12px;left:12px;z-index:3;
  width:40px;height:40px;border-radius:50%;border:1px solid var(--line-strong);
  background:rgba(12,11,22,.66);backdrop-filter:blur(8px);color:var(--ink);
  font-size:22px;line-height:1;display:grid;place-items:center;
  transition:background .3s var(--ease),transform .3s var(--ease),color .3s,border-color .3s;
}
.pcard-add:hover{background:var(--accent);border-color:var(--accent);color:#fff;transform:scale(1.1)}
.pcard-add.added{background:#1faa59;border-color:#1faa59;color:#fff}
.pcard-go{position:relative;z-index:0}

.btn-add{
  border:1px solid var(--accent);color:var(--ink);
  background:var(--accent-soft);
}
.btn-add:hover{background:var(--accent);color:#fff}
.btn-add.added{background:#1faa59;border-color:#1faa59;color:#fff}

/* ============================================================
   "ARMA TU EVENTO" — moodboard flotante (abajo-izquierda)
   ============================================================ */
.mood{position:fixed;left:max(18px,env(safe-area-inset-left));bottom:24px;z-index:70;font-family:var(--sans);transition:opacity .5s var(--ease),transform .5s var(--ease)}
.mood.is-hidden{opacity:0;visibility:hidden;transform:translateY(26px);pointer-events:none}
.mood-fab{
  position:relative;display:inline-flex;align-items:center;gap:11px;
  padding:16px 26px 16px 22px;border-radius:100px;border:1.5px solid rgba(226,0,205,.55);
  background:linear-gradient(135deg,rgba(226,0,205,.22),rgba(27,52,216,.16)),rgba(13,11,23,.74);
  backdrop-filter:blur(16px) saturate(150%);-webkit-backdrop-filter:blur(16px) saturate(150%);
  color:var(--ink);font-size:14.5px;font-weight:600;letter-spacing:.03em;
  box-shadow:0 18px 46px -16px rgba(226,0,205,.5);
  transition:transform .3s var(--ease),border-color .3s,background .3s,box-shadow .3s;
  animation:moodBreathe 3s var(--ease) infinite;
}
.mood-fab svg{width:21px;height:21px}
@keyframes moodBreathe{
  0%,100%{box-shadow:0 18px 46px -16px rgba(226,0,205,.5), 0 0 0 0 rgba(226,0,205,.55)}
  50%{box-shadow:0 18px 46px -16px rgba(226,0,205,.5), 0 0 0 14px rgba(226,0,205,0)}
}
body.no-motion .mood-fab{animation:none}
.mood-fab:not(.empty){animation:none}
.mood.open .mood-fab,.mood-fab:hover{animation:none}
.mood-fab:hover{transform:translateY(-3px);border-color:var(--accent);box-shadow:0 24px 58px -16px rgba(226,0,205,.65)}
.mood-fab svg{width:21px;height:21px}
.mood-count{
  min-width:22px;height:22px;padding:0 6px;border-radius:100px;background:var(--accent);color:#fff;
  font-size:12px;font-weight:700;display:inline-grid;place-items:center;
}
.mood-fab.empty .mood-count{background:var(--muted)}
.mood-count.pop{animation:moodPop .5s var(--ease)}
@keyframes moodPop{0%{transform:scale(1)}40%{transform:scale(1.5)}100%{transform:scale(1)}}
.mi-thumb{width:50px;height:50px;border-radius:10px;background:linear-gradient(150deg,var(--orquidea),var(--purpura) 60%,var(--cobalto))}
.mood-panel{
  position:absolute;left:0;bottom:calc(100% + 16px);width:min(94vw,404px);
  background:
    radial-gradient(130% 90% at 0% 0%, rgba(226,0,205,.2), transparent 55%),
    radial-gradient(130% 90% at 100% 100%, rgba(27,52,216,.18), transparent 55%),
    rgba(12,11,22,.78);
  backdrop-filter:blur(26px) saturate(155%);-webkit-backdrop-filter:blur(26px) saturate(155%);
  border:1px solid rgba(226,0,205,.35);border-radius:26px;padding:24px;
  box-shadow:0 50px 110px -34px rgba(0,0,0,.9), inset 0 1px 0 rgba(255,255,255,.06);
  opacity:0;visibility:hidden;transform:translateY(16px) scale(.97);transform-origin:bottom left;
  transition:opacity .38s var(--ease),transform .38s var(--ease),visibility .38s;
  max-height:min(74vh,600px);display:flex;flex-direction:column;
}
.mood.open .mood-panel{opacity:1;visibility:visible;transform:none}
.mood-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}
.mood-head b{font-size:20px}
.mood-head small{display:block;font-size:11px;color:var(--muted);letter-spacing:.04em;font-weight:400}
.mood-close{background:none;border:0;color:var(--muted);font-size:18px;padding:6px;line-height:1}
.mood-close:hover{color:var(--ink)}
.mood-list{overflow-y:auto;margin:8px -6px;padding:0 6px;display:flex;flex-direction:column;gap:10px;flex:1}
.mood-item{display:grid;grid-template-columns:50px 1fr auto;gap:12px;align-items:center}
.mood-item img{width:50px;height:50px;border-radius:10px;object-fit:cover;background:var(--surface-2)}
.mood-item .mi-name{font-size:13.5px;line-height:1.25;color:var(--ink)}
.mood-item .mi-name a{color:var(--ink)}
.mood-item .mi-name a:hover{color:var(--rosa)}
.mood-item .mi-rm{background:none;border:0;color:var(--muted);font-size:16px;padding:6px}
.mood-item .mi-rm:hover{color:var(--magenta)}
.mood-empty{padding:10px 2px 4px;display:flex;flex-direction:column;gap:0}
.mood-kicker{font-size:10.5px;letter-spacing:.24em;text-transform:uppercase;color:var(--rosa);margin-bottom:10px}
.mood-h{font-size:clamp(24px,6vw,30px);line-height:1.04;color:#fff;margin:0 0 12px}
.mood-h em{color:var(--rosa)}
.mood-empty p{margin:0 0 20px;color:rgba(236,231,244,.82);font-size:14.5px;line-height:1.6}
.mood-empty b{color:#fff}
.mood-cat{width:100%;justify-content:center;font-size:14px;padding:15px 22px}
.mood-actions{display:flex;flex-direction:column;gap:10px;margin-top:14px;padding-top:14px;border-top:1px solid var(--line)}
.mood-actions .btn{justify-content:center;width:100%}
.mood-actions #moodClear{padding:10px;font-size:12.5px}
@media (max-width:520px){
  .mood{bottom:18px}
  .mood-fab{padding:12px 16px 12px 14px;gap:8px;font-size:12px}
}
body.no-motion .mood-panel{transition:none}

/* ============================================================
   TRANSICIONES CINEMÁTICAS entre páginas (View Transitions API)
   Navegador compatible (Chrome/Edge): cross-fade suave entre páginas.
   ============================================================ */
@view-transition{ navigation: auto; }
@media (prefers-reduced-motion: no-preference){
  ::view-transition-old(root){ animation: vtOut .32s cubic-bezier(.2,.7,.2,1) both; }
  ::view-transition-new(root){ animation: vtIn .42s cubic-bezier(.2,.7,.2,1) both; }
  @keyframes vtOut{ to{ opacity:0; transform:translateY(-8px) scale(.992); } }
  @keyframes vtIn{ from{ opacity:0; transform:translateY(12px) scale(.994); } }
}

/* ============================================================
   MARKETPLACE — barra de categorías, zonas, buscador, grilla
   ============================================================ */
/* Barra de categorías sticky (siempre arriba al navegar el catálogo) */
.catbar{position:sticky;top:58px;z-index:40;
  background:rgba(9,8,15,.82);backdrop-filter:blur(16px) saturate(140%);-webkit-backdrop-filter:blur(16px) saturate(140%);
  border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.catbar-inner{display:flex;gap:9px;overflow-x:auto;max-width:var(--maxw);margin:0 auto;padding:12px var(--gut);scrollbar-width:none}
.catbar-inner::-webkit-scrollbar{display:none}
.catbar a{flex:none;padding:9px 18px;border-radius:100px;border:1px solid var(--line);
  font-size:12.5px;letter-spacing:.03em;color:rgba(236,231,244,.85);white-space:nowrap;
  transition:border-color .3s,background .3s,color .3s}
.catbar a::after{display:none}
.catbar a:hover{border-color:var(--line-strong);color:var(--ink)}
.catbar a.active{background:var(--ink);border-color:var(--ink);color:#0b0a12;font-weight:600}

/* Tarjetas de zona (6 categorías principales) */
.zone-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:28px}
@media (max-width:820px){.zone-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:520px){.zone-grid{grid-template-columns:1fr}}
.zcard{position:relative;min-height:188px;border-radius:18px;overflow:hidden;border:1px solid var(--line);
  display:flex;align-items:flex-end;padding:20px;isolation:isolate;
  transition:transform .5s var(--ease),border-color .5s}
.zcard::before{content:"";position:absolute;inset:0;z-index:-2;background:var(--img) center/cover;transition:transform .8s var(--ease)}
.zcard::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(180deg,rgba(9,8,15,.12),rgba(9,8,15,.84))}
.zcard:hover{transform:translateY(-4px);border-color:var(--accent)}
.zcard:hover::before{transform:scale(1.07)}
.zcard-t{display:block;font-size:22px;color:#fff;line-height:1.1}
.zcard-d{display:block;font-size:12.5px;color:rgba(236,231,244,.82);margin-top:4px}

/* Toolbar (título + buscador) y buscador */
.cat-toolbar{display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap;margin-bottom:18px}
.cat-toolbar h2{font-size:clamp(26px,3.6vw,40px)}
.cat-back{font-size:13px;color:var(--muted);transition:color .3s}
.cat-back:hover{color:var(--ink)}
.cat-search{position:relative;display:flex;align-items:center;min-width:min(320px,100%);flex:1;max-width:360px}
.cat-search svg{position:absolute;left:15px;width:18px;height:18px;color:var(--muted);pointer-events:none}
.cat-search input{width:100%;padding:13px 18px 13px 44px;border-radius:100px;border:1px solid var(--line-strong);
  background:rgba(236,231,244,.04);color:var(--ink);font-family:var(--sans);font-size:14px;transition:border-color .3s}
.cat-search input::placeholder{color:var(--muted)}
.cat-search input:focus{outline:none;border-color:var(--accent);background:rgba(236,231,244,.06)}

.catchip-lbl{flex:none;align-self:center;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-right:4px}
/* Chips de subcategoría */
.subchips{display:flex;flex-wrap:wrap;gap:9px;margin-bottom:26px}
.noresults{color:var(--muted);padding:24px 0;font-size:15px}
.noresults a{color:var(--rosa);text-decoration:underline;text-underline-offset:3px}

/* Strip de zonas: tarjetas con icono, montadas sobre el hero, scroll horizontal */
.zonespick{position:relative;z-index:6;margin-top:clamp(-118px,-8vw,-78px)}
.zonespick .wrap{position:relative}
.zone-strip{display:flex;gap:14px;overflow-x:auto;padding:2px 0 8px;scrollbar-width:none;scroll-behavior:smooth;
  -webkit-mask:linear-gradient(90deg,#000 0,#000 90%,transparent 100%);mask:linear-gradient(90deg,#000 0,#000 90%,transparent 100%)}
.zone-strip.at-end{-webkit-mask:none;mask:none}
.zone-strip::-webkit-scrollbar{display:none}

/* Hero del catálogo: degradé de marca + logo (sin foto) */
.chero{padding:calc(100px + 3vh) 0 clamp(128px,15vh,176px);overflow:hidden;border-bottom:0}
.chero-bg{position:absolute;inset:0;z-index:0;
  background:
    radial-gradient(70% 90% at 8% 0%, rgba(226,0,205,.5), transparent 58%),
    radial-gradient(60% 95% at 98% 20%, rgba(27,52,216,.42), transparent 58%),
    linear-gradient(180deg,#34104c 0%,#1b1140 36%,#100d22 66%,var(--bg) 100%)}
.chero-stars{position:absolute;inset:0;width:100%;height:100%;z-index:1;pointer-events:none}
/* Galería de montajes (pistas LED): cuadrícula simple sobre los gx-item del home */
.pgal{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:14px;margin-top:18px}
.pgal .gx-item{aspect-ratio:4/3;width:100%}
/* Tablero de inspiración estilo Pinterest: columnas con alturas naturales */
.pinboard{columns:300px 4;column-gap:14px;margin-top:22px}
.pinboard .gx-item{display:block;width:100%;height:auto;margin:0 0 14px;break-inside:avoid;border-radius:18px}
.pinboard .gx-item img{position:static;width:100%;height:auto;object-fit:unset}
/* Ideas para eventos: feed estilo Instagram */
.ig-head{display:flex;align-items:center;gap:clamp(18px,4vw,40px);margin-bottom:26px}
.ig-avatar{width:clamp(72px,10vw,120px);height:clamp(72px,10vw,120px);border-radius:50%;
  border:3px solid var(--accent);padding:4px;background:var(--surface)}
.ig-meta{display:flex;flex-direction:column;gap:8px;min-width:0}
.ig-row{display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.ig-handle{font-family:var(--serif);font-size:clamp(20px,3vw,28px);letter-spacing:.01em}
.ig-follow{font-size:13px;font-weight:700;color:#fff;background:var(--accent);
  padding:8px 18px;border-radius:10px;transition:transform .3s var(--ease),box-shadow .3s}
.ig-follow:hover{transform:translateY(-2px);box-shadow:0 10px 26px -10px var(--accent)}
.ig-stats{font-size:14px;color:var(--muted)}
.ig-stats b{color:var(--ink)}
.ig-bio{margin:0;font-size:14.5px;color:var(--ink);max-width:60ch}
.ig-highs{display:flex;gap:clamp(14px,3vw,26px);margin:6px 0 22px;overflow-x:auto;padding-bottom:6px;scrollbar-width:none}
.ig-highs::-webkit-scrollbar{display:none}
.ig-high{display:flex;flex-direction:column;align-items:center;gap:8px;flex:none;text-decoration:none}
.ig-high-ring{width:76px;height:76px;border-radius:50%;padding:3px;display:block;
  background:linear-gradient(45deg,var(--magenta),var(--purpura),var(--cobalto))}
.ig-high-ring img{width:100%;height:100%;border-radius:50%;object-fit:cover;border:3px solid var(--bg)}
.ig-high-t{font-size:12px;color:var(--muted);max-width:90px;text-align:center}
.ig-high:hover .ig-high-t{color:var(--ink)}
.igrid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}
.igrid .gx-item{aspect-ratio:1/1;width:100%;border-radius:6px}
@media (max-width:640px){.igrid{gap:3px}.igrid .gx-item{border-radius:3px}}
/* ============ LA REVISTA: identidad editorial propia ============
   Sobria, alternando papel blanco con secciones oscuras. Sin partículas. */
body.mag{background:#FAF7F1}
body.mag::before,body.mag::after{display:none}   /* sin aurora ni grano: papel limpio */
body.mag .nav{background:rgba(9,8,15,.94);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid rgba(0,0,0,.08)}       /* barra siempre sólida sobre blanco */
.mag-hero{position:relative;z-index:2;background:#FAF7F1;text-align:center;
  padding:calc(110px + 4vh) 0 clamp(44px,7vh,72px);border-bottom:1px solid #E7DFD2}
.mag-hero img{width:clamp(110px,14vw,160px);height:auto;margin:0 auto;
  filter:drop-shadow(0 12px 30px rgba(0,0,0,.12))}
.mag-sec{position:relative;z-index:2;padding:clamp(54px,9vh,110px) 0}
.mag-sec.dark{background:var(--bg)}
.mag-sec.light{background:#FAF7F1;color:#16121E}
.mag-sec.light h2,.mag-sec.light .serif{color:#16121E}
.mag-sec.light .eyebrow{color:#8A7B5C}
.mag-sec.light .eyebrow::before{background:#16121E;opacity:.5}
.mag-sec.light p{color:#5A5264}
.mag-sec.light em.ital{color:var(--magenta)}
.mag-sec.light .mag-feature{background:#fff;border-color:#E7DFD2;box-shadow:0 24px 60px -34px rgba(22,18,30,.25)}
.mag-sec.light .mag-feature:hover{box-shadow:0 40px 80px -40px rgba(22,18,30,.3)}
.mag-sec.light .mag-feature-copy h2{color:#16121E}
.mag-sec.light .mag-feature-copy p{color:#5A5264}
.mag-sec.light .mag-more{color:#16121E}
.mag-inspo{text-align:center;max-width:760px}
.mag-inspo h2{font-size:clamp(30px,4.6vw,56px);margin-top:16px;line-height:1.05}
.mag-inspo p{margin:16px 0 26px;font-size:17px}
.mag-link{display:inline-flex;align-items:center;gap:10px;font-weight:600;font-size:15px;
  color:#16121E;border-bottom:2px solid var(--magenta);padding-bottom:6px;
  transition:gap .3s var(--ease)}
.mag-link svg{width:19px;height:19px}
.mag-link:hover{gap:16px}
/* panel gris para el footer: sobre el papel claro el texto claro se perdía */
body.mag .footer{background:#26222E;border-top:1px solid rgba(255,255,255,.06)}
/* La Revista: artículo en portada */
.mag-feature{display:grid;grid-template-columns:1.25fr 1fr;gap:0;margin-top:18px;border-radius:24px;overflow:hidden;
  border:1px solid var(--line-strong);background:var(--surface);text-decoration:none;
  transition:transform .45s var(--ease),box-shadow .45s var(--ease)}
.mag-feature:hover{transform:translateY(-4px);box-shadow:0 40px 80px -40px rgba(226,0,205,.45)}
.mag-feature-media{min-height:320px}
.mag-feature-media img{width:100%;height:100%;object-fit:cover}
.mag-feature-copy{padding:clamp(26px,4vw,52px);display:flex;flex-direction:column;justify-content:center;gap:14px}
.mag-feature-copy h2{font-size:clamp(24px,3.2vw,40px);line-height:1.06}
.mag-feature-copy p{color:var(--muted);margin:0}
.mag-tag{align-self:flex-start;font-size:10.5px;font-weight:700;letter-spacing:.28em;text-transform:uppercase;
  color:#fff;background:var(--accent);padding:6px 12px;border-radius:999px}
.mag-more{display:inline-flex;align-items:center;gap:8px;color:var(--ink);font-weight:600;font-size:14px;margin-top:4px}
.mag-more svg{width:18px;height:18px;transition:transform .35s var(--ease)}
.mag-feature:hover .mag-more svg,.magband:hover .mag-more svg{transform:translateX(4px)}
@media (max-width:820px){.mag-feature{grid-template-columns:1fr}.mag-feature-media{min-height:220px}}
/* La Revista: banda hacia el tablero de inspiración */
.magband{position:relative;display:block;border-radius:24px;overflow:hidden;isolation:isolate;text-decoration:none;
  border:1px solid var(--line-strong);
  background:linear-gradient(100deg,rgba(9,8,15,.92) 30%,rgba(9,8,15,.45) 70%,rgba(9,8,15,.2)),var(--img) center/cover;
  transition:transform .45s var(--ease),box-shadow .45s var(--ease)}
.magband:hover{transform:translateY(-4px);box-shadow:0 40px 80px -40px rgba(226,0,205,.45)}
.magband-copy{padding:clamp(30px,5vw,64px);max-width:560px;display:flex;flex-direction:column;gap:12px}
.magband-copy h2{font-size:clamp(26px,4vw,46px);color:#fff}
.magband-copy p{color:rgba(236,231,244,.85);margin:0}
.chero .wrap{position:relative;z-index:2}
.chero-wrap{display:grid;grid-template-columns:1fr auto;gap:48px;align-items:center}
@media (max-width:760px){.chero-wrap{grid-template-columns:1fr}.chero-logo{display:none}}
.chero-copy h1{font-size:clamp(40px,7vw,82px);margin-top:12px}
.chero .sub{color:rgba(236,231,244,.9);max-width:46ch;margin-top:18px}
.chero-logo{width:clamp(130px,15vw,184px);height:auto;justify-self:end;
  filter:drop-shadow(0 18px 54px rgba(226,0,205,.55))}

/* Flechas de navegación del strip (desktop) */
.zone-nav{position:absolute;top:calc(50% - 4px);transform:translateY(-50%);z-index:8;
  width:46px;height:46px;border-radius:50%;display:grid;place-items:center;
  background:rgba(13,11,23,.9);backdrop-filter:blur(10px);border:1px solid var(--line-strong);color:var(--ink);
  cursor:pointer;transition:background .3s,border-color .3s,transform .3s;box-shadow:0 12px 30px -12px rgba(0,0,0,.8)}
.zone-nav svg{width:22px;height:22px}
.zone-nav:hover{background:var(--accent);border-color:var(--accent);color:#fff}
.zone-prev{left:calc(var(--gut) - 23px)}
.zone-next{right:calc(var(--gut) - 23px)}
@media (hover:none),(max-width:640px){.zone-nav{display:none}}
.zchip{position:relative;flex:none;width:clamp(210px,26vw,272px);min-height:200px;border-radius:20px;overflow:hidden;
  border:1px solid var(--line-strong);padding:20px;display:flex;flex-direction:column;justify-content:flex-end;
  isolation:isolate;cursor:pointer;text-align:left;color:#fff;
  appearance:none;-webkit-appearance:none;background:transparent;font-family:var(--sans);
  box-shadow:0 26px 60px -30px rgba(0,0,0,.8);
  transition:transform .4s var(--ease),border-color .4s,box-shadow .4s}
.zchip-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;transition:transform .6s var(--ease);filter:saturate(.95)}
.zchip::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(9,8,15,.1) 0%,rgba(9,8,15,.4) 45%,rgba(9,8,15,.86) 100%)}
.zchip:hover{transform:translateY(-5px);border-color:var(--accent)}
.zchip:hover .zchip-bg{transform:scale(1.08)}
.zchip.active{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent),0 26px 60px -30px rgba(0,0,0,.85)}
.zchip-ic{position:absolute;z-index:2;top:14px;left:14px;width:40px;height:40px;border-radius:11px;display:grid;place-items:center;
  background:rgba(12,11,22,.5);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
  color:#fff;border:1px solid rgba(255,255,255,.2)}
.zchip-ic svg{width:21px;height:21px}
.zchip-t{position:relative;z-index:2;font-family:var(--serif);font-size:21px;font-weight:600;line-height:1.1;text-shadow:0 2px 14px rgba(0,0,0,.55)}

/* Barra de zonas (botones que filtran en sitio) */
.catbar button,.zbar-btn{flex:none;padding:9px 18px;border-radius:100px;border:1px solid var(--line);
  background:none;font-family:var(--sans);font-size:12.5px;letter-spacing:.03em;color:rgba(236,231,244,.85);
  white-space:nowrap;cursor:pointer;transition:border-color .3s,background .3s,color .3s}
.catbar button:hover,.zbar-btn:hover{border-color:var(--line-strong);color:var(--ink)}
.catbar button.active,.zbar-btn.active{background:var(--ink);border-color:var(--ink);color:#0b0a12;font-weight:600}

/* Paneles de zona (uno visible a la vez) */
.zone-panel[hidden]{display:none}
.svc-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(24px,5vw,56px);align-items:center}
@media (max-width:860px){.svc-grid{grid-template-columns:1fr}}
.svc-ic{display:inline-flex;width:56px;height:56px;border-radius:14px;align-items:center;justify-content:center;
  background:var(--accent-soft);color:var(--rosa);margin-bottom:10px}
.svc-ic svg{width:30px;height:30px}
.svc-copy h2{font-size:clamp(28px,4vw,48px);margin:6px 0 12px}
.svc-copy p{color:var(--muted);max-width:46ch;margin:0 0 18px}
.svc-bullets{list-style:none;padding:0;margin:0 0 26px;display:flex;flex-direction:column;gap:11px}
.svc-bullets li{position:relative;padding-left:24px;color:rgba(236,231,244,.86)}
.svc-bullets li::before{content:"";position:absolute;left:0;top:9px;width:8px;height:8px;border-radius:50%;background:var(--accent)}
.svc-photo{display:block;border-radius:22px;min-height:320px;border:1px solid var(--line);
  position:relative;overflow:hidden;isolation:isolate}
.svc-photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.svc-photo::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,transparent,rgba(9,8,15,.32))}

/* FAQ (acordeón nativo, sin JS) */
.faq{max-width:840px;margin-top:10px;border-top:1px solid var(--line)}
.faq-item{border-bottom:1px solid var(--line)}
.faq-item summary{list-style:none;cursor:pointer;padding:20px 46px 20px 0;position:relative;
  font-family:var(--serif);font-size:clamp(16px,2vw,20px);color:var(--ink);transition:color .3s}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary:hover{color:var(--rosa)}
.faq-item summary::after{content:"+";position:absolute;right:6px;top:50%;transform:translateY(-50%);
  font-size:26px;line-height:1;color:var(--rosa);transition:transform .3s var(--ease)}
.faq-item[open] summary::after{content:"–"}
.faq-a{padding:0 46px 22px 0;color:var(--muted);max-width:74ch;line-height:1.7}
