* {
  box-sizing: border-box;
  transition: opacity 0.3s ease-out;
}

*:focus {
  outline: none;
}

html,
body {
  scroll-behavior: smooth;
}

/* 
  font-family: "SoleSans", Arial, Helvetica, sans-serif;
  font-family: "sole_text", Georgia, Times, "Times New Roman", serif;
  font-family: "sole_headline", Georgia, Times, "Times New Roman", Serif;
  font-family: "sole_display", Georgia, Times, "Times New Roman", serif;
*/

body {
  font-family: "sole_text", Georgia, Times, "Times New Roman", serif;
  background-color: #f2f2f2;
  padding: 0;
  margin: 0;
  color: #0f0f0f;
  overflow-x: hidden;
}

div {
  width: 100%;
}

/* TOP BAR */

#header-fisso {
  z-index: 99999 !important;
}

.top-bar {
  height: 50px !important;
}

.faN {
  width: 30px !important;
  height: 30px !important;
}

/* SECTIONS */

section {
  width: 100%;
  display: flex;
  display: -webkit-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  flex-direction: column;
  -webkit-box-pack: flex-start;
  -ms-flex-pack: flex-start;
  -webkit-justify-content: flex-start;
  justify-content: flex-start;
  -webkit-box-align: center;
  -ms-flex-align: center;
  -webkit-align-items: center;
  align-items: center;
  text-align: center;
}

section:first-of-type {
  margin-top: 50px;
}

p {
  width: 100%;
  max-width: 786px;
  font-family: "sole_text", Georgia, Times, "Times New Roman", serif;
  font-size: 20px;
  font-style: normal;
  font-weight: 400;
  line-height: 34px;
  color: #0f0f0f;
  text-align: left;
}

p a:link {
  color: #0f0f0f !important;
  text-decoration: underline;
}

p a:visited {
  color: #0f0f0f !important;
  ;
  text-decoration: underline;
}

p a:hover {
  color: #6e6e6e !important;
  ;
  text-decoration: underline;
}

p a:active {
  color: #6e6e6e !important;
  text-decoration: underline;
}

.aggiornamento {
  margin: auto;
}

.aggiornamento span {
  position: relative;
  color: #0f0f0f7a;
  font-family: "SoleSans", Arial, Helvetica, sans-serif;
  font-size: 18px;
  font-style: normal;
  font-weight: 400;
  line-height: normal;
  text-align: center;
}

.aggiornamento span::before {
  content: "";
  position: absolute;
  top: 4px;
  left: -21px;
  width: 15px;
  height: 15px;
  background-image: url(../img/star_red.svg);
}

h2 {
  width: 100%;
  max-width: 786px;
  margin: auto;
  text-align: center;
  font-family: "sole_display", Georgia, Times, "Times New Roman", serif;
  color: #0f0f0f;
  font-size: 56px;
  font-style: normal;
  font-weight: 800;
  line-height: normal;
  margin-block-start: 0.63em;
  margin-block-end: 0.63em;
}

/* .intro {
  color: #0f0f0f;
  font-family: "SoleSans", Arial, Helvetica, sans-serif;
  font-size: 18px;
  font-style: normal;
  font-weight: 400;
  line-height: 25px;
  padding-bottom: 50px;
  text-align: left;
  max-width: 786px;
  margin: auto;
} */

/* SCHERMATA DUE COLONNE CON MPU */

.two_columns {
  display: -webkit-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  flex-direction: row;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-box-align: flex-start;
  -ms-flex-align: flex-start;
  -webkit-align-items: flex-start;
  align-items: stretch;
  /* width: 980px; */
  overflow-x: hidden;
  padding: 0;
  margin: auto;
  position: relative;
  margin-top: 20px;
  margin-bottom: 20px;
  /* margin-left: 90px; */
  overflow: hidden;
}

.column_left {
  width: 480px;
  padding-left: 0;
  padding-right: 20px;
}

.column_left p {
  margin-block-start: 0;
  margin-block-end: 15px;
}

