/* ============================================
   JAY MAYA · byjaymaya.com
   Design System v3 — Exacto del corporativo
   Oswald + Montserrat · Purple #6B21A8 / #9333EA
   ============================================ */

/* ---------- RESET ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;overflow-x:hidden}
body{min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
img,video{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{cursor:pointer;border:0;font:inherit;background:transparent;color:inherit}
input,textarea,select{font:inherit;color:inherit}
ul,ol{list-style:none}

/* ---------- DESIGN TOKENS — EXACTO ---------- */
:root{
  /* Paleta exacta del corporativo */
  --black:#000000;
  --black-deep:#040006;
  --gray:#0a0a0a;
  --gray2:#111111;
  --gray3:#1a1a1a;
  --bg:#000000;
  --bg-elev:#0a0a0a;
  --bg-card:#111111;
  --bg-soft:#1a1a1a;

  --purple:#6B21A8;
  --purple-bright:#9333EA;
  --purple-soft:rgba(147,51,234,.1);
  --purple-line:rgba(147,51,234,.3);
  --purple-faint:rgba(147,51,234,.06);
  --purple-glow:rgba(147,51,234,.25);

  --white:#ffffff;
  --fg:#ffffff;
  --white-60:rgba(255,255,255,.6);
  --white-45:rgba(255,255,255,.45);
  --white-30:rgba(255,255,255,.3);
  --white-15:rgba(255,255,255,.15);
  --white-08:rgba(255,255,255,.08);
  --fg-muted:rgba(255,255,255,.6);
  --fg-dim:rgba(255,255,255,.3);

  --line:#111;
  --line-strong:#1f1f1f;
  --line-soft:rgba(255,255,255,.05);

  /* Tipografía EXACTA */
  --font-display:'Oswald','Helvetica Neue','Arial Narrow',sans-serif;
  --font-body:'Montserrat','Helvetica Neue','Arial',sans-serif;

  /* Escalas */
  --maxw:1380px;
  --pad-x:60px;

  --t-fast:.18s ease;
  --t:.3s ease;
  --t-slow:.6s ease;

  --shadow-sm:0 4px 14px rgba(0,0,0,.4);
  --shadow:0 10px 40px rgba(0,0,0,.5);
  --shadow-glow:0 0 60px var(--purple-glow);
}

body{
  background:var(--black);
  color:var(--white);
  font-family:var(--font-body);
  font-weight:400;
  line-height:1.6;
  overflow-x:hidden;
}

/* ---------- TYPOGRAPHY ---------- */
h1,h2,h3,h4{
  font-family:var(--font-display);
  font-weight:700;
  line-height:1;
  text-transform:uppercase;
  color:var(--white);
}
h1{font-size:clamp(48px,8.5vw,110px);letter-spacing:4px;line-height:.95}
h2{font-size:clamp(36px,5vw,64px);letter-spacing:3px}
h3{font-size:18px;letter-spacing:2px;line-height:1.2}
h4{font-size:16px;letter-spacing:3px}
h5{font-family:var(--font-body);font-size:9px;letter-spacing:4px;text-transform:uppercase;font-weight:600;color:var(--white-30)}

p{
  color:var(--white-60);
  font-size:13px;
  font-weight:300;
  line-height:1.8;
  letter-spacing:.3px;
  max-width:640px;
}

/* Eyebrows / section labels — replicando exacto */
.eyebrow,.section-label{
  font-family:var(--font-body);
  font-size:9px;
  font-weight:600;
  letter-spacing:6px;
  text-transform:uppercase;
  color:var(--purple-bright);
  margin-bottom:14px;
  text-align:center;
  display:block;
}
.label{
  font-family:var(--font-body);
  font-size:9px;
  font-weight:600;
  letter-spacing:3px;
  text-transform:uppercase;
  color:var(--purple-bright);
}

.lead{
  font-family:var(--font-body);
  font-size:13px;
  font-weight:300;
  color:var(--white-60);
  line-height:1.8;
  letter-spacing:.3px;
  max-width:640px;
}

strong{color:var(--purple-bright);font-weight:500}
em{font-style:normal;color:var(--white);font-weight:500}

.text-accent,.text-purple{color:var(--purple-bright)}
.text-muted{color:var(--white-45)}
.text-center{text-align:center}

/* Title split — "VISTO EN MEDIOS." pattern */
.title-split{
  text-align:center;
  width:100%;
  margin-left:auto;
  margin-right:auto;
  display:block;
}
.title-split .white{color:var(--white)}
.title-split .purple{color:var(--purple-bright)}
.title-split .accent{color:var(--purple-bright)}
.title-split span{display:inline-block}
/* Mobile: cada palabra a su propia línea para máxima legibilidad y centrado limpio */
@media (max-width:600px){
  .title-split .white,
  .title-split .purple{display:block;width:100%;text-align:center}
}

/* Línea decorativa debajo de títulos — 40px x 2px */
.line-under,.section-line{
  display:block;
  width:40px;
  height:2px;
  background:var(--purple);
  margin:0 auto 30px;
  border:0;
}

/* ---------- LAYOUT ---------- */
.container{
  width:100%;
  max-width:var(--maxw);
  margin:0 auto;
  padding:0 var(--pad-x);
  position:relative;
}
.container-narrow{max-width:1000px;margin-left:auto;margin-right:auto}
section{padding:100px var(--pad-x);position:relative;border-top:1px solid var(--line)}
section.tight{padding:60px var(--pad-x)}

