/*NORMALIZE*/
/* FONT */
* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

html {
  overflow-y: scroll;
  scroll-behavior: smooth;
}

body {
  font-family: var(--font-base, sans-serif);
  margin: 0;
}

img {
  max-width: 100%;
  display: block;
}

button {
  cursor: pointer;
  border: none;
}

p {
  margin: 15px 0;
}

ul {
  padding-left: 15px;
}

.visually-hidden {
  display: none;
}

.nascosto {
  display: none;
}

a {
  text-decoration: none;
}

ul {
  padding: 0;
  margin: 0;
  list-style: none;
}

fieldset {
  border: none;
}

.larghezza-contenitore {
  float: left;
  width: 100%;
}

.larghezza-base {
  max-width: var(--larghezza-base, 1260px);
  margin: 0 auto;
}

.larghezza-1260 {
  max-width: 1260px;
  margin: 0 auto;
}

.larghezza-1200 {
  max-width: 1200px;
  margin: 0 auto;
}

.larghezza-1100 {
  max-width: 1100px;
  margin: 0 auto;
}

.larghezza-1024 {
  max-width: 1024px;
  margin: 0 auto;
}

.larghezza-960 {
  max-width: 960px;
  margin: 0 auto;
}

.larghezza-768 {
  max-width: 768px;
  margin: 0 auto;
}

.larghezza-640 {
  max-width: 640px;
  margin: 0 auto;
}

.larghezza-480 {
  max-width: 480px;
  margin: 0 auto;
}

@media (max-width: 1299px) {
  .larghezza-base, .larghezza-1260, .larghezza-1200, .larghezza-1100, .larghezza-1024, .larghezza-960, .larghezza-768, .larghezza-640 {
    padding: 0 10px;
  }
}
/***MISURA 1140PX ***/
/***MISURA 1024 ***/
/***MISURA 960PX ***/
/***MISURA 768PX ***/
/***MISURA 640PX ***/
@media (max-width: 767px) {
  .larghezza-base, .larghezza-1260, .larghezza-1200, .larghezza-1100, .larghezza-1024, .larghezza-960, .larghezza-768, .larghezza-640, .larghezza-480 {
    padding: 0 5px;
  }
}
/***MISURA 480PX ***/
/***MISURA 320PX ***/
.com-content-category-blog__pagination ul.pagination, .com-finder__navigation ul.pagination {
  display: flex;
  gap: 10px;
}
.com-content-category-blog__pagination ul.pagination li, .com-finder__navigation ul.pagination li {
  background-color: #F00;
  padding: 0 10px;
}
.com-content-category-blog__pagination ul.pagination li.disabled, .com-finder__navigation ul.pagination li.disabled {
  background-color: #000;
}
.com-content-category-blog__pagination ul.pagination li a, .com-content-category-blog__pagination ul.pagination li span, .com-finder__navigation ul.pagination li a, .com-finder__navigation ul.pagination li span {
  color: #FFF;
}
.com-content-category-blog__pagination ul.pagination li span.icon-angle-double-left:before, .com-finder__navigation ul.pagination li span.icon-angle-double-left:before {
  content: "\f100";
  font-family: "Font Awesome 6 Pro";
  font-weight: 900;
}
.com-content-category-blog__pagination ul.pagination li span.icon-angle-left:before, .com-finder__navigation ul.pagination li span.icon-angle-left:before {
  content: "\f104";
  font-family: "Font Awesome 6 Pro";
  font-weight: 900;
}
.com-content-category-blog__pagination ul.pagination li span.icon-angle-right:before, .com-finder__navigation ul.pagination li span.icon-angle-right:before {
  content: "\f105";
  font-family: "Font Awesome 6 Pro";
  font-weight: 900;
}
.com-content-category-blog__pagination ul.pagination li span.icon-angle-double-right:before, .com-finder__navigation ul.pagination li span.icon-angle-double-right:before {
  content: "\f101";
  font-family: "Font Awesome 6 Pro";
  font-weight: 900;
}

.com-finder__counter {
  display: none;
}

/*OVERRIDE*/
.slider-home-contenitore .slider-home .slideplus-navigation {
  margin-top: -22px;
  z-index: 9;
  position: relative;
}

.slider-home-contenitore .slider-home .slideplus-paging a {
  border-radius: 0;
  border: none;
  width: 10px;
  height: 10px;
  background-color: #FFF;
}

.slider-home-contenitore .slider-home .slideplus-paging a.slideplus-current {
  background-color: #666;
}

.slider-home-contenitore .slider-home .slideplus-paging a span {
  display: none;
}

.slider-home-contenitore .slider-home .slideplus-first {
  display: none !important;
}

.slider-home-contenitore .slider-home .slideplus-previous {
  display: none !important;
}

.slider-home-contenitore .slider-home .slideplus-next {
  display: none !important;
}

