@charset "UTF-8";
/*!
* CSS personalizado Tecn72
*/

body{
    background-image:url(/assets/img/bg-site-tecn72.webp);
    background-repeat:no-repeat;
    background-position:center top;
    background-size:cover;
    background-color:#5932FF;
    background-attachment:fixed;
}

a{
    text-decoration:none;
}

a:hover{
    color:#5932FF;
    text-decoration:none;
}

form{
    display:block;
    margin:0 auto;
}

form input,
form select,
form textarea{
    margin-bottom:20px;
}

footer p{
    line-height:1.5;
}

footer a{
    color:#fff;
    text-decoration:none;
    transition:.3s;
}

footer a:hover{
    color:#5932FF;
}

.btn{
    margin:25px auto!important;
}

.footer-links li{
    margin-bottom:10px;
}

.bg-72-color{
    background-color:#5932FF;
}

.ti-footer-filter-text{
    display:none;
}

.bg-branco{
    background-color:#fff;
}

.feature{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    height:4rem;
    width:4rem;
    font-size:2rem;
}

.mt-n4{
    margin-top:-1.5rem!important;
}

.mb-4{
    margin-bottom:1.5rem!important;
}

.bf{
    font-weight:bold;
}

.btn-whatsapp{
    background-color:#0EC044;
    border:1px solid #066623;
    color:#fff;
}

.btn-whatsapp:hover{
    background-color:#0aa83b;
    border-color:#066623;
    color:#fff;
}

.btn-roxo{
    background-color:#5932FF;
    border:1px solid #2100A4;
    color:#fff;
}

.btn-roxo:hover{
    background-color:#4324cc;
    border-color:#2100A4;
    color:#fff;
}

/* Topo das páginas */

.site-hero{
    padding:2.25rem 0 2.75rem;
}

.site-hero .bg-branco{
    box-shadow:0 4px 12px rgba(0,0,0,.05);
    overflow:hidden;
}

.site-hero-content{
    margin:1.25rem auto;
    max-width:980px;
}

.site-hero-title{
    margin:28px auto 0!important;
    font-size:35px!important;
    line-height:1.2!important;
    max-width:900px;
}

.site-hero p{
    max-width:850px;
    margin:1rem auto 0;
    line-height:1.55;
}

.site-hero .btn{
    margin-top:28px!important;
}

/* Logo topo */

@media(max-width:420px){

    .site-hero-logo,
    img.site-hero-logo{
        width:100%!important;
        max-width:190px!important;
        height:auto!important;
        display:block!important;
        margin:0 auto 20px auto!important;
    }

}

@media(max-width:768px){

    .site-hero{
        padding:1.25rem 0 1.75rem;
    }

    .site-hero .container{
        padding-left:1rem!important;
        padding-right:1rem!important;
    }

    .site-hero .bg-branco{
        padding:1.5rem 1.1rem!important;
        border-radius:1rem!important;
    }

    .site-hero-content{
        margin:0 auto;
    }

    .site-hero-title{
        margin-top:22px!important;
        font-size:2rem!important;
        line-height:1.15!important;
    }

    .site-hero p{
        font-size:1.08rem!important;
        line-height:1.5;
    }

    .site-hero .btn{
        width:100%;
        max-width:360px;
        padding:.85rem 1rem;
        font-size:1rem;
    }

    .hero img,
    .page-header img,
    header img[src*="logo-tecn72"]{
        width:100%!important;
        max-width:220px!important;
        height:auto!important;
        object-fit:contain!important;
        display:block!important;
        margin:0 auto 20px auto!important;
    }

}

@media(min-width:769px) and (max-width:1024px){

    .hero img,
    .page-header img,
    header img[src*="logo-tecn72"]{
        max-width:260px!important;
    }

}

/* Menu Sanduíche */

.menu72-btn{
    position:fixed;
    right:20px;
    bottom:20px;
    z-index:9999;
    width:60px;
    height:60px;
    border:0;
    border-radius:50%;
    background:#5932FF;
    color:#fff;
    font-size:2rem;
    display:flex!important;
    align-items:center;
    justify-content:center;
    cursor:pointer;
    margin:0!important;
    box-shadow:0 10px 25px rgba(0,0,0,.25);
    transition:.3s;
}

