@charset "UTF-8";
/*

 +-+-+-+-+-+-+-+-+-+ +-+-+-+-+-+-+-+-+-+ +-+-+-+-+-+-+
 |E|d|u|c|a|t|i|o|n| |M|a|r|k|e|t|i|n|g| |I|t|a|l|i|a|
 +-+-+-+-+-+-+-+-+-+ +-+-+-+-+-+-+-+-+-+ +-+-+-+-+-+-+
 
Author:  Phil @ Education Marketing Italia
URL: https://educationmarketing.it

*/
/* TYPO */
@import url("https://fonts.googleapis.com/css2?family=Crimson+Text:ital,wght@0,400;0,600;0,700;1,400;1,600;1,700&family=Work+Sans:ital,wght@0,100..900;1,100..900&display=swap");
/* BASE */
.clearfix:after {
  visibility: hidden;
  display: block;
  font-size: 0;
  content: " ";
  clear: both;
  height: 0; }

.clearfix {
  display: inline-block; }

* html .clearfix {
  height: 1%; }

.clearfix {
  display: block; }

div.clear {
  clear: both; }

.show {
  display: block !important; }

html {
  width: 100%;
  height: 100%; }

html, body {
  font-size: 16px;
  line-height: 24px;
  font-weight: 400;
  color: #333;
  font-family: "Work Sans", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  overflow-x: hidden; }
  html p, body p {
    margin-bottom: 15px;
    font-weight: 400;
    margin-top: 0; }
  html .post, html .page, body .post, body .page {
    margin: 0; }
  html .page-content, html .entry-content, body .page-content, body .entry-content {
    margin: 0; }
  html a, body a {
    text-decoration: underline;
    color: #204660;
    -webkit-transition: all 0.3s 0s linear;
    -moz-transition: all 0.3s 0s linear;
    -o-transition: all 0.3s 0s linear;
    transition: all 0.3s 0s linear; }
    html a:hover, html a:visited, html a:focus, body a:hover, body a:visited, body a:focus {
      color: #377081;
      -webkit-transition: all 0.3s 0s linear;
      -moz-transition: all 0.3s 0s linear;
      -o-transition: all 0.3s 0s linear;
      transition: all 0.3s 0s linear; }
  html .text-center, body .text-center {
    text-align: center; }
  html .p-privacy, body .p-privacy {
    margin: 15px 0;
    display: inline-block; }
  html .vc_col-has-fill > .vc_column-inner,
  html .vc_row-has-fill + .vc_row-full-width + .vc_row > .vc_column_container > .vc_column-inner,
  html .vc_row-has-fill + .vc_row > .vc_column_container > .vc_column-inner,
  html .vc_row-has-fill > .vc_column_container > .vc_column-inner, body .vc_col-has-fill > .vc_column-inner,
  body .vc_row-has-fill + .vc_row-full-width + .vc_row > .vc_column_container > .vc_column-inner,
  body .vc_row-has-fill + .vc_row > .vc_column_container > .vc_column-inner,
  body .vc_row-has-fill > .vc_column_container > .vc_column-inner {
    padding-top: 0; }
  html h1, body h1 {
    font-family: "Crimson Text", serif;
    font-size: 60px;
    line-height: 65px;
    color: #333;
    font-weight: 500;
    margin: 0 0 10px 0; }
    @media (max-width: 768px) {
      html h1, body h1 {
        text-align: center;
        margin-bottom: 25px !important;
        font-size: 50px;
        line-height: 55px; } }
  html h2, body h2 {
    font-family: "Crimson Text", serif;
    font-size: 40px;
    line-height: 50px;
    font-weight: 700 !important;
    margin: 0 0 25px 0 !important;
    color: #333; }
    html h2.titolo-font-alternativo, body h2.titolo-font-alternativo {
      font-family: "Work Sans", sans-serif;
      font-weight: 500 !important;
      font-size: 30px;
      line-height: 40px; }
      @media (max-width: 768px) {
        html h2.titolo-font-alternativo, body h2.titolo-font-alternativo {
          text-align: center; } }
    @media (max-width: 768px) {
      html h2, body h2 {
        font-size: 35px;
        line-height: 40px; } }
  html h3, body h3 {
    font-family: "Crimson Text", serif;
    font-size: 30px;
    line-height: 40px;
    font-weight: 600;
    margin: 0 0 25px 0;
    color: #333; }
    html h3.titolo-font-alternativo, body h3.titolo-font-alternativo {
      font-family: "Work Sans", sans-serif; }
  html h4, body h4 {
    font-family: "Crimson Text", serif;
    font-size: 20px;
    line-height: 30px;
    font-weight: 600;
    margin: 0 0 25px 0;
    color: #333; }
  html strong, body strong {
    font-weight: 700; }
  html .no-margin-bottom, body .no-margin-bottom {
    margin-bottom: 0; }
  html .no-margin-title h2, body .no-margin-title h2 {
    margin: 0 !important; }
  html .black, body .black {
    font-weight: 900; }
  html .rosso, body .rosso {
    color: #B30000; }
  html ul, html ol, body ul, body ol {
    margin: 15px 0; }
    html ul li, html ol li, body ul li, body ol li {
      line-height: 26px;
      font-size: 16px;
      /*margin-bottom:15px;*/ }
  html .site-wrapper, body .site-wrapper {
    width: 100%;
    max-width: 1250px;
    padding: 0 25px;
    margin: 0 auto; }
  html img, body img {
    position: relative; }
  html .comment-navigation .nav-links, html .posts-navigation .nav-links, html .post-navigation .nav-links, body .comment-navigation .nav-links, body .posts-navigation .nav-links, body .post-navigation .nav-links {
    display: none; }
  html img, body img {
    image-rendering: -moz-crisp-edges;
    /* Firefox */
    image-rendering: -o-crisp-edges;
    /* Opera */
    image-rendering: -webkit-optimize-contrast;
    /* Webkit (non-standard naming) */
    image-rendering: crisp-edges;
    -ms-interpolation-mode: nearest-neighbor;
    /* IE (non-standard property) */ }
  html .img-mobile, body .img-mobile {
    min-height: 400px; }
  html .padding-50 .vc_column-inner, body .padding-50 .vc_column-inner {
    padding: 50px !important; }
  html .hidden-sm, body .hidden-sm {
    display: block; }
    @media (max-width: 768px) {
      html .hidden-sm, body .hidden-sm {
        display: none; } }
  html .show-sm, body .show-sm {
    display: none; }
    @media (max-width: 768px) {
      html .show-sm, body .show-sm {
        display: block; } }
  @media (max-width: 768px) {
    html .text-center-mobile, body .text-center-mobile {
      text-align: center;
      margin: 0 auto; } }

/* HEADER */
.header-wrapper {
  height: 100px; }
  @media (max-width: 992px) {
    .header-wrapper {
      height: 100px; } }

/* Top menu */
#menu-top .top-sx {
  width: 50%;
  display: flex; }
  #menu-top .top-sx .social a {
    display: flex; }
    #menu-top .top-sx .social a img {
      width: 20px;
      margin-right: 15px; }
#menu-top .top-dx {
  width: 50%; }
