/* Importar las nuevas fuentes de Google */
@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@300;400;500;600;700;800;900&family=Montserrat:wght@300;400;500;600;700;800;900&family=Raleway:wght@300;400;500;600;700;800;900&display=swap');

/* Variables CSS para la nueva paleta de colores CARIBE TURQUESA */
:root {
    /* Colores Primarios */
    --turquesa-oscuro: #007A82;
    --turquesa-claro: #35B5B1;
    --arena-playa: #D8A676;
    --amarillo-sol: #F4C15C;
    --azul-cielo: #3B9CA4;
    --negro-texto: #1F1F1F;
    --blanco-puro: #FFFFFF;
    
    /* Variantes de transparencia */
    --turquesa-oscuro-light: rgba(0, 122, 130, 0.1);
    --turquesa-claro-light: rgba(53, 181, 177, 0.1);
    --arena-playa-light: rgba(216, 166, 118, 0.1);
    --amarillo-sol-light: rgba(244, 193, 92, 0.1);
    --azul-cielo-light: rgba(59, 156, 164, 0.1);
    
    /* Tipografía */
    --font-titulares: 'Poppins', sans-serif;
    --font-parrafos: 'Montserrat', sans-serif;
    --font-premium: 'Raleway', sans-serif;
}

/* Reset y estilos base */
body { 
    font-family: var(--font-parrafos);
    background-color: var(--blanco-puro);
    color: var(--negro-texto);
}

/* Tipografía para títulos */
h1, h2, h3, h4, h5, h6 {
    font-family: var(--font-titulares);
    font-weight: 700;
    color: rgb(45 191 165);
}

/* Hero gradient con nueva paleta */
.hero-gradient { 
    background: linear-gradient(135deg, rgba(53, 181, 177, 0.3) 0%, rgba(0, 122, 130, 0.2) 50%, rgba(255, 255, 255, 0.9) 100%),
                linear-gradient(45deg, #ffffff 0%, rgba(59, 156, 164, 0.1) 100%);
}

/* Gradiente para texto con nueva paleta */
.text-gradient { 
    background: linear-gradient(135deg, var(--turquesa-oscuro), var(--azul-cielo)); 
    -webkit-background-clip: text; 
    -webkit-text-fill-color: transparent; 
}

/* Gradiente alternativo para elementos premium */
.text-gradient-premium { 
    background: linear-gradient(135deg, var(--turquesa-claro), var(--amarillo-sol)); 
    -webkit-background-clip: text; 
    -webkit-text-fill-color: transparent; 
}

/* Botones principales */
.btn-primary {
    background-color: var(--turquesa-oscuro);
    color: var(--blanco-puro);
    border: 2px solid var(--turquesa-oscuro);
    transition: all 0.3s ease;
}

.btn-primary:hover {
    background-color: var(--turquesa-claro);
    border-color: var(--turquesa-claro);
    color: var(--blanco-puro);
    transform: translateY(-2px);
    box-shadow: 0 8px 25px rgba(0, 122, 130, 0.3);
}

/* Botones secundarios */
.btn-secondary {
    background-color: transparent;
    color: var(--azul-cielo);
    border: 2px solid var(--azul-cielo);
    transition: all 0.3s ease;
}

.btn-secondary:hover {
    background-color: var(--azul-cielo);
    color: var(--blanco-puro);
}

/* Enlaces */
a {
    color: var(--turquesa-oscuro);
    transition: color 0.3s ease;
}

a:hover {
    color: var(--azul-cielo);
}

/* Navegación */
.header-nav a {
    color: var(--negro-texto);
    transition: all 0.3s ease;
    position: relative;
    padding: 0.5rem 1rem;
    text-decoration: none;
}

.header-nav a:hover {
    color: var(--turquesa-oscuro);
}

.header-nav a.active {
    color: var(--turquesa-oscuro);
    font-weight: 600;
}

.header-nav a.active::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 60%;
    height: 2px;
    background-color: var(--turquesa-oscuro);
    border-radius: 1px;
}

/* Logo */
.logo-principal {
    color: var(--negro-texto);
    font-family: var(--font-titulares);
    font-weight: 800;
    transition: color 0.3s ease;
}

.logo-principal:hover {
    color: var(--turquesa-oscuro);
}

/* Contact phone */
.contact-phone {
    color: #f5f7f7;
    font-family: var(--font-titulares);
    font-weight: 700;
    transition: color 0.3s ease;
}

.contact-phone:hover {
    color: var(--azul-cielo);
}

/* Contact highlight */
.contact-highlight {
    background-color: var(--amarillo-sol);
    color: var(--negro-texto);
}

