/*colores principales*/
:root {
    --colorMain: #19c4cf;
    --colorTexto: #666;
    --colorTransparente: #008cff1d;
    --colorHover: #26959d;
    --outlineMarkerInput: 4px solid #008cff;
    --borderInput: border: .2px solid #201f1f;
    --parrafo: 1.2em;
    --titulos: 1.4em;
    --fuente: Arial, Helvetica, sans-serif;
    --padding: 20px 30px 5px 43px;
    --inputTamano: 1em;
    --colorMainText: #fff;
    --inputBorder: #000000a3;
}
/*fin de los colores principales*/


.FrontContent{
    position: relative;
}
.FrontContent p{
    margin: 0;
}


/*estilos del selector de andata y ritorno*/
.FrontContent__formCheck{ /*contenedor*/
    display: flex;
    flex-wrap: wrap;
    gap: 18px;
    position: relative;
    left: -2px;
}
.FrontContent__formCheck__content1{ /*contenedor de las 2 primeras opciones*/
    display: flex;
    flex-wrap: wrap;
    gap: 18px;
}

.FrontContent__formCheck__label{ /*contenedores label*/
    display: flex;
    gap: 4px;
    cursor: pointer;
    align-items: center;
}

.FrontContent__formCheck__input{ /*inputs radio*/
    appearance: none !important;
    -webkit-appearance: none !important;
    -moz-appearance: none !important;
    width: 28px;
    height: 28px;
    border: var(--colorMain) 2px solid;
    border-radius: 50% !important;
    outline: none;
    position: relative;
    background-color: transparent !important;
    font-size: var(--inputTamano);
    margin: 0 !important;
}
.FrontContent__formCheck__colorTexto{ /*colorTexto del input radio*/
    color: var(--colorTexto);
    font-size: var(--colorTexto);
    font-family: var(--fuente);
}
.FrontContent__formCheck__input:checked {
    background-color: #fff; /* Color de fondo cuando está seleccionado */
    border: var(--colorMain) 2px solid !important;
}
.FrontContent__formCheck__input:focus{
    border: var(--colorMain) 2px solid !important;
}
.FrontContent__formCheck__input:checked::after {
    content: "";
    width: 15px;
    height: 15px;
    background-color: var(--colorMain); /* Color de la bolita interior */
    border-radius: 50% !important;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}

@media (min-width: 700px){
    .FrontContent__formCheck__content2{ /*contenedor de las 2 ultimas opciones*/
        width: auto;
    }
}
/*fin de los estilos del selector de andata y ritorno*/

/*estilos del selector del tipo de tren*/
.selectTypeTrain{ /*contenedor*/
    display: flex;
    align-items: center;
    gap: 15px;
    position: relative;
}
.selectTypeTrainHide{
    opacity: .5;
    pointer-events: none;
}
.selectTypeTrainCText{ /*contenedor del titulo y la opcion elegida*/
    display: flex;
    flex-direction: column;
    gap: 2px;
}
.selectTypeTrain__textTypeTr{ /*titulo de tipo di treno*/
    padding: 0 !important;
    margin: 0 !important;
    line-height: 1 !important;
    color: var(--colorTexto) !important;
    font-size: 1.2em !important;
}
.selectTypeTrain__textInd{ /*texto indicador*/
    padding: 0 !important;
    margin: 0 !important;
    line-height: 1 !important;
    color: #3f3939 !important;
    font-size: 1.2em !important;
}
.selectTypeTrain__icon{ /*icono indicador*/
    width: 25px !important;
    height: 25px !important;
    transition-duration: .2s;
}

.selectTypeTrain__options{ /*contenedor de las opciones*/
    display: none;
    flex-direction: column;
    justify-content: space-between;
    position: absolute;
    top: -4px;
    left: -4px;
    background-color: #fff;
    outline: .2px solid #000;
    z-index: 5;
    padding: 0 !important;
    margin: 0 !important;
    border-radius: 8px;
    min-width: 180px;
    height: calc(100% - 75px);
    width: calc(100% + 8px);
    overflow: hidden;
}
.selectTypeTrain__optionsShow{
    display: flex;
}
.selectTypeTrain__options__li{ /*opciones*/
    list-style: none;
    padding: 8.5px;
}
.selectTypeTrain__options__li:hover{
    background-color: var(--colorMain);
    color: var(--colorMainText);
}
.selectTypeTrain__options__liSelected{
    background-color: var(--colorMain);
    color: var(--colorMainText);
}
@media (min-width: 850px){
    .selectTypeTrain__options{
        height: 100%;
        min-height: 210px;
    }
}
/*fin de los estilos del selector del tipo de tren*/


/*estilos del switch selector de tipo de transporte*/
.contentTypeTransport{ /*contenedor del boton e iconos externos*/
    display: flex;
    justify-content: flex-end;
    gap: 4px;
    align-items: center;
}
.contentTypeTransport__btn{ /*estilos del boton que hace de switch*/
    position: relative;
    background-color: #80808066 !important;
    border-radius: 1000px;
    padding: 8px !important;
    margin: 0 !important;
    width: 65px;
    height: 25px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    border: none;
    outline: none;
}
.contentTypeTransport__btnInd{ /*bolita indicadora*/
    width: 35px;
    height: 35px;
    left: 0;
    background-color: #fff;
    position: absolute;
    border-radius: 1000px;
    border: .2px solid #000;
    z-index: 1;
}
.contentTypeTransport__btnIndRight{ /*bolita indicadora derecha*/
    left: auto;
    right: 0;
}

