/* ===== HERO TABLET ===== */
@media (max-width: 960px) {
    .hero__content {
        max-width: 520px;
    }
}

/* ===== TABLET (1024px) ===== */
@media (max-width: 1024px) {
    .about__inner {
        grid-template-columns: 1fr;
        gap: 48px;
    }

    .about__visual {
        order: -1;
        position: static;
    }

    .about__stats-card {
        max-width: 480px;
    }

    .footer__inner {
        grid-template-columns: 1fr;
        gap: 40px;
    }
}

/* ===== TABLET (900px) ===== */
@media (max-width: 900px) {
    .contact__inner {
        grid-template-columns: 1fr;
        gap: 48px;
    }

    .services__grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .testimonial-card {
        flex: 0 0 calc(50% - 10px);
    }
}

/* ===== NAV MOBILE / DRAWER (768px) ===== */
@media (max-width: 768px) {
    /* ── Overlay ── */
    .nav-overlay {
        display: block;
        position: fixed;
        inset: 0;
        background: rgba(15,23,42,0.45);
        backdrop-filter: blur(2px);
        -webkit-backdrop-filter: blur(2px);
        z-index: 190;
        opacity: 0;
        pointer-events: none;
        transition: opacity 0.3s ease;
    }
    .nav-overlay.open {
        opacity: 1;
        pointer-events: auto;
    }

    /* ── Drawer ── */
    .nav {
        position: fixed;
        top: 0;
        right: 0;
        bottom: 0;
        left: auto;
        width: min(320px, 88vw);
        background: #FFFFFF;
        display: flex;
        flex-direction: column;
        padding: 0 0 32px;
        transform: translateX(100%);
        transition: transform 0.32s cubic-bezier(0.4, 0, 0.2, 1);
        z-index: 195;
        overflow-y: auto;
        box-shadow: -8px 0 40px rgba(0,0,0,0.12);
    }

    .nav.open {
        transform: translateX(0);
    }

    /* ── Topo do drawer ── */
    .nav::before {
        content: '';
        display: block;
        height: 72px;
        flex-shrink: 0;
        border-bottom: 1px solid #E2E8F0;
        background: #FFFFFF;
    }

    /* ── Nav list ── */
    .nav__list {
        flex-direction: column;
        align-items: stretch;
        gap: 0;
        padding: 8px 0;
    }

    .nav__list > li {
        border-bottom: none;
    }

    .nav__link {
        font-size: 0.9375rem;
        font-weight: 600;
        color: #1E293B !important;
        padding: 14px 24px;
        display: flex;
        align-items: center;
        justify-content: space-between;
        width: 100%;
        border-radius: 0;
        transition: background 0.15s, color 0.15s;
    }

    .nav__link:hover {
        color: var(--color-primary) !important;
        background: #FEF9F1;
    }

    /* ── Megamenu mobile: oculto, abre como accordion ── */
    .nav-mega {
        display: none !important;
    }

    /* ── Sub-lista accordion ── */
    .nav-sub__list {
        display: none;
        flex-direction: column;
        padding: 4px 24px 8px 40px;
        gap: 0;
        background: #F8FAFC;
    }

    .nav__item--mega.open .nav-sub__list {
        display: flex;
    }

    .nav-sub__link {
        font-size: 0.875rem;
        font-weight: 500;
        color: #475569;
        padding: 10px 0;
        display: flex;
        align-items: center;
        gap: 8px;
        border-bottom: 1px solid #E2E8F0;
        transition: color 0.15s;
    }

    .nav-sub__link:last-child {
        border-bottom: none;
    }

    .nav-sub__link::before {
        content: '';
        width: 5px;
        height: 5px;
        border-radius: 50%;
        background: var(--color-primary);
        flex-shrink: 0;
        opacity: 0.6;
    }

    .nav-sub__link:hover {
        color: var(--color-primary);
    }

    /* ── Seta do submenu ── */
    .nav__link--has-sub {
        color: #1E293B !important;
    }

    .nav__link--has-sub svg {
        color: #94A3B8;
        transition: transform 0.2s ease;
    }

    .nav__item--mega.open .nav__link--has-sub svg {
        transform: rotate(180deg);
        color: var(--color-primary);
    }

    /* ── CTAs mobile ── */
    .nav__mobile-cta {
        display: flex;
        flex-direction: column;
        gap: 10px;
        padding: 20px 20px 0;
        margin-top: auto;
        border-top: 1px solid #E2E8F0;
    }

    .nav__mobile-btn {
        display: flex;
        align-items: center;
        justify-content: center;
        gap: 10px;
        padding: 13px 20px;
        border-radius: var(--radius-sm);
        font-size: 0.9375rem;
        font-weight: 600;
        transition: var(--transition);
    }

    .nav__mobile-btn--whatsapp {
        background: #25D366;
        color: #fff;
    }

    .nav__mobile-btn--whatsapp:hover {
        background: #1ebe5d;
    }

    .nav__mobile-btn--location {
        background: transparent;
        color: var(--color-primary);
        border: 1.5px solid var(--color-primary);
    }

    .nav__mobile-btn--location:hover {
        background: #FEF9F1;
    }

    /* ── Esconde CTA de agendamento do header ── */
    .header .btn--gradient {
        display: none;
    }

    .hamburger {
        display: flex;
        z-index: 201;
        position: relative;
    }

    .hamburger span {
        background: var(--color-text);
    }

    .hamburger.open span:nth-child(1) {
        transform: translateY(7px) rotate(45deg);
    }

    .hamburger.open span:nth-child(2) {
        opacity: 0;
        transform: scaleX(0);
    }

    .hamburger.open span:nth-child(3) {
        transform: translateY(-7px) rotate(-45deg);
    }
}

