
/* ========== SECCIÃ“N: ANIMALES DESTACADOS ========== */
.featured-animals {
    padding: 1rem 0 2rem 0;
    background: #ffffff;
    box-sizing: border-box;
}
.featured-grid {
    display: grid;
    /* En PC se adapta automÃ¡ticamente, igual que tus otras secciones */
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 2rem;
    margin-top: 2rem;
}
.featured-card {
    background: white;
    border-radius: 1.5rem;
    overflow: hidden;
    box-shadow: 0 10px 25px rgba(0,0,0,0.08);
    transition: all 0.3s;
    display: flex;
    flex-direction: column;
}
.featured-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 20px 35px rgba(0,0,0,0.12);
}
.featured-card img {
    width: 100%;
    height: 200px;
    object-fit: cover;
}
.featured-card__body {
    padding: 1.5rem;
    text-align: center;
    display: flex;
    flex-direction: column;
    flex: 1;
}
.featured-card__body h3 {
    color: #6A1B9A;
    font-size: 1.5rem;
    margin-bottom: 0.5rem;
}
.featured-card__body p {
    color: #5C5348;
    margin-bottom: 1.2rem;
    flex: 1; 
}
.btn--sm {
    padding: 0.5rem 1.5rem;
    font-size: 0.9rem;
    display: inline-block;
}

/* ========== SECCIÃ“N: EDUCACIÃ“N (RESUMEN) ========== */
.edu-summary {
    padding: 1rem 0 4rem 0;
    background: white;
    box-sizing: border-box;
}
.education__grid {
    display: grid;
    /* Comportamiento fluido en PC, igual que animales */
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 2rem;
    margin-top: 2rem;
}
.education__feature {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    padding: 2rem;
    background: #fdfcf0;
    border-radius: 1.5rem;
    transition: transform 0.3s;
    box-sizing: border-box;
    gap: 0.5rem;
}
.education__feature-icon {
    font-size: 2.5rem;
    margin-bottom: 0.5rem;
}
.education__feature h4 {
    color: #1e3b2f;
    font-size: 1.25rem;
    margin-bottom: 0.2rem;
}
.education__feature p {
    color: #5c5348;
    margin: 0;
}

/* ========== SECCIÃ“N: TESTIMONIOS (COMENTARIOS) ========== */
.testimonials {
    padding: 4rem 0;
    background: #ffffff;
    box-sizing: border-box;
}
.testimonials__grid {
    display: grid;
    /* Comportamiento fluido en PC, igual que animales */
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 1.5rem;
    margin-top: 2rem;
}
.testimonial-card {
    background: white;
    padding: 1.5rem;
    border-radius: 1.2rem;
    box-shadow: 0 8px 20px rgba(0,0,0,0.05);
    display: flex;
    flex-direction: column;
}
.testimonial-card__text {
    font-style: italic;
    color: #5c5348;
    margin-bottom: 1rem;
    font-size: 0.95rem;
    line-height: 1.5;
}
.testimonial-card__user {
    display: flex;
    align-items: center;
    gap: 0.8rem;
    margin-top: auto;
}
.testimonial-card__avatar {
    width: 45px;
    height: 45px;
    border-radius: 50%;
    object-fit: cover;
}
.testimonial-card__name {
    font-weight: 700;
    color: #1e3b2f;
    font-size: 0.9rem;
}

/* ========== SECCIÃ“N: PLANIFICA TU VISITA ========== */
.visit-summary {
    padding: 4rem 0;
    background: #ffffff;
    box-sizing: border-box;
}
.visit-summary .visit__card {
    text-align: center;
    box-sizing: border-box;
}