@media (max-width: 992px) {
  #menu-top {
    display: none; } }
#menu-top.mobile {
  position: fixed;
  bottom: 0;
  display: block;
  z-index: 160;
  background-color: #204660;
  flex-direction: column-reverse;
  width: 100%; }
  #menu-top.mobile .site-wrapper {
    flex-direction: column-reverse; }
    #menu-top.mobile .site-wrapper .top-sx {
      width: 100%;
      justify-content: center;
      margin: 10px 0; }
    #menu-top.mobile .site-wrapper .top-dx {
      width: 100%; }

.top-menu {
  background-color: #204660;
  padding: 0;
  height: 40px;
  display: flex;
  align-items: center; }
  @media (max-width: 992px) {
    .top-menu {
      height: auto; } }
  .top-menu .menu-top-container {
    width: 100%;
    display: flex;
    justify-content: flex-end; }
    @media (max-width: 992px) {
      .top-menu .menu-top-container {
        justify-content: center; } }
    .top-menu .menu-top-container ul {
      margin: 0;
      text-align: right;
      display: flex;
      justify-content: flex-end;
      list-style: none;
      padding-left: 0;
      position: relative;
      width: max-content; }
      @media (max-width: 992px) {
        .top-menu .menu-top-container ul {
          justify-content: center; } }
      .top-menu .menu-top-container ul li {
        margin-left: 10px;
        display: flex;
        align-items: center;
        justify-content: center;
        height: 40px;
        margin-bottom: 0; }
        .top-menu .menu-top-container ul li:not(:last-child):after {
          content: '|';
          color: #fff;
          padding-left: 10px; }
        .top-menu .menu-top-container ul li a {
          color: #fff;
          text-decoration: none;
          font-size: 13px;
          font-weight: 400 !important; }
          .top-menu .menu-top-container ul li a:hover {
            color: #C99F22; }
            @media (max-width: 992px) {
              .top-menu .menu-top-container ul li a:hover {
                color: #fff; } }
        .top-menu .menu-top-container ul li.registro-elettronico span {
          font-size: 18px;
          top: 4px;
          position: relative; }

/* Main Menu */
#masthead {
  display: block;
  align-items: center;
  /*-webkit-box-shadow: 0px 2px 5px 0px rgba(0,0,0,0.25);
  -moz-box-shadow: 0px 2px 5px 0px rgba(0,0,0,0.25);
  box-shadow: 0px 2px 5px 0px rgba(0,0,0,0.25);*/
  -webkit-transition: background-color 0.3s 0s linear;
  -moz-transition: background-color 0.3s 0s linear;
  -o-transition: background-color 0.3s 0s linear;
  transition: background-color 0.3s 0s linear;
  top: 0;
  position: relative;
  z-index: 150;
  /* Fix per doppio logo */
  /* Fix per colore menù quando fixed */ }
  .page-home #masthead {
    background-color: #204660; }
  body:not(.page-home) #masthead {
    background-color: #fff;
    -webkit-box-shadow: 0px 2px 5px 0px rgba(0, 0, 0, 0.25);
    -moz-box-shadow: 0px 2px 5px 0px rgba(0, 0, 0, 0.25);
    box-shadow: 0px 2px 5px 0px rgba(0, 0, 0, 0.25); }
  @media (max-width: 992px) {
    #masthead {
      border-bottom: 1px solid rgba(255, 255, 255, 0.5);
      display: flex;
      height: 100px; }
      #masthead.mobile {
        height: 100%; } }
  #masthead .site-wrapper {
    width: 100%;
    max-width: 1250px;
    padding: 0 25px;
    margin: 0 auto;
    display: flex;
    align-items: center;
    border-bottom: 1px solid rgba(255, 255, 255, 0.5); }
    @media (max-width: 992px) {
      #masthead .site-wrapper {
        border-bottom: none; } }
  #masthead.fixed {
    position: fixed;
    width: 100%;
    top: 0;
    z-index: 150;
    background-color: #fff;
    /*-webkit-transition: all 0.3s 0s smoothScroll;
    -moz-transition: all 0.3s 0s smoothScroll;
    -o-transition: all 0.3s 0s smoothScroll;
    transition: all 0.3s 0s smoothScroll;*/
    animation: smoothScroll 0.5s forwards;
    -webkit-box-shadow: 0px 2px 5px 0px rgba(0, 0, 0, 0.25);
    -moz-box-shadow: 0px 2px 5px 0px rgba(0, 0, 0, 0.1);
    box-shadow: 0px 2px 5px 0px rgba(0, 0, 0, 0.1); }