.section-header{
  margin-bottom:60px;
  max-width:800px;
  margin-left:auto;
  margin-right:auto;
  text-align:center;
}
.section-header h1,
.section-header h2{margin-bottom:18px}
.section-header p{
  font-family:var(--font-body);
  font-size:13px;
  font-weight:300;
  color:var(--white-45);
  line-height:1.8;
  letter-spacing:.5px;
  text-align:center;
  max-width:600px;
  margin:0 auto;
}

.divider{height:1px;background:var(--line);margin:0;border:0}

/* ---------- HEADER / NAV — EXACTO ---------- */
.site-header{
  position:fixed;
  top:0;left:0;right:0;
  z-index:1000;
  background:rgba(0,0,0,.97);
  border-bottom:1px solid var(--line);
  transition:background var(--t);
}
.nav{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:16px var(--pad-x);
  max-width:none;
  margin:0;
  gap:1rem;
}
.brand{
  font-family:var(--font-display);
  font-weight:700;
  font-size:14px;
  letter-spacing:5px;
  color:var(--white);
  text-transform:uppercase;
  display:flex;
  align-items:center;
  gap:14px;
  text-decoration:none;
}
.brand-cross{
  display:inline-block;
  width:22px;
  height:22px;
  background-color:var(--purple-bright); /* color sólido para que mask tome */
  -webkit-mask-image:url('/assets/img/profile/logo-cruz-jerusalen.png');
  mask-image:url('/assets/img/profile/logo-cruz-jerusalen.png');
  -webkit-mask-size:contain;
  mask-size:contain;
  -webkit-mask-repeat:no-repeat;
  mask-repeat:no-repeat;
  -webkit-mask-position:center;
  mask-position:center;
  flex-shrink:0;
}
.nav-menu{
  display:flex;
  gap:1.5rem;
  align-items:center;
  list-style:none;
}
.nav-menu a{
  font-family:var(--font-body);
  font-size:10px;
  font-weight:600;
  letter-spacing:3px;
  text-transform:uppercase;
  color:var(--white-30);
  transition:color var(--t-fast);
  position:relative;
  padding:.25rem 0;
}
.nav-menu a:hover{color:var(--white-60)}
.nav-menu a.active{color:var(--purple-bright)}
.nav-menu a.active::after{content:"";position:absolute;left:0;right:0;bottom:-4px;height:1px;background:var(--purple-bright)}

.nav-right{display:flex;align-items:center;gap:1rem}
.lang-switch{
  display:flex;
  gap:.4rem;
  font-family:var(--font-body);
  font-size:9px;
  font-weight:600;
  letter-spacing:3px;
  color:var(--white-30);
}
.lang-switch a{color:var(--white-30);transition:color var(--t-fast)}
.lang-switch a.active{color:var(--purple-bright)}
.lang-switch a:hover{color:var(--white-60)}
.lang-switch span{color:var(--white-15)}
.nav-cta{
  padding:8px 18px;
  border:1px solid var(--purple-bright);
  color:var(--purple-bright);
  font-family:var(--font-body);
  font-size:10px;
  font-weight:600;
  letter-spacing:3px;
  text-transform:uppercase;
  transition:all var(--t);
}
.nav-cta:hover{background:var(--purple-bright);color:var(--white)}
.nav-meta{
  font-family:var(--font-body);
  font-size:9px;
  font-weight:600;
  letter-spacing:4px;
  text-transform:uppercase;
  color:var(--white-30);
}

/* Mobile menu */
.nav-toggle{display:none;width:32px;height:32px;flex-direction:column;justify-content:center;gap:5px;cursor:pointer}
.nav-toggle span{width:22px;height:2px;background:var(--white);transition:transform var(--t),opacity var(--t)}

@media (max-width:900px){
  .nav-menu,.nav-cta{display:none}
  .nav-toggle{display:flex}
  .nav-menu.open{
    display:flex;position:fixed;top:54px;left:0;right:0;
    background:var(--gray);flex-direction:column;
    padding:2rem;gap:1.5rem;border-bottom:1px solid var(--line);
  }
  .nav-menu.open a{font-size:11px;text-align:center}
}

