/*
Theme Name: City Theme
Theme URI:
Author: Flavia Bernárdez Rodríguez
Author URI:
Description:
Requires at least: 6.8
Tested up to: 6.8
Requires PHP: 5.7
Version:
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: city-theme
Tags:
*/

/* Hide scrollbar for Chrome, Safari and Opera */
body::-webkit-scrollbar {
    display: none;
}

::-webkit-scrollbar {
    width: 0;
}

/* Hide scrollbar for Firefox */
html {
    scrollbar-width: none;
    overflow-x: hidden;
    scroll-behavior: smooth;
}
.smooth-scroll {
    scroll-behavior: smooth;
}
.manco-fix {
    position: fixed !important;
    width: 100%;
}

.wp-block-cloudcatch-light-modal-block__close {
    border-radius: 40%;
    right: 0;
    top: 0;
    padding: 2rem;
}
.wp-block-navigation__responsive-container-close {
    top: 12px !important;
}

/* Deactivate animation open */
.wp-block-navigation__responsive-container.is-menu-open {
    animation: unset;
    animation-fill-mode: forwards;
}

/* Menu */
.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-content {
    padding: 10rem var(--wp--preset--spacing--20) var(--wp--preset--spacing--20);
}
.wp-block-navigation__responsive-container-close {
    position: fixed;
    z-index: 1000;
    right: 24px;
    top: 36px;
}
.wp-block-navigation__responsive-container-open svg,
.wp-block-navigation__responsive-container-close svg {
    width: 40px;
    height: 40px;
}

/* Fix Columnas */
@media (max-width: 600px) {
    .wp-block-post-template-is-layout-grid.wp-block-post-template-is-layout-grid.wp-block-post-template-is-layout-grid.wp-block-post-template-is-layout-grid {
        grid-template-columns: 1fr 1fr !important;
    }
}

/* Botón fijo */
.flu-fijo-abajo {
    width: 100vw;
    margin-left: -1.5rem;
    position: fixed;
    bottom: 0;
}

/* Barra cookies */
#moove_gdpr_cookie_info_bar.moove-gdpr-dark-scheme,
#moove_gdpr_cookie_info_bar.moove-gdpr-light-scheme {
    height: 100vh;
    min-height: unset;
    max-height: unset;
    background-color: rgba(0,0,0,0.5) !important;
    border-top: 0 !important;
    box-shadow: 0;
}
#moove_gdpr_cookie_info_bar .moove-gdpr-info-bar-container {
    margin: 20px;
    border-radius: 8px;
    background-color: inherit;
}