.column_right {
  padding-right: 0;
  max-width: 320px;
  background-color: #D2D2D2;
}

.text_ctn {
  max-width: 786px;
}

.chart_ctn {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}

h3 {
  max-width: 100%;
  font-size: 38px;
  margin-block-start: 0.4em;
  margin-block-end: 0.4em;
}

h4.chart_title {
  width: 100%;
  max-width: 786px;
  color: #0f0f0f;
  text-align: center;
  font-family: "SoleSans", Arial, Helvetica, sans-serif;
  font-size: 26px;
  font-style: normal;
  font-weight: 600;
  line-height: normal;
  margin: auto;
  margin-block-start: 0.33em;
  margin-block-end: 0.33em;
}

.chart_subtitle {
  color: #0f0f0f;
  text-align: center;
  font-family: "SoleSans", Arial, Helvetica, sans-serif;
  font-size: 18px;
  font-style: normal;
  font-weight: 400;
  line-height: 25px;
  padding-bottom: 20px;
  max-width: 786px;
  margin: auto;
}

.chart_second_title {
  width: 100%;
  max-width: 786px;
  color: #0f0f0f;
  text-align: center;
  font-family: "SoleSans", Arial, Helvetica, sans-serif;
  font-size: 24px;
  font-style: normal;
  font-weight: 600;
  line-height: normal;
  padding-bottom: 10px;
  margin: auto;
  margin-block-start: 0.33em;
  margin-block-end: 0.33em;
}

.chart_regular {
  max-width: 786px;
  margin: auto;
}

.chart_large {
  max-width: 992px;
  margin: auto;
}

.chart_full {
  max-width: 100%;
  margin: auto;
}

.chart_double {
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  max-width: 1607px;
  margin: auto;
}

.chart_double .chart_double_item {
  width: 45%;
}

.chart_source {
  color: #0F0F0F;
  font-family: "SoleSans", Arial, Helvetica, sans-serif;
  font-size: 16px;
  font-style: normal;
  font-weight: 400;
  line-height: normal;
  opacity: .5;
  max-width: 786px;
  text-align: left;
  margin: auto;
  padding-top: 15px;
}

.chart_btn_cnt {
  display: flex;
  flex-direction: row;
  justify-content: center;
  align-items: center;
  padding-bottom: 50px;
}

.chart_btn {
  font-family: "SoleSans", Arial, Helvetica, sans-serif;
  width: fit-content;
  background: #D9D9D9;
  border: 1px solid #D9D9D9;
  padding: 10px 20px;
  color: #0f0f0f;
  font-style: normal;
  font-weight: 400;
  font-size: 18px;
  line-height: normal;
  text-align: center;
  cursor: pointer;
  min-width: 190px;
}


.chart_btn_selected {
  background: #FFF;
  font-weight: 500;
}

.round {
  border-radius: 50%;
}

.bg_red {
  background-color: #e31d3c;
}

.bg_blue {
  background-color: #0061aa;
}

.bg_light_red {
  background-color: #EEB3BC;
}

.bg_light_blue {
  background-color: #b5cddf;
}

.bg_light_grey {
  background-color: #e5e5e5;
}

.bg_grey {
  background-color: #999;
}

.bg_neutral {
  background-color: #DBAC34;
}

.cw_event_date.bg_star {
  background-color: #DBAC34;
}

.text_red {
  color: #e31d3c;
}

.text_blue {
  color: #0061aa;
}

.text_grey {
  color: #999;
}

.text_white {
  color: #fff;
}

.text_neutral {
  color: #DBAC34;
}

.pointer {
  cursor: pointer;
}

.delimiter {
  text-align: center;
}

.mtb_50 {
  margin: 50px auto;
}

/*--- FOOTER ----*/

footer {
  z-index: 20;
}

#footer_div {
  font-family: "SoleSans", Arial, Helvetica, sans-serif;
  line-height: 1.3;
  background-color: #19171a;
  color: #a19e9e;
  font-size: 14px;
  text-transform: none;
  padding: 30px 100px;
  text-align: center;
}