@keyframes smoothScroll {
  0% {
    transform: translateY(-40px); }
  100% {
    transform: translateY(0px); } }
  #masthead .site-title, #masthead .site-description {
    display: none; }
  #masthead .logo-wrapper {
    position: relative;
    width: 220px;
    height: 72px; }
    @media (max-width: 992px) {
      #masthead .logo-wrapper {
        position: absolute;
        top: 14px; } }
  #masthead .logo-default,
  #masthead .logo-fixed {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    transition: opacity 0.3s ease-in-out; }
  .page-home #masthead .logo-default {
    opacity: 1; }
  .page-home #masthead .search-icon-path {
    fill: #fff; }
    @media (max-width: 992px) {
      .page-home #masthead .search-icon-path {
        fill: #333; } }
  .page-home #masthead .logo-fixed {
    opacity: 0; }
  body:not(.page-home) #masthead .logo-default {
    opacity: 0; }
  body:not(.page-home) #masthead .logo-fixed {
    opacity: 1; }
  #masthead.fixed .logo-default {
    opacity: 0; }
  #masthead.fixed .logo-fixed {
    opacity: 1; }
  #masthead.fixed .search-icon-path {
    fill: #333; }
  #masthead .custom-logo-link {
    display: flex; }
    #masthead .custom-logo-link img {
      width: 220px;
      max-width: 100%; }
      @media (max-width: 992px) {
        #masthead .custom-logo-link img {
          width: 150px; } }
  #masthead #site-navigation .menu-toggle {
    display: block;
    position: absolute;
    right: 35px;
    top: 35px;
    background-color: transparent !important;
    border: 0;
    outline: none;
    padding: 0; }
    @media (min-width: 992px) {
      #masthead #site-navigation .menu-toggle {
        display: none; } }
    #masthead #site-navigation .menu-toggle .sr-only {
      position: absolute;
      width: 1px;
      height: 1px;
      padding: 0;
      margin: -1px;
      overflow: hidden;
      clip: rect(0, 0, 0, 0);
      border: 0; }
  #masthead #site-navigation .burger-menu {
    width: 25px;
    height: 2px;
    color: #666;
    position: relative;
    margin: 6px 0;
    display: block;
    -webkit-transition: all 0.3s 0s linear;
    -moz-transition: all 0.3s 0s linear;
    -o-transition: all 0.3s 0s linear;
    transition: all 0.3s 0s linear; }
    .page-home #masthead #site-navigation .burger-menu {
      background-color: #fff; }
    body:not(.page-home) #masthead #site-navigation .burger-menu {
      background-color: #204660; }
  #masthead #site-navigation .menu-menu-container {
    -webkit-transition: all 0.3s 0s linear;
    -moz-transition: all 0.3s 0s linear;
    -o-transition: all 0.3s 0s linear;
    transition: all 0.3s 0s linear; }
  #masthead #site-navigation.toggled .burger-menu {
    opacity: 0; }
  #masthead #site-navigation.toggled .menu-toggle {
    margin-top: 8px; }
  #masthead #site-navigation.toggled .burger-menu:nth-child(2) {
    transform: rotate(45deg);
    opacity: 1;
    -webkit-transition: all 0.3s 0s linear;
    -moz-transition: all 0.3s 0s linear;
    -o-transition: all 0.3s 0s linear;
    transition: all 0.3s 0s linear; }
  #masthead #site-navigation.toggled .burger-menu:last-child {
    transform: rotate(-45deg);
    top: -16px;
    opacity: 1;
    -webkit-transition: all 0.3s 0s linear;
    -moz-transition: all 0.3s 0s linear;
    -o-transition: all 0.3s 0s linear;
    transition: all 0.3s 0s linear; }
  #masthead #site-navigation.toggled .menu-menu-container {
    background-color: #204660;
    width: 100%;
    height: calc(100dvh - 100px);
    position: absolute;
    top: 100px;
    left: 0;
    visibility: visible;
    opacity: 1;
    -webkit-transition: all 0.5s 0s linear;
    -moz-transition: all 0.5s 0s linear;
    -o-transition: all 0.5s 0s linear;
    transition: all 0.5s 0s linear;
    display: flex;
    justify-content: center;
    text-align: center;
    align-items: center;
    /*padding-top:50px;*/
    z-index: 150; }
    @media (max-width: 992px) {
      #masthead #site-navigation.toggled .menu-menu-container {
        background: #FFF;
        /*background: -webkit-linear-gradient(45deg, rgba(255, 255, 255, 1) 40%, rgba(244, 234, 218, 1) 100%);
        background: -moz-linear-gradient(45deg, rgba(255, 255, 255, 1) 40%, rgba(244, 234, 218, 1) 100%);
        background: linear-gradient(45deg, rgba(255, 255, 255, 1) 40%, rgba(244, 234, 218, 1) 100%);
        filter: progid:DXImageTransform.Microsoft.gradient(startColorstr="#FFFFFF", endColorstr="#F4EADA", GradientType=0);*/ } }
  #masthead #site-navigation.toggled #primary-menu {
    float: none; }
    @media (max-width: 992px) {
      #masthead #site-navigation.toggled #primary-menu {
        display: block; } }
    #masthead #site-navigation.toggled #primary-menu .menu-item {
      margin: 20px 15px; }
  #masthead #site-navigation #primary-menu {
    float: right; }
    @media (max-width: 992px) {
      #masthead #site-navigation #primary-menu {
        display: none; } }
    #masthead #site-navigation #primary-menu .menu-item {
      margin: 0 15px;
      height: 100px;
      display: flex;
      align-items: center;
      justify-content: center; }
      #masthead #site-navigation #primary-menu .menu-item:last-child {
        margin: 0 0 0 15px; }
      @media (max-width: 992px) {
        #masthead #site-navigation #primary-menu .menu-item {
          height: auto; } }
      #masthead #site-navigation #primary-menu .menu-item.indietro {
        background-color: #204660;
        border-radius: 8px;
        border: 1px solid #204660;
        -webkit-transition: all 0.3s 0s linear;
        -moz-transition: all 0.3s 0s linear;
        -o-transition: all 0.3s 0s linear;
        transition: all 0.3s 0s linear;
        box-shadow: 0px 7.5px 5px 0px rgba(0, 0, 0, 0.1);
        -webkit-box-shadow: 0px 7.5px 5px 0px rgba(0, 0, 0, 0.1);
        -moz-box-shadow: 0px 7.5px 5px 0px rgba(0, 0, 0, 0.1); }
        #masthead #site-navigation #primary-menu .menu-item.indietro a {
          color: #fff !important;
          -webkit-transition: all 0.3s 0s linear;
          -moz-transition: all 0.3s 0s linear;
          -o-transition: all 0.3s 0s linear;
          transition: all 0.3s 0s linear;
          text-transform: none !important;
          font-weight: 500 !important;
          top: 0 !important;
          padding: 7px 25px; }
          #masthead #site-navigation #primary-menu .menu-item.indietro a:hover, #masthead #site-navigation #primary-menu .menu-item.indietro a:focus {
            background-color: #fff;
            color: #204660 !important;
            -webkit-transition: all 0.3s 0s linear;
            -moz-transition: all 0.3s 0s linear;
            -o-transition: all 0.3s 0s linear;
            transition: all 0.3s 0s linear; }
      #masthead #site-navigation #primary-menu .menu-item .sub-menu a {
        color: #333 !important;
        -webkit-transition: all 0.3s 0s linear;
        -moz-transition: all 0.3s 0s linear;
        -o-transition: all 0.3s 0s linear;
        transition: all 0.3s 0s linear; }
        #masthead #site-navigation #primary-menu .menu-item .sub-menu a:hover {
          color: #F0B935;
          -webkit-transition: all 0.3s 0s linear;
          -moz-transition: all 0.3s 0s linear;
          -o-transition: all 0.3s 0s linear;
          transition: all 0.3s 0s linear; }
      #masthead #site-navigation #primary-menu .menu-item .sub-menu .indietro a {
        color: #fff !important; }
      .page-home #masthead #site-navigation #primary-menu .menu-item.current-menu-parent > a {
        color: #fff; }
      body:not(.page-home) #masthead #site-navigation #primary-menu .menu-item.current-menu-parent > a {
        color: #333; }
      @media (max-width: 992px) {
        #masthead #site-navigation #primary-menu .menu-item.current-menu-parent > a {
          color: #333; } }
      #masthead #site-navigation #primary-menu .menu-item.current-menu-parent > a:after {
        content: '';
        display: block;
        height: 2px;
        -webkit-transition: all 0.3s 0s linear;
        -moz-transition: all 0.3s 0s linear;
        -o-transition: all 0.3s 0s linear;
        transition: all 0.3s 0s linear;
        opacity: 1;
        width: 100%;
        background-color: #C99F22; }
      #masthead #site-navigation #primary-menu .menu-item a {
        font-weight: 500;
        font-size: 16px;
        width: max-content;
        /*text-transform: uppercase;*/
        position: relative;
        top: 1px; }
        .page-home #masthead #site-navigation #primary-menu .menu-item a {
          color: #fff; }
          @media (max-width: 992px) {
            .page-home #masthead #site-navigation #primary-menu .menu-item a {
              color: #333; } }
        body:not(.page-home) #masthead #site-navigation #primary-menu .menu-item a {
          color: #333; }
        @media (max-width: 992px) {
          #masthead #site-navigation #primary-menu .menu-item a {
            width: max-content;
            font-size: 20px;
            /*color:#333!important;*/ } }
        #masthead #site-navigation #primary-menu .menu-item a:after {
          content: '';
          display: block;
          height: 2px;
          opacity: 0;
          -webkit-transition: all 0.3s 0s linear;
          -moz-transition: all 0.3s 0s linear;
          -o-transition: all 0.3s 0s linear;
          transition: all 0.3s 0s linear;
          width: 0; }
          @media (max-width: 992px) {
            #masthead #site-navigation #primary-menu .menu-item a:after {
              display: none; } }
        #masthead #site-navigation #primary-menu .menu-item a:hover {
          color: #C99F22; }
          #masthead #site-navigation #primary-menu .menu-item a:hover:after {
            -webkit-transition: all 0.3s 0s linear;
            -moz-transition: all 0.3s 0s linear;
            -o-transition: all 0.3s 0s linear;
            transition: all 0.3s 0s linear;
            opacity: 1;
            width: 100%;
            background-color: #C99F22; }
            @media (max-width: 992px) {
              #masthead #site-navigation #primary-menu .menu-item a:hover:after {
                display: none; } }
      .page-home #masthead #site-navigation #primary-menu .menu-item.current_page_item a {
        color: #fff; }
        @media (max-width: 992px) {
          .page-home #masthead #site-navigation #primary-menu .menu-item.current_page_item a {
            color: #333; } }
      body:not(.page-home) #masthead #site-navigation #primary-menu .menu-item.current_page_item a {
        color: #333; }
      #masthead #site-navigation #primary-menu .menu-item.current_page_item a:after {
        content: '';
        display: block;
        height: 2px;
        -webkit-transition: all 0.3s 0s linear;
        -moz-transition: all 0.3s 0s linear;
        -o-transition: all 0.3s 0s linear;
        transition: all 0.3s 0s linear;
        opacity: 1;
        width: 100%;
        background-color: #C99F22; }
      @media (max-width: 992px) {
        #masthead #site-navigation #primary-menu .menu-item.current_page_item a {
          color: #333;
          width: max-content; }
          #masthead #site-navigation #primary-menu .menu-item.current_page_item a:after {
            color: #333;
            background-color: #333; } }
      #masthead #site-navigation #primary-menu .menu-item-has-children:after {
        content: "";
        width: 0;
        height: 0;
        border-left: 4px solid transparent;
        border-right: 4px solid transparent;
        position: relative;
        right: -7.5px; }
        .page-home #masthead #site-navigation #primary-menu .menu-item-has-children:after {
          border-top: 4px solid #fff; }
          @media (max-width: 992px) {
            .page-home #masthead #site-navigation #primary-menu .menu-item-has-children:after {
              border-top: 4px solid #333; } }
        body:not(.page-home) #masthead #site-navigation #primary-menu .menu-item-has-children:after {
          border-top: 4px solid #333; }
        @media (max-width: 992px) {
          #masthead #site-navigation #primary-menu .menu-item-has-children:after {
            /*display:none;*/
            border-top: 4px solid #333;
            top: 3px; } }
    #masthead #site-navigation #primary-menu .sub-menu {
      display: block;
      background-color: #fff; }
      #masthead #site-navigation #primary-menu .sub-menu li {
        display: block;
        height: auto; }
  #masthead.fixed #site-navigation .burger-menu {
    background-color: #204660; }
  #masthead.fixed #site-navigation #primary-menu .menu-item a {
    color: #333 !important; }
    @media (max-width: 992px) {
      #masthead.fixed #site-navigation #primary-menu .menu-item a {
        color: #fff; } }
  #masthead.fixed #site-navigation #primary-menu .menu-item.indietro a {
    color: #fff !important; }
  #masthead.fixed #site-navigation #primary-menu .menu-item-has-children:after {
    border-top: 4px solid #333; }

.main-navigation ul li:hover > ul, .main-navigation ul li.focus > ul {
  left: 0;
  min-width: 200px; }
  @media (max-width: 992px) {
    .main-navigation ul li:hover > ul, .main-navigation ul li.focus > ul {
      left: auto; } }
  .main-navigation ul li:hover > ul li, .main-navigation ul li.focus > ul li {
    margin: 15px !important;
    height: 100%; }
    .main-navigation ul li:hover > ul li a, .main-navigation ul li.focus > ul li a {
      color: #000; }

.dropdown-livello-2-parent {
  display: none !important; }
  @media (max-width: 992px) {
    .dropdown-livello-2-parent {
      display: block !important; } }

.dropdown-livello-2-aperto {
  position: fixed !important;
  display: flex !important;
  align-items: center !important;
  left: 0 !important;
  top: 100px !important;
  width: 100% !important;
  height: calc(100dvh - 180px) !important;
  z-index: 70 !important;
  flex-direction: column;
  justify-content: center;
  background: #FFF; }
  .dropdown-livello-2-aperto li {
    margin: 10px auto !important;
    line-height: 20px; }

.dropdown-livello-2-chiuso {
  display: none !important; }

.indietro {
  background-color: #204660;
  border-radius: 8px;
  border: 1px solid #204660;
  -webkit-transition: all 0.3s 0s linear;
  -moz-transition: all 0.3s 0s linear;
  -o-transition: all 0.3s 0s linear;
  transition: all 0.3s 0s linear;
  box-shadow: 0px 7.5px 5px 0px rgba(0, 0, 0, 0.1);
  -webkit-box-shadow: 0px 7.5px 5px 0px rgba(0, 0, 0, 0.1);
  -moz-box-shadow: 0px 7.5px 5px 0px rgba(0, 0, 0, 0.1); }
  .indietro a {
    color: #fff !important;
    -webkit-transition: all 0.3s 0s linear;
    -moz-transition: all 0.3s 0s linear;
    -o-transition: all 0.3s 0s linear;
    transition: all 0.3s 0s linear;
    text-transform: none !important;
    font-weight: 500 !important;
    top: 0 !important;
    padding: 7px 25px; }
    .indietro a:hover, .indietro a:focus {
      background-color: #fff;
      color: #204660 !important;
      -webkit-transition: all 0.3s 0s linear;
      -moz-transition: all 0.3s 0s linear;
      -o-transition: all 0.3s 0s linear;
      transition: all 0.3s 0s linear; }

/* Header pagine */
#header {
  min-height: 500px;
  background-position: center;
  background-size: cover;
  background-repeat: no-repeat;
  display: flex;
  justify-content: flex-end;
  position: relative; }
  @media (max-width: 768px) {
    #header {
      min-height: 350px; } }

/* Titolo pagine */
#titolo p {
  font-size: 23px;
  font-weight: 500; }
