@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@400;500;600;700&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Roboto:ital,wght@0,100;0,300;0,400;0,500;0,700;0,900;1,100;1,300;1,400;1,500;1,700;1,900&display=swap');

/*
@font-face {
        font-family: Roboto;
        src: url('../Fonts/Roboto-Black.ttf'), 
             url('../Fonts/Roboto-BlackItalic.ttf'),
             url('../Fonts/Roboto-Bold.ttf'),
             url('../Fonts/Roboto-BoldItalic.ttf'),
             url('../Fonts/Roboto-Light.ttf'),
             url('../Fonts/Roboto-LightItalic.ttf'),
             url('../Fonts/Roboto-Medium.ttf),
             url('../Fonts/Roboto-Regular.ttf),
             url('../Fonts/Roboto-Thin.ttf),
             url('../Fonts/Roboto-ThinItalic.ttf);
    }

@font-face {
        font-family: Roboto;
        src: url('../Fonts/Roboto-Regular.ttf');
           }
*/

:root{
    --background-contact: #EABE3F;
    --background-work: #F5F5F5;
    --background-color: #F5F5F5;
    --primary-color: #000;
    --highlight-color: #0000FF;
    --link-color: #5391C7;
    --danger-color: #FF0000;
}

*{
    font-size: 16px;
    /*font-family: 'Poppins', sans-serif;*/
}

html{
    scroll-behavior: smooth;
}

body{
    background-color: var(--background-work);
    font-family: 'Work Sans', Arial, Helvetica, sans-serif;
    line-height: 1.5;
    padding: 0;
    margin: 0;
}

:-moz-selection{
    background-color: var(--highlight-color);
}
::selection{
    background-color: var(--highlight-color);
}

a{
  color: var(--link-color);
  text-decoration: none;
  padding: 10px;
  transition: color 0.2s ease-in-out
}

a:hover{
    color: var(--highlight-color);
}

h2, h3, h4{
    font-family: 'Barlow Condensed', Arial, Helvetica, sans-serif;
}

h2{
    font-size: 2.0rem;
    text-align: center;
}

h3{
    font-size: 1.5rem;
    text-align: center;
}

h4{
    font-size: 1rem;
    text-align: center;
}

h5{
    text-align: center;
}

.reset-style {
    all: unset;
    display: block;
}

.container{
    width: 1920px;
}

/*
              MENU
**/

.menu{
    text-align: center;
    display: flex;
    justify-content: space-between;
    margin: 10px auto 0 auto;
    width: 60%;
    align-items: center;
}

.menu > div{
    width: 33%;
}

.menu ul{
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    justify-content: center;
    gap: 30px;
}

.menu ul li{
    animation-name: opening-logo;
    animation-duration: 1.4s;
    animation-timing-function: ease-in-out;
}

.menu a{
    font-family: 'barlow Condensed';
    font-size: 1.5rem;
}


.menu .logo img{
    animation-name: opening-logo;
    animation-duration: 1.6s;
    animation-timing-function: ease-in-out;
}

.menu .menu-left a{
    font-family: 'barlow Condensed';
    font-size: 1.5rem;
}

.menu .menu-right a{
    font-family: 'barlow Condensed';
    font-size: 1.5rem;
}

.menu-mobile{
    display: none;
}

.menu-mobile a:hover svg{
    fill: var(--highlight-color);
}

.menu-mobile .header{
    display: flex;
    width: 100%;
    flex-direction: row;
    align-items: center;
    justify-content: space-evenly;
    align-content: center;
}

.menu-mobile .header .logo{
    flex-grow: 2;
    text-align: center;
}

.menu-mobile .header .logo img{
    width: 256px;

    animation-name: opening-logo;
    animation-duration: 1.6s;
    animation-timing-function: ease-in-out;
}

.menu-mobile ul{
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
}

.menu-mobile ul li{
    text-align: center;
}

.menu-mobile ul li a{
    display: block;
    padding: 10px 0;
}

