/*
Theme Name: Hello Elementor Child
Theme URI: https://elementor.com/hello-theme/?utm_source=wp-themes&utm_campaign=theme-uri&utm_medium=wp-dash
Template: hello-elementor
Author: Elementor Team
Author URI: https://elementor.com/?utm_source=wp-themes&utm_campaign=author-uri&utm_medium=wp-dash
Description: Hello Elementor is a lightweight and minimalist WordPress theme that was built specifically to work seamlessly with the Elementor site builder plugin. The theme is free, open-source, and designed for users who want a flexible, easy-to-use, and customizable website. The theme, which is optimized for performance, provides a solid foundation for users to build their own unique designs using the Elementor drag-and-drop site builder. Its simplicity and flexibility make it a great choice for both beginners and experienced Web Creators.
Tags: accessibility-ready,flexible-header,custom-colors,custom-menu,custom-logo,featured-images,rtl-language-support,threaded-comments,translation-ready
Version: 3.4.4.1754473009
Updated: 2025-08-06 11:36:49

*/


/***
* class: .sticky-header
*/
header.sticky-header {
    --header-height: 100px;
    --shrink-header-to: 0.6;
    --transition: .45s cubic-bezier(.4, 0, .2, 1);
    background-color: rgba(244, 245, 248, 1);
    transition: background-color var(--transition),
        backdrop-filter var(--transition),
        box-shadow var(--transition);
}

/***
* Sticky header activated
*/
header.sticky-header.elementor-sticky--effects {
    background-color: rgba(0, 0, 0, 0.65);
    box-shadow: 0px 4px 33px 1px rgba(0, 0, 0, .07);
    -webkit-backdrop-filter: saturate(180%) blur(20px);
    backdrop-filter: saturate(180%) blur(20px);
}

header.sticky-header>.elementor-container {
    min-height: var(--header-height);
    transition: min-height var(--transition);
}

header.sticky-header.elementor-sticky--effects>.elementor-container {
    min-height: calc(var(--header-height) * var(--shrink-header-to));
}

/***
* Shorter header on mobile (70px instead of 100px)
*/
@media only screen and (max-width: 767px) {
    header.sticky-header {
        --header-height: 70px;
    }
}

/***
* class: .logo
*/
header.sticky-header .logo img {
    transition: transform var(--transition);
}

header.sticky-header.elementor-sticky--effects .logo img {
    transform: scale(.8);
}


/*MENU*/

/* --- Estilos para Menú Vertical Collapse en Elementor --- */


/* 1. Forzar al submenú a estar en el flujo del documento */
#menu-vertical-collapse .sub-menu {
    position: static !important;
    /* La clave: quita el posicionamiento absoluto */
    display: none;
    /* Oculto por defecto */
    width: 100%;
    /* Ocupa todo el ancho del padre */

}

/* 2. Estilos para los elementos del submenú */
#menu-vertical-collapse .sub-menu li a {

}

/* 3. Eliminar la flecha/icono por defecto de Elementor */
#menu-vertical-collapse .elementor-nav-menu--dropdown-arrow {
    display: none;
}


/*HACER CLICKABLE ELEMENTO PADRE*/

/* Haz que la flecha sea claramente clicable y separada del enlace */
.elementor-nav-menu .sub-arrow,
.elementor-nav-menu .js-submenu-arrow {
    pointer-events: auto;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-left: .4rem;
    background: transparent;
    border: none;
    padding: 0;
}

/* Forzar mostrar el submenú cuando abrimos por JS */
.elementor-nav-menu li.js-sub-menu-open>.sub-menu,
.elementor-nav-menu li.js-sub-menu-open>ul {
    display: block !important;
}

/* Opcional: animación pequeña */
.elementor-nav-menu .sub-menu {
    transition: opacity .18s ease, transform .18s ease;
}


/*HOVER TEXTO*/


.texto-oculto {
    position: absolute;
    top: 0;
    left: 0;
    visibility: hidden;
    transition: all .5s ease;
    display: none;
}
.caja-hover:hover .titulo-caja-oculta {
    visibility: hidden;
    display: none;
}
.caja-hover:hover .texto-oculto {
    visibility: visible !important;
    transition: all .5s ease;
    display: block;
}

.caja-hover:hover {
    background-color: #00000043;
    -webkit-backdrop-filter: blur(29px);
    backdrop-filter: blur(29px);
    transition: all .5s ease;
}



.ver-mas-ico:after {
    transition: all .5s ease;
    content: "";
    border-radius: 100%;
    background: #ffffff26;
    backdrop-filter: blur(20px);
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    right: 0;
    z-index: -1;
}

.ver-mas-ico:hover:after {
    backdrop-filter: blur(5px);
}

/*PASO TRATAMIENTO*/
.paso-tratamiento {
    height: 140px;
    overflow-y: auto !important;
    overflow-x: hidden;
    padding-right: 10px;
    margin-bottom: 10px !important;
}


/* MENU PRINCIPAL */
.cont-menu-elementor {
    height: 100vh !important;
    overflow-y: auto !important;
    padding-bottom: 70px !important;
}

ul#menu-menu-principal {
    padding: 0;
    margin: 0;
    list-style: none;
}

ul#menu-menu-principal>li.menu-item {
    margin: 0 0 10px 0;
   
}
ul#menu-menu-principal li .arrow_link{
    transition: all .3s ease;
    display: block;
}
ul#menu-menu-principal li .arrow_link:hover {
    transform: translateX(10px) !important;
    transition: all .3s ease;
}

ul#menu-menu-principal li a {
    font-size: 30px;
    text-transform: uppercase;
    font-family: 'Halis GR';
    color: var(--e-global-color-text);

}


span.arrow_submenu {
    display: none;
    cursor: pointer;
}

.menu-item-has-children > span.arrow_link span.arrow_submenu {
    display: inline-block;
    
}
button.js-submenu-arrow.sub-arrow {
    display: none;
}
.menu-item-has-children>span.arrow_link span.arrow_submenu {
    display: inline-block;
    transform: translateY(-4px);
    margin-left: 15px;
}
ul.sub-menu {
    padding: 0 0 0 20px;
    list-style: none;
    margin: 0;
    display: none;
    margin-bottom: 15px;
}
ul.sub-menu li {
    margin-bottom: 6px;
}
ul.sub-menu.activo {
    display: block;
}
ul.sub-menu li a {
    font-size: 20px !important;
}
ul.sub-menu ul.sub-menu li a {
    font-size: 16px !important;
}
ul.sub-menu span.arrow_submenu svg {
    width: 10px;
}