/* ========== DECORACIÃ“N LATERAL (HOJAS) ========== */
.content-with-leaves {
    position: relative;
    overflow-x: clip; 
}
.leafs-left, .leafs-right {
    position: absolute;
    top: 0; bottom: 0;
    display: flex;
    flex-direction: column;
    justify-content: space-around; 
    pointer-events: none;   
    z-index: 1;
    opacity: 0.5;           
    font-size: 1.5rem;
    gap: 0.4rem;
}
.leafs-left { left: 5px; }
.leafs-right { right: 5px; }
.leafs-left i, .leafs-right i {
    color: #2e7d32;
    filter: drop-shadow(0 1px 2px rgba(0,0,0,0.1));
    transition: transform 0.2s;
}
.leafs-left i:nth-child(3n) { color: #1b5e20; }
.leafs-left i:nth-child(3n+1) { color: #4caf50; }
.leafs-left i:nth-child(3n+2) { color: #388e3c; }
.leafs-right i:nth-child(3n) { color: #66bb6a; }
.leafs-right i:nth-child(3n+1) { color: #2e7d32; }
.leafs-right i:nth-child(3n+2) { color: #1b5e20; }
.leafs-left i { transform: rotate(-5deg); }
.leafs-left i:nth-child(even) { transform: rotate(8deg); }
.leafs-left i:nth-child(3n) { transform: rotate(-12deg); }
.leafs-right i { transform: rotate(5deg); }
.leafs-right i:nth-child(even) { transform: rotate(-8deg); }
.leafs-right i:nth-child(3n) { transform: rotate(12deg); }


/* ========== OPTIMIZACIÃ“N PARA PC ========== */
@media (min-width: 769px) {
    .visit-summary .visit__grid {
        flex-direction: column;  
        align-items: center;      
    }
    .visit-summary .visit__info {
        display: flex;
        gap: 2rem;
        justify-content: center;
        width: 100%;
        max-width: 900px;        
    }
    .visit-summary .visit__card {
        flex: 1 1 300px;
        max-width: 400px;
    }
    .visit-summary .visit__grid > div:last-child {
        width: 100%;
        max-width: 500px;
        margin-top: 2rem;
    }
}


/* =========================================================
   DISEÃ‘O RESPONSIVO (MÃ“VILES - TODO DE 2 EN 2) 
   ========================================================= */
@media (max-width: 768px) {
    /* Ajustes generales de la pÃ¡gina */
    .edu-summary,
    .testimonials,
    .visit-summary {
        padding: 2.5rem 1rem;
        background: transparent; 
    }

    /* 1. Animales destacados AJUSTADO EXACTO A LA PÃGINA ANIMALES */
    .featured-animals {
        padding: 2.5rem 0 !important; /* Quitamos el padding lateral para ganar ancho real */
        background: transparent;
    }
    .featured-animals .container {
        padding-left: 0.8rem !important;  /* Mismo espacio horizontal que la otra pÃ¡gina */
        padding-right: 0.8rem !important;
    }
    .featured-grid {
        grid-template-columns: repeat(2, 1fr) !important; 
        gap: 0.8rem !important; /* Mismo espacio entre tarjetas */
        margin-top: 1.5rem;
    }
    .featured-card { 
        border-radius: 1.2rem; /* Mismo radio de borde */
    }
    .featured-card img { 
        height: 140px !important; /* Misma altura proporcional */
    }
    .featured-card__body { 
        padding: 0.8rem; /* Mismo padding interno */
    }
    .featured-card__body h3 { 
        font-size: 1rem; 
        margin-bottom: 0.2rem; 
    } 
    .featured-card__body p { 
        font-size: 0.75rem; 
        margin-bottom: 0.8rem; 
        line-height: 1.3; 
    } 
    .btn--sm { 
        padding: 0.5rem 1rem; 
        font-size: 0.8rem; 
    }

    /* 2. EducaciÃ³n FORZADO a 2 columnas */
    .education__grid {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 0.8rem;
    }
    .education__feature {
        padding: 1.2rem 0.8rem;
        border-radius: 1rem;
    }
    .education__feature-icon { font-size: 1.8rem; margin-bottom: 0.5rem; }
    .education__feature h4 { font-size: 0.95rem; margin-bottom: 0.4rem; line-height: 1.2;}
    .education__feature p { font-size: 0.8rem; line-height: 1.2; }

    /* 3. Testimonios FORZADO a 2 columnas */
    .testimonials__grid {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 0.8rem;
    }
    .testimonial-card {
        padding: 1rem;
        border-radius: 1rem;
    }
    .testimonial-card__text {
        font-size: 0.75rem; 
        line-height: 1.3;
        margin-bottom: 0.8rem;
    }
    .testimonial-card__avatar { width: 35px; height: 35px; }
    .testimonial-card__name { font-size: 0.75rem; }

    /* Hojas decorativas */
    .leafs-left, .leafs-right {
        font-size: 1rem;
        gap: 0.2rem;
        opacity: 0.3;
    }
}

@media (max-width: 480px) {
    .leafs-left, .leafs-right { display: none; }
    
    .testimonial-card__user {
        flex-direction: column;
        text-align: center;
        gap: 0.4rem;
    }
    .testimonial-card__name { line-height: 1.1; }
}/* ========== CARRUSEL DE RESEÃ‘AS (JS CONTINUO) ========== */
.reviews-carousel {
    overflow: hidden;
    width: 100%;
    position: relative;
}

.reviews-track {
    display: flex;
    gap: 1rem;
    /* La animaciÃ³n ahora se controla con JS, no con CSS */
    will-change: transform;
}

/* Tarjetas igual que antes */
.review-card {
    background: white;
    border-radius: 1rem;
    padding: 1rem 0.9rem;
    box-shadow: 0 8px 20px rgba(0,0,0,0.05);
    border: 2px solid #f1c40f;
    flex-shrink: 0;
    width: 220px;
    display: flex;
    flex-direction: column;
}
.review-card .review-header {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin-bottom: 0.6rem;
}
.review-card .review-avatar {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    object-fit: cover;
    border: 2px solid #FFB74D;
}
.review-card .review-name {
    font-family: 'Outfit', sans-serif;
    font-size: 0.85rem;
    color: #2E4053;
    line-height: 1.2;
}
.review-card .review-stars {
    color: #F1C40F;
    font-size: 0.75rem;
    margin-top: 0.2rem;
}
.review-card .review-text {
    color: #5C5348;
    font-style: italic;
    font-size: 0.72rem;
    line-height: 1.35;
    flex: 1;
    overflow: hidden;
    display: -webkit-box;
    -webkit-line-clamp: 5;
    -webkit-box-orient: vertical;
}
.review-card .review-source {
    font-size: 0.65rem;
    color: #888;
    margin-top: 0.5rem;
}

/* MÃ³vil */
@media (max-width: 768px) {
    .review-card {
        width: 72vw;
        padding: 0.9rem 0.8rem;
    }
    .reviews-track {
        gap: 0.8rem;
    }
    .review-card .review-avatar {
        width: 30px;
        height: 30px;
    }
    .review-card .review-name {
        font-size: 0.8rem;
    }
    .review-card .review-text {
        font-size: 0.7rem;
        -webkit-line-clamp: 4;
    }
}/* ========== SECCIÃ“N DE VIDEOS (3 EN FILA, TAMAÃ‘O AMPLIO, CONTROLES FUNCIONALES) ========== */
.visit__video-section {
    width: 100%;
    max-width: 1400px;        /* ancho amplio */
    margin: 2rem auto 0 auto;
    padding: 0 1.5rem;
    box-sizing: border-box;
}

.visit__video-title {
    font-family: 'Outfit', sans-serif;
    font-size: 2rem;
    color: var(--color-deep-green);
    margin-bottom: 2rem;
    text-align: center;
}

.visit__video-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr); /* 3 columnas iguales */
    gap: 2rem;
    width: 100%;
}

.visit__video-item {
    display: flex;
    flex-direction: column;
    align-items: center;
}

.visit__video-container {
    position: relative;
    width: 100%;                 /* ocupa todo el ancho disponible de la celda */
    /* max-width eliminado para que crezcan mÃ¡s */
    border-radius: 1rem;
    overflow: hidden;
    box-shadow: 0 10px 20px rgba(0,0,0,0.1);
    background: #000;
    aspect-ratio: 16 / 9;
    cursor: pointer;
}

.visit__video {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: cover;
}

/* Ãcono de play personalizado */
.visit__video-play-icon {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    font-size: 2.5rem;
    color: white;
    background: rgba(0,0,0,0.6);
    border-radius: 50%;
    width: 60px;
    height: 60px;
    display: flex;
    align-items: center;
    justify-content: center;
    pointer-events: none;
    transition: opacity 0.3s ease;
    opacity: 1;
}

.visit__video-container.is-playing .visit__video-play-icon {
    opacity: 0;
}

.visit__video-caption {
    margin-top: 0.6rem;
    font-size: 1rem;
    color: var(--color-text-light);
    text-align: center;
    font-weight: 500;
}

/* ========== MÃ“VIL ========== */
@media (max-width: 768px) {
    .visit__video-section {
        max-width: 100%;
        padding: 0 1rem;
    }
    .visit__video-grid {
        grid-template-columns: 1fr;       /* una columna */
        gap: 1.5rem;
    }
    .visit__video-title {
        font-size: 1.6rem;
    }
}
/* ========== SECCIONES AÑADIDAS DESDE REFERENCIA ========== */
.section-label{display:block;font-size:.78rem;font-weight:600;color:var(--color-leaf-green);letter-spacing:.18em;text-transform:uppercase;margin-bottom:8px}
.section-title{font-family:var(--font-heading);font-size:clamp(1.8rem,3vw,2.6rem);color:var(--color-deep-green);margin-bottom:16px}
.section-line{width:56px;height:3px;background:var(--color-sunset-gold);margin-bottom:24px}
#inicio-about{background: #ffffff;display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center;max-width:1200px;margin:0 auto;padding: 50px 20px 10px 20px}
.about-img-wrap{position:relative;border-radius:var(--border-radius);overflow:hidden;aspect-ratio:4/3; max-height:600px;box-shadow:var(--shadow-card)}
.about-img-wrap img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.about-img-wrap:hover img{transform:scale(1.04)}
.about-badge{position:absolute;bottom:20px;right:20px;background:var(--color-deep-green);color:white;border-radius:12px;padding:14px 18px;text-align:center;box-shadow:var(--shadow-card)}
.about-badge strong{font-family:var(--font-heading);font-size:1.8rem;display:block;color:var(--color-sunset-gold)}
.about-badge span{font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;opacity:.85}
.about-text p{color:var(--color-text-light);line-height:1.8;margin-bottom:16px;font-size:1.02rem}
.features-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:24px}
.feature-item{background:var(--color-deep-green);border-radius:var(--border-radius);padding:20px;display:flex;gap:16px;align-items:flex-start;box-shadow:var(--shadow-card);transition:var(--transition)} .feature-item:hover{transform:translateY(-5px)}
.feature-icon{font-size:1.6rem;flex-shrink:0;margin-top:2px;color:var(--color-sunset-gold);background:rgba(212,155,59,0.15);padding:10px;border-radius:50%;display:flex;align-items:center;justify-content:center;width:45px;height:45px}
.feature-item h4{font-family:var(--font-heading);font-size:1.05rem;font-weight:600;color:var(--color-sunset-gold);margin-bottom:4px}
.feature-item p{font-family:var(--font-body);font-size:.85rem;color:rgba(255,255,255,0.85);line-height:1.6;margin:0}
#animales{background:white;max-width:100%}
.animales-header{text-align:center;margin-bottom:50px;max-width:1200px;margin-left:auto;margin-right:auto}
.animales-header .section-line{margin:0 auto 24px}
.animales-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(270px,1fr));gap:28px;max-width:1200px;margin:0 auto}
.animal-card{background:var(--color-cream);border-radius:var(--border-radius);overflow:hidden;box-shadow:0 4px 20px rgba(0,0,0,.10);transition:var(--transition);cursor:pointer}
.animal-card:hover{transform:translateY(-8px);box-shadow:0 12px 36px rgba(0,0,0,.18)}
.card-img{position:relative;height:210px;overflow:hidden;background:var(--color-deep-green)}
.card-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.animal-card:hover .card-img img{transform:scale(1.08)}
.card-badge{position:absolute;top:14px;left:14px;padding:5px 12px;border-radius:20px;font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:white}
.badge-felino{background:#e07b39}.badge-ave{background:#7b5ea7}.badge-roedor{background:#c4971f;color:var(--color-text)}.badge-reptil{background:#3a8a4f}.badge-mamifero{background:#3a6ea8}.badge-primate{background:#a84a3a}
.card-body{padding:20px 22px}
.card-body h3{font-family:var(--font-heading);font-size:1.25rem;color:var(--color-deep-green);margin-bottom:4px}
.card-body .sci{font-size:.8rem;color:var(--color-text-light);font-style:italic;margin-bottom:10px}
.card-body p{font-size:.85rem;color:var(--color-text-light);line-height:1.6}
#horarios{background:var(--color-deep-green);color:white;text-align:center;position:relative;overflow:hidden}
#horarios::before{content:'';position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='%2352b788' fill-opacity='0.06'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/svg%3E")}
#horarios .section-title{color:var(--color-white)}
#horarios .section-label{color:var(--color-sunset-gold)}
#horarios .section-line{background:var(--color-sunset-gold);margin:0 auto 40px}

.horario-card{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);border-radius:var(--border-radius);padding:28px 20px;backdrop-filter:blur(4px)}
.horario-card .ico{font-size:2rem;margin-bottom:10px}
.horario-card h3{font-family:var(--font-heading);font-size:1.05rem;color:var(--color-sunset-gold);margin-bottom:8px}
.horario-card p{font-size:.9rem;color:rgba(255,255,255,.78);line-height:1.6}
.precios-table{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.14);border-radius:var(--border-radius);overflow:hidden;max-width:480px;margin:0 auto;position:relative}
.precios-row{display:flex;justify-content:space-between;align-items:center;padding:16px 28px;border-bottom:1px solid rgba(255,255,255,.08);font-size:.95rem}
.precios-row:last-child{border-bottom:none}
.precio-label{color:rgba(255,255,255,.8)}
.precio-val{font-family:var(--font-heading);font-size:1.25rem;color:var(--color-sunset-gold);font-weight:700;white-space:nowrap;flex-shrink:0}
#contacto{background: #ffffff;padding: 10px 20px 40px 20px}
.contacto-inner{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:start}
.contacto-info .section-line{margin-bottom:28px}
.contacto-info p{color:var(--color-text-light);line-height:1.8;margin-bottom:28px;font-size:1.02rem}
.contact-items{display:flex;flex-direction:column;gap:16px}
.contact-item{display:flex;align-items:flex-start;gap:16px;background:white;border-radius:12px;padding:18px 20px;box-shadow:0 2px 14px rgba(0,0,0,.07)}
.contact-item .ci-ico{width:42px;height:42px;background:var(--color-jungle-green);color:white;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0}
.contact-item h4{font-size:.8rem;color:var(--color-text-light);text-transform:uppercase;letter-spacing:.06em;margin-bottom:2px}
.contact-item p{font-size:.95rem;color:var(--color-text);font-weight:500;margin:0}
.contacto-form{background:white;border-radius:var(--border-radius);padding:36px 32px;box-shadow:var(--shadow-card)}
.contacto-form h3{font-family:var(--font-heading);font-size:1.5rem;color:var(--color-deep-green);margin-bottom:24px}
.form-group{margin-bottom:18px}
.form-group label{display:block;font-size:.82rem;font-weight:600;color:var(--color-deep-green);margin-bottom:6px;letter-spacing:.04em}
.form-group input,.form-group textarea,.form-group select{width:100%;padding:12px 16px;border:1.5px solid #d8e8d8;border-radius:10px;font-family:var(--font-body);font-size:.92rem;color:var(--color-text);background:var(--color-cream);outline:none;transition:border .25s}
.form-group input:focus,.form-group textarea:focus{border-color:var(--color-leaf-green);background:white}
.form-group textarea{resize:vertical;min-height:110px}
.form-submit{width:100%;padding:14px;background:var(--color-jungle-green);color:white;border:none;border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer;transition:var(--transition);font-family:var(--font-body)}
.form-submit:hover{background:var(--color-deep-green);transform:translateY(-2px)}
@keyframes fadeUp{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}





/* Responsive para las nuevas secciones */
@media(max-width:900px) {
  #inicio-about {grid-template-columns:1fr;padding:50px 24px}
  .contacto-inner {grid-template-columns:1fr}
}
@media(max-width:600px) {
  section {padding:50px 20px}
  }








/* Fix for badge size on mobile */
@media(max-width:600px) {
  .about-badge {
    bottom: 10px;
    right: 10px;
    padding: 8px 12px;
  }
  .about-badge strong {
    font-size: 1.2rem;
  }
  .about-badge span {
    font-size: 0.65rem;
  }
}


/* Estado del formulario */
.form-status {
    margin-top: 0.5rem;
    font-weight: 600;
    font-size: 0.95rem;
    display: block;
}
.form-status.success { color: #2ECC71; }
.form-status.error { color: #E74C3C; }
.form-status.loading { color: #F39C12; }

/* Contador de caracteres */
.char-counter {
    font-size: 0.8rem;
    color: #888;
    text-align: right;
    margin-top: 0.3rem;
}
.char-counter.limit-reached {
    color: #E74C3C;
    font-weight: 600;
}

/* =========== NUEVO LAYOUT HORARIOS Y PRECIOS =========== */
.horarios-wrapper {
    display: grid;
    grid-template-columns: 1.1fr 0.9fr;
    gap: 40px;
    max-width: 1100px;
    margin: 0 auto 30px auto;
    align-items: start;
    text-align: left;
    position: relative;
    z-index: 2;
}
.horarios-info, .precios-info {
    background: rgba(255,255,255,0.04);
    padding: 35px;
    border-radius: var(--border-radius);
    border: 1px solid rgba(255,255,255,0.1);
    box-shadow: 0 10px 30px rgba(0,0,0,0.15);
    backdrop-filter: blur(5px);
}
.horarios-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
    margin: 0;
}
/* Reajustar la tarjeta dentro del grid nuevo */
.horario-card {
    padding: 20px 16px;
    background: rgba(255,255,255,0.05);
}
.precios-table {
    max-width: 100%;
    margin: 0;
    box-shadow: none;
    background: rgba(255,255,255,0.05);
}
.precios-row {
    padding: 20px 24px;
}
@media (max-width: 900px) {
    .horarios-wrapper {
        grid-template-columns: 1fr;
        gap: 25px;
    }
    .horarios-grid {
        grid-template-columns: 1fr;
    }
    .horarios-info, .precios-info {
        padding: 25px 20px;
    }
}


@media (max-width: 768px) {
    #inicio-about { grid-template-columns: 1fr; gap: 20px; padding: 30px 15px; }
    .about-img-wrap { max-height: 180px !important; aspect-ratio: 2.5/1 !important; }
    .about-badge { display: none !important; }
    .features-grid { grid-template-columns: 1fr; }
    #contacto { padding: 40px 15px; }
    .contacto-inner { gap: 25px; }
    .contacto-form { padding: 24px 18px; }
    .contact-item { padding: 14px 16px; }
}



/* ========== FAQ SECTION ========== */
.faq-section {
    padding: 1rem 0 2rem 0;
    background: #ffffff;
    box-sizing: border-box;
}
.faq-grid {
    max-width: 800px;
    margin: 2rem auto 0;
    display: flex;
    flex-direction: column;
    gap: 1rem;
}
.faq-item {
    background: white;
    border-radius: 1rem;
    overflow: hidden;
    box-shadow: 0 4px 15px rgba(0,0,0,0.06);
    transition: box-shadow 0.3s;
}
.faq-item:hover {
    box-shadow: 0 6px 20px rgba(0,0,0,0.1);
}
.faq-question {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 1.2rem 1.5rem;
    background: none;
    border: none;
    width: 100%;
    text-align: left;
    font-family: var(--font-body);
    font-size: 1.05rem;
    font-weight: 600;
    color: var(--color-deep-green);
    gap: 1rem;
    transition: background 0.3s;
}
.faq-question:hover {
    background: rgba(0,0,0,0.02);
}
.faq-question .faq-icon {
    font-size: 1.5rem;
    font-weight: 300;
    transition: transform 0.3s;
    flex-shrink: 0;
    color: var(--color-sunset-gold);
}
.faq-item.active .faq-icon {
    transform: rotate(45deg);
}
.faq-answer {
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.4s ease, padding 0.4s ease;
    padding: 0 1.5rem;
}
.faq-item.active .faq-answer {
    max-height: 200px;
    padding: 0 1.5rem 1.2rem;
}
.faq-answer p {
    color: var(--color-text-light);
    line-height: 1.7;
    font-size: 0.95rem;
}
@media (max-width: 768px) {
    .faq-question { font-size: 0.95rem; padding: 1rem 1.2rem; }
    .faq-answer p { font-size: 0.85rem; }
}

/* ========== PROMO POPUP ========== */
.promo-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0,0,0,0.6);
    backdrop-filter: blur(4px);
    z-index: 10000;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    visibility: hidden;
    transition: all 0.4s ease;
}
.promo-overlay.active {
    opacity: 1;
    visibility: visible;
}
.promo-popup {
    background: white;
    border-radius: 1.5rem;
    padding: 2.5rem;
    max-width: 450px;
    width: 90%;
    text-align: center;
    position: relative;
    transform: scale(0.8);
    transition: transform 0.4s ease;
    box-shadow: 0 25px 60px rgba(0,0,0,0.3);
}
.promo-overlay.active .promo-popup {
    transform: scale(1);
}
body.dark-mode .promo-popup { background: #1e1e2e; }
.promo-close {
    position: absolute;
    top: 15px;
    right: 15px;
    background: none;
    border: none;
    font-size: 1.5rem;
    color: #999;
    width: 35px;
    height: 35px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.3s;
}
.promo-close:hover { background: rgba(0,0,0,0.1); color: #333; }
.promo-emoji { font-size: 3.5rem; margin-bottom: 1rem; }
.promo-popup h3 {
    font-family: var(--font-heading);
    font-size: 1.6rem;
    color: var(--color-deep-green);
    margin-bottom: 0.8rem;
}
body.dark-mode .promo-popup h3 { color: #7BA05B; }
.promo-popup p {
    color: var(--color-text-light);
    font-size: 1rem;
    line-height: 1.6;
    margin-bottom: 1.5rem;
}
body.dark-mode .promo-popup p { color: #b0b0b0; }
.promo-popup .btn { width: 100%; justify-content: center; }

/* ========== WEATHER WIDGET (LIQUID GLASS) ========== */
.weather-widget {
    position: absolute;
    top: calc(50% - 270px); /* Ligeramente más arriba según la solicitud */
    right: 3%; /* Cerca de la barra de deslizar pero con respiro */
    z-index: 10;
    background: rgba(255, 255, 255, 0.15);
    backdrop-filter: blur(16px) saturate(180%);
    -webkit-backdrop-filter: blur(16px) saturate(180%);
    padding: 12px 20px;
    border-radius: 16px;
    box-shadow: 0 8px 32px rgba(0,0,0,0.15);
    display: flex;
    align-items: center;
    gap: 12px;
    font-family: var(--font-body);
    color: white;
    border: 1px solid rgba(255, 255, 255, 0.3);
    transition: all 0.3s ease;
}
.weather-widget i {
    font-size: 1.8rem;
    color: #F1C40F; /* Sol amarillo brillante */
    text-shadow: 0 0 10px rgba(241, 196, 15, 0.5);
}
.weather-info {
    display: flex;
    flex-direction: column;
}
.weather-temp {
    font-weight: 700;
    font-size: 1.3rem;
    line-height: 1;
    text-shadow: 0 2px 4px rgba(0,0,0,0.3);
}
.weather-city {
    font-size: 0.75rem;
    color: rgba(255, 255, 255, 0.85);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-top: 2px;
}
body.dark-mode .weather-widget {
    background: rgba(0, 0, 0, 0.25);
    border-color: rgba(255, 255, 255, 0.15);
    box-shadow: 0 8px 32px rgba(0,0,0,0.4);
}
body.dark-mode .weather-city {
    color: rgba(255, 255, 255, 0.7);
}

@media (max-width: 768px) {
    .weather-widget {
        display: none !important;
    }
}

@media (min-width: 993px) {
    .education__feature {
        flex-direction: row;
        text-align: left;
        align-items: center;
        padding: 2rem 3rem;
    }
    .education__feature-icon {
        margin-bottom: 0;
        margin-right: 1.5rem;
        font-size: 3rem;
    }
}
