/* =========================================
   1. VARIÁVEIS E GLOBAIS
   ========================================= */
:root {
    /* Cores da Marca Rota do Sol */
    --rota-blue: #1059AC;
    --rota-dark-blue: #0a3d7a;
    --rota-orange: #ff9c1b;
    --cvc-blue-cta: #0038A8;
    --promo-blue: #03337c;

    /* Mapeamentos Gerais */
    --primary-color: var(--rota-blue);
    --secondary-color: var(--rota-orange);
    --rating-color: var(--rota-blue);
    --dark-color: #1a1a1a;
    --light-color: #f8f9fa;
    --text-dark: #334155;
    --light-grey-color: #f2f2f2;

    /* Bootstrap Overrides */
    --bs-primary: var(--rota-blue);
    --bs-primary-rgb: 0, 84, 166;
    --bs-link-color: #1a1a1a;
    --bs-link-hover-color: #004285;
    --bs-warning: #ffc107;
}

html {
    scroll-behavior: smooth;
}

body {
    font-family: 'Montserrat', sans-serif; /* Padrão atualizado */
    color: var(--text-dark);
    background-color: var(--light-grey-color);
}

h1, h2, h3, h4, .navbar-brand {
    font-family: 'Montserrat', sans-serif;
}

/* Utilitários de Texto */
.text-primary { color: var(--rota-blue) !important; }
.bg-primary { background-color: var(--rota-blue) !important; }
.bg-orange { background-color: var(--rota-orange) !important; color: #fff; }
.text-orange { color: var(--rota-orange) !important; }
.text-shadow { text-shadow: 2px 2px 4px rgba(0, 0, 0, .7); }
.ultra-small { font-size: 12px; }

/* =========================================
   2. NAVBAR E HEADER
   ========================================= */
.top-bar {
    background-color: var(--rota-blue);
    color: white;
    font-size: 0.8rem;
    font-weight: 600;
    padding: 8px 0;
}

.navbar {
    box-shadow: 0 4px 10px rgba(0,0,0,0.05);
    padding: 15px 0;
    background-color: rgba(255, 255, 255, .98);
}

.nav-link {
    font-weight: 600;
    color: #333 !important;
    margin: 0 10px;
}

.btn-header {
    background-color: var(--rota-blue);
    color: white;
    font-weight: bold;
    border-radius: 50px;
    padding: 8px 25px;
    transition: all 0.3s;
}

.btn-header:hover {
    background-color: var(--rota-dark-blue);
    color: white;
}

/* Scrollbar do Dropdown */
.navbar .dropdown-menu {
    max-height: 300px;
    overflow-y: auto;
}
.sticky-top {
    /* Comandos de Fixação */
    position: -webkit-sticky; /* Para Safari */
    position: sticky;
    top: 0;
    
    /* Estilo Visual */
    background-color: rgba(255, 255, 255, .98);
    box-shadow: 0 4px 10px rgba(0,0,0,0.05);
    z-index: 1030; /* Garante que fique acima de tudo */
    width: 100%; /* Garante largura total */
    transition: all 0.3s ease;
}
.navbar .dropdown-menu::-webkit-scrollbar { width: 8px; }
.navbar .dropdown-menu::-webkit-scrollbar-track { background: #f1f1f1; }
.navbar .dropdown-menu::-webkit-scrollbar-thumb { background: #ccc; border-radius: 4px; }

/* =========================================
   3. HERO E SEÇÕES DE BUSCA
   ========================================= */
/* Hero Estilo CVC (Home) */
.hero-cvc {
    background-color: var(--rota-orange);
    padding: 20px 0 20px 0;
    position: relative;
    margin-bottom: 10px;
}

/* Header de Busca (Página de Resultados) */
.search-header {
    background-color: var(--rota-orange);
    padding: 10px 0;
    margin-bottom: 40px;
}

/* Hero Genérico (Páginas Institucionais) */
.page-hero {
    background-size: cover;
    background-position: center;
    min-height: 60vh;
    display: flex;
    align-items: center;
    color: #fff;
    padding-top: 80px;    
}

/* Breadcrumb */
.breadcrumb-section {
    background-color: #f8f9fa;
    border-bottom: 1px solid #e9ecef;
}
.breadcrumb-item a { color: var(--rota-blue); text-decoration: none; }
.breadcrumb-item.active { color: #6c757d; }

/* =========================================
   4. COMPONENTES DE BUSCA
   ========================================= */
.search-box {
    background: white;
    border-radius: 16px;
    padding: 20px;
    box-shadow: 0 15px 40px rgba(0,0,0,0.1);
    margin-top: 5px;
}

.search-tab {
    font-weight: 700;
    color: var(--rota-blue);
    border-bottom: 3px solid transparent;
    padding-bottom: 10px;
    margin-right: 20px;
    cursor: pointer;
}

.search-tab.active {
    border-bottom: 3px solid var(--rota-blue);
}

.form-control {
    border: 1px solid #dee2e6; /* Borda suave padrão */
    padding: 12px;
    font-weight: 600;    
}
/* Na busca interna removemos a borda para ficar clean */
.search-header .form-control { border: none; }

.btn-search {
    background-color: var(--rota-blue);
    color: white;
    font-weight: bold;
    width: 100%;
    height: 50px; /* Altura fixa para alinhar com inputs */
    border-radius: 8px;
    border: none;
    transition: background 0.3s;
}
.btn-search:hover {
    background-color: var(--rota-dark-blue);
    color: white;
}

/* Autocomplete (Lista de sugestões) */
.autocomplete-list {
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background: white;
    border: 1px solid #ddd;
    border-radius: 0 0 8px 8px;
    max-height: 200px;
    overflow-y: auto;
    z-index: 1000;
    list-style: none;
    padding: 0;
    margin: 0;
    box-shadow: 0 4px 10px rgba(0,0,0,0.1);
    display: none;
}
.autocomplete-list li {
    padding: 10px 15px;
    cursor: pointer;
    font-size: 0.9rem;
    color: #333;
    border-bottom: 1px solid #f0f0f0;
}
.autocomplete-list li:hover {
    background-color: #f8f9fa;
    color: var(--rota-blue);
    font-weight: bold;
}

/* =========================================
   5. CARDS DE VIAGEM (Principal)
   ========================================= */
.card-travel {
    border: none;
    border-radius: 12px;
    overflow: hidden;
    box-shadow: 0 4px 15px rgba(0,0,0,0.15);
    transition: transform 0.3s;
    background: white;
    height: 100%; /* Garante altura igual na linha */
}

.card-travel:hover {
    transform: translateY(-5px);
    box-shadow: 0 10px 25px rgba(0,0,0,0.1);
}

.card-img-wrapper {
    position: relative;
    height: 220px; /* Altura fixa IMPORTANTE para não achatar */
    overflow: hidden;
    border-radius: 12px 12px 0 0;
}

.card-img-top {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.badge-promo {
    position: absolute;
    top: 15px;
    left: 15px;
    background-color: var(--rota-orange);
    color: white;
    font-weight: bold;
    padding: 5px 15px;
    border-radius: 50px;
    font-size: 0.8rem;
    z-index: 2;
}

.card-body { padding: 20px; }

.card-title {
    font-weight: 700;
    color: var(--rota-blue);
    font-size: 1.1rem;
    margin-bottom: 5px;
}

.rating-badge {
    background-color: var(--rota-blue);
    color: white;
    font-size: 0.75rem;
    padding: 2px 6px;
    border-radius: 4px;
    font-weight: bold;
    margin-right: 5px;
}

.btn-card {
    border: 2px solid var(--rota-blue);
    color: var(--rota-blue);
    font-weight: bold;
    border-radius: 50px;
    width: 100%;
    padding: 8px 0;
    margin-top: 15px;
    transition: all 0.3s;
    display: block;
    text-align: center;
    text-decoration: none;
}
.btn-card:hover { background-color: var(--rota-blue); color: white; }

/* =========================================
   6. PÁGINA DE DETALHES
   ========================================= */
.detail-img-wrapper {
    position: relative;
    border-radius: 16px;
    overflow: hidden;
    box-shadow: 0 10px 30px rgba(0,0,0,0.1);
    height: 400px;
    background-color: #e2e8f0;
}
.detail-img { width: 100%; height: 100%; object-fit: cover; }

.badge-detail {
    position: absolute; top: 20px; left: 20px;
    background-color: var(--rota-orange); color: white;
    font-weight: bold; padding: 8px 20px; border-radius: 50px;
    font-size: 0.9rem; z-index: 10;
}

.price-card {
    background: white;
    padding: 30px;
    border-radius: 16px;
    box-shadow: 0 10px 40px rgba(0,0,0,0.08);
    position: sticky;
    top: 100px;
    border: 1px solid rgba(0,0,0,0.05);
}

.amenity-item {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 15px;
    font-size: 0.95rem;
    color: #475569;
    font-weight: 600;
}
.amenity-icon {
    color: var(--rota-blue);
    background: rgba(16, 89, 172, 0.1);
    padding: 8px;
    border-radius: 10px;
    min-width: 36px;
    height: 36px;
}

/* =========================================
   7. ELEMENTOS ESPECIAIS (Vagão, Galeria)
   ========================================= */
.gallery-img {
    height: 250px;
    border-radius: 12px;
    object-fit: cover;
    transition: transform .3s;
    cursor: pointer;
    width: 100%;
}
.gallery-img:hover { transform: scale(1.02); box-shadow: 0 10px 20px rgba(0,0,0,0.15); }

/* Card de Vagão (Trem) */
.vagao-card {
    position: relative;
    border-radius: 16px;
    overflow: hidden;
    height: 420px;
    box-shadow: 0 10px 25px rgba(0,0,0,0.2);
    cursor: pointer;
    background-color: #000;
}
.vagao-img {
    width: 100%; height: 100%; object-fit: cover;
    transition: transform .6s cubic-bezier(.165, .84, .44, 1);
    opacity: .95;
}
.vagao-overlay {
    position: absolute; bottom: 0; left: 0; width: 100%; height: 100%;
    background: linear-gradient(to top, rgba(0,0,0,0.9) 10%, rgba(0,0,0,0.3) 50%, rgba(0,0,0,0) 100%);
    display: flex; flex-direction: column; justify-content: flex-end; padding: 25px;
}
.vagao-content { transform: translateY(140px); transition: transform .5s; }
.vagao-title { color: #fff; font-weight: 800; font-size: 1.6rem; margin-bottom: 15px; text-shadow: 2px 2px 4px rgba(0,0,0,0.95); }
.vagao-desc {
    color: #fff; background-color: rgba(20,20,20,0.75); padding: 15px;
    border-radius: 10px; font-size: 1rem; opacity: 0; transition: .4s .1s; margin-bottom: 20px;
}
.vagao-card:hover .vagao-img { transform: scale(1.1); opacity: 1; }
.vagao-card:hover .vagao-content { transform: translateY(0); }
.vagao-card:hover .vagao-desc { opacity: 1; transform: translateY(0); }

/* =========================================
   8. FOOTER
   ========================================= */
.footer-link { transition: color .3s; }
.footer-link:hover { color: var(--rota-orange) !important; padding-left: 5px; }
.footer-seg { margin: 5px; }
.footer-text { font-size: 16px; }
.pay-card { width: 45px; margin: 2px; }

/* =========================================
   9. ANIMAÇÕES E FLUTUANTES
   ========================================= */
.whatsapp-float {
    position: fixed; bottom: 25px; right: 25px;
    background-color: #25d366; color: #fff;
    width: 60px; height: 60px; border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    font-size: 30px; box-shadow: 0 4px 10px rgba(0,0,0,0.3);
    z-index: 1000; transition: .3s; text-decoration: none;
    animation: 2s infinite pulse-green;
}
.whatsapp-float:hover { background-color: #128c7e; transform: scale(1.1); color: #fff; }

@keyframes pulse-green {
    0% { box-shadow: 0 0 0 0 rgba(37, 211, 102, .7); }
    70% { box-shadow: 0 0 0 15px rgba(37, 211, 102, 0); }
    100% { box-shadow: 0 0 0 0 rgba(37, 211, 102, 0); }
}

.animate-in { animation: fadeIn 0.5s ease forwards; opacity: 0; }
@keyframes fadeIn { from { opacity: 0; transform: translateY(10px); } to { opacity: 1; transform: translateY(0); } }

/* =========================================
   10. RESPONSIVIDADE
   ========================================= */
@media (max-width: 991px) {
    .vagao-card { height: 450px; }
    .hero-cvc { padding: 40px 0 60px 0; }
    .search-box { padding: 20px; margin-top: 0; }
    .btn-search { margin-top: 10px; }
}
.nav-logo{
    height: 80px;
}
/* =========================================
   11. FLUTUANTES (WhatsApp e BackToTop)
   ========================================= */
.whatsapp-float {
    position: fixed;
    bottom: 25px;
    right: 25px;
    background-color: #25d366;
    color: #fff;
    width: 60px;
    height: 60px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 30px;
    box-shadow: 0 4px 10px rgba(0, 0, 0, .3);
    z-index: 1000;
    transition: .3s;
    text-decoration: none;
    animation: 2s infinite pulse-green;
}

.whatsapp-float:hover {
    background-color: #128c7e;
    transform: scale(1.1);
    color: #fff;
}

.whatsapp-icon { width: 35px; height: 35px; fill: white; }

@keyframes pulse-green {
    0% { box-shadow: 0 0 0 0 rgba(37, 211, 102, .7); }
    70% { box-shadow: 0 0 0 15px rgba(37, 211, 102, 0); }
    100% { box-shadow: 0 0 0 0 rgba(37, 211, 102, 0); }
}

.back-to-top {
    position: fixed;
    bottom: 25px;
    left: 25px;
    background-color: var(--rota-blue); /* Usando sua variável existente */
    color: #fff;
    width: 60px;
    height: 60px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 4px 10px rgba(0, 0, 0, .3);
    z-index: 1000;
    transition: .3s;
    text-decoration: none;
    opacity: 0;
    visibility: hidden;
    transform: translateY(20px);
}

.back-to-top.show { opacity: 1; visibility: visible; transform: translateY(0); }
.back-to-top:hover {
    background-color: var(--rota-dark-blue);
    color: #fff;
    transform: translateY(-5px) scale(1.1);
}

/* =========================================
   12. ACESSIBILIDADE FAB
   ========================================= */
.acc-fab-container {
    position: fixed;
    right: 20px;
    bottom: 100px; /* Fica acima do whats */
    z-index: 2147483647;
    display: flex;
    flex-direction: column;
    align-items: center;
}
.acc-btn {
    width: 55px;
    height: 55px;
    border-radius: 50%;
    border: none;
    color: white;
    background-color: var(--rota-blue);
    box-shadow: 0px 4px 12px rgba(0,0,0,0.3);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.3s cubic-bezier(0.68, -0.55, 0.27, 1.55);
    position: relative;
    padding: 0;
    outline: none;
}
.acc-btn svg { width: 70%; height: 70%; object-fit: contain; transition: transform 0.3s ease; }
.acc-btn:active { transform: scale(0.95); }
.acc-btn:hover { filter: brightness(1.2); }

.acc-main-btn {
    width: 65px; height: 65px;
    box-shadow: 0px 6px 15px rgba(0,0,0,0.4);
    background-color: var(--rota-blue);
    position: relative; z-index: 2;
}
.acc-main-btn.open svg { transform: rotate(45deg); }

.acc-options {
    position: absolute;
    bottom: 75px;
    right: 5px;
    display: flex;
    flex-direction: column;
    gap: 12px;
    opacity: 0;
    visibility: hidden;
    transform: translateY(20px) scale(0.8);
    transform-origin: bottom center;
    transition: all 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275);
    pointer-events: none;
    z-index: 1;
}
.acc-options.show {
    opacity: 1; visibility: visible;
    transform: translateY(0) scale(1);
    pointer-events: all;
}

.acc-tooltip {
    position: absolute;
    right: 65px;
    background: rgba(30, 30, 30, 0.9);
    color: #fff;
    padding: 6px 12px;
    border-radius: 6px;
    font-size: 13px;
    font-weight: 500;
    white-space: nowrap;
    opacity: 0;
    visibility: hidden;
    transform: translateX(10px);
    transition: opacity 0.3s ease, transform 0.3s ease;
    pointer-events: none;
    box-shadow: 2px 2px 5px rgba(0,0,0,0.2);
}
@media (hover: hover) {
    .acc-btn:hover .acc-tooltip { opacity: 1; visibility: visible; transform: translateX(0px); }
}

/* Esconde o botão padrão feio do VLibras */
[vw-access-button], .access-button { 
    display: none !important; visibility: hidden !important; 
    opacity: 0 !important; width: 0 !important; 
}

@media (max-width: 380px) {
    .acc-fab-container { right: 15px; bottom: 90px; }
    .acc-main-btn { width: 60px; height: 60px; }
    .acc-btn { width: 50px; height: 50px; }
    .acc-options { bottom: 70px; right: 5px; }
}
/* 2. Controla o tamanho do Logo no Celular para não quebrar */
@media (max-width: 991px) {
    .navbar-brand img {
        max-width: 140px; /* Reduz o logo no mobile */
        height: auto;
    }
    
    /* Ajusta espaçamento da barra azul no mobile */
    .top-bar {
        text-align: center;
        padding: 5px 0;
    }
}
@media (max-width: 768px) {
    /* Ajustes gerais do container */
    .hero-cvc {
        padding-top: 20px !important;
        padding-bottom: 20px !important;
    }
    
    /* Reseta o H1 para não atrapalhar */
    .hero-cvc h1{
        line-height: 1.7rem!important;
        margin-bottom: 15px !important;
    }

    /* Linha 1: "Viagens em promoção" */
    .promo-line {
        font-size: 2.3rem!important; /* Bem grande */
        color: var(--promo-blue) !important; /* Azul */
    }

    /* Linha 2: "para você curtir o mundo!" */
    .slogan-line {
        font-size: 1.7rem!important; /* Menor */
        color: #fff !important; /* Branco */
        display: block; /* Garante a quebra de linha */
        margin-top: 10px; /* Espacinho entre as linhas */
        margin-bottom: -5px;
    }

    /* Mantém o parágrafo pequeno */
    .hero-cvc p {
        font-size: 0.9rem !important;
        margin-bottom: 5px;
    }
}
@media (min-width: 769px) {
    /* Ajustes gerais do container */
    .hero-cvc {
        padding-top: 20px !important;
        padding-bottom: 20px !important;
    }    
    
    /* Reseta o H1 para não atrapalhar */
    .hero-cvc h1{
        line-height: 1.7rem!important;        
    }

    /* Linha 1: "Viagens em promoção" */
    .promo-line {
        font-size: 2.9rem!important; /* Bem grande */
        color: var(--promo-blue) !important; /* Azul */        
    }

    /* Linha 2: "para você curtir o mundo!" */
    .slogan-line {
        font-size: 2.2rem!important; /* Menor */
        color: #fff !important; /* Branco */
        display: block; /* Garante a quebra de linha */
        margin-top: 15px; /* Espacinho entre as linhas */        
    }

    /* Mantém o parágrafo pequeno */
    .hero-cvc p {
        font-size: 0.9rem !important;
        margin-bottom: 5px;
    }
}

    
/* =========================================
   CALENDÁRIO CUSTOMIZADO (Estilo Airbnb/Booking)
   ========================================= */
.flatpickr-calendar {
    border: none !important;
    box-shadow: 0 15px 40px rgba(0,0,0,0.1) !important;
    border-radius: 16px !important;
    padding: 15px !important;
    font-family: 'Montserrat', sans-serif !important;
}

/* Cabeçalho (Mês e Ano) */
.flatpickr-month {
    margin-bottom: 10px !important;
}
.flatpickr-current-month {
    font-size: 1.1rem !important;
    font-weight: 700 !important;
    color: var(--rota-blue) !important;
}

/* Dias da Semana (Dom, Seg...) */
.flatpickr-weekdays {
    margin-bottom: 5px !important;
}
span.flatpickr-weekday {
    color: #64748b !important; /* Cinza suave */
    font-weight: 600 !important;
    font-size: 0.85rem !important;
}

/* Dias (Números) */
.flatpickr-day {
    border-radius: 8px !important; /* Quadrado arredondado igual da foto */
    font-weight: 600 !important;
    color: #334155 !important;
    border: 1px solid transparent !important; /* Evita pulos de layout */
}

/* Dia HOJE */
.flatpickr-day.today {
    border-color: #e2e8f0 !important;
    background: transparent !important; 
    color: var(--rota-blue) !important;
}
.flatpickr-day.today:hover {
    background: #f1f5f9 !important;
    color: var(--rota-blue) !important;
}

/* Dia SELECIONADO (Fundo Azul Escuro) */
.flatpickr-day.selected, 
.flatpickr-day.startRange, 
.flatpickr-day.endRange, 
.flatpickr-day.selected.inRange, 
.flatpickr-day.startRange.inRange, 
.flatpickr-day.endRange.inRange, 
.flatpickr-day.selected:focus, 
.flatpickr-day.startRange:focus, 
.flatpickr-day.endRange:focus, 
.flatpickr-day.selected:hover, 
.flatpickr-day.startRange:hover, 
.flatpickr-day.endRange:hover {
    background: var(--rota-blue) !important;
    border-color: var(--rota-blue) !important;
    color: #fff !important;
    box-shadow: 0 4px 10px rgba(16, 89, 172, 0.3) !important;
}
input[readonly] {
    cursor: pointer !important;
}
/* Intervalo (Fundo Azul Claro/Roxo igual da foto) */
.flatpickr-day.inRange {
    background: #eef4ff !important; /* Azulzinho bem claro */
    border-color: #eef4ff !important;
    color: var(--rota-blue) !important;
    box-shadow: -5px 0 0 #eef4ff, 5px 0 0 #eef4ff !important; /* Conecta os dias */
}

/* Hover nos dias */
.flatpickr-day:hover {
    background: #f8f9fa !important;
}

/* Setas de Navegação */
.flatpickr-prev-month, .flatpickr-next-month {
    fill: var(--rota-blue) !important;
}
.flatpickr-prev-month:hover svg, .flatpickr-next-month:hover svg {
    fill: var(--rota-orange) !important;
}
/* =========================================
   13. SELO DE PASSAGEIROS (DINÂMICO)
   ========================================= */
.pax-badge {
    display: inline-flex;
    align-items: center;
    background-color: #f1f5f9;
    color: var(--text-dark);
    padding: 2px 8px; /* Mais fino */
    border-radius: 6px; /* Menos redondo para alinhar com o rating-badge */
    font-size: 11px;
    font-weight: 700;
    border: 1px solid #e2e8f0;
    white-space: nowrap; /* Garante que não quebre linha */
}
.pax-badge i {
    color: var(--rota-blue);
}
.info-icon-wrapper {
    width: 65px;
    height: 65px;
    background-color: var(--rota-blue); /* Azul da sua marca */
    color: white;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto;
    transition: transform 0.3s;
}
.info-icon-wrapper:hover {
    transform: scale(1.1);
    background-color: var(--rota-orange); /* Efeito legal no hover */
}
.info-icon-wrapper svg {
    width: 32px;
    height: 32px;
}
.badge-duracao-floating {
    position: absolute;
    top: 90%; /* Centraliza na altura da foto */
    right: 8px; /* Recuo da borda direita */
    transform: translateY(-50%); /* Alinhamento vertical perfeito */
    background-color: #ffeb3b; 
    color: #222;
    padding: 3px 12px;
    border-radius: 50px; /* Formato de pílula */
    font-size: 0.75rem;
    font-weight: 800;
    box-shadow: 0 4px 10px rgba(0,0,0,0.2);
    z-index: 5;
    white-space: nowrap;
    border: 1px solid rgba(0,0,0,0.05);
}
.noshow{
    display: none!important;
}
/* --- EFEITO DE ZOOM SUAVE --- */

/* 1. Garante que a imagem não vaze para fora do card quando der zoom */
.card-img-wrapper {
    overflow: hidden !important;
    position: relative;
}

/* 2. Configura a velocidade e a "curva" do movimento na imagem */
.card-img-wrapper img {
    /* transform: o que vai mudar
       0.7s: tempo de duração (quanto maior, mais lento/suave)
       cubic-bezier: faz o movimento começar lento, acelerar e frear suavemente no fim
    */
    transition: transform 0.7s cubic-bezier(0.25, 0.46, 0.45, 0.94) !important;    
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block; /* Remove espaços brancos fantasmas */
}

/* 3. O gatilho: quando passar o mouse no wrapper, a imagem cresce */
.card-img-wrapper:hover img {
    transform: scale(1.08) !important; /* Zoom de 8% (mais elegante que 1.1) */
}

/* Faixa de Desconto Inclinada */
.ribbon-discount {
    position: absolute;
    /* 1. Definimos um tamanho fixo para a faixa */
    width: 200px; 
    
    /* 2. Posicionamento para centralizar a diagonal */
    top: 35px; 
    right: -50px; 
    
    /* 3. Estética */
    background-color: #127429;
    color: white;
    padding: 5px 0; /* Padding lateral zero, pois o width já resolve */
    font-size: 0.85rem;
    font-weight: bold;
    text-transform: uppercase;
    
    /* 4. Centralização real do texto */
    text-align: center;
    
    transform: rotate(45deg);
    z-index: 10;
    box-shadow: 0 2px 5px rgba(0,0,0,0.2);
    pointer-events: none;
    white-space: nowrap;
}
.ribbon-discount-2 {
    position: absolute;
    /* 1. Definimos um tamanho fixo para a faixa */
    width: 200px; 
    
    /* 2. Posicionamento para centralizar a diagonal */
    top: 35px; 
    right: -50px; 
    
    /* 3. Estética */
    background-color: #641977;
    color: white;
    padding: 5px 0; /* Padding lateral zero, pois o width já resolve */
    font-size: 0.85rem;
    font-weight: bold;
    text-transform: uppercase;
    
    /* 4. Centralização real do texto */
    text-align: center;
    
    transform: rotate(45deg);
    z-index: 10;
    box-shadow: 0 2px 5px rgba(0,0,0,0.2);
    pointer-events: none;
    white-space: nowrap;
}
.ribbon-discount-3 {
    position: absolute;
    /* 1. Definimos um tamanho fixo para a faixa */
    width: 200px; 
    
    /* 2. Posicionamento para centralizar a diagonal */
    top: 35px; 
    right: -50px; 
    
    /* 3. Estética */
    background-color: #641977;
    color: white;
    padding: 5px 0; /* Padding lateral zero, pois o width já resolve */
    font-size: 0.85rem;
    font-weight: bold;
    text-transform: uppercase;
    
    /* 4. Centralização real do texto */
    text-align: center;
    
    transform: rotate(45deg);
    z-index: 10;
    box-shadow: 0 2px 5px rgba(0,0,0,0.2);
    pointer-events: none;
    white-space: nowrap;
}

/* Container precisa esconder o que sobra da faixa */
.card-img-wrapper {
    overflow: hidden; 
}
.card-promo{
    background-color: white;
}
.card-ultimas{
    background-color: #ffc107!important;
}
.lg-cli{
    display: flex;
}
/* Alvo: O container que criamos */
.datepicker-group {
    position: relative;
    display: flex;
    align-items: center;
}

/* Alvo: Tanto o seu input quanto o input mobile do Flatpickr */
.datepicker-group input {
    padding-left: 40px !important; /* Abre espaço para o ícone na esquerda */
    border-radius: 5px !important;
    height: 50px !important;
    text-align: center !important;        
}

/* Garante que o ícone fique sempre centralizado verticalmente */
.calendar-icon-prefix {
    position: absolute;
    left: 12px;
    z-index: 10;
    pointer-events: none;
    display: flex;
    align-items: center;
    height: 100%; /* Ocupa a altura toda para o flex centralizar */
    color: #6c757d;
}
@media (max-width: 387px) {
    .calendar-icon-prefix {
        display: none!important;
    }
    .datepicker-group input {
        padding-left: 12px !important;
        text-align: center !important;        
    }
}
.frm-origem{
    border-radius: 0 5px 5px 0 !important;
}
.br-5{
    border-radius: 5px 5px 5px 5px !important;
}
.img-zoom {
    transition: transform 1.2s ease-in-out; /* Zoom mais lento para banners grandes */
}

/* Efeito ao passar o mouse */
.img-zoom:hover {
    transform: scale(1.02); /* Aumenta 5% para um efeito elegante */
}
.bn-promo-start{
    display: flex !important;
}
.bn-promo-st-style{
    max-height: 260px;
    width: 100%;
    object-fit: cover;
}
@media (min-width: 994px) {
    /* Container que define a área do banner */
    .app-banner-position {
        position: relative;
        display: inline-block;
        width: 100%;
    }

    /* Centralização do Card sobre o banner */
    .qr-horizontal-card {
        position: absolute;
        top: 50%;
        left: 47%;
        transform: translate(-50%, -50%);
        background: white;
        border-radius: 12px;
        padding: 3px 3px;
        display: flex;
        align-items: center;
        box-shadow: 0 10px 30px rgba(0,0,0,0.2);
        width: 300px; /* Largura para caber o texto ao lado */
        text-align: left;
        border: 1px solid #eee;
    }

    /* Seção do QR Code */
    .qr-section img {
        width: 130px;
        height: 130px;
        border-right: 1px solid #eee;
        padding-right: 0px;
        margin-right: 15px;
    }

    /* Seção de Texto conforme imagem enviada */
    .text-section h3 {
        font-size: 14px;
        font-weight: 700;
        color: #333;
        margin: 0 0 5px 0;
    }

    .text-section p {
        font-size: 10px;
        color: #666;
        line-height: 1.4;
        margin-bottom: 10px;
    }

    .play-badge {
        height: 45px;
        display: block;
    }
}
@media (min-width: 769px) {
    @media (max-width: 993px) {
        /* Container que define a área do banner */
        .app-banner-position {
            position: relative;
            display: inline-block;
            width: 100%;
        }

        /* Centralização do Card sobre o banner */
        .qr-horizontal-card {
            position: absolute;
            top: 50%;
            left: 47%;
            transform: translate(-50%, -50%);
            background: white;
            border-radius: 12px;
            padding: 3px 3px;
            display: flex;
            align-items: center;
            box-shadow: 0 10px 30px rgba(0,0,0,0.2);
            width: 118px; /* Largura para caber o texto ao lado */
            text-align: left;
            border: 1px solid #eee;
        }

        /* Seção do QR Code */
        .qr-section img {
            width: 110px;
            height: 110px;
            border-right: 1px solid #eee;
            padding-right: 0px;
            margin-right: 15px;
        }

        /* Seção de Texto conforme imagem enviada */
        .text-section h3 {
            display: none;
            font-size: 14px;
            font-weight: 700;
            color: #333;
            margin: 0 0 5px 0;
        }

        .text-section p {
            display: none;
            font-size: 10px;
            color: transparent;
            line-height: 1.4;
            margin-bottom: 10px;
        }

        .play-badge {
            display: none;
            height: 35px;            
        }
    }
}
@media (max-width: 768px) {
    /* Container que define a área do banner */
    .app-banner-position {
        position: relative;
        display: inline-block;
        width: 100%;        
    }
    /* Centralização do Card sobre o banner */
    .qr-horizontal-card {
        display: none!important;
    }    
    .play-button{
        display: block;
        position: absolute;
        top: 80%;
        left: 75%;
        transform: translate(-50%, -50%);
    }    
}
/* Ajuste para sumir no app instalado */
.is-app {
    display: none;
}