.menu-mobile-closed{
    display: none;
}
/*
              MAIN VIDEO
**/

.main-video{
    margin-top: 250px;
    transform-origin: 0 0;
    transform: skewY(-10deg);
    overflow: hidden;
    height: 500px;
    margin-bottom: 150px;
}

.main-video .video{
    overflow: hidden;
    transform: skewY(10deg) scale(1.4, 1.4);
}

.main-video .video video{
    margin-top: -100px;
    width: 100%;
}

/*
              INTRO
**/

.intro{
    text-align: center;
    width: 320px;
    margin: 0 auto;
    margin-top: -100px;
    padding-bottom: 100px;
}

/*
              WORK
*/

.work{
    /*padding-top: 150px;*/
    transform-origin: 0 0;
    /*transform: skewY(-10deg);*/
}

.grid{
    display: grid;
    grid-template-columns: 1fr 1fr 1fr 1fr;
    gap: 0;

}

.grid .item{
    padding: 0;
    position: relative;
    overflow: hidden;
    height: 300px;
}

.grid .item img{
    /*width: 101%;*/
    /*margin-top: -60px;*/
    /*transform: skewY(10deg) scale(1.2,1.2);*/
    transition: all 0.075s;
}

.grid .item:hover img{
    /*transform: skewY(10deg) scale(1.4,1.4);*/
}

.grid .item .bg-hover{
    background-color: rgba(0,0,0,0.7);
    width: 100%;
    height: 150%;
    display: grid;
    position: absolute;
    z-index: 2;
    top: -25%;
    opacity: 0;
    transition: opacity 0.3s ease-in-out;
    /*transform: skewY(10deg) scale(1,1);*/
    justify-items: center;
    align-items: center;
    text-align: center;
}

.grid .item:hover .bg-hover{
    oveoverflow: hidden;
    opacity: 1;
}

.grid .item:hover .bg-hover .info{
    animation-name: bounce;
    animation-duration: 0.4s;
    animation-timing-function: ease-in-out;
}

.grid .item .bg-hover .title{
    color: white;
}
.grid .item .bg-hover .customer{
    color: var(--background-color);
}

/*
              GRID ITEM X
*/

.grid .work{
    font-family: 'Roboto', sans-serif;
    font-size: 12px;
}


.grid .itemX img{
    /*width: 220px;
    height: 220px;
    border:solid;*/
}

.grid .itemX .iconoX{
    /*width: 220px;
    height: 220px;*/
}
.grid .itemX .bg-hoverX .infoX .titleX{
    font-family: 'Roboto', sans-serif;
    font-size: 14px;
    font-weight:bold;
    margin: 0px;
    line-height: 1.2;
}

.grid .itemX .bg-hoverX .infoX .customerX{
    font-family: 'Roboto', sans-serif;
    font-size: 14px;
    margin: 0px;
    line-height: 1.2;
}

.grid .itemX .bg-hoverX{
    /*width: 100%;*/
}

.main-container {
    align-content:center;
    /*margin-left:10px;
    margin-right:10px;*/
}

.evento{
    /*width: 75%;*/
    width: 90%;
    text-align: center;
    margin: 0 auto;
    padding-bottom: 0px;
    line-height:0;
    vertical-align:middle;
    overflow:auto;
}

/*
.evento section p {
    
}
*/

.evento img {
    width: 1000px;
}

.precios{
    /*width: 100%;*/
    /*width: 75%;*/
    align-content: center;
    text-align: center;
    margin: 0 auto;
    padding-bottom: 0px;
    /*font-family: 'Poppins', sans-serif;*/
}

.precios table{
    /*width: 800px;*/
    vertical-align:middle;
    align-content:center;
}

.precios div {
    color: var(--highlight-color);
    font-size: .8rem;
}

.botones{
    /*width: 100%;*/
    /*width: 75%;*/
    align-content: center;
    text-align: center;
    margin: 0 auto;
    padding-bottom: 0px;
    /*font-family: 'Poppins', sans-serif;*/
}