@media (max-width: 768px) {
  #titolo {
    padding-bottom: 50px;
    text-align: center; } }

/* Header nuovo */
.header-h2 {
  font-family: "Work Sans", sans-serif !important; }

/* Elementi decorativi */
.elemento-decorativo {
  width: 200px; }
  .elemento-decorativo.centrato {
    margin: 0 auto; }
  .elemento-decorativo.small {
    width: 125px; }
  .elemento-decorativo .svg-container {
    width: 100%;
    height: 200px;
    /* Altezza fissa */
    display: flex;
    align-items: center;
    justify-content: center; }
    .elemento-decorativo .svg-container svg {
      max-width: 100%;
      max-height: 100%;
      width: auto;
      height: auto; }

.barra-sopra:before {
  width: 100px;
  height: 4px;
  content: '';
  display: block;
  background-color: #F36A55;
  margin-bottom: 15px; }

@keyframes morphing-circle {
  0% {
    border-radius: 60% 40% 42% 58% / 41% 38% 62% 59%; }
  25% {
    border-radius: 40% 60% 58% 42% / 62% 59% 41% 38%; }
  50% {
    border-radius: 58% 42% 60% 40% / 38% 62% 59% 41%; }
  75% {
    border-radius: 42% 58% 40% 60% / 59% 41% 38% 62%; }
  100% {
    border-radius: 60% 40% 42% 58% / 41% 38% 62% 59%; } }
