/*
Theme Name: Fixu FSE
Author: Fixu
Author URI: https://fixu.cl
Theme URI: https://fixu.cl
Tags: full-site-editing, block-patterns
Text Domain: fixu-fse
Requires at least: 6.4
Requires PHP: 7.4
Tested up to: 6.4
Version: 100.0

License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
*/
*,
*::before,
*::after {
    box-sizing: inherit;
}
/* 
* Styles intended only for the front.
*/
html {
    scroll-behavior: smooth;
}

@media screen and (prefers-reduced-motion: reduce) {
    html {
        scroll-behavior: auto;
    }
}

body {
    -moz-osx-font-smoothing: grayscale;
    -webkit-font-smoothing: antialiased;
}

.entry-content.is-layout-constrained > * {
    margin-block-start: 0;
}

:where(.wp-site-blocks) > * {
    margin-block-start: 0;
}

.site-footer {
    margin-block-start: 0;
}

main {
    padding-bottom: 0 !important;
}

strong {
    font-weight: 700;
}

/* .wp-block-button.is-style-outline .wp-block-button__link:hover {
        filter: brightness(0.87);
    } */

/* 
* Resetea los márgenes de los encabezados en los bloques de contenido. 
*/

h1 {
    text-wrap: pretty;
}
h2,
h3,
h4,
h5,
h6 {
    text-wrap: balance;
    line-height: 0.9;
}

/* 
* Estilos para los elementos de formulario. 
*/
input,
button,
textarea,
select {
    font: inherit;
}

input[type="button"],
input[type="email"],
input[type="search"],
input[type="submit"],
input[type="text"],
textarea {
    -webkit-appearance: none;
    appearance: none;
}

input:not([type="submit"]),
select,
textarea,
.wp-block-post-comments-form input:not([type="submit"]):not([type="checkbox"]),
.wp-block-post-comments-form textarea {
    color: var(--wp--preset--color--contrast);
    border: solid 1px var(--wp--preset--color--contrast);
    padding: 0.5em 1em;
    font-size: var(--wp--preset--font-size--small);
    background-color: var(--wp--preset--color--base);
}

input:focus-visible,
textarea:focus-visible {
    outline-color: var(--wp--preset--color--contrast);
}

input[type="checkbox"],
input[type="image"],
input[type="radio"] {
    width: auto;
}

label {
    width: 100%;
    display: block;
}

::placeholder {
    color: var(--wp--preset--color--gray-60);
    font-size: var(--wp--preset--font-size--small);
    opacity: 0.75;
}

/* 
* Estilos para el bloque de navegación. 
*/
.nav-primary .wp-block-navigation-item__content {
    padding-bottom: 0.9rem;
    padding-top: 1.4rem;
    border-bottom: 2px solid transparent;
    transition: all 0.3s ease;
    position: relative;
}

/* Hover para el menú principal (usa :where() para baja especificidad) */
/* .nav-primary .wp-block-navigation-item__content:hover {
    border-bottom: 2px solid var(--wp--preset--color--primary);
    transition: all 0.3s ease;
} */
/* Efecto hover solo para el menú principal (no para el submenú) */
.nav-primary .wp-block-navigation__container > .wp-block-navigation-item > .wp-block-navigation-item__content:hover {
    color: var(--wp--preset--color--primary) !important;
}
.nav-primary .wp-block-navigation__container > .wp-block-navigation-item > .wp-block-navigation-item__content::after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 2px;
    background-color: transparent;
}
.nav-primary .wp-block-navigation__container > .wp-block-navigation-item > .wp-block-navigation-item__content:hover::after {
    background-color: var(--wp--preset--color--primary);
    transition: all 0.3s ease;
}
.nav-primary .wp-block-navigation__container > .wp-block-navigation-item > .wp-block-navigation-item__content:active::after {
    border-bottom: 2px solid var(--wp--preset--color--primary);
    transition: all 0.3s ease;
}

/* Asegurar que el submenú no tenga el efecto ::after */
.nav-primary .wp-block-navigation__submenu-container .wp-block-navigation-item__content::after {
    display: none;
}