#moove_gdpr_cookie_modal .moove-gdpr-modal-content .moove-gdpr-modal-close:hover i, #moove_gdpr_cookie_modal .moove-gdpr-modal-content .moove-gdpr-modal-left-content #moove-gdpr-menu li a, #moove_gdpr_cookie_modal .moove-gdpr-modal-content .moove-gdpr-modal-left-content #moove-gdpr-menu li button, #moove_gdpr_cookie_modal .moove-gdpr-modal-content .moove-gdpr-modal-left-content #moove-gdpr-menu li button i, #moove_gdpr_cookie_modal .moove-gdpr-modal-content .moove-gdpr-modal-left-content #moove-gdpr-menu li a i, #moove_gdpr_cookie_modal .moove-gdpr-modal-content .moove-gdpr-tab-main .moove-gdpr-tab-main-content a:hover, #moove_gdpr_cookie_info_bar.moove-gdpr-dark-scheme .moove-gdpr-info-bar-container .moove-gdpr-info-bar-content a.mgbutton:hover, #moove_gdpr_cookie_info_bar.moove-gdpr-dark-scheme .moove-gdpr-info-bar-container .moove-gdpr-info-bar-content button.mgbutton:hover, #moove_gdpr_cookie_info_bar.moove-gdpr-dark-scheme .moove-gdpr-info-bar-container .moove-gdpr-info-bar-content a:hover, #moove_gdpr_cookie_info_bar.moove-gdpr-dark-scheme .moove-gdpr-info-bar-container .moove-gdpr-info-bar-content button:hover, #moove_gdpr_cookie_info_bar.moove-gdpr-dark-scheme .moove-gdpr-info-bar-container .moove-gdpr-info-bar-content span.change-settings-button:hover, #moove_gdpr_cookie_info_bar.moove-gdpr-dark-scheme .moove-gdpr-info-bar-container .moove-gdpr-info-bar-content button.change-settings-button:hover, #moove_gdpr_cookie_info_bar.moove-gdpr-dark-scheme .moove-gdpr-info-bar-container .moove-gdpr-info-bar-content u.change-settings-button:hover, #moove_gdpr_cookie_info_bar span[data-href]>u.change-settings-button, #moove_gdpr_cookie_info_bar.moove-gdpr-dark-scheme .moove-gdpr-info-bar-container .moove-gdpr-info-bar-content a.mgbutton.focus-g, #moove_gdpr_cookie_info_bar.moove-gdpr-dark-scheme .moove-gdpr-info-bar-container .moove-gdpr-info-bar-content button.mgbutton.focus-g, #moove_gdpr_cookie_info_bar.moove-gdpr-dark-scheme .moove-gdpr-info-bar-container .moove-gdpr-info-bar-content a.focus-g, #moove_gdpr_cookie_info_bar.moove-gdpr-dark-scheme .moove-gdpr-info-bar-container .moove-gdpr-info-bar-content button.focus-g, #moove_gdpr_cookie_info_bar.moove-gdpr-dark-scheme .moove-gdpr-info-bar-container .moove-gdpr-info-bar-content a.mgbutton:focus, #moove_gdpr_cookie_info_bar.moove-gdpr-dark-scheme .moove-gdpr-info-bar-container .moove-gdpr-info-bar-content button.mgbutton:focus, #moove_gdpr_cookie_info_bar.moove-gdpr-dark-scheme .moove-gdpr-info-bar-container .moove-gdpr-info-bar-content a:focus, #moove_gdpr_cookie_info_bar.moove-gdpr-dark-scheme .moove-gdpr-info-bar-container .moove-gdpr-info-bar-content button:focus, #moove_gdpr_cookie_info_bar.moove-gdpr-dark-scheme .moove-gdpr-info-bar-container .moove-gdpr-info-bar-content span.change-settings-button.focus-g, span.change-settings-button:focus, button.change-settings-button.focus-g, button.change-settings-button:focus, #moove_gdpr_cookie_info_bar.moove-gdpr-dark-scheme .moove-gdpr-info-bar-container .moove-gdpr-info-bar-content u.change-settings-button.focus-g, #moove_gdpr_cookie_info_bar.moove-gdpr-dark-scheme .moove-gdpr-info-bar-container .moove-gdpr-info-bar-content u.change-settings-button:focus {
    color: var(--wp--preset--color--core-black) !important;
}
#moove_gdpr_cookie_info_bar .moove-gdpr-info-bar-container .moove-gdpr-info-bar-content a.mgbutton, #moove_gdpr_cookie_info_bar .moove-gdpr-info-bar-container .moove-gdpr-info-bar-content button.mgbutton {
    background-color: var(--wp--preset--color--core-black) !important;
}

/* -----------------------------------------------
 * Botones con flechas SVG hand-drawn
 * Clase arrow-* en el .wp-block-button
 * La flecha aparece via ::after con fade-in from left al hover
 * ----------------------------------------------- */
.wp-block-button[class*="arrow-"] .wp-block-button__link {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: space-between;
}
.wp-block-button[class*="arrow-"] .wp-block-button__link::after {
    content: "";
    display: inline-block;
    flex-shrink: 0;
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
    opacity: 0;
    transform: translateX(-20px);
    transition: opacity 0.3s ease, transform 0.3s ease;
}
.wp-block-button.arrow-euskera .wp-block-button__link::after {
    width: 94px; height: 25px;
    background-image: url('./assets/images/arrow-euskera.svg');
}
.wp-block-button.arrow-castellano .wp-block-button__link::after {
    width: 59px; height: 23px;
    background-image: url('./assets/images/arrow-castellano.svg');
}
.wp-block-button.arrow-catala .wp-block-button__link::after {
    width: 77px; height: 25px;
    background-image: url('./assets/images/arrow-catala.svg');
}
.wp-block-button[class*="arrow-"] .wp-block-button__link:hover::after,
.wp-block-button[class*="arrow-"] .wp-block-button__link:focus::after {
    opacity: 1;
    transform: translateX(0);
}

/* -----------------------------------------------
 * Preloader
 * ----------------------------------------------- */
