@import url("https://fonts.googleapis.com/css2?family=Roboto:ital,wght@0,100..900;1,100..900&family=Stack+Sans+Notch:wght@200..700&display=swap");
/* material */
.material-symbols-outlined {
  vertical-align: bottom;
  font-variation-settings: 'FILL' 0, 'wght' 200, 'GRAD' -25, 'opsz' 24; }

/* --------- */
body {
  font-family: "Roboto", sans-serif;
  color: #2a3321;
  font-size: 1rem;
  font-weight: 300;
  font-style: normal;
  background-color: #ffffff; }

div#main-content {
  padding: 2rem 0; }

section {
  padding: 4rem 0;
  margin-top: 2rem; }

/* Tipografy */
h1, h2, h3, h4, h5, h6 {
  font-family: "Stack Sans Notch", sans-serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal; }

h1 {
  font-size: 3rem;
  color: #000000; }

h2 {
  font-size: 2.4rem;
  color: #2B997B;
  margin-bottom: 1rem; }

h3 {
  font-size: 1.4rem;
  color: #000000;
  padding: 2rem 0 1rem 0; }

a {
  color: #2B997B;
  text-decoration: none; }

a:hover {
  color: #2a3321;
  text-decoration: none; }

/* Navbar */
nav {
  background-color: #ffffff;
  font-family: "Stack Sans Notch", sans-serif; }
  nav ul {
    margin: 0;
    padding: 0;
    list-style: none; }
  nav li {
    display: inline-block;
    padding-left: .5rem; }
  nav .nav-link {
    display: block;
    color: #2a3321;
    font-weight: 300;
    text-decoration: none;
    text-transform: uppercase; }
  nav .navbar-nav .nav-link {
    padding-right: 0.3rem !important;
    padding-left: 0.3rem !important; }
  nav .nav-link:hover, nav .nav-link:focus {
    color: #2B997B;
    text-decoration: none; }
  nav .dropdown-toggle::after {
    width: 1.25em;
    line-height: 0;
    content: url("../img/expand_more_FILL0_wght100_GRAD0_opsz24.svg");
    transition: none;
    border: 0; }
  nav .dropdown-toggle[aria-expanded="true"]::after {
    transform: rotate(-180deg); }
  nav .dropdown-toggle::after {
    vertical-align: middle; }
  nav .navbar-brand img {
    width: 200px; }
  nav #top-search li a {
    display: block;
    color: #000000;
    text-decoration: none; }
  nav .dropdown-menu {
    border: 0;
    background-color: #ffffff;
    padding: 1rem;
    border-radius: 10px;
    box-shadow: 0 0 1rem rgba(0, 0, 0, 0.1) !important;
    padding: 1.5rem 0;
    -o-transition: all 0.5s ease;
    -moz-transition: all 0.5s ease;
    -webkit-transition: all 0.5s ease;
    transition: all 0.5s ease; }
  nav ul.dropdown-menu li {
    padding: 0.5rem 0.5rem 0;
    color: #2a3321;
    text-transform: uppercase; }
  nav .dropdown-item.active, nav .dropdown-item:active,
  nav .dropdown-item:focus, nav .dropdown-item:hover {
    color: #2B997B;
    text-decoration: none;
    background-color: #ffffff; }
  nav ul.dropdown-menu.show li a {
    border-bottom: 1px solid #2a3321;
    font-weight: 300; }
  nav .dropdown-menu.show li {
    display: block; }
  nav a.nav-link {
    color: #000000; }
  nav .navbar-nav {
    align-items: center; }
  nav a.menu-item.search::after {
    display: none; }

.navbar {
  padding: 2rem 0; }

.navbar.sticky {
  box-shadow: 0 0 1rem rgba(0, 0, 0, 0.1) !important;
  padding: 1.5rem 0;
  -o-transition: all 0.5s ease;
  -moz-transition: all 0.5s ease;
  -webkit-transition: all 0.5s ease;
  transition: all 0.5s ease; }

.navbar.sticky .navbar-brand img {
  width: 180px;
  -o-transition: all 0.5s ease;
  -moz-transition: all 0.5s ease;
  -webkit-transition: all 0.5s ease;
  transition: all 0.5s ease; }

.navbar-toggler-icon {
  background-image: url(../img/ico-menu.png); }

.navbar-toggler {
  background-color: #2B997B;
  border: 1px solid #2B997B; }

.navbar-expand-lg .navbar-collapse,
.navbar-nav {
  justify-content: flex-end; }

i.fab {
  color: #2a3321; }

a.icon.search {
  color: #2a3321; }

/* Buttons */
.btn {
  font-weight: 300;
  font-size: 1.2rem;
  font-family: "Stack Sans Notch", sans-serif;
  letter-spacing: 0px;
  border-radius: 0;
  padding: 0.6rem 1rem;
  text-decoration: none;
  border: 0;
  margin: 0.5rem 0;
  text-transform: none; }

.btn-primary {
  color: #2a3321;
  background-color: transparent;
  border: 1px solid #2a3321;
  -o-transition: all 0.5s ease;
  -moz-transition: all 0.5s ease;
  -webkit-transition: all 0.5s ease;
  transition: all 0.5s ease; }

.btn-primary:hover {
  color: #ffffff;
  background-color: #2B997B;
  border: 1px solid #2B997B; }

.btn-secondary {
  color: #ffffff;
  background-color: transparent;
  border: 1px solid #ffffff;
  -o-transition: all 0.5s ease;
  -moz-transition: all 0.5s ease;
  -webkit-transition: all 0.5s ease;
  transition: all 0.5s ease; }

.btn-secondary:hover {
  color: #ffffff;
  background-color: #2a3321;
  border: 1px solid #2a3321; }

.btn-check:focus + .btn-primary, .btn-primary:focus {
  color: #ffffff;
  background-color: #000000 !important;
  border-color: #000000 !important;
  box-shadow: 0 0 0 0.25rem rgba(49, 132, 253, 0.5); }

div#banner-img {
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1; }

/* home */
#banner-home {
  margin-top: 110px;
  background-image: url("../img/banner.png");
  background-size: cover;
  background-position: center bottom;
  height: 480px; }
  #banner-home #intro-text {
    padding: 3rem; }
    #banner-home #intro-text h1 {
      font-size: 2.8rem;
      font-weight: 400;
      color: #ffffff;
      font-family: "Stack Sans Notch", sans-serif;
      line-height: 3rem !important; }

section#project h2 {
  color: #2B997B; }
section#project .numbers {
  padding: 2rem;
  background-color: #2B997B;
  font-family: "Stack Sans Notch", sans-serif;
  color: #ffffff; }
  section#project .numbers .numeri {
    font-size: 3rem;
    text-align: end; }
  section#project .numbers .label {
    font-size: 1rem; }
  section#project .numbers ul {
    list-style: none;
    text-align: left;
    padding: 0; }