.radius-animato img {
  width: 450px;
  /*border-radius: 60% 40% 42% 58% / 41% 38% 62% 59%;*/
  border-radius: 30% 70% 73% 27%/30% 30% 70% 70%;
  animation: morphing-circle 20s ease-in-out infinite; }
  @media (max-width: 768px) {
    .radius-animato img {
      margin-bottom: 25px; } }

/* Slider news */
.slider-news .slide-news {
  background-color: #f7f7f7;
  border-top-left-radius: 8px;
  border-top-right-radius: 8px;
  border-bottom-left-radius: 8px;
  border-bottom-right-radius: 8px; }
  .slider-news .slide-news img {
    aspect-ratio: 1 / 1;
    object-fit: cover;
    border-top-left-radius: 8px;
    border-top-right-radius: 8px; }
  .slider-news .slide-news .categoria {
    position: absolute;
    z-index: 10;
    background-color: #fff;
    width: max-content;
    top: 10px;
    right: 15px;
    padding: 0 5px;
    color: #204660;
    font-size: 13px;
    line-height: 23px;
    border-radius: 5px;
    text-transform: uppercase;
    font-weight: 700;
    -webkit-box-shadow: 0px 2px 5px 0px rgba(0, 0, 0, 0.25);
    -moz-box-shadow: 0px 2px 5px 0px rgba(0, 0, 0, 0.25);
    box-shadow: 0px 2px 5px 0px rgba(0, 0, 0, 0.25); }
  .slider-news .slide-news .desc {
    padding: 5px 15px; }
    .slider-news .slide-news .desc a {
      text-decoration: none; }
    .slider-news .slide-news .desc .data {
      font-size: 13px; }
  .slider-news .slide-news .titolo {
    color: #204660;
    font-weight: 600;
    font-size: 19px;
    line-height: 25px;
    margin-bottom: 15px;
    text-decoration: none;
    font-family: "Work Sans", sans-serif; }
  .slider-news .slide-news .excerpt {
    font-size: 14px;
    line-height: 20px;
    margin-bottom: 20px; }
  .slider-news .slide-news .btn {
    margin: 0 15px 25px 15px;
    padding: 5px 20px;
    font-size: 14px;
    line-height: 24px; }

