/* mobile.css - Estilos responsivos dedicados a dispositivos móveis */

@media (max-width: 1024px) {
    /* Tablets e celulares maiores: traz o foco do banner mais para o centro
       e reduz o respiro entre hero e cases. */
    .hero-bg img {
        object-position: 82% center;
    }

    .cases {
        padding-top: 36px;
    }

    .cases-header {
        margin-bottom: 36px;
    }

    .cases-carousel {
        padding-top: 12px;
        padding-bottom: 12px;
    }

    .cases-slide {
        gap: 18px;
        padding-right: 18px;
    }
}

@media (max-width: 768px) {
    html {
        scroll-padding-top: 110px; /* Compensação menor para o cabeçalho no mobile */
    }

    /* Navbar */
    .navbar {
        padding: 10px 4%;
    }
    
    .nav-links {
        display: none; /* Oculta os links internos no mobile */
    }
    
    .logo-container .logo {
        height: 70px; /* Reduz tamanho do logo para não estourar a tela do mobile */
    }
    
    .nav-action .btn {
        padding: 8px 16px;
        font-size: 0.8rem;
    }

    /* Hero Section (Banner) */
    .hero {
        padding-top: 100px;
        padding-bottom: 24px;
        min-height: auto;
        display: flex;
        flex-direction: column;
        justify-content: center;
        align-items: flex-start;
    }

    .hero-bg img {
        object-position: 82% center; /* Mantém a área principal do banner visível no lado direito */
    }

    .hero-gradient {
        /* Gradiente vertical no mobile para não escurecer a imagem inteira horizontalmente, 
           mantendo a imagem visível no fundo e o texto legível */
        background: linear-gradient(180deg, rgba(5, 8, 12, 0.4) 0%, rgba(5, 8, 12, 0.8) 70%, var(--bg-dark) 100%);
    }

    .hero-content {
        padding: 20px 0;
        z-index: 5;
        max-width: 100%;
    }

    .hero-sidebar {
        display: none; /* Oculta a barra de linhas lateral no mobile */
    }

    .hero-main .subtitle {
        font-size: 0.8rem;
        margin-bottom: 12px;
        text-shadow: 0 1px 3px rgba(0, 0, 0, 0.8);
    }

    .hero-main h1 {
        font-size: 2.2rem;
        margin-bottom: 15px;
        text-shadow: 0 2px 5px rgba(0, 0, 0, 0.9);
    }

    .hero-main p {
        font-size: 0.95rem;
        margin-bottom: 30px;
        text-shadow: 0 1px 3px rgba(0, 0, 0, 0.8);
    }
    
    /* Faz as quebras de linha (<br>) do desktop sumirem para encaixar o texto dinamicamente no mobile */
    .hero-main p br {
        display: none;
    }

    .hero-buttons {
        flex-direction: column;
        gap: 12px;
        width: 100%;
    }

    .hero-buttons .btn {
        width: 100%;
        text-align: center;
        justify-content: center;
    }

    /* Badge flutuante vira cartão no final da seção hero */
    .hero-badge {
        position: relative;
        bottom: auto;
        right: auto;
        margin-top: 30px;
        width: 100%;
        background-color: rgba(13, 21, 32, 0.95);
        justify-content: center;
    }

    /* Seção Cases */
    .cases {
        padding: 24px 0 24px 0;
    }

    .cases-header {
        margin-bottom: 24px;
    }

    .cases-header h2 {
        font-size: 1.8rem;
    }

    .cases-carousel {
        padding: 12px 0;
    }

    .cases-slide {
        gap: 12px;
        padding-right: 12px;
    }

    .case-card {
        width: 260px;
        height: 185px;
        border-radius: 8px;
    }

    .cases-carousel::before,
    .cases-carousel::after {
        width: 10%; /* Gradiente menor no mobile */
    }

    /* Seção de Serviços */
    .services {
        padding: 50px 4%;
    }

    .services-tabs {
        margin-bottom: 30px;
        gap: 10px;
    }

    .tab-btn {
        padding: 10px 20px;
        font-size: 0.8rem;
    }

    .services-grid {
        grid-template-columns: 1fr; /* Um cartão por linha no mobile */
        gap: 15px;
    }

    .service-card {
        padding: 30px 20px;
    }
    
    .card-header {
        margin-bottom: 20px;
    }

    .about-block {
        padding: 30px 10px;
        text-align: center;
    }

    .about-block h2 {
        font-size: 1.6rem;
    }

    .about-block .btn {
        align-self: center;
    }

    /* Barra de Features no rodapé */
    .features-bar {
        padding: 30px 4%;
    }

    .features-container {
        display: grid;
        grid-template-columns: repeat(2, 1fr); /* 2x2 itens fica mais organizado */
        gap: 20px;
        justify-content: center;
    }

    .feature-item {
        flex-direction: column;
        text-align: center;
        align-items: center;
        gap: 8px;
    }

    .floating-whatsapp {
        display: inline-flex;
        bottom: calc(18px + env(safe-area-inset-bottom));
        right: calc(18px + env(safe-area-inset-right));
        padding: 13px 16px;
    }
}

@media (max-width: 480px) {
    .features-container {
        grid-template-columns: 1fr; /* Coluna única para celulares muito pequenos */
    }
    
    .hero-main h1 {
        font-size: 1.8rem;
    }

    .cases-header p {
        font-size: 0.98rem;
    }
    
    .logo-container .logo {
        height: 60px;
    }

    .floating-whatsapp {
        right: 14px;
        bottom: calc(14px + env(safe-area-inset-bottom));
        padding: 12px 14px;
    }

    .floating-whatsapp span {
        font-size: 0.82rem;
    }
}
