/* ----------------------------------------------------------
   ----------------------------------------------------------

        CSS proceso reservas

   ---------------------------------------------------------
   ---------------------------------------------------------- */

/* ------------------------------- open: LLAMADA TIPOS (sólo si es necesario dependiendo de dónde se integre el sistema) ------------------------------------------ */

@import url('https://fonts.googleapis.com/css?family=Roboto:100,300,400,500,700,900');

/* ------------------------------- close: LLAMADA TIPOS ------------------------------------------ */

/* ------------------------------- open: VARIABLES ------------------------------------------ */

:root {
    --white: #fff;
    /* color white */
    --white-rgb: 255, 255, 255;
    /* color white */
    --neutral-10: #dddddd;
    /* color neutral 10 */
    --neutral-20: #C0BFBD;
    /* color neutral 20 */
    --neutral-40: #999999;
    /* color neutral 40 */
    --neutral-60: #666666;
    /* color neutral 60 */
    --neutral-80: #333333;
    /* color neutral 80 */
    --black: #010101;
    /* color black Rippa */
    --black-rgb: 22, 22, 22;
    /* color black RGB Rippa Dorii */

    --bg: #F4F5F5;
    /* color fondo página */
    --bg-rgb: 233, 237, 238;
    /* color fondo RGB */

    --main: #0B0908;
    /* color principal */
    --main-rgb: 11,9, 8;
    /* color principal RGB */

    --secondary: #A9525B;
    /* color secundario/ hover */

    --error: #e04747;
    /* color errores en formulario */
    --ayuda: #76a74f;
    /* color ayuda solicitada en formulario */

    --typo-primary: "Noe Display" , 'Times New Roman', Times, serif;
    /* tipografía del site */
    --typo-secondary:  'Roboto',Helvetica,Arial,Lucida,sans-serif;
    /* tipografía para detalles */

    --transition: all 0.3s ease-in-out;
    /* transición corta de elementos tipo button, enlaces, velos etc */
    --transition-1: all 0.7s ease-in-out;
    /* transición larga de elementos tipo button, enlaces, velos etc */

    --shadow-shoft: 0px 8px 16px 0px rgba(var(--black-rgb), 0.05);
}

/* ------------------------------- close: VARIABLES ------------------------------------------ */

/* ------------------------------- open: GENERAL ------------------------------------------ */

body {
    font-family: var(--typo-secondary) !important;
    color: var(--black) !important;
    font-size: 14px;
}

h1,
h2,
h3,
h4,
h5,
h6 {
    font-family: var(--typo-primary) !important;
}


p {
    font-weight: 400;
    font-size: 14px;
    line-height: 21px;
    color: var(--neutral-60);
    margin: 0 0 8px 0;
}

a,
a:hover {
    text-decoration: none;
    -webkit-transition: var(--transition);
    -moz-transition: var(--transition);
    -o-transition: var(--transition);
    transition: var(--transition);
}

#main-header {
    background: none;
}


.et_pb_text_0 {
    font-family: var(--typo-secondary) !important;
}


#section-visitas.home-visitas{
    display: inline-block;
    width: 100%;
    min-height: calc(100vh - 112px);
    margin: 24px 0 0 0;
    padding: 0 0 0 0;
} 

#section-visitas.enoexperiencia-detalle{
    display: inline-block;
    width: 100%;
    /*min-height: calc(80vh - 112px);*/
    margin: 24px 0 0 0;
    padding: 0 0 0 0;
} 










/* inputs general */
*::-webkit-input-placeholder {
    /* Google Chrome y Safari */
    color: var(--neutral-20) !important;
    font-weight: 400;
    opacity: 1;
    letter-spacing: 0.03em;
}

*:-moz-placeholder {
    /* Firefox anterior a 19 */
    color: var(--neutral-20) !important;
    font-weight: 400;
    opacity: 1;
    letter-spacing: 0.03em;
}

*::-moz-placeholder {
    /* Firefox 19 y superior */
    color: var(--neutral-20) !important;
    font-weight: 400;
    opacity: 1;
    letter-spacing: 0.03em;
}

*:-ms-input-placeholder {
    /* Internet Explorer 10 y superior */
    color: var(--neutral-20) !important;
    font-weight: 400;
    opacity: 1;
    letter-spacing: 0.03em;
}

#section-visitas input.form-control,
#section-visitas textarea.form-control{
    padding: 0 10px !important;
    height: 45px;
    line-height: 35px;
    letter-spacing: 0.03em;
    color: var(--neutral-60);
    -webkit-appearance: none;
    background-color: var(--white);
    width: 100%;
    font-size: 14px;
    transition: var(--transition);
    border-radius: 0;
    border: 1px solid var(--neutral-20);
}

#section-visitas input.form-control:hover,
#section-visitas select:hover {
    border: 1px solid var(--neutral-40);
}

#section-visitas input.form-control:focus,
#section-visitas select:focus {
    color: var(--main);
    background-color: var(--bg);
    border: 1px solid var(--black);
    box-shadow: none;
}

#section-visitas select {
    padding: 0 10px !important;
    height: 45px;
    line-height: 35px;
    letter-spacing: 0.03em;
    color: var(--neutral-60);
    background-color: var(--white);
    width: 100%;
    font-size: 14px;
    transition: var(--transition);
    border-radius: 0;
    border: 1px solid var(--neutral-20);
}

#section-visitas select:hover {
    border: 1px solid var(--neutral-40);
}

#section-visitas select:focus {
    color: var(--main);
    background-color: var(--bg);
    border: 1px solid var(--black);
}





.caracteres_textarea {
    float: right;
    font-size: 12px;
    padding: 5px 5px 0;
    letter-spacing: 1px;
    color: var(--neutral-40);
    font-weight: 400;
}

/* fin inputs general */

/* botones */
.btn-solid-main {
    padding: 0 15px;
    letter-spacing: 2px !important;
    font-weight: 500;
    font-size: 12px;
    text-transform: uppercase;
    background: none;
    border: none;
    border-radius: 0;
    color: var(--black);
    border:1px solid var(--black);
    display: block;
    width: 100%;
    height: 50px;
    line-height: 50px;
    transition: var(--transition);
}

.btn-solid-main:hover {
    background-color: var(--secondary);
border-color: var(--secondary);
color: var(--white) !important;
}

.btn-solid-neutral {
    padding: 0 15px;
    letter-spacing: 2px !important;
    font-weight: 500;
    font-size: 12px;
    text-transform: uppercase;
    background: none;
    border: none;
    border-radius: 0;
    color: var(--neutral-20);
    display: block;
    width: 100%;
    height: 50px;
    line-height: 50px;
    transition: var(--transition);
}

.btn-solid-neutral:hover {
    background:none;
    color: var(--secondary);
}

/* fin botones */

/* loader */
.loader {
    background: rgba(var(--white-rgb), 0.8);
    position: fixed;
    z-index: 1000;
    top: 0;
    left: 0;
    height: 100%;
    width: 100%;
    backdrop-filter: blur(5px);
}

.loader .cont-loader {
    display: flex;
    height: 100%;
    align-items: center;
}

/* fin loader */

/* breadcrumb visitas */

#breadcrumb.row-visitas {
    padding: 15px 0 15px 0;
    float: left;
    width: 100%;
}

/* ···················································································· 1024px*/
@media only screen and (max-width: 1024px) {

    #breadcrumb.row-visitas {
        margin-left: -5px;
    }
}

/* ···················································································· 767px*/
@media only screen and (max-width: 767px) {

    #breadcrumb.row-visitas {
        margin-left: 0;
    }
}

/* fin breadcrumb visitas */

/* header */
@media only screen and (max-width: 810px) {
    .et_header_style_centered header#main-header .logo_container {
        max-width: 100%;
        text-align: center;
        height: 120px;
        max-height: 120px;
        margin-bottom: -10px;
    }

    .et_header_style_centered header#main-header .logo_container img {
        height: 60%;
        padding: 0;
        max-height: 60%;
    }

    #et-top-navigation {
        display: none;
    }
}

/* fin header */

/* footer */
.footer-col-info strong {
    text-transform: uppercase;
    font-weight: 600;
}

.footer-col-menu #menu-footer-es {
    display: block;
}

.footer-col-menu .et_pb_menu__menu {
    display: inherit;
}

.footer-col-menu .et_mobile_nav_menu {
    display: none;
}

.footer-col-menu #menu-footer-es li {
    padding: 0;
    text-align: center;
    display: block;
}

.footer-col-menu #menu-footer-es li a,
.footer-col-menu #menu-footer-es li a:hover {
    background: none;
}

/* fin footer */

/* steps pasos procesos */

.steps {
    display: flex;
    gap: 4px;
    justify-content: flex-end;
    margin: 0 0 0  0;
    padding: 8px 16px;
    text-transform: uppercase;
    background: #ededed;
    font-size: 12px;
    color: #939393;
}

