:root{
  --title-blue: #005A83;
  --h1-color: var(--title-blue);
  --h2-color: var(--title-blue);
  --h3-color: var(--title-blue);
  --h4-color: var(--title-blue);
  --primary: #005A83;
  --secondary: #d8f0fb;
  --tertiary: #e55a00;
  --primary-bg: #d8f0fb;
}

/* GLOBALI
-------------------------------------------------- */
html{
  font-size: 14px;
}

body {
  color: #000000;
  font-family: "sole-sans-variable", sans-serif;
  font-variation-settings: "wdth" 100, "wght" 500;
  font-size: 1.4rem;
}

h1{
  color: var(--h1-color);
  font-family: "sole-sans-variable", sans-serif;
  font-variation-settings: "wdth" 90, "wght" 300;
  font-style: italic;
  font-weight:bolder;
  font-size: 3rem;
}
h2{
  color: var(--h2-color);
  font-size: 2.5rem;
  margin: 2rem 0 2rem;
    font-variation-settings: "wdth" 100, "wght" 500;

}
h3{
  color: var(--h3-color);
}
h4{
  color: var(--h4-color);
}

p{
  font-size: 1.4rem;
  line-height: 1.4;
  font-weight: 500;
}

.avatar {
  vertical-align: middle;
  width: 7rem;
  height: 7rem;
  border-radius: 50%;
}
.v-center {
  display: grid;
  align-items: center;
  height: 100%;
}
.rdb-container{
  padding:1rem 12%;
}
.bg-white {
  background-color: white !important;
}
.bg-light {
  background-color: var(--secondary) !important;
}


@media only screen and (max-width: 991px){
  .rdb-container{
    padding:1rem 10%;
  }
}

.rdb-highlights  .row .col {
  padding: 1rem;
  text-align: center;
  flex: auto;
}
/*.rdb-container .row .col img {
  padding: 1rem ;
  background: #e55a00;
  border-radius: 3rem;
  overflow: visible;
}*/

.row-odd{
  padding-top: 1.8rem;
  padding-bottom: 1.8rem;
}

.row-even{
  background-color: #d8f0fb;
  padding-top: 1.8rem;
  padding-bottom: 1.8rem;
}

.bd-placeholder-img {
  font-size: 1.125rem;
  text-anchor: middle;
  -webkit-user-select: none;
  -moz-user-select: none;
  user-select: none;
}
.box-moduli {
  padding: 1.5rem;
    background-color: var(--primary-bg);
    text-align: center;
}
.box h4,
.products h4,
.vantaggi h4{
  text-transform: uppercase;
  font-size: 2rem;
  margin-bottom: 1rem;
  padding: 1rem 0;
  font-family: "sole-sans-variable", sans-serif;
  font-style: italic;
  font-variation-settings: "wdth" 100, "wght" 600;
}
.box img {
  background-color: var(--tertiary);
  width: 25%;
  margin: auto;
  border-radius: 100%;
  overflow: visible;
  padding: 1rem;
}
/* .box h4::before {
  content: "\0483"; /* Unicode character 
  float: left;
  font-size: 4rem;
  height: 30px;
  width: 30px;
  text-align-last: center;
} */

.ico-1 h4::before {
  color: #2d54e2;
  rotate: 16deg;
}
.ico-2 h4::before {
  color: #ed4a4a;
  rotate: 16deg;
}
.ico-3 h4::before {
  color: #4a8ced;
  rotate: 16deg;
}
.ico-4 h4::before {
  color: #edab4a;
  rotate: 16deg;
}
.ico-5 h4::before {
  color: #ff6633;
  rotate: 16deg;
}
.ico-6 h4::before {
  color: #8a4aed;
  rotate: 16deg;
}
.ico-7 h4::before {
  color: #63d15a;
  rotate: 16deg;
}
.ico-8 h4::before {
  color: #0ba9f6;
  rotate: 16deg;
}





#btn-go-up{
  bottom: 2rem;
  right: 2rem;
  position: fixed;
  background-color: var(--primary);
  border-spacing: 0cqb;
  border-radius: 50%;
  height: 3rem;
  width: 3rem;
  padding: .6rem .6rem;
  text-align: center;
  vertical-align: middle;
}
.fa-arrow-up:before {
  content: "\f062";
  color: var(--bs-white);
  font-size: 1.5rem;
}
.text-center {
  text-align: center;
}
a {
  color: rgba(var(--h3-color), var(--h3-color));
  text-decoration: underline;
}
.pr-2 {
  padding-right: 2rem;
}
.ptb-2 {
  padding: 3rem 15%;
}