/* ---------- HERO — EXACTO + 100dvh para mobile ---------- */
.hero{
  position:relative;
  min-height:100vh;
  min-height:100dvh; /* fallback para iOS y Android para que no se monte con barras del browser */
  padding:140px var(--pad-x) 80px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  text-align:center;
  overflow:hidden;
  background:var(--black-deep);
  border-top:0;
}
/* Mobile: reducir letter-spacing y padding */
@media (max-width:600px){
  :root{--pad-x:16px}
  .hero{padding:120px 16px 60px !important}
  .hero h1{letter-spacing:1px;font-size:clamp(40px,12vw,72px)}
  .hero-tagline,.hero-eyebrow{letter-spacing:4px;font-size:9px}
  .hero-sub{letter-spacing:3px;font-size:10px}
  h2{letter-spacing:1px;font-size:clamp(28px,7vw,42px)}
  h3{letter-spacing:1px}
  .nav{padding:14px 16px !important;gap:.5rem}
  .brand{font-size:12px;letter-spacing:3px;gap:8px}
  .brand-cross{width:18px;height:18px}

  /* === LA CLAVE: section sin padding lateral, container con 16px === */
  section{padding:60px 0 !important}
  .container{padding:0 16px !important;max-width:100% !important;margin:0 !important;width:100% !important}

  /* === EDGE-TO-EDGE EN MOBILE — sale del container con margen negativo === */
  .formats-grid,
  .photo-grid-3,
  .photo-grid-2,
  .gallery-bio,
  .gallery-grid,
  .video-double,
  .video-embed-wrapper,
  .acts-grid,
  .cbb-three{
    margin-left:-16px !important;
    margin-right:-16px !important;
    width:calc(100% + 32px) !important;
    max-width:none !important;
    gap:0 !important;
    display:block !important;        /* romper grid en mobile */
  }
  .format-card,
  .media-card,
  .video-embed,
  .photo-grid-3 .photo,
  .gallery-item,
  .act-card,
  .cbb-card{
    border-radius:0 !important;
    margin:0 !important;
    border-left:0 !important;
    border-right:0 !important;
    width:100% !important;
    display:block !important;
  }

  /* === FOTOS COMPLETAS — sin cropping === */
  .media-card{aspect-ratio:auto !important;background:transparent !important}
  .media-card-img{
    position:relative !important;
    aspect-ratio:auto !important;
    width:100% !important;
    height:auto !important;
    overflow:visible !important;
  }
  .media-card-img img{
    position:relative !important;
    inset:auto !important;
    width:100% !important;
    height:auto !important;
    object-fit:contain !important;
    display:block !important;
  }
  /* Format card images full width */
  .format-card img,
  .photo-grid-3 .photo img,
  .gallery-item img{
    width:100% !important;
    height:auto !important;
    display:block !important;
    aspect-ratio:auto !important;
  }
  /* Photos en grid de eventos: aspect natural */
  .photo-grid-3 .photo,
  .gallery-item{aspect-ratio:auto !important;height:auto !important}

  /* === TÍTULOS CENTRADOS === */
  .section-header{
    text-align:center !important;
    max-width:100% !important;
    margin:0 auto 40px !important;
    padding:0 !important;
  }
  .section-header h1,
  .section-header h2,
  .section-header h3,
  .section-header p{
    text-align:center !important;
    margin-left:auto !important;
    margin-right:auto !important;
  }
  .title-split{text-align:center !important;width:100% !important}
  .title-split .white,
  .title-split .purple{display:block !important;width:100% !important;text-align:center !important}
}
.hero-bg{
  position:absolute;
  inset:0;
  z-index:0;
  overflow:hidden;
  background:
    radial-gradient(ellipse 60% 50% at 50% 35%, rgba(147,51,234,.20) 0%, transparent 65%),
    radial-gradient(ellipse 40% 60% at 15% 75%, rgba(107,33,168,.12) 0%, transparent 55%),
    var(--black);
}
.hero-bg video,.hero-bg img{
  width:100%;height:100%;
  object-fit:cover;
  object-position:center;
  opacity:.55;
}
.hero-bg::after{
  content:"";
  position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(0,0,0,.5) 0%,rgba(0,0,0,.7) 70%,rgba(0,0,0,1) 100%);
  z-index:1;
}
.hero-content{
  position:relative;
  z-index:2;
  max-width:1200px;
  margin:0 auto;
  width:100%;
  text-align:center;
}
.hero-content .container{
  display:flex;flex-direction:column;align-items:center;
  text-align:center;
  padding:0;
}
.hero-badge{
  display:inline-block;
  border:1px solid var(--purple-line);
  padding:8px 18px;
  margin-bottom:28px;
  background:rgba(0,0,0,.4);
}
.hero-tagline,.hero-eyebrow{
  font-family:var(--font-body);
  font-size:10px;
  font-weight:600;
  letter-spacing:8px;
  text-transform:uppercase;
  color:var(--purple-bright);
  margin-bottom:24px;
  display:block;
}
.hero h1{
  font-family:var(--font-display);
  font-weight:700;
  font-size:clamp(48px,8.5vw,110px);
  letter-spacing:4px;
  line-height:.95;
  text-transform:uppercase;
  color:var(--white);
  margin-bottom:24px;
  text-align:center;
}
.hero h1 .accent,
.hero h1 .purple{color:var(--purple-bright);display:block}
.hero-sub{
  font-family:var(--font-body);
  font-size:11px;
  font-weight:600;
  letter-spacing:6px;
  text-transform:uppercase;
  color:var(--white-45);
  margin-bottom:36px;
  display:block;
  max-width:none;
}
.hero-lead{
  font-family:var(--font-body);
  font-size:13px;
  font-weight:300;
  color:var(--white-60);
  max-width:640px;
  margin:0 auto 40px;
  line-height:1.8;
  letter-spacing:.3px;
}
.hero-cta{display:flex;gap:1rem;flex-wrap:wrap;justify-content:center;margin-top:30px}
.scroll-indicator{
  position:absolute;bottom:2rem;left:50%;
  transform:translateX(-50%);
  z-index:3;
  font-family:var(--font-body);
  color:var(--white-30);
  font-size:9px;
  letter-spacing:4px;
  font-weight:600;
  text-transform:uppercase;
  animation:bounce 2.5s ease-in-out infinite;
}
.scroll-indicator::after{
  content:"";
  display:block;
  width:1px;height:30px;
  background:var(--purple-bright);
  margin:8px auto 0;
}
@keyframes bounce{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(8px)}}