.steps div {
    width: 9px;
    height: 9px;
    background: none;
    border-radius: 10px;
    border: 1px solid var(--main);
}

.steps .color-step {
    background-color: var(--main);
}

@media only screen and (max-width: 767px) {
    .steps div {
        height: 7px;
        width: 7px;
    }
}

/* fin steps pasos procesos */

/* menseje error y success */
.msg_error,
label.error {
    padding: 0 0 0 20px;
    margin: 16px 0;
    color: var(--error);
    font-weight: 500;
    font-size: 12px;
    background-image: url(/wp-content/plugins/visitas/modules/visitas/reservas/images/error.svg);
    background-size: 14px;
    background-repeat: no-repeat;
    background-position: top 1px left;
    float: left;
    width: 100%;
}

.success {
    padding: 0 0 0 18px;
    margin: 10px 0 0px;
    color: #22b472;
    font-weight: 500;
    font-size: 12px;
    background-image: url(/wp-content/plugins/visitas/modules/visitas/reservas/images/check.svg);
    background-size: 12px;
    background-repeat: no-repeat;
    background-position: top 4px left;
    float: left;
    width: 100%;
}

/* fin menseje error */

/* ------------------------------- close: GENERALES ------------------------------------------ */


/*  ----------------------------------------------------------------------------------------------------------------------------
    ----------------------------------------------------------------------------------------------------------------------------
        OPEN: Selección de servicios
    ----------------------------------------------------------------------------------------------------------------------------
    ----------------------------------------------------------------------------------------------------------------------------  */

/* filtro fecha cuando vienes */
.contenedor_filtros_visitas {
    text-align: center;
}

.contenedor_filtros_visitas h1 {
    margin: 0 0 20px;
    padding: 0;
    font-weight: 200;
    font-size: 42px;
    line-height: 42px;
    text-transform: uppercase;
    text-align: center;
    color: var(--main);
    letter-spacing: 0.03em;
}

#section-visitas .contenedor_filtros_visitas input::-webkit-input-placeholder {
    /* Google Chrome y Safari */
    color: var(--neutral-40) !important;
    font-size: 16px;
}

#section-visitas .contenedor_filtros_visitas input:-moz-placeholder {
    /* Firefox anterior a 19 */
    color: var(--neutral-40) !important;
    font-size: 16px;
}

#section-visitas .contenedor_filtros_visitas input::-moz-placeholder {
    /* Firefox 19 y superior */
    color: var(--neutral-40) !important;
    font-size: 16px;
}

#section-visitas .contenedor_filtros_visitas input:-ms-input-placeholder {
    /* Internet Explorer 10 y superior */
    color: var(--neutral-40) !important;
    font-size: 16px;
}

#section-visitas .contenedor_filtros_visitas input {
    max-width: 350px;
    margin: 0 auto;
    text-align: center;
    font-size: 24px;
    letter-spacing: 2px;
    height: auto;
    text-transform: uppercase;
    line-height: 150%;
    background-color: rgba(var(--white-rgb), 0);
    color: var(--neutral-60);
    padding: 7px 15px 5px !important;

    border: 1px solid var(--neutral-20);
    transition: var(--transition);
    cursor: pointer;
}

#section-visitas .contenedor_filtros_visitas input:hover {
    border: 1px solid var(--neutral-40);
}

#section-visitas .contenedor_filtros_visitas input:focus {
    border: 1px solid var(--black);
    color: var(--neutral-60);
}

/* datepicker cuando vienes */
.datepicker.datepicker-dropdown {
    min-width: 350px;
    border-radius: 10px;
    box-shadow: var(--shadow-shoft);
    border: none;
    margin-top: 40px;
}

.datepicker-dropdown.datepicker-orient-left::before {
    left: 50% !important;
    margin-left: -7px;
    border-bottom-color: var(--white);
}

.datepicker-dropdown.datepicker-orient-left::after {
    left: 50% !important;
    margin-left: -6px;
}

.datepicker-days .table-condensed {
    width: 100%;
}

/* fin datepicker cuando vienes */

@media only screen and (max-width: 767px) {
    .contenedor_filtros_visitas h1 {
        font-weight: 300;
        font-size: 30px;
        line-height: 30px;
    }

    #section-visitas .contenedor_filtros_visitas input {
        max-width: 300px;
        line-height: 100%;
        padding-top: 5px;
    }

    .datepicker.datepicker-dropdown {
        min-width: 300px;
        border-radius: 10px;
        box-shadow: var(--shadow-shoft);
        border: none;
    }
}

/* fin filtro fecha cuando vienes */

#servicios_posibles {
    display: inline-block;
    width: 100%;
    margin: 0 0 0 0;
    text-align: center;
}

/* grid cards visita masonry listado */
.grid-layout {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(350px, 1fr));
    grid-gap: 16px;
    grid-auto-rows: minmax(350px, auto);
    grid-auto-flow: dense;
    padding: 1px;
    position: relative;
}

.grid-item {
    padding: 16px;
    background-color: var(--bg);
    position: relative;
    transition: var(--transition);
}

.grid-item:hover {
    transform: scale(0.99);
}

/* imagen card visita */
.imagen-visita {
    display: inline-block;
    width: 100%;
    height: 170px;
    position: relative;
    overflow: hidden;
    margin-bottom: 10px;
}

.imagen-visita img {
    display: inline-block;
    width: 100% !important;
    height: 100% !important;
    object-fit: cover;
    object-position: center;
    -webkit-transition: var(--transition);
    -moz-transition: var(--transition);
    -o-transition: var(--transition);
    transition: var(--transition);
}

.grid-item:hover .imagen-visita img {
    -webkit-transform: scale(1.02);
    -moz-transform: scale(1.02);
    -ms-transform: scale(1.02);
    -o-transform: scale(1.02);
    transform: scale(1.02);
}

.imagen-visita .sombra_img {
    position: absolute;
    width: 100%;
    height: 100%;
    z-index: 1;
    transition: var(--transition);
}

.grid-item:hover .imagen-visita .sombra_img {

    background-color: rgba(var(--main-rgb), .3);
}

/* fin imagen card visita */

/* info del card visita */
.info-visita {
    position: relative;
    
}

/* título y texto resumen card visita */
.text-card-visita {
    padding: 0 15px;
    text-align: left;
    margin-bottom: 20px;
    height: 190px;
    overflow: hidden;
}

.text-card-visita h2 {
    line-height: normal;
    padding: 8px 0;
    margin: 0;
    font-weight: 600;
    font-size: 24px;
    color: var(--black);
    transition: var(--transition);

}

.text-card-visita h3 {
    margin: 0;
    padding: 0;
    font-weight: 400;
    font-size: 14px;
    line-height: 18px;
    letter-spacing: 0.23px;
    color: var(--black);
    text-transform: inherit;
    font-family: var(--typo-secondary) !important;
}

/* fin título y texto resumen card visita */

/* fecha card visita */
.fecha-card-visita {
    display: flex;
    padding: 0 15px;
    justify-content: flex-end;
    position: absolute;
    top: -174px;
    left: -5px;
}

.grid-item-destacado .fecha-card-visita {
    top: 10px;
    left: -5px;
    }


.fecha-card-visita .text-fecha {
    padding: 8px 16px !important;
    margin: 0;
    font-family: var(--typo-secondary) !important;
    font-size: 12px;
    color: var(--neutral-80);
    font-weight: 500;
    background: var(--white);
    border-radius: 2px;
}

/* fin fecha card visita */

/* footer card visita */
.footer-card-visita {
    display: flex;
    align-items: center;
    gap: 5px;
}

.footer-card-visita h4 {
    width: 110px;
    height: 50px;
    line-height: 50px;
    margin: 0;
    padding: 0;
    font-family: var(--typo-secondary) !important;
    font-size: 24px;
    font-weight: 350000;
    color: var(--main);
    border: 0px solid rgba(var(--black-rgb), 0.2);
}

.footer-card-visita a.boton_compra {
    font-weight: 500;
    height: 50px;
    line-height: 50px;
    margin: 0;
    padding: 0;
    width: calc(100% - 110px);
    display: block;
    border: none;
    color: var(--main);
    transition: var(--transition);
    text-transform: uppercase;
    font-size: 12px;
    letter-spacing: 1px;
    border: 1px solid var(--main);
}

.grid-item:hover .footer-card-visita a.boton_compra {
    background-color: var(--secondary);
    border-color:var(--secondary);
    color: var(--white);
    font-weight: 500;
}
#boton_reserva:hover{
    color: var(--white) !important; 
}
#boton_contacta:hover{
    color: var(--white) !important; 
}

/* fin footer card visita */

/* fin info del card visita */

/* input para que todo el card visita sea clicable */
.grid-item form input.btn-info-visita {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    border: none;
    cursor: pointer;
    color: transparent;
    background: none !important;
    z-index: 2;
}

/* fin input para que todo el card visita sea clicable */