.contentTypeTransport--imgTrain{ /*iconos de tren*/
    width: 35px;
    height: 35px;
}
.contentTypeTransport--imgBus{ /*iconos de bus*/
    width: 35px;
    height: 35px;
}
/*fin de los estilos del switch selector de tipo de transporte*/


/*estilos de los buscadores*/
.FrontContent__formSearch{ /*contenedor de los inputs y boton de invertir*/
    display: flex;
    flex-direction: column;
    gap: 15px;
    align-items: center;
    justify-content: center;
    width: 100%;
}
.FrontContent__formInput{ /*contenedor de cada input de buscador*/
    width: 100%;
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: transparent !important;
    border-radius: 8px !important;
}
.FrontContent__formInput__p{ /*texto de arriba*/
    font-size: 1em !important;
    line-height: 1;
    background-color: transparent;
    position: absolute;
    top: 8px !important;
    left: 45px;
    z-index: 2;
    pointer-events: none;
}
.FrontContent__formInputImg{ /*estilos de los iconos*/
    width: 35px;
    height: 35px;
    transform: scale(1.3);
    position: absolute;
    border-radius: 0 !important;
    left: 5px;
    pointer-events: none;
    object-fit: cover;
    padding: 7px;
    z-index: 1;
    overflow: auto !important;
}
.FrontContent__form__input{ /*inputs*/
    outline: none;
    position: relative;
    margin: 0 !important;
    width: 100% !important;
    height: 100% !important;
    background-color: #fff !important;
    border: none !important;
    padding: var(--padding) !important;
    color: var(--colorTexto);
    border-radius: 8px !important;
    pointer-events: auto;
    font-size: var(--inputTamano) !important;
    box-shadow: 0px 0px 0px .2px var(--inputBorder) !important;
}

.btnDelString{ /*estilos del icono de borrar sugerencias*/
    position: absolute;
    width: 25px;
    height: 25px;
    right: 8px;
    left: auto;
    pointer-events: auto;
    display: none;
    padding: 4px;
    transform: rotate(45deg);
}
.btnDelStringShow{ /*mostrar el boton para las sugerencias*/
    display: block;
}
.btnDelString:hover{ /*cuando el mouse pase encima del boton de borrar*/
    border-radius: 1000px !important;
    box-shadow: 0 0 4px 1px #000;
}

@media screen  and (min-width: 850px){
    .FrontContent__formSearch{ /*contenedor de los inputs y boton de invertir*/
        flex-direction: row;
    }
    .btnDelString{ /*estilos del icono de borrar sugerencias*/
        cursor: pointer;
    }
    .FrontContent__form__input{ /*inputs*/
        padding: 30px 30px 12px 45px !important;
    }
    .FrontContent__formInput__p{ /*texto de arriba*/
        top: 15px !important;
        left: 47px;
    }
}
/*fin de los estilos de los buscadores*/


/*estilos de las sugerencias*/
.sugerencias__content{ /*contenedor de las sugerencias*/
    position: absolute;
    top: 115%;
    left: 0;
    width: 100%;
    max-height: 340px;
    display: flex;
    flex-direction: column;
    background-color: #fff;
    box-shadow: 0px 12px 18px -6px #0000004d;
    border: 2px solid var(--colorMain);
    overflow: auto;
    border-radius: 8px;
    /* border-bottom-left-radius: 8px; */
    /* border-bottom-right-radius: 8px; */
    z-index: 4;
    opacity: 0;
    visibility: hidden;
    transition-duration: .2s;
}
.sugerencias__contentShow{ /*mstrar las sugerencias*/
    opacity: 1;
    visibility: visible;
    transition-duration: .2s;
}
/*estilos del scroll*/
    .sugerencias__content::-webkit-scrollbar{
        width: 10px;
        cursor: pointer;
    }
    .sugerencias__content::-webkit-scrollbar-thumb{
        background-color: var(--colorTransparente);
    }
/*fin de los estilos del scroll*/


/*sugerencias reenderizadas*/
.optionsSugerencias{ /*contenedor de cada sugerencia*/
    display: flex;
    align-items: center;
    padding: 15px;
    gap: 8px;
}
.optionsSugerencias:hover{ /*cuando el mouse pase en sima de cada sugerencia*/
    background-color: var(--colorMain);
    color: #fff;
}
.optionsSugerenciasImg{ /*imagen de las sugerencias*/
    width: 25px;
    height: 25px;
}
.optionsSugerenciasParrafo{ /*estilos del texto de cada sugerencia*/
    white-space: pre-wrap;
    line-height: normal;
}

.optionsSugerenciasErr{ /*cuando no se encontro resultados*/
    pointer-events: none;
    padding: 15px !important;
    display: flex;
    gap: 15px;
    align-items: center;
}

.optionsSugerenciasErrParrafo{ /*texto de advertencia*/
    color: #f00;
}

.optionsSugerenciasErrImg{ /*imagen de error*/
    width: 25px;
    height: 25px;
}

