/*
*
* BY ing. Domenico Cosentino d.cosentino@4sigma.it
* dott.ssa Valeria La Mantia v.lamantia@4sigma.it
* ing. Nicolò Chiellini n.chiellini@4sigma.it
*
*/

:root {
  --scrollbar-width: 0px;
  --vh: 1vh;
  --bianco: #ffffff;
  --nero: #000000;
  --grigio-chiaro: #f2f2f2;
  --arancio: #ec8652;
  --blu: #054480;
  --azzurro: #8faec7;
  --azzurro-20: #8faec720;
  --grigio-placeholder: #a8a8a8;
  --grigio-titolo: #bfbfbf;
  --rosso: red;
  --whatsapp: #20b038;
  --stripe: #635bff;
  --input-size: 50px;
}
.ibm-mono {
  font-family: 'IBM Plex Mono';
}
.ibm-sans {
  font-family: 'IBM Plex Sans';
}
html {
  width: 100%;
  min-height: 100%;
  margin: 0px;
  float: left;
  padding: 0px;
  font-family: 'IBM Plex Sans';
  background-color: var(--grigio-chiaro);
  overflow-x: hidden;
/*   scroll-behavior: smooth; */
}
body {
  border: none;
  padding: 0px;
  margin: 0px;
  width: 100%;
  min-height: calc(100vh - 40px);
  float: left;
  -webkit-text-size-adjust: 100%;
  font-weight: 400;
  position: relative;
  color: var(--nero);
  overflow-x: hidden;
  position: relative;
  font-size: 13px;
  line-height: 18px;
}

td {
  border: none;
  text-align: left;
  margin: 0px;
  padding: 0px;
}
div,
p,
h1,
h2,
h3,
h4,
h5,
h6,
ul,
footer,
header,
nav,
article,
main,
aside,
section,
form,
fieldset,
marquee,
figure,
figcation {
  float: left;
  margin: 0px;
  padding: 0px;
  width: 100%;
  text-align: left;
  text-decoration: none;
  -webkit-text-size-adjust: 100%;
}
img {
  text-decoration: none;
  border: none;
  vertical-align: middle;
}
svg {
  border: none;
  border-image-width: 0;
  stroke-width: 0px;
}
iframe {
  margin: 0px;
  padding: 0px;
  border: none;
}
video[poster] {
  height: 100%;
  width: 100%;
  object-fit: cover;
}
video {
  max-width: 100%;
}
table,
td,
tr {
  margin: 0px;
  padding: 0px;
  border: none;
}
table {
  float: left;
}
label {
  cursor: pointer;
}
a, .btn-action {
  outline: none;
  text-decoration: none;
  cursor: pointer;
  /* TODO Colore Stile Link */
  color: var(--blu);
  font-weight: bold;
  transition: color 0.2s;
  -webkit-transition: color 0.2s;
}
button {
  color: var(--nerino);
}
li {
  outline: none;
}

i,
em,
.italic {
  font-style: italic;
  font-weight: inherit;
}
i strong,
em strong {
  font-style: italic;
}
.underline {
  text-decoration: underline;
}
*:-placeholder {
  color: var(--grigio-placeholder);
}
button::-moz-focus-inner {
  border: 0;
}
a:focus {
  outline: none;
}
input:focus:-webkit-input-placeholder {
  color: transparent;
}
input:focus:-moz-placeholder {
  color: transparent;
}
input:focus:-ms-input-placeholder {
  color: transparent;
}