.botones table{
    /*width: 800px;*/
    vertical-align:middle;
    align-content:center;
}

.botones div {
    color: var(--highlight-color);
    font-size: .8rem;
}


.detalle{
    /*width: 100%;*/
    /*width: 75%;*/
    align-content: center;
    text-align: center;
    margin: 0 auto;
    padding-bottom: 0px;
    /*font-family: 'Poppins', sans-serif;*/
}

.detalle table{
    /*width: 800px;*/
    vertical-align:middle;
    align-content:center;
    font-size:1rem;
}

.totales{
    /*width: 75%;*/
    width: 50%;
    text-align: center;
    margin: 0 auto;
    padding-bottom: 0px;
    line-height:0;
    vertical-align:middle;
    overflow:auto;
}

.datos{
    /*width: 75%;*/
    /*width: 50%;*/
    /*width: 100% !important;*/
    text-align: center;
    margin: 0 auto;
    padding-bottom: 0px;
    line-height:0;
    vertical-align:middle;
    overflow:auto;
}

.datos input {
    text-align:center;
    vertical-align:middle;
}

.sesion div {
    color: var(--highlight-color);
    font-size: .8rem;
}

.sesion table tr td p {
    color: var(--danger-color);
    font-size: .8rem;
}

.correo div {
    color: var(--highlight-color);
    font-size: .8rem;
}   

.banco div {
    color: var(--highlight-color);
    font-size: .8rem;
}

.mapa img {
    width: 500px;
    /*height: 500px;*/
}

.about{
    width: 90%;
    text-align: center;
    margin: 0 auto;
    padding-bottom: 150px;

    gap: 30px;
}

.columns{
    width: 100%;

    display: flex;
    justify-content: space-between;
    gap: 30px;
}

.infoevento{
    /*display: flex;*/
    justify-content: space-between;
    /*gap: 30px;*/

    display: grid;
    grid-template-columns: 1fr 1fr 1fr 1fr;
    gap: 0;

}

.contact{
    background-color: #000;
    padding-0px;
}

.contact{
    background-color: #000;
    padding-top: 150px;
    color: white;
    transform: skewY(-10deg);
}

.contact .contact-container{
    transform: skewY(10deg);
    color: var(--background-contact);
    width: 1280px;
    margin: 0 auto;
}

.contact .contact-container h3{
    color: white;
}

.contact .contact-container .emails{
    text-align: right;
}

.contact .contact-container .emails h3{
    text-align: right;
}

.contact .contact-container .location h3{
    text-align: left;
}

.contact .contact-container .social{
    text-align: center;
}

.contact .contact-container .social a:hover path{
    fill: var(--highlight-color);
}

footer{
    background-color: #000;
    height: 450px;
    margin-top: -170px;
}

#screen{
    background-color:var(--highlight-color);
    position: fixed;
    z-index: 100;
    top: -280px;
    left: 0;
    width: 100vw;
    height: 10vh;
    transform: skewY(-10deg);
    transition: all 0.45s;
    animation-timing-function: lineal;
    animation-duration: 2s;
}

#details-container{
    background-color: var(--background-color);
    position: fixed;
    top:0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 10;
    overflow: auto;
    display: none;
}

#details-container .nav-bar{
    display: flex;
    justify-content: space-between;
    padding: 20px;
}

.item-hide{
    display: none;
}

#details-container .items{
    width: 60%;
    margin: 0 auto;
}

#details-container .items .item .main-image img{
    width: 100%;
}

#details-container .items .item .title{
    text-align: center;
}

.txtDerechoAutor
{
    width: 90%;
	color:#555555;
    font-size:12px;
}

.imgIcoMenu
{
    width:25px;
    height:25px;
}	

.lblMenu
{
	color: #FFd700;
	font-family: Verdana, Arial, Helvetica, sans-serif;
	font-size: 10px;
	font-weight: normal;
}