@media screen and (min-width: 850px) and (max-width: 1200px){
    .sugerencias__content{ /*contenedor de las sugerencias*/
        top: 110%;
    }
    .optionsSugerencias{ /*contenedor de cada sugerencia*/
        cursor: pointer;
    }
}

@media screen and (min-width: 1200px){
    .sugerencias__content{ /*contenedor de las sugerencias*/
        width: 300px;
        top: 110%;
    }
    .optionsSugerencias{ /*contenedor de cada sugerencia*/
        cursor: pointer;
    }
}

/*fin de los estilos de las sugerencias*/


/*estilos del boton para invertir*/
.FrontContent__formSearchInvert{ /*contenedor del boton para invertir*/
    position: absolute;
    right: 35px;
    width: 38px;
    height: 38px;
    z-index: 2;
    border-radius: 1000px;
    background-color: #ffffff;
    border: .2px solid #000;
    outline: none;
    display: flex;
    align-items: center;
    justify-content: center;
}
.FrontContent__formSearchInvert:hover{ /*cuando el mouse pase en sima del boton de invertir*/
    outline: 2px solid var(--colorMain);
}
.FrontContent__formInputInvertImg{ /*icono de invertir texto*/
    width: 35%;
    height: 35%;
    transition-duration: .2s;
    user-select: none;
    outline:  none;
    user-select: none;
}
.FrontContent__formInputInvertImgAnimation{ /*estilos para girar el boton de invertir*/
    transform: rotate(180deg);
    transition-duration: .3s;
}

@media (min-width: 850px){
    .FrontContent__formSearchInvert{ /*contenedor del boton para invertir*/
        right: auto;
        width: 30px;
        height: 30px;
    }
    .FrontContent__formInputInvertImg{ /*icono de invertir texto*/
        transform: rotate(90deg);
        cursor: pointer;
    }
    .FrontContent__formInputInvertImgAnimation{ /*estilos para girar el boton de invertir*/
        transform: rotate(270deg);
    }
}
/*fin de los estilos del boton para invertir*/



/*estilos de la recoleccion de fechas*/
.FrontContent__formdate{ /*contenedor de los campos de fechas y ventana de calendario*/
    display: flex;
    flex-direction: row;
    position: relative;
    gap: 4px;
}
.FrontContent__formdateContent{ /*contenedor de la imagen input y texto indicativo*/
    width: 50%;
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 35px;
    background-color: #fff;
    border-radius: 8px !important;
}
.FrontContent__formdateContent__p{ /*texto indicativo*/
    font-size: 1em;
    line-height: 1;
    background-color: transparent;
    position: absolute;
    top: 8px;
    left: 45px;
    z-index: 2;
    pointer-events: none;
}
.FrontContent__formdateContent__icon{ /*iconos de los calendarios*/
    width: 20px;
    height: 20px;
    transform: scale(1.3);
    position: absolute;
    left: 15px;
    z-index: 2;
    pointer-events: none;
}
.FrontContent__form__inputDate{ /*inputs de fechas*/
    outline: none;
    position: relative;
    margin: 0;
    width: 100% !important;
    height: 100% !important;
    border: var(--borderInput);
    color: var(--colorTexto);
    background-color: #fff !important;
    border-radius: 8px !important;
    padding: 20px 0 5px 43px !important;
    font-size: var(--inputTamano);
    outline: none !important;
    border: none !important;
    box-shadow: 0px 0px 0px .2px var(--inputBorder) !important;
}

.indicadorFecha{ /*flecha indicadora en los campos de fecha*/
    position: absolute;
    top: 92%;
    left: auto;
    right: auto;
    z-index: 156449;
    width: 50%;
    height: 25px !important;
    opacity: 0;
    transition-duration: .2s;
}
.indicadorFechaShow{ /*mostrar el indicador de las fehcas*/
    opacity: 1;
    transition-duration: .2s;
}

@media screen and (min-width: 850px) {
    .FrontContent__formdate{ /*contenedor de los campos de fechas y ventana de calendario*/
        gap: 5px;
    }
    .FrontContent__form__inputDate{ /*inputs de fechas*/
        padding: 30px 0 12px 45px !important;
        width: 140px !important;
        
    }
    .FrontContent__formdateContent__p{ /*texto indicativo*/
        top: 15px !important;
        left: 47px;
    }
}

/*fin de los estilos de la recoleccion de fechas*/

/*estilos de la flecha indicadora de los calendario*/

.FrontContent__formdate_Calendar__trianguloContent {
    position: absolute;
    width: 0;
    height: 0;
    border-left: 14px solid transparent;  /* ancho */
    border-right: 14px solid transparent; /* ancho */
    border-bottom: 8px solid var(--colorMain); /* altura baja */
    top: -9px;
    left: 10%;
}

.FrontContent__formdate_Calendar__triangulo {
    position: absolute;
    width: 0;
    height: 0;
    border-left: 13px solid transparent;
    border-right: 13px solid transparent;
    border-bottom: 8px solid #fff;
    top: -7px;
    left: calc(10% + 1px);
}


.trianguloContentRight{
    left: 55%;
}
.trianguloRight{
    left: calc(55% + 1px);
}


