/*▼▼▼▼▼▼▼▼▼▼▼▼▼▼▼▼▼*/
/*---- ▼ template ▼ ----*/
:root{
    --body-pt: 0px;
    --body-pt-d: 0px;
    
    --header-height: 50px;
    --header-height-d: 60px;
    
    --color-1: #0C1C3D; /*azul escuro*/
    --color-2: #F4C542; /*dourado*/
    --color-3: #1E4CA1; /*azul real*/
    
    --icons-1-color: var(--color-1);
    
    --color-black: #111;
    --color-white: #fff;
    
    --txt-1-font: "Inter", sans-serif;
    --txt-1-color: var(--color-black);
    --txt-1-size: 17px;
    --txt-1-weight: 400;
    --txt-1-line-height: 1.5;
    --txt-1-icons-color: #34c85a;
    
    --txt-2-color: var(--color-2);
    --txt-2-color-hover: #F4C542; /*dourado*/
    
    --txt-3-color: var(--color-3);
    
    --swiper-pb: 0px;
}

body{
    font-family: "Inter", sans-serif;
    font-optical-sizing: auto;
    font-size: 17px;
    font-style: normal;
    font-weight: 400;
    color: var(--txt-1-color);
    line-height: 1.5;
    /*padding-top: var(--body-pt);*/
    /*overflow-x: hidden;*/
}
body.tpl-home{
    padding-top: 0px;
}
@media(min-width: 992px){
    body{
        /*padding-top: var(--body-pt-d);*/
    }
    body.tpl-home{
        padding-top: 0px;
    }
}


.color-black{
    color: var(--color-black) !important;
}
.color-white{
    color: var(--color-white) !important;
}
.color-1{
    color: var(--color-1) !important;
}
.color-2{
    color: var(--color-2) !important;
}
.color-3{
    color: var(--color-3) !important;
}


*::selection{
    background: var(--color-1);
    color: #fff;
}
*::-moz-selection{
    background: var(--color-1);
    color: #fff;
}
b, strong{
    font-weight: 600;
}
a{
    color: blue;
    outline: none;
}
a:hover{
    color: inherit;
    text-decoration: underline;
}
a.link{
    color: blue;
    text-decoration: underline;
}
a.btn{
    text-decoration: none;
}
p{
    
}
p + p{
    margin-top: 1rem;
}
h1, h2, h3, h4, h5, h6,
.h1, .h2, .h3, .h4, .h5, .h6{
    color: inherit;
    font-weight: 700;
}

@media(min-width: 1400px){
    .container{
        max-width: 1400px;
    }
}

.hover:hover{
    opacity: 0.8;
}
.hover-border:hover{
    border: solid 1px #aaa;
    box-sizing: border-box;
    opacity: 0.8;
}

img.lazyload:not([src]),
img.lazy:not([src]),
img.lazyload[src=""],
img.lazy[src=""]{
    visibility: hidden;
}
li{
    list-style-position: inside;
}
.fw-black{
    font-weight: 900;
}


.text-truncate-line{
    display: -webkit-box;
    -webkit-line-clamp: 1;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
}
.text-truncate-line.line-2{
    -webkit-line-clamp: 2;
}
.text-truncate-line.line-3{
    -webkit-line-clamp: 3;
}
.text-truncate-line.line-4{
    -webkit-line-clamp: 4;
}
.text-truncate-line.line-5{
    -webkit-line-clamp: 5;
}
.text-truncate-line.line-6{
    -webkit-line-clamp: 6;
}


.btn-1x{
    font-size: 1rem !important;
    padding: 0.6rem 2rem !important;
}
.btn-2x{
    font-size: 1.2rem !important;
    padding: 1.0rem 2rem !important;
}
.btn-3x{
    font-size: 1.4rem !important;
    padding: 1rem 1.8rem !important;
}
@media(min-width: 992px){
    .btn-1x{
        font-size: 1.35rem !important;
        padding: 0.6rem 2.5rem !important;
    }
    .btn-2x{
        font-size: 1.5rem !important;
        padding: 0.8rem 4rem !important;
    }
    .btn-3x{
        font-size: 2rem !important;
        padding: 1rem 4rem !important;
    }
}


.btn-1x{
    font-size: 1rem !important;
    padding: 0.6rem 2rem !important;
}
.btn-2x{
    font-size: 1.2rem !important;
    padding: 1.0rem 2rem !important;
}
.btn-3x{
    font-size: 1.4rem !important;
    padding: 1rem 1.8rem !important;
}
@media(min-width: 992px){
    .btn-1x{
        font-size: 1.35rem !important;
        padding: 0.6rem 2.5rem !important;
    }
    .btn-2x{
        font-size: 1.5rem !important;
        padding: 0.8rem 4rem !important;
    }
    .btn-3x{
        font-size: 2rem !important;
        padding: 1rem 4rem !important;
    }
}


