html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed, 
figure, figcaption, footer, header, hgroup, 
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
	margin: 0;
	padding: 0;
	border: 0;
	font-size: 100%;
	font: inherit;
	vertical-align: baseline;
}
/ HTML5 display-role reset for older browsers /
article, aside, details, figcaption, figure, 
footer, header, hgroup, menu, nav, section {
	display: block;
}
body {
	line-height: 1;
	background:#fff;
	color:#5c5c5c;
}
ol, ul {
	list-style: none;
}
blockquote, q {
	quotes: none;
}
blockquote:before, blockquote:after,
q:before, q:after {
	content: '';
	content: none;
}
table {
	border-collapse: collapse;
	border-spacing: 0;
}
a {
	outline:none;
	}

img {
	max-width:100%;
	height:auto;
	}
em {
	font-style:italic;
	}

.site-header {
     padding: 2em 0;
     background: #fff;
}
 .site-header .site-title {
     margin-bottom: 0;
}
 .site-header .site-title img {
     width: 135px;
}
 .site-header .flex-wrapper {
     display: flex;
     justify-content: space-between;
     align-items: center;
}
 .site-header .white-logo {
     display: none;
}
 .site-header.scrolled, .site-header.transparent.scrolled {
     position: fixed;
     top: 0;
     width: 100%;
     z-index: 5;
     background-color: white;
     animation: topfade 0.5s forwards;
     box-shadow: 0 0 20px #333;
     padding: .8em;
}
 .site-header.scrolled .white-logo, .site-header.transparent.scrolled .white-logo {
     display: none;
}
 .site-header.scrolled .blue-logo, .site-header.transparent.scrolled .blue-logo {
     display: block;
}
 .site-header.reverted, .site-header.transparent.reverted {
     animation: fade 0.5s forwards;
}
 .site-header.reverted .site-title:not(.site-title-scrolled), .site-header.transparent.reverted .site-title:not(.site-title-scrolled) {
     display: block;
}
 @keyframes topfade {
     from {
         opacity: 0;
         transform: translateY(-100%);
    }
     to {
         opacity: 1;
         transform: translateY(0%);
    }
}
 @keyframes fade {
     0 {
         opacity: 0;
    }
     100% {
         opacity: 1;
    }
}
 .site-header.transparent {
     position: fixed;
     top: 0;
     width: 100%;
     z-index: 5;
     color: white;
     opacity: 0;
     animation: fade 0.5s forwards;
     background: transparent;
}
 .site-header.transparent.scrolled .site-title:not(.site-title-scrolled) {
     display: none;
}
 .site-header.transparent.reverted {
     animation: fade 0.5s forwards;
}
 .site-header.transparent.reverted .white-logo {
     display: block;
}
 .site-header.transparent.reverted .blue-logo {
     display: none;
}
 .site-header.transparent.reverted .site-title:not(.site-title-scrolled) {
     display: block;
}
 .site-header.transparent .blue-logo {
     display: none;
}
 .site-header.transparent .white-logo {
     display: block;
}
 .site-header.transparent .site-title {
     margin-bottom: 0;
}
 .site-header.transparent .site-title img {
     width: 135px;
}
 .site-header.transparent a {
     color: white;
}
 .scrolled .site-header.transparent a {
     color: #3270b6;
}
 #pull {
     position: relative;
     text-transform: uppercase;
     text-align: center;
     font-size: 2em;
     cursor: pointer;
     transition: 0.2s ease-in-out all;
     cursor: pointer;
     width: 42px;
     height: 42px;
}
 .site-header #pull {
     color: #3270b6;
}
 .site-header.transparent #pull {
     color: #fff;
}
 .scrolled.site-header #pull {
     color: #3270b6;
}
 #pull i {
     position: absolute;
     right: 0;
     transition: linear .5s all;
}
 #pull i.hover {
     opacity: 0;
     transition: linear .5s all;
}
 #pull:hover {
     color: fade(white, 90%);
}
 .scrolled #pull:hover {
     color: fade(#3270b6, 90%);
}
 #pull:hover i {
     opacity: 0;
     transition: linear .5s all;
}
 #pull:hover i.hover {
     opacity: 1;
     transition: linear .5s all;
}
.no-scroll {
     overflow: hidden;
}
.site-menu {
  z-index: -1;
  pointer-events: none;
  position: fixed;
  inset: 0;
  height: 100vh;
  opacity: 0;
  transform: scale(0.9);
  transition: .3s linear all;
  padding: 2rem; }
  @media (max-width: 768px) {
    .site-menu {
      background: #3270b6;
      top: 0;
      bottom: 0;
      left: 0;
      right: 0;
      height: 100%; } }
  @media (min-width: 769px) {
    .site-menu {
      background: linear-gradient(90deg, rgba(50, 112, 182, 0.5) 60%, #3270b6 0); } }
  @media (min-width: 1101px) {
    .site-menu {
      background: linear-gradient(90deg, rgba(50, 112, 182, 0.5) 70%, #3270b6 0); } }
  .site-menu.active {
    transition: .3s linear all;
    opacity: 1;
    z-index: 100;
    transform: scale(1);
    pointer-events: auto; }
  .site-menu .mmenu-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    width: calc( 30% - 4rem);
    height: 70px;
    margin: 0 0 0 auto; }
    @media (max-width: 768px) {
      .site-menu .mmenu-header {
        width: 100%; } }
    .site-menu .mmenu-header .mm-logo {
      width: 135px;
      height: 40px; }
    .site-menu .mmenu-header .mm-close {
      background: #10263f;
      width: 42px;
      height: 42px;
      display: flex;
      align-items: center;
      justify-content: center;
      cursor: pointer; }
      .site-menu .mmenu-header .mm-close img {
        transition: all 0.2s ease-in; }
      .site-menu .mmenu-header .mm-close:hover img {
        transition: all 0.2s ease-in;
        transform: rotate(90deg); }
  .site-menu .mmenu-content {
    width: 100%;
    height: calc(100% - 70px);
    position: relative;
    margin: 0 0 0 auto;
    padding-top: 50px;
    padding-right: 4%;
    text-align: left; }
    @media (max-width: 900px) {
      .site-menu .mmenu-content {
        padding-left: 2%;
        padding-top: 40px; } }
    @media (min-width: 769px) {
      .site-menu .mmenu-content {
        width: calc( 40% - 4rem); } }
    @media (min-width: 1101px) {
      .site-menu .mmenu-content {
        width: calc( 30% - 4rem); } }
  .site-menu .primary-menu {
    width: 100%;
    height: 100%;
    overflow: auto; }
    .site-menu .primary-menu .heading a {
      color: #10263f !important;
      font-size: 1rem !important;
      text-transform: uppercase !important;
      font-family: 'Proxima Nova Light' !important;
      pointer-events: none; }
      .site-menu .primary-menu .heading a:after {
        display: none; }
    .site-menu .primary-menu li a {
      display: inline-block;
      color: white;
      margin-bottom: 1rem;
      position: relative; }
      .site-menu .primary-menu li a:after {
        content: "";
        position: absolute;
        bottom: 0;
        right: 0;
        height: 50%;
        background: #02bff2;
        width: 0;
        z-index: -1;
        transition: all 0.2s ease-in; }
      .site-menu .primary-menu li a:hover:after {
        transition: all 0.2s ease-in;
        width: 100%; }
    .site-menu .primary-menu li.current-menu-parent > a:after,
    .site-menu .primary-menu li.current-menu-item > a:after {
      width: 100%; }
    .site-menu .primary-menu li.with-sub > a {
      display: inline-flex;
      flex-direction: row-reverse;
      gap: 1rem;
      align-items: center; }
      .site-menu .primary-menu li.with-sub > a:before {
        content: "\f054";
        font-family: 'Font Awesome 5 Free';
        font-weight: 900;
        font-size: 1rem;
        line-height: 2rem;
        margin-right: .5rem;
        color: #10263f;
        text-decoration: none; }
    .site-menu .primary-menu > li > a {
      font-size: 30px;
      text-decoration: none;
      font-family: 'Proxima Nova Bold'; 
      line-height: 1;
      }
      @media (max-width: 650px) {
        .site-menu .primary-menu > li > a {
          font-size: 28px; } }
    .site-menu .primary-menu .menu-item-has-children .sub-menu {
      display: none; }
    .site-menu .primary-menu .menu-item-has-children.open .sub-menu {
      display: flex; }
    .site-menu .primary-menu .menu-item-has-children .sub-menu {
      flex-direction: column;
      justify-content: flex-start;
      position: absolute;
      right: 37%;
      top: 100px;
      bottom: 0;
      left: 0;
      overflow: auto; }
      .site-menu .primary-menu .menu-item-has-children .sub-menu > li > a {
        display: inline-block;
        font-size: 1.25rem;
        margin-bottom: 1.5rem;
        font-family: 'Proxima Nova SemiBold';
        color: #fff;
        text-decoration: none; }
      @media (max-width: 768px) {
        .site-menu .primary-menu .menu-item-has-children .sub-menu {
          top: 40px;
          right: 2%;
          bottom: 20px;
          background: #3270b6;
          z-index: 1; }
          .site-menu .primary-menu .menu-item-has-children .sub-menu .back a {
            padding-right: 1.25rem;
            position: relative;
            pointer-events: auto;
            cursor: pointer; }
          .site-menu .primary-menu .menu-item-has-children .sub-menu .back a:after {
            width: 100%;
            transition: unset;
            display: block;
            content: "\f054";
            font-family: 'Font Awesome 5 Free';
            font-weight: 900;
            font-size: 1rem;
            top: 0;
            right: 0;
            height: auto;
            z-index: 0;
            bottom: auto;
            background: transparent; } }
  .site-menu .sub-menus-list {
    position: fixed;
    top: 0;
    left: 0;
    bottom: 0;
    width: 100%;
    pointer-events: none; }
    @media (min-width: 769px) {
      .site-menu .sub-menus-list {
        width: 60%;
        pointer-events: all; } }
    @media (min-width: 1101px) {
      .site-menu .sub-menus-list {
        width: 70%; } }
    .site-menu .sub-menus-list .sub-menu {
      padding: 4rem;
      position: absolute;
      top: 0;
      left: 0;
      background: #225FA5;
      opacity: 0;
      width: 100%;
      height: 100%;
      pointer-events: none; }
      @media (max-width: 768px) {
        .site-menu .sub-menus-list .sub-menu {
          height: calc(100% - 70px);
          bottom: 0;
          top: auto;
          background: #3270b6;
          padding: 2rem 2rem 15vh 3rem; } }
      .site-menu .sub-menus-list .sub-menu.active {
        opacity: 1;
        pointer-events: all; }
      .site-menu .sub-menus-list .sub-menu__head {
        margin-bottom: 3rem; }
        @media (max-width: 768px) {
          .site-menu .sub-menus-list .sub-menu__head {
            margin-bottom: 1.5rem; } }
      .site-menu .sub-menus-list .sub-menu__title {
        font-size: 16px;
        text-transform: uppercase;
        font-family: 'Proxima Nova Bold';
        color: #02bff2;
        text-decoration: none; }
        @media (max-width: 768px) {
          .site-menu .sub-menus-list .sub-menu__title {
            position: relative;
            cursor: pointer; }
            .site-menu .sub-menus-list .sub-menu__title:before {
              content: "\f053";
              font-family: 'Font Awesome 5 Free';
              font-weight: 900;
              font-size: 1rem;
              line-height: 2rem;
              color: #10263f;
              text-decoration: none;
              position: absolute;
              left: 0;
              top: 50%;
              transform: translate(calc(-.5rem - 100%), -50%); } }
      .site-menu .sub-menus-list .sub-menu__desc {
        font-size: 18px;
        color: white;
        margin: 0;
        margin-top: .5rem; }
        .site-menu .sub-menus-list .sub-menu__desc a {
          color: white; }
        @media (max-width: 768px) {
          .site-menu .sub-menus-list .sub-menu__desc span {
            display: none; }
          .site-menu .sub-menus-list .sub-menu__desc a {
            margin-top: 1.5rem;
            font-size: 22px;
            text-decoration: none;
            font-family: 'Proxima Nova Bold';
            display: flex;
            gap: 1rem;
            align-items: center; }
            .site-menu .sub-menus-list .sub-menu__desc a:after {
              content: "\f054";
              font-family: 'Font Awesome 5 Free';
              font-weight: 900;
              font-size: 1rem;
              line-height: 2rem;
              margin-right: 0.5rem;
              color: #10263f;
              text-decoration: none; } }
      .site-menu .sub-menus-list .sub-menu__nav {
        overflow: auto;
        max-height: 90%;
        padding-right: 20px; }
        .site-menu .sub-menus-list .sub-menu__nav::-webkit-scrollbar {
          width: 12px; }
          .site-menu .sub-menus-list .sub-menu__nav::-webkit-scrollbar-track {
            background: #1F5A9D; }
          .site-menu .sub-menus-list .sub-menu__nav::-webkit-scrollbar-thumb {
            background: #02bff2; }
        @media (min-width: 901px) {
          .site-menu .sub-menus-list .sub-menu__nav.--list {
            display: grid;
            gap: 2rem;
            grid-template-columns: repeat(2, 1fr); } }
      .site-menu .sub-menus-list .sub-menu__item {
        color: white;
        text-decoration: none;
        transition: .2s linear;
        position: relative; }
        .site-menu .sub-menus-list .sub-menu__item.--icon {
          display: flex;
          gap: 14px;
          align-items: flex-start;
          padding: 1rem 0;
          margin-bottom: 2rem;
          border-bottom: 1px solid rgba(255, 255, 255, 0.2); }
          @media (max-width: 768px) {
            .site-menu .sub-menus-list .sub-menu__item.--icon {
              margin-bottom: 1rem; } }
          @media (min-width: 901px) {
            .site-menu .sub-menus-list .sub-menu__item.--icon .side {
              padding-right: 3rem; } }
          .site-menu .sub-menus-list .sub-menu__item.--icon img {
            width: 36px;
            height: auto; }
          .site-menu .sub-menus-list .sub-menu__item.--icon span {
            font-family: 'Proxima Nova Bold';
            font-size: 30px;
            line-height: 1;
            text-transform: uppercase; }
            @media (max-width: 768px) {
              .site-menu .sub-menus-list .sub-menu__item.--icon span {
                font-size: 22px; } }
          .site-menu .sub-menus-list .sub-menu__item.--icon p {
            margin: 0;
            font-family: 'Proxima Nova Light';
            font-size: 18px; }
            @media (max-width: 768px) {
              .site-menu .sub-menus-list .sub-menu__item.--icon p {
                display: none; } }
        .site-menu .sub-menus-list .sub-menu__item.--list {
          font-weight: 500;
          font-size: 30px;
          line-height: 45px;
          border-bottom: 1px solid rgba(255, 255, 255, 0.2);
          padding: 1rem 0;
          display: block;
          line-height: 1.25;
          height: 100%;
          display: flex;
          align-items: center; }
          @media (min-width: 901px) {
            .site-menu .sub-menus-list .sub-menu__item.--list {
              padding-right: 2rem; } }
          @media (max-width: 768px) {
            .site-menu .sub-menus-list .sub-menu__item.--list {
              font-size: 24px; } }
        .site-menu .sub-menus-list .sub-menu__item::after {
          content: "\f061";
          font-family: 'Font Awesome 5 Free';
          position: absolute;
          top: 50%;
          right: 1rem;
          transform: translateY(-50%);
          font-weight: 900;
          font-size: 1.5rem;
          line-height: 1;
          color: white;
          opacity: 0; }
        .site-menu .sub-menus-list .sub-menu__item:hover {
          background-color: #02bff2;
          padding: 1rem 0 1rem 1rem; }
          .site-menu .sub-menus-list .sub-menu__item:hover::after {
            opacity: 1; }

.site-menu.active {
  transition: .3s linear all;
  opacity: 1;
  z-index: 100;
  transform: scale(1);
  pointer-events: auto; }
.mmenu-socials {
  font-size: 1.25em;
  position: absolute;
  bottom: 1rem;
  left: calc(70% + 3rem); }
  @media (max-width: 768px) {
    .mmenu-socials {
      left: 50%;
      bottom: 1rem;
      transform: translateX(-50%); } }
  .mmenu-socials a {
    color: #10263f;
    display: inline-block;
    margin: 0 0.25em;
    transition: all 0.2s ease-in; }
    .mmenu-socials a:hover {
      transition: all 0.2s ease-in;
      transform: scale(1.2); }

/****************** SELEZIONE CATEGORIE TOP *************************/
.main-blog-category-selection {
  background-color: #3270b6;
  color: white;
}
@media (max-width: 767px){
  .header-container-wrapper .main-blog-category-selection .page-center {
    width:90%;
  }
}
/* NASCONDI SU PAGINA 404 */
.error-template .main-blog-category-selection {
display:none;
}

.main-blog-category-selection .label {
  padding: 0.5rem 0;
  font-family: 'Proxima Nova Bold';
  font-size:1.375rem;
}
.main-blog-category-selection .label span {
  display:inline-block;
  cursor:pointer;
}
.main-blog-category-selection .label i {
  font-size:1rem;
  transition:.2s linear all;
}
.main-blog-category-selection .label.active i {
  transform:rotate(-180deg);
  transition:.2s linear all;
}
.main-blog-category-selection a {
  color:white;
}
.main-blog-category-selection a:hover {
  color:white;
  text-decoration:underline;
}
.main-blog-category-selection .categories-menu-wrapper {
  display:none;
}
.main-blog-category-selection .categories-menu-wrapper.active {
  display:block;
}
.main-blog-category-selection .categories-menu {
  display:flex;
  flex-wrap:wrap;
  padding:1.5rem 0;
  border-top:1px solid #295990;
}
@media (min-width:901px){
  .main-blog-category-selection .categories-menu ul {
    margin-left:4rem;
  }
  .main-blog-category-selection .categories-menu ul:first-child {
    margin-left:0;
  }
}
@media (max-width:900px){
  .main-blog-category-selection .categories-menu {
    flex-direction:column;
  }
}

.mmenu-socials a:hover{
  color:#10263f;
}

.site-header.scrolled, .site-header.transparent.scrolled{
  left:0;
}