input,
textarea,
select,
button {
  outline: none;
  border: none;
  padding: 0px;
  -webkit-border-radius: 0px;
  font-family: 'IBM Plex Sans';
}
textarea {
    resize: none;
}
select {
  -webkit-appearance: none;
  background-image: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAsAAAAWCAYAAAAW5GZjAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAA3BpVFh0WE1MOmNvbS5hZG9iZS54bXAAAAAAADw/eHBhY2tldCBiZWdpbj0i77u/IiBpZD0iVzVNME1wQ2VoaUh6cmVTek5UY3prYzlkIj8+IDx4OnhtcG1ldGEgeG1sbnM6eD0iYWRvYmU6bnM6bWV0YS8iIHg6eG1wdGs9IkFkb2JlIFhNUCBDb3JlIDYuMC1jMDAyIDc5LjE2NDQ2MCwgMjAyMC8wNS8xMi0xNjowNDoxNyAgICAgICAgIj4gPHJkZjpSREYgeG1sbnM6cmRmPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIj4gPHJkZjpEZXNjcmlwdGlvbiByZGY6YWJvdXQ9IiIgeG1sbnM6eG1wTU09Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9tbS8iIHhtbG5zOnN0UmVmPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAvc1R5cGUvUmVzb3VyY2VSZWYjIiB4bWxuczp4bXA9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC8iIHhtcE1NOk9yaWdpbmFsRG9jdW1lbnRJRD0ieG1wLmRpZDozYWZiZjdlZi01YWI5LTQxOTgtYWM4NS03NjY3MTY0OTY4MzUiIHhtcE1NOkRvY3VtZW50SUQ9InhtcC5kaWQ6QUFGNzc5RkEzNjI0MTFFQkEyMjdCNDFBRUE1NjNBNkUiIHhtcE1NOkluc3RhbmNlSUQ9InhtcC5paWQ6QUFGNzc5RjkzNjI0MTFFQkEyMjdCNDFBRUE1NjNBNkUiIHhtcDpDcmVhdG9yVG9vbD0iQWRvYmUgUGhvdG9zaG9wIENDIDIwMTggKE1hY2ludG9zaCkiPiA8eG1wTU06RGVyaXZlZEZyb20gc3RSZWY6aW5zdGFuY2VJRD0ieG1wLmlpZDpGRUM3M0JFODJEOTYxMUVCQThENkYzNzEzNEFCMjA0NCIgc3RSZWY6ZG9jdW1lbnRJRD0ieG1wLmRpZDpGRUM3M0JFOTJEOTYxMUVCQThENkYzNzEzNEFCMjA0NCIvPiA8L3JkZjpEZXNjcmlwdGlvbj4gPC9yZGY6UkRGPiA8L3g6eG1wbWV0YT4gPD94cGFja2V0IGVuZD0iciI/PivKHYoAAACeSURBVHjaYvz//z8DsYCJgQQwSBSzgAhGLU9ksQwgngDEBUA8Ayb4/9p2iGIkkAnE06Ds6SBzoDSGM5AVwsA0qDiKYmwKMTTAFHcT8Fs33INAoAnEwngUv0VW/BiKCQcdEMgSYfJjmOLrQMyNR/FXIOaBebCUgAtKkUMDFPBZOBRmwSIGOVKwacjCFYMwDaAI+AmlpyNLMg7BnAIQYADcuSEq6NODFQAAAABJRU5ErkJggg==);
  background-position: calc(100% - 15px) 50%;
  background-repeat: no-repeat;
  background-size: 11px 22px;



  background-image: url(data:image/png;base64,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);
  background-position: calc(100% - 15px) 50%;
  background-repeat: no-repeat;
  background-size: auto 12px;
}
input[type="number"]::-webkit-inner-spin-button,
input[type="number"]::-webkit-outer-spin-button {
  -webkit-appearance: none;
  margin: 0;
}
input[type="number"] {
  -moz-appearance: textfield;
}
input[type="date"]::-webkit-inner-spin-button,
input[type="date"]::-webkit-outer-spin-button {
  -webkit-appearance: none;
  margin: 0;
}
input[type="date"] {
  -moz-appearance: textfield;
}
button {
  cursor: pointer;
  -webkit-appearance: none;
  background-color: transparent;
  font-family: 'IBM Plex Sans';
}
input[type="checkbox"] {
  -webkit-appearance: checkbox;
  -webkit-border-radius: auto;
  vertical-align: middle;
}
input[type="radio"] {
  /*    -webkit-appearance: checkbox;
    -webkit-border-radius: auto;*/
  vertical-align: middle;
}
input[type="submit"] {
  -webkit-border-radius: 0px;
  -webkit-appearance: none;
}
.hidden {
  display: none;
}
.over_hidden {
  overflow: hidden;
}
.block {
  display: block;
}
.flex {
  display: flex;
}
.flex-center {
  display: flex;
  align-items: center;
  justify-content: center;
}
.justify-center {
  justify-content: center;
}
.justify-left {
  justify-content: flex-start;
}
.mobile {
  display: none;
}
.opacity_0 {
  opacity: 0;
}
.opacity_1 {
  opacity: 1;
}
.inline-block {
  display: inline-block;
}
.inline-desktop {
  display: inline;
}
.relative {
  position: relative;
}
.absolute {
  position: absolute;
}
.pointer {
  cursor: pointer;
}
.wait {
  cursor: wait;
}
.left {
  float: left;
}
.right {
  float: right;
}
.none {
  float: none;
}
.clear {
  clear: both;
}
.v_top {
  vertical-align: top;
}
.text_top {
  vertical-align: text-top;
}
.v_middle {
  vertical-align: middle;
}
.v_bottom {
  vertical-align: bottom;
}
.m_auto {
  margin: 0px auto;
}
.w_auto {
  width: auto;
}
.max_w100pe {
  max-width: 100%;
}
.max_w80pe {
  max-width: 80%;
}
.max_w75pe {
  max-width: 75%;
}
.max_w70pe {
  max-width: 70%;
}
.max_w50pe {
  max-width: 50%;
}
.w_33pe {
  width: 33.333333%;
}
.maxw_100pe {
  max-width: 100%;
}
.text-center {
  text-align: center;
}
.text-left {
  text-align: left;
}
.text-right {
  text-align: right;
}
.text-justify {
  text-align: justify;
}
.text-truncate {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.extralight {
  font-weight: 200;
}
.light {
  font-weight: 300;
}
.normal {
  font-weight: 400;
}
.style-normal {
  font-style: normal;
}
.strike {
  text-decoration: line-through;
}
.medium {
  font-weight: 500;
}
.semibold {
  font-weight: 600;
}
.bold,
strong,
b {
  font-weight: 700;
}
.extrabold {
  font-weight: 900;
}
.red {
  color: red;
}
.green {
  color: green;
}
.black,
.nero {
  color: var(--nero);
}
.white,
.bianco {
  color: var(--bianco);
}

.grigio-titolo {
  color: var(--grigio-titolo);
}
.grigio-chiaro {
  color: var(--grigio-chiaro);
}
.grigio-placeholder {
  color: var(--grigio-placeholder);
}
.blu {
  color: var(--blu);
}
.azzurro {
  color: var(--azzurro);
}
.arancio {
    color: var(--arancio);
}
.bt-grigio {
    border-top: 1px solid var(--grigio-titolo);
}
.bb-grigio {
    border-bottom: 1px solid var(--grigio-titolo);
}
.cover {
  background-size: 100% 100%;
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
}
.cover-picture img {
  object-fit: cover;
  width: 100%;
  height: auto;
}
.cover-picture-full img {
  object-fit: cover;
  width: 100%;
  height: 100%;
}
.cover-picture-abs {
  position: absolute;
  top: 0px;
  left: 0px;
  width: 100%;
  height: 100%;
  border-radius: 10px;
}
.uppercase {
  text-transform: uppercase;
}
.lowercase {
  text-transform: lowercase;
}
.capitalize {
  text-transform: capitalize;
}
.two-column {
  -webkit-column-count: 2;
  -moz-column-count: 2;
  column-count: 2;
  -webkit-column-gap: 40px;
  -moz-column-gap: 40px;
  column-gap: 40px;
}

/*.ritch-cont {
  overflow: hidden;
}
.ritch-cont * {
}

.ritch-cont a {
  font-weight: bold;
}
.ritch-cont a[name] {
  color: #000000;
  font-weight: inherit;
}*/
.ritch-cont ul {
  width: 100%;
  box-sizing: border-box;
  list-style-type: disc;
  padding-left: 20px;
  display: block;
}
.ritch-cont ol {
  width: 100%;
  box-sizing: border-box;
  list-style-type: decimal;
  padding-left: 20px;
}
.ritch-cont li {
  float: left;
  width: 100%;
}
.ritch-cont img {
  max-width: 100% !important;
  height: auto !important;
}
.gen-text-flex {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.flex-reverse-row {
  flex-direction: row-reverse;
}

/* Honey POT anti SPAM */
.hnpt {
  position: absolute;
  top: 0px;
  left: 0px;
  width: 100%;
  background-color: transparent;
  height: 100%;
  z-index: 100;
}
#over-box {
  display: none;
  position: fixed;
  z-index: 9998;
  background-color: rgba(102, 102, 102, 0.6);
  width: 100%;
  height: 100%;
  top: 0px;
  left: 0px;
}
#over-box.show {
  display: block;
}
.noscroll {
  position: fixed;
  /*    overflow-y: scroll;*/
}
.modal-box {
  display: none;
  position: fixed;
  background-color: var(--bianco);
  color: var(--nerino);
  text-align: center;
  z-index: 9999;
  top: -500px;
  opacity: 1;
  width: 680px;
  min-height: 355px;
  left: 50%;
  margin-left: -340px;
  border-radius: 10px;
  box-shadow: 0px 0px 25px 0px rgb(0 0 0 / 15%);
  max-height: 70vh;
}
#modal-int {
  padding: 50px 100px 50px 100px;
  box-sizing: border-box;
}
#modal-int a {
  font-size: 12px;
  line-height: 15px;
  font-weight: 600;
  text-decoration: underline;
}
input:autofill,
input:auto-fill,
input:-webkit-autofill,
input:-webkit-auto-fill {
  background-color: transparent !important;
  background-image: none !important;
}