/* ---------- BUTTONS ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  gap:.5rem;
  padding:14px 24px;
  font-family:var(--font-body);
  font-size:10px;
  font-weight:600;
  letter-spacing:3px;
  text-transform:uppercase;
  border:1px solid var(--purple-bright);
  color:var(--purple-bright);
  background:transparent;
  cursor:pointer;
  transition:all var(--t);
}
.btn:hover{background:var(--purple-bright);color:var(--white)}
.btn-primary{background:var(--purple);color:var(--white);border-color:var(--purple)}
.btn-primary:hover{background:var(--purple-bright);border-color:var(--purple-bright)}
.btn-ghost{border-color:var(--white-15);color:var(--white)}
.btn-ghost:hover{border-color:var(--purple-bright);color:var(--purple-bright);background:transparent}

/* ---------- FORMAT CARDS — cuadradas (aspect 1/1) como en corporativo ---------- */
.formats-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:3px;
  max-width:1400px;
  margin:0 auto;
}
@media (min-width:760px){.formats-grid{grid-template-columns:repeat(2,1fr)}}
@media (min-width:1180px){.formats-grid{grid-template-columns:repeat(5,1fr)}}

.format-card{
  background:var(--gray2);
  border-top:2px solid var(--purple);
  display:flex;
  flex-direction:column;
  position:relative;
  transition:background .3s ease;
  overflow:hidden;
  cursor:pointer;
  aspect-ratio:auto;
  padding:0;
  margin:0;
  border-left:0;border-right:0;border-bottom:0;
  width:100%;
  text-align:center;
  font:inherit;
  color:inherit;
  touch-action:manipulation;
  -webkit-tap-highlight-color:rgba(0,0,0,0);
}
button.format-card{appearance:none;-webkit-appearance:none}
.format-card:hover{background:var(--gray3)}
.format-card:hover img{opacity:.65;transform:scale(1.04)}
.format-card::before{display:none}
.format-card img{
  width:100%;
  aspect-ratio:1/1;
  object-fit:cover;
  transition:opacity .4s ease,transform .4s ease;
}
.format-card-content{
  position:static;
  padding:24px 20px 28px;
  text-align:center;
  flex:1;
  display:flex;
  flex-direction:column;
  z-index:auto;
  background:var(--gray2);
}
.format-card-num{
  font-family:var(--font-display);
  font-size:32px;
  font-weight:700;
  color:rgba(147,51,234,.18);
  line-height:1;
  letter-spacing:2px;
  margin-bottom:10px;
  display:block;
}
.format-card h3{
  font-family:var(--font-display);
  font-size:18px;
  font-weight:700;
  letter-spacing:2px;
  text-transform:uppercase;
  color:var(--white);
  line-height:1.2;
  margin-bottom:8px;
}
.format-card-sub{
  font-family:var(--font-body);
  font-size:9px;
  font-weight:600;
  letter-spacing:3px;
  text-transform:uppercase;
  color:var(--purple-bright);
}
.format-card-play{
  position:absolute;
  top:25%;left:50%;
  transform:translate(-50%,-50%) scale(.7);
  width:60px;height:60px;
  border-radius:50%;
  background:rgba(147,51,234,.92);
  display:flex;align-items:center;justify-content:center;
  z-index:3;opacity:0;
  transition:all var(--t);
}
.format-card-play svg{width:22px;height:22px;fill:var(--white);margin-left:3px}
.format-card:hover .format-card-play{opacity:1;transform:translate(-50%,-50%) scale(1)}

/* ---------- GALLERY GRID — aspect 4:3 con caption ---------- */
.photo-grid-3,.gallery-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:16px;
  max-width:1400px;
  margin:0 auto;
}
@media (min-width:760px){.photo-grid-3,.gallery-grid{grid-template-columns:repeat(2,1fr)}}
@media (min-width:1100px){.photo-grid-3,.gallery-grid{grid-template-columns:repeat(3,1fr)}}

/* Foto simple sin caption */
.photo-grid-3 .photo,.gallery-item{
  position:relative;
  aspect-ratio:4/3;
  overflow:hidden;
  background:var(--gray2);
  border:1px solid rgba(147,51,234,.1);
  cursor:pointer;
  transition:border-color .3s ease;
}
.photo-grid-3 .photo:hover,.gallery-item:hover{border-color:var(--purple-bright)}
.photo-grid-3 .photo img,.gallery-item img,.gallery-img{
  width:100%;height:100%;
  object-fit:cover;
  transition:transform .6s ease;
}
.photo-grid-3 .photo:hover img,.gallery-item:hover img{transform:scale(1.06)}

/* Media card con label + título sobre la foto (overlay) */
.media-card{
  position:relative;
  aspect-ratio:4/3;
  overflow:hidden;
  background:var(--gray2);
  border:1px solid rgba(147,51,234,.1);
  cursor:pointer;
  transition:border-color .3s ease;
}
.media-card:hover{border-color:var(--purple-bright)}
.media-card:hover img{transform:scale(1.06)}
.media-card-img{
  position:absolute;inset:0;
  width:100%;height:100%;
  overflow:hidden;
}
.media-card-img img{
  width:100%;height:100%;
  object-fit:cover;
  transition:transform .6s ease;
}
.media-card-caption{
  position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 50%,rgba(0,0,0,.92) 100%);
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:flex-end;
  padding:20px 16px;
  text-align:center;
  z-index:2;
  width:100%;
}
.media-card-caption .label{
  font-family:var(--font-body);
  font-size:9px;
  font-weight:600;
  letter-spacing:3px;
  text-transform:uppercase;
  color:var(--purple-bright);
  margin-bottom:6px;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  max-width:100%;
}
.media-card-caption .title{
  font-family:var(--font-display);
  font-size:16px;
  font-weight:700;
  letter-spacing:2px;
  text-transform:uppercase;
  color:var(--white);
  line-height:1.2;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  max-width:100%;
}
@media (max-width:600px){
  /* Solo caption styling — el resto de media-card mobile rules está en el bloque principal arriba */
  .media-card-caption{
    position:static !important;
    inset:auto !important;
    background:var(--gray2);
    padding:14px 16px 18px;
    flex-direction:column;
    justify-content:center;
    align-items:center;
    z-index:auto;
    width:100%;
  }
  .media-card-caption .label{font-size:9px;letter-spacing:3px;white-space:normal}
  .media-card-caption .title{font-size:15px;letter-spacing:1.5px;white-space:normal}
}

