/* =====================================================================
   GLOBALY TOURS — Hoja de estilos
   Paleta tomada del logo (violeta #6E3397 + azul globo) con un acento
   magenta de "luces de escenario" para los conciertos.
   ===================================================================== */

:root{
  /* Fondos */
  --ink:#08060F;        /* fondo base (arena a oscuras) */
  --ink-2:#0D0A1A;      /* secciones alternas */
  --ink-3:#15102A;      /* tarjetas */
  --ink-4:#1D1740;      /* tarjetas elevadas */

  /* Marca */
  --violet:#6E3397;     /* violeta del logo */
  --violet-2:#9D4EDD;   /* violeta claro */
  --blue:#2E7DD1;       /* azul globo */
  --azure:#36B6F0;      /* azul brillante (acento) */
  --magenta:#FF2E7E;    /* energía de concierto (acento audaz) */
  --magenta-2:#FF6BA6;

  /* Texto */
  --paper:#F4F1FB;
  --muted:#ADA6CC;
  --muted-2:#827CA0;

  /* Líneas */
  --line:rgba(255,255,255,.085);
  --line-2:rgba(255,255,255,.16);

  /* Degradados */
  --grad-brand:linear-gradient(120deg,#6E3397,#2E7DD1);
  --grad-hot:linear-gradient(118deg,#9D4EDD 0%,#FF2E7E 100%);
  --grad-text:linear-gradient(96deg,#C79BF2,#7FD0F7 55%,#FF8FBD);

  --maxw:1220px;
  --r:20px;
  --shadow:0 34px 90px -34px rgba(0,0,0,.85);
  --glow-v:0 0 0 1px rgba(157,78,221,.35), 0 18px 60px -18px rgba(157,78,221,.5);

  --ff-display:"Bricolage Grotesque",-apple-system,"Segoe UI",sans-serif;
  --ff-body:"Plus Jakarta Sans",-apple-system,"Segoe UI",Roboto,sans-serif;
  --ff-mono:"Space Mono","SFMono-Regular",ui-monospace,monospace;
}

/* ---------- Reset ---------- */
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--ff-body);
  background:var(--ink);
  color:var(--paper);
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
ul{list-style:none}
:focus-visible{outline:2px solid var(--azure);outline-offset:3px;border-radius:6px}
::selection{background:var(--magenta);color:#fff}

/* Atmósfera de fondo */
body::before{
  content:"";position:fixed;inset:0;z-index:-2;pointer-events:none;
  background:
    radial-gradient(1100px 700px at 78% -8%, rgba(110,51,151,.42), transparent 60%),
    radial-gradient(900px 620px at 8% 12%, rgba(46,125,209,.28), transparent 58%),
    radial-gradient(800px 700px at 50% 116%, rgba(255,46,126,.16), transparent 60%);
}

/* ---------- Utilidades ---------- */
.wrap{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:24px}
.eyebrow{
  font-family:var(--ff-mono);font-size:.72rem;letter-spacing:.32em;
  text-transform:uppercase;color:var(--azure);display:inline-flex;align-items:center;gap:.6em;
}
.eyebrow::before{content:"";width:26px;height:1px;background:linear-gradient(90deg,var(--azure),transparent)}
.gtext{background:var(--grad-text);-webkit-background-clip:text;background-clip:text;color:transparent}
.section{padding:clamp(64px,9vw,128px) 0;position:relative}
.section--alt{background:linear-gradient(180deg,var(--ink-2),var(--ink))}
.s-head{max-width:680px;margin-bottom:clamp(36px,5vw,60px)}
.s-head h2{
  font-family:var(--ff-display);font-weight:800;line-height:1.02;letter-spacing:-.02em;
  font-size:clamp(2rem,5.2vw,3.5rem);margin:.5rem 0 .7rem;
}
.s-head p{color:var(--muted);font-size:1.05rem;max-width:60ch}
.s-head--center{margin-inline:auto;text-align:center}
.s-head--center .eyebrow{justify-content:center}

/* Botones */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.55em;
  font-weight:700;font-size:.96rem;padding:.92em 1.5em;border-radius:999px;
  transition:transform .25s cubic-bezier(.2,.7,.2,1),box-shadow .25s,filter .25s;
  white-space:nowrap;position:relative;
}
.btn svg{width:1.15em;height:1.15em}
.btn--wa{
  background:var(--grad-hot);color:#fff;
  box-shadow:0 14px 36px -12px rgba(255,46,126,.6),inset 0 1px 0 rgba(255,255,255,.25);
}
.btn--wa:hover{transform:translateY(-3px);box-shadow:0 22px 50px -14px rgba(255,46,126,.75)}
.btn--ghost{border:1px solid var(--line-2);color:var(--paper);background:rgba(255,255,255,.03);backdrop-filter:blur(8px)}
.btn--ghost:hover{transform:translateY(-3px);border-color:var(--violet-2);background:rgba(157,78,221,.12)}
.btn--block{width:100%}
.btn--sm{padding:.72em 1.15em;font-size:.86rem}

/* Chips */
.chips{display:flex;flex-wrap:wrap;gap:10px}
.chip{
  display:inline-flex;align-items:center;gap:.5em;font-size:.85rem;font-weight:600;
  padding:.5em .95em;border-radius:999px;border:1px solid var(--line);
  background:rgba(255,255,255,.04);color:var(--paper);
}
.chip svg{width:1.05em;height:1.05em;color:var(--azure)}

/* =====================================================================
   NAV
   ===================================================================== */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:60;
  transition:background .35s,border-color .35s,backdrop-filter .35s;
  border-bottom:1px solid transparent;
}
.nav.scrolled{
  background:rgba(8,6,15,.78);backdrop-filter:blur(16px) saturate(140%);
  border-bottom-color:var(--line);
}
.nav__in{display:flex;align-items:center;justify-content:space-between;height:74px;gap:18px}
.brand{display:flex;align-items:center;gap:12px;font-family:var(--ff-display);font-weight:800;font-size:1.18rem;letter-spacing:-.01em}
.brand img{height:42px;width:auto;filter:drop-shadow(0 6px 18px rgba(110,51,151,.55))}
.brand small{display:block;font-family:var(--ff-mono);font-weight:400;font-size:.56rem;letter-spacing:.34em;color:var(--azure);margin-top:2px}
.nav__links{display:flex;align-items:center;gap:6px}
.nav__links a{
  font-size:.92rem;font-weight:600;color:var(--muted);padding:.55em .85em;border-radius:10px;
  transition:color .2s,background .2s;position:relative;
}
.nav__links a:hover,.nav__links a.active{color:var(--paper)}
.nav__links a.active::after{
  content:"";position:absolute;left:50%;bottom:2px;transform:translateX(-50%);
  width:18px;height:2px;border-radius:2px;background:var(--grad-hot);
}
.nav__cta{display:flex;align-items:center;gap:10px}
.nav__toggle{display:none;width:44px;height:44px;border-radius:12px;border:1px solid var(--line-2);align-items:center;justify-content:center}
.nav__toggle span{display:block;width:20px;height:2px;background:var(--paper);position:relative;transition:.3s}
.nav__toggle span::before,.nav__toggle span::after{content:"";position:absolute;left:0;width:20px;height:2px;background:var(--paper);transition:.3s}
.nav__toggle span::before{top:-6px}.nav__toggle span::after{top:6px}
.nav.open .nav__toggle span{background:transparent}
.nav.open .nav__toggle span::before{top:0;transform:rotate(45deg)}
.nav.open .nav__toggle span::after{top:0;transform:rotate(-45deg)}

/* =====================================================================
   HERO
   ===================================================================== */
.hero{position:relative;min-height:100svh;display:flex;align-items:flex-end;overflow:hidden;isolation:isolate}
.hero__bg{position:absolute;inset:0;z-index:-2}
.hero__bg img{width:100%;height:100%;object-fit:cover;object-position:center 32%}
.hero__bg::after{
  content:"";position:absolute;inset:0;
  background:
    linear-gradient(180deg, rgba(8,6,15,.62) 0%, rgba(8,6,15,.35) 30%, rgba(8,6,15,.82) 78%, var(--ink) 100%),
    linear-gradient(95deg, rgba(8,6,15,.9), transparent 62%);
}
.hero__grain{position:absolute;inset:0;z-index:-1;opacity:.5;mix-blend-mode:soft-light;
  background-image:radial-gradient(rgba(255,255,255,.08) 1px,transparent 1px);background-size:3px 3px}
.hero__in{padding-bottom:clamp(120px,16vh,180px);padding-top:120px;max-width:920px}
.hero h1{
  font-family:var(--ff-display);font-weight:800;letter-spacing:-.025em;line-height:.98;
  font-size:clamp(2.7rem,8vw,5.6rem);margin:.7rem 0 1.1rem;
}
.hero h1 .live{position:relative;white-space:nowrap}
.hero h1 .live::after{
  content:"";position:absolute;left:0;right:0;bottom:.06em;height:.5em;z-index:-1;
  background:var(--grad-hot);opacity:.28;filter:blur(2px);border-radius:6px;
}
.hero p.lede{font-size:clamp(1.05rem,1.6vw,1.28rem);color:#E7E2F6;max-width:60ch;margin-bottom:1.8rem}
.hero__actions{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:1.7rem}
.hero .chips{max-width:640px}

/* Badge "EN VIVO" */
.live-badge{
  display:inline-flex;align-items:center;gap:.6em;font-family:var(--ff-mono);font-weight:700;
  font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;color:#fff;
  padding:.5em 1em;border-radius:999px;border:1px solid rgba(255,46,126,.5);
  background:rgba(255,46,126,.12);backdrop-filter:blur(6px);
}
.live-badge .dot{width:9px;height:9px;border-radius:50%;background:var(--magenta);box-shadow:0 0 0 0 rgba(255,46,126,.7);animation:pulse 1.8s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(255,46,126,.7)}70%{box-shadow:0 0 0 10px rgba(255,46,126,0)}100%{box-shadow:0 0 0 0 rgba(255,46,126,0)}}

/* Ecualizador-horizonte (firma de la marca) */
.equalizer{position:absolute;left:0;right:0;bottom:0;height:120px;z-index:-1;display:flex;align-items:flex-end;gap:5px;padding:0 4vw;opacity:.9;mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.equalizer .bar{flex:1;border-radius:4px 4px 0 0;background:linear-gradient(180deg,var(--magenta),var(--violet-2) 45%,var(--azure));transform-origin:bottom;animation:eq 1.4s ease-in-out infinite;opacity:.85}
@keyframes eq{0%,100%{transform:scaleY(.25)}50%{transform:scaleY(1)}}

.scroll-hint{position:absolute;left:50%;bottom:22px;transform:translateX(-50%);z-index:2;font-family:var(--ff-mono);font-size:.62rem;letter-spacing:.3em;color:var(--muted-2);text-transform:uppercase;display:flex;flex-direction:column;align-items:center;gap:8px}
.scroll-hint::after{content:"";width:1px;height:34px;background:linear-gradient(var(--azure),transparent);animation:drop 1.8s infinite}
@keyframes drop{0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}51%{transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* =====================================================================
   PRÓXIMAS FECHAS — tarjetas estilo "pase de abordar / boleto"
   ===================================================================== */
.events{display:grid;gap:22px}
.event-feature{
  position:relative;display:grid;grid-template-columns:1.15fr 1fr;gap:0;border-radius:26px;overflow:hidden;
  border:1px solid var(--line);background:var(--ink-3);box-shadow:var(--shadow);min-height:380px;
}
.event-feature__media{position:relative;overflow:hidden}
.event-feature__media img{width:100%;height:100%;object-fit:cover;transition:transform 1.2s ease}
.event-feature:hover .event-feature__media img{transform:scale(1.06)}
.event-feature__media::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent 40%,var(--ink-3) 99%)}
.event-feature__body{padding:clamp(28px,3.5vw,46px);display:flex;flex-direction:column;justify-content:center;gap:14px;position:relative;z-index:1}
.event-feature__body h3{font-family:var(--ff-display);font-weight:800;font-size:clamp(1.8rem,3vw,2.6rem);line-height:1.02;letter-spacing:-.02em}
.event-feature__meta{display:flex;flex-wrap:wrap;gap:18px;color:var(--muted);font-size:.92rem}
.event-feature__meta b{color:var(--paper)}
.event-feature p{color:var(--muted);max-width:46ch}
.event-feature__foot{display:flex;flex-wrap:wrap;align-items:center;gap:16px;margin-top:6px}
.price{font-family:var(--ff-display);font-weight:800;font-size:1.5rem}
.price small{display:block;font-family:var(--ff-mono);font-weight:400;font-size:.6rem;letter-spacing:.2em;color:var(--muted-2);text-transform:uppercase}

.events-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(330px,1fr));gap:22px}