/* news */
.news-item {
  padding: 0;
  margin-bottom: 1rem;
  transition: ease-in-out 0.3s; }

.news-item .material-symbols-outlined,
.news-info .material-symbols-outlined {
  font-size: 30px; }

.bg-greylight {
  background-color: #ededed; }

section#news .news-item, section#events .news-item {
  margin-bottom: 1rem;
  transition: ease-in-out 0.3s; }
  section#news .news-item .news-img, section#events .news-item .news-img {
    margin-bottom: 1rem; }
section#news .news-info .data, section#events .news-info .data {
  color: #bcbcbc;
  font-size: 1.2rem;
  font-family: "Stack Sans Notch", sans-serif; }
section#news .news-info h3, section#events .news-info h3 {
  font-family: "Roboto", sans-serif;
  font-size: 1.8rem;
  padding-top: 0; }
section#news .news-info h3 a, section#events .news-info h3 a {
  text-decoration: none;
  color: #2a3321;
  font-family: "Roboto", sans-serif;
  text-decoration: none;
  color: #2a3321;
  font-size: 1.2rem; }
section#news .news-info h3 a:hover, section#events .news-info h3 a:hover {
  text-decoration: none;
  color: #2B997B; }

.stats .stats-item span {
  font-size: 48px;
  display: block;
  color: black;
  font-weight: 700; }

/*partners carousel */
#partnersCarousel .carousel-item {
  background: #ffffff;
  width: 80%;
  margin-right: -80%; }

#partnersCarousel .carousel-inner .carousel-item.active,
#partnersCarousel .carousel-inner .carousel-item-next,
#partnersCarousel .carousel-inner .carousel-item-prev {
  display: flex; }

#partnersCarousel .carousel-inner .carousel-item-right.active,
#partnersCarousel .carousel-inner .carousel-item-next {
  transform: translateX(25%); }

#partnersCarousel .carousel-inner .carousel-item-left.active,
#partnersCarousel .carousel-inner .carousel-item-prev {
  transform: translateX(-25%); }

#partnersCarousel .carousel-inner .carousel-item-right,
#partnersCarousel .carousel-inner .carousel-item-left {
  transform: translateX(0); }

#partnersCarousel .carousel-control-next, #partnersCarousel .carousel-control-prev {
  width: 5%;
  bottom: 40px; }

#partnersCarousel .carousel-control-next {
  right: 0px !important; }

#partnersCarousel .carousel-control-prev {
  right: 5%;
  left: unset; }

#partnersCarousel .carousel-control-next-icon, #partnersCarousel .carousel-control-prev-icon {
  background-image: url(../img/fdx-gray.png);
  width: 30px;
  background-size: 70%; }

#partnersCarousel .carousel-control-prev-icon {
  background-image: url(../img/fsx-gray.png); }

#partnersCarousel .carousel-item img {
  height: 140px;
  padding-bottom: 30px;
  -o-transition: all .5s ease;
  -moz-transition: all .5s ease;
  -webkit-transition: all .5s ease;
  transition: all .5s ease; }

#partners-logos li {
  width: 140px;
  height: 110px;
  margin-left: 5px;
  background: #ffffff;
  text-align: center;
  margin-bottom: 1rem; }

