* {
    font-size: 13px;
    font-family: "Poppins", sans-serif !important;
    font-style: normal;
}


/* colors */

:root {
    --blue: #496EB4;
    --purple: #5554A0;
    --blue-text: #486DB3;
    --purple-text: #55529E;
    --black-text: #272727;
    --light-purple: #7B7ABE;
    --purple-bg: #e8e8fb;
    --blue-bg: #F3F9FF;
}

/* text */

h1 { font-weight: 600!important; font-size: 36px!important; color: var(--blue)!important;}
h2 { font-weight: 600!important; font-size: 28px!important; }
h3 { font-weight: 500!important; font-size: 20px!important; color: var(--purple)!important;}
h4 { font-weight: 500!important; font-size: 18px!important;}
h5 { font-weight: 400!important; font-size: 14px!important; color: var(--blue-text)!important;}
p{ font-weight: 400!important; font-size: 13px!important; color: var(--black-text)!important; line-height: 23px;}
a{ text-decoration: none!important;}

.text-blue { color: var(--blue);}
.text-purple { color: var(--purple);}
.text-blue-lighter { color: var(--blue-text)!important;}


@media (max-width:768px){
    h1 { font-size: 30px!important; }
    h2 { font-size: 22px!important; }
    h3 { font-size: 16px!important; }
    h4 { font-size: 14px!important; }
    .h1-slider { font-size: 32px!important; }
}

/* different text */

.h1-slider {  color: var(--purple-text)!important; font-size: 40px!important;}
.h3-slider {  color: var(--blue-text)!important;}
.text-blue { color: var(--blue-text) !important; }
.h1-page { color: var(--purple)!important; font-size: 38px!important;}
.breadcrumb li { font-size: 13px!important; padding: 0 2px;}
ul { list-style: none;}

#legal h2 {
    color: var(--blue)!important;
}

#legal h4 {
    color: var(--purple)!important;
}

#legal strong {
    color: var(--blue)!important;
}


/* containers */ 

@media (max-width:768px) {
    .container { padding: 20px 0 !important;}
}


/* bg blobs */

.top-left-big-blob {
    background-image: url('/assets/img/website/bg/top-left-big-blob.svg');
    background-size:auto;
    background-position: top left;
    background-repeat: no-repeat;
}

.top-right-blob {
    background: url('/assets/img/website/bg/top-right-blob.svg');
    background-size: auto;
    background-repeat: no-repeat;
    background-position: top right;
}

.bottom-right-blob {
    background: url('/assets/img/website/bg/bottom-right-blob.svg');
    background-size: auto;
    background-repeat: no-repeat;
    background-position: bottom  right;
    
}

.top-left-small-blob {
    background: url('/assets/img/website/bg/top-left-small-blob.svg');
    background-size: auto;
    background-repeat: no-repeat;
    background-position: top left;
    
}

/* images */

.rounded-image {
    border-radius: 2rem;
    overflow: hidden;
    height: 350px;
    display: flex;
    position: relative;
}
.rounded-image img {
    object-fit: cover;
    min-width:100%; 
    min-height:100%
}

/* btns */

.btn {
    min-width: 170px;
    /* border-radius: 5rem!important; */
    border-radius: 1rem!important;
    padding: 10px 15px!important;
    font-size: 13px!important;
}

.btn:hover {
    cursor: pointer;
}