.btn-ic{
    position: relative;
    display: table;
    font-weight: 600;
    
    &:hover{
        box-shadow: 0 0 0 0.25rem rgba(0, 0, 0, 0.1);
    }
    &.btn-1x:hover{
        box-shadow: 0 0 0 0.40rem rgba(0, 0, 0, 0.1);
    }
    &.btn-2x:hover{
        box-shadow: 0 0 0 0.50rem rgba(0, 0, 0, 0.1);
    }
    &.btn-3x:hover{
        box-shadow: 0 0 0 0.65rem rgba(0, 0, 0, 0.1);
    }
    
    &.btn-success{
        background-color: #25d366;
        border: none;
        
        &:active{
            background-color: var(--color-1);
        }
    }

    &.btn-dark{
        display: table;
        font-weight: 600;
        text-transform: none;
        background-color: #111;
        border: none;
        padding-left: 1rem;
        padding-right: 1rem;
    }

    .btn-notify{
        position: absolute;
        display: flex;
        justify-content: center;
        align-items: center;
        font-size: 9px;
        color: #fff;
        line-height: 1;
        background-color: red;
        border: solid 1px rgba(255, 255, 255, 0.9);
        border-radius: 50px;
        margin: 0;
        padding: 0;
        height: 17px;
        width: 17px;
        top: -9px;
        right: 2px;
    }
    &.btn-lg .btn-notify{
        font-size: 13px;
        height: 26px;
        width: 26px;
        top: -13px;
        right: 5px;
    }
    &.btn-1x .btn-notify{
        font-size: 14px;
        height: 30px;
        width: 30px;
        top: -15px;
        right: 5px;
    }
    &.btn-2x .btn-notify{
        font-size: 16px;
        height: 30px;
        width: 30px;
        top: -15px;
        right: 5px;
    }
}

.btn-legend{
    font-weight: 400;
    font-style: italic;
    /*opacity: 0.8;*/
}
/*▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲*/
/*---- ▲ template ▲ ----*/



/*▼▼▼▼▼▼▼▼▼▼▼▼▼▼▼*/
/*---- ▼ header ▼ ----*/
header{
    background-color: #fff;
    
    .logo{
        /*width: 200px;*/
    }
}
/*▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲*/
/*---- ▲ header ▲ ----*/



/*▼▼▼▼▼▼▼▼▼▼▼▼▼▼*/
/*---- ▼ body ▼ ----*/
main{
    padding-top: var(--body-pt);
    min-height: 300px;
}
@media(min-width: 992px){
    main{
        padding-top: var(--body-pt-d);
        min-height: 400px;
    }
}
.container-header-no-margin{
    margin-top: calc(-0.5px - var(--body-pt));
}
@media (min-width: 1200px) {
    .container-header-no-margin{
        margin-top: calc(-0.5px - var(--body-pt-d));
    }
}
.container-header-padding{
    padding-top: var(--body-pt-d);
}
.container-footer-no-margin{
    margin-bottom: -50px;
}
.container-footer-padding{
    padding-bottom: 0px;
}

.grecaptcha-badge{
    display: none;
}

.stretched-link,
.stretched-link *{
    text-decoration: none !important;
}


.title-1{
    font-size: 24px;
    font-weight: 700;
    color: var(--color-black);
    
    @media(min-width: 992px){
        &{
            font-size: 40px;
        }
    }
    &.v1{
        font-size: 20px;
        
        @media(min-width: 992px){
            &{
                font-size: 22px;
            }
        }    
    }
}
.title-2{
    font-family: "Lora", serif;
    font-size: 24px;
    font-optical-sizing: auto;
    font-style: normal;
    font-weight: 700;
    line-height: 1.3;
    color: var(--color-black);
    
    @media(min-width: 992px){
        &{
            font-size: 40px;
        }
    }
    &.v1{
        font-size: 22px;
        font-weight: 500;
        
        @media(min-width: 992px){
            &.v1{
                font-size: 30px;
            }
        }    
    }
}