.form-input:-webkit-autofill,
.form-input:-webkit-autofill:hover,
.form-input:-webkit-autofill:focus,
.form-input:autofill,
.form-input:autofill:hover,
.form-input:autofill:focus,
.form-input-textarea:-webkit-autofill,
.form-input-textarea:-webkit-autofill:hover,
.form-input-textarea:-webkit-autofill:focus,
.form-input-textarea:autofill,
.form-input-textarea:autofill:hover,
.form-input-textarea:autofill:focus {
  -webkit-box-shadow: 0 0 0px 40rem var(--bianco) inset;
  border: 0.5px solid var(--bianco);
  box-sizing: border-box;
}

.form-full-input-cont {
    width: 100%;
}
.form-full-btn-input-cont {
    width: calc(100% - 60px);
}
.form-half-input-cont {
  width: calc(50% - 5px);
}
.form-two-third-input-cont {
  width: calc((100% * 2 / 3) - 5px);
}
.form-third-input-cont {
  width: calc((100% / 3) - 5px);
}

.form-text-cont {
    padding: 15px 10px 0px 10px;
    position: absolute;
    box-sizing: border-box;
    display: flex;
    align-items: center;
    right: 0px;
    top: 0px;
    height: 100%;
}
.form-half-input-cont:last-child {
  width: calc(50% - 5px);
  float: right;
}
.form-half-input-cont-special {
  width: calc(50% - 10px);
}
.form-half-input-cont-special:last-child {
  width: calc(50% - 10px);
  float: right;
}
.form-one-fourth-cont {
  width: calc(25% - 5px);
}
.form-three-fourth-cont {
  width: calc(75% - 5px);
}
.form-two-third-input-cont {
  width: calc((100% * 2 / 3) - 5px);
}
.form-third-input-cont {
  width: calc((100% / 3) - 5px);
}
.form-input,
.span-input {
  width: 100%;
  height: var(--input-size);
  line-height: var(--input-size);
  color: var(--nero);
  border-radius: 5px;
  padding: 0px 15px;
  box-sizing: border-box;
  background-color: var(--bianco);
}
.form-input-upload {
  width: 100%;
  height: var(--input-size);
  line-height: var(--input-size);
  color: var(--nero);
  border-radius: 5px;
  padding: 0px 15px;
  box-sizing: border-box;
  background-color: var(--grigio-titolo);
}
.span-input {
  display: inline-block;
  cursor: default;
  background-color: var(--white);
  border: 0.5px solid var(--grigino);
  color: #000;
  font-weight: bold;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.span-textarea {
  display: inline-block;
  cursor: default;
  background-color: var(--white);
  border: 0.5px solid var(--grigino);
  color: #000;
  font-weight: bold;
  width: 100%;
  min-height: 60px;
  border-radius: 5px;
  padding: 18px 15px 12px 15px;
  box-sizing: border-box;
  font-size: 15px;
  line-height: 20px;
}
.form-input:focus,
.form-select:focus,
.form-input-textarea:focus {
  border: 0.5px solid var(--blu-scuro);
}
.form-select {
  width: 100%;
  height: var(--input-size);
  line-height: var(--input-size);
  color: var(--nero);
  border-radius: 5px;
  padding: 0px 15px;
  box-sizing: border-box;
  background-color: var(--bianco);
}
.form-input-textarea {
  width: 100%;
  min-height: var(--input-size);
  color: var(--nero);
  border-radius: 5px;
  padding: 15px;
  box-sizing: border-box;
  background-color: var(--bianco);
}
.form-error .form-input,
.form-error .form-input-textarea {
  border: 0.5px solid red;
}
.form-error-text .text-checkbox {
    border-bottom: 0.5px solid red;
}
.form-error-span {
  display: inline-block;
  float: left;
  margin-top: 5px;
  font-size: 12px;
  line-height: 15px;
  font-weight: bold;
  color: red;
  box-sizing: border-box;
  padding: 0px 15px;
}
.form-input:focus,
.form-input-textarea:focus {
}
.ico-input-cal {
  position: absolute;
  top: calc(50% - 6px);
  right: 10px;
}
.label-input {
  font-weight: 900;
  color: var(--blu-scuro);
  text-transform: uppercase;
  padding: 0px 15px;
  box-sizing: border-box;
}
.label-checkbox {
    position: relative;
    padding-left: 20px;
    box-sizing: border-box;
}
.label-checkbox input {
    position: absolute;
    left: 0px;
    top: 2px;
}
.label-password input {
    padding-right: 70px;
}

.form-error .label-checkbox {
    padding: 5px 5px 5px 25px;
    border: 0.5px solid red;
    border-radius: 5px;
}
.form-error .label-checkbox input {
    position: absolute;
    left: 5px;
    top: 7px;
}
.btn {
    width: 100%;
    height: var(--input-size);
    line-height: var(--input-size);
    border-radius: 5px;
    font-weight: 500;
    font-family: 'IBM Plex Mono';
    text-align: center;
    overflow: hidden;
    position: relative;
}
.btn-loader {
    position: absolute;
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    background-color: green;
    top: 0px;
    left: 0px;
}
.btn-square {
    width: var(--input-size);
    height: var(--input-size);
    line-height: var(--input-size);
    border-radius: 5px;
    font-weight: 500;
    font-family: 'IBM Plex Mono';
    text-align: center;
}
.btn-blu {
    color: var(--bianco);
    background-color: var(--blu);
}
.btn-arancio {
    color: var(--bianco);
    background-color: var(--arancio);
}
.btn-azzurro {
    color: var(--bianco);
    background-color: var(--azzurro);
}
.btn-rosso {
    color: var(--rosso);
    background-color: var(--bianco);
}
.btn-disabled {
    color: var(--bianco);
    background-color: var(--grigio-placeholder);
}
.btn-whatsapp {
    background-color: var(--whatsapp);
}
.btn-whatsapp img {
    height: 20px;
}
.btn-stripe {
    background-color: var(--stripe);
}
.btn-stripe img {
    height: 20px;
}
#btn-aggiungi-fattura {
    display: block;
    float: left;
    width: calc(100% - 40px);
    position: fixed;
    left: 20px;
    bottom: 10px;
}

