/* css/style.css */

/* --- Configurações Globais e Fontes --- */
body {
    font-family: 'Roboto', sans-serif;
    padding-top: 75px; /* Altura do header fixo ajustada */
    background-color: #f7f7f7; /* Fundo levemente acinzentado para destacar os cards */
}

/* --- AJUSTES PARA HEADER MODERNO E HARMONICO --- */

/* Estilo do Header na Home Page ANTES da rolagem */
body.is-home header .navbar {
    background-color: f7f7f7; /* Fundo transparente */
    box-shadow: none !important; /* Sem sombra inicial */
    transition: background-color 0.4s ease-out, box-shadow 0.4s ease-out; /* Transição suave */
}

/* Altera a cor dos links para branco para contrastar com o banner escuro */
body.is-home header .navbar-nav .nav-link,
body.is-home header .navbar-toggler-icon {
    color: var(--pedeqr-primary-color) !important
}

/* Mantém os botões visíveis */
body.is-home header .btn-outline-dark {
    border: 1px solid var(--pedeqr-primary-color);
    border-radius: 25px;
    color: var(--pedeqr-primary-color);
	font-weight: bold;
}
body.is-home header .btn-outline-dark:hover {
    background-color: rgba(255, 255, 255, 0.9);
}

/* Classe que será adicionada via JavaScript na rolagem */
header .navbar.scrolled {
    background-color: #ffffff !important; /* Volta a ser branco */
    box-shadow: 0 0.125rem 0.25rem rgba(0, 0, 0, 0.075) !important; /* Adiciona a sombra suave */
}

/* Garante que os links voltem à cor escura quando o fundo for branco */
header .navbar.scrolled .navbar-nav .nav-link {
    color: var(--pedeqr-dark-color) !important;
}
header .navbar.scrolled .navbar-nav .nav-link:hover {
    color: var(--pedeqr-primary-color) !important;
}

header .navbar.scrolled .btn-outline-dark {
    color: #212529; /* Cor original do Bootstrap */
    border-color: #212529;
}

.navbar.fixed-top {
    padding-top: 0.2rem;
    padding-bottom: 0.2rem;	
    background-color: #f8f9fa !important; /* Um cinza muito claro em vez de branco puro */
    box-shadow: 0 2px 15px rgba(43, 45, 66, 0.08) !important; /* Sombra mais suave e difundida */
	    /* Adicione esta linha às regras anteriores */
    border-top: 3px solid var(--pedeqr-primary-color); /* Usa a cor primária do seu site */
}

h1, h2, h3, h4, h5, h6 {
    font-family: 'Poppins', sans-serif;
    font-weight: 700; /* Títulos mais fortes */
}

/* --- Novas Cores e Tema "Fast Food" --- */
:root {
    --pedeqr-primary-color: #e63946; /* Vermelho vibrante */
    --pedeqr-secondary-color: #fca311; /* Amarelo/Laranja como destaque */
    --pedeqr-dark-color: #2b2d42; /* Um azul/cinza escuro para texto */
    --pedeqr-light-color: #edf2f4; /* Cor clara para fundos de seção */
    
    /* Cores Hover */
    --pedeqr-primary-hover-color: #d62828;
    --pedeqr-secondary-hover-color: #e89200;
}

/* Classes de utilidade com as novas cores */
.text-pedeqr-primary { color: var(--pedeqr-primary-color) !important; }
.bg-pedeqr-primary { background-color: var(--pedeqr-primary-color) !important; }
.text-pedeqr-secondary { color: var(--pedeqr-secondary-color) !important; }
.bg-pedeqr-secondary { background-color: var(--pedeqr-secondary-color) !important; }

.btn-primary-pedeqr {
    background-color: var(--pedeqr-primary-color);
    border-color: var(--pedeqr-primary-color);
    color: #fff;
    font-weight: 600;
    padding: 10px 25px;
    border-radius: 50px; /* Botões arredondados */
    transition: all 0.3s ease;
}
.btn-primary-pedeqr:hover {
    background-color: var(--pedeqr-primary-hover-color);
    border-color: var(--pedeqr-primary-hover-color);
    transform: translateY(-2px);
    box-shadow: 0 4px 10px rgba(0,0,0,0.1);
    color: #fff;
}
.btn-secondary-pedeqr {
    background-color: var(--pedeqr-secondary-color);
    border-color: var(--pedeqr-secondary-color);
    color: var(--pedeqr-dark-color);
    font-weight: 600;
    padding: 10px 25px;
    border-radius: 50px;
    transition: all 0.3s ease;
}
.btn-secondary-pedeqr:hover {
    background-color: var(--pedeqr-secondary-hover-color);
    border-color: var(--pedeqr-secondary-hover-color);
    transform: translateY(-2px);
    box-shadow: 0 4px 10px rgba(0,0,0,0.1);
    color: var(--pedeqr-dark-color);
}


a { color: var(--pedeqr-primary-color); text-decoration: none; }
a:hover { color: var(--pedeqr-primary-hover-color); }

/* --- Componentes Específicos --- */