/* card visita destacado */
@media only screen and (min-width: 768px) {

    /* imagen card visita destacado */
    .grid-item-destacado .imagen-visita {
        height: 100%;
        width: 50%;
        margin: 0;
    }

    /* fin imagen card visita destacado */

    /* info del card visita destacado */

    .grid-item-destacado {
        grid-column-end: span 2;
        grid-row-end: span 1;
        display: flex;
        align-items: center;
        border: 1px solid var(--white);
        padding: 16px;
    }

    .grid-item-destacado:hover {
    
    }

    .grid-item-destacado .info-visita {
        width: 50%;
        padding: 0 0 0 5px;
        height: 100%;
        position: relative;
        display: flex;
        flex-wrap: wrap;
        align-items: center;
    }

    .grid-item-destacado .text-card-visita {
        margin-top: -100px;
        margin-bottom: 0;
        height: auto;
    }

    .grid-item-destacado .info-visita h2 {
        font-size: 24px;
        font-weight: 600;
        line-height: 100%;
        color: var(--black);
    }


    .grid-item-destacado .fecha-card-visita {
        top: 10px;
        left: 10px;
        padding: 0;
    }


    /* fin info del card visita destacado */

    /* footer card visita destacado */
    .grid-item-destacado .footer-card-visita {
        position: absolute;
        bottom: 0;
        width: calc(100% - 5px);
    }

    /* fin footer card visita destacado */
}

@media only screen and (max-width: 810px) {
    .grid-item-destacado {
      
    }
}

/* fin card visita destacado */

/* fin cards visita grid masonry listado */

.servicio_bloque .novedad,
.servicio_bloque .evento,
.enviar_formulario_destacado .novedad,
.enviar_formulario_destacado .evento {
    position: absolute;
    top: 40px;
    right: 40px;
    padding: 5px 15px;
    font-family: var(--typo-primary);
    font-weight: 700;
    text-transform: uppercase;
    font-size: 13px;
    color: var(--white);
    border: 1px solid var(--white);
    line-height: 100%;
    z-index: 1;
}

/* aviso todo vendido en bloque listado */
.aviso-no-plazas {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    border-radius: 10px;
    backdrop-filter: blur(1.5px);
    background-color: rgba(var(--white-rgb), .4);
    box-shadow: var(--shadow-shoft);
    z-index: 1;
}

.aviso-no-plazas .reserva-tramite {
    width: 250px;
    height: 60px;
    position: absolute;
    top: 50%;
    left: 50%;
    margin-top: -30px;
    margin-left: -125px;
    margin-bottom: 0;
    border: 0.5px solid var(--white);
    border-radius: 10px;
    color: var(--white);
    font-size: 30px;
    font-weight: 600;
    line-height: 60px;
    background-color: rgba(var(--main-rgb), .8);
    transform: rotate(-20deg);
    box-shadow: var(--shadow-shoft);
}

/* fin aviso todo vendido en bloque listado */

/* botones gastrobar/gastrotienda */
.gastrotiendas {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 16px;
    margin: 80px 0 0;
    padding: 50px 0;
    border-top: 1px dashed rgba(var(--black-rgb), .15);
    border-bottom: 1px dashed rgba(var(--black-rgb), .15);
}

.gastrotiendas a {
    border: .5px solid var(--neutral-40);
    color: var(--neutral-50);
    padding: 8px 16px;
    border-radius: 8px;
    text-transform: uppercase;
    letter-spacing: 0.03em;
    font-size: 13px;
    font-weight: 400;
    width: 180px;
    text-align: center;
    transition: var(--transition);
    text-decoration: none;
}

.gastrotiendas a:hover {
    border: .5px solid var(--main);
    color: var(--main);
}

@media only screen and (max-width: 767px) {
    .gastrotiendas {
        gap: 0;
        flex-wrap: wrap;
        padding: 30px 0;
    }

    .gastrotiendas a {
        width: 100%;
        margin: 8px 0;
    }
}

/* fin botones gastrobar/gastrotienda */

/* aviso no visitas disponible filtrando por fecha */
.contenedor_tipo_visitas.no_hay_visitas {
    max-width: 600px;
    width: 90%;
    margin: 0 auto;
}

/* fin aviso no visitas disponible filtrando por fecha */

/* ------------------------------------------------------CLOSE: Selección de servicios ------------------------------------------------------ */

/*  ----------------------------------------------------------------------------------------------------------------------------
    ----------------------------------------------------------------------------------------------------------------------------
        OPEN: Paso 1 Selección de Fecha Idioma Número personas
    ----------------------------------------------------------------------------------------------------------------------------
    ----------------------------------------------------------------------------------------------------------------------------  */

#paso_1_all {
    float: left;
}

/* card visita info*/
.card-visita {
    margin: 15px 0;
    padding: 16px;
    position: relative;
    background: var(--bg);
    border-radius: 0;
    box-shadow: none;
    float: left;
    width: 100%;
}

.info_servicio_cabecera {
    display: flex;
    gap:16px;
    margin: 0 0 0 0;
}

.info_servicio_cabecera .imagen-visita-detalle {
    width: 50%;
    border-radius: 0;
    overflow: hidden;
}

.info_servicio_cabecera .imagen-visita-detalle img {
    object-fit: cover;
    height: 100%;
    width: 100%;
}

.info-visita-detalle {
    width: 50%;
    padding: 30px 30px 40px 0;
    min-height: 350px;
}

.info-visita-detalle h1 {
    font-size: 27px;
    color: var(--main);
    letter-spacing: 0.03em;
    line-height: 30px;
    font-weight: 600;
    padding: 8px 0;
    margin: 0;
}

.info-visita-detalle p {
    margin:0;

}

.info-visita-detalle p.nombre-bodega,
.text-card-visita p.nombre-bodega{
    font-size: 12px;
    text-transform: uppercase;
    margin: 0;

}

@media only screen and (max-width: 810px) {
    .info_servicio_cabecera {
        gap: 0;
        flex-wrap: wrap;
        margin-top: 0;
    }

    .info_servicio_cabecera .imagen-visita-detalle {
        width: 100%;
        max-height: 250px;
    }

    .info-visita-detalle {
        width: 100%;
        padding: 0 0 0 0;
        min-height: inherit;
    }

    .info-visita-detalle h1 {
        padding: 8px 0;
    }

    .info-visita-detalle p.nombre-bodega {
        margin-top:16px;
    }
}

@media only screen and (max-width: 767px) {
    .info_servicio_cabecera .imagen-visita-detalle {
        max-height: 200px;
    }

    .info-visita-detalle {
        padding: 0 0 0 0;
    }

    .info-visita-detalle h1 {
        font-size: 21px;
        line-height: 24px;
    }
}

/* fin card visita info*/

/* bloque selección fecha / personas / horarios */
.cuerpo_servicio {
    margin: 16px 0;
    float: left;
    width: 100%;
}

.confirmacion_servicios {
    display: inline-block;
    width: 100%;
    margin: 0 0 0 0;
    padding: 0 0;
}

.title-no-card {
    margin: 0 0 0 0;
    padding: 0 0 0 0;
    font-size: 28px;
    letter-spacing: 0.03em;
    color: var(--black);
    font-weight: 300;
}

@media only screen and (max-width: 1023px) {
    .title-no-card {
        font-size: 22px;
    }
}





/* card filtros */
.Filtros {
    display: flex;
    gap: 30px;
}

.Filtros .card-visita {
    width: calc(100% / 3);
    background: none;
}

.title-card-filtro {
    padding: 0;
    border-radius: 0;
    margin: 0 0 0 0;
    /*color: var(--main);*/
    /*font-size: 18px;*/
    text-align: left;
    /*font-weight: 400;*/

    font-size: 28px;
    letter-spacing: 0.03em;
    color: var(--black);
    font-weight: 300;
}

/* selección fecha */
.confirmacion_servicios #FechaVisita-container {
    border: none;
    padding: 5px 5px 10px;
    float: left;
    width: 100%;
}

/* datepicker */

.content-card-filtro {
    border: none;
    padding: 0 0 0 0;
    float: left;
    width: 100%;
}

.confirmacion_servicios #FechaVisita-container .datepicker table {
    background: none !important;
    border: none !important;
    margin: 0;
}

.confirmacion_servicios .fechaseleccion .datepicker-inline {
    width: 100%;
}

.datepicker table tr th {
    line-height: 40px;
    color: var(--black);
    text-align: center !important;
    border: none !important;
}

.datepicker table tr td {
    border: none !important;
}

.datepicker table tr .datepicker-switch:hover {
    background: none;
}

.datepicker table tr th.prev,
.datepicker table tr th.next,
.datepicker table tr th.datepicker-switch {
    border-left: 0 !important;
    border-right: 0 !important;
    height: 12px;
    padding: 0 5px;
    line-height: 12px;
    color: var(--neutral-20);
    transition: var(--transition);
}

.datepicker table tr th.prev:hover,
.datepicker table tr th.next:hover {
    background: none;
    color: var(--neutral-60);
}

