/*!
Version: 1.0.0
*/


.header-2020 {
	position: sticky;
	z-index: 20;
    top: 0;
}

.main-navigation {
	position: sticky;
	top: 36px;
	z-index: 20;
}

@keyframes flicker-on {
  0%  { filter: blur(1px) invert(100%); }
  20%  { filter: blur(1px); }
  40%  { filter: blur(1px) invert(100%); }
  60%  { filter: blur(1px); }
  80%  { filter: blur(1px) invert(100%); }
  100%  { filter: blur(1px)  }
}

.festival-2026{
    font-family: "neue-haas-grotesk-text", sans-serif;
    font-weight: 500;
    font-style: normal;    
    overflow:hidden;
    
}

    
.estilo-2026 {
	display: inline-block;
	line-height: 100%;
	text-shadow: 
   2px 0px 0px #fff, -2px 0px 0 #fff, 0px 2px #fff, 0px -2px 0 #fff, 1px 11px 9px #ffffff80, -1px -11px 10px #ffffff80;
    font-size: 100px;
    letter-spacing: -6%;
    filter: blur(1px);
    margin: 1px;
    position: relative;
}
    
.estilo-2026:after{
    background-color: #111;
    content: "";
    position: absolute;
    top: 7px;
    width: 100%;
    height: 100%;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: -1;
    }
    
.estilo-2026 span, .estilo-2026 a{
    display: inline-block;
    position: relative;
    z-index: 2;
    }

.abonos-evento-festival h3 a{
    z-index: 9;
    pointer-events: all;
}

.lineup small{
    white-space: nowrap;
    line-height: 100%;
}

.estilo-2026:has(.splitspan):after{
    display: none;
}

.estilo-2026 .splitspan .splitspan-line{
    position: relative;
    display: inline-block !important;
}

.estilo-2026 .splitspan  .splitspan-line:after{
    background-color: #111;
    content: "";
    position: absolute;
    top: 7px;
    width: 100%;
    height: 100%;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: -1;
}
.festival-2026{
    padding-top: 40px;
}

    
.estilo-2026:has(a):hover, .site-intro:hover .estilo-2026, .ficha-artista-link:hover, .tiquet-evento-festival a:hover, .dantz-fest-abono-active:hover, .site-intro-container .tickets:hover{
     animation: flicker-on 0.3s steps(1) forwards; 
}   

.site-intro a{
    display: inline-block;
}

.estilo-2026 small {
    font-size: 40px;
    }

.estilo-2026-xs {
    text-shadow: 
   1px 0px 0px #fff, -1px 0px 0 #fff, 0px 1px #fff, 0px -1px 0 #fff, 1px 1px 1px #ffffff80, -1px -1px 1px #ffffff80;
    font-size: 30px;
}


.estilo-2026-s {
    text-shadow: 
   1px 0px 0px #fff, -1px 0px 0 #fff, 0px 1px #fff, 0px -1px 0 #fff, 1px 3px 3px #ffffff80, -1px -3px 3px #ffffff80;
    font-size: 50px;
}

.estilo-2026-m {
    text-shadow: 
   1px 0px 0px #fff, -1px 0px 0 #fff, 0px 1px #fff, 0px -1px 0 #fff, 1px 3px 3px #ffffff80, -1px -3px 3px #ffffff80;
    font-size: 70px;
}

.estilo-2026-l {
    text-shadow: 2px 0px 0px #fff, -2px 0px 0 #fff, 0px 2px #fff, 0px -2px 0 #fff, 1px 11px 9px #ffffff80, -1px -11px 10px #ffffff80;
    font-size: 70px;
}


.editorial p, .site-intro > *, .artista-ficha-descripcion-bio p, .descripcion-informacion-evento p {
	font-family: "neue-haas-grotesk-text", sans-serif;
	display: block;
	box-decoration-break: inherit;
	font-size: 27px;
	line-height: 125%;
	text-shadow: 0.5px 0px 0px #fff, -0.5px 0px 0 #fff, -0.5px 0px #fff, 0px -0.5px 0 #fff;
	letter-spacing: -2%;
	filter: blur(1px);
	max-width: 990px;
}

.editorial p span, .site-intro > * span, .parrafo-span span {
	background-color: black;
}

.splitspan:has(.splitspan-line){
    background-color: transparent;
}

.page-template-page-festival-2026 .site-intro-container {
	position: sticky;
	top: 90px;
	display: flex;
	flex-direction: column;
	gap: 30px;
	align-items: center;
	margin-bottom: 60px;
}