/* Header */
.navbar-brand img { max-height: 45px; } /* Logo um pouco maior */
.navbar .nav-link { font-weight: 600; text-transform: uppercase; font-size: 0.9rem; }
.navbar .nav-link.active, .navbar .nav-link:hover { color: var(--pedeqr-primary-color) !important; }
.navbar .btn { padding: 8px 20px; }

/* Seções */
.section-padding { padding: 40px 0; }
.section-bg { background-color: var(--pedeqr-light-color); }
.section-title h2 { font-size: 2.5rem; }

/* Seção Herói */
.hero-section {
    /* ALTERAÇÃO APLICADA AQUI */
    background: linear-gradient(rgba(0, 0, 0, 0.4), rgba(0, 0, 0, 0.4)), url('../assets/imagens/background_hero.php') no-repeat center center;
    background-size: cover;
    color: #fff;
    padding: 120px 0;
    text-align: center;
}
.hero-section h1 { font-size: 3rem; font-weight: 700; }
.hero-section .btn-lg { margin-top: 20px; }

/* Seção de Parceiros (Nova) */
.partner-card {
    background-color: #fff;
    border-radius: 15px;
    padding: 30px;
    text-align: center;
    transition: all 0.3s ease;
    box-shadow: 0 5px 25px rgba(0,0,0,0.07);
    height: 100%;
}
.partner-card:hover {
    transform: translateY(-10px);
    box-shadow: 0 10px 30px rgba(0,0,0,0.12);
}
.partner-icon {
    font-size: 3.5rem;
    margin-bottom: 20px;
    color: var(--pedeqr-primary-color);
}
.partner-card h3 {
    color: var(--pedeqr-dark-color);
    margin-bottom: 15px;
}

/* Features Section (Ajustada) */
.feature-card {
    border: none;
    border-radius: 15px;
    padding: 30px;
    text-align: center;
    transition: all 0.3s ease;
    background-color: #fff;
    box-shadow: 0 5px 25px rgba(0,0,0,0.07);
    margin-bottom: 30px;
}
.feature-card:hover { transform: translateY(-5px); box-shadow: 0 8px 20px rgba(0,0,0,0.1); }
.feature-icon { font-size: 3rem; margin-bottom: 20px; color: var(--pedeqr-primary-color); }

/* FAQ Section (Accordion) */
.accordion-button { font-weight: 700; font-family: 'Poppins', sans-serif; }
.accordion-button:not(.collapsed) {
    color: #fff;
    background-color: var(--pedeqr-primary-color);
}
.accordion-item { border-radius: 10px !important; margin-bottom: 10px; border: 1px solid #ddd; overflow: hidden; }
.accordion-header { border-radius: 10px; }

/* Footer */
footer { padding: 50px 0; background-color: var(--pedeqr-dark-color) !important; }
footer a.text-white:hover { color: var(--pedeqr-secondary-color) !important; }
footer .text-pedeqr-primary { color: var(--pedeqr-secondary-color) !important; }


/* --- Media Queries (Ajustes finos para responsividade) --- */
@media (max-width: 992px) {
    .hero-section h1 { font-size: 2.5rem; }
    .section-padding { padding: 60px 0; }
}

@media (max-width: 768px) {
    .hero-section h1 { font-size: 2.2rem; }
    .partner-card { margin-bottom: 30px; }
}

/* ===== ESTILOS PARA BOTÃO FLUTUANTE E BALÃO DE CONTATO ===== */

.contact-fab {
    position: fixed;
    bottom: 25px;
    right: 25px;
    width: 60px;
    height: 60px;
    background-color: var(--pedeqr-primary-color);
    color: white;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 28px;
    box-shadow: 0 4px 12px rgba(0,0,0,0.2);
    cursor: pointer;
    z-index: 1050;
    transition: all 0.3s ease;
}
.contact-fab:hover {
    background-color: var(--pedeqr-primary-hover-color);
    transform: scale(1.1);
}

.contact-balloon {
    position: fixed;
    bottom: 100px;
    right: 25px;
    width: 350px;
    max-width: calc(100% - 40px);
    background-color: #ffffff;
    border-radius: 15px;
    box-shadow: 0 5px 20px rgba(0,0,0,0.15);
    z-index: 1049;
    
    /* Estado inicial (oculto) */
    opacity: 0;
    visibility: hidden;
    transform: translateY(20px) scale(0.95);
    transition: all 0.3s cubic-bezier(0.25, 0.8, 0.25, 1);
}

.contact-balloon.show {
    /* Estado visível */
    opacity: 1;
    visibility: visible;
    transform: translateY(0) scale(1);
}

.contact-balloon-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 15px 20px;
    background-color: var(--pedeqr-light-color);
    border-bottom: 1px solid #e9ecef;
    border-top-left-radius: 15px;
    border-top-right-radius: 15px;
}
.contact-balloon-header h5 {
    margin: 0;
    font-size: 1.1rem;
    color: var(--pedeqr-dark-color);
}
.contact-balloon-body {
    padding: 20px;
}
.contact-balloon-body .form-control {
    font-size: 0.9rem;
    padding: 10px;
}
.contact-balloon-body .separator {
    text-align: center;
    margin: 20px 0;
    font-size: 0.9rem;
    color: #adb5bd;
    display: flex;
    align-items: center;
}
.contact-balloon-body .separator::before,
.contact-balloon-body .separator::after {
    content: '';
    flex: 1;
    border-bottom: 1px solid #dee2e6;
}
.contact-balloon-body .separator:not(:empty)::before {
    margin-right: .5em;
}
.contact-balloon-body .separator:not(:empty)::after {
    margin-left: .5em;
}