/* footer */
section#prefooter {
  background-image: url("../img/banner-footer.png");
  background-size: cover;
  background-position: center bottom; }
  section#prefooter p {
    color: #ffffff; }
  section#prefooter h2 {
    font-size: 2rem;
    color: #ffffff; }
  section#prefooter .newsletter {
    border-bottom: 1px solid #ffffff;
    margin-bottom: 2rem;
    padding-bottom: 2rem; }

.share {
  border-top: 1px solid #ededed;
  border-bottom: 1px solid #ededed;
  padding: 1rem;
  margin: 1rem; }

.share a i {
  color: #000000 !important; }

section#footer {
  background: #2a3321;
  font-size: 0.9rem;
  margin-top: 4rem;
  padding: 2rem;
  color: #ffffff; }
  section#footer img.eulogo {
    width: 200px;
    padding-bottom: 1rem; }
  section#footer i.fab, section#footer a {
    color: #ffffff; }
  section#footer #footer a:hover {
    color: #2B997B; }

/* pagina */
#page-title {
  margin-top: 110px;
  background-image: url("../img/banner-interno.png");
  background-size: cover;
  background-position: center bottom;
  height: 200px;
  padding: 4rem 3rem; }

#page-title h1 {
  font-size: 2.8rem;
  font-weight: 400;
  color: #ffffff;
  font-family: "Stack Sans Notch", sans-serif;
  line-height: 3rem !important; }

.doclist {
  background-color: #ededed;
  padding: 1.5rem 0; }

.filter-navbar {
  top: 90px;
  /* altezza navbar principale */
  z-index: 1020; }

.doc-title a, .doc-title,
p.doc-title {
  color: #2B997B;
  text-decoration: none;
  font-weight: 500; }

.doc-type {
  font-size: 1rem; }

.doc-title a:hover {
  color: #000000;
  text-decoration: none; }

.content-video {
  padding: 0 0 0 2rem; }

.lista-video {
  padding: 1rem 0;
  border-bottom: 1px solid #ededed; }

.brd-bottom {
  border-bottom: 1px solid #ededed; }

/* partner */
.partner {
  padding: 1rem;
  margin-bottom: 1.5rem !important;
  border-bottom: 1px solid #2B997B; }
  .partner h3 {
    text-transform: none !important;
    padding: 0;
    font-weight: 300; }
  .partner .partner-info {
    font-size: 0.8rem;
    font-weight: 300;
    padding-top: 1rem; }
  .partner .partner-info a {
    text-decoration: none; }
  .partner .partner-info a .icon-more {
    transform: rotate(180deg);
    width: 20px; }
  .partner .partner-info .collapsed .icon-more {
    transform: rotate(0deg); }
  .partner .partner-info .btn.collapsed .fa-angle-up:before {
    content: "\f107" !important; }
  .partner .partner-info a:hover {
    color: #000000; }
  .partner .badge-info {
    background-color: #2B997B;
    color: #ffffff;
    font-family: "Stack Sans Notch", sans-serif;
    font-weight: 400;
    margin-bottom: 1rem;
    border-radius: 0;
    padding: 0.5rem; }

.partner.row {
  align-items: center !important; }

ul#filter-list .nav-link {
  color: #2B997B;
  padding: 0 1rem 0 1rem; }

div#search-field {
  padding: 1rem !important;
  width: 20rem; }

/**/
.btn-check:focus + .btn, .btn:focus,
.btn-check:active + .btn-primary:focus, .btn-check:checked + .btn-primary:focus, .btn-primary.active:focus, .btn-primary:active:focus, .show > .btn-primary.dropdown-toggle:focus {
  box-shadow: none; }

.page-link {
  color: #000000; }

#documents-list {
  padding: 1rem; }

.search-result {
  border-bottom: 1px solid #2a3321; }

#scrollUp {
  bottom: 80px;
  right: 20px;
  height: 50px;
  width: 50px;
  background: url(../img/scroll-up.png) no-repeat;
  background-size: 100%; }

.breadcrumb {
  justify-content: flex-end;
  font-size: 0.9rem; }

.breadcrumb a,
.breadcrumb_last {
  font-size: 0.9rem; }

/* mobile */
@media (max-width: 1024px) and (min-width: 992px) {
  #partnersCarousel .carousel-item img {
    height: 112px; } }
@media (max-width: 768px) {
  .doclist {
    padding: 0.5rem; }

  section#project .numbers .numeri,
  section#project .numbers .label {
    text-align: center; }

  #page-title {
    height: unset;
    padding: 3rem 0rem; }

  #banner-home {
    height: 320px; }
    #banner-home #intro-text {
      padding: 0rem; }

  #partnersCarousel .carousel-item img {
    height: 88px; } }
@media (max-width: 426px) {
  #banner-home {
    height: 370px; }

  .filter-navbar {
    display: none; }

  #partnersCarousel .carousel-item img {
    padding-bottom: 0px; } }
@media (max-width: 320px) {
  #banner-home #intro-text h1 {
    font-size: 2.0rem; }

  #page-title h1 {
    font-size: 2rem; }

  h2 {
    font-size: 2rem; } }