.title-3{
    font-size: 35px;
    font-style: italic;
    font-weight: 500;
    color: var(--txt-2-color);
    text-align: center;
    text-transform: uppercase;
}
.title-3 span{
    font-weight: 800;
}
@media (min-width: 992px) {
    .title-3{
        font-size: 35px;
    }
}
.title-4{
    font-size: 35px;
    font-style: italic;
    font-weight: 500;
    color: var(--txt-1-color);
    text-align: center;
    text-transform: uppercase;
}
.title-4 span{
    font-weight: 800;
}
@media (min-width: 992px) {
    .title-4{
        font-size: 35px;
    }
}
.title-5{
    font-family: "Montserrat", sans-serif;
    font-optical-sizing: auto;
    font-weight: 700;
    font-style: normal;
}
.title-6{
    font-size: 40px;
    font-weight: 900;
    color: #17375b;
    text-transform: uppercase;
    /*-webkit-text-stroke-width: 1px;*/
    /*-webkit-text-stroke-color: #bd9a5f47;*/
}
@media(min-width: 992px){
    .title-6{
        font-size: 65px;
    }
}
.title-7{
    font-size: 35px;
    font-weight: 900;
    color: #17375b;
    text-transform: uppercase;
}
@media(min-width: 992px){
    .title-7{
        font-size: 40px;
    }
}

.text-1{
    font-size: 20px;
}
.text-2{
    font-size: 22px;
}


section#headline{
    color: var(--color-white);
    /*background-color: #0C1C3D;*/
    background: linear-gradient(135deg, #0C1C3D 0%, #1E4CA1 100%);
    /*background-image: url(/_src/img/header-robson.webp);*/
    background-position: top right;
    background-repeat: no-repeat;
    background-size: contain;
    min-height: 100vh;
    height: 100vh;
    
    @media(min-width: 1400px){
        &{
            /*height: 96vh;*/
        }
    }
    
    .badge{
        font-size: 16px;
        font-weight: 300;
        background-color: var(--color-3) !important;
        
    }
    h1{
        font-family: "Lora", serif;
        font-size: 45px;
        font-optical-sizing: auto;
        font-style: normal;
        font-weight: 600;
        line-height: 1.3;
        color: var(--color-white);
        
        span{
            color: var(--txt-2-color);
        }
    }
    h2{
        font-weight: 300;
        line-height: 1.3;
        
        strong{
            font-weight: 600;
        }
    }
    .bg-1{
        position: absolute;
        height: 95vh;
        width: auto;
        bottom: 0px;
        right: 0px;
        z-index: 9999;
    }
    .img-1{
        position: relative;
    }
}


section#qualificacoes{
    border-bottom: solid 1px #fafafa;
    
    h3{
        font-size: 50px;
        color: var(--color-2);
        text-align: center;
        
        i{
            /*color: var(--color-1);*/
        }
        &+p{
            font-size: 20px;
            color: var(--color-1);
            text-align: center;
            margin: 0;
        }
    }
}


section#sobre-pre{
    background-color: #fff;
    
    .card{
        color: #fff;
        background-color: var(--color-1);
        border-top: none;
        border-right: none;
        border-bottom: solid 3px var(--color-2);
        border-left: none;
        border-radius: 1rem;
        height: 100%;
        
        .card-title{
            color: var(--color-2);
            padding-bottom: 1rem;
        }
    }
}


section#publico{
    color: #fff;
    background-color: var(--color-3);
}


section#problema{
    background-color: #fff;
    
    .card{
        color: #fff;
        background-color: var(--color-1);
        border-top: none;
        border-right: none;
        border-bottom: solid 3px var(--color-2);
        border-left: none;
        border-radius: 1rem;
        height: 100%;
        
        .card-title{
            color: var(--color-2);
            padding-bottom: 1rem;
        }
    }
}


section#resultados{
    color: #fff;
    background-color: var(--color-3);
    
    ul > li{
        margin-bottom: 3.5rem;
        
        h3{
            display: inline-block;
            font-size: 2rem;
            font-weight: 700;
            color: var(--color-2);
            padding: 0;
            margin: 0;

        }
        p{
            font-size: var(--txt-1-size);
            font-weight: var(--txt-1-weight);
            color: var(--color-white);
        }
        svg{
            display: inline-block;
            margin: 0 0 1rem;
            width: 3rem;
        }
    }
}



section#faq{
    @media(min-width: 992px){
        .container{
            width: 60%;
        }
    }
    .accordion{
        .accordion-item{
            border: none;
        }
        .accordion-button{
            font-size: 18px;
            font-weight: 600;
            color: var(--color-1);
            background-color: #eee;
            box-shadow: none;
            margin-bottom: 4px;
            
            &.collapsed{
                color: var(--color-black);
                background-color: #fafafa;
            }
        }
    }
}






.paper-wrap {
    position: relative;
    display: block; /* ou block, se preferir ocupar a linha toda */
}