/* ---------- VIDEO EMBED ---------- */
.video-embed{
  position:relative;width:100%;aspect-ratio:16/9;
  background:#000;overflow:hidden;
  border:1px solid var(--purple-line);
}
.video-embed iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.video-embed-wrapper{max-width:1100px;margin:0 auto}
.video-double{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media (max-width:800px){.video-double{grid-template-columns:1fr}}

/* ---------- LITE YOUTUBE — no carga iframe hasta click ---------- */
/* Resuelve el problema de iframes que se auto-reproducen al scroll en Android */
.yt-lite{
  position:relative;
  width:100%;
  aspect-ratio:16/9;
  background-color:#000;
  background-size:cover;
  background-position:center;
  cursor:pointer;
  overflow:hidden;
  border:1px solid var(--purple-line);
}
.yt-lite::before{
  content:"";
  position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(0,0,0,.25),transparent 30%,transparent 70%,rgba(0,0,0,.4));
  pointer-events:none;
}
.yt-lite::after{
  content:"";
  position:absolute;
  top:50%;left:50%;
  transform:translate(-50%,-50%);
  width:68px;height:48px;
  background:rgba(147,51,234,.92);
  border-radius:8px;
  transition:background .25s ease,transform .25s ease;
  z-index:1;
}
.yt-lite .yt-play{
  position:absolute;
  top:50%;left:50%;
  transform:translate(-50%,-50%);
  width:0;height:0;
  border-style:solid;
  border-width:10px 0 10px 16px;
  border-color:transparent transparent transparent #fff;
  z-index:2;
  pointer-events:none;
  margin-left:3px;
}
.yt-lite:hover::after{background:var(--purple-bright);transform:translate(-50%,-50%) scale(1.08)}
.yt-lite.activated{cursor:auto;background-image:none!important}
.yt-lite.activated::before,.yt-lite.activated::after,.yt-lite.activated .yt-play{display:none}
.yt-lite.activated iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
/* Vertical aspect para shorts/reels */
.yt-lite[data-vertical]{aspect-ratio:9/16}

/* ---------- CAROUSEL ---------- */
.carousel{position:relative}
.carousel-track{
  display:flex;gap:16px;
  overflow-x:auto;
  scroll-snap-type:x mandatory;
  scroll-padding:0 var(--pad-x);
  padding-bottom:1.5rem;
  scrollbar-width:thin;
  scrollbar-color:var(--purple) transparent;
}
.carousel-track::-webkit-scrollbar{height:6px}
.carousel-track::-webkit-scrollbar-track{background:transparent}
.carousel-track::-webkit-scrollbar-thumb{background:var(--purple);border-radius:3px}
.carousel-item{flex:0 0 min(420px,80vw);scroll-snap-align:start}
.carousel-item .video-embed{aspect-ratio:16/9}
.carousel-shorts .carousel-item{flex:0 0 min(280px,70vw)}
.carousel-shorts .carousel-item .video-embed{aspect-ratio:9/16}
.carousel-controls{
  display:flex;gap:.5rem;
  justify-content:center;
  margin-top:.5rem;
}
.carousel-btn{
  width:42px;height:42px;
  border:1px solid var(--purple-line);
  color:var(--white);
  display:flex;align-items:center;justify-content:center;
  transition:all var(--t-fast);
  background:transparent;
}
.carousel-btn:hover{border-color:var(--purple-bright);color:var(--purple-bright)}
.carousel-btn svg{width:18px;height:18px}

/* ---------- CBB Section ---------- */
.cbb-section{
  background:var(--gray);
  position:relative;
}
.cbb-section::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(ellipse at 50% 30%,var(--purple-glow) 0%,transparent 60%);
  opacity:.5;pointer-events:none;
}
.cbb-section>*{position:relative;z-index:1}
.cbb-quote{
  font-family:var(--font-display);
  font-size:clamp(20px,2.4vw,32px);
  font-weight:500;
  line-height:1.3;
  letter-spacing:2px;
  color:var(--white);
  max-width:50ch;
  margin:2.5rem auto;
  text-transform:uppercase;
  text-align:center;
  position:relative;
  padding:1.5rem 0;
}
.cbb-quote::before,.cbb-quote::after{
  content:"";display:block;width:40px;height:2px;background:var(--purple);
  margin:1.25rem auto;
}
.cbb-three{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin:3rem 0}
@media (max-width:800px){.cbb-three{grid-template-columns:1fr}}
.cbb-card{
  padding:30px 28px;
  background:var(--gray2);
  border-top:2px solid var(--purple);
  text-align:center;
  transition:background .3s ease;
}
.cbb-card:hover{background:var(--gray3)}
.cbb-card-eye{
  font-family:var(--font-body);
  font-size:9px;
  font-weight:600;
  letter-spacing:3px;
  text-transform:uppercase;
  color:var(--purple-bright);
  margin-bottom:14px;
}
.cbb-card h3{
  font-family:var(--font-display);
  font-size:18px;
  font-weight:700;
  letter-spacing:2px;
  margin-bottom:18px;
}
.cbb-card ul{display:flex;flex-direction:column;gap:.5rem;align-items:center}
.cbb-card li{
  font-family:var(--font-body);
  color:var(--white-60);
  font-size:12px;
  font-weight:300;
  line-height:1.6;
}