/* Fix arrow home page */
.page-home .slider-nav-dark .slider-nav::after {
  background-color: #fff; }

/* Pagina news*/
/* NEWS */
.grid-news {
  /* Fix per virgola dopo categoria se più di una */ }
  .grid-news .vc_grid-filter {
    margin: 0 0 50px 0; }
    .grid-news .vc_grid-filter .vc_grid-filter-item {
      background-color: #f0f0f0; }
      .grid-news .vc_grid-filter .vc_grid-filter-item span {
        color: #333 !important; }
      .grid-news .vc_grid-filter .vc_grid-filter-item.vc_active {
        background-color: #204660 !important; }
        .grid-news .vc_grid-filter .vc_grid-filter-item.vc_active span {
          color: #fff !important; }
      .grid-news .vc_grid-filter .vc_grid-filter-item span {
        color: #fff;
        font-weight: 500; }
  .grid-news .vc_grid-filter.vc_grid-filter-default > .vc_grid-filter-item {
    border-radius: 8px;
    margin: 0 5px 0 5px; }
  .grid-news .vc_gitem-zone-a {
    border-top-left-radius: 8px;
    border-top-right-radius: 8px; }
    .grid-news .vc_gitem-zone-a .categoria {
      position: absolute;
      z-index: 10;
      background-color: #fff !important;
      width: max-content;
      top: 10px;
      right: 15px;
      padding: 0 5px;
      color: #204660;
      font-size: 13px;
      line-height: 23px;
      border-radius: 5px;
      text-transform: uppercase;
      font-weight: 700; }
      .grid-news .vc_gitem-zone-a .categoria .vc_grid-filter-item {
        background-color: #fff !important; }
        .grid-news .vc_gitem-zone-a .categoria .vc_grid-filter-item span {
          color: #204660 !important;
          font-weight: 700;
          cursor: default; }
  .grid-news .vc_gitem-zone-c {
    border-bottom-left-radius: 8px;
    border-bottom-right-radius: 8px;
    padding: 5px 15px !important;
    background-color: #f7f7f7; }
    .grid-news .vc_gitem-zone-c .titolo h3 {
      color: #204660;
      font-weight: 600;
      font-size: 19px;
      line-height: 25px;
      margin-bottom: 15px;
      text-decoration: none;
      font-family: "Work Sans", sans-serif; }
    .grid-news .vc_gitem-zone-c .desc p {
      font-size: 14px;
      line-height: 20px;
      margin-bottom: 20px; }
    .grid-news .vc_gitem-zone-c .data {
      font-size: 13px; }
    .grid-news .vc_gitem-zone-c .leggi-tutto {
      margin-bottom: 0; }
      .grid-news .vc_gitem-zone-c .leggi-tutto a {
        color: #fff !important;
        background-color: #204660;
        text-transform: uppercase;
        font-weight: 600;
        -webkit-transition: all 0.3s 0s linear;
        -moz-transition: all 0.3s 0s linear;
        -o-transition: all 0.3s 0s linear;
        transition: all 0.3s 0s linear;
        display: inline-block;
        cursor: pointer;
        text-align: center;
        font-size: 14px;
        line-height: 24px;
        position: relative;
        border: 1px solid #204660;
        border-radius: 8px;
        z-index: 30;
        margin: 0 0 25px 0;
        padding: 5px 20px;
        font-size: 14px;
        line-height: 24px;
        background-image: none; }
        .grid-news .vc_gitem-zone-c .leggi-tutto a:hover {
          -webkit-transition: all 0.3s 0s linear;
          -moz-transition: all 0.3s 0s linear;
          -o-transition: all 0.3s 0s linear;
          transition: all 0.3s 0s linear;
          background-color: #fff;
          color: #204660 !important; }
  .grid-news .vc_gitem-post-category-name:not(:last-child)::after {
    content: ", "; }
  .grid-news .vc_grid-pagination {
    margin-top: 50px; }
    .grid-news .vc_grid-pagination .vc_grid-pagination-list > li > a, .grid-news .vc_grid-pagination .vc_grid-pagination .vc_grid-pagination-list > li > span {
      font-size: 17px;
      line-height: 27px; }

/* News */
.post .entry-header {
  background-color: #204660;
  padding: 50px 0; }
  .post .entry-header h1, .post .entry-header h2 {
    color: #fff; }
  .post .entry-header h1 {
    font-size: 50px;
    line-height: 60px; }
  .post .entry-header .categorie .categoria {
    background-color: #fff;
    color: #204660;
    border-radius: 2.5px;
    margin-right: 10px;
    text-transform: uppercase;
    font-weight: 600;
    padding: 1.5px 5px; }
  .post .entry-header .data-pubblicazione {
    color: #fff; }
    .post .entry-header .data-pubblicazione span {
      font-weight: 600; }
.post .entry-content {
  margin: 50px 0; }
.post .post-thumbnail {
  margin-top: 50px; }
  .post .post-thumbnail img {
    aspect-ratio: 16 / 9;
    object-fit: cover;
    width: 100%;
    border-radius: 12px; }
.post .indietro-archivio {
  text-align: center;
  margin-bottom: 50px; }

.page .entry-header {
  width: 100%;
  max-width: 1250px;
  padding: 0 25px;
  margin: 0 auto;
  display: none; }

#primary {
  min-height: calc(100vh - 100px);
  position: relative; }
  #primary .site-wrapper {
    width: 100%;
    max-width: 1250px;
    padding: 0 25px;
    margin: 0 auto;
    background-color: transparent;
    position: relative; }
  #primary input[type="text"],
  #primary input[type="email"],
  #primary input[type="url"],
  #primary input[type="password"],
  #primary input[type="search"],
  #primary input[type="number"],
  #primary input[type="tel"],
  #primary input[type="range"],
  #primary input[type="date"],
  #primary input[type="month"],
  #primary input[type="week"],
  #primary input[type="time"],
  #primary input[type="datetime"],
  #primary input[type="datetime-local"],
  #primary input[type="color"],
  #primary textarea,
  #primary select {
    color: #333;
    border: none;
    border-radius: 8px;
    padding: 3px;
    background-color: #FEFEFE;
    margin: 5px 0;
    width: 100%;
    padding: 10px;
    font-size: 16px;
    line-height: 24px;
    cursor: pointer; }
  #primary input[type="button"],
  #primary input[type="reset"],
  #primary input[type="submit"] {
    color: #fff !important;
    border: 1px solid #204660;
    background-color: #204660;
    text-transform: uppercase;
    font-weight: bold;
    border-radius: 0;
    -webkit-transition: all 0.3s 0s linear;
    -moz-transition: all 0.3s 0s linear;
    -o-transition: all 0.3s 0s linear;
    transition: all 0.3s 0s linear;
    border-radius: 8px;
    text-align: left;
    padding: 5px 20px;
    margin-top: 15px;
    display: inline-block;
    cursor: pointer;
    text-align: center;
    font-size: 14px;
    line-height: 24px; }
    #primary input[type="button"]:hover,
    #primary input[type="reset"]:hover,
    #primary input[type="submit"]:hover {
      background-color: #fff;
      border: 1px solid #204660;
      color: #204660 !important;
      -webkit-transition: all 0.3s 0s linear;
      -moz-transition: all 0.3s 0s linear;
      -o-transition: all 0.3s 0s linear;
      transition: all 0.3s 0s linear; }

.show-mobile {
  display: none; }
  @media (max-width: 480px) {
    .show-mobile {
      display: block; } }

/* SEARCH */
.search .search-field, .error404 .search-field {
  background-color: #f7f7f7 !important; }
.search .page-header, .error404 .page-header {
  background-color: #204660;
  padding: 0 0; }
  @media (max-width: 768px) {
    .search .page-header, .error404 .page-header {
      padding-bottom: 25px; } }
  .search .page-header .title-wrapper, .error404 .page-header .title-wrapper {
    display: flex;
    align-items: center; }
    @media (max-width: 768px) {
      .search .page-header .title-wrapper, .error404 .page-header .title-wrapper {
        flex-direction: column; } }
    .search .page-header .title-wrapper .elemento-decorativo, .error404 .page-header .title-wrapper .elemento-decorativo {
      margin: 0 50px 0 0; }
      @media (max-width: 768px) {
        .search .page-header .title-wrapper .elemento-decorativo, .error404 .page-header .title-wrapper .elemento-decorativo {
          margin: 0 auto; } }
    .search .page-header .title-wrapper h2, .search .page-header .title-wrapper h1, .error404 .page-header .title-wrapper h2, .error404 .page-header .title-wrapper h1 {
      margin-bottom: 0 !important;
      color: #fff; }
      @media (max-width: 768px) {
        .search .page-header .title-wrapper h2, .search .page-header .title-wrapper h1, .error404 .page-header .title-wrapper h2, .error404 .page-header .title-wrapper h1 {
          text-align: center; } }
      .search .page-header .title-wrapper h2 span, .search .page-header .title-wrapper h1 span, .error404 .page-header .title-wrapper h2 span, .error404 .page-header .title-wrapper h1 span {
        font-style: italic; }

.search-no-results .page-content, .error404 .page-content {
  margin-top: 50px; }

.search-results .risultati {
  margin: 50px 0;
  display: flex;
  flex-wrap: wrap;
  gap: 45px; }
  .search-results .risultati .risultato {
    width: calc(33.333% - 30px); }
    @media (max-width: 992px) {
      .search-results .risultati .risultato {
        width: calc(50% - 30px); } }
    @media (max-width: 768px) {
      .search-results .risultati .risultato {
        width: 100%; } }
    .search-results .risultati .risultato .post-thumbnail img {
      aspect-ratio: 1;
      object-fit: cover; }
    .search-results .risultati .risultato .entry-title {
      margin: 15px 0; }
    .search-results .risultati .risultato .entry-summary {
      margin: 0 0 15px 0;
      font-size: 15px;
      line-height: 25px; }
    .search-results .risultati .risultato .meta {
      position: relative; }
      .search-results .risultati .risultato .meta img {
        border-top-left-radius: 8px;
        border-top-right-radius: 8px;
        border-bottom-left-radius: 0;
        border-bottom-right-radius: 0; }
      .search-results .risultati .risultato .meta .tipo-post {
        text-transform: uppercase;
        background-color: #204660;
        border-radius: 8px;
        width: max-content;
        padding: 2px 5px;
        color: #fff;
        font-weight: 600;
        right: 8px;
        top: 8px;
        font-size: 13px;
        line-height: 20px;
        position: absolute;
        z-index: 60; }
  .search-results .risultati article {
    background-color: #f0f0f0;
    border: 1px solid #eee;
    border-radius: 8px; }
    .search-results .risultati article .desc {
      padding: 0 15px 15px 15px;
      border-bottom-left-radius: 8px;
      border-bottom-right-radius: 8px; }
      .search-results .risultati article .desc a {
        text-decoration: none;
        margin-bottom: 15px;
        color: #333; }
        .search-results .risultati article .desc a:hover {
          color: #204660; }
        .search-results .risultati article .desc a:visited {
          color: #204660; }

/* Ivory search */
.astm-search-menu .is-search-icon {
  background-color: #204660; }
.astm-search-menu .is-form-style .is-search-submit path {
  fill: #ffffff; }

.is-menu a {
  border-left: 1px solid #ddd;
  padding-left: 15px; }
  @media (max-width: 992px) {
    .is-menu a {
      padding: 15px 0 0 0;
      border-left: none; } }
@media (max-width: 992px) {
  .is-menu.is-dropdown form {
    right: auto !important;
    left: auto !important;
    margin-top: 15px; } }
@media (max-width: 992px) {
  .is-menu.is-dropdown .search-close {
    top: calc(100% + 22px); } }
.is-menu .search-icon-path {
  fill: #333; }

/* MAPPE */
.mappa .vc_column-inner {
  padding: 0 !important; }

/* FORM */
.form .wpcf7-list-item {
  margin: 5px 0 10px 0; }
.form .privacy {
  font-size: 14px; }

.btn {
  color: #fff !important;
  background-color: #204660;
  text-transform: uppercase;
  font-weight: 600;
  -webkit-transition: all 0.3s 0s linear;
  -moz-transition: all 0.3s 0s linear;
  -o-transition: all 0.3s 0s linear;
  transition: all 0.3s 0s linear;
  padding: 7.5px 20px;
  /*margin-top:15px;*/
  display: inline-block;
  cursor: pointer;
  text-align: center;
  font-size: 14px;
  line-height: 24px;
  position: relative;
  border: 1px solid #204660;
  border-radius: 10px;
  z-index: 30;
  text-decoration: none; }
  .btn:hover {
    -webkit-transition: all 0.3s 0s linear;
    -moz-transition: all 0.3s 0s linear;
    -o-transition: all 0.3s 0s linear;
    transition: all 0.3s 0s linear;
    background-color: #fff;
    border: 1px solid #204660;
    color: #204660 !important; }
  .btn--white {
    color: #204660 !important;
    background-color: #fff;
    border: 1px solid #fff; }
    .btn--white:hover {
      background-color: #204660;
      color: #fff !important;
      border: 1px solid #fff; }
  .btn--arancione {
    color: #fff !important;
    background-color: #F36A55;
    border: 1px solid #F36A55; }
    .btn--arancione:hover {
      background-color: #fff;
      color: #F36A55 !important; }

/* CONTATTI */
.visible-sm {
  display: none; }
  @media (max-width: 768px) {
    .visible-sm {
      display: block; } }

.visible-md {
  display: block; }
  @media (max-width: 768px) {
    .visible-md {
      display: none; } }

/* FOOTER */
#colophon {
  min-height: 70px;
  display: flex;
  justify-content: center;
  flex-direction: column;
  font-size: 14px;
  color: #fff;
  background-color: #204660; }
  #colophon .pre-widget {
    margin: 25px 0 0 0; }
    #colophon .pre-widget .logo {
      display: flex;
      align-items: center; }
      #colophon .pre-widget .logo img {
        width: 250px; }
        @media (max-width: 768px) {
          #colophon .pre-widget .logo img {
            width: 250px; } }
        @media (max-width: 480px) {
          #colophon .pre-widget .logo img {
            margin-bottom: 15px; } }
      #colophon .pre-widget .logo .desc {
        display: flex;
        flex-direction: column;
        margin-left: 15px; }
        @media (max-width: 480px) {
          #colophon .pre-widget .logo .desc {
            margin-left: 0; } }
        #colophon .pre-widget .logo .desc span {
          font-family: "Crimson Text", serif;
          font-size: 20px;
          line-height: 35px;
          text-transform: uppercase; }
  #colophon .site-wrapper {
    /*padding:0;*/ }
  #colophon #footer-widget {
    width: 100%;
    min-height: 100px;
    padding: 25px 0 50px 0; }
    #colophon #footer-widget .site-wrapper {
      padding: 0 10px; }
    #colophon #footer-widget .footer-widget__col {
      width: 33.3333%;
      float: left;
      padding: 0 15px; }
      #colophon #footer-widget .footer-widget__col a {
        color: #fff;
        font-weight: 400;
        text-decoration: none; }
      #colophon #footer-widget .footer-widget__col li {
        margin-bottom: 0;
        font-size: 14px;
        line-height: 24px; }
      #colophon #footer-widget .footer-widget__col .widget-title {
        letter-spacing: 0;
        font-weight: 600 !important;
        font-size: 20px;
        line-height: 30px;
        font-family: "Crimson Text", serif;
        margin: 25px 0 12px 0 !important;
        color: #fff; }
      #colophon #footer-widget .footer-widget__col .social {
        width: 35px;
        margin-top: 15px; }
      #colophon #footer-widget .footer-widget__col .logo-footer {
        margin: 25px 0 35px 0;
        width: 100%;
        max-width: 250px; }
        @media (max-width: 768px) {
          #colophon #footer-widget .footer-widget__col .logo-footer {
            max-width: 300px; } }
      @media (max-width: 768px) {
        #colophon #footer-widget .footer-widget__col {
          width: 100%;
          float: none; } }