.menu72-btn:hover{
    background:#4320e0;
    color:#fff;
    transform:translateY(-3px);
}

.menu72-offcanvas{
    width:390px!important;
    max-width:92%;
    border:0;
    background:#fff;
    box-shadow:-10px 0 35px rgba(0,0,0,.15);
}

.menu72-top{
    min-height:85px;
    padding:20px 24px;
    background:#fff;
    border-bottom:1px solid #e9ecef;
    display:flex;
    align-items:center;
    justify-content:space-between;
}

.menu72-top img{
    max-height:45px;
    width:auto;
}

.menu72-close{
    width:42px;
    height:42px;
    border:0;
    border-radius:50%;
    background:#f5f5f5;
    color:#222;
    font-size:1.25rem;
    cursor:pointer;
    margin:0!important;
    display:flex!important;
    align-items:center;
    justify-content:center;
    transition:.3s;
}

.menu72-close:hover{
    background:#5932FF;
    color:#fff;
}

.menu72-body{
    padding:18px 22px 30px;
}

.menu72-group{
    padding:18px 0;
    border-bottom:1px solid #ececec;
}

.menu72-group:last-of-type{
    border-bottom:0;
}

.menu72-title{
    display:flex;
    align-items:center;
    gap:12px;
    margin-bottom:10px;
    color:#5932FF;
    font-size:.95rem;
    font-weight:800;
    text-transform:uppercase;
    letter-spacing:.5px;
}

.menu72-title span{
    width:42px;
    height:42px;
    border-radius:12px;
    background:#5932FF;
    color:#fff;
    display:flex;
    align-items:center;
    justify-content:center;
    font-size:1.15rem;
    box-shadow:0 6px 18px rgba(89,50,255,.20);
}

div.menu72-subtitle{
    margin:18px 0 6px;
    padding-left:12px;
    color:#999999;
    font-size:.78rem;
    font-weight:800;
    text-transform:uppercase;
    letter-spacing:1px;
}

@media(max-width:640px){
    div.menu72-subtitle{
        padding-left:12px;
    }
}

.menu72-group a{
    display:flex;
    align-items:center;
    justify-content:space-between;
    padding:10px 0 10px 54px;
    color:#222;
    font-size:.98rem;
    font-weight:600;
    text-decoration:none;
    transition:.25s;
}

.menu72-group a:hover{
    color:#5932FF;
    transform:translateX(4px);
}

.menu72-group a i{
    color:#999;
    font-size:.85rem;
}

.menu72-whatsapp{
    margin-top:22px;
    padding:16px 18px;
    border-radius:12px;
    background:#0EC044;
    color:#fff!important;
    text-decoration:none;
    display:grid;
    grid-template-columns:48px 1fr;
    grid-template-areas:
        "icon titulo"
        "icon texto";
    align-items:center;
    box-shadow:0 8px 20px rgba(14,192,68,.25);
    transition:.3s;
}

.menu72-whatsapp:hover{
    transform:translateY(-2px);
    color:#fff!important;
}

.menu72-whatsapp i{
    grid-area:icon;
    font-size:2rem;
}

.menu72-whatsapp strong{
    grid-area:titulo;
    display:block;
    font-size:1.05rem;
}

.menu72-whatsapp small{
    grid-area:texto;
    display:block;
    opacity:.95;
}

.menu72-social{
    display:flex;
    justify-content:center;
    gap:12px;
    margin-top:22px;
}

.menu72-social a{
    width:46px;
    height:46px;
    border:1px solid #ddd;
    border-radius:50%;
    display:flex;
    align-items:center;
    justify-content:center;
    color:#5932FF;
    text-decoration:none;
    transition:.3s;
}

.menu72-social a:hover{
    background:#5932FF;
    color:#fff;
    border-color:#5932FF;
}

body.menu72-open .menu72-btn{
    display:none!important;
}

/* Footer */