.acts-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin:3rem 0}
@media (max-width:1000px){.acts-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:500px){.acts-grid{grid-template-columns:1fr}}
.act-card{
  padding:30px 24px;
  background:var(--gray2);
  border-top:2px solid var(--purple);
  text-align:center;
  transition:background .3s ease;
}
.act-card:hover{background:var(--gray3)}
.act-num{
  font-family:var(--font-display);
  font-size:42px;
  font-weight:700;
  color:rgba(147,51,234,.18);
  line-height:1;
  letter-spacing:2px;
  margin-bottom:14px;
}
.act-card h4{
  font-family:var(--font-display);
  font-size:18px;
  font-weight:700;
  letter-spacing:2px;
  margin-bottom:14px;
}
.act-card p{
  font-family:var(--font-body);
  font-size:12px;
  font-weight:300;
  line-height:1.7;
  color:var(--white-60);
  margin:0 auto;
}

.peers-row{
  display:flex;flex-wrap:wrap;
  justify-content:center;
  gap:1.5rem 2.5rem;
  padding:2.5rem 0;
  align-items:center;
}
.peer{
  font-family:var(--font-display);
  font-size:18px;
  font-weight:500;
  color:var(--white-30);
  letter-spacing:3px;
  text-transform:uppercase;
}
.peer.featured{color:var(--purple-bright);font-weight:700}

/* ---------- LOGOS "VISTO EN" ---------- */
.logos-row{
  display:flex;flex-wrap:wrap;
  justify-content:center;align-items:center;
  gap:2.5rem 4rem;
  padding:2.5rem 0;
}
.logos-row img{
  height:48px;width:auto;max-width:140px;
  object-fit:contain;
  opacity:.4;
  filter:grayscale(1) brightness(1.8);
  transition:opacity var(--t),filter var(--t);
}
.logos-row img:hover{opacity:1;filter:grayscale(0) brightness(1)}

/* ---------- MUSIC PLAYERS ---------- */
.music-player{
  margin-bottom:1.5rem;
  background:var(--gray2);
  border:1px solid var(--purple-line);
  padding:1rem;
}
.music-player h3{
  padding:0 0 1rem;
  font-family:var(--font-body);
  font-size:9px;
  letter-spacing:6px;
  font-weight:600;
  text-transform:uppercase;
  color:var(--purple-bright);
  text-align:center;
}
.music-player iframe{display:block;width:100%;border:0}

/* Music page — profile 2 columnas: foto izq + texto der */
.profile-block-2col{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:48px;
  align-items:center;
  max-width:1100px;
  margin:0 auto 4rem;
  padding:0 var(--pad-x);
}
@media (max-width:800px){
  .profile-block-2col{grid-template-columns:1fr;gap:32px}
}
.profile-square{
  width:100%;
  max-width:480px;
  aspect-ratio:1/1;
  margin:0 auto;
  border:1px solid var(--purple-bright);
  overflow:hidden;
  background:var(--gray2);
  box-shadow:0 0 80px var(--purple-glow);
}
.profile-square img{width:100%;height:100%;object-fit:cover}
.profile-info{
  text-align:left;
  max-width:540px;
  margin:0;
}
@media (max-width:800px){.profile-info{text-align:center;margin:0 auto}}
.profile-info h2{
  font-size:clamp(28px,3.5vw,42px);
  letter-spacing:2px;
  margin-bottom:1.5rem;
  text-align:left;
}
@media (max-width:800px){.profile-info h2{text-align:center}}

/* ---------- VIDEO MODAL POPUP ---------- */
.vid-modal{
  display:none;
  position:fixed;
  inset:0;
  background:rgba(0,0,0,.94);
  z-index:9999;
  align-items:center;
  justify-content:center;
  padding:24px;
}
.vid-modal.open{display:flex}
.vid-modal-inner{
  width:100%;
  max-width:1100px;
  background:var(--black);
  border:1px solid var(--purple-line);
  box-shadow:0 0 80px var(--purple-glow);
  position:relative;
}
.vid-modal-close{
  position:absolute;
  top:-40px;right:0;
  width:36px;height:36px;
  background:transparent;
  border:1px solid var(--purple-line);
  color:var(--white);
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:18px;
  transition:all var(--t);
}
.vid-modal-close:hover{
  background:var(--purple-bright);
  border-color:var(--purple-bright);
}
.vid-modal-wrap{
  position:relative;
  padding-bottom:56.25%;
  height:0;
  overflow:hidden;
}
.vid-modal-wrap iframe{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  border:0;
}