.btn-colored , .btn-primary{
    color: white !important;
    background-size: 300% 100%;
    -o-transition: all .4s ease-in-out !important;
    -webkit-transition: all .4s ease-in-out !important;
    transition: all .4s ease-in-out;
    background-image: linear-gradient(to right, #496EB4, #5554A0, #5554A0, #496EB4);
    border: none!important;
}

.btn-colored:hover , .btn-colored:active , .btn-primary:hover, .btn-primary:active{
    background-position: 100% 0;
    -o-transition: all .4s ease-in-out !important;
    -webkit-transition: all .4s ease-in-out !important;
    transition: all .4s ease-in-out !important;
    background-image: linear-gradient(to right, #496EB4, #5554A0, #5554A0, #496EB4);
    border: none!important;
}

.btn-colored-success {
    color: white !important;
    -o-transition: all .4s ease-in-out !important;
    -webkit-transition: all .4s ease-in-out !important;
    transition: all .4s ease-in-out;
    background-size: 300% 100%;
    background-image: linear-gradient(to right, #0ba360, #3cba92, #0ba360, #3cba92);
}

.btn-colored-success:hover , .btn-colored-success:active {
    -o-transition: all .4s ease-in-out !important;
    -webkit-transition: all .4s ease-in-out !important;
    transition: all .4s ease-in-out !important;
    background-position: 100% 0;
    background-image: linear-gradient(to right, #0ba360, #3cba92, #0ba360, #3cba92);

}

.btn-outline {
    color: var(--purple-text) !important;
    border: 1px solid var(--blue)!important;
}

/* header */

header .navbar {
    background-color: var(--blue-bg)!important;
}

header .navbar-nav > li {
    padding: 10px 20px;
    align-self: center;
}
header .navbar-nav > li > a{
    padding: unset;
    text-transform: none;
    font-size: 15px;
    font-weight: 500;
    color: var(--blue)!important;
}
header .navbar-nav > li > a:hover {
    opacity: unset;
    border: none;
    background: unset;
    padding-bottom: unset;
}

header .dropdown-menu {
    display: block;
    opacity: 0;
    visibility: hidden;
    transform: translateY(20%);
    transition: all .5s;
}
header  .dropdown:hover .dropdown-menu{
    opacity: 1;
    visibility: visible;
    transform: translateY(0%);
}

header .navbar-nav > li > a:focus {
    opacity: unset;
    border-bottom: unset;
    padding-bottom: initial;
}

.navbar .dropdown-menu li {
    padding: 5px 0;
}

.dropdown-menu>li>a:hover {
    background-color: transparent;
    color: var(--purple);
}

.navbar-expand-lg .navbar-collapse{
    justify-content: right;
}

@media (max-width: 991px) {
    header .container {
        padding: 0!important;
    }
}
@media (min-width:991px) and (max-width:1050px) {
    header .navbar-nav > li {
        padding: 10px 12px;
    }
}

@media (min-width:768px) and (max-width:991px) {
    .collapse:not(.show){
        display: none!important;
    }
}

/* footer */

footer {
    background: linear-gradient(to top, #496EB4, #5494CF);
}

footer ul {
    list-style: none;
    color: #E1E1F9;
    line-height: 25px;
}

footer a { color: #E1E1F9; cursor: pointer;}
footer a:hover { color: rgb(196, 196, 241); }

footer h3 {
    text-transform: unset;
    color: white!important;
}
/* 
footer::before {
    content: url('/assets/img/website/bg/white-wave-bg.svg');
} */

#small-footer {
    background-color: #4566A4;
}

.legal {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    padding: 5px 0;
}

/* slider */

.slider-row {
    align-items: center;
}

/* card */

.service-card , .card-resume-panel, .table-row-card, .card-contacts, .product-card, .faqs-card, .account-card, .legal-card, .blog-card{
    box-shadow: 0 4px 14px #496fb43c;
    background: white;
    border: none;
    border-radius: 1rem!important;
}

.blog-card {
    overflow: hidden;
    padding: 0 !important;
}

.checkout-card {
    box-shadow: 0 4px 14px #496fb43c;
    background: white;
    border: none;
    padding: 20px;
    border-radius: 2rem;
    border-top-left-radius: 0;
}

.payment-card {
    box-shadow: 0 0 14px #496fb43c;
    background: white;
    border: none;
    border-radius: 1rem;
}

.card-resume-panel { padding: 20px; }

/* pages */

/* home  */

.home-slider {
    background-color: #F3F9FF; 
    height:760px; 
    overflow: hidden;
}


.industrial-img {
    width: 70%;
}

/* contacts */

.card-contacts , .section-contacts{
    padding: 5%!important;
}

/* budget */


#budget select{
    border-radius: 1rem !important;
    height: 35px!important;
    border: none!important;
    background-color: #F0F5FF!important;
    font-size: 12px!important;
    padding: 5px 15px !important;
    color: var(--black-text)!important;
    display: block;
    width: 100%;
}

#budget select:focus {
    background-color: #F5F5FF !important;
    color: #55529E !important;
}


/* faqs and account card*/


.faqs-card{
    padding: 8px 15px;
}

.account-card {
    padding: 10px!important;
}
.faqs-card-item , .account-card-item{
    padding: 10px!important;
}

.faqs-card-item, .account-card-item{
    color: var(--purple)!important;
}

.faqs-card-item .active ,.account-card-item.active{
    color: var(--purple)!important;
    background-color: var(--purple-bg)!important;
}



.collapse.in {
    display: block!important;
}
.panel-default>.panel-heading+.panel-collapse>.panel-body {
    border: none;
}
.panel-default>.panel-heading {
    background-color: transparent;

}

/* legal */

.legal-card {
    border: none;
    border-radius: 1.5rem!important;
}

#legal .list-group-item.active {
    background-color: var(--blue);
    border-color: var(--blues);
    color: white;
}

#legal .list-group-item:hover{
    background-color: var(--purple-bg);
    border-color: var(--purple-bg);
}

#legal .list-group-item.active:hover {
    background-color: var(--light-purple);
    border-color: var(--light-purple);
} 