/* Boleto */
.ticket{
  position:relative;display:flex;background:var(--ink-3);border:1px solid var(--line);
  border-radius:18px;overflow:hidden;transition:transform .3s,border-color .3s,box-shadow .3s;
}
.ticket:hover{transform:translateY(-5px);border-color:var(--violet-2);box-shadow:var(--glow-v)}
.ticket__stub{
  flex:0 0 92px;background:var(--grad-brand);color:#fff;display:flex;flex-direction:column;
  align-items:center;justify-content:center;text-align:center;padding:14px 8px;position:relative;
}
.ticket__stub .d{font-family:var(--ff-display);font-weight:800;font-size:2.1rem;line-height:1}
.ticket__stub .m{font-family:var(--ff-mono);font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;margin-top:2px}
.ticket__stub .y{font-family:var(--ff-mono);font-size:.6rem;opacity:.8;margin-top:6px}
.ticket__stub::before{content:"";position:absolute;top:0;bottom:0;right:-1px;width:2px;
  background-image:linear-gradient(var(--ink) 50%,transparent 50%);background-size:2px 9px}
/* muescas del boleto */
.ticket::before,.ticket::after{content:"";position:absolute;left:84px;width:16px;height:16px;border-radius:50%;background:var(--ink-2);z-index:2}
.section .ticket::before,.section .ticket::after{background:var(--ink)}
.section--alt .ticket::before,.section--alt .ticket::after{background:var(--ink-2)}
.ticket::before{top:-8px}.ticket::after{bottom:-8px}
.ticket__body{flex:1;padding:18px 20px;display:flex;flex-direction:column;gap:9px;min-width:0}
.ticket__type{display:flex;align-items:center;gap:8px;font-family:var(--ff-mono);font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;color:var(--azure)}
.ticket__body h4{font-family:var(--ff-display);font-weight:700;font-size:1.18rem;line-height:1.12;letter-spacing:-.01em}
.ticket__loc{display:flex;align-items:center;gap:6px;color:var(--muted);font-size:.88rem}
.ticket__loc svg{width:14px;height:14px;color:var(--magenta)}
.ticket__foot{margin-top:auto;display:flex;align-items:center;justify-content:space-between;gap:10px;padding-top:8px;border-top:1px dashed var(--line-2)}
.ticket__price{font-family:var(--ff-display);font-weight:800;font-size:1.12rem}
.ticket__price small{font-family:var(--ff-mono);font-weight:400;font-size:.58rem;letter-spacing:.12em;color:var(--muted-2);display:block}