/* OVERRIDE BOOTSTRAP
-------------------------------------------------- */
.card {
  margin: .5rem;
}
.img-fluid {
  width: 100%;
}
.row {
  --bs-gutter-x: 0px;
}

/* MAIN
-------------------------------------------------- */
main{
  width: 100%;
  max-width: 100%;
}

/* HEADER
-------------------------------------------------- */
.rdb-header{
  background-color: var(--bs-white);
  position: fixed;
  z-index: 6;
  width: 100%;
  padding: 1rem;
}
.navbar-brand{
  font-size: 2rem;
}
.nav-item img{
  height: 15px;
}
.nav-link {
  /* font-family: "Lato", sans-serif; */
  font-family: "sole-sans-variable", sans-serif;
  color: var(--primary);
  /* font-weight: 600; */
}
.navbar-nav .nav-link.active, .navbar-nav .nav-link.show {
  color: var(--primary);
}

.navbar-nav .nav-item {
  margin: 0rem 0.5rem;
}
.navbar-nav .nav-item a {
  position: relative;
}
/*.navbar-nav .nav-item a:hover::after, .navbar-nav .nav-item a.active::after {
  width: 100%;
  right: auto;
  left: 0;
}
.navbar-nav .nav-item a::after {
  content: '';
  position: absolute;
  left: 0;
  right: auto;
  width: 0px;
  height: 3px;
  background: var(--primary);
  bottom: -3px;
  transition: all 0.3s ease-out 0s;
  border-radius: 5px;
}*/
.nav-link:focus, .nav-link:hover {
  color: var(--primary);
}

/*========= new navbar ==========*/
.navbar-area {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 99;
  -webkit-transition: all 0.3s ease-out 0s;
  transition: all 0.3s ease-out 0s;
}

.sticky {
  position: fixed;
  z-index: 99;
  background-color: rgba(255, 255, 255, 0.8);
  -webkit-backdrop-filter: blur(5px);
          backdrop-filter: blur(5px);
  -webkit-box-shadow: inset 0 -1px 0 0 rgba(0, 0, 0, 0.1);
  box-shadow: inset 0 -1px 0 0 rgba(0, 0, 0, 0.1);
  -webkit-transition: all 0.3s ease-out 0s;
  transition: all 0.3s ease-out 0s;
}

.sticky .navbar {
  padding: 10px 0;
}

@media only screen and (min-width: 768px) and (max-width: 991px), (max-width: 767px) {
  .sticky .navbar {
    padding: 15px 0;
  }
}

.sticky .navbar .navbar-nav .nav-item a {
  color: var(--primary);
}

.sticky .navbar .navbar-nav .nav-item a::before {
  color: var(--primary);
}

.sticky .navbar .navbar-toggler .toggler-icon {
  background: var(--primary);
}

.navbar {
  padding: 0;
  border-radius: 5px;
  position: relative;
  -webkit-transition: all 0.3s ease-out 0s;
  transition: all 0.3s ease-out 0s;
  padding: 20px 0;
}

@media only screen and (min-width: 768px) and (max-width: 991px), (max-width: 767px) {
  .navbar {
    padding: 17px 0;
  }
}

.navbar-brand {
  padding: 0;
}

.navbar-brand img {
  height: 5rem;
}

.navbar-toggler {
  padding: 0;
}

.navbar-toggler:focus {
  outline: none;
  -webkit-box-shadow: none;
  box-shadow: none;
}

.navbar-toggler .toggler-icon {
  width: 30px;
  height: 2px;
  background-color: var(--primary);
  display: block;
  margin: 5px 0;
  position: relative;
  -webkit-transition: all 0.3s ease-out 0s;
  transition: all 0.3s ease-out 0s;
}

.navbar-toggler.active .toggler-icon:nth-of-type(1) {
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  top: 7px;
}

.navbar-toggler.active .toggler-icon:nth-of-type(2) {
  opacity: 0;
}

.navbar-toggler.active .toggler-icon:nth-of-type(3) {
  -webkit-transform: rotate(135deg);
  transform: rotate(135deg);
  top: -7px;
}