.galeria .swiper-slide {
  width: auto;
}

.site-intro {
	
}
.site-intro > *{
    font-size: 28px;
}


.site-intro li:nth-child(1){
    margin-left: 30px;
}

.site-intro li:nth-child(2){
    margin-left: 15px;
}
.site-intro li:nth-child(4){
    margin-left: 30px;
}
.site-intro li:nth-child(5){
    margin-left: 60px;
}


.bg-video{
    width: 100%;
    position: fixed;
    left: 0;
    top: 0;
    right: 0;
    bottom: 0;
    z-index: -1;
}

.bg-video video{
    width: 100%;
    height: 100%;
    object-fit: cover;    
}

.festival-2026{
    position: relative;
}

.artista-template-default .site{
    padding-bottom: 120px;
}

.festival-2026:after, .artista-template-default .site:after, .evento-festival-template-default .evento-festival:after{
    background-image: url(https://dantz.eu/festival/wp-content/uploads/sites/3/2026/03/ruido.jpg);
    content: "";
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-repeat: repeat;
    mix-blend-mode: soft-light;
    pointer-events: none;
    z-index: 10;
    opacity: 50%;

}

.festival-2026 ul, .site-intro ul{
    display: flex;
    flex-direction: column;
    list-style: none;
    margin: 0;
    padding: 0;
}    

.festival-contact{
    display: none !important;
}    

.artista{
    position: relative;
}

.artista img {
	width: 100%;
	height: auto;
	filter: blur(1px);
    aspect-ratio:1 / 1;
}

.artista h3{
position: absolute;
  z-index: 10;
  bottom: 0;
  right: 0;
    text-align: right;
    pointer-events: none;
}

.grid .artista{
    width: 80%;
}

.grid li:nth-child(even) .artista{
    float: right;
}

.grid .artista .splitspan {
	text-align: right;
	position: absolute;
	bottom: 0;
	right: 0;
}

.glitch-frame {
	position: relative;
	width: auto;
	aspect-ratio: auto;
	display: inline-block;
}


.glitch-base {
  position: static;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 1;
  filter: saturate(0.7) blur(2px);
  pointer-events: none;
display: inline-block;
}

.glitch-slices {
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 1;
  opacity: 0;
}

.glitch-slice {
  --top: 0%;
  --height: 0%;
  --offset: 0px;
  --skew: 0deg;
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  clip-path: inset(var(--top) 0 calc(100% - var(--top) - var(--height)) 0);
  transform: translateX(var(--offset)) skewX(var(--skew));
  overflow: hidden;
}

.glitch-slice-image {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: saturate(0.7) blur(2px);
  pointer-events: none;
}

.glitch-frame:hover .glitch-base {
  animation: glitch-base-flicker 0.3s steps(1, end) forwards;
}

.glitch-frame:hover .glitch-slices {
  animation: glitch-slices-flicker 0.3s steps(1, end) forwards;
}

h2 {
  margin: 12px 0 0;
  font-size: 1rem;
  font-weight: 500;
}

.editorial{
    margin-top: 120px;
    margin-bottom: 120px;
}

.editorial-titulo{
    margin-bottom: 40px;
}

.festival-2026 ul.more-tba {
	margin-top: 20px;
	margin-bottom: 120px;
}

@keyframes glitch-base-flicker {
  0% {
    opacity: 1;
  }

  10% {
    opacity: 0;
  }

  24% {
    opacity: 1;
  }

  38% {
    opacity: 0;
  }

  52% {
    opacity: 1;
  }

  66% {
    opacity: 0;
  }

  100% {
    opacity: 0;
  }
}

@keyframes glitch-slices-flicker {
  0% {
    opacity: 0;
  }

  10% {
    opacity: 1;
  }

  24% {
    opacity: 0;
  }

  38% {
    opacity: 1;
  }

  52% {
    opacity: 0;
  }

  66% {
    opacity: 1;
  }

  100% {
    opacity: 1;
  }
}

.swiper-colaboradores{
    margin-bottom: 120px;
}


.swiper-colaboradores img{
    aspect-ratio: 3/3;
	object-fit: contain;
	width: 100%;
	height: auto;
	max-height: 86px;
	max-width: 210px;
    filter: blur(1px);
    background-color: #2b2b2b;
    padding: 5px;
    
}

.abonos-evento-festival {
	margin-bottom: 60px;
	pointer-events: none;
}


.abonos-evento-festival li:last-child h3.estilo-2026-xs{
    max-width: 400px;
}

.dantz-fest-abono-soldout {
	opacity: 0.5;
	pointer-events: none;
	position: relative;
	display: inline flow-root list-item;
	width: auto;
	/* background-color: red; */
}
.dantz-fest-abono-soldout .dantz-fest-abono-precio {
	position: relative;
	width: auto;
	display: inline-block;
}

.dantz-fest-abono-soldout .dantz-fest-abono-precio::after {
	content: "SOLD OUT";
	background-color: #000;
	position: absolute;
	width: auto;
	top: 50%;
	left: 50%;
	font-size: 20px;
	text-align: center;
	transform: translate(-50%, -50%) rotate(-15deg);
	white-space: nowrap;
}

.dantz-fest-abono{
    opacity: 0.4;
    display: block;
}

.dantz-fest-abono-active{
    opacity: 1;
    pointer-events:all;
}

.galeria {
	overflow: hidden;
	margin-bottom: 60px;
}

.galeria img {
	width: 100%;
	height: 100%;
	max-height: 590px;
	filter: blur(0.5px);
}

.galeria .swiper-slide {
  width: auto;
}

.galeria .swiper{
    overflow: visible;
    margin: 120px 0;
}


.galeria .swiper-slide img{
    transform: scale(1.2);
}

.galeria .swiper-slide-par{
    margin: -30px;
    margin: 0;
    z-index: 2;   
}
.galeria .swiper-slide-par img {
	transform: scale(1.15) translateY(45px);
}

.estilo-2026.logo-dantz-2026 {
	font-size: 1px;
	margin-bottom: 0;
	margin-top: 0;
	margin-left: -15px;
    filter: blur(0.5px);
}

.lineup-gallery ul.grid {
  display: grid;
  grid-template-columns: 1fr; /* o repeat(2, 1fr) si quieres */
  gap: 40px;
  padding: 0 20px;
}

.lineup-gallery ul.grid li {
  grid-column: auto;
}


/* ARTISTA */

.bio-dantz-artista{
    margin-bottom: 0;
}

.artista-ficha-descripcion h1{
    margin-bottom: 30px;
    
}

.ficha-artista-links a {
	position: relative;
	z-index: 1;
	font-size: 35px;
}

.ficha-artista-links i{
    position: relative;
    z-index: 1;
}


.ficha-artista-links a::after {
	content: "";
	background-color: black;
	position: absolute;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
	z-index: -1;
}

.ficha-artista-retrato img {
	width: 100%;
	height: auto;
}


.layout-artista {
  display: grid;
  gap: 1.5rem;
  grid-template-columns: 1fr;
}

.site-intro,
.ficha-artista-retrato,
.bio-dantz-artista,
.layout-artista__gap {
  width: 100%;
}

.contenido-dantz-artista {
  order: 3;
}

.ficha-artista-retrato {

  order: 1;
}

.bio-dantz-artista {
  order: 2;
}

.layout-artista__gap {
  order: 4;
}

.site-intro-container {
	display: flex;
	margin-top: 60px;
	gap: 5px;
	justify-content: start;
	align-items: start;
}

.site-intro-container .logo-dantz-2026{
    margin-top: 0;
}

.artista-template-default .site{
    overflow-x: hidden;
}

.artista-template-default .logo-dantz-2026 img{
    width: 100%;
    height: auto;
}

.artista-template-default .estilo-2026.logo-dantz-2026{
    margin-left: 0;
}

.artista-template-default .estilo-2026-xs{
    font-size: 27px;
}

.tabla-escenario-evento {
	margin-top: 22px;
}

.tabla-escenario-evento .interior-tabla-evento:first-child {
	border-top: solid 6px black;
	box-shadow: 0px 7px 0 black,  0px -7px 0 #fff;
    
}

.interior-tabla-evento {
	display: flex;
	justify-content: space-between;
	align-items: end;
	border-bottom: solid 6px #fff;
	padding: 10px 0;
	gap: 3rem;
	box-shadow: 0px 7px 0 black;
}

.interior-tabla-evento p {
	margin-bottom: 0px;
	text-transform: uppercase;
	font-size: 1.1rem;
}

.evento-header-txt {
	display: flex;
	flex-direction: column;
	height: 100%;
	justify-content: space-between;
	align-items: flex-end;
    padding: 60px 0;
}

.evento-header-txt .info-evento-festival > div {
	width: auto;
	display: flex;
	flex-direction: column;
	align-items: baseline;
}

.evento-header-txt .hora-evento-festival {
	transform: translate(60px, -5px);
}

.hora-tabla-evento{
    white-space: nowrap;
}


@media (min-width: 576px) {

.festival-2026{
overflow: clip;
}
 
.galeria .swiper-slide img{
    transform: scale(1.1);
}

.galeria .swiper-slide-par img {
	transform: scale(1.1) translateY(-15px);
}    
    
}

@media (min-width: 768px) { 
    
    
.site-intro-container {
	gap: 30px;
}    

.artista-template-default .estilo-2026-xs{
    font-size: 30px;
}
    
.artista-template-default .logo-dantz-2026 img{
    width: auto;
    height: auto;
}
    
.artista-template-default .estilo-2026.logo-dantz-2026{
    margin-left: -15px;
}    
    
.site-intro-container{
    flex-direction:column;
}
    

.grid .artista{
    width: 100%;
}

.grid li .artista{
    float:none;
}

@media (min-width: 768px) {
 
   
.galeria .swiper-slide img {
	transform: scale(1.15);
}
        
.galeria .swiper-slide-par img {
	transform: scale(1.15) translateY(45px);
}
    
    
    
  .layout-artista {
    grid-template-columns: 1fr 1fr;
    grid-template-areas:
      "intro retrato"
      "gap   retrato"
      "bio   bio";
    align-items: start;
  }

  .contenido-dantz-artista {
    grid-area: intro;
    order: initial;
  }

  .ficha-artista-retrato {
    grid-area: retrato;
    order: initial;
  }

  .bio-dantz-artista {
    grid-area: bio;
    order: initial;
  }

  .layout-artista__gap {
    grid-area: gap;
    order: initial;
  }
    
.ficha-artista-retrato img {
	margin-top: 60px;
}    

.galeria img {
	filter: blur(1px);
}    

    
}


@media (min-width: 768px) and  (max-width: 992px) {
    
  .lineup-gallery ul.grid {
    grid-template-columns: repeat(5, 1fr);
    padding: 0 60px;
  }

  .lineup-gallery ul.grid li {
    grid-column: span 2;
  }

  /* fila impar */
  .lineup-gallery ul.grid li:nth-child(4n + 1) {
    grid-column: 2 / span 2;
  }

  /* fila par */
  .lineup-gallery ul.grid li:nth-child(4n + 3) {
    grid-column: 1 / span 2;
  }    
    
}


@media (min-width: 992px) {
       
.estilo-2026-l {
    text-shadow: 2px 0px 0px #fff, -2px 0px 0 #fff, 0px 2px #fff, 0px -2px 0 #fff, 1px 11px 9px #ffffff80, -1px -11px 10px #ffffff80;
    font-size: 80px;
}
    
   .lineup-gallery ul.grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 60px;
  padding: 0 0;
}

.lineup-gallery ul.grid li {
  grid-column: span 2;
}


.lineup-gallery ul.grid li:nth-child(6n + 1) {
  grid-column: 2 / span 2;
}

.lineup-gallery ul.grid li:nth-child(6n + 4) {
  grid-column: 1 / span 2;
}
     
    
    .lineup ul{
        column-count: 2;
        display: block;
    }    
    

  .layout-artista {
    grid-template-columns: 1.2fr 0.85fr;
    grid-template-areas:
      "intro retrato"
      "bio   retrato"
      "gap   .";
    align-items: start;
  }

  .contenido-dantz-artista{
    grid-area: intro;
  }

  .ficha-artista-retrato {
    grid-area: retrato;
  }

  .bio-dantz-artista {
    grid-area: bio;
  }

  .layout-artista__gap {
    grid-area: gap;
  }
    
      
.site-intro-container{
    flex-direction:row;
}        
 
    .site-intro-container .site-intro{
        margin: 0;
    }    
    
.site-intro-container .estilo-2026.logo-dantz-2026 {
	margin-left: 0;
    margin-bottom: 0;
}    
    
}
        

@media (min-width: 1200px) {
    

    
}

@media (min-width: 1400px) {

.container, .container-lg, .container-md, .container-sm, .container-xl, .container-xxl {
	max-width: 1580px;
}
    
}

    
@media (min-width: 1700px) {
    


}    

@media (min-width: 2000px) {

    
}  
    