.datepicker table tr th.datepicker-switch {
    font-weight: 500;
    font-size: 12px;
    letter-spacing: 0.03em;
    text-transform: uppercase;
    height: 12px;
    padding: 0 5px;
    color: var(--neutral-80);
}

.datepicker table tr th.datepicker-switch:hover {
    cursor: default;
}

.datepicker table tr th.dow {
    color: var(--neutral-60);
    font-weight: 400;
    padding: 5px;
    text-transform: uppercase;
    font-size: 12px;
    letter-spacing: 0.05em;
}

.datepicker table tr td.day {
    color: var(--neutral-80);
    font-weight: 600;
    transition: var(--transition);
}

.datepicker table tr td.day:hover {
    color: var(--main);
    background: none !important;
}

.datepicker table tr td.disabled,
.datepicker table tr td.disabled:hover {
    color: var(--neutral-40) !important;
    font-weight: 400;
    background: none;
}

.datepicker table tr td.old,
.datepicker table tr td.new,
.datepicker table tr td.old:hover,
.datepicker table tr td.new:hover {
    color: var(--neutral-10) !important;
    font-weight: 400;
    background: none;
}

.datepicker table tr td.day.active,
.datepicker table tr td.day.active:hover {
    background: var(--secondary) !important;
    text-shadow: none;
    color: var(--white) !important;
    border-radius: 0;
}

/* fin datepicker */

/* fin selección fecha */

/* seleccion personas */

.confirmacion_servicios .usuarios_grupos_disponibles .adultos,
#FormCompraEvento .usuarios_grupos_disponibles .adultos {
    margin-top: 25px;
    text-align: left;
}

.confirmacion_servicios .usuarios_grupos_disponibles .adultos:first-child {
    margin-top: 0 !important;
}

.content-card-filtro h4 {
    font-family: var(--typo-secondary) !important;
    text-transform: uppercase;
    font-size: 11px !important;
    font-weight: 500 !important;
    color: var(--neutral-80);
    margin: 0;
    text-align: left;
    padding-bottom: 4px;
    letter-spacing: 0.03em;
}

/* botones + - selección de personas */


.content-card-filtro .input-group.bootstrap-touchspin {
margin-top:10px
} 



.confirmacion_servicios .usuarios_grupos_disponibles .adultos .input-group-btn .btn,
#FormCompraEvento .usuarios_grupos_disponibles .adultos .input-group-btn .btn {
    height: 35px;
    width: 35px;
    border: 0px solid var(--black);
    font-size: 70px;
    font-weight: 100;
    line-height: 21px;
    padding: 0;
    margin: 0;
    color: var(--black);
    border-radius: 40px;
    transition: var(--transition);
    background: none;
    box-shadow: none !important;
}

.confirmacion_servicios .usuarios_grupos_disponibles .adultos .input-group-btn .btn:hover,
#FormCompraEvento .usuarios_grupos_disponibles .adultos .input-group-btn .btn:hover {
    background: none;
}

.confirmacion_servicios .usuarios_grupos_disponibles .adultos .input-group-btn .btn svg {
    fill: var(--neutral-40);
    -webkit-transition: var(--transition);
    -moz-transition: var(--transition);
    -o-transition: var(--transition);
    transition: var(--transition);
}

.confirmacion_servicios .usuarios_grupos_disponibles .adultos .input-group-btn .btn:hover svg {
    fill: var(--secondary);
}

.confirmacion_servicios .usuarios_grupos_disponibles .adultos .input-group-btn .btn svg rect {
    transition: var(--transition);
}

.confirmacion_servicios .usuarios_grupos_disponibles .adultos .input-group-btn .btn:hover svg rect {
    height: 31px;
    width: 2px;
}

.confirmacion_servicios .usuarios_grupos_disponibles .adultos .input-group-btn .btn:hover svg rect:first-child {
    height: 2px;
    width: 31px;
}

/* fin botones + - selección de personas */

/* input cards filtros */
#section-visitas input.input-card {
    background-color: var(--white);
    border: 1px solid var(--neutral-20);
    text-align: center;
    margin: 0 16px;
    width: calc(100% - 102px);
    transition: var(--transition);
    font-weight: 400;
    color: var(--black);
    font-size: 18px;
}

#section-visitas input.input-card:hover {
 
    color: var(--black);
    box-shadow: none;
    border: 1px solid var(--neutral-40);
}

#section-visitas input.input-card:focus {
    color: var(--main);
    background-color: var(--bg);
    border: 1px solid var(--black);
}

/* fin seleccion personas */

/* selección hora */

#ResultadosVisitas {
    margin-top: 10px;
    float: left;
    width: 100%;
}

.info_servicio .radio.inputs-horas {
    margin: 0;
    padding: 0 0 10px;
    float: left;
    width: 100%;
}

.info_servicio .radio.inputs-horas label {
    display: block;
    width: calc(100% / 4 - 8px);
    margin: 4px;
    padding: 7px 5px;
    text-align: center;
    color: var(--black);
    border: 1px solid var(--black);
    border-radius: 0;
    transition: var(--transition);
    float: left;
}

.info_servicio .radio.inputs-horas label:hover {
    background: var(--secondary) !important;
    border: 1px solid var(--secondary);
    color: var(--white) !important;
}

.info_servicio .radio.inputs-horas label.hour-selected,
.info_servicio .radio.inputs-horas label.hour-selected:hover {
    background: var(--secondary) !important;
    border: 1px solid var(--secondary);
    color: var(--white) !important;
}

.info_servicio .radio.inputs-horas label input {
    position: absolute;
    visibility: hidden;
}

.info_servicio .radio.inputs-horas label span {
    display: block;
    font-weight: 600;
    font-size: 12px;
    color: var(--black);
    transition: var(--transition);
    cursor: pointer;
}

.info_servicio .radio.inputs-horas label:hover span {
    color: var(--white);
}

.info_servicio .radio.inputs-horas label.hour-selected span,
.info_servicio .radio.inputs-horas label.hour-selected:hover span {
    color: var(--white);
}

.info_servicio em {
    display: block;
    width: 100%;
    margin: 0 0 20px 0;
    padding: 0 0 0 0;
    text-align: left;
    font-size: 13px;
}

.info_servicio em a {
    color: #111;
}

.info_servicio em a:hover {
    color: var(--black);
}

.resultados-horarios-posibles .personas_minimo {
    margin-bottom: 20px;
    margin-top: 0;
}

.info_servicio .enviar_visita {
    margin-top: 20px;
    float: left;
}

#MensajeContacto {
    display: inline-block;
    margin-top: 25px;
    padding: 10px 5px 0;
    border-top: 0.5px solid var(--neutral-20);
    color: var(--neutral-60);
    font-size: 11px !important;
    font-weight: 400;
    line-height: 16px;
}

#MensajeContacto em a {
    color: var(--secondary);
    font-weight: 500;
}
#MensajeContacto em a:hover {
    color: var(--secondary);
    text-decoration: underline;
}





/* fin selección hora */

/* selección para regalar */ 
.confirmacion_servicios_regalo .Filtros .card-visita {
    width: 100%;
}

.confirmacion_servicios_regalo .Filtros .content-card-filtro {
    padding: 5px 0 15px;
}


.confirmacion_servicios.confirmacion_servicios_regalo .usuarios_grupos_disponibles .adultos {
    width: calc(100%/2 - 32px);
    margin: 16px  !important;
    float: left;
}

/* fin selección para regalar */

@media only screen and (max-width: 810px) {
    .confirmacion_servicios.confirmacion_servicios_regalo .usuarios_grupos_disponibles .adultos {
        width: 100%;
    }




    .Filtros {
        flex-wrap: wrap;
    }

    .Filtros .card-visita {
        width: calc(100% / 2 - 15px);
    }

    .card-visita.resultados-horarios-posibles {
        margin-top: -15px;
        width: 100%;
    }
}

@media only screen and (max-width: 767px) {
    .Filtros {
        gap: 0;
    }

    .Filtros .card-visita {
        width: 100%;
        margin-top: 15px;
    }
}

/* fin card filtros */

/* ------------------------------------------------------ CLOSE: PASO 1: Selección Fecha Idioma Número personas  ------------------------------------------------------ */

/*  ----------------------------------------------------------------------------------------------------------------------------
    ----------------------------------------------------------------------------------------------------------------------------
        OPEN: Paso 2 Resumen Extras Datos Formas de pago
    ----------------------------------------------------------------------------------------------------------------------------
    ----------------------------------------------------------------------------------------------------------------------------  */

#paso_2_all,
#paso_3_all,
#paso_resumen_all {
    float: left;
}

/* resumen visita */
#FormCompraServicio .card-visita{
    width: 100%;
}

.card-visita.botones_completar_reserva {
    background: none;
}





#FormCompraServicio .card-visita.reserva-tramite,
.card-visita.datos-reserva {
    margin-top: 0px;
    margin-bottom: 16px;
}
.datos-servicio-container {
display: flex;
}