/* Responsividade para o balão em telas pequenas */
@media (max-width: 400px) {
    .contact-balloon {
        width: calc(100% - 20px);
        right: 10px;
        bottom: 90px;
    }
    .contact-fab {
        bottom: 15px;
        right: 15px;
    }
}

/* --- Seção de Parceiros (Carrossel) --- */
.partners-section {
    padding: 20px 0;
}

.swiper-partners {
    width: 100%;
    height: 100%;
    padding-top: 20px;
    padding-bottom: 50px; /* Espaço para a paginação */
}

.swiper-slide-partner {
    text-align: center;
    font-size: 18px;
    background: #fff;
    display: flex;
    justify-content: center;
    align-items: center;
    filter: grayscale(100%);
    opacity: 0.7;
    transition: all 0.4s ease;
    padding: 10px;
    border-radius: 8px;
}

.swiper-slide-partner:hover {
    filter: grayscale(0%); /* Remove o filtro no hover */
    opacity: 1;
    transform: scale(1.1);
}

.swiper-slide-partner img {
    display: block;
    width: 100%;
    max-width: 150px; /* Largura máxima do logo */
    height: auto;
    object-fit: contain;
}

/* Estilo para os pontos de paginação do Swiper */
.swiper-pagination-bullet-active {
    background-color: var(--pedeqr-primary-color) !important;
}

/* Estilos para o carrossel de depoimentos contínuo */
.testimonials-section {
    padding: 40px 0;
    position: relative;
}

#depoimentosCarousel {
    overflow: hidden;
    padding: 20px 0 40px;
}

.carousel-inner {
    transition: transform 0.6s ease-in-out;
}

.carousel-item {
    transition: opacity 0.6s ease-in-out;
}

.carousel-control-prev,
.carousel-control-next {
    width: 5%;
    color: var(--pedeqr-primary-color);
    opacity: 1;
    background: none;
}

.carousel-control-prev-icon,
.carousel-control-next-icon {
    background-color: var(--pedeqr-primary-color);
    border-radius: 50%;
    width: 40px;
    height: 40px;
    background-size: 60%;
}

/* Efeito de fade para suavizar a transição */
.carousel-item {
    opacity: 0;
    transition: opacity 0.6s ease-in-out;
}

.carousel-item.active {
    opacity: 1;
}

/* Ajustes para telas menores */
@media (max-width: 991.98px) {
    .carousel-control-prev,
    .carousel-control-next {
        width: 10%;
    }
}

/* Adicione estas regras ao seu CSS existente */

@media (min-width: 921px) {
    /* Garante que as colunas dos planos fiquem na mesma linha */
    .row.justify-content-center {
        display: flex;
        flex-wrap: wrap;
    }
    
    /* Define altura igual para todos os cards de plano */
    .card-plano {
        height: 100%;
        display: flex;
        flex-direction: column;
    }
    
    /* Garante que o corpo do card ocupe todo o espaço disponível */
    .card-body {
        flex: 1;
        display: flex;
        flex-direction: column;
    }
    
    /* Faz com que a lista de recursos ocupe o espaço disponível */
    .list-group {
        flex: 1;
    }
    
    /* Alinha todos os cards pelo topo */
    .col-lg-4.col-md-6 {
        display: flex;
    }
	.navbar-brand img {
		max-height: 75px;
		position: relative;
		top: -6px;
		margin: 0px 0px -10px 0px;
	}	
}

/* Ajuste adicional para garantir que os cards não fiquem muito largos em telas grandes */
/* Garante que o botão fique sempre na parte inferior do card */
.planos-section .card-plano {
    display: flex;
    flex-direction: column;
    height: 100%;
}
.planos-section .card-body {
    display: flex;
    flex-direction: column;
    flex-grow: 1;
}
.planos-section .list-group {
    flex-grow: 1;
}
.planos-section .mt-auto {
    margin-top: auto !important;
}

/* Ajuste de largura e centralização APENAS para as colunas dos planos em telas grandes */
@media (min-width: 1200px) {
    .planos-section .col-lg-4 {
        /* Opcional: Se quiser um leve espaçamento extra entre os cards */
        flex: 0 0 31%;
        max-width: 31%;
    }
}

/* Garante que o botão fique sempre na parte inferior */
.mt-auto {
    margin-top: auto !important;
}

.list-group.list-group-flush {
    min-height: 300px; /* Ajuste este valor conforme necessário */
}