#btn-show-password,
#btn-show-ripeti-password,
.btn-show-password {
  position: absolute;
  color: var(--grigio);
}

/* MAIN */
header {
    height: 80px; /* TODO */
}
main {
    min-height: calc(100vh - 130px);
}
footer {
    padding: 10px 10px;
    text-align: center;
    font-size: 11px;
    line-height: 15px;
    box-sizing: border-box;
}
#fake-footer {
  text-align: center;
  font-size: 11px;
  line-height: 15px;
  box-sizing: border-box;
}
footer a {
    color: var(--blu);
    font-weight: bold;
}
.page,
.page-small {
    float: none;
    margin-left: auto;
    margin-right: auto;
    padding: 20px 20px;
    box-sizing: border-box;
}
.page {
    max-width: 1024px;
}
.page-small {
    max-width: 768px;
}
.label-login {
    display: block;
    float: left;
    width: 100%;
    position: relative;
}
.label-login.hidden {
    display: none;
}
.label-login .form-input {
    padding-left: var(--input-size);
}
.label-login #id_password {
    padding-right: var(--input-size);
}
.label-login .label-login-icon {
    position: absolute;
    left: 0px;
    top: 0px;
    width: var(--input-size);
    height: var(--input-size);
    display: block;
    float: left;
    text-align: center;
    line-height: var(--input-size);
    color: var(--blu);
}
.label-fake-checkbox-cont {
    position: relative;
    padding-left: 30px;
    box-sizing: border-box;
/*    font-size: 12px;
    line-height: 16px;*/
}
.label-fake-checkbox-cont input {
    position: absolute;
    left: 10px;
    top: 10px;
    visibility: hidden;
}
input:checked + .fake-checkbox-int {
    display: block;
}
.label-fake-checkbox {
    display: block;
    float: left;
    width: 20px;
    height: 20px;
    border-radius: 5px;
    background-color: var(--bianco);
    position: absolute;
    z-index: 10;
    box-sizing: border-box;
    left: 0px;
    top: 0px;
}
.fake-checkbox-int {
    position: absolute;
    display: none;
    float: left;
    width: 20px;
    height: 20px;
    font-size: 15px;
    line-height: 20px;
    text-align: center;
    top: 0px;
    left: 0px;

}

