.elementor-9820 .elementor-element.elementor-element-a4a99c4{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}.elementor-9820 .elementor-element.elementor-element-7d9554f{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}:root{--page-title-display:none;}/* Start custom CSS for html, class: .elementor-element-894c96c */.roteiro-section{
    padding:80px 20px;
    background:#f5f7fb;
}

.titulo-roteiro{
    max-width:1200px;
    margin:auto;
    margin-bottom:40px;
}

.titulo-roteiro h2{
    font-size:38px;
    margin-bottom:10px;
    color:#111;
}

.titulo-roteiro p{
    color:#666;
}

.roteiro-grid{
    max-width:1200px;
    margin:auto;
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(320px,1fr));
    gap:25px;
}

.card-roteiro{
    background:white;
    border-radius:28px;
    overflow:hidden;
    box-shadow:0 10px 35px rgba(0,0,0,0.08);
    transition:0.4s;
    position:relative;
}

.card-roteiro:hover{
    transform:translateY(-8px);
}

.card-img{
    height:230px;
    background-size:cover;
    background-position:center;
}

.card-content{
    padding:25px;
}

.periodo{
    display:inline-block;
    padding:8px 16px;
    border-radius:50px;
    font-size:13px;
    font-weight:bold;
    color:white;
    margin-bottom:15px;
}

.manha{
    background:#ff9800;
}

.tarde{
    background:#03a9f4;
}

.noite{
    background:#673ab7;
}

.card-content h3{
    font-size:28px;
    margin-bottom:10px;
    color:#111;
}

.card-content p{
    color:#666;
    line-height:1.6;
}

.card-footer{
    display:flex;
    justify-content:space-between;
    margin-top:20px;
    font-size:14px;
    color:#777;
}

@media(max-width:768px){

.titulo-roteiro h2{
    font-size:28px;
}

}
.filtros-destinos{
    max-width:1200px;
    margin:auto;
    margin-bottom:40px;
    display:flex;
    gap:15px;
    overflow:auto;
    padding-bottom:10px;
}

.filtro{
    border:none;
    padding:14px 22px;
    border-radius:50px;
    background:white;
    cursor:pointer;
    font-weight:bold;
    box-shadow:0 5px 15px rgba(0,0,0,0.08);
    transition:0.3s;
    white-space:nowrap;
}

.filtro:hover{
    transform:translateY(-3px);
}

.filtro.ativo{
    background:#111;
    color:white;
}
.badge-ideal{
    position:absolute;
    top:20px;
    right:20px;
    background:#00c853;
    color:white;
    padding:10px 16px;
    border-radius:50px;
    font-size:13px;
    font-weight:bold;
    z-index:2;
}
.top-actions{
    max-width:1200px;
    margin:auto;
    margin-bottom:25px;
    display:flex;
    justify-content:flex-end;
}

.btn-gerar{
    border:none;
    padding:16px 28px;
    border-radius:60px;
    background:linear-gradient(135deg,#6a11cb,#2575fc);
    color:white;
    font-weight:bold;
    cursor:pointer;
    transition:0.4s;
    box-shadow:0 10px 30px rgba(37,117,252,0.3);
    font-size:15px;
}

.btn-gerar:hover{
    transform:translateY(-4px) scale(1.03);
    box-shadow:0 15px 40px rgba(37,117,252,0.45);
}

.card-roteiro{
    animation:fadeCard 0.6s ease;
    backdrop-filter:blur(20px);
}

@keyframes fadeCard{

    from{
        opacity:0;
        transform:translateY(30px);
    }

    to{
        opacity:1;
        transform:translateY(0);
    }

}

.card-img{
    transition:0.5s;
}

.card-roteiro:hover .card-img{
    transform:scale(1.05);
}

.card-content h3{
    font-size:24px;
    color:#111;
}

.card-content p{
    line-height:1.7;
}

.hero-clima{
    animation:bgMove 10s ease infinite alternate;
}

@keyframes bgMove{

    from{
        filter:hue-rotate(0deg);
    }

    to{
        filter:hue-rotate(15deg);
    }

}
.btn-mapa{
    display:inline-block;
    margin-top:18px;
    padding:12px 18px;
    border-radius:50px;
    background:#111;
    color:white;
    text-decoration:none;
    font-size:14px;
    font-weight:bold;
    transition:0.3s;
}

.btn-mapa:hover{
    transform:translateY(-3px);
    background:#2575fc;
}
.distancia{
    margin-top:15px;
    font-size:14px;
    color:#2575fc;
    font-weight:bold;
}
.particles{
    position:absolute;
    width:100%;
    height:100%;
    overflow:hidden;
    top:0;
    left:0;
    z-index:1;
}

.particles span{
    position:absolute;
    display:block;
    width:12px;
    height:12px;
    background:rgba(255,255,255,0.25);
    border-radius:50%;
    animation:floatParticle linear infinite;
    bottom:-50px;
}

@keyframes floatParticle{

    from{
        transform:translateY(0) scale(1);
        opacity:0;
    }

    20%{
        opacity:1;
    }

    to{
        transform:translateY(-120vh) scale(0);
        opacity:0;
    }

}
.mobile-nav{

    position:fixed;
    bottom:0;
    left:0;
    width:100%;
    height:80px;

    background:rgba(255,255,255,0.9);

    backdrop-filter:blur(20px);

    display:flex;
    justify-content:space-around;
    align-items:center;

    z-index:9999;

    border-top:1px solid rgba(0,0,0,0.08);

}

.mobile-nav a{

    display:flex;
    flex-direction:column;

    align-items:center;

    justify-content:center;

    text-decoration:none;

    color:#111;

    font-size:22px;

    font-weight:bold;

    transition:0.3s;

}

.mobile-nav span{

    font-size:11px;
    margin-top:4px;

}

.mobile-nav a:hover{

    transform:translateY(-5px);
    color:#2575fc;

}/* End custom CSS */