/*
*
* 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;
    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;
    appearance: none;
    margin: 0;
}

input[type="number"] {
    appearance: textfield;
    -moz-appearance: textfield;
}

/*input[type="date"]::-webkit-inner-spin-button,
input[type="date"]::-webkit-outer-spin-button {
	-webkit-appearance: none;
	-moz-appearance: textfield;
	appearance: none;
	margin: 0;
}*/
button {
    cursor: pointer;
    appearance: none;
    -webkit-appearance: none;
    background-color: transparent;
    font-family: 'IBM Plex Sans';
}

input[type="checkbox"] {
    appearance: checkbox;
    -webkit-appearance: checkbox;
    -webkit-border-radius: auto;
    border-radius: auto;
    vertical-align: middle;
}

input[type="radio"] {
    /*    -webkit-appearance: checkbox;
    -webkit-border-radius: auto;*/
    vertical-align: middle;
}

input[type="submit"] {
    border-radius: 0px;
    -webkit-border-radius: 0px;
    appearance: none;
    -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;
}

.fatture-modal .form-input,
.fatture-modal .form-input-textarea,
.fatture-modal .form-select,
.fatture-modal .span-input,
.fatture-modal .span-textarea {
    background-color: var(--grigio-chiaro);
}

.rigafattura-label-importo {
    width: 110px;
    display: block;
    float: right;
}

.rigafattura-label-descrizione {
    width: calc(100% - 120px);
    display: block;
    float: left;
}

.rigafattura-label-importo .form-input {
    text-align: right;
    height: 64px;
    line-height: 34px;

}

.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,
.span-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,
.form-error {
    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;
}

.fatture-item-flex-row {
    display: flex;
}
.fatture-item-flex-row-left {
    width: calc(100% - 100px);
}
.fatture-item-flex-row-right {
    width: 100%;
    text-align: right;
}
.fatture-modal  {
    position: fixed;
    background-color: #fff;
    height: 100vh;
    padding: 50px 0px 70px 0px;
    box-sizing: border-box;
}
.fatture-modal-int {
    max-height: 100%;
    overflow: auto;
}
.fatture-modal-btn-cont {
    position: fixed;
    bottom: 0px;
    left: 0px;
}
.fatture-modal-btn-cont .page-small {
    padding-bottom: 10px;
}
.fattura-modal-btn-cont {
    position: fixed;
    bottom: 0px;
    left: 0px;
}
/* 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;
    }
}