/* ---------- BOOKING — DESKTOP: 3 cards (diseño original conservado) ---------- */
.booking-contacts{
  display:grid;grid-template-columns:repeat(3,1fr);gap:16px;
  margin:3rem auto;max-width:1100px;
}
@media (max-width:900px){.booking-contacts{grid-template-columns:1fr}}
.contact-card{
  padding:40px 28px;
  background:var(--gray2);
  border-top:2px solid var(--purple);
  text-align:center;
  transition:background .3s ease;
}
.contact-card:hover{background:var(--gray3)}
.contact-card-icon{
  width:48px;height:48px;
  border:1px solid var(--purple-bright);
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 1.25rem;
  color:var(--purple-bright);
}
.contact-card-icon svg{width:20px;height:20px;fill:currentColor}
.contact-card-label,
.contact-card h3{
  font-family:var(--font-display);
  font-size:14px;
  letter-spacing:2px;
  color:var(--white);
  margin-bottom:1rem;
  font-weight:600;
  text-transform:uppercase;
}
.contact-card p{
  font-family:var(--font-body);
  color:var(--white-60);
  font-size:13px;
  font-weight:300;
  font-style:italic;
  letter-spacing:.3px;
  margin:0 auto;
  max-width:none;
}
.contact-card a{color:var(--white-60);transition:color var(--t-fast);word-break:break-word}
.contact-card a:hover{color:var(--purple-bright)}

/* ---------- WhatsApp link — refinado (no botón sólido morado pesado) ---------- */
.wa-link{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:14px 28px;
  border:1px solid var(--purple-line);
  border-radius:999px;
  background:transparent;
  font-family:var(--font-body);
  font-size:11px;
  font-weight:500;
  letter-spacing:2.5px;
  text-transform:uppercase;
  color:var(--white);
  transition:all var(--t);
}
.wa-link:hover{
  border-color:var(--purple-bright);
  background:rgba(147,51,234,.08);
  color:var(--purple-bright);
}
.wa-link svg{flex-shrink:0;opacity:.7}
.wa-link:hover svg{opacity:1}
.wa-divider{opacity:.4;margin:0 4px}
.wa-number{font-weight:600;letter-spacing:1.5px}

/* ---------- BOOKING MOBILE — estilo HAUSER minimalista ---------- */
@media (max-width:600px){
  /* Quitar fondo, borde y cuadro de cards. Convertirlas en bloques de texto centrados */
  .booking-contacts{
    grid-template-columns:1fr !important;
    gap:48px !important;
    max-width:520px !important;
    margin:2rem auto 3rem !important;
  }
  .contact-card{
    background:transparent !important;
    border:0 !important;
    border-top:0 !important;
    padding:0 !important;
    text-align:center !important;
  }
  .contact-card:hover{background:transparent !important}
  /* Ocultar el ícono del email — estilo HAUSER puro texto */
  .contact-card-icon{display:none !important}
  /* Título en blanco grande (Booking / Prensa / Personal Manager) */
  .contact-card-label,
  .contact-card h3{
    font-size:15px !important;
    letter-spacing:2px !important;
    color:var(--white) !important;
    margin-bottom:8px !important;
  }
  /* Email en gris itálica */
  .contact-card p{font-size:13px !important;font-style:italic !important;color:var(--white-60) !important}

  /* WhatsApp link más compacto en mobile — solo "WhatsApp · +57 313 392 1188" */
  .wa-link{
    padding:12px 22px !important;
    font-size:10px !important;
    letter-spacing:2px !important;
  }
  .wa-link .wa-org,
  .wa-link .wa-divider-1{display:none !important}
}

.socials-grid{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:16px;margin:3rem auto;max-width:1000px;
}
@media (max-width:800px){.socials-grid{grid-template-columns:repeat(2,1fr)}}
.social-card{
  padding:2rem 1rem;
  background:var(--gray2);
  border-top:2px solid var(--purple);
  text-align:center;
  transition:background .3s ease;
  color:var(--white);
}
.social-card:hover{background:var(--gray3)}
.social-card svg{width:28px;height:28px;margin:0 auto 1rem;display:block;fill:var(--purple-bright)}
.social-card span{
  display:block;
  font-family:var(--font-display);
  font-size:14px;
  letter-spacing:2px;
  text-transform:uppercase;
  color:var(--white);
  font-weight:700;
}
.social-card small{
  display:block;
  font-family:var(--font-body);
  font-size:9px;
  font-weight:600;
  letter-spacing:3px;
  text-transform:uppercase;
  color:var(--white-30);
  margin-top:.5rem;
}

/* ---------- ACCORDION ---------- */
.accordion{margin-top:3rem;border-top:1px solid var(--line)}
.accordion-item{border-bottom:1px solid var(--line)}
.accordion-trigger{
  width:100%;
  padding:24px 0;
  display:flex;align-items:center;justify-content:space-between;gap:1rem;
  text-align:left;
  cursor:pointer;
  background:transparent;
  color:var(--white);
  font-family:var(--font-display);
  font-size:16px;
  font-weight:700;
  letter-spacing:3px;
  text-transform:uppercase;
  transition:color var(--t-fast);
}
.accordion-trigger:hover{color:var(--purple-bright)}
.accordion-trigger::after{
  content:"+";font-size:1.5rem;
  color:var(--purple-bright);
  font-family:var(--font-body);
  font-weight:300;
  transition:transform var(--t);
}
.accordion-item[open] .accordion-trigger::after{transform:rotate(45deg)}
.accordion-content{padding:0 0 2rem;color:var(--white-60);max-width:80ch}
.accordion-content h4{
  font-family:var(--font-body);
  font-size:11px;
  letter-spacing:4px;
  text-transform:uppercase;
  color:var(--purple-bright);
  margin-top:1.5rem;
  margin-bottom:.75rem;
  font-weight:600;
}
.accordion-content p,.accordion-content li{
  font-family:var(--font-body);
  font-size:12px;
  line-height:1.8;
  margin-bottom:.5rem;
  color:var(--white-60);
  font-weight:300;
  letter-spacing:.3px;
}
.accordion-content ul{padding-left:1.5rem;list-style:disc;margin-bottom:1rem}
.accordion-content strong{color:var(--white);font-weight:500}