@media (min-width: 850px){
    .FrontContent__formdate_Calendar{ /*contenedor de la ventana calendario*/
        width: 750px;
        top: calc(100% + 12px);
    }
    
    .FrontContent__formdate_Calendar__trianguloContent{
        border-bottom: 9px solid var(--colorMain); /* altura baja */
        left: 4%;        
    }
    .FrontContent__formdate_Calendar__triangulo{
        left: calc(4% + 1px);
    }
    .trianguloContentRight{
        left: 23%;
    }
    .trianguloRight{
        left: calc(23% + 1px);
    }
}

@media (min-width: 1200px){
    .FrontContent__formdate_Calendar{ /*contenedor del calendario*/
        width: 608px !important;
    }

    .FrontContent__formdate_Calendar__trianguloContent{
        border-bottom: 9px solid var(--colorMain); /* altura baja */
        left: 4%;        
    }
    .FrontContent__formdate_Calendar__triangulo{
        left: calc(4% + 1px);
    }
    .trianguloContentRight{
        left: 28%;
    }
    .trianguloRight{
        left: calc(28% + 1px);
    }
}
/*fin de los estilos de la flecha indicadora de los calendario*/


/*estilos de la ventana de calendario*/
.FrontContent__formdate_Calendar{ /*contenedor de la ventana calendario*/
    position: absolute;
    top: calc(100% + 12px);
    background-color: #fff;
    z-index: 50;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    width: 100%;
    box-shadow: 0px 12px 18px -6px #0000004d;
    border: 2px solid var(--colorMain);
    border-radius: 8px;
    gap: 15px;
    opacity: 0;
    visibility: hidden;
    transition-duration: .2s;
    padding-bottom: 15px;
}
.FrontContent__formdate_CalendarShow{ /*mostrar input*/
    opacity: 1;
    visibility: visible;
    transition-duration: .2s;
}

@media (min-width: 850px){
    .FrontContent__formdate_Calendar{ /*contenedor de la ventana calendario*/
        width: 750px;
        
    }
}

/*fin de los estilos de la ventana de calendario*/



/*estilos de las fechas flexibles*/
.custom-checkbox input[type="checkbox"] { /* Oculta el checkbox original */
    position: absolute;
    opacity: 0;
}
.custom-checkbox{ /*contenedor del input y el texto*/
    position: absolute;
    left: 8px;
    top: 20px;
    display: flex;
    align-items: center;
    user-select: none;
    font-size: 1.2em;
}
.checkmark{ /*checkout personalizado*/
    width: 20px;
    height: 20px;
    padding: 10px;
    border: 2px solid #ccc; /* Borde del checkbox */
    border-radius: 4px; /* Redondeo de esquinas */
    margin-right: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background-color 0.2s, border-color 0.2s;
}
.checkmark::after { /**poner icono de fecha flexible marcada*/
    content: "";
    width: 8px;
    height: 14px;
    border: solid #fff; /* Color de la aspa */
    border-width: 0 3px 3px 0;
    transform: rotate(45deg);
    display: none;
}
/* Cambios cuando el checkbox está marcado */
.custom-checkbox input[type="checkbox"]:checked ~ .checkmark {
    background-color: var(--colorMain); /* Fondo al marcar */
    border-color: var(--colorMain); /* Borde al marcar */
}
.custom-checkbox input[type="checkbox"]:checked ~ .checkmark::after {
    display: block;
}
/*fin de los cambios cuando checkbox esta marcado*/
@media(min-width: 850px){
    .custom-checkbox input[type="checkbox"] { /* Oculta el checkbox original */
        cursor: pointer;
    }
    .custom-checkbox{ /*contenedor del input y el texto*/
        cursor: pointer;
    }
}
/*fin de los estilos de las fechas flexibles*/


/*estilos de los botones de navegacion del calendario*/
.ContentPrevNext{ /*contenedor de los dos botones*/
    position: absolute;
    width: 100%;
    height: 400px;
    top: 0;
    pointer-events: none;
    display: flex;
    justify-content: end;
    gap: 35px;
    padding-top: 52px;
    padding-right: 20px;
}
#prevPeriod{ /*boton de anterior*/
    padding: 0;
    border: none !important;
    outline: none;
    background-color: transparent;
    width: 25px;
    height: 25px;
    transform: rotate(180deg);
    pointer-events: auto;
    display: none;
}
.prevPeriodShow{
    display: block !important;
}

#nextPeriod{ /*boton de siguiente*/
    padding: 0;
    border: none !important;
    outline: none;
    background-color: transparent;
    width: 25px;
    height: 25px;
    pointer-events: auto;
    display: block;
}
.nextPeriodHide{
    display: none !important;
}

@media (min-width: 850px){
    #prevPeriod{ /*boton de anterior*/
        cursor: pointer;
    }
    #nextPeriod{ /*boton de siguiente*/
        cursor: pointer;
    }
}
/*fin d elos estilos de los botones de navegacion del calendario*/


/*estilos del calendario reenderizado*/
#calendarContainer { /*contenedor de las fechas*/
    display: flex;
    gap: 15px;
    flex-direction: column;
}

.month { /*contenedor de cada mes*/
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    margin-top: 31px;
}
.month h3{ /*titulo del mes*/
    margin-top: 25px;
    margin-right: 35px;
    font-size: 1.3em;
    position: relative;
    margin-bottom: 0;
    color: #000;
    font-family: var(--fuente);
    font-weight: normal;
}


.calendar { /*contenedor de las fechas*/
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    height: 250px;
    margin-top: 0;
    color: var(--colorTexto);
}