@media only screen and (min-width: 768px) and (max-width: 991px), (max-width: 767px) {
  .navbar-collapse {
    position: absolute;
    top: 100%;
    left: 0;
    width: 100%;
    background-color: #fff;
    z-index: 9;
    -webkit-box-shadow: 0px 15px 20px 0px rgba(0, 0, 0, 0.1);
    box-shadow: 0px 15px 20px 0px rgba(0, 0, 0, 0.1);
  }
}

@media only screen and (min-width: 768px) and (max-width: 991px), (max-width: 767px) {
  .navbar-nav {
    padding: 20px 30px;
  }
}

.navbar-nav .nav-item {
  position: relative;
  margin: 0 1rem;
}

@media only screen and (min-width: 768px) and (max-width: 991px), (max-width: 767px) {
  .navbar-nav .nav-item {
    margin-left: 0px;
  }
}

.navbar-nav .nav-item a {
  font-size: 1.5rem;
    color: var(--primary);
    -webkit-transition: all 0.3s ease-out 0s;
    transition: all 0.3s ease-out 0s;
    padding: 10px 0;
    position: relative;
    z-index: 1;
    text-decoration: none;
    font-variation-settings: "wdth" 90, "wght" 500;
}

.navbar-nav .nav-item a::before {
  content: "";
  position: absolute;
  height: 5px;
  width: 0;
  border-radius: 16px;
  background: var(--tertiary);
  bottom: 0px;
  left: 0;
  z-index: -1;
  -webkit-transition: all 0.3s ease-out 0s;
  transition: all 0.3s ease-out 0s;
}

@media only screen and (min-width: 768px) and (max-width: 991px), (max-width: 767px) {
  .navbar-nav .nav-item a::before {
    top: auto;
    bottom: 0;
  }
}

@media only screen and (min-width: 768px) and (max-width: 991px), (max-width: 767px) {
  .navbar-nav .nav-item a {
    display: inline-block;
    padding: 6px 0px;
    color: #162447;
  }
}

.navbar-nav .nav-item a:hover::before, .navbar-nav .nav-item a.active::before {
  width: 100%;
}

.navbar-toggler:active,
.navbar-toggler:focus,
.navbar-toggler:hover {
  background-color: transparent !important;
  border-color: transparent !important;
}


/* INTRO
-------------------------------------------------- */

.rdb-intro{
    position: relative;
    overflow: hidden;
    height: 620px;
    display: flex;
    align-items: center;
    background-image: url(../images/color-bg.svg);
    background-size: cover;
    background-position: bottom center;
    background-repeat: no-repeat;
    z-index: 1;
  }



/*IMAGE INTRO*/
.rdb-intro .image-intro{
  padding: 0rem 2rem;
}

.image-intro img {
  width: 100%;
  border-radius: 2rem;
  box-shadow: 0px 1px 20px 3px #1f1670;
}

@media only screen and (max-width: 1730px) {
  .rdb-intro .image-intro img {
    width: 100%;
  }
}
@media only screen and (max-width: 991px) {
  .rdb-intro .image-intro {
    padding: 0;
  }
  .rdb-intro .image-intro img {
    padding: 0;
    width: 100%;
    margin-top: 2rem;
  }
}

  @media only screen and (min-width: 1200px) and (max-width: 1399px) {
    .rdb-intro{
      height: 750px;
    }
  }
  
  @media only screen and (min-width: 992px) and (max-width: 1199px) {
    .rdb-intro {
      height: 700px;
    }
  }
  
  @media only screen and (min-width: 768px) and (max-width: 991px), (max-width: 767px) {
    .rdb-intro{
      height: auto;
      padding: 150px 0 50px;
    }
  }

.rdb-intro h1 {
  color: var(--primary);
  font-size: 4.2rem;
  margin-bottom: 1rem;
  margin-top: 2rem; 
}
@media only screen and (min-width: 992px) and (max-width: 1199px) {
  .rdb-intro h1 {
    font-size: 50px;
  }
}

@media (max-width: 767px) {
  .rdb-intro h1 {
    font-size: 45px;
  }
}

.rdb-intro p{
  font-size: 1.8rem;
  color: var(--primary);
}
.rdb-intro h1 span {
  color: var(--tertiary);
  font-variation-settings: "wdth" 80, "wght" 500;
  /* -webkit-text-fill-color: transparent;
  -webkit-text-stroke-width: 2px;
  -webkit-text-stroke-color: var(--tertiary);
  color: var(--primary); 
  font-size: 3.5rem;*/
}