.slider-home-contenitore .slider-home .slideplus-last {
  display: none !important;
}

.tns-outer {
  position: relative;
}
.tns-outer .tns-controls {
  z-index: 1;
  display: flex;
  position: absolute;
  top: 50%;
  justify-content: space-between;
  width: 100%;
}
.tns-outer .tns-controls button {
  background-color: transparent;
  border: none;
}
.tns-outer .tns-controls button i {
  font-size: 100px;
  color: #FFF;
}
.tns-outer .tns-nav {
  z-index: 1;
  display: flex;
  position: absolute;
  bottom: 20px;
  justify-content: center;
  gap: 10px;
  width: 100%;
}
.tns-outer .tns-nav button {
  background-color: transparent;
  border: 1px solid #FFF;
  width: 12px;
  height: 12px;
  border-radius: 100%;
}
.tns-outer .tns-nav button.tns-nav-active {
  background-color: #F00;
  border: none;
  width: 13px;
  height: 13px;
}
.tns-outer .tns-nav button i {
  font-size: 100px;
  color: #FFF;
}

/*FRONTEND*/
.header-contenitore {
  padding: 15px 0;
  background-color: #fff;
}
.header-contenitore .header {
  display: grid;
  grid-template-columns: 130px 1fr 220px;
  grid-template-rows: auto auto auto;
  grid-column-gap: 30px;
  grid-row-gap: 10px;
  align-items: center;
  /* LOGO: Occupa tutte le righe a sinistra */
  /* RIGA 1: Slogan a sinistra, Social a destra */
  /* RIGA 2: MENU PRINCIPALE (Libero fino a colonna 2) */
  /* Lo teniamo nella colonna centrale per non farlo andare sotto la lingua */
  /* RIGA 3: LINGUA (Sotto i social, ma allineata a destra) */
}
.header-contenitore .header .logo {
  grid-area: 1/1/4/2;
  align-self: center;
}
.header-contenitore .header .logo img {
  max-width: 100%;
  height: auto;
}
.header-contenitore .header .slogan {
  grid-area: 1/2/2/3;
  align-self: center;
}
.header-contenitore .header .menu-social-contenitore {
  grid-area: 1/3/2/4;
  justify-self: end;
}
.header-contenitore .header .menu-social-contenitore .mn-nav {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  list-style: none;
  margin: 0;
  padding: 0;
}
.header-contenitore .header .menu-top-contenitore {
  grid-area: 2/2/3/3;
  align-self: center;
}
.header-contenitore .header .menu-top-contenitore .mn-nav {
  display: flex;
  gap: 20px;
  list-style: none;
  margin: 0;
  padding: 0;
}
.header-contenitore .header .menu-lingua-contenitore {
  grid-area: 2/3/3/4;
  justify-self: end;
  align-self: center;
}
.header-contenitore .header .menu-lingua-contenitore ul {
  display: flex;
  gap: 10px;
  list-style: none;
  margin: 0;
  padding: 0;
}

/* Sticky footer: la pagina occupa almeno tutta l'altezza della viewport.
   <main> si espande e spinge il footer in fondo quando il contenuto e' corto;
   con contenuto piu' lungo dello schermo il footer scorre normalmente. */
body {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}

main {
  flex: 1 0 auto;
}

/* Header fisso: attivo SOLO con il parametro "Header Fixed" (classe body.header-fixed
   aggiunta da index.php). Senza il parametro l'header resta nel flusso normale. */
body.header-fixed .header-contenitore {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 150;
}
body.header-fixed main {
  margin-top: 120px;
}

.footer-contenitore {
  background-color: #333;
  text-align: center;
}
.footer-contenitore .footer {
  color: #FFFFFF;
}
.footer-contenitore .credits {
  display: flex;
  justify-content: space-between;
  align-items: center;
  color: #fff;
  font-size: 12px;
  font-weight: 600;
}
.footer-contenitore .credits .copyright a {
  color: #fff;
  text-decoration: underline;
}
.footer-contenitore .credits .logo {
  display: flex;
  align-items: center;
  justify-content: center;
}
.footer-contenitore .credits .logo img {
  width: 45px;
  margin-left: 5px;
}

/* BackToTop: attivato dal parametro "BackToTop". Nascosto di default,
   compare quando si scrolla la pagina (classe .visibile aggiunta da logic.js). */
.back-to-top {
  position: fixed;
  right: 20px;
  bottom: 20px;
  z-index: 200;
  display: none;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background-color: #f00;
  color: #fff;
  font-size: 18px;
  text-decoration: none;
  opacity: 0;
  transition: opacity 0.25s ease;
}
.back-to-top.visibile {
  display: flex;
  opacity: 1;
}
.back-to-top i {
  color: inherit;
}

/*# sourceMappingURL=template.css.map */