.calendar-day-name, .calendar-day { /*contenedor de cada numero de los dias*/
    padding: 4px;
    text-align: center;
}

.empty { /*ocultar los dias en blanco*/
    visibility: hidden;
}


.disabled { /*dias bloqueados*/
    color: var(--colorTexto);
    opacity: 0.4;
    cursor: not-allowed;
    display: flex;
    justify-content: center;
    align-items: center;
    margin: 0 !important;
    padding: 0 !important;
    width: 35px;
    height: 35px;
    font-size: 1.1em;
}

.selectable{ /*dias permitidos para seleccioar*/
    width: 35px;
    height: 35px;
    margin: 4px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.1em;
    margin: 0 !important;
    padding: 0 !important;
}
.selectable:hover { /*cuando el mouse pase en sima de cada dia seleccionanle*/
    cursor: pointer;
    background-color: var(--colorMain);
    border-radius: 4px;
    color: var(--colorMainText);
}
.selectableSelected{
    background-color: var(--colorMain);
    border-radius: 4px;
    color: var(--colorMainText) !important;
}
.rangeHighlight {
    background-color: var(--colorTransparente);  /* Fondo azul opaco para el rango */
}
.rangeHighlight:hover {
    background-color: var(--colorTransparente);  /* Fondo azul opaco para el rango */
    color: var(--colorTexto);
}

@media (min-width: 850px){
    #calendarContainer{
        flex-direction: row;
    }
}
/*fin de los estilos del calendario reenderizado*/


/*estilos del boton para confirmar las fechas*/
.ConfirmDateContent{ /*contenedor del boton para confirmar*/
    width: 100%;
    padding: 15px;
    padding-top: 0;
    padding-bottom: 0;
    display: none;
    justify-content: center;
}
.ConfirmDateContentShow{ /*mostrar el contenedor del boton para confirmar*/
    display: flex;
}
.btnConfirmDate{ /*boton de confirmar datos*/
    display: flex !important;
    justify-content: center;
    align-items: center;
    background-color: var(--colorMain);
    transition-duration: .2s;
    border: none !important;
    padding: 15px;
    border-radius: 8px !important;
    width: 100%;
    color: var(--colorMainText) !important;
    font-size: var(--parrafo);
    font-family: var(--fuente) !important;
    box-shadow: 0px 12px 18px -6px #0000004d;
}
.btnConfirmDate:hover{
    background-color: var(--colorHover) !important;
    transition-duration: .2s;
}
.btnConfirmDate:focus{
    background-color: var(--colorHover) !important;
}
@media(min-width: 850px){
    .btnConfirmDate{ /*boton de confirmar datos*/
        cursor: pointer;
    }
}
/*fin de los estilos del boton para confirmar las fechas*/




/*contenedor de reloj*/
.ContentReloj{
    display: none;
    opacity: .5;
    pointer-events: none;
}
.ContentRelojShow{ /*contenedor del reloj y sus datos*/
    display: flex;
    flex-direction: column;
    justify-content: start;
    align-items: center;
    width: 90%;
    opacity: 1;
    pointer-events: auto;
}
.ContentRelojData{ /*contenedor de los datos*/
    width: 100%;
    display: flex;
    position: relative;
    justify-content: space-between;
    gap: 18px;
    background-color: #fafbfa;
    padding: 15px;
    border-radius: 15px;
    border: var(--colorMain) 4px solid;
}
.ContentRelojData__contentInfo{ /*contenedor de imagen y texto*/
    display: flex;
    align-items: center;
    gap: 10px;
}

.imgReloj{ /*imagen de reloj*/
    width: 35px;
    height: 35px;
}
.ContentReloj__ora{ /*texto de seleccionar ora*/
    font-size: 1em;
    font-family: Arial, Helvetica, sans-serif !important;
    line-height: normal !important;
    display: flex;
    align-items: center;
}
.ContentReloj__ora{
    padding: 0 !important;
    margin: 0 !important;
}


@media(min-width: 850px){
    .ContentRelojData{ /*contenedor de los datos*/
        width: 350px;
    }
}
/*fin de los estilos de reloj*/


/*estilos del boton para desplegar o ocultar rangos de hora.*/
.ContentReloj__btnOpen{ /*boton*/
    background-color: transparent;
    border: none;
    outline: none;
    width: 35px;
    height: 35px;
    padding: 0 !important;
    pointer-events: none;
    transform: rotate(180deg);
}
@media(min-width: 850px){
    .ContentReloj__btnOpen{ /*boton*/
        cursor: pointer;
    }
}
.ContentReloj__btnOpen__img{ /*imagen*/
    width: 100%;
    height: 100%;
    object-fit: cover;
    transform: rotate(0deg);
    transition-duration: .3s;
}
.ContentReloj__btnOpen__imgUp{
    transform: rotate(180deg);
    transition-duration: .3s;
}
/*fin de los estilos para el indicador de desplegar selector de rango de ora.*/


