.mobile-only { display: none; }

/* ==================== TABLET (max-width: 1024px) ==================== */
@media (max-width: 1024px) {
    body {
        padding-top: var(--header-h);
    }
    .site-footer__grid {
        grid-template-columns: 1fr 1fr;
        gap: var(--sp-6);
    }
}

/* ==================== MEDIUM (max-width: 920px) ==================== */
@media (max-width: 920px) {
    /* Home page */
    .home-hero { text-align: center; }
    .home-hero__inner { grid-template-columns: 1fr; gap: 48px; }
    .home-hero__text { margin: 0 auto; }
    .home-hero__eyebrow { justify-content: center; }
    .home-hero__ctas { justify-content: center; }
    .home-hero__meta { justify-content: center; }
    .home-hero__photo-wrap { max-width: 380px; margin: 0 auto; width: 100%; }
    .home-hero__photo-badge {
        left: 50%;
        transform: translateX(-50%);
        bottom: -20px;
        width: max-content;
        max-width: calc(100vw - 48px);
        padding: 12px 18px;
    }
    .home-hero__photo-badge-text {
        white-space: normal;
        font-size: 0.72rem;
        line-height: 1.3;
    }
    .home-quote__inner { grid-template-columns: 1fr; gap: 40px; }
    .home-locations__grid { grid-template-columns: 1fr; gap: 32px; }
    .home-cta__inner { grid-template-columns: 1fr; gap: 32px; padding: 56px 40px; text-align: center; }
    .home-cta h2, .home-cta p { margin-left: auto; margin-right: auto; }
    .home-cta__actions { align-items: center; }
    .home-testimonials__card { padding: 48px 32px; }
    .home-testimonials__text { font-size: 1.2rem; }

    /* About page */
    .about-hero__grid { grid-template-columns: 1fr; gap: 48px; }
    .about-hero__photo-col { max-width: 380px; }
    .about-pillars__grid { grid-template-columns: 1fr; }
    .about-facts__grid { grid-template-columns: 1fr; gap: 40px; }
    .about-facts__stats { grid-template-columns: 1fr 1fr; }
    .education-timeline::before { left: 12px; }
    .education-item { grid-template-columns: 80px 1fr; gap: 20px; }
    .education-dot { left: 6px; }
    .education-year { text-align: left; padding-right: 0; font-size: 0.76rem; }

    /* Agendar */
    .booking-container { grid-template-columns: 1fr; }
    .booking-panel--calendar { max-width: 440px; margin: 0 auto; width: 100%; }
    .booking-right > .booking-panel { min-height: auto; }
    .booking-right { width: 100%; }

}