#btn-toggle-login-reset {
    display: block;
    float: left;
    width: 100%;
    text-align: center;
}
#btn-submit-login-reset {
    display: block;
    float: left;
    margin-top: 30px;
}
.btn-eye-password {
    position: absolute;
    width: var(--input-size);
    height: var(--input-size);
    display: block;
    float: left;
    line-height: var(--input-size);
    text-align: center;
    top: 0px;
    right: 0px;
}
.titolo-riga-bg {
    position: relative;
    text-align: center;
}
.titolo-riga-bg svg {
    position: absolute;
    top: 50%;
    left: 0px;
}
.titolo-riga-bg .text-int {
    position: relative;
    display: inline-block;
    padding: 0px 10px;
    z-index: 2;
    background-color: var(--grigio-chiaro);
}
#id_codice_fiscale,
#id_nascita_data {
    padding-right: 50px;
}
.input-right-ico {
    position: absolute;
    display: block;
    float: left;
    width: var(--input-size);
    height: var(--input-size);
    line-height: var(--input-size);
    text-align: center;
    top: 0px;
    right: 0px;
}
#dashboard-btn-cont {
    margin: 15px 0px;
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}
.dashboard-btn {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-end;
    gap: 20px;
    width: calc((100% - 20px) / 2);
    background-color: var(--bianco);
    border-radius : 5px;
    padding: 15px;
    box-sizing: border-box;
}
.dashboard-btn-icon {
    font-size: 60px;
    color: var(--blu);
}
.dashboard-btn-txt {
  font-size: 12px;
  line-height: 15px;
  color: var(--nero);
  font-weight: 500;
  font-family: 'IBM Plex Mono';
}
.news-item {
    border-bottom: 0.5px solid var(--grigio-titolo);
    padding: 20px 0px;
    box-sizing: border-box;
}
.news-item-title {
    font-size: 12px;
    line-height: 16px;
    font-weight: bold;
    margin-bottom: 20px;
}
.news-item-btn {
    font-size: 12px;
    line-height: 15px;
    color: var(--blu);
    font-weight: 500;
    font-family: 'IBM Plex Mono';
}
#menu {
    width: 100%;
    height: calc(100vh - 50.5px);
    background-color: var(--bianco);
    position: absolute;
    z-index: 1;
    top: -100vh;
    left: 0px;
    transition: top 0.5s;
    -webkit-transition: top 0.5s;
}
#menu.open {
    top: 50.5px;
    transition: top 0.5s;
    -webkit-transition: top 0.5s;
}
#menu .page-small {
    height: 100%;
}
#menu-int {
    height: 100%;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}