/*estilos del renderizado de rangos de ora*/
.ContentRelojData__rango{ /*contenedor principal*/
    position: absolute;
    outline: 4px solid var(--colorMain);
    bottom: calc(100% + 12px);
    left: 0;
    width: 100%;
    max-height: 250px;
    background-color: #fff;
    border-radius: 8px;
    overflow: auto;
    z-index: 15;
    opacity: 0;
    visibility: hidden;
    transition-duration: .2s;
}
.ContentRelojData__rango::-webkit-scrollbar{
    background-color: #fff;
    width: 10px;
    border-bottom-right-radius: 8px;
    border-top-right-radius: 8px;
}
.ContentRelojData__rango::-webkit-scrollbar-thumb{
    background-color: var(--colorTransparente);
}
.ContentRelojData__rangoShow{ /*mostrar rangos de ora*/
    opacity: 1;
    visibility: visible;
    transition-duration: .2s;
}

.ContentRelojData__rango__div{ /*contenedor del selectable del rango de ora*/
    display: flex;
    gap: 15px;
    align-items: center;
    padding: 8px;
    font-size: 1.2em;
    transition-duration: .2s;
    font-family: Arial, Helvetica, sans-serif;
}
.ContentRelojData__rango__div:hover{ 
    background-color: var(--colorMain);
    color: #fff;
    transition-duration: .2s;
}
.ContentRelojData__rango__div:hover > img{
    filter: invert(1);
}

.ContentRelojData__rango__divSelected{ /*hora seleccionada*/
    background-color: var(--colorMain);
    color: #fff;
}
.ContentRelojData__rango__divHide{
    opacity: .5;
    pointer-events: none;
}
.ContentRelojData__rango__divSelected > img{
    filter: invert(1);
}
.ContentRelojData__rango__img{ /*imagen*/
    width: 25px;
    height: 25px;
}
.ContentRelojData__rango__p{
    margin: 0 !important;
}
@media(min-width: 850px){
    .ContentRelojData__rango__div{ /*contenedor del selectable del rango de ora*/
        cursor: pointer;
    }
}
/*fin de los estilos del rango de ora*/




/*estilos del input de pasajeros*/
.formContent__formPsjContent{ /*contenedor del input e iconos*/
    width: 100%;
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 35px;
    border-radius: 8px;
    transition-duration: .2s;
}
.formContent__formPsjContent:hover{
    outline: 4px solid var(--colorMain) !important;
    transition-duration: .2s;
}

.formContent__formPsjContent--textInd{ /*texto indicador*/
    font-size: 1em;
    line-height: 1 !important;
    background-color: transparent;
    position: absolute;
    top: 8px;
    left: 45px;
    pointer-events: none;
    z-index: 1;
}

.formContent__formPsjContent--iconPsj{ /*icono de pasajeros*/
    width: 20px;
    height: 20px;
    position: absolute;
    top: auto;
    left: 15px;
    pointer-events: none;
    z-index: 1;
}
.formContent__formPsjContent--iconInd{ /*icono indicador*/
    position: absolute;
    right: 8px;
    width: 18px;
    height: 18px;
    cursor: pointer;
    pointer-events: auto;
    transition-duration: .1s;
}
.formContent__formPsjContent--input{ /*input*/
    outline: none;
    position: relative;
    margin: 0;
    width: 100% !important;
    height: 100% !important;
    border: none !important;
    padding: 20px 35px 5px 43px !important;
    font-size: var(--inputTamano) !important;
    color: var(--colorTexto) !important;
    border-radius: 8px !important;
    transition-duration: .2s;
    box-shadow: 0px 0px 0px .2px var(--inputBorder) !important;
    background-color: #fff !important;
}

@media(min-width: 850px){
    .formContent__formPsjContent--textInd{
        top: 15px !important;
        left: 47px;
    }
}
/*fin de los estilos del input de pasajeros*/



/*estilos de la ventana de selector de pasajeros*/
.formContent__formPsjContent--contentSelector{
    display: none;
    position: absolute;
    width: 100%;
    top: calc(100% + 15px);
    right: 0;
    flex-direction: column;
    padding: 22px 0 4px 0;
    background-color: #fff;
    box-shadow: 0px 12px 18px -6px #0000004d;
    border: 2px solid var(--colorMain);
    z-index: 2;
    gap: 15px;
    border-radius: 8px;
}
.formContent__formPsjContent--contentSelectorShow{
    display: flex;
}