#legal .list-group-item {
    padding: 10px 20px;
    color: var(--purple);
}

/* shop */

.product-card { 
    /* display:flex; 
    flex-direction: column; 
    justify-content: space-between; 
    overflow: hidden; 
    border-radius: 2rem; 
    min-height: 100%; 
    position:relative; */

    display: flex;
    flex-direction: column;
    justify-content: space-between;
    overflow: hidden;
    border-radius: 2rem;
    min-height: 100%;
    position: relative;
    height: 100%; 
}

.product-card-footer {
    margin-top: auto; 
    padding: 20px;
}


.input-group-outline {
    border-radius: 2rem!important;
    border: 1px solid var(--blue);
    padding: 8px 12px;
    justify-content: space-between;
    padding-right: 30px;
}

.form-control-outline , .form-control-outline:focus {
    border: none;
}

.form-control-outline::placeholder {
    color: var(--blue-text);
}

.btn-search-icon {
    background: transparent;
    border: none;
    width: auto;
}

/* services */

.service-gallery {
    padding-right: 50px;
}
.service-gallery #images, .gallery-item{
    border-radius: 2rem;
    overflow: hidden;
}

.service-gallery .img-responsive {
    border-radius: 1rem;
}

/* background styling services page */

/* 3rd service blue bg */
#services-list .service-container:nth-child(3) {background:none}
#services-list .service-container:nth-child(3) .service-bg { background-color: #528AC8;}
#services-list .service-container:nth-child(3) .container { padding-top: 20px; padding-bottom:20px;}
#services-list .service-container:nth-child(3) h1 , #services-list .service-container:nth-child(3) p{ color:white!important; }
#services-list .service-container:nth-child(3) h3{ color: #e8e8fb!important; }
#services-list .service-container .bg { display: none; }
#services-list .service-container:nth-child(3) .bg { display: block; }

/* other */

/* shopping cart */

.breadcrumb>li+li:before { padding: initial; }

.text-muted-light { color: var(--light-purple)!important; opacity: 0.8;}

.table>tbody>tr>td {
    border: none;
    color: var(--purple);
    background: transparent;
    padding: 10px;
    align-items: center;
}

.vertical-align-middle { vertical-align:middle !important; }


.table>:not(caption)>*>* {
    border: none;
}

.table>thead>tr>th {
    font-weight: 600;
    color: var(--blue-text);
    background:transparent;
    border: none;
    font-size: 13px;
}

.table-row-card {
    border: none;
    background: transparent;
}

.input-group>:not(:first-child):not(.dropdown-menu):not(.valid-tooltip):not(.valid-feedback):not(.invalid-tooltip):not(.invalid-feedback) {
    border-radius: 2rem!important;
    border-color: var(--blue);
    border-width: 0.5px;
}

.table-hover>tbody>tr:hover{
    box-shadow: 0 4px 14px #60449c3c;
    background-color: unset;
}

.table-hover>tbody>tr:hover>* {
    --bs-table-bg-state: transparent!important;
}


.number-spinner {
    display: flex;
    align-items: center;
    white-space: nowrap;
}

.table-shopping-cart {
    border-collapse: separate;
    border-spacing: 0 15px;
}

.table-shopping-cart td:first-child { border-top-left-radius: 2rem; border-bottom-left-radius: 2rem;}
.table-shopping-cart td:last-child { border-top-right-radius: 2rem; border-bottom-right-radius: 2rem;}