#menu .titolo-riga-bg .text-int {
    background-color: var(--bianco);
}
#menu .btn-whatsapp {
    margin: 20px 0px 40px 0px;
}
.menu-item {
    padding: 15px 0px;
    box-sizing: border-box;
    border-bottom: 0.5px solid var(--grigio-titolo);
}
.menu-item a {
    font-size: 16px;
    line-height: 20px;
    color: var(--blu);
    font-weight: 500;
    font-family: 'IBM Plex Mono';
}
.menu-item a.sel {
    font-weight: 700;
}
.menu-item-icon {
    display: block;
    float: left;
    width: 21px;
    margin-right: 5px;
}
.fatture-item,
.documenti-item {
    font-size: 12px;
    line-height: 16px;
    border-bottom: 0.5px solid var(--grigio-titolo);
    padding: 10px 0px;
    box-sizing: border-box;
}
.documenti-item-controls {
    padding-right: 100px;
    box-sizing: border-box;
    margin-top: 5px;
}
.documenti-item-obj {
    display: block;
    float: left;
    width: 100%;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    font-weight: bold;
    color: var(--blu);
}
.documenti-item-delete {
    display: block;
    float: left;
    width: 100px;
    position: absolute;
    top: 5px;
    right: 0px;
    text-align: right;
    color: red;
}
.simulazione-item-cont {
    width: 100%;
    height: 40px;
    line-height: 40px;
    border-radius: 5px;
    font-size: 12px;
    font-weight: 700;
    padding: 0px 20px;
    box-sizing: border-box;
    margin-bottom: 10px;
}
.simulazione-azzurro {
    background-color: var(--azzurro-20);
}
.simulazione-blu {
    background-color: var(--blu);
}
.dati-block-cont {
    border-bottom: 0.5px solid var(--grigio-titolo);
    padding: 10px 0px;
    box-sizing: border-box;
}
.form-output-msg {
    line-height: 20px;
    padding: 10px 10px;
    box-sizing: border-box;
    text-align: center;
    margin-bottom: 20px;
    border-radius: 5px;
    font-weight: bold;
}
.form-output-success {
    background-color: #00723c;
    color: white;
}

/* Qui vanno gli eventi di Hover. Non metterli da altre parti!!!!! */
@media only screen and (min-width: 1201px) and (max-width: 10000px) {
    a:hover, .btn-action:hover {
    }
}

/* Tablet Landscape */
@media only screen and (min-width: 1024px) and (max-width: 1279px) {
}

/* Tablet Portrait */
@media only screen and (min-width: 768px) and (max-width: 1023px) {

}

/* Cellulari */
@media only screen and (min-width: 220px) and (max-width: 767px) {
    .data-label .input-right-ico {
        display: none;
    }
}