/* sombra atrás da folha */
.paper-wrap::before {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: -25px;   /* empurra a sombra para fora */
    height: 50px;

    background: radial-gradient(
        ellipse at center top,
        rgba(0,0,0,0.28) 0%,
        rgba(0,0,0,0.16) 45%,
        rgba(0,0,0,0) 90%
    );

    filter: blur(10px);
    z-index: 1;      /* fica atrás da folha, mas acima do fundo da página */
    pointer-events: none;
}

.paper {
    position: relative;
    z-index: 2;      /* garante que a folha fique acima da sombra */
    /*background: #fff;*/
    padding: 30px;
    border-radius: 6px;
}




.paper-2-wrap {
    position: relative;
    display: table;
    
    border-radius: inherit !important;
    box-sizing: border-box !important;
    z-index: 1;
}

/* sombra horizontal atrás da folha — laterais mais para dentro */
.paper-2-wrap::before {
    content: "";
    position: absolute;
    left: 4%;
    right: 4%;
    bottom: -8px;
    height: 30px;

    background: linear-gradient(
        to right,
        rgba(0,0,0,0.45) 10%,     /* antes era 0% → agora começa 10% para dentro */
        rgba(0,0,0,0.10) 30%,     /* suavização mais interna */
        rgba(0,0,0,0) 50%,        /* centro claro */
        rgba(0,0,0,0.10) 70%,     /* suavização mais interna */
        rgba(0,0,0,0.45) 90%      /* antes era 100% → agora termina 10% antes */
    );

    filter: blur(10px);
    z-index: 1;
    pointer-events: none;
    box-sizing: border-box !important;
}

.paper-2 {
    position: relative;
    z-index: 2;
    /*background: #fff;*/
    /*padding: 10px 30px 0px;*/
    padding: 0px;
    /*border-radius: inherit !important;*/
    box-sizing: border-box !important;
}























/*▲▲▲▲▲▲▲▲▲▲▲▲▲▲*/
/*---- ▲ body ▲ ----*/



/*▼▼▼▼▼▼▼▼▼▼▼▼▼▼▼▼*/
/*---- ▼ footer ▼ ----*/

footer{
    color: var(--color-white);
    text-align: center;
    background-color: var(--color-1);
    
    h5{
        color: var(--color-2);
    }
    a, a:hover, a:focus{
        color: var(--color-white) !important;
    }
    li{
        text-align: center;
    }
    
    .social{
        i{
            color: var(--color-2);
        }
    }
    
    .to-top i{
        color: var(--color-2);
        cursor: pointer;
    }
    
    .whatsapp-fixed{
        font-size: 2rem;
        text-decoration: none;
        background-color: #25d366;
        border-radius: 50%;
        left: auto; 
        right: 0px;
        height: 50px;
        width: 50px;
        animation: pulse-whats 2.5s infinite;
        z-index: 9999;
        
        &:hover{
            text-decoration: none;
            animation: none;
        }
        .badge{
            position: absolute;
            font-family: arial;
            font-size: 12px;
            font-weight: 500;
            border: 1px solid rgba(255, 255, 255, 0.8);
            -webkit-background-clip: padding-box; /* for Safari */
            background-clip: padding-box; /* for IE9+, Firefox 4+, Opera, Chrome */
            padding: 0px;
            line-height: 20px;
            height: 20px;
            width: 20px;
            top: -5px;
            right: -6px;
        }
    }
}

/*▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲*/
/*---- ▲ footer ▲ ----*/



/*▼▼▼▼▼▼▼▼▼▼▼▼▼▼▼▼▼▼*/
/*---- ▼ Formulário ▼ ----*/
.form-control,
.form-select{
    font-weight: 600;
}
label{
    font-weight: 400;
}
.form-floating .btn-lg{
    padding-top: 13px;
    padding-bottom: 13px;
}
.form-floating label{
    color: #555 !important;
    font-weight: 400;
}
.form-floating > .form-control:focus~label,
.form-floating > .form-control:not(:placeholder-shown)~label,
.form-floating > .form-select~label{
    opacity: 0.5;
    transform: scale(.81) translateY(-.7rem) translateX(.15rem);
}
.form-floating > .form-control.rounded-pill,
.form-floating > .form-select.rounded-pill{
    padding-left: 1.6rem;
}
.form-floating > .form-control.rounded-pill ~ label,
.form-floating > .form-select.rounded-pill ~ label{
    /*padding-left: 1.8rem;*/
    margin-left: 0.9rem;
    background-color: transparent;
}
/*▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲*/
/*---- ▲ Formulário ▲ ----*/



/*▼▼▼▼▼▼▼▼▼▼▼▼▼▼▼▼*/
/*---- ▼ Extras ▼ ----*/



/*▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲*/
/*---- ▲ Extras ▲ ----*/