/* 
*Estilos específicos para el submenú 
*/
.nav-primary .wp-block-navigation:not(.has-background) .wp-block-navigation__submenu-container {
    border: 1px solid var(--wp--preset--color--contrast);
}
.nav-primary .wp-block-navigation__submenu-container .wp-block-navigation-link:not(:last-child) {
    border-bottom: 1px solid var(--wp--preset--color--contrast) !important;
}
.nav-primary .wp-block-navigation__submenu-container .wp-block-navigation-item__content {
    background-color: inherit;
}
.nav-primary .wp-block-navigation__submenu-container .wp-block-navigation-item__content:hover {
    border-bottom: 2px solid transparent;
    transition: all 0.3s ease;
    filter: brightness(0.95);
}

.nav-primary .wp-block-navigation__submenu-container .wp-block-navigation-item__content:active {
    border-bottom: 2px solid transparent;
    transition: all 0.3s ease;
    filter: brightness(0.85);
}

/* 
* Estilos para el bloque de navegación responsive. 
*/
/* Contenedor del menú responsive */
.wp-block-navigation__responsive-container.is-menu-open.has-modal-open {
    padding: 0rem;
}

.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-content {
    gap: 1rem;
}

.wp-block-navigation__responsive-container.is-menu-open.has-modal-open .wp-block-navigation__container {
    width: 100%;
    gap: 5px !important;
}

.wp-block-navigation__responsive-container.is-menu-open.has-modal-open .wp-block-page-list {
    width: 100%;
}

.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-content .has-child .wp-block-navigation__submenu-container {
    border-radius: 0;
    margin: 0;
    padding: 0;
    align-items: flex-start;
    flex-direction: column;
    gap: 5px;
    width: 100%;
}

.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-content .has-child .wp-block-navigation__submenu-container .wp-block-navigation-item:last-child {
    border-bottom: none;
}

.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-content .has-child .wp-block-navigation__submenu-container .wp-block-navigation-item {
    padding-left: 1.5rem;
}

/* Icon toggle */
.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-content .wp-block-navigation__submenu-icon {
    display: block;
    position: absolute;
    right: 0;
    top: 5px;
    height: auto;
    width: 60px;
    padding: 15px 0;
    margin: 0;
    z-index: 10;
}

.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-content .wp-block-navigation__submenu-icon svg {
    height: 16px;
    margin: 0;
}

.wp-block-navigation .has-child .wp-block-navigation__submenu-container {
    display: none;
}

.wp-block-navigation-submenu__toggle[aria-expanded="true"] ~ .wp-block-navigation-submenu,
.wp-block-navigation-submenu__toggle[aria-expanded="true"] ~ .wp-block-navigation__submenu-container {
    display: flex;
}

.wp-block-navigation__responsive-container.is-menu-open.has-modal-open .wp-block-navigation__container li:not(.wp-social-link) {
    width: 100%;
    padding: 0 0;
    position: relative;
}

/* Mobile menu links */
.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-content .wp-block-navigation-item__content {
    width: 100%;
    font-size: var(--wp--preset--font-size--base);
    padding: 15px;
}

.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item {
    border-bottom: 1px solid var(--wp--preset--color--contrast);
}

.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__container .current-menu-item > .wp-block-navigation-item__content,
.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__container .wp-block-navigation-item:hover > .wp-block-navigation-item__content {
    transition: 0.3s ease;
    text-decoration: none;
    background: color-mix(in srgb, currentColor, transparent 97%);
    -webkit-tap-highlight-color: transparent;
}

.wp-block-navigation__container .wp-block-navigation-item:has(.wp-block-navigation__submenu-container:hover) > .wp-block-navigation-item__content {
    /* background: red; */
}

/* Mobile menu open button */
.wp-block-navigation__responsive-container-close,
.wp-block-navigation__responsive-container-open {
    padding: 4px;
    background: transparent;
    color: var(--wp--preset--color--contrast);
}

/* Mobile menu close button */
.wp-block-navigation__responsive-container-close {
    background: transparent;
    color: var(--wp--preset--color--contrast);
}
/*  
* Clases helper responsive para gutemberg
*/

/* Justify Content - Base classes */
.relative {
    position: relative;
}
.overflow-hidden {
    overflow: hidden;
}

.justify-center {
    justify-content: center;
}

/* Responsive - Medium (md) - 768px and up */
@media (max-width: 576px) {
    .max-sm\:justify-center {
        justify-content: center;
    }
}

@media (max-width: 768px) {
    .max-md\:justify-center {
        justify-content: center;
    }
    .max-md\:col-reverse {
        flex-direction: column-reverse;
    }
}