.title-visit {
    font-weight: 600;
    font-size: 18px;
    color: var(--neutral-80);
    margin-top: 15px;
}



.date-visit-resume {
    padding-left: 30px;
    margin-left: 30px;
    font-family: var(--typo-secondary) ;
    border-left: 0.5px solid var(--neutral-20);
    font-weight: 300;
}

.date-visit-resume:first-child {
    padding-left: 0px;
    margin-left: 0px;
    border-left: none;
}

.date-visit-resume strong {
    font-family: var(--typo-primary) ;
    color: var(--main);
    font-weight: 700;
    padding-left: 0px;
    letter-spacing: 1px;
}



.datos-servicio {
    font-family: var(--typo-primary) !important;

}

/* tabla resumen */
.carrito-tabla {
    border-top: 1px dashed var(--neutral-10);
    padding-top: 25px;
    margin-top: 15px;
}

.tabla-resumen {
    border: none !important;
    margin: 0 !important;
}

.tabla-resumen tr td {
    padding: 2px 0;
    border: none;
    line-height: 1.4em;
    
}

.tabla-resumen tr th {
    padding: 0;
}

.tabla-resumen tr th:nth-child(2) {
    text-align: center;
}

.tabla-resumen tr th:nth-child(3) {
    text-align: right;
}

.tabla-resumen th h5 {
    font-weight: 600;
    font-size: 12px;
    letter-spacing: 1px;
    margin: 0;
    color: var(--neutral-80);
    font-family: var(--typo-secondary) !important;
}

.tabla-resumen tr td:first-child {
    width: 50%;
}

.tabla-resumen tr td:nth-child(2) {
    width: 23%;
}

#FormCompraEvento .tabla-resumen tr td:nth-child(2) {
    width: auto;
}

.tabla-resumen tr td.casi-last {
    width: 20%;
    text-align: right;
}

.tabla-resumen tr td:last-child {
    width: 7%;
    text-align: right;
    font-weight: 400;
}

.tabla-resumen tr td .num_usuarios {
    border: none;
    text-align: center;
    display: block;
    width: 100%;
    padding: 0;

}

.tabla-resumen tr td input {
    background: none;
}

.tabla-resumen tr.totales td {
    color: var(--main);
    padding-top: 10px;
    text-transform: uppercase;
    letter-spacing: 1px;
    font-size: 14px;
    font-weight: 700;
}

.tabla-resumen tr.totales td.total_precio {
    font-weight: 700;
}

.tabla-resumen tr td label {
    margin: 0;
    padding: 2px 0;
    font-weight: normal;
    font-size: 14px;
    letter-spacing: 0.03em;
}

/* fila tabla extra */

.tabla-resumen tr td.delete-mejora .fa {
    color: var(--error);
    cursor: pointer;
    font-size: 24px;
    padding-top: 5px;
    background: none !important;
    line-height: 24px;
    transition: var(--transition);
}

.tabla-resumen tr td.delete-mejora .fa:hover {
    color: var(--error);
}

tr.extra-mejora-tabla td {
    color: var(--neutral-40);
    padding-top: 7px;
    font-weight: 400;
}

tr.extra-mejora-tabla td input {
    text-align: center;
    border: none;
    color: var(--neutral-40);
    width: 100%;
    font-style: initial;
}

tr.extra-mejora-tabla td.casi-last {
    font-style: initial;
}

/* fin fila tabla extra */

/* fin tabla resumen */

@media only screen and (max-width: 810px) {
    .datos-servicio-container {
        flex-wrap: wrap;
        margin-top:16px;
    }
    .name-visit-resume {
        display: block;
        padding-bottom: 10px;
        font-size: 14px;
    }

    .date-visit-resume {
        width: 100%;
        padding-left: 0;
        margin-left: 0;
        border-left: none;
        padding-right: 8px;
        margin-right: 8px;
        border-right: none;
        font-size: 14px;
    }

    .date-visit-resume:last-child {
        padding-right: 0;
        margin-right: 0;
        border-right: none;
    }
}

@media only screen and (max-width: 767px) {

    .tabla-resumen tr td,
    .tabla-resumen tr td label {
        font-size: 12px;
    }

    .tabla-resumen tr.totales td {
        font-size: 14px;
    }

    .tabla-resumen tr.totales td {

    }
}

/* fin resumen visita */

/* extras mejora tus visitas */

#mejora-tus-visitas {
    margin: 0;
    padding: 0;
    display: flex;
    gap: 0px 30px;
    flex-wrap: wrap;
    align-content: flex-start;
}

#mejora-tus-visitas li.card-visita {
    list-style: none;
    width: calc(100% / 4 - 25px);
}

.content-extra {
    position: relative;
    height: 100%;
}

.mejora-texto-titulo {
    align-content: center;
    display: flex;
    align-items: center;
    padding: 15px 15px 0;
    font-weight: 400;
    transition: var(--transition);
    font-size: 16px;
    color: var(--neutral-80);
}

.mejora-texto-titulo strong {
    font-weight: 600;
}

.mejora-texto {
    font-style: italic;
    align-content: center;
    display: flex;
    align-items: center;
    padding: 10px 15px 0;
    font-weight: 400;
    transition: var(--transition);
    line-height: 21px;
    color: var(--neutral-60);
}

.mejora-precio {
    padding: 0 15px 60px;
    transition: var(--transition);
}

.mejora-precio .cont-mejora-precio {
    border-top: 1px dashed var(--neutral-10);
    padding-top: 15px;
    margin-top: 20px;
    color: var(--neutral-40);
}

.mejora-precio .cont-mejora-precio .usuario_grupo_precio {
    line-height: 16px;
    padding-bottom: 10px;
}

.error_anadir_extra {
    font-size: 12px;
    padding-top: 10px;
    display: block;
}

.mejora-enviar {
    align-items: center;
    display: flex;
    position: absolute;
    bottom: 0;
    width: 100%;
}

.mejora-enviar .enviar_extra {
    border: none;
    padding: 0;
    display: block;
    width: 100%;
    height: 45px;
    line-height: 45px;
    background:none;
    color: var(--main);
    border: 1px solid var(--main);
}

.mejora-enviar .enviar_extra:hover {
    background:var(--secondary);
    color: var(--white);
    border: 1px solid var(--secondary);
}

.mejora-enviar button.enviar_extra i {
    font-size: 16px;
    line-height: 45px;
}

#mejora-extra .msg_error {
padding: 0;
background: none;
color: var(--secondary);
font-weight: 300;
font-size: 12px;
}

#mejora-tus-visitas li.card-visita {
    background: none;
border: 1px solid var(--main);
}






@media only screen and (max-width: 810px) {
    #mejora-tus-visitas li.card-visita {
        width: calc(100% / 2 - 15px);
    }
}

@media only screen and (max-width: 767px) {
    #mejora-tus-visitas li.card-visita {
        width: 100%;
    }
}

/* fin extras mejora tus visitas */

/* tus datos */
.text-expli .campos-obligatorios {
    font-style: italic;
    font-size: 12px;
    padding-left: 10px;
    color: var(--neutral-40);
}

.cont-datos-personales {
    display: flex;
    align-items: flex-start;
    gap: 0px 30px;
    flex-wrap: wrap;
    align-content: flex-start;
}

.linea_datos {
    margin-top: 15px;
    width: calc(100% / 2 - 15px);
}

@media only screen and (max-width: 767px) {
    .text-expli .campos-obligatorios {
        padding-left: 0;
        display: block;
    }

    .text-expli {
        margin-bottom: 0;
    }

    .linea_datos {
        width: 100%;
    }

    #section-visitas textarea.form-control {
        height: 100px;
    }
}

/* fin tus datos */

/* formas pago */

#FormasPago {
    display: flex;
    align-items: flex-start;
    gap: 0px 16px;
    flex-wrap: wrap;
    align-content: flex-start;
    padding:15px 0 10px 0
}

/* card tipo pago */
#FormasPago .pago {
    margin-top: 0;
    padding: 0;
    width: calc(100% / 4 - 16px);
    background: none;
    
}

#FormasPago .pago label {
    height: 82px;
    padding: 50px 5px 10px;
    margin: 0;
    color: var(--neutral-40);
    text-transform: uppercase;
    font-size: 12px;
    line-height: 16px;
    text-align: center;
    letter-spacing: 0.03em;
    display: block;
    font-weight: 500 !important;
    background-repeat: no-repeat;
    background-position: center top 15px;
    border-radius: 0;
    border: 1px solid var(--black);
    background-size: 24px;
    background-position: top;
    cursor: pointer;
}

#FormasPago .pago label:hover {
background-color: var(--secondary);
border-color: var(--secondary);
color: var(--white);
background-position: bottom;
}

#FormasPago .pago.selected label {
background-color: var(--secondary);
border-color: var(--secondary);
color: var(--white);
background-position: bottom;
}