.city-preloader {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    width: 100vw !important;
    height: 100vh !important;
    height: 100dvh !important;
    background-color: var(--wp--preset--color--core-off-white, #F5F5F5) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    z-index: 99999 !important;
    opacity: 1;
    visibility: visible;
    transition: opacity 0.3s ease;
}
.city-preloader.is-hidden {
    opacity: 0 !important;
    pointer-events: none !important;
    visibility: hidden !important;
    transition: opacity 0.3s ease, visibility 0s linear 0.3s;
}
.city-preloader__spinner {
    width: 48px;
    height: 48px;
    border: 3px solid var(--wp--preset--color--core-light-gray, #E2E2E2);
    border-top-color: var(--wp--preset--color--core-black, #1E1E1E);
    border-radius: 50%;
    animation: city-spin 0.8s linear infinite;
}
@keyframes city-spin {
    to { transform: rotate(360deg); }
}

/* -----------------------------------------------
 * Animaciones reutilizables (mobile-friendly)
 * Solo transform y opacity, GPU-accelerated.
 * ----------------------------------------------- */
:root {
    --city-anim-duration: 300ms;
    --city-anim-easing: cubic-bezier(0.16, 1, 0.3, 1);
    --city-anim-distance: 24px;
    --city-anim-stagger: 150ms;
}

.city-anim-fade-in,
.city-anim-slide-up,
.city-anim-slide-down {
    opacity: 0;
    transition: opacity var(--city-anim-duration) var(--city-anim-easing),
                transform var(--city-anim-duration) var(--city-anim-easing);
    transition-delay: calc(var(--anim-index, 0) * var(--city-anim-stagger));
    will-change: opacity, transform;
}
.city-anim-slide-up { transform: translateY(var(--city-anim-distance)); }
.city-anim-slide-down { transform: translateY(calc(-1 * var(--city-anim-distance))); }

.city-anim-fade-in.is-visible,
.city-anim-slide-up.is-visible,
.city-anim-slide-down.is-visible {
    opacity: 1;
    transform: translateY(0);
}

/* Stagger en hijos directos del grupo */
.city-anim-stagger > * {
    opacity: 0;
    transform: translateY(var(--city-anim-distance));
    transition: opacity var(--city-anim-duration) var(--city-anim-easing),
                transform var(--city-anim-duration) var(--city-anim-easing);
}
.city-anim-stagger.is-visible > * {
    opacity: 1;
    transform: translateY(0);
}
.city-anim-stagger.is-visible > *:nth-child(1) { transition-delay: 0ms; }
.city-anim-stagger.is-visible > *:nth-child(2) { transition-delay: 150ms; }
.city-anim-stagger.is-visible > *:nth-child(3) { transition-delay: 300ms; }
.city-anim-stagger.is-visible > *:nth-child(4) { transition-delay: 450ms; }
.city-anim-stagger.is-visible > *:nth-child(5) { transition-delay: 600ms; }
.city-anim-stagger.is-visible > *:nth-child(n+6) { transition-delay: 750ms; }

/* Delay manual: anadir city-anim-delay-N para retrasar la aparicion de un elemento concreto */
.city-anim-delay-1 { transition-delay: 1s !important; }
.city-anim-delay-2 { transition-delay: 2s !important; }
.city-anim-delay-3 { transition-delay: 3s !important; }

/* Respetar prefers-reduced-motion */
@media (prefers-reduced-motion: reduce) {
    .city-preloader__spinner,
    .city-anim-fade-in,
    .city-anim-slide-up,
    .city-anim-slide-down,
    .city-anim-stagger > * {
        animation: none !important;
        transition: none !important;
        opacity: 1 !important;
        transform: none !important;
    }
}

/* -----------------------------------------------
 * Click feedback (state change al pulsar)
 * Auto en .wp-block-button__link y .wp-element-button
 * Opt-in con .city-click-feedback en otros elementos
 * ----------------------------------------------- */
.wp-block-button__link,
.wp-element-button,
.city-click-feedback {
    -webkit-tap-highlight-color: transparent;
    transition: transform 200ms var(--city-anim-easing),
                opacity 200ms var(--city-anim-easing) !important;
    cursor: pointer;
}
.wp-block-button__link:active,
.wp-element-button:active,
.city-click-feedback:active {
    transform: scale(0.92) !important;
    opacity: 0.8 !important;
    transition-duration: 80ms !important;
}

/* Loading state — opt-in con .city-click-loading */
.city-click-loading.is-loading {
    pointer-events: none;
    position: relative;
    color: transparent !important;
}
.city-click-loading.is-loading::after {
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    width: 20px;
    height: 20px;
    margin: -10px 0 0 -10px;
    border: 2px solid var(--wp--preset--color--core-black);
    border-top-color: transparent;
    border-radius: 50%;
    animation: city-spin 0.6s linear infinite;
}

@media (prefers-reduced-motion: reduce) {
    .wp-block-button__link:active,
    .wp-element-button:active,
    .city-click-feedback:active {
        transform: none !important;
    }
    .city-click-loading.is-loading::after {
        animation: none !important;
    }
}