/* Language selector */
.language-selector {
    background-color: var(--blanco-puro);
    border: 1px solid var(--arena-playa);
    color: var(--negro-texto);
    transition: all 0.3s ease;
}

.language-selector:hover {
    background-color: var(--arena-playa);
    border-color: var(--turquesa-oscuro);
    color: var(--negro-texto);
}

/* Backgrounds alternativos */
.bg-turquesa-claro {
    background-color: var(--turquesa-claro);
}

.bg-turquesa-oscuro {
    background-color: var(--turquesa-oscuro);
}

.bg-arena-playa {
    background-color: var(--arena-playa);
}

.bg-azul-cielo {
    background-color: var(--azul-cielo);
}

.bg-amarillo-sol {
    background-color: var(--amarillo-sol);
}

/* Textos de colores específicos */
.text-turquesa-oscuro {
    color: rgb(38 84 89);
    text-shadow: 2px 2px #899593;
}

.text-turquesa-claro {
    color: var(--turquesa-claro);
}

.text-arena-playa {
    color: var(--arena-playa);
}

.text-azul-cielo {
    color: var(--azul-cielo);
}

.text-amarillo-sol {
    color: var(--amarillo-sol);
}

.text-white {
    --tw-text-opacity: 1;
    color: rgb(225, 223, 221);
}

/* Clases adicionales para contraste */
.text-title-dark {
    color: var(--negro-texto) !important;
}

.text-title-turquesa {
    color: rgb(45 191 165) !important;
}

.text-title-contrast {
    color: var(--turquesa-oscuro) !important;
    text-shadow: 1px 1px 2px rgba(255, 255, 255, 0.3);
}

/* Animación fade-in */
.fade-in { 
    animation: fadeIn 0.5s ease-in; 
}

@keyframes fadeIn { 
    from { 
        opacity: 0; 
        transform: translateY(20px); 
    } 
    to { 
        opacity: 1; 
        transform: translateY(0); 
    } 
}

/* Efectos de sombra con colores de marca */
.shadow-turquesa {
    box-shadow: 0 4px 15px rgba(0, 122, 130, 0.3);
}

.shadow-turquesa-intenso {
    box-shadow: 0 8px 25px rgba(0, 122, 130, 0.4);
}

.shadow-azul-cielo {
    box-shadow: 0 4px 15px rgba(59, 156, 164, 0.3);
}

/* Cards con nuevo estilo */
.card-premium {
    background-color: var(--blanco-puro);
    border: 1px solid var(--arena-playa);
    transition: all 0.3s ease;
}

.card-premium:hover {
    border-color: var(--turquesa-claro);
    transform: translateY(-5px);
    box-shadow: 0 8px 25px rgba(53, 181, 177, 0.2);
}

/* Service Cards */
.service-card {
    background-color: var(--blanco-puro);
    transition: all 0.3s ease;
}

.service-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 10px 30px rgba(0, 122, 130, 0.15);
}

/* Destinos Cards */
.destino-card {
    transition: all 0.3s ease;
}

.destino-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 10px 30px rgba(53, 181, 177, 0.15);
}

/* Cookie Banner */
.cookie-banner {
    background-color: var(--negro-texto);
    color: var(--blanco-puro);
}

.cookie-banner button {
    background-color: var(--turquesa-oscuro);
    color: var(--blanco-puro);
}

.cookie-banner button:hover {
    background-color: var(--turquesa-claro);
    color: var(--blanco-puro);
}

/* Decorative circles */
.decorative-circle {
    background: linear-gradient(135deg, var(--turquesa-claro), var(--azul-cielo));
    opacity: 0.7;
}

/* Gradientes especiales para elementos destacados */
.gradient-caribe {
    background: linear-gradient(135deg, var(--turquesa-oscuro) 0%, var(--turquesa-claro) 50%, var(--azul-cielo) 100%);
}

.gradient-playa {
    background: linear-gradient(135deg, var(--arena-playa) 0%, var(--amarillo-sol) 100%);
}

.gradient-océano {
    background: linear-gradient(135deg, var(--azul-cielo) 0%, var(--turquesa-oscuro) 100%);
}

/* Responsive */
@media (max-width: 768px) {
    .header-nav a {
        padding: 0.75rem 0;
        border-bottom: 1px solid var(--arena-playa-light);
    }
    
    .header-nav a.active::after {
        display: none;
    }
    
    .header-nav a.active {
        background-color: var(--turquesa-oscuro-light);
        border-radius: 0.5rem;
        margin: 0.25rem 0;
    }
}