/* SUB FOOTER */
.subfooter {
  min-height: 70px;
  display: flex;
  align-items: center;
  background-color: #737665;
  color: #fff;
  font-size: 13px;
  line-height: 28px;
  position: relative;
  z-index: 30;
  padding: 15px 0; }
  .subfooter a {
    color: #fff !important; }
  @media (max-width: 768px) {
    .subfooter {
      text-align: center;
      padding: 10px 0; } }
  .subfooter__desc {
    float: left; }
    @media (max-width: 768px) {
      .subfooter__desc {
        float: none; } }
    .subfooter__desc p {
      margin: 0; }
  .subfooter__credits {
    float: right; }
    .subfooter__credits img {
      height: 25px;
      margin-left: 15px; }
    @media (max-width: 768px) {
      .subfooter__credits {
        float: none; } }

/* MISC */
.clearfix:after {
  content: "";
  display: table;
  clear: both; }

.grecaptcha-badge {
  width: 70px !important;
  overflow: hidden !important;
  transition: all 0.3s ease !important;
  left: 4px !important;
  display: none !important; }

.grecaptcha-badge:hover {
  width: 256px !important; }

.d-flex-center {
  display: flex;
  align-items: center; }

.text-white h1, .text-white h2, .text-white h3, .text-white h4, .text-white h5, .text-white h6, .text-white p, .text-white span, .text-white li {
  color: #fff !important; }

#back-to-top {
  width: 40px;
  height: 40px;
  background-color: #F36A55;
  position: fixed;
  bottom: 25px;
  right: 25px;
  border-radius: 5px;
  display: flex;
  opacity: 0;
  visibility: hidden;
  -webkit-transition: all 0.3s 0s linear;
  -moz-transition: all 0.3s 0s linear;
  -o-transition: all 0.3s 0s linear;
  transition: all 0.3s 0s linear;
  align-items: center;
  justify-content: center;
  color: #333;
  border: 1px solid #none;
  z-index: 70;
  box-shadow: 0px 5px 5px 0px rgba(0, 0, 0, 0.1);
  -webkit-box-shadow: 0px 5px 5px 0px rgba(0, 0, 0, 0.1);
  -moz-box-shadow: 0px 5px 5px 0px rgba(0, 0, 0, 0.1);
  text-decoration: none; }
  #back-to-top span {
    font-size: 20px;
    font-weight: bold; }
  #back-to-top.attivo {
    opacity: 1;
    visibility: visible;
    -webkit-transition: all 0.3s 0s linear;
    -moz-transition: all 0.3s 0s linear;
    -o-transition: all 0.3s 0s linear;
    transition: all 0.3s 0s linear; }
  @media (max-width: 480px) {
    #back-to-top {
      width: 35px;
      height: 35px;
      bottom: 15px;
      right: 15px; }
      #back-to-top span {
        font-size: 20px; } }

/* 404*/
.error-404 {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  /*min-height:calc(100vh - 170px);*/
  text-align: center; }

.d-none {
  display: none !important; }

.iub__us-widget {
  display: none !important; }

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