/* ===== MOBILE (640px) ===== */
@media (max-width: 640px) {
    :root {
        --section-padding: 64px 0;
        --container-padding: 0 20px;
    }

    /* Hero */
    .hero {
        padding-bottom: 60px;
    }

    .hero__content {
        padding-top: 120px;
        padding-bottom: 60px;
        max-width: 100%;
    }

    /* Specialties — sem overlap no mobile */
    .specialties {
        margin-top: 0;
    }

    .specialties__label {
        color: rgba(255,255,255,0.35);
    }

    .specialty-item span {
        color: rgba(255,255,255,0.5);
    }

    .hero__title {
        font-size: 2.75rem;
    }

    .hero__actions {
        flex-direction: column;
        margin-bottom: 40px;
    }

    .hero__actions .btn {
        text-align: center;
    }

    .hero__stats {
        gap: 28px;
    }

    /* Services */
    .services__grid {
        grid-template-columns: 1fr;
        max-width: 480px;
        margin-left: auto;
        margin-right: auto;
    }

    /* About */
    .about__stats-card {
        flex-direction: column;
        padding: 32px;
    }

    .big-stat {
        padding: 16px 0;
        text-align: left;
    }

    .big-stat + .big-stat {
        border-left: none;
        border-top: 1px solid rgba(255,255,255,0.07);
    }

    /* Testimonials / Reviews */
    .testimonial-card {
        flex: 0 0 calc(100% - 0px);
    }

    .reviews-summary {
        gap: 12px;
    }

    .reviews-summary__score {
        font-size: 2.75rem;
    }

    /* Footer */
    .footer__links {
        grid-template-columns: 1fr 1fr;
    }

    /* CTA */
    .cta-section__title {
        font-size: 1.875rem;
    }
}

/* ===== MEGAMENU TABLET ===== */
@media (max-width: 1100px) {
    .nav__list {
        gap: 16px;
    }

    .nav-mega__grid {
        grid-template-columns: 1fr 1fr 1fr 1fr;
    }

    .nav-mega__intro {
        display: none;
    }

    .nav-mega__card {
        padding: 0 16px;
    }
}

/* ===== LOCALIZAÇÃO + COMO FUNCIONA BLOCO ===== */
@media (max-width: 1024px) {
    .processo-steps {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 640px) {
    /* Localização — stack photos behind, simplify layout */
    .localizacao__visual {
        opacity: 0.35;
    }

    .localizacao__photos {
        grid-template-columns: 1fr;
    }

    .localizacao__content {
        max-width: 100%;
    }

    .localizacao__features {
        flex-direction: column;
        gap: 16px;
    }

    /* Como funciona bloco */
    .processo-steps {
        grid-template-columns: 1fr;
        gap: 16px;
    }
}

/* ===== MOBILE XS (375px) ===== */
@media (max-width: 400px) {
    .hero__title {
        font-size: 2.375rem;
    }

    .footer__links {
        grid-template-columns: 1fr;
    }
}