.footer-tabla {
  width: 100%;
  background-color: #f5f5f5; /* fondo claro sutil */
  color: #333; /* texto gris oscuro legible */
  padding: 2rem 1rem;
  font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
  border-top: 3px solid #c9a23f; /* dorado elegante */
}

.footer-tabla td {
  text-align: center;
}

.txtCopyright {
  font-size: 1rem;
  font-weight: 600;
  color: #2c2c2c;
  margin-bottom: 0.5rem;
}

.txtDerechoAutor {
  font-size: 0.875rem;
  line-height: 1.6;
  max-width: 800px;
  margin: 0 auto;
  padding: 0 1rem;
  text-align: justify;
  color: #555; /* gris medio para contraste suave */
}

.checkbox-container {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
  font-size: 0.95rem;
  color: #333;
  line-height: 1.5;
  max-width: 800px;
  margin: 1rem auto;
  padding: 0.5rem;
}

.checkbox-container input[type="checkbox"] {
  width: 1.1rem;
  height: 1.1rem;
  accent-color: #c9a23f; /* dorado elegante */
  cursor: pointer;
  margin-top: 3px;
}

.checkbox-container label {
  cursor: pointer;
}

.checkbox-container a {
  color: #c9a23f;
  text-decoration: none;
  font-weight: 600;
}

.checkbox-container a:hover {
  text-decoration: underline;
}

.form-login {
    width: 90%;
    max-width: 350px;
    margin: 0 auto;
    padding: 20px;
    box-sizing: border-box;
    display: grid;
    grid-template-columns: repeat(1, 1fr);
    gap: 1rem; /* Espacio entre los elementos de la cuadrícula */
    background-color: #fbfbfb; /* Asegúrate de que el fondo sea blanco para que la sombra sea visible */
    border-radius: 8px; /* Opcional: agrega bordes redondeados para un efecto más suave */
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2); /* Sombra: desplazamiento-x, desplazamiento-y, desenfoque, color */
}

/* Estilo general del formulario */
.form-container-4cols {
    max-width: 90%;
    margin: 0 auto;
    padding: 20px;
    box-sizing: border-box;
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1rem; /* Espacio entre los elementos de la cuadrícula */
    background-color: #fbfbfb; /* Asegúrate de que el fondo sea blanco para que la sombra sea visible */
    border-radius: 8px; /* Opcional: agrega bordes redondeados para un efecto más suave */
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2); /* Sombra: desplazamiento-x, desplazamiento-y, desenfoque, color */
}

/* Estilo general del formulario */
.form-container-3cols {
    max-width: 90%;
    margin: 0 auto;
    padding: 20px;
    box-sizing: border-box;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1rem; /* Espacio entre los elementos de la cuadrícula */
    background-color: #fbfbfb; /* Asegúrate de que el fondo sea blanco para que la sombra sea visible */
    border-radius: 8px; /* Opcional: agrega bordes redondeados para un efecto más suave */
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2); /* Sombra: desplazamiento-x, desplazamiento-y, desenfoque, color */
}

.form-group {
    margin: 0; /* Elimina el margen inferior para los grupos de formulario en la cuadrícula */
}

.form-control {
    width: 100%;
    padding: 8px;
    border: 1px solid #ddd;
    border-radius: 4px;
    box-sizing: border-box;
}

.form-group label {
    display: block;
    margin-bottom: 5px;
    font-weight: normal;
}

.form-actions {
    display: block;
    justify-content: space-between;
    margin-top: 20px;
}

@keyframes opening-logo{
    0%{
        transform: scale(0);
    }

    100%{
        transform: scale(1);
    }
}

@keyframes bounce{
    0% {transform: translateY(500px);}
    80% {transform: translateY(-30px);}
    100% {transform: translateY(0);}
}

@keyframes fade-in{
    0%{height: 0vh;}
    50%{height: 150vh;}
    100%{height: 0vh;}
}