.hero-primary {
    font-size: var(--wp--preset--font-size--xx-large);
    font-family: var(--wp--preset--font-family--bebas-neue);
    line-height: 1.3;
    font-style: normal;
    line-height: 0.9;
    font-weight: 400;
}

.hero-primary__text-top {
    font-family: var(--wp--preset--font-family--bebas-neue);
    font-size: clamp(20px, 1.25rem + ((1vw - 3.2px) * 1.5), 32px);
    font-style: normal;
    font-weight: 400;
    text-transform: uppercase;
    display: block;
    margin-bottom: 10px;
}

/* Título con linea debajo */
.title-with-line s,
.hero-primary__text--line {
    position: relative;
    display: inline;
    background: linear-gradient(to top, #e91eae 0.25em, transparent 0.25em);
    background-position: 0 1em; /* sube o baja la línea */
    box-decoration-break: clone;
    -webkit-box-decoration-break: clone;
    padding: 0 0.1em;
    text-decoration: none;
}

.mask-about-home-left-top {
    position: absolute;
    top: 0;
    left: 0;
    object-fit: cover;
    object-position: left top;
    z-index: 1;
    max-width: 70%;
}

.mask-countdown-home-left-bottom {
    position: absolute;
    bottom: 0;
    left: 0;
    object-fit: cover;
    object-position: left bottom;
    z-index: 1;
    max-width: 30%;
}

.mask-countdown-home-right-top {
    position: absolute;
    top: 0;
    right: -100px;
    object-fit: cover;
    object-position: right top;
    z-index: 1;
    max-width: 60%;
}

/* Página de contacto */
.mask-contact-left-bottom,
.mask-about-left-bottom {
    position: absolute;
    bottom: -150px;
    left: 0;
    object-fit: cover;
    object-position: left bottom;
}

.mask-contact-right-top {
    position: absolute;
    top: 0;
    right: 0;
    object-fit: cover;
    object-position: right top;
    z-index: 1;
    max-width: 30%;
}

.contact-container {
    min-height: calc(100vh - 210px);
}

/* Página de Nosotros */
.mask-about-left-bottom {
    z-index: 2;
}
/* .title-with-line::after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 5px;
    background-color: red;
} */

.card-overlay {
    position: relative;
    overflow: hidden;
    cursor: pointer;
}

/* Overlay oculto inicialmente */
.card-overlay__text {
    position: absolute;
    inset: 0; /* ocupa todo el contenedor */
    display: flex;
    align-items: center;
    justify-content: center;
    background: red; /* negro con 50% de opacidad */
    color: #fff;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.3s ease, visibility 0.3s ease;
    text-align: center;
    padding: 1.5rem;
}

/* Al hacer hover en toda la card */
.card-overlay:hover .card-overlay__text {
    opacity: 1;
    visibility: visible;
}

@media (min-width: 768px) {
    .hero-primary__cover img {
        position: absolute;
        top: 30px;
        right: 0;
    }

    .mask-about-home-left-top {
        max-width: 40% !important;
    }

    .mask-countdown-home-right-top {
        max-width: 90% !important;
    }
}

@media (min-width: 1024px) {
    .mask-about-home-left-top {
        max-width: 100%;
    }

    .mask-countdown-home-left-bottom {
        max-width: 100%;
    }

    .mask-countdown-home-right-top {
        max-width: 100%;
    }

    /* Estilos para el bloque de contenido, para que el footer siempre esté al final de la página. */
    .wp-site-blocks {
        min-height: 100vh;
        display: grid;
        grid-template-rows: auto 1fr auto;
    }
}

/* WP Form styles */
.wpforms-submit-container .wpforms-submit {
    width: 100% !important;
    padding: 12px 20px !important;
    font-size: 18px !important;
    font-weight: bold !important;
    font-style: normal !important;
    cursor: pointer !important;
    transition: all 0.3s ease !important;
    font-family: "avenir", sans-serif !important;
    text-transform: uppercase !important;
}

div.wpforms-confirmation-container-full p {
    font-size: 18px !important;
}

/* Estilos para el bloque modal de cloudcatch */
.wp-block-cloudcatch-light-modal-block__close {
    top: 22px;
    right: 12px;
}
.wp-block-cloudcatch-light-modal-block__close svg {
    filter: drop-shadow(0 0 0.5px currentColor); /* Darle más peso visual */
}
