/* =========================
   TABLET GRANDE
========================= */
@media (max-width: 1100px) {
    .card-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .benefits-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .gallery-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

/* =========================
   TABLET
========================= */
@media (max-width: 900px) {
    .split,
    .register-box {
        grid-template-columns: 1fr;
    }

    .hero {
        min-height: auto;
        background-position: 62% center;
    }

    .hero-content {
        max-width: 100%;
        padding: 110px 0 90px;
    }

    .nav {
        gap: var(--space-md);
    }

    .nav-links {
        display: none;
    }

    .gallery-grid .image-box,
    .gallery-grid .image-box img {
        height: 280px;
        min-height: 280px;
    }
}

/* =========================
   MÓVIL
========================= */
@media (max-width: 640px) {
    .section {
        padding: var(--space-3xl) 0;
    }

    .header-inner {
        min-height: 64px;
        gap: 12px;
    }

    .brand {
        gap: 10px;
        min-width: 0;
    }

    .brand img {
        width: 42px;
        height: 42px;
        flex-shrink: 0;
    }

    .brand-text {
        min-width: 0;
    }

    .brand-text strong {
        font-size: 0.92rem;
        line-height: 1.1;
    }

    .brand-text span {
        font-size: 0.78rem;
    }

    .nav-links {
        display: none;
    }

    /* Ocultamos el CTA del header en móvil */
    .nav .btn {
        display: none;
    }

    .hero {
        min-height: auto;
        background-position: 64% center;
    }

    .hero-content {
        padding: 78px 0 72px;
    }

    .hero-badge {
        max-width: 100%;
        font-size: 0.75rem;
        line-height: 1.4;
        padding: 8px 14px;
    }

    .hero h1 {
        max-width: 100%;
        margin-bottom: 18px;
    }

    .hero .lead,
    .hero-highlight,
    .hero-highlight-strong,
    .hero-note {
        max-width: 100%;
    }

    .hero .lead {
        font-size: 1.05rem;
    }

    .hero-highlight {
        font-size: 1.02rem;
    }

    .hero-highlight-strong {
        font-size: 1.08rem;
    }

    .hero-actions {
        flex-direction: column;
        align-items: stretch;
        gap: 14px;
    }

    .hero-actions .btn {
        width: 100%;
    }

    .card-grid,
    .benefits-grid,
    .gallery-grid {
        grid-template-columns: 1fr;
    }

    .gallery-grid .image-box,
    .gallery-grid .image-box img {
        height: 250px;
        min-height: 250px;
    }

    .card,
    .benefit-card,
    .register-copy,
    .register-form {
        padding: 24px 20px;
    }

    .footer-inner {
        flex-direction: column;
        align-items: flex-start;
    }
}
/* =========================
   EXPERIENCIA MÓVIL
========================= */
@media (max-width: 640px) {
    .experience-grid {
        gap: 16px;
    }

    .experience-card {
        padding: 22px 18px;
        border-radius: 18px;
    }

    .experience-card h3 {
        font-size: 1.05rem;
        margin-bottom: 10px;
    }

    .experience-card p {
        font-size: 0.98rem;
        line-height: 1.55;
    }
}
@media (max-width: 640px) {
    .section-actions,
    .final-cta-actions {
        flex-direction: column;
        align-items: stretch;
    }

    .section-actions .btn,
    .final-cta-actions .btn {
        width: 100%;
    }

    .final-cta-box {
        padding: 28px 20px;
    }
}