.formContent__formPsjContent--count{ /*contendor de cada contador, imagen titulo subtitulo y contador*/
    padding: 0 8px 0 8px;
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
}
.formContent__formPsjContent--countIconPsj{ /*icono principal*/
    position: relative;
    left: auto;
    margin-right: 6px;
    width: 30px;
    height: 30px;
}
.formContent__formPsjContent--countTitle{ /*contenedor del titulo y el subtitulo*/
    display: flex;
    flex-direction: column;
    width: 60%;
    font-size: var(--parrafo);
    display: flex;
}
.formContent__formPsjContent--countTitle p{ /*titulo*/
    color: var(--colorTexto);
    font-size: 1em !important;
    line-height: normal;
    padding: 0 !important;
    margin: 0 !important;
}
.formContent__formPsjContent--contentCount{ /*contenedor del contador*/
    display: flex;
    margin-right: 4px;
}
.btnCantidadPsj__icon{ /*icono de sumar y restar*/
    width: 20px !important;
    height: 20px !important;
}
.formContent__formPsjContent--btnDec{ /*boton de restar*/
    width: 50px;
    height: 50px;
    color: var(--colorTexto);
    font-size: 1.5em;
    border: 1px solid #201f1f;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    user-select: none;
    border-top-left-radius: 7px;
    border-bottom-left-radius: 7px;
    position: relative;
}
.formContent__formPsjContent--btnDec:hover{ /*boton de restar*/
    background-color: var(--colorTransparente);
}
.formContent__formPsjContent--btnInc{ /*boton de incrementar*/
    width: 50px;
    height: 50px;
    font-size: 2em;
    border: 1px solid #201f1f;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    user-select: none;
    border-top-right-radius: 7px;
    border-bottom-right-radius: 7px;
    position: relative;
}
.formContent__formPsjContent--btnInc:hover{ /*boton de incrementar*/
    background-color: var(--colorTransparente);
}
.formContent__formPsjContent--cantidad{ /*cantidad*/
    border-top: 1px solid #000;
    border-bottom: 1px solid #000;
    width: 50px;
    height: 50px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.5em;
    user-select: none;
}
.formContent__formPsjContentButton{ /*contenedor del boton de conferma*/
    display: flex;
    justify-content: center;
    padding: 0px 10px 10px 10px;
    width: 100%;
}
.formContent__formPsjContentButton--btn{ /*boton de conferma*/
    background-color: var(--colorMain) !important;
    width: 100%;
    transition-duration: .2s;
    color: var(--colorMainText) !important;
    display: flex;
    align-items: center;
    justify-content: center;
    border: none !important;
    padding: 15px;
    border-radius: 8px !important;
    cursor: pointer;
    font-size: var(--parrafo);
    font-family: var(--fuente) !important;
    box-shadow: 0px 12px 18px -6px #0000004d;
    cursor: pointer;
    transition-duration: .2s;
}
.formContent__formPsjContentButton--btn:hover{
    background-color: var(--colorHover);
    transition-duration: .2s;
}
/*fin de los estilos de la ventana de selector de pasajeros*/





/*estilos del boton para buscar vuelos*/
#btnSendData{ /*boton para hacer la busqueda*/
    background-color: var(--colorMain) !important;
    font-size: 1.4em;
    border-radius: 8px !important;
    display: flex;
    justify-content: center;
    gap: 8px;
    align-items: center;
    padding: 16px 10px 16px 10px;
    border: none !important;
    cursor: pointer;
    width: 100%;
    font-family: var(--fuente) !important;
    box-shadow: 0px 12px 18px -6px #0000004d;
}
#btnSendData:hover{
    box-shadow: 0 0 8px 1px #000;
}
.btnSendData--cerca{ /*texto del boton cerca*/
    color: var(--colorMainText) !important;
    margin: 0;
}
.btnSendData--img{ /*imagen de la lupa de boton para buscar vuelos*/
    width: 35px;
    height: 35px;
}

@media screen and (min-width: 850px) and (max-width: 1200px){
    #btnSendData{ /*boton para hacer la busqueda*/
        width: 140px;
    }
    .btnSendData--img{ /*imagen de la lupa de boton para buscar vuelos*/
        width: 20px;
        height: 20px;
    }
}

@media screen and (min-width: 1200px){
    #btnSendData{ /*boton para hacer la busqueda*/
        width: 140px;
    }
    .btnSendData--img{ /*imagen de la lupa de boton para buscar vuelos*/
        width: 20px;
        height: 20px;
    }
}
/*fin de los estilos del boton para buscar vuelos*/


/*estilos de la ventana loader*/
.FrontContent__load{ /*contenedor de la ventana loader*/
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    background-color: #4941418e;
    border-radius: 8px !important;
    backdrop-filter: blur(4px);
    z-index: 158;
    display: flex;
    justify-content: center;
    align-items: center;
    opacity: 0;
    visibility: hidden;
    transition-duration: .3s;
    overflow: hidden;
}
.FrontContent__loadHide{ /*ocultar la ventana loader*/
    opacity: 0;
    visibility: hidden;
    transition-duration: .3s;
}
.FrontContent__load--imgContent{ /*contenedor de la imagen de loader*/
    /* width: 150px; */
    /* height: 150px; */
    border-radius: 1000px;
    pointer-events: none;
    display: flex;
}

.FrontContent__load--img{ /*imagen*/
    width: 150px;
    height: 150px;
    margin: 0;
    object-fit: cover;
    animation-name: trainLoadingAnimationWp;
    animation-duration: 2s;
    animation-iteration-count: infinite;
    filter: invert(.2);
}
.FrontContent__load--imgContentRoad{
    width: 100%;
    height: 4px;
    top: calc(50% + 15px);
    left: 0;
    background-color: #474141;
    position: absolute;
}
@media screen and (min-width: 850px) and (max-width: 1200px){
    .FrontContent__load--imgContent{ /*contenedor de la imagen de loader*/
        width: 105px;
        height: 105px;
    }
    .FrontContent__load--img{ /*imagen*/
        width: 105px;
        height: 105px;
    }
    .FrontContent__load--imgContentRoad{
        top: calc(50% + 10px);
    }
}
@media screen and (min-width: 1200px) {
    .FrontContent__load--imgContent{ /*contenedor de la imagen de loader*/
        width: 150px;
        height: 150px;
    }
    .FrontContent__load--img{ /*imagen*/
        width: 100%;
        height: 100%;
        object-fit: cover;
    }
}