.mobile {
  display: none;
}

/* RESPONSIVE  */

@media only screen and (max-width: 820px) {
  header {
    padding-left: 0;
    padding-right: 0;
  }

  .two_columns {
    max-width: 100%;
    flex-direction: column;
    padding: 0;
    margin: 0;
  }

  .column_left {
    width: 100%;
    max-width: 100%;
  }

  .column_right {
    max-width: 0;
    display: none;
  }

  .text_cnt {
    max-width: 100%;
  }
}

@media only screen and (max-width: 480px) {
  section {
    padding-left: 15px;
    padding-right: 15px;
  }

  p {
    max-width: 100%;
  }

  .intro {
    max-width: 100%;
  }

  .aggiornamento {
    font-size: 16px;
  }

  h2 {
    max-width: 100%;
    font-size: 32px;
    margin-block-start: 0.63em;
    margin-block-end: 0.63em;
  }


  h3 {
    font-size: 32px;
  }

  .text_cnt {
    max-width: 100%;
  }

  h4.chart_title {
    max-width: 100%;
  }

  .chart_subtitle {
    max-width: 100%;
  }

  .chart_second_title {
    max-width: 100%;
  }

  .chart_regular {
    max-width: 100%;
  }

  .chart_large {
    max-width: 100%;
  }

  .chart_double {
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    max-width: 100%;
  }

  .chart_source {
    max-width: 100%;
  }

  .chart_double .chart_double_item {
    width: 100%;
  }

  .chart_btn_cnt {
    flex-direction: column;
  }

  .chart_btn {
    min-width: 100%;
  }



  .riferimenti_bibliografici {
    width: 100%;
    padding: 0 15px;
  }

  #footer_div {
    padding: 30px 10px;
  }

  .mobile {
    display: initial;
  }

  .desktop {
    display: none;
  }
}

/* GESTIONE ADV */

body:not(.backgroundAdv) #adv-MaxTicker {
  margin-top: 50px;
}

#div-gpt-ad-MaxTicker>div {
  display: flex !important;
  align-items: center;
  justify-content: center;
}

.backgroundAdv {
  background-attachment: fixed;
}

#adv-MaxTicker {
  margin: auto;
  padding-top: 20px;
  padding-bottom: 20px;
  text-align: center;
  width: 100%;
  background-color: #ebebeb;
}

#mpu_top_cnt {
  width: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: #d2d2d2 !important;
}

#ad-Mpu_Top {
  display: flex;
  justify-content: center;
  width: 320px;
  padding: 10px 0;
}

#div-gpt-ad-MPU_Top>div {
  display: flex !important;
  justify-content: center;
}

#ad-Mpu_Middle {
  background-color: #f2f2f2;
  display: flex;
  justify-content: center;
  width: 320px;
  margin: 70px auto;
}

#div-gpt-ad-MPU_Middle>div {
  display: flex !important;
  justify-content: center;
}

.bordo_adv {
  padding: 10px 0;
  background-color: #f2f2f2;
}

#Mpu_Top {
  text-align: center;
  width: fit-content;
}

#Mpu_Middle {
  text-align: center;
  width: fit-content;
}

#ad-Mpu_Top div,
#ad-Mpu_Middle div,
#adv-MaxTicker div {
  width: inherit !important;
}

.container_over_skin {
  width: 100%;
  z-index: 5;
  background-color: #f2f2f2;
}

.container_over_skin>* {
  z-index: 5;
  background-color: #f2f2f2;
}

.shrinkable,
.backgroundAdv {
  background-color: #f2f2f2 !important;
}

.pubblicita {
  display: flex;
  justify-content: center;
}

@media only screen and (max-width: 820px) {
  body:not(.backgroundAdv) #adv-MaxTicker {
    margin-top: 50px;
  }

  #ad-Mpu_Middle {
    margin: 20px auto;
  }

  /*  .bordo_adv {
    margin-left: 25%;
  } */
}