.footer72{
    background:linear-gradient(
        180deg,
        rgba(16,16,16,.85),
        rgba(5,5,5,.85)
    );
    /*backdrop-filter:blur(8px);
    -webkit-backdrop-filter:blur(8px);*/
    border-top:1px solid rgba(255,255,255,.07);
}

.footer72-icon{
    width:70px;
    height:70px;
    border-radius:16px;
    background:#5932FF;
    color:#fff;
    display:flex;
    align-items:center;
    justify-content:center;
    font-size:2rem;
    box-shadow:0 8px 20px rgba(89,50,255,.25);
}

.footer72-check{
    color:#5932FF;
}

.footer72-line{
    border-color:rgba(255,255,255,.12);
}

.footer72-logo{
    max-height:70px;
    width:auto;
}

.footer72-social{
    width:46px;
    height:46px;
    border:1px solid rgba(255,255,255,.25);
    border-radius:50%;
    color:#fff;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    text-decoration:none;
    margin:0 5px;
    transition:.3s;
}

.footer72-social:hover{
    background:#5932FF;
    border-color:#5932FF;
    color:#fff;
}

.footer72-privacy{
    color:#fff;
    text-decoration:none;
    transition:.3s;
}

.footer72-privacy:hover{
    color:#5932FF;
}

@media(max-width:768px){

    .menu72-btn{
        right:15px;
        bottom:15px;
        width:54px;
        height:54px;
        font-size:1.8rem;
    }

    .menu72-top{
        min-height:75px;
        padding:16px 20px;
    }

    .menu72-top img{
        max-height:40px;
    }

    .menu72-body{
        padding:15px 18px 25px;
    }

    .menu72-group a{
        padding-left:50px;
        font-size:.95rem;
    }

    .footer72{
        text-align:center;
    }

    .footer72 .d-flex{
        justify-content:center;
    }

    .footer72-icon{
        width:62px;
        height:62px;
        font-size:1.7rem;
    }

    .footer72-logo{
        max-height:60px;
    }

}.menu72-btn{
    animation:menuPulse 3s infinite;
}

.menu72-btn i{
    transform:translateY(2px);
    animation:menuFloat 2s ease-in-out infinite;
}

@keyframes menuPulse{

    0%{
        box-shadow:0 0 0 0 rgba(89,50,255,.35);
    }

    70%{
        box-shadow:0 0 0 12px rgba(89,50,255,0);
    }

    100%{
        box-shadow:0 0 0 0 rgba(89,50,255,0);
    }

}

@keyframes menuFloat{

    0%,100%{
        transform:translateY(2px);
    }

    50%{
        transform:translateY(-1px);
    }

}

/* Botões dos cards da Home */
.btn-home-sites{
    background:#5932FF;
    border:1px solid #000066;
    color:#FFFFFF;
}

.btn-home-sites:hover{
    background:#4b28e6;
    border-color:#000066;
    color:#FFFFFF;
}

.btn-home-ti{
    background:#FFBF00;
    border:1px solid #A47B00;
    color:#000000;
}

.btn-home-ti:hover{
    background:#e6ac00;
    border-color:#A47B00;
    color:#000000;
}

.btn-home-international{
    background:#282534;
    border:1px solid #02080D;
    color:#FFFFFF;
}

.btn-home-international:hover{
    background:#1f1c29;
    border-color:#02080D;
    color:#FFFFFF;
}

.home-card72 .card-body{
    display:flex;
    flex-direction:column;
}

.home-card72 p{
    margin-bottom:1.6rem!important;
}

.home-card72 .btn{
    width:100%;
    max-width:260px;
    margin-top:0!important;
    margin-bottom:0!important;
}


/* Correção imagens do Portfólio */
.portfolio img,
.portfolio-card img,
.portfolio-item img,
.card-portfolio img,
.portfolio .card img,
.portfolio .card-img-top{
    width:100%!important;
    height:auto!important;
    max-width:100%!important;
    object-fit:contain!important;
    aspect-ratio:auto!important;
}

.portfolio .card,
.portfolio-card,
.portfolio-item{
    overflow:hidden;
}