/* icons para cada tipo de pago */
#FormasPago .pago.pago_en_bodega label {
    background-image: url(/wp-content/plugins/visitas/modules/visitas/reservas/images/pago-bodega-icon.svg);
}

#FormasPago .pago.tarjeta_de_credito label {
    background-image: url(/wp-content/plugins/visitas/modules/visitas/reservas/images/pago-card-icon.svg);
}

#FormasPago .pago.bizum label {
    background-image: url(/wp-content/plugins/visitas/modules/visitas/reservas/images/pago-bizum-icon.svg);
}

#FormasPago .pago.paypal label {
    background-image: url(/wp-content/plugins/visitas/modules/visitas/reservas/images/pago-paypal-icon.svg);
}

#FormasPago .pago.apple_pay label {
    background-image: url(/wp-content/plugins/visitas/modules/visitas/reservas/images/pago-apple-icon.svg);
}

#FormasPago .pago.google_pay label {
    background-image: url(/wp-content/plugins/visitas/modules/visitas/reservas/images/pago-google-icon.svg);
}

#FormasPago .pago.pago_en_instalacion label,
#FormasPago .pago.pago_en_la_instalacion label {
    background-image: url(/wp-content/plugins/visitas/modules/visitas/reservas/images/pago-instalacion-icon.svg);
}

#FormasPago .pago.gratuito label {
    background-image: url(/wp-content/plugins/visitas/modules/visitas/reservas/images/pago-gratis-icon.svg);
}




/* fin icons para cada tipo de pago */

#FormasPago .pago label input {
    width: 0;
    height: 0;
    opacity: 0;
}

/* fin card tipo pago */

@media only screen and (max-width: 810px) {
    #FormasPago .pago {
        width: calc(100% / 3 - 20px);
    }
}

@media only screen and (max-width: 767px) {
    #FormasPago {
        gap: 0px 20px;
        margin-top: 10px;
    }

    #FormasPago .pago {
        width: calc(100% / 2 - 10px);
        margin-top: 5px;
    }

    #FormasPago .pago label {
        padding: 40px 5px 10px;
        font-size: 11px;

    }
}

/* fin formas pago */

/* botones cancelar y continuar */
.finalizar_compra {
    display: flex;
    justify-content: space-between;
    background: none;

}

@media only screen and (max-width: 767px) {
    .finalizar_compra {
        flex-wrap: wrap;
        flex-direction: column-reverse;
        gap: 5px;
        width: 100%;
    }

    .finalizar_compra .divider-input,
    .finalizar_compra .cierre-volver {
        width: 100%;
        text-align: center;
    }
}

/* fin botones cancelar y continuar */

/* ------------------------------------------------------ CLOSE: Paso 2 Resumen Extras Datos Formas de pago  ------------------------------------------------------ */

/*  ----------------------------------------------------------------------------------------------------------------------------
    ----------------------------------------------------------------------------------------------------------------------------
        OPEN: Paso 3 Confirmar compra
    ----------------------------------------------------------------------------------------------------------------------------
    ----------------------------------------------------------------------------------------------------------------------------  */

/* datos reserva */
.datos-reserva-ok{
    text-align: left;
}

.datos-reserva .datos-visitas.fecha {
    border-top: 1px dashed var(--neutral-10);
    padding-top: 5px;
    margin-top: 15px;
}

.datos-reserva .datos-visitas.fecha .title-visit {
    margin-bottom: 0;
    margin-top: 5px;
    padding-bottom: 0;
    text-align: left;
}

.datos-reserva .datos-visitas.fecha .date-visit-resume {
    padding-left: 0;
    margin-left: 0;
    border-left: none;
    font-size: 14px;
}

@media only screen and (max-width: 767px) {
    .datos-reserva .datos-visitas.fecha .date-visit-resume {
        font-size: 13px;
    }
}

/* fin datos reserva */

/* cupón descuento */
#cupones {
    margin: 16px;
    display: none;
}


#cupones .cont-datos-personales {
    position: relative;
    margin-top: 10px;
    float: left;
    width: 100%;
    max-width: 400px;
}

#cupones .linea_datos {
    /*idth: 100%;*/
    margin: 0;
}

#cupones .linea_datos input#cupon {
    /*padding-right: 200px !important;*/
}

#cupones .contiene-cupon {
    width: 200px;
    position: absolute;
    top: 5px;
    right: 5px;
}

#cupones .contiene-cupon #validar_cupon {
    font-weight: 600;
    height: 45px;
    line-height: 41px;
    margin: -5px 0px;
    padding: 0;
    display: block;
    border: none;
    background-color: rgba(var(--black-rgb), 0.05);
    color: var(--black);
    transition: var(--transition);
    text-transform: uppercase;
    font-size: 14px;
    width: 100%;
    padding: 0px 20px;
    letter-spacing: 2px;
    font-weight: 500;
    font-size: 12px;
    text-transform: uppercase;
    background: none;
    border-radius: 0;
    border: 1px solid var(--black);
    display: block;
    width: 100%;
}

#cupones .contiene-cupon #validar_cupon:hover {
    background-color: var(--secondary);
    border-color: var(--secondary);
    color: var(--white) !important;
}

@media only screen and (max-width: 767px) {
    #cupones .linea_datos input#cupon {
        padding-right: 30px !important;
    }

    #cupones .contiene-cupon {
        width: 160px;
    }

    #cupones .contiene-cupon #validar_cupon {
        font-size: 13px;
    }
}

/* fin cupón descuento */

/* tus datos */

.card-visita.tus-datos-personales {
    margin: 16px 0;
    background: none;
}

.tus-datos-personales .cont-datos-persona {
    display: flex;
    align-items: flex-start;
    gap: 0px 30px;
    flex-wrap: wrap;
    align-content: flex-start;
    padding-top: 10px;
}

.cont-datos-persona .datos-visitas {
    width: calc(100% / 4 - 25px);
}
.cont-datos-persona .datos-visitas-cinco {
    width: calc(100% / 5 - 25px);
    text-align:left;
}
.cont-datos-persona .datos-visitas-confirmacion {
    width: calc(100% / 5 - 25px);
}

.tus-datos-personales .datos-visitas p {
    font-weight: 400;
    font-size: 12px;
    letter-spacing: 1px;
    margin: 0;
    color: var(--neutral-40);
    text-transform: uppercase;
    padding-bottom: 5px;
}

.tus-datos-personales .datos-visitas strong {
    font-weight: 500;
    font-size: 14px;
    letter-spacing: 0.03em;
    color: var(--neutral-80);
    text-transform: initial;
}

.tus-datos-personales .datos-visitas-confirmacion p {
    font-weight: 400;
    font-size: 12px;
    letter-spacing: 1px;
    margin: 0;
    color: var(--neutral-40);
    text-transform: uppercase;
    padding-bottom: 5px;
}

.tus-datos-personales .datos-visitas-confirmacion strong {
    font-weight: 500;
    font-size: 14px;
    letter-spacing: 0.03em;
    color: var(--neutral-80);
    text-transform: initial;
}

@media only screen and (max-width: 810px) {
    .cont-datos-persona .datos-visitas,
    .cont-datos-persona .datos-visitas-cinco {
        width: calc(100% / 2 - 15px);
        margin: 5px 0;
    }
}

/* fin tus datos */

/* condiciones */
.condiciones_servicio {
    margin:0 0 0 0;
    padding: 16px;
}

.condiciones_servicio .text-condiciones p,
.condiciones_servicio .text-condiciones ul li,
.condiciones_servicio .text-condiciones p ul li {
    margin: 0;
    padding: 8px 30px 0px 30px;
    background-image: url(/wp-content/plugins/visitas/modules/visitas/reservas/images/guion.svg);
    background-size: 4px;
    background-repeat: no-repeat;
    background-position: top 16px left 15px;
    font-size: 12px;
    color: var(--neutral-60);
}

.condiciones_servicio .text-condiciones ul {
    padding: 0;
}
.condiciones_servicio .text-condiciones ul,
.condiciones_servicio .text-condiciones p,
.condiciones_servicio .text-condiciones p ul {
list-style: none;
font-size: 12px;
color: var(--neutral-60);
}


/* fin condiciones */

/* formulario por qué */

.formulario-bloque .row {
    margin-top: 20px;
    margin-bottom: 0;
    padding: 0;
}

.formulario-bloque ul.formulario_preguntas li {
    margin: 5px 0 0;
}

.formulario-bloque ul.formulario_preguntas li label {
    font-size: 13px;
    font-style: italic;
    line-height: 1.4em;
}

.formulario-bloque ul.formulario_preguntas li label input {
    margin-top: 3px;
}

/* fin formulario por qué */

/* mensage sesión caducada */

#session-caducada-msg {
    margin-top: 15px;
}

/* fin mensage sesión caducada */
.datos-passbook {
display: none;
}

@media (max-width: 767px) {
.datos-passbook {
display: inline-block;
width: 100%;
padding: 16px;
background: #f8f8f8;
}
}





