/* ============================================================================
   SKIN CDMX — v2 (rediseño del hero, marco tipo timbre postal)
   ----------------------------------------------------------------------------
   Aditivo, NO toca GDL. Todas las reglas viven bajo `body.sede-cdmx`.
   Si el toggle quita esa clase, el hero se ve "limpio" (base GDL).

   Cómo está montado el marco (de fuera hacia adentro):
     .hero            → fondo mostaza (es el sello completo)
     .hero::after     → perforaciones (medio-discos color papel sobre el borde
                        exterior, dejando dientes de mostaza entre muescas)
     .hero__paper     → papel crema con textura envejecida (inset = ancho de la
                        banda mostaza visible alrededor)
     .hero::before    → estrellitas azules dispersas sobre el papel
     .hero__inner     → contenido + borde rojo interior (::before)

   Variables de control:
     --tr   radio del diente de la perforación   (11px mobile / 14px desktop)
     --tg   paso entre dientes                   (22px / 28px)
     .hero__paper inset  = ancho de la banda mostaza (20px / 28px)
   ============================================================================ */

body.sede-cdmx {
  --cdmx-mostaza:       #D4A537;
  --cdmx-mostaza-ink:   #9A7522;
  --cdmx-mostaza-deep:  #7a5b1a;
  --cdmx-cafe:          #6B4423;
  --cdmx-cafe-deep:     #4a2e15;
  --cdmx-rojo-postal:   #b9281f;
  --cdmx-azul:          #1f3a8a;
  --cdmx-verde-pet:     #2a6b3a;
}

/* ─── Brand básico CDMX ─────────────────────────────────────────────────── */
body.sede-cdmx .btn--primary {
  background: var(--cdmx-mostaza);
  color: var(--ink);
  border-color: var(--cdmx-mostaza-ink);
  box-shadow: 0 3px 0 var(--cdmx-mostaza-ink);
}
body.sede-cdmx .btn--primary:hover {
  background: #caa036;
  box-shadow:
    0 4px 0 var(--cdmx-mostaza-ink),
    inset 0 0 0 60px rgba(122,91,26,.07);
}
body.sede-cdmx .btn--primary:active {
  box-shadow: 0 1px 0 var(--cdmx-mostaza-ink);
}
body.sede-cdmx .kicker-strong { color: var(--cdmx-mostaza-ink) }

/* Sin invert sobre logos del navbar/footer (el verde se ve bien directo) */
body.sede-cdmx .brand-logo-img,
body.sede-cdmx .footer-logo-img { filter: none }

/* Logo navbar CDMX: drop-shadow marcado (doble sombra crema + mostaza)
   para que el verde botella destaque sobre el navbar oscuro */
body.sede-cdmx .brand-logo-img {
  filter:
    drop-shadow(0 0 1px rgba(244, 236, 216, 0.9))
    drop-shadow(0 2px 0 rgba(154, 117, 34, 0.7))
    drop-shadow(0 0 12px rgba(212, 165, 55, 0.45));
}

/* Logo CDMX en el hero: tamaño protagónico como en el flyer. */
body.sede-cdmx .hero__logo {
  width: min(98%, 900px);
  filter: none;
}


/* ============================================================================
   MARCO TIPO TIMBRE POSTAL
   ============================================================================ */

/* 1. FONDO MOSTAZA — la silueta del sello.
      El padding controla cuánta banda mostaza queda visible alrededor
      del paper crema interior. */
body.sede-cdmx .hero {
  background: var(--cdmx-mostaza);
  padding: 30px 22px 44px;
  isolation: isolate;
  overflow: hidden;
}
@media (min-width: 760px) {
  body.sede-cdmx .hero { padding: 42px 38px 56px; }
}


/* 2. PAPER INTERIOR — crema con textura envejecida.
      inset = ancho de la banda mostaza alrededor del paper. */