@keyframes trainLoadingAnimationWp{
    0%{
        transform: translate(-40vw,0);
    }
    100%{
        transform: translate(60vw,0);
    }
}
/*fin de los estilos de la ventana loader*/


/*estilos de oscurecer pantalla para resaltar*/
.mensajesGenerales{ /*contenedor de los mensajes generales*/
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: #00000095;
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 1.4em;
    opacity: 0;
    visibility: hidden;
    transition-duration: .3s;
    z-index: 2;
}
.mensajesGeneralesShow{ /*mostrar el contenedor de los generales*/
    opacity: 1;
    visibility: visible;
    transition-duration: .3s;
}

.inputForm{ /*quitar resaltado de input inputs*/
    z-index: auto;
    padding: 2px;
    background-color: transparent !important;
}
.inputForm:hover{
    outline: 2px solid var(--colorMain) !important;
}

/*fin de los estilos de oscurecer pantalla para resaltar*/


/*estilos del mensaje indicativo en el resaltado*/
.mensajesGenerales__content{ /*contenedor principal del mensaje para el resaltado*/
    position: fixed;
    pointer-events: none;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: transparent;
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 1.4em;
    opacity: 0;
    visibility: hidden;
    transition-duration: .3s;
}
.mensajesGenerales__contentShow{ /*mostrar contenedor principal del mensaje para el resaltado*/
    opacity: 1;
    visibility: visible;
    transition-duration: .3s;
    z-index: 85;
}

.mensajesGenerales__msg{ /*contenedor del mensaje */
    position: absolute;
    z-index: 2;
    background-color: #000000a4;
    backdrop-filter: blur(4px);
    max-width: 92% !important;
    min-width: 90% !important;
    /* min-height: 90px; */
    border-radius: 8px !important;
    padding: 15px;
    display: flex;
    justify-content: center;
    align-items: center;
}
.mensajesGenerales__info{ /*contenedor del mensaje de informacion*/
    display: flex;
    align-items: center;
    gap: 15px;
}
.mensajesGenerales__info--img{ /*imagen del texto informativo de errores*/
    width: 25px;
    height: 25px;
}
.mensajesGenerales__text{ /*mensaje indicativo*/
    color: #fff;
    font-size: .8em;
    text-align: center;
}

@media(min-width: 850px){
    .mensajesGenerales__msg{ /*contenedor del mensaje */
        width: auto;
        max-width: auto !important;
        min-width: auto !important;
        padding: 15px;
        top: auto;
    }
}
/*fin de los estilos del mensaje indicativo en el resaltado*/





/*contenedores*/
.FrontContent__form{ /*contenedor del checkbox y contenedor del formulario*/
    display: flex;
    flex-direction: column;
    gap: 20px;
    font-family: Arial, Helvetica, sans-serif;
    position: relative;
}
.FrontContent__formInputsContent{/*contenedor de los inputs excepto los check*/
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 15px;
    width: 100%;
    position: relative;
}
.FrontContent__formInputsContentHide{ /*ocultar contenedor de los inputs excepto los checl*/
    display: none;
}

.FrontContent__formLast{ /*contenedor de los calendarios y pasajeros y boton cerca*/
    display: flex;
    flex-direction: column;
    gap: 15px;
    width: 100%;
}

@media screen and (min-width: 850px) and (max-width: 1200px){
    .FrontContent__formLast{ /*contenedor de los calendarios y pasajeros y boton cerca*/
        flex-direction: row;
        gap: 5px;
    }
}

@media screen and (min-width: 1200px){
    .FrontContent__formInputsContent{/*contenedor de los inputs exceptos los check*/
        flex-direction: row;
        gap: 5px;
    }
    .FrontContent__formLast{ /*contenedor de los calendarios y pasajeros y boton cerca*/
        flex-direction: row;
        gap: 5px;
    }
}
/*fin de contenedores*/



/*estilos de los indicadores de las ventanas emergentes*/
.indicadorGeneralInput{ /*icono*/
    position: absolute;
    width: 85px;
    height: 24px !important;
    top: 90%;
    display: none;
    z-index: 100;
    transform: rotate(180deg);
}
.indicadorGeneralInputShow{ /*mostrar el indicador de las ventanas emergentes*/
    display: none;
}
/*fin de los estilos de los indicadores de las ventanas emergentes*/




/*estilos generales*/

    /*contadores en pasajeros*/
        .NullEventCantidad{ /*cuando los contadores se anulan*/
            cursor: not-allowed !important;
            opacity: .3;
        }
    /*fin de los contadores en pasajeros*/

    /*animacion de flechitas indicadoras de pasajeros*/
        .indicadorPjsGeneralHide{ /*animacion para poner como era antes*/
            transform: rotate(180deg) translate(0,0);
            transition-duration: .1s;
        }
        .indicadorPjsGeneralHideUp{ /*girar arriba*/
            transform: translate(0px,-18px) rotate(180deg);
            opacity: 0;
            transition-duration: .5s;
        }
    /*fin de las animacion de flechitas indicadoras de pasajeros*/

    /* estilos para marcar a un input */
        .marcarInput{
            outline: 2px solid var(--colorMain) !important;
            box-shadow: 0 0 4px .5px #000;
        }
    /* fin de los estilos para marcar a un input */


/*fin de los estilos generales*/