@media (max-width: 1450px){
    .main-video{
        height: 600px;
    }

    .grid .item{
        padding: 0;
        position: relative;
        overflow: hidden;
        height: 250px;
    }

}

@media (max-width: 1280px){
    .main-video{
        height: 400px;
    }

    .grid{
        grid-template-columns: 1fr 1fr 1fr; 
    }

    .grid .item{
        height: 150px;
    }

    .contact .contact-container{
        width: 100%;
        margin: 0 auto;
        text-align: center;
    }

    .contact .contact-container h3{
        text-align: center !important;
    }
    .contact .contact-container .emails{
        text-align: center;
    }

    .evento img {
        width: 750px;
    }

    .evento {
        width: 75%;
        line-height:1;
    }

    .precios table {
        width: 750px;
    }

    .detalle table {
        width: 750px;
    }

    .botones table img image {
        width: 750px;
    }

    .form-container-3cols {
        grid-template-columns: repeat(3, 1fr);
    }

    .form-container-4cols {
        grid-template-columns: repeat(4, 1fr);
    }

}

@media (max-width: 900px){
    .grid .item{
        height: 150px;
    }
    .grid{
        grid-template-columns: 1fr 1fr; 
    }

    .evento img {
        width: 500px;
    }

    .evento {
        width: 75%;
    }

    .precios table {
        width: 500px;
    }

    .detalle table {
        width: 550px;
    }

    .botones table img image {
        width: 500px;
    }

    .form-container-3cols {
        grid-template-columns: repeat(3, 1fr);
    }

    .form-container-4cols {
        grid-template-columns: repeat(4, 1fr);
    }
}

@media (max-width: 800px){
    .main-video{
        height: 200px;
    }

    .main-video .video video{
        margin-top: 0;
    }

    .grid .item{
        height: 150px;
    }

    .grid{
        grid-template-columns: 1fr 1fr; 
    }

    .columns{
        flex-direction: column; 
        gap: 0;
    }

    .columns div{
        width: 100%;
        text-align: center;
    }

    .infoevento{
        flex-direction: column; 
        gap: 0;
    }

    .infoevento div{
        width: 100%;
        text-align: center;
    }

    .evento img {
        width: 500px;
    }

    .infoevento{
        grid-template-columns: 1fr 1fr 1fr 1fr;  
    }

    .mapa img {
        width: 400px;
        /*height: 400px;*/
    }

    .precios table {
        width: 500px;
    }

    .detalle table {
        width: 500px;
    }

    .botones table {
        width: 500px;
    }

    .form-container-3cols {
        grid-template-columns: repeat(2, 1fr);
    }

    .form-container-4cols {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 600px) {
  .txtCopyright {
    font-size: 0.9rem;
  }

  .txtDerechoAutor {
    font-size: 0.8rem;
    text-align: left;
  }

  .footer-tabla {
    padding: 1.5rem 0.5rem;
  }

  .checkbox-container {
    flex-direction: column;
    align-items: flex-start;
  }

}

@media (max-width: 540px){
    .menu{
        display: none;
    }

    .menu-mobile{
        display: block;
    }

    .main-video .video video{
        margin-top: 0;
    }
    

    .main-video{
        margin-top: 100px;
        height: 150px;
    }

    .grid .item{
        height: 200px;
    }

    .grid{
        grid-template-columns: 1fr; 
    }

    .evento img {
        width: 400px;
    }

    .evento {
        width: 75%;
        line-height:1;
    }

    .infoevento{
        grid-template-columns: 1fr 1fr 1fr 1fr; 
    }

    .precios table {
        width: 370px;
    }

    .detalle table {
        width: 370px;
    }

    .botones table img image {
        width: 370px;
    }

    .form-container-3cols {
        grid-template-columns: repeat(1, 1fr);
    }

    .form-container-4cols {
        grid-template-columns: repeat(1, 1fr);
    }
}