/* ---------- FOOTER ---------- */
.site-footer{
  padding:4rem var(--pad-x) 2rem;
  border-top:1px solid var(--line);
  background:var(--gray);
  position:relative;
}
.footer-grid{
  display:grid;grid-template-columns:2fr 1fr 1fr 1fr;
  gap:3rem;margin-bottom:3rem;
  max-width:var(--maxw);margin-left:auto;margin-right:auto;
}
@media (max-width:800px){.footer-grid{grid-template-columns:1fr 1fr;gap:2rem;text-align:center}}
@media (max-width:500px){.footer-grid{grid-template-columns:1fr}}
.footer-brand{
  font-family:var(--font-display);
  font-size:14px;
  font-weight:700;
  letter-spacing:5px;
  color:var(--white);
  margin-bottom:1rem;
  text-transform:uppercase;
  display:flex;align-items:center;gap:14px;
}
@media (max-width:800px){.footer-brand{justify-content:center}}
.footer-brand .brand-cross{width:22px;height:22px}
.footer-tagline{
  font-family:var(--font-body);
  color:var(--white-45);
  font-size:12px;
  line-height:1.8;
  margin-bottom:1.5rem;
  font-weight:300;
  letter-spacing:.3px;
}
.footer-socials{display:flex;gap:1rem}
@media (max-width:800px){.footer-socials{justify-content:center}}
.footer-socials a{
  width:38px;height:38px;
  border:1px solid var(--white-15);
  display:flex;align-items:center;justify-content:center;
  transition:all var(--t-fast);
  color:var(--white-45);
}
.footer-socials a:hover{border-color:var(--purple-bright);color:var(--purple-bright)}
.footer-socials svg{width:16px;height:16px;fill:currentColor}
.footer-col h5{
  font-family:var(--font-body);
  font-size:9px;
  letter-spacing:4px;
  text-transform:uppercase;
  color:var(--purple-bright);
  margin-bottom:1rem;
  font-weight:600;
}
.footer-col ul li{margin-bottom:.5rem}
.footer-col a{
  font-family:var(--font-body);
  color:var(--white-45);
  font-size:11px;
  font-weight:300;
  transition:color var(--t-fast);
  letter-spacing:.3px;
}
.footer-col a:hover{color:var(--white)}
.footer-bottom{
  padding-top:2rem;
  border-top:1px solid var(--line);
  display:flex;justify-content:space-between;flex-wrap:wrap;
  gap:1rem;
  font-family:var(--font-body);
  font-size:9px;color:var(--white-30);
  letter-spacing:3px;
  font-weight:600;
  text-transform:uppercase;
  max-width:var(--maxw);
  margin:0 auto;
}
@media (max-width:600px){.footer-bottom{justify-content:center;text-align:center}}

/* ---------- FLOATING SOCIAL MENU — color blanco ---------- */
.social-float{
  position:fixed;
  right:1.5rem;
  top:50%;
  transform:translateY(-50%);
  z-index:90;
  display:flex;
  flex-direction:column;
  gap:.6rem;
}
.social-float a{
  width:44px;height:44px;
  display:flex;align-items:center;justify-content:center;
  background:rgba(0,0,0,.65);
  border:1px solid var(--white-15);
  color:var(--white);
  backdrop-filter:blur(8px);
  transition:all var(--t);
}
.social-float a:hover{
  background:var(--purple-bright);
  color:var(--white);
  border-color:var(--purple-bright);
  box-shadow:0 0 24px var(--purple-glow);
}
.social-float svg{width:18px;height:18px;fill:currentColor}
@media (max-width:700px){
  .social-float{
    top:auto;bottom:1rem;right:50%;
    transform:translateX(50%);
    flex-direction:row;
  }
}

/* ---------- UTILITIES ---------- */
.full-width{width:100%}
.flex{display:flex}
.center{align-items:center;justify-content:center}
.gap-sm{gap:1rem}
.gap{gap:1.5rem}
.gap-lg{gap:2.5rem}
.mb-0{margin-bottom:0}.mb-sm{margin-bottom:1rem}.mb{margin-bottom:2rem}.mb-lg{margin-bottom:3rem}
.mt-0{margin-top:0}.mt-sm{margin-top:1rem}.mt{margin-top:2rem}.mt-lg{margin-top:3rem}
.mx-auto{margin-left:auto;margin-right:auto}

/* Reveal animations */
.reveal{opacity:0;transform:translateY(20px);transition:opacity var(--t-slow),transform var(--t-slow)}
.reveal.in{opacity:1;transform:translateY(0)}
@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}

/* Accessibility */
:focus-visible{outline:2px solid var(--purple-bright);outline-offset:3px}
@media (prefers-reduced-motion:reduce){*{animation-duration:.01ms!important;transition-duration:.01ms!important}}

/* Doc badge */
.doc-badge{
  display:inline-block;
  padding:8px 18px;
  border:1px solid var(--purple-line);
  font-family:var(--font-body);
  font-size:10px;
  letter-spacing:5px;
  text-transform:uppercase;
  color:var(--purple-bright);
  font-weight:600;
  margin:0 auto 28px;
  background:rgba(0,0,0,.4);
}