.rdb-intro button{
  font-size: 1.5rem;
  background-color: #ffffff;
  border: 3px solid #005a83;
  padding: .8rem 2rem;
  font-weight: 500;
  color: #005a83;
  border-radius: 3rem;
  transition: transform .2s;
}
.rdb-intro button:hover{
  background-color: #3982a3;
  border-color: #005a83;
  -ms-transform: scale(1.05); /* IE 9 */
  -webkit-transform: scale(1.05); /* Safari 3-8 */
  transform: scale(1.05);
  color: #ffffff; 
}
button {
  font-size: 1.5rem;
    background-color: #ffffff;
    border: 3px solid #005a83;
    padding: .8rem 2rem;
    /* font-weight: 600; */
    color: #005a83;
    border-radius: 3rem;
    transition: transform .2s;
}
button:hover{
  background-color: #3982a3;
    border-color: #005a83;
    -ms-transform: scale(1.05);
    -webkit-transform: scale(1.05);
    transform: scale(1.05);
    color: #ffffff;
}

/* HIGHLITS
-------------------------------------------------- */
.rdb-highlights{
  margin-top: 10px;
}
.icon-round-wrap {
  padding: 1rem;
  background: #e55a00;
  border-radius: 3rem;
  overflow: visible;
  width: 80px;
  margin: 0 auto;
}



/* PUNTI DI FORZA
-------------------------------------------------- */
.rdb-strengths{

}
#img-strengths{
  padding: 25px;
  background: url("../../assets/images/img-3.png");
  background-repeat: no-repeat;
  background-size: cover;
  height: 100%;
  width: 100%;
  box-shadow: 0px 1px 7px 0px #73727a;
  
  background-position: center;
}
@media (max-width: 991px) {
  #img-strengths {
    height: 16rem;
    padding-right: 0px;
    margin-bottom: 1rem;
  }
  .div-strenghts {
    padding: 0px;
  }
}



/* DETTAGLIO APPLICATIVO
-------------------------------------------------- */
#rdb-details{
}
#rdb-details ul li{
  margin-bottom: .5rem;
}
#rdb-details p{
  font-size:1.4rem;
  line-height: 160%;
  text-align: center;
}
#rdb-details ul li .number-list {
  border: 3px solid #d9d9d9;
  width: 3rem;
  height: 3rem;
  font-size: 1.7rem;
  font-weight: bold;
  padding: 0 .85rem;
  border-radius: 50%;
  color: #a2a2a2;
  clear: right;
}
#rdb-details .card {
  margin: 0.8rem;
}
#rdb-details .card {
  box-shadow: 0px 2px 7px 0px #8389c1;
  
}

/* FUNZIONALITA'
-------------------------------------------------- */
#rdb-functionality {}

/* FOOTER
-------------------------------------------------- */
.rdb-footer
{

 }
.rdb-footer span{
  font-size: 1rem !important;
}
@media (max-width: 768px) {
  #rdb-contacts .book,
  #rdb-contacts .book button {
    width: 100%;
  }
}

/* RESPONSIVE
-------------------------------------------------- */
@media (max-width: 1366px) {
  body {
    font-size: 1.2rem;
  }

  #rdb-details p {
    font-size: 1.2rem;
    line-height: 130%;
  }

  h1 {
    font-size: 2.5rem;
  }

  h2 {
    font-size: 2.3rem;
  }

  p {
    font-size: 1.2rem;
  }

  @media (max-width: 1366px){
    p {
      font-size: 1rem;
    }
  }
}

@media (max-width: 991px) {
  .card {
    width:100%;
  }
  h1{
    font-size: 2.3rem;
  }
  h2{
    font-size: 2.1rem;
  }
  p {
    font-size: 1.1rem;
  }
}

/* Google translate */
.goog-logo-link {
  display:none !important;
}
.goog-te-gadget{
  color: transparent !important;
  font-size: 0 !important;
  content: '';
}
.goog-te-gadget > span {
  display:none;
}
.skiptranslate iframe{
  display: none;
}
body{top: 0 !important;}

/* Cookies */
#cb-cookie-banner {
  position: fixed;
  bottom: 0;
  left: 0;
  width: 100%;
  z-index: 999;
  border-radius: 0;
  display: none;
  border: none;
}