.value-button {
    display: inline-block;
    border: 1px solid var(--blue);
    margin: 0px;
    width: 40px;
    height: 20px;
    text-align: center;
    vertical-align: middle;
    padding: 11px 0;
    -webkit-touch-callout: none;
    -webkit-user-select: none;
    -khtml-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
  }

  .value-button:hover {
    cursor: pointer;
  }

  form .decrease, #decrease {
    border-radius: 2rem 0 0 2rem;
    height: 40px;
  }

  form .increase, #increase {
    height: 40px;
    border-radius: 0 2rem 2rem 0;
  }

  form #input-wrap {
    margin: 0px;
    padding: 0px;
  }

  .update-product {
    text-align: center;
    border: none;
    border-top: 1px solid var(--blue);
    border-bottom: 1px solid var(--blue);
    margin: 0px;
    width: 50px;
    height: 40px;
  }

  .update-product:focus {
    border: 1px solid var(--blue);
    color: inherit;
  }

  input[type=number]::-webkit-inner-spin-button,
  input[type=number]::-webkit-outer-spin-button {
      -webkit-appearance: none;
      margin: 0;
  }

/* checkout  */

.form-control {
    border-radius: 1rem !important;
    line-height: 25px!important;
    border: none!important;
    background-color: #F0F5FF!important;
    font-size: 12px!important;
    padding: 5px 15px !important;
    color: var(--black-text)!important;
}

.form-control:focus {
    background-color: #F5F5FF !important;
    color: #55529E !important;
}

.form-label{
    font-weight: normal;
    color: var(--blue);
}

.checkbox label, .radio label {
    padding-left: 0;
}

.label-default {
    background-color: var(--light-purple);
    margin-left: 5px;
}

.nav-tabs {
    border: none;
    margin-bottom: -2px!important;
}

.nav-tabs>li.active>a, .nav-tabs>li.active>a:focus, .nav-tabs>li.active>a:hover {
    box-shadow: 0 -4px 14px #496fb43c !important;
    border: none;
}

.nav-tabs>li>a {
    color: var(--purple);
}
.nav-tabs>li>a:hover {
    border-color: var(--purple-bg);
    background-color: var(--purple-bg);
}

/* form is requeired icon color  */
.form-group.is-required > label:after, .label-required:after {
    color: var(--purple)!important;
}

/* water animation  */
  #water {
    position: absolute;
    z-index: 0;
    top: 0;
    width: 100%;
    height: 100%;
    pointer-events: none;
  }
  .dg.ac {
    display: none;
  }

  /* account */


  .list-group a {
    color: #7C9AD2;
    transition: 0.3s ease;
  }

  .list-group a:hover {
    color: #5b75be;
  }
  .list-group a:active, .list-group a:focus {
    color: #55529E;
  }

  .breadcrumb>li+li:before {
    content: none;
  }

  .breadcrumb {
    padding: unset;
    margin: unset;
    list-style: unset;
    background-color: unset;
    border-radius: unset;
  }

  .nav-tabs-account {
    border-bottom: none!important;
  }

  .nav-tabs-account a{
    font-weight: 500;
  }

  .account-card .list-group-item {
    border: none;
  }



  /* alerts */

  .alert-dismissable .close {
    right: 0!important;
  }

  .fade .in {
    opacity: 1 !important;
  }



  /* #canvas {
    position: absolute;
    top: 0;
    left: 0;
    z-index: 0; /* Garante que o canvas fique atrás dos botões 
}

.home-slider-container {
    z-index: 1;
} */



#canvas {
    position: absolute; 
    top: 0; 
    left: 0; 
    width: 100%; 
    height: 100%; 
    z-index: 0; 
    filter: blur(10px);
}

.home-slider-container {
    position: relative;
    margin-left:auto;
    margin-right: auto; /* Centraliza os itens na linha */
    top:150px;
    z-index: 1; /* Mantém os elementos acima do canvas */
    background-color: transparent; /* Torna o fundo transparente */
    pointer-events: none; /* Permite cliques passarem pelo elemento */
}

/* Estilos para os botões e textos */
.btn {
    background-color: rgba(255, 255, 255, 0.8); /* Exemplo: botão com fundo semi-transparente */
    color: #333; /* Cor do texto dos botões */
    border: 1px solid #ccc; /* Borda dos botões */
    pointer-events: auto; /* Permite que os botões sejam clicáveis */
}

a{
    cursor: pointer;
}

header{ /*tive que colocar isto pq por algum motivo, algum css que deve andar por ai, o header (elemento fora) nao tinha altura*/
    min-height: 70px;
}

.align-middle{
    vertical-align: middle !important;
}