/* Estados */
.state{font-family:var(--ff-mono);font-size:.62rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;padding:.35em .7em;border-radius:999px;white-space:nowrap}
.state--ok{color:#7BE6B0;background:rgba(40,200,130,.12);border:1px solid rgba(40,200,130,.3)}
.state--few{color:#FFC36B;background:rgba(255,170,60,.12);border:1px solid rgba(255,170,60,.32)}
.state--soon{color:var(--azure-2,#7FD0F7);background:rgba(54,182,240,.12);border:1px solid rgba(54,182,240,.3)}
.state--out{color:#FF7A9C;background:rgba(255,46,126,.12);border:1px solid rgba(255,46,126,.32)}

/* =====================================================================
   PROMOCIONES / PUBLICIDAD
   ===================================================================== */
.promos{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:22px}
.promo{
  position:relative;border-radius:22px;overflow:hidden;min-height:300px;display:flex;align-items:flex-end;
  border:1px solid var(--line);isolation:isolate;transition:transform .35s,box-shadow .35s;
}
.promo:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.promo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:-2;transition:transform 1.1s ease}
.promo:hover img{transform:scale(1.07)}
.promo::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(180deg,rgba(8,6,15,.05) 0%,rgba(8,6,15,.55) 52%,rgba(8,6,15,.95) 100%)}
.promo__in{padding:24px;width:100%}
.promo__tag{display:inline-block;font-family:var(--ff-mono);font-size:.64rem;letter-spacing:.16em;text-transform:uppercase;color:#fff;padding:.4em .8em;border-radius:999px;background:var(--grad-hot);margin-bottom:12px}
.promo h3{font-family:var(--ff-display);font-weight:800;font-size:1.5rem;line-height:1.06;letter-spacing:-.01em;margin-bottom:8px}
.promo p{color:#D8D2EC;font-size:.95rem;margin-bottom:16px}
.promo--wide{grid-column:span 2}
@media(max-width:760px){.promo--wide{grid-column:span 1}}

/* =====================================================================
   SERVICIOS
   ===================================================================== */
.services{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:18px}
.service{
  padding:30px 26px;border-radius:var(--r);border:1px solid var(--line);
  background:linear-gradient(180deg,var(--ink-3),var(--ink-2));transition:transform .3s,border-color .3s;position:relative;overflow:hidden;
}
.service::before{content:"";position:absolute;inset:0;background:var(--grad-hot);opacity:0;transition:opacity .3s;z-index:0;mix-blend-mode:overlay}
.service:hover{transform:translateY(-6px);border-color:var(--violet-2)}
.service>*{position:relative;z-index:1}
.service__ic{
  width:54px;height:54px;border-radius:15px;display:grid;place-items:center;margin-bottom:18px;
  background:rgba(157,78,221,.14);border:1px solid rgba(157,78,221,.32);color:var(--violet-2);
}
.service__ic svg{width:26px;height:26px}
.service h3{font-family:var(--ff-display);font-weight:700;font-size:1.25rem;margin-bottom:8px;letter-spacing:-.01em}
.service p{color:var(--muted);font-size:.95rem}

/* =====================================================================
   GALERÍAS (Destinos + Recuerdos)
   ===================================================================== */
.gallery{columns:3;column-gap:16px}
@media(max-width:900px){.gallery{columns:2}}
@media(max-width:540px){.gallery{columns:1}}
.gal-item{
  break-inside:avoid;margin-bottom:16px;position:relative;border-radius:16px;overflow:hidden;
  cursor:pointer;border:1px solid var(--line);display:block;width:100%;
}
.gal-item img{width:100%;height:auto;transition:transform .8s ease;display:block}
.gal-item:hover img{transform:scale(1.08)}
.gal-item__cap{
  position:absolute;left:0;right:0;bottom:0;padding:34px 16px 14px;
  background:linear-gradient(transparent,rgba(8,6,15,.9));
  font-weight:600;font-size:.95rem;display:flex;align-items:center;gap:8px;
  transform:translateY(8px);opacity:0;transition:.35s;
}
.gal-item__cap svg{width:15px;height:15px;color:var(--magenta);flex:none}
.gal-item:hover .gal-item__cap,.gal-item:focus-visible .gal-item__cap{transform:none;opacity:1}
.gal-item__zoom{position:absolute;top:12px;right:12px;width:34px;height:34px;border-radius:50%;background:rgba(8,6,15,.55);backdrop-filter:blur(6px);display:grid;place-items:center;opacity:0;transition:.3s;border:1px solid var(--line-2)}
.gal-item__zoom svg{width:16px;height:16px}
.gal-item:hover .gal-item__zoom{opacity:1}

/* Lightbox */
.lb{position:fixed;inset:0;z-index:200;background:rgba(5,4,10,.94);backdrop-filter:blur(10px);display:none;align-items:center;justify-content:center;padding:30px}
.lb.open{display:flex}
.lb img{max-width:92vw;max-height:82vh;border-radius:14px;box-shadow:0 40px 120px rgba(0,0,0,.7);animation:zoomIn .35s cubic-bezier(.2,.8,.2,1)}
@keyframes zoomIn{from{opacity:0;transform:scale(.94)}to{opacity:1;transform:none}}
.lb__cap{position:absolute;bottom:26px;left:0;right:0;text-align:center;font-weight:600;color:var(--paper);font-size:1rem}
.lb__x,.lb__nav{position:absolute;width:52px;height:52px;border-radius:50%;background:rgba(255,255,255,.08);border:1px solid var(--line-2);display:grid;place-items:center;transition:.25s}
.lb__x:hover,.lb__nav:hover{background:var(--violet);transform:scale(1.08)}
.lb__x{top:24px;right:24px}.lb__x svg,.lb__nav svg{width:22px;height:22px}
.lb__nav{top:50%;transform:translateY(-50%)}
.lb__prev{left:18px}.lb__next{right:18px}
.lb__prev:hover,.lb__next:hover{transform:translateY(-50%) scale(1.08)}

/* =====================================================================
   OPINIONES
   ===================================================================== */
.reviews{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px}
.review{padding:28px;border-radius:var(--r);border:1px solid var(--line);background:var(--ink-3);position:relative;display:flex;flex-direction:column;gap:14px}
.review__stars{color:#FFC36B;letter-spacing:.12em;font-size:1rem}
.review p{color:#E0DBF0;font-size:1.02rem;line-height:1.6}
.review__who{display:flex;align-items:center;gap:12px;margin-top:auto}
.review__av{width:44px;height:44px;border-radius:50%;display:grid;place-items:center;font-family:var(--ff-display);font-weight:800;color:#fff;background:var(--grad-hot);flex:none}
.review__who b{font-weight:700;display:block}
.review__who span{color:var(--muted-2);font-size:.84rem;font-family:var(--ff-mono);letter-spacing:.05em}
.review__q{position:absolute;top:18px;right:24px;font-family:var(--ff-display);font-size:4rem;line-height:1;color:var(--violet);opacity:.25}

/* =====================================================================
   CONTACTO
   ===================================================================== */
.contact{display:grid;grid-template-columns:1fr 1fr;gap:30px;align-items:stretch}
.contact__card{padding:clamp(28px,3.5vw,42px);border-radius:24px;border:1px solid var(--line);background:linear-gradient(180deg,var(--ink-3),var(--ink-2))}
.contact__lead h2{font-family:var(--ff-display);font-weight:800;font-size:clamp(1.9rem,4vw,2.8rem);line-height:1.04;letter-spacing:-.02em;margin:.4rem 0 .8rem}
.contact__lead p{color:var(--muted);margin-bottom:24px;max-width:48ch}
.contact__rows{display:flex;flex-direction:column;gap:8px;margin-bottom:24px}
.crow{display:flex;align-items:center;gap:14px;padding:14px;border-radius:14px;border:1px solid var(--line);background:rgba(255,255,255,.02);transition:border-color .25s,transform .25s}
.crow:hover{border-color:var(--violet-2);transform:translateX(4px)}
.crow__ic{width:44px;height:44px;border-radius:12px;display:grid;place-items:center;background:rgba(54,182,240,.12);color:var(--azure);flex:none}
.crow__ic svg{width:20px;height:20px}
.crow b{display:block;font-size:1.02rem}
.crow span{color:var(--muted);font-size:.85rem}
.socials{display:flex;gap:12px}
.socials a{width:48px;height:48px;border-radius:14px;display:grid;place-items:center;border:1px solid var(--line);background:rgba(255,255,255,.03);transition:.25s}
.socials a:hover{transform:translateY(-4px);border-color:var(--violet-2);background:rgba(157,78,221,.14)}
.socials svg{width:22px;height:22px}

/* Form -> WhatsApp */
.field{margin-bottom:16px}
.field label{display:block;font-size:.8rem;font-family:var(--ff-mono);letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:7px}
.field input,.field select,.field textarea{
  width:100%;padding:13px 15px;border-radius:12px;border:1px solid var(--line-2);
  background:rgba(255,255,255,.03);color:var(--paper);font-family:inherit;font-size:.96rem;transition:border-color .2s,background .2s;
}
.field textarea{resize:vertical;min-height:96px}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--violet-2);background:rgba(157,78,221,.07)}
.field select option{background:var(--ink-3)}
.form-note{font-size:.82rem;color:var(--muted-2);margin-top:12px;display:flex;align-items:center;gap:8px}
.form-note svg{width:15px;height:15px;color:var(--azure);flex:none}

.map-embed{margin-top:18px;border-radius:16px;overflow:hidden;border:1px solid var(--line);height:230px}
.map-embed iframe{width:100%;height:100%;border:0;filter:grayscale(.3) invert(.92) hue-rotate(180deg) contrast(.9)}

/* =====================================================================
   FOOTER
   ===================================================================== */
.footer{border-top:1px solid var(--line);padding:64px 0 32px;background:var(--ink-2)}
.footer__grid{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:40px;margin-bottom:44px}
.footer__brand img{height:54px;margin-bottom:16px}
.footer__brand p{color:var(--muted);max-width:38ch;font-size:.94rem}
.footer h5{font-family:var(--ff-mono);font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted-2);margin-bottom:16px}
.footer__col a{display:block;color:var(--muted);padding:5px 0;font-size:.95rem;transition:color .2s,padding .2s}
.footer__col a:hover{color:var(--paper);padding-left:6px}
.footer__bottom{display:flex;flex-wrap:wrap;justify-content:space-between;gap:14px;padding-top:26px;border-top:1px solid var(--line);color:var(--muted-2);font-size:.84rem}
.footer__bottom a{color:var(--muted)}

/* FAB WhatsApp */
.fab{position:fixed;right:22px;bottom:22px;z-index:90;width:60px;height:60px;border-radius:50%;background:var(--grad-hot);display:grid;place-items:center;box-shadow:0 16px 40px -10px rgba(255,46,126,.6);transition:transform .3s;animation:floaty 3.5s ease-in-out infinite}
.fab:hover{transform:scale(1.1)}
.fab svg{width:30px;height:30px;color:#fff}
.fab::after{content:"";position:absolute;inset:0;border-radius:50%;border:2px solid var(--magenta);animation:ring 2.4s infinite}
@keyframes ring{0%{transform:scale(1);opacity:.7}100%{transform:scale(1.7);opacity:0}}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}

/* Reveal on scroll */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}

/* =====================================================================
   RESPONSIVE
   ===================================================================== */
@media(max-width:980px){
  .event-feature{grid-template-columns:1fr}
  .event-feature__media{min-height:230px}
  .event-feature__media::after{background:linear-gradient(180deg,transparent 35%,var(--ink-3) 99%)}
  .contact{grid-template-columns:1fr}
  .footer__grid{grid-template-columns:1fr 1fr}
}
@media(max-width:860px){
  .nav__links,.nav__cta .btn--ghost{display:none}
  .nav__toggle{display:flex}
  .nav__menu{
    position:fixed;inset:74px 0 auto 0;background:rgba(8,6,15,.97);backdrop-filter:blur(18px);
    border-bottom:1px solid var(--line);flex-direction:column;align-items:stretch;gap:0;padding:14px 24px 26px;
    display:none;
  }
  .nav.open .nav__menu{display:flex}
  .nav__menu a{padding:14px 4px;border-bottom:1px solid var(--line);font-size:1.05rem;color:var(--paper)}
  .nav__menu a.active::after{display:none}
}
@media(max-width:560px){
  .footer__grid{grid-template-columns:1fr}
  .gallery{column-gap:12px}
  .hero__in{padding-bottom:120px}
  .equalizer{height:80px}
  .fab{width:54px;height:54px}
}

/* Movimiento reducido */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
  .equalizer .bar{transform:scaleY(.55)}
}