/*@media (min-width:576px) {
  .rdb-container {
    max-width:540px
  }
}
@media (min-width:768px) {
  .rdb-container {
    max-width:720px
  }
}
@media (min-width:992px) {
  .rdb-container {
    max-width:960px
  }
}
@media (min-width:1200px) {
  .rdb-container {
    max-width:1140px;
  }
}*/




/*INTRO*/ 






/*IMAGE INTRO*/
.rdb-intro .image-intro{
  padding: 0rem 2rem;
}

.image-intro img {
  width: 110%;
  border-radius: 2rem;
  box-shadow: 0px 0 16px 0px #7d91c1;
}

/*@media only screen and (min-width: 992px) and (max-width: 1199px), only screen and (min-width: 1200px) and (max-width: 1399px) {
  .image-intro img {
      width: 100%;
  }
@media only screen and (min-width: 768px) and (max-width: 991px), (max-width: 767px) {
  .image-intro img {
    max-width: 100%;
    margin: auto;
  }
}*/

.nav-fixed {
  position: fixed;
  z-index: 99;
  background-color: #fff;
  box-shadow: 0 20px 50px 0 rgba(0,0,0,.05);
  transition: all .3s ease-out 0s;
}

.bd-highlight .number-list {
  position: relative;
  width: 1rem;
}
.bd-highlight .number-list::before {
  content: "";
  width: 20px;
  height: 20px;
  border-radius: 50%;
  /*background: #DAFF7D;*/
  border: 4px solid #5848ef ;
  position: absolute;
  left: 0;
  top: 6.5px;
  -webkit-box-shadow: 2px 4px 6px 0px rgb(176 152 205 / 26%);
  box-shadow: 2px 4px 6px 0px rgb(176 152 205 / 26%);
  z-index: 3;
}
.bd-highlight-1 .number-list {
  position: relative;
  width: 2rem;
}
.bd-highlight-1 .number-list::before {
  content: "";
  width: 20px;
  height: 20px;
  border-radius: 50%;
  /*background: #DAFF7D;*/
  border: 4px solid #5848ef ;
  position: absolute;
  left: 0;
  top: 6.5px;
  -webkit-box-shadow: 2px 4px 6px 0px rgb(176 152 205 / 26%);
  box-shadow: 2px 4px 6px 0px rgb(176 152 205 / 26%);
  z-index: 3;
}

.form-control {
  /* font-family: "Lato", sans-serif; */
  font-family: "sole-sans-variable", sans-serif;
  font-size: 1.2rem;
}

.rdb-contacts {
  background: var(--primary);
}
.contatti {
  color: white !important;
}


.products .img-prodotti {
  height: 70px;
  margin: 0 0 1.5rem ;
  width: 100%;
}
.products > div,
.vantaggi > div {
  padding: 1rem 2rem;
}
.products div.bg,
.vantaggi div.bg {
  padding: 2rem 2rem 1rem;  
  height: 100%;  
}


@media (max-width: 767px) {
  .products .img-prodotti {
    height: 50px;
  }
  .products > div,
  .vantaggi > div {
    padding: 1rem 0rem;
  }
  .products div.bg{
    padding: 2rem;
    background-color: var(--primary-bg);
    border-radius: 2rem 5rem;
  }
}

.caption img {
  height: 4rem;
  margin: auto;
}
.caption .text-caption   {
  font-family: "sole-sans-variable", sans-serif;
  line-height: 3rem;
  color: var(--h2-color);
  /* font-weight: 600; */
  font-size: 2rem;
  padding: 1.5rem 0;
  font-style: italic;
}

.w-full{width:100%}

.navbar-toggler{padding: 5px;}


/* ABOUT
-------------------------------------------------- */
#rdb-about{
  padding-bottom: 0rem !important;
}
.image-adaptive {
  background: url(../../assets/images/img-chi-siamo.png);
  background-size: cover;
  background-repeat: no-repeat;
  height: 100%;
  width: 100%;
  min-height: 150px;
  padding: 25px;
  background-position: center;
  border-radius: 2px;
  -webkit-box-shadow: 0px 1px 7px 0px #73727a;
  box-shadow: 0px 1px 7px 0px #73727a;
}



@media only screen and (max-width: 570px) {
  .hero-content{
    padding: 0 30px;
  }
}