body.sede-cdmx .hero__paper {
  inset: 20px;
  z-index: 1;
  background:
    /* manchas suaves marrones (papel envejecido) */
    radial-gradient(ellipse 180px 90px at 12% 18%, rgba(122,91,26,.10), transparent 70%),
    radial-gradient(ellipse 220px 110px at 88% 22%, rgba(107,68,35,.09), transparent 70%),
    radial-gradient(ellipse 240px 140px at 18% 88%, rgba(107,68,35,.08), transparent 70%),
    radial-gradient(ellipse 280px 130px at 82% 80%, rgba(122,91,26,.08), transparent 70%),
    /* motas pequeñas (granitos de papel viejo) */
    radial-gradient(circle 3px   at 22% 34%, rgba(107,68,35,.18), transparent 100%),
    radial-gradient(circle 2px   at 71% 46%, rgba(107,68,35,.22), transparent 100%),
    radial-gradient(circle 2.5px at 38% 72%, rgba(107,68,35,.15), transparent 100%),
    radial-gradient(circle 2px   at 85% 64%, rgba(107,68,35,.16), transparent 100%),
    radial-gradient(circle 2px   at 14% 56%, rgba(107,68,35,.13), transparent 100%),
    /* viñeta sutil */
    radial-gradient(ellipse 110% 110% at 50% 50%, transparent 55%, rgba(74,46,21,.10) 100%),
    /* grain SVG fractal noise */
    url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.4  0 0 0 0 0.28  0 0 0 0 0.12  0 0 0 0.14 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>"),
    /* líneas de cuaderno crema */
    repeating-linear-gradient(0deg,  transparent 0 28px, rgba(80,60,20,.035) 28px 29px),
    repeating-linear-gradient(90deg, transparent 0 28px, rgba(80,60,20,.035) 28px 29px),
    var(--paper);
}
@media (min-width: 760px) {
  body.sede-cdmx .hero__paper { inset: 28px }
}


/* 3. PERFORACIONES DEL TIMBRE (greca exterior).
      Medio-discos color papel cortan desde AFUERA HACIA ADENTRO de la banda
      mostaza — el borde exterior del sello queda festoneado. */
body.sede-cdmx .hero::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  --tr: 11px;   /* radio del diente */
  --tg: 22px;   /* paso entre dientes */
  background:
    /* TOP */
    radial-gradient(circle var(--tr) at 50% 0,   var(--paper) var(--tr), transparent calc(var(--tr) + .5px))
      center 0    / var(--tg) var(--tr) repeat-x,
    /* BOTTOM */
    radial-gradient(circle var(--tr) at 50% 100%, var(--paper) var(--tr), transparent calc(var(--tr) + .5px))
      center 100% / var(--tg) var(--tr) repeat-x,
    /* LEFT */
    radial-gradient(circle var(--tr) at 0   50%,  var(--paper) var(--tr), transparent calc(var(--tr) + .5px))
      0    center / var(--tr) var(--tg) repeat-y,
    /* RIGHT */
    radial-gradient(circle var(--tr) at 100% 50%, var(--paper) var(--tr), transparent calc(var(--tr) + .5px))
      100% center / var(--tr) var(--tg) repeat-y;
}
@media (min-width: 760px) {
  body.sede-cdmx .hero::after { --tr: 14px; --tg: 28px; }
}


/* 4. BORDE ROJO INTERIOR — una sola línea delgada, como en el flyer. */
body.sede-cdmx .hero__inner {
  position: relative;
  z-index: 3;
  padding: 42px 22px 32px;
}
@media (min-width: 760px) {
  body.sede-cdmx .hero__inner { padding: 60px 56px 48px; }
}
body.sede-cdmx .hero__inner::before {
  content: "";
  position: absolute;
  inset: 14px;
  border: 1.5px solid var(--cdmx-rojo-postal);
  pointer-events: none;
  z-index: 0;
}
body.sede-cdmx .hero__inner > * { position: relative; z-index: 1 }


/* 5. ESTRELLITAS AZULES DISPERSAS — sobre el papel, debajo del contenido. */
body.sede-cdmx .hero::before {
  content: "";
  position: absolute;
  inset: 20px;
  z-index: 2;
  pointer-events: none;
  --star:    url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M12 2 L14 9 L22 9 L15.5 13.5 L18 21 L12 16.5 L6 21 L8.5 13.5 L2 9 L10 9 Z' fill='%231f3a8a'/></svg>");
  --star-sm: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M12 2 L14 9 L22 9 L15.5 13.5 L18 21 L12 16.5 L6 21 L8.5 13.5 L2 9 L10 9 Z' fill='%231f3a8a' opacity='0.78'/></svg>");
  background:
    var(--star)    32px              32px / 20px 20px no-repeat,
    var(--star)    calc(100% - 32px) 32px / 20px 20px no-repeat,
    var(--star-sm) 16%  20% / 13px 13px no-repeat,
    var(--star-sm) 82%  18% / 13px 13px no-repeat,
    var(--star-sm) 10%  46% / 12px 12px no-repeat,
    var(--star-sm) 88%  50% / 12px 12px no-repeat,
    var(--star-sm) 20%  70% / 13px 13px no-repeat,
    var(--star-sm) 80%  72% / 13px 13px no-repeat,
    var(--star-sm) 50%  90% / 14px 14px no-repeat;
}
@media (min-width: 760px) {
  body.sede-cdmx .hero::before { inset: 28px }
}


/* ============================================================================
   AJUSTES MENORES DEL CONTENIDO DENTRO DEL SELLO
   ============================================================================ */