.datos-passbook h4.rotulo-compras2 {
    margin: 0 0 8px 0;
    padding: 0;
}

.wallet-form {
    text-align: center;
}

.wallet-form button[type="submit"] {
    width: 100%;
    margin-top: 24px;
    padding: 16px 16px 16px 74px;
    background:var(--secondary) url(../img/ico-wallet.png) no-repeat 16px center;
    color: var(--white);
    background-size: 30px;
    border-radius: 0px;
    border:0px;
    text-align: left;
    text-transform: uppercase;
    font-weight: 700;
    font-size: 12px;
    letter-spacing: 0.23px !important;    
}

.wallet-form button[type="submit"]:hover,
.wallet-form button[type="submit"]:focus {
    background-color:#813C43;
    color: var(--white);
}

/* botones volver y confirmar reserva */
@media only screen and (max-width: 767px) {

    .finalizar_compra.finalizar_confirmacion form {
        width: 100%;
        flex-wrap: wrap;
        flex-direction: column-reverse;
    }
}

/* fin botones volver y confirmar reserva */

/* ---------- responsive ----------------------------- */

@media only screen and (max-width: 767px) {}

/* ------------------------------------------------------ CLOSE: Paso 3 Confirmar compra  ------------------------------------------------------ */

/* ------------------------------------------------------OPEN: RESERVA FINALIZADA: Resumen  ------------------------------------------------------ */

/* datos reserva finalizada */


.row.vuelta-pago {
display: inline-block;
text-align: center;
width: 100%;
}

.row.vuelta-pago .checkmark{
display: inline-block;
}

.reserva-fin-resumen .row,
.datos-personales-resumen .row {
    margin-top: 30px;
}

.reserva-fin-resumen .row:first-child {
    margin-top: 0;
}

.reserva-fin-resumen .rotulo {
    font-weight: 500;
    font-size: 16px;
    text-transform: uppercase;
    letter-spacing: 2px;
    padding-bottom: 10px;
    color: var(--black);
    margin: 0;
    font-family: var(--typo-primary);
}

.reserva-fin-resumen .localizador {
    text-align: right;
}

.reserva-fin-resumen .localizador p {
    margin: 5px 0 0;
    border: 0.5px dashed var(--black);
    padding: 15px 20px 10px 25px !important;
    border-right: 5px solid var(--black);
    display: inline-block;
    text-align: right;
    margin-bottom: 10px;
}

.reserva-fin-resumen .localizador p .rotulo-localizador {
    font-size: 16px;
    font-weight: 500;
    color: var(--black);
    display: block;
    line-height: 100%;
    letter-spacing: 1px;
    margin-bottom: 5px;
}

.reserva-fin-resumen .localizador p .cifra-localizador {
    font-size: 42px;
    font-weight: 600;
    color: var(--black);
    display: block;
    line-height: 100%;
}


 .localizador-pago-ok {
    display: inline-block;
    width: 100%;
    margin:24px 0 0 0 ;
    font-family: var(--typo-primary);
    font-size: 24px;
    color: var(--secondary);
 }

 .row.vuelta-pago .textos-pagos a.google-maps-link {
display: inline-block;
margin: 24px 0;
padding: 4px 16px;
color: var(--secondary);
font-weight: 400;
border: 1px solid var(--secondary);
}

 .row.vuelta-pago .textos-pagos a.google-maps-link:hover,
 .row.vuelta-pago .textos-pagos a.google-maps-link:focus {
    color: var(--white) !important;
    background: var(--secondary);
 }



/* fin reserva finalizada */

/* open modificar reserva */
#CambioReserva {
    display: inline-block;
    width: 100%;
}

p.text-expli{
    text-align: left;
}
.row.result-modificar {
    width: 100%;
    text-align: center;
    margin-bottom: 16px;
}
/* close modificar reserva */

/* botones acciones */

#paso_resumen_all .finalizar_resumen {
    background: none;
    padding: 0;
}

.btns-reserva-finalizada {
    display: flex;
    justify-content: space-between;
    width: 100%;
}


/* fin botones acciones */

/* ---------- responsive ----------------------------- */

@media only screen and (max-width: 767px) {

    .reserva-fin-resumen .localizador p {
        width: 100%;
        margin-top: 20px;
        margin-bottom: 0;
        text-align: left;
        border-left: 5px solid var(--black);
        border-right: 0.5px dashed var(--black);
        padding-left: 20px !important;
    }
}

/* ------------------------------------------------------ CLOSE: RESERVA FINALIZADA: Resumen  ------------------------------------------------------ */

/*  ----------------------------------------------------------------------------------------------------------------------------
    ----------------------------------------------------------------------------------------------------------------------------
        OPEN: Pantalla pago OK
    ----------------------------------------------------------------------------------------------------------------------------
    ----------------------------------------------------------------------------------------------------------------------------  */

.text-reserva-ok {
    /*display: flex;
    align-items: center;
    justify-content: center;
    gap: 30px;*/
    display: inline-block;
    width: 100%;
    text-align: center;
}

.text-saludo-vuelta {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 30px;
}

.checkmark {
    width: 70px;
    height: 70px; 
    margin: auto;
}

.text-saludo-vuelta h3 {
    font-weight: 200;
    font-size: 48px;
    margin: 0;
    padding: 0;
}

.vuelta-pago-ok .text-saludo-vuelta h3 {
    color: var(--ayuda);
    text-align: center;
}

.vuelta-pago-ok #ReservaModificar {
    visibility: hidden;
}

.vuelta-pago-nok .text-saludo-vuelta h3 {
    color: var(--error);
}

.text-info-vuelta {
    text-align: center;
    font-size: 18px;
    margin: 15px 0 25px;
    font-weight: 600;
}

.vuelta-pago-ok .text-info-vuelta {
    color: var(--ayuda);
}

.vuelta-pago-nok .text-info-vuelta {
    color: var(--error);
}

.text-vuelta-parrafo {
    margin: 50px 0;
    text-align: center;
    float: left;
    width: 100%;
}

.card-visita.boton-pago-imprimir,
.card-visita.boton-pago-imprimir form {
    display: flex;
    justify-content: space-between;
    width: 100%;
}

.info-localizador-ok {
    display: flex;
    gap: 30px;
}

.info-localizador-ok p {
    width: 50%;
    text-align: center;
}

.info-localizador-ok p span {
    display: block;
    text-transform: uppercase;
    border-bottom: 0.5px solid var(--neutral-10);
    width: ;
    max-width: 500px;
    margin: 0 auto;
    padding-bottom: 5px;
    letter-spacing: 1px;
    color: var(--neutral-40);
}

.info-localizador-ok p:first-child strong {
    display: block;
    margin: 20px 0 0;
    text-transform: uppercase;
    font-size: 18px;
    letter-spacing: 0.03em;
    font-weight: 600;
    color: var(--neutral-80);
}

.info-localizador-ok p:last-child strong {
    font-size: 30px;
    line-height: 30px;
    display: block;
    padding: 15px 0 0;
    color: var(--neutral-80);
}

/* animacion ok */

.path {
    stroke-dasharray: 1000;
    stroke-dashoffset: 0;
    animation: dash 2s ease-in-out;
    -webkit-animation: dash 2s ease-in-out;
}

.spin {
    animation: spin 2s;
    -webkit-animation: spin 2s;
    transform-origin: 50% 50%;
    -webkit-transform-origin: 50% 50%;
}

@-webkit-keyframes dash {
    0% {
        stroke-dashoffset: 1000;
    }

    100% {
        stroke-dashoffset: 0;
    }
}

@keyframes dash {
    0% {
        stroke-dashoffset: 1000;
    }

    100% {
        stroke-dashoffset: 0;
    }
}

@-webkit-keyframes spin {
    0% {
        -webkit-transform: rotate(0deg);
    }

    100% {
        -webkit-transform: rotate(360deg);
    }
}

@keyframes spin {
    0% {
        -webkit-transform: rotate(0deg);
    }

    100% {
        -webkit-transform: rotate(360deg);
    }
}

@-webkit-keyframes text {
    0% {
        opacity: 0;
    }

    100% {
        opacity: 1;
    }
}

@keyframes text {
    0% {
        opacity: 0;
    }

    100% {
        opacity: 1;
    }
}

/* fin animacion ok */

/* ---------- responsive ----------------------------- */

@media only screen and (max-width: 767px) {
    .text-saludo-vuelta {
        gap: 15px;
    }

    .checkmark {
        width: 50px;
        height: 50px;
        margin: auto;
    }

    .text-saludo-vuelta h3 {
        font-weight: 300;
        font-size: 24px;
    }

    .text-info-vuelta {
        font-size: 16px;
    }

    .info-localizador-ok {
        gap: 10px;
        flex-wrap: wrap;
    }

    .info-localizador-ok p {
        width: 100%;
    }

    .info-localizador-ok p:first-child strong {
        margin: 10px 0 0;
        font-size: 16px;
    }

    .info-localizador-ok p:last-child strong {
        font-size: 24px;
        padding: 10px 0 0;
    }

    .card-visita.boton-pago-imprimir,
    .card-visita.boton-pago-imprimir form {
        flex-wrap: wrap;
        gap: 5px;
    }

    .card-visita.boton-pago-imprimir div {
        width: 100%;
        text-align: center;
    }

}

