/**
 * =============================================================================
 * Component: Full Page Theming
 * -----------------------------------------------------------------------------
 * Styles for a cohesive, full-height page theme.
 * =============================================================================
 */

/* Ensures the body and main container fill the screen's height */
html, body {
    height: 100%;
}

body {
    display: flex;
    flex-direction: column;
}

main.container-fluid {
    flex-grow: 1; /* Allows the main content to expand and push the footer down */
    padding-bottom: 2rem;
}

#mobile-menu-toggle-container {
	display: none;
}

.site-header {
    display: flex;
    align-items: center; /* Alinea todo verticalmente al centro */
    padding: 1rem 1.5rem;
    border-bottom: 0.1rem solid #E8E8E8;
    background: #FFFFFF;
    position: relative;
    gap: 1.5rem; /* Añade un espacio entre el logo y el panel derecho */
}

.header-right-panel {
    display: flex;
    align-items: center;
    gap: 1.5rem; /* Espacio entre los elementos del panel derecho */
    width: 100%; /* Permite que el panel ocupe el espacio restante */
}

.header-right-panel p {
	color: #087748;
}

/* Este es el truco */
#topbar-lang-switcher,
#mobile-menu-toggle-container {
    margin-left: auto; /* Empuja el selector de idioma y el menú móvil al final */
}

.coming-soon-container {
    /* Centra el contenedor y le da más espacio vertical */
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: 0rem 0; /* Aumenta el espaciado vertical */
}

.main-content-wrapper {
    /* Contenedor del texto */
    max-width: 50%; /* Ocupa el 50% en pantallas anchas */
    margin: 0 auto;  /* Lo centra horizontalmente */
    text-align: center;
}

/* --- Responsive Design para Móviles --- */
@media (max-width: 768px) {
    .main-content-wrapper {
        max-width: 100%; /* Ocupa todo el ancho en pantallas pequeñas */
        padding: 0 2rem; /* Añade los márgenes laterales de 2rem */
        box-sizing: border-box; /* Asegura que el padding no cause desbordamiento */
    }
}

footer.site-footer {
    background-color: #FFFFFF; 
    padding-bottom: 6rem;
}

/* Text color adjustments for dark backgrounds */
.logo,
#topbar-lang-switcher,
#bottombar-lang-switcher, 
.footer-bottom {
    color: #0B3948; 
}

.logo img {
    /* La imagen nunca será más ancha que su contenedor. */
    max-width: 100%;

    /* El navegador ajustará la altura automáticamente para mantener la proporción. */
    height: auto;
}

.coming-soon-container h1 {
    color: #087748; 
    font-size: clamp(2.5rem, 6vw, 4rem); /* Hacemos el título más grande */
    font-weight: 900;
}

.coming-soon-container p {
    color: #0B3948; /* Un blanco más suave para el párrafo */
    line-height: 1.7;
}

p.khamaleon-link {
	color: #087748;
}