/* ==================== MOBILE (max-width: 768px) ==================== */
@media (max-width: 768px) {
    :root { --gutter: 24px; }

    body {
        padding-top: var(--header-h);
    }

    /* --- Nav toggle --- */
    .nav-toggle { display: flex; }

    .header-cta { display: none; }
    .mobile-only { display: list-item; }

    .main-nav {
        position: fixed;
        top: 76px;
        left: 0;
        right: 0;
        background: rgba(250, 247, 236, 0.97);
        backdrop-filter: blur(12px);
        -webkit-backdrop-filter: blur(12px);
        box-shadow: 0 8px 24px rgba(31,29,23,0.08);
        transform: translateY(-120%);
        z-index: 99;
        border-top: 1px solid var(--border);
    }

    .main-nav.is-animating {
        transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    }

    .main-nav.is-open {
        transform: translateY(0);
    }

    .main-nav ul {
        flex-direction: column;
        padding: 16px 0 24px;
        gap: 0;
        align-items: center;
        width: 100%;
    }

    .main-nav ul li {
        width: 100%;
        text-align: center;
    }

    .main-nav a {
        padding: 14px 24px;
        font-size: 0.92rem;
        display: block;
        width: 100%;
        border-bottom: 1px solid rgba(31,29,23,0.05);
    }

    .main-nav a.is-active::after { display: none; }

    /* --- Home hero --- */
    .home-hero { padding: 48px 0 64px; }
    .home-hero__title { font-size: 2.4rem; }
    .home-hero__ctas { flex-direction: column; align-items: stretch; gap: 10px; }
    .home-hero__meta { gap: 24px; }

    /* --- Home quote --- */
    .home-quote { padding: 80px 0; }
    .home-quote__text { font-size: 1.6rem; }

    /* --- Home locations --- */
    .home-locations { padding: 80px 0; }
    .home-locations__map { min-height: 320px; }

    /* --- Home testimonials --- */
    .home-testimonials { padding: 80px 0; }
    .home-testimonials__card { padding: 40px 24px; min-height: auto; }
    .home-testimonials__text { font-size: 1.1rem; }

    /* --- Home CTA --- */
    .home-cta { padding: 80px 0; }
    .home-cta__inner { padding: 48px 28px; border-radius: var(--radius-lg); text-align: center; }
    .home-cta__actions { align-items: center; }
    .home-cta__actions .btn { width: 100%; max-width: 320px; white-space: normal; height: auto; text-align: center; }

    /* --- About hero --- */
    .about-hero { padding: 48px 0 64px; }
    .about-hero__name { font-size: 3rem; }
    .about-hero__cta-row { flex-direction: column; align-items: stretch; gap: 10px; }

    /* --- About pillars --- */
    .about-pillars { padding: 80px 0; }

    /* --- About education --- */
    .about-education { padding: 80px 0; }
    .education-item { grid-template-columns: 1fr; padding-left: 24px; border-left: 2px solid var(--clay-100); margin-bottom: 28px; position: relative; }
    .education-item::before { content: ''; position: absolute; left: -7px; top: 16px; width: 12px; height: 12px; border-radius: 50%; background: var(--cream-50); border: 2px solid var(--primary); z-index: 1; }
    .education-dot { display: none; }
    .education-year-col { text-align: left; padding-top: 0; padding-bottom: 8px; }
    .education-timeline::before { display: none; }

    /* --- About facts --- */
    .about-facts { padding: 80px 0; }
    .about-facts__stats { grid-template-columns: 1fr; }

    /* --- Agendar --- */
    .ag-hero { padding: 48px 0 32px; }
    .ag-hero h1 { font-size: 2rem; }
    .stepper__inner { overflow-x: auto; gap: 0; white-space: nowrap; }
    .step__line { min-width: 32px; }
    .trust__grid { grid-template-columns: 1fr; gap: 28px; }

    /* --- Footer --- */
    .site-footer { margin-top: var(--sp-7); padding: var(--sp-7) 0 var(--sp-5); }
    .site-footer__grid { grid-template-columns: 1fr 1fr; gap: var(--sp-5); }
    .site-footer__bottom { flex-direction: column; align-items: flex-start; gap: 12px; }
    .footer-regulatory { gap: 12px; }
    .social-icons { margin-top: 14px; }

    /* --- Section title legacy --- */
    .section-title { font-size: 1.75rem; margin-bottom: 28px; }

    /* --- Page hero legacy --- */
    .page-hero { padding: 64px 0 40px; }
    .page-hero__title { font-size: 2rem; }

    /* --- Standard hero blobs --- */
    .standard-hero-blobs { display: none; }

    /* --- WhatsApp FAB --- */
    .whatsapp-fab { bottom: 20px; right: 16px; width: 50px; height: 50px; }

    /* --- Agendar responsive --- */
    .booking-panel { padding: 24px; }
    .slots-grid { grid-template-columns: repeat(2, 1fr); }
    .booking-panel--placeholder { min-height: 180px; }
}

/* ==================== SMALL MOBILE (max-width: 480px) ==================== */
@media (max-width: 480px) {
    :root { --gutter: 16px; }

    /* Home hero */
    .home-hero__title { font-size: 2rem; }
    .home-hero__meta { flex-direction: column; gap: 14px; }

    /* Home testimonials */
    .home-testimonials__card { padding: 36px 20px 56px; }
    .home-testimonials__nav { gap: 8px; }
    .home-testimonials__btn { width: 36px; height: 36px; }

    /* About */
    .about-hero__name { font-size: 2.5rem; }
    .about-facts__stats { grid-template-columns: 1fr 1fr; }

    /* Footer */
    .site-footer__grid { grid-template-columns: 1fr; }
    .footer-regulatory { flex-wrap: wrap; }

    /* Agendar */
    .booking-panel { padding: 18px; }
    .page-hero { padding: 56px 0 32px; }
    .page-hero__title { font-size: 1.75rem; }
}