body.sede-cdmx .kicker { color: var(--cdmx-cafe-deep) }

body.sede-cdmx .entrada-libre {
  border-top-color: var(--cdmx-mostaza-ink);
  color: var(--cdmx-cafe-deep);
}
body.sede-cdmx .entrada-libre::before { color: var(--cdmx-rojo-postal) }

body.sede-cdmx .hero__org-line  { background: var(--cdmx-cafe); opacity: .5 }
body.sede-cdmx .hero__org-label { color: var(--cdmx-cafe-deep) }

body.sede-cdmx .city-chip {
  background: var(--cdmx-rojo-postal);
  color: #fff;
  box-shadow: 0 2px 0 #6a160e;
}

body.sede-cdmx .cd-cell      { background: #1a1612; border: 1px solid rgba(212,165,55,.18) }
body.sede-cdmx .cd-cell__n   { color: var(--cdmx-mostaza) }
body.sede-cdmx .cd-cell__l   { color: rgba(212,165,55,.65) }


/* ============================================================================
   ANIMACIONES DE CARGA (escalonadas, sutiles)
   ============================================================================ */
@media (prefers-reduced-motion: no-preference) {
  body.sede-cdmx .hero__paper         { animation: cdmx-stamp-in .6s cubic-bezier(.2,.7,.2,1.05) }
  body.sede-cdmx .hero__inner::before { animation: cdmx-fade-in  .5s ease-out .25s backwards }
  body.sede-cdmx .hero::before        { animation: cdmx-fade-in  .8s ease-out .40s backwards }
  body.sede-cdmx .hero__topline       { animation: cdmx-fade-in  .5s ease-out .30s backwards }
  body.sede-cdmx .hero__title         { animation: cdmx-rise-in  .7s cubic-bezier(.2,.7,.2,1) .40s backwards }
  body.sede-cdmx .hero__org           { animation: cdmx-fade-in  .5s ease-out .55s backwards }
  body.sede-cdmx .hero__meta          { animation: cdmx-fade-in  .5s ease-out .65s backwards }
  body.sede-cdmx .hero__pitch         { animation: cdmx-fade-in  .5s ease-out .75s backwards }
  body.sede-cdmx .hero__cta           { animation: cdmx-fade-in  .5s ease-out .85s backwards }
  body.sede-cdmx .hero__countdown     { animation: cdmx-fade-in  .5s ease-out .95s backwards }
}

@keyframes cdmx-stamp-in {
  0%   { transform: scale(.985) }
  100% { transform: scale(1) }
}
@keyframes cdmx-fade-in {
  from { opacity: 0; transform: translateY(6px) }
  to   { opacity: 1; transform: translateY(0) }
}
@keyframes cdmx-rise-in {
  from { opacity: 0; transform: translateY(14px) scale(.97) }
  to   { opacity: 1; transform: translateY(0)    scale(1) }
}


/* ============================================================================
   TRANSICIONES SUAVES ENTRE SEDES (cross-fade al hacer toggle CDMX ↔ GDL)
   Aplican siempre, no solo en CDMX, para que la transición funcione en ambas
   direcciones. Solo afectan a propiedades que cambian entre los dos modos.
   ============================================================================ */
.hero,
.hero__paper,
.hero__inner,
.hero__logo,
.btn--primary,
.kicker-strong,
.kicker,
.brand-logo-img,
.footer-logo-img,
.city-chip,
.cd-cell,
.cd-cell__n,
.cd-cell__l,
.entrada-libre,
.hero__org-label {
  transition:
    background-color 420ms ease,
    background-image 420ms ease,
    color 420ms ease,
    border-color 420ms ease,
    box-shadow 320ms ease,
    filter 380ms ease;
}

/* El logo del hero hace cross-fade más explícito (cambia el src vía JS) */
.hero__logo {
  transition:
    opacity 280ms ease,
    transform 420ms cubic-bezier(.2,.7,.2,1),
    filter 380ms ease;
}

/* Decoraciones del sello (perforaciones, estrellitas, borde rojo): fade suave */
.hero::before,
.hero::after,
.hero__inner::before {
  transition: opacity 420ms ease;
}

/* Respetar usuarios con animaciones reducidas */
@media (prefers-reduced-motion: reduce) {
  .hero, .hero__paper, .hero__inner, .hero__logo, .btn--primary,
  .kicker-strong, .kicker, .brand-logo-img, .footer-logo-img,
  .city-chip, .cd-cell, .cd-cell__n, .cd-cell__l,
  .entrada-libre, .hero__org-label,
  .hero::before, .hero::after, .hero__inner::before {
    transition: none !important;
  }
}