/* ------------------------------------------------------ CLOSE: Pantalla pago OK  ------------------------------------------------------ */

/* ------------------------------------------------------OPEN: PANTALLA PAGO ERROR  ------------------------------------------------------ */

/* animacion error */

.textos-pagos-error .checkmark {
    margin-top: 20px;
    margin-bottom: 20px;
}

.path {
    stroke-dasharray: 1000;
    stroke-dashoffset: 0;
}

.path.circle {
    -webkit-animation: dash 0.9s ease-in-out;
    animation: dash 0.9s ease-in-out;
}

.path.line {
    stroke-dashoffset: 1000;
    -webkit-animation: dash 0.9s 0.35s ease-in-out forwards;
    animation: dash 0.9s 0.35s ease-in-out forwards;
}

.path.check {
    stroke-dashoffset: -100;
    -webkit-animation: dash-check 0.9s 0.35s ease-in-out forwards;
    animation: dash-check 0.9s 0.35s ease-in-out forwards;
}

@-webkit-keyframes dash {
    0% {
        stroke-dashoffset: 1000;
    }

    100% {
        stroke-dashoffset: 0;
    }
}

@keyframes dash {
    0% {
        stroke-dashoffset: 1000;
    }

    100% {
        stroke-dashoffset: 0;
    }
}

@-webkit-keyframes dash-check {
    0% {
        stroke-dashoffset: -100;
    }

    100% {
        stroke-dashoffset: 900;
    }
}

@keyframes dash-check {
    0% {
        stroke-dashoffset: -100;
    }

    100% {
        stroke-dashoffset: 900;
    }
}

@keyframes stroke {
    100% {
        stroke-dashoffset: 0;
    }
}

/* fin animacion error */

/* textos error */

.textos-pagos.textos-pagos-error h2 {
    color: var(--main);
}

/* fin textos error */

/* ------------------------------------------------------ CLOSE: PANTALLA PAGO ERROR  ------------------------------------------------------ */

#servicios_slider {
    max-width: 1020px;
    margin: 0 auto;
}

/* ···························· inicio IGUALAR ESTILOS ESPACIOS MENU EN VISITAS ·········································· */


#top-menu li a {
    padding-left: 0;
    padding-right: 0;
}

#top-menu li a:hover {
    background: none;
}

/* ----------------------------------- 1440px */


/* ···························· fin IGUALAR ESTILOS ESPACIOS MENU EN VISITAS ·········································· */
/* ···························· open RESEÑAS ·········································· */
.row_resenas_visitas {
    margin: 20px 0 0 0;
    padding: 15px 0 !important;
    background: var(--white);
}

.row_resenas_visitas .title-reviews p {
    font-family: var(--typo-secondary);
    font-weight: 500;
    font-size: 16px;
    text-align: left;
    text-transform: uppercase;
    letter-spacing: 2px;
    padding-bottom: 10px;
    color: var(--black);
    margin: 0 0 0 15px;
}

/* ···························· CLOSE RESEÑAS ·········································· */

/* tunear checkbox */
.acepto-condiciones label {
    display: flex;
    align-items: flex-start;
    margin: 0;
    color: var(--neutral-40);
    position: relative;
    min-height: inherit;
    padding: inherit;
    font-size: 12px;
    letter-spacing: 0;
    line-height: 14px;
}

.acepto-condiciones label a {
    color: var(--secondary);
    padding-left: 5px;
    font-weight: 500;
}

.acepto-condiciones label a:hover {
    color: var(--black);
    text-decoration: underline;
}

.acepto-condiciones input {
    width: 0;
    height: 0;
    opacity: 0;
}

.acepto-condiciones label>span {
    width: 15px;
    height: 15px;
    display: flex;
    justify-content: center;
    border: 0.5px solid var(--neutral-10);
    margin-right: 5px;
    transition: all 0.3s;
    background-color: rgba(var(--white-rgb), 0.7);
}

.acepto-condiciones input:checked+label>span {
    animation: bounce 250ms;
    border-color: var(--main);
}

.acepto-condiciones input:checked+label>span::before {
    content: "";
    position: absolute;
    top: 7px;
    left: 2px;
    border-right: 2px solid transparent;
    border-bottom: 2px solid transparent;
    transform: rotate(45deg);
    transform-origin: 0% 100%;
    animation: checked-box 125ms 250ms forwards;
}

@keyframes checked-box {
    0% {
        width: 0;
        height: 0;
        border-color: var(--main);
        transform: translate(0, 12px) rotate(45deg);
    }

    33% {
        width: 5px;
        height: 0;
        border-color: var(--main);
        transform: translate(0, 4px) rotate(45deg);
    }

    100% {
        width: 5px;
        height: 10px;
        border-color: var(--main);
        transform: translate(0, -8px) rotate(45deg);
    }
}

@keyframes bounce {
    0% {
        transform: scale(1);
    }

    33% {
        transform: scale(0.7);
    }

    100% {
        transform: scale(1);
    }
}

/* fin tunear checkbox */

input#reserva_anular {
display:none;
}

/*-------------------- INICIO REEMBOLSO ----------------------*/
#informacion_reembolso {
    margin-top: 30px;
    margin-bottom: 30px;
    text-align: justify;
}

.total-reembolso {
    border-top: 1px dashed var(--neutral-10);
    padding-top: 10px;
    padding-bottom: 10px;
    margin-top: 15px;
    border-bottom: 1px dashed var(--neutral-10);
}

#informacion_reembolso .instrucciones-localizador{
    font-size: 12px;
}

#informacion_reembolso .rotulo-compras2 {
    font-size: 14px;
}


#informacion_reembolso .instrucciones-localizador .titulo_total,
#informacion_reembolso .instrucciones-localizador .total_precio{
    font-size: 14px;
}

#anular-reserva-all {
    display: block;
    /*text-align: center;*/
}

#DivResultadoModificacion .texto-pagos {
    text-align: center; 
    display: inline-block;
}
/*-------------------- FIN REEMBOLSO ---------------------*/

/*-----------------ETIQUETA IDIOMA-------------------*/
.bodega-idioma {
    display: inline-flex;
    width: 100%;
    justify-content: flex-end;
}
.bodega-idioma .idioma-servicio{
    font-size: 10px;
    text-transform: none !important;
    background-color: var(--neutral-80);
    color: var(--neutral-10);
    padding: 4px 8px;
    border-radius: 2px;
}
/*---------------FIN ETIQUETA IDIOMA------------------*/

/*--------------PASO 02 Y 03 COMPRA-----------------------*/
#DivAvisoPrepago{
    display: none;
}
#DivTusExtras{
    display: none;
}
/*--------------FIN PASO 02 Y 03 COMPRA-----------------------*/
#DivMsnRegalarOK{
    display: none;
}
#DivMsnCabRegalarOK{
    text-align: center;
    display: inline-block;
}

#DivEdicionPlazas{
    display:none;
}
#DivEdicionFechas{
    display:none;
}
#DivCarritoResumen{
    /* padding: 0px 15px 15px 15px !important; */
}
#DivCarritoResumenConfirmar{
    display:none;
    /* padding: 0px 15px 15px 15px !important; */
}
#DivOpcionesModificacion{
    /* padding: 30px 40px !important; */
}
#DivCabeceraModificacion{
    /* padding: 15px 15px 15px 15px !important; */
}
#DivTusDatosModificacion{
    /* padding: 30px 40px !important; */
}
#DivResumenModificacion{
    display:none;
}
.carrito_confirmar_modificar{
    /* padding: 0px 15px 15px 15px !important; */
}
#informacion_reembolso_modificar{
    display: none;
}
#informacion_reembolso{
    /* padding: 0px 30px !important; */
}
#DivPagoInstalacion{
    display: none;
}

#FormasPago .pago.tolono label {
    background-image: url(/wp-content/plugins/visitas/modules/visitas/reservas/images/pago-gratis-icon.svg);
}

input[type='radio'] {accent-color: var(--black);}


#FormasPagoTolono .card-visita{
    background: white;
padding:0px}

#Chkclub_tolono{
    float: left;
  margin-right: 10px;
  margin-bottom: 10px;
  appearance: none;
  border: 1px solid #000;
  height: 20px;
  width: 20px;
  border-radius: 12px;
}

#Chkclub_tolono:checked{
    background-color: #000;
    background-image: url(/wp-content/plugins/visitas/img/estrella.svg);
    background-size: 12px auto;
    background-repeat: no-repeat;
    background-position: 3px 3px;
}



.texto-club{
        padding-left:30px}

#ClubTolono{padding-left:0px}