/* ============================================================
   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}

/* El contenedor del menú móvil (overlay editorial) se define en styles.css.
   Aquí solo el comportamiento de acordeón de los submenús, centrado. */
@media (max-width:920px){
  .nav-group{flex-direction:column;align-items:center;width:100%}
  .nav-grp-btn{justify-content:center;gap:10px;width:auto}
  .nav-sub{
    position:static;transform:none !important;opacity:1;visibility:hidden;pointer-events:auto;
    display:none;flex-direction:column;gap:14px;min-width:0;margin:8px 0 2px;align-items:center;
    background:none;border:0;box-shadow:none;backdrop-filter:none;padding:6px 0;
  }
  .nav-group.exp .nav-sub{display:flex;visibility:visible}
  .nav-group.exp .nav-grp-btn svg{transform:rotate(180deg)}
  .nav-sub a{font-size:16px;color:var(--muted)}
  .nav-col{gap:14px;min-width:0;align-items:center}
}

/* ---------- 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}
.art-meta{font-size:13px;color:var(--muted);margin:0 0 24px!important}
.art-meta b{color:var(--champan);font-weight:600}
.prose table{width:100%;border-collapse:collapse;margin:6px 0 22px;font-size:15px}
.prose th,.prose td{text-align:left;padding:11px 14px;border-bottom:1px solid var(--line)}
.prose th{color:var(--champan);font-family:var(--sans);font-weight:700;font-size:11.5px;letter-spacing:.08em;text-transform:uppercase}
.prose td{color:rgba(236,231,244,.82)}
.prose h3{scroll-margin-top:90px}
.legal{max-width:78ch}

/* ---------- Portal de clientes (Área de clientes → MOE) ---------- */
.portal-feats{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.portal-feats .pf{padding:30px 26px;border:1px solid var(--line);border-radius:20px;background:rgba(236,231,244,.025)}
.pf-ic{display:inline-flex;width:48px;height:48px;align-items:center;justify-content:center;border-radius:14px;background:var(--accent-soft);color:var(--accent);margin-bottom:16px}
.pf-ic svg{width:24px;height:24px}
.portal-feats h3{font-size:19px;margin:0 0 8px}
.portal-feats p{color:var(--muted);font-size:14.5px;line-height:1.6;margin:0}
.portal-paths{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.ppath{padding:42px 36px;border:1px solid var(--line-strong);border-radius:24px;background:rgba(236,231,244,.03)}
.ppath-alt{background:linear-gradient(150deg,var(--accent-soft),rgba(236,231,244,.03))}
.ppath h2{font-size:clamp(26px,3.4vw,40px);margin:8px 0 14px}
.ppath p{color:var(--muted);margin:0 0 26px;max-width:44ch;line-height:1.65}
@media(max-width:860px){.portal-feats{grid-template-columns:1fr}.portal-paths{grid-template-columns:1fr}}

/* ---------- 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}
/* ====== LA REVISTA · PORTADA DINÁMICA (papel claro + aurora viva) ====== */
body.mag{--grad-rev:linear-gradient(100deg,#FF6FE6,#E200CD 34%,#B23BE0 60%,#1B34D8)}
body.mag main{position:relative;z-index:2}
.rev-aurora{position:fixed;inset:0;z-index:0;pointer-events:none;overflow:hidden;filter:blur(75px);opacity:.4}
.rev-aurora span{position:absolute;border-radius:50%;animation:revdrift 22s var(--ease) infinite alternate}
.rev-aurora .a1{width:48vw;height:48vw;left:-10vw;top:-12vw;background:radial-gradient(circle,rgba(255,111,230,.55),transparent 60%)}
.rev-aurora .a2{width:44vw;height:44vw;right:-12vw;top:2vw;background:radial-gradient(circle,rgba(27,52,216,.4),transparent 60%);animation-delay:-7s}
.rev-aurora .a3{width:40vw;height:40vw;left:26vw;top:42vw;background:radial-gradient(circle,rgba(178,59,224,.42),transparent 62%);animation-delay:-13s}
.rev-aurora .a4{width:34vw;height:34vw;right:6vw;bottom:-10vw;background:radial-gradient(circle,rgba(239,228,212,.7),transparent 60%);animation-delay:-4s}
@keyframes revdrift{to{transform:translate3d(7vw,5vw,0) scale(1.16)}}
.rev-ticker{position:relative;z-index:2;overflow:hidden;border-bottom:1px solid rgba(23,19,31,.1);padding:9px 0;white-space:nowrap;-webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.rev-ticker .run{display:inline-block;animation:revrun 32s linear infinite}
.rev-ticker b{font-family:var(--serif);font-style:italic;font-size:14px;margin:0 6px;color:#7B2CD6}
.rev-ticker i{color:var(--rosa);margin:0 18px;font-style:normal}
@keyframes revrun{to{transform:translateX(-50%)}}
.rev-hero{position:relative;z-index:2;padding:clamp(28px,5vw,58px) 0 clamp(16px,3vw,30px)}
.rev-hero-card{display:grid;grid-template-columns:1fr 1.05fr;gap:clamp(22px,4vw,52px);align-items:center}
.rev-media{position:relative;border-radius:24px;overflow:hidden;aspect-ratio:5/4;display:block;border:1px solid rgba(23,19,31,.1);box-shadow:0 40px 90px -42px rgba(178,59,224,.5)}
.rev-media img{width:100%;height:100%;object-fit:cover;transition:transform 1.1s var(--ease)}
.rev-media:hover img{transform:scale(1.06)}
.rev-copy h1{font-family:var(--serif);font-weight:600;font-size:clamp(30px,4.4vw,56px);line-height:1.02;margin:16px 0 14px;letter-spacing:-.01em;color:#17131F}
.rev-copy h1 em{font-style:italic;background:var(--grad-rev);-webkit-background-clip:text;background-clip:text;color:transparent}
.rev-copy p{color:#5a5366;font-size:clamp(15px,1.5vw,18px);max-width:520px}
.rev-tag{display:inline-flex;align-items:center;gap:7px;font-size:11px;font-weight:800;letter-spacing:.16em;text-transform:uppercase;padding:7px 14px;border-radius:100px;color:#fff;background:var(--grad-rev);box-shadow:0 6px 18px -4px rgba(226,0,205,.5)}
.rev-tag.ghost{color:var(--magenta);background:rgba(226,0,205,.07);border:1px solid rgba(226,0,205,.3);box-shadow:none}
.rev-tag.ghost::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--rosa)}
.rev-meta{display:flex;align-items:center;gap:14px;margin-top:18px;font-size:13px;color:#776F82}
.rev-meta i{width:4px;height:4px;border-radius:50%;background:#bdb4c8;font-style:normal}
.rev-btn{display:inline-flex;align-items:center;gap:9px;margin-top:24px;padding:13px 24px;border-radius:100px;font-weight:700;font-size:14px;color:#fff;background:var(--grad-rev);background-size:200% 100%;box-shadow:0 12px 30px -10px rgba(226,0,205,.5);transition:gap .25s,transform .25s;animation:revshine 6s linear infinite}
.rev-btn:hover{gap:16px;transform:translateY(-2px)}
.rev-btn svg{width:18px;height:18px}
.rev-btn.ghost{background:transparent;color:#17131F;border:1px solid rgba(23,19,31,.2);box-shadow:none;animation:none}
.rev-btn.ghost:hover{border-color:var(--magenta);color:var(--magenta)}
@keyframes revshine{to{background-position:200% 0}}
.rev-word{display:inline-block;opacity:0;transform:translateY(22px);filter:blur(5px);animation:revword .9s var(--ease) forwards}
@keyframes revword{to{opacity:1;transform:none;filter:none}}
@media(max-width:820px){.rev-hero-card{grid-template-columns:1fr}.rev-media{order:-1}}
.rev-head{position:relative;z-index:2;padding:24px 0 4px}
.rev-head .eyebrow{color:#8A7B5C}
.rev-head h2{font-family:var(--serif);font-size:clamp(26px,3.4vw,46px);font-weight:600;line-height:1.05;color:#17131F;margin-top:8px}
.rev-head h2 em{font-style:italic;background:var(--grad-rev);-webkit-background-clip:text;background-clip:text;color:transparent}
.rev-filters{position:relative;z-index:2;display:flex;gap:10px;flex-wrap:wrap;padding:14px 0 8px}
.rev-pill{font-size:13px;font-weight:600;padding:9px 18px;border-radius:100px;cursor:pointer;color:#776F82;background:#fff;border:1px solid rgba(23,19,31,.1);transition:.25s;user-select:none}
.rev-pill:hover{color:#17131F;border-color:rgba(226,0,205,.4)}
.rev-pill.on{color:#fff;background:var(--grad-rev);border-color:transparent;box-shadow:0 8px 20px -8px rgba(226,0,205,.5)}
.rev-grid{position:relative;z-index:2;display:grid;grid-template-columns:repeat(6,1fr);gap:22px;padding:18px 0 48px}
.rev-card{position:relative;grid-column:span 2;background:#fff;border-radius:20px;overflow:hidden;border:1px solid rgba(23,19,31,.08);display:flex;flex-direction:column;box-shadow:0 14px 34px -24px rgba(23,19,31,.45);transition:transform .4s var(--ease),box-shadow .4s var(--ease),opacity .5s var(--ease);opacity:0;transform:translateY(26px) scale(.985)}
.rev-card.in{opacity:1;transform:none}
.rev-card.big{grid-column:span 3}
.rev-card .ph{position:relative;display:block;overflow:hidden;aspect-ratio:16/10}
.rev-card.big .ph{aspect-ratio:16/9}
.rev-card .ph img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease)}
.rev-card .ctag{position:absolute;top:14px;left:14px;z-index:2;font-size:10px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:#fff;padding:6px 12px;border-radius:100px;background:rgba(23,19,31,.5);backdrop-filter:blur(6px)}
.rev-card .cbody{padding:20px 22px 22px;display:flex;flex-direction:column;flex:1}
.rev-card h3{font-family:var(--serif);font-weight:600;font-size:clamp(19px,1.8vw,24px);line-height:1.14;margin-bottom:9px;color:#17131F}
.rev-card .ex{font-size:13.5px;color:#776F82;flex:1;line-height:1.55}
.rev-card .cmeta{display:inline-flex;align-items:center;gap:8px;margin-top:16px;font-size:12px;font-weight:600;color:var(--magenta)}
.rev-card .cmeta .g{width:16px;height:16px;border-radius:50%;background:var(--grad-rev)}
.rev-card-link{position:absolute;inset:0;z-index:3}
.rev-card:hover{transform:translateY(-8px);box-shadow:0 34px 60px -32px rgba(178,59,224,.45)}
.rev-card:hover .ph img{transform:scale(1.07)}
.rev-card.hide{display:none}
@media(max-width:900px){.rev-grid{grid-template-columns:repeat(2,1fr)}.rev-card,.rev-card.big{grid-column:span 1}}
@media(max-width:560px){.rev-grid{grid-template-columns:1fr}}
.rev-band{position:relative;z-index:2;margin:8px 0 60px;border-radius:26px;overflow:hidden;border:1px solid rgba(23,19,31,.1);padding:clamp(34px,5vw,58px);text-align:center;background:radial-gradient(130% 150% at 50% 0%,rgba(255,111,230,.16),rgba(255,255,255,0) 60%),#fff}
.rev-band .eyebrow{color:#8A7B5C}
.rev-band h2{font-family:var(--serif);font-size:clamp(26px,4vw,44px);font-weight:600;line-height:1.05;margin:8px 0 12px;color:#17131F}
.rev-band h2 em{font-style:italic;background:var(--grad-rev);-webkit-background-clip:text;background-clip:text;color:transparent}
.rev-band p{color:#776F82;max-width:520px;margin:0 auto 24px}
.rev-band-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
/* ----- Mezcla: carrusel de portada + secciones temáticas ----- */
.rev-cz{position:relative;z-index:2;padding:clamp(18px,3vw,34px) 0 6px}
.rev-cz-kick{display:block;margin-bottom:14px}
.rev-carousel{position:relative;overflow:hidden;border-radius:26px}
.rev-track{display:flex;transition:transform .6s var(--ease)}
.rev-slide{min-width:100%;display:grid;grid-template-columns:1fr 1.04fr;gap:clamp(20px,4vw,48px);align-items:center;padding:4px}
.rev-slide h2{font-family:var(--serif);font-weight:600;font-size:clamp(28px,3.8vw,52px);line-height:1.02;margin:14px 0 12px;letter-spacing:-.01em;color:#17131F}
.rev-slide h2 em{font-style:italic;background:var(--grad-rev);-webkit-background-clip:text;background-clip:text;color:transparent}
.rev-slide p{color:#5a5366;font-size:clamp(14px,1.4vw,17px);max-width:480px}
.rev-smedia{display:block;border-radius:22px;overflow:hidden;aspect-ratio:5/4;border:1px solid rgba(23,19,31,.1);box-shadow:0 36px 80px -42px rgba(178,59,224,.5)}
.rev-smedia img{width:100%;height:100%;object-fit:cover;transition:transform 1s var(--ease)}
.rev-smedia:hover img{transform:scale(1.05)}
@media(max-width:820px){.rev-slide{grid-template-columns:1fr}.rev-smedia{order:-1}}
.rev-cbar{display:flex;align-items:center;justify-content:space-between;margin-top:14px}
.rev-dots{display:flex;gap:8px}
.rev-dot{width:9px;height:9px;border-radius:50%;border:none;background:rgba(23,19,31,.18);cursor:pointer;transition:.3s;padding:0}
.rev-dot.on{width:26px;border-radius:6px;background:var(--grad-rev)}
.rev-arrows{display:flex;gap:8px}
.rev-arrow{width:42px;height:42px;border-radius:50%;border:1px solid rgba(23,19,31,.12);background:#fff;cursor:pointer;display:grid;place-items:center;transition:.25s;color:#17131F}
.rev-arrow:hover{border-color:var(--rosa);color:var(--magenta)}
.rev-arrow svg{width:20px;height:20px}
.rev-filters-c{justify-content:center}
.rev-sec{position:relative;z-index:2;padding:clamp(24px,4vw,42px) 0 0}
.rev-sec.hide{display:none}
.rev-sec-head{margin-bottom:16px}
.rev-sec-head h3{font-family:var(--serif);font-size:clamp(23px,3vw,38px);font-weight:600;line-height:1.04;color:#17131F}
.rev-sec-head h3::before{content:"";display:inline-block;width:22px;height:3px;border-radius:2px;background:var(--grad-rev);vertical-align:middle;margin-right:12px}
.rev-sec-sub{color:#776F82;font-size:14px;margin-top:8px}
/* ----- Portada de revista: masthead "La Revista" + destacados pequeños ----- */
.rev-cover{display:grid;grid-template-columns:.82fr 1.18fr;gap:clamp(24px,4vw,56px);align-items:center;padding:clamp(8px,2vw,22px) 0}
.rev-masthead .eyebrow{color:#8A7B5C}
.rev-masthead h1{font-family:var(--serif);font-weight:600;font-size:clamp(52px,8.5vw,118px);line-height:.9;margin:10px 0 16px;letter-spacing:-.02em;color:#17131F}
.rev-masthead h1 em{font-style:italic;display:block;background:var(--grad-rev);-webkit-background-clip:text;background-clip:text;color:transparent}
.rev-masthead h1 .mast-la{display:block;font-family:var(--sans);font-weight:700;font-size:clamp(11px,1.3vw,15px);letter-spacing:.34em;text-transform:uppercase;color:#8A7B5C;margin-bottom:12px}
.rev-masthead h1 .mast-ev{display:block;font-style:normal;font-size:.46em;letter-spacing:.015em;color:#17131F;-webkit-text-fill-color:#17131F;margin-top:4px}
.rev-masthead p{color:#5a5366;font-size:clamp(15px,1.5vw,18px);max-width:340px}
.rev-feats{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.rev-feat{position:relative;display:block;border-radius:16px;overflow:hidden;background:#fff;border:1px solid var(--line);box-shadow:0 12px 28px -20px rgba(23,19,31,.4);transition:transform .3s var(--ease),box-shadow .3s}
.rev-feat:hover{transform:translateY(-5px);box-shadow:0 24px 46px -26px rgba(178,59,224,.45)}
.rev-feat-ph{position:relative;display:block;aspect-ratio:16/10;overflow:hidden}
.rev-feat-ph img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.rev-feat:hover .rev-feat-ph img{transform:scale(1.06)}
.rev-feat-tag{position:absolute;top:10px;left:10px;font-size:9.5px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:#fff;padding:4px 10px;border-radius:100px;background:rgba(23,19,31,.5);backdrop-filter:blur(6px)}
.rev-feat-t{display:block;padding:13px 15px 16px;font-family:var(--serif);font-weight:600;font-size:15.5px;line-height:1.18;color:#17131F}
@media(max-width:820px){.rev-cover{grid-template-columns:1fr;gap:22px}.rev-masthead h1{font-size:clamp(46px,15vw,86px)}}
@media(max-width:430px){.rev-feats{grid-template-columns:1fr}}
.rev-srow{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.rev-srow .rev-card{grid-column:auto;opacity:1;transform:none}
@media(max-width:860px){.rev-srow{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.rev-srow{grid-template-columns:1fr}}
.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}
