﻿
@import url('newportal.css');

.hidden {
    display: none !important;
}

.mobile-only {
    display: none !important;
}

.mobile-hidden {
    display: block;
}

@media screen and (max-width: 768px) {
    .mobile-only {
        display: block !important;
    }

    .mobile-hidden {
        display: none !important;
    }
}

/************* END RESPONSIVENESS ***************/


/***************** GRID LABELS *****************/

.subtitle, .descrizioneCompleta {
    font-weight: 600;
    color: var(--main-text-color);
    word-wrap: break-word;
    word-break: break-all;
    text-wrap: normal;
    overflow-wrap: normal;
}

.breakable {
    font-weight: 400;
    color: var(--main-text-color);
    word-wrap: break-word;
    word-break: break-all;
    text-wrap: normal;
    overflow-wrap: normal;
}

.microLabel {
    display: inline-block;
    font-family: var(--text-font);
    font-size: 12px;
    line-height: 22px !important;
    font-weight: bold;
    padding: 0 4px;
    margin: 1px 0;
    width: 102px;
    border-radius: 3px;
    -webkit-border-radius: 3px;
    -moz-border-radius: 3px;
    text-transform: uppercase;
    text-align: center;
    background-color: rgba(0, 0, 0, 0.20);
    color: #fff;
    text-overflow: ellipsis;
    white-space: nowrap;
}

    .microLabel.small {
        width: 24px;
        min-width: 24px;
        height: 24px;
        min-height: 24px;
        border-radius: 50%;
        -webkit-border-radius: 50%;
        -moz-border-radius: 50%;
        text-transform: unset;
        text-align: center;
        margin: 0;
        padding: 0;
        line-height: 24px;
    }

.redLabel {
    background-color: rgba(209, 17, 73, 0.8) !important;
    color: #fff !important;
}

.orangeLabel {
    background-color: rgba(241, 113, 5, 0.8) !important;
    color: #fff !important;
}

.purpleLabel {
    background-color: rgba(143, 35, 180, 0.80) !important;
    color: #fff !important;
}

.greenLabel {
    background-color: rgba(57, 181, 74, 0.8) !important;
    color: #fff !important;
}

.darkgreenLabel {
    background-color: rgba(42, 113, 52, 0.80) !important;
    color: #fff !important;
}

.yellowLabel {
    background-color: #e6c229 !important;
    color: #fff !important;
}

.blueLabel {
    background-color: rgba(0, 170, 222, 0.80) !important;
    color: #fff !important;
}

.darkblueLabel {
    background-color: rgba(0, 102, 204, 0.80) !important;
    color: #fff !important;
}

.grayLabel {
    background-color: rgba(0, 0, 0, 0.20) !important;
    color: #fff !important;
}

.noLabel {
    padding: 0 !important;
    text-align: left !important;
    background-color: transparent !important;
    color: var(--main-text-color) !important;
}

.blackLabel {
    background-color: rgba(0, 0, 0, 0.80) !important;
    color: #fff !important;
}

/***************** GRID LABELS *****************/

/***************** FOOTER *******************/
.footer {
    position: relative;
    height: 60px;
    min-height: 60px;
    width: 100%;
    background-color: var(--footer-bg-color);
    color: var(--footer-text-color);
    display: flex;
    flex-direction: row;
    align-items: center;
    font-family: var(--text-font);
    font-size: 12px;
    padding: 0;
    margin: 0;
}

.footer-div {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    padding: 0 20px;
    color: var(--footer-text-color);
}

    .footer-div a {
        padding-left: 30px;
        text-decoration: none;
        color: var(--footer-text-color);
    }


/*********************************/
/*            Header             */
/*********************************/

.header {
    display: flex;
    display: -webkit-flex;
    flex-direction: row;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 80px;
    background: var(--header-bg-color);
    color: var(--header-text-color);
    overflow: hidden;
    border-bottom: 1px solid var(--lines-color-light);
    flex-direction: row;
    align-items: center;
    justify-content: flex-start;
    padding: 0;
    z-index: 100;
}

    .header img {
        height: 40px;
    }

.nobackground {
    background: transparent;
    border-bottom: none;
}

/********************** LOGO ************************/

.logo-container {
    margin-left: 20px;
}

.logo, .staticLogo {
    height: 44px;
    min-height: 44px;
    max-height: 44px;
    width: auto;
    margin: 5px 0 0 0;
    padding: 0;
}

@media screen and (max-width : 760px) {
    .logo {
        height: 30px;
        min-height: 30px;
        max-height: 30px;
    }
}

/***************** TOGGLE BUTTON *******************/

.toggle-button {
    width: 65px;
    height: 50px;
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: center;
    align-content: center;
    font-size: 28px;
    font-weight: 300;
    margin: 0 0 0 10px;
    color: var(--header-text-color);
    vertical-align: middle;
}

.circle-icon {
    background: transparent;
    width: 50px;
    height: 50px;
    border-radius: 50%;
    -webkit-border-radius: 50%;
    -moz-border-radius: 50%;
    text-align: center;
    line-height: 50px;
    vertical-align: middle;
    padding: 0px;
    margin: 0 0 0 15px;
    cursor: pointer;
}

    .circle-icon:hover {
        background-color: var(--enphasys-color);
    }


/***************** LOGGED USER *******************/

.logged-user {
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: center;
    font-size: 18px;
    margin-left: auto;
    cursor: pointer;
}

.user-name {
    font-family: var(--text-font);
    font-weight: 400;
    color: var(--header-text-color);
    text-transform: capitalize;
}

.user-photo {
    background: var(--brand-color);
    width: 50px;
    height: 50px;
    margin: 5px 20px 5px 10px;
    border: 1px solid var(--lines-color);
    border-radius: 50%;
    -webkit-border-radius: 50%;
    -moz-border-radius: 50%;
    text-align: center;
    line-height: 50px;
    vertical-align: middle;
    padding: 0px;
    background-image: url(/images/user.svg);
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
}

    .user-photo img {
        position: relative;
        top: -1px;
        left: -1px;
        width: 52px;
        height: 52px;
        border-radius: 50%;
        -webkit-border-radius: 50%;
        -moz-border-radius: 50%;
    }

.right-header {
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: center;
    font-size: 16px;
    margin-left: auto;
    margin-right: 30px;
}

@media screen and (max-width : 760px) {
    .right-header {
        display: none;
    }
}


/***************** DROPDOWN MENU *******************/

#dropdown-menu {
    display: none;
}

.dropdown {
    display: block;
    min-width: 230px;
    min-height: 36px;
    z-index: 99;
}

div.dropdown {
    display: flex;
    flex-direction: column;
    background-color: var(--dropdown-bgcolor);
    right: 62px;
    top: 70px;
    width: 230px;
    padding: 10px;
    position: fixed;
    height: auto;
    text-align: left;
    z-index: 9998;
    border: 1px solid var(--lines-color);
    border-radius: 4px;
    -webkit-border-radius: 4px;
    -moz-border-radius: 4px;
    box-shadow: 0 12px 16px rgba(0, 0, 0, 0.2);
    -moz-box-shadow: 0 12px 16px rgba(0, 0, 0, 0.2);
    -webkit-box-shadow: 0 12px 16px rgba(0, 0, 0, 0.2);
}

div.arrow {
    background-color: var(--dropdown-bgcolor);
    position: fixed;
    right: 77px;
    top: 60px;
    width: 20px;
    height: 20px;
    border-top: 1px solid var(--lines-color);
    border-right: 1px solid var(--lines-color);
    -ms-transform: rotate(-45deg); /* IE 9 */
    -webkit-transform: rotate(-45deg); /* Safari */
    transform: rotate(-45deg);
    z-index: 9999;
}

.dropdown-menu-item {
    display: flex;
    flex-direction: row;
    padding: 4px 0 5px 0;
    margin: 5px;
    min-width: 210px;
    background-color: transparent;
    color: var(--dropdown-textcolor);
    border-bottom: 2px solid var(--dropdown-bgcolor);
    text-overflow: ellipsis;
    white-space: nowrap;
    overflow: hidden;
}

    .dropdown-menu-item:hover {
        background-color: var(--dropdown-selected-bgcolor);
        color: var(--dropdown-selected-textcolor);
    }

a.dropdown {
    text-decoration: none;
    display: block;
}

.dropdown-menu-icon {
    display: block;
    align-items: center;
    text-align: center;
    padding: 0 10px;
    font-size: 19px;
    width: 30px;
}

.dropdown-menu-text {
    display: block;
    font-family: var(--std-font);
    align-items: center;
    text-align: left;
    font-size: 19px;
    font-weight: 500;
}


/***************** VIEW *******************/

.main-container {
    display: flex;
    flex-direction: column;
    width: 100%;
    min-width: 100%;
    background-color: var(--main-bg-color);
    color: var(--main-text-color);
    overflow: auto;
    -webkit-overflow-scrolling: touch;
}

@media screen and (max-width : 768px) {
    .main-container {
        overflow-x: hidden;
    }
}

.page-container {
    display: flex;
    flex-direction: row;
    width: 100%;
    min-width: 100%;
    background-color: var(--main-bg-color);
    color: var(--main-text-color);
}

.standard-container {
    display: flex;
    flex-direction: column;
    display: -webkit-flex;
    -webkit-flex-direction: column;
    width: 100%;
    height: auto;
    min-height: calc(100vh - 60px);
    padding: 0px;
    align-items: flex-start;
    border-left: 1px solid var(--lines-color-light);
    background-color: var(--main-bg-color);
    color: var(--main-text-color);
}

@media screen and (max-width: 1024px) and (min-width: 768px) {
    .standard-container {
        min-width: 767px;
        overflow-x: hidden;
    }
}

.standard-div-content {
    display: flex;
    flex-direction: row;
    align-content: flex-start;
    align-items: flex-start;
    padding: 80px 0 0 0;
    width: 100%;
}

.centered {
    width: 100%;
    justify-content: center !important;
}

/***************** LEFT PANEL *****************/

.left-div-open {
    position: relative;
    display: flex;
    flex-direction: column;
    align-content: center;
    width: auto;
    min-width: 300px;
    max-width: 300px;
    overflow-x: hidden;
    background-color: var(--left-div-bg-color);
    color: var(--left-div-text-color);
    -webkit-transition: all .2s linear;
    -moz-transition: all .2s linear;
    -ms-transition: all .2s linear;
    -o-transition: all .2s linear;
    transition: all .2s linear;
    left: 0px;
    z-index: 10;
}

    .left-div-open.closed {
        left: -300px;
        width: 0px;
        min-width: 0px;
        height: 0px;
    }

.left-div-content {
    padding: 100px 20px 30px 30px;
}

.left-menu-item {
    text-align: left;
    margin: 20px 0px;
    text-overflow: ellipsis;
    white-space: nowrap;
    overflow: hidden;
}

    .left-menu-item a {
        font-family: var(--text-font);
        color: var(--left-div-text-color);
        font-weight: 500;
        font-size: 1rem;
        line-height: 1.3rem;
        text-decoration: none;
        text-align: left;
        text-overflow: ellipsis;
        white-space: nowrap;
        overflow: hidden;
    }

        .left-menu-item a:hover {
            border-bottom: 2px solid var(--brand-color);
        }


/************************   SHOP CARDS   *************************/

:root {
    /* Tile Dimensions */
    --carousel-tile-spacing: 70px;
    --carousel-tile-width: 200px;
    --carousel-tile-height: calc(var(--carousel-tile-width) / (16 / 9));
    /*  Growth Factor*/
    --carousel-growth-factor: 1;
    /* Fade to Opacity */
    --carousel-fade-opacity: 0.25;
    --carousel-normal-opacity: 1;
    /* Automatic Offsets*/
    --carousel-offset-left: calc(-1 * (var(--carousel-tile-width) * (var(--carousel-growth-factor) - 1) / 2));
    --carousel-offset-right: calc(var(--carousel-tile-width) * (var(--carousel-growth-factor) - 1));
    /* Transition Speeds*/
    --carousel-transition-1: 1s;
    --carousel-transition-2: 0.5s;
    --carousel-transition-3: 0.3s;
}

.carousel {
    padding: 0 15px;
    margin: 0;
    box-sizing: border-box;
    width: calc(84% + 15px);
    height: calc((var(--carousel-tile-height) * 4));
    overflow-x: auto;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
}

.carousel-landing {
    padding: 5px 15px;
    margin: 0;
    box-sizing: border-box;
    /*width: calc(84% + 15px);*/
    width: calc(100% - 140px);
    min-width: 315px;
    max-width: 1280px;
    height: 550px;
    overflow-x: auto;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
}

.carousel-row {
    margin: 0 15px;
    white-space: nowrap;
    margin-top: calc((var(--carousel-tile-height) * (var(--carousel-growth-factor) - 1)) / 2);
    margin-bottom: calc((var(--carousel-tile-height) * (var(--carousel-growth-factor) - 1)) / 2);
    margin-left: calc((var(--carousel-tile-width) * (var(--carousel-growth-factor) - 1)) / 2);
    margin-right: calc((var(--carousel-tile-width) * (var(--carousel-growth-factor) - 1)) / 2);
    transition: var(--carousel-transition-2);
    display: flex;
    height: calc((var(--carousel-tile-height) * 4));
}

.carousel::-webkit-scrollbar {
    display: none;
}

.carousel-landing::-webkit-scrollbar {
    display: none;
}

.carousel-tile {
    position: relative;
    display: inline-block;
    width: var(--carousel-tile-width);
    height: var(--carousel-tile-height);
    margin-right: var(--carousel-tile-spacing);
    transition: var(--carousel-transition-2);
    -webkit-transform-origin: center left;
    transform-origin: center left;
    cursor: pointer;
}

    .carousel-tile:last-of-type {
        margin-right: calc(var(--carousel-tile-width)/2);
    }


    .carousel-tile * {
        display: block;
    }


.carousel-row:hover {
    -webkit-transform: translate3d(var(--carousel-offset-left), 0, 0);
    transform: translate3d(var(--carousel-offset-left), 0, 0);
}

    /*Content Tile on Carousel Row Hover*/
    /*.carousel-row:hover .carousel-tile {
 opacity: var(--carousel-fade-opacity);
}*/

    /* Content Tile on Hover on Carousel Row Hover*/
    .carousel-row:hover .carousel-tile:hover {
        -webkit-transform: scale(var(--carousel-growth-factor));
        transform: scale(var(--carousel-growth-factor));
        opacity: var(--carousel-normal-opacity);
    }

/*Content Tile on Hover */
.carousel-tile:hover ~ .carousel-tile {
    -webkit-transform: translate3d(var(--carousel-offset-right), 0, 0);
    transform: translate3d(var(--carousel-offset-right), 0, 0);
}


.controls-container {
    display: flex;
    flex-direction: row;
    align-content: center;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    margin: 0 30px;
}

.category-container {
    display: flex;
    flex-direction: row;
    align-content: flex-start;
    align-items: flex-start;
    justify-content: flex-start;
    flex-wrap: nowrap;
    width: calc(100% - 30px);
    margin: 0 0 0 30px;
    padding: 10px 0;
    font-family: var(--std-font);
    font-size: 22px;
    font-weight: 600;
    color: var(--gray-text-color);
    text-decoration: none;
}

    .category-container a {
        color: var(--gray-text-color);
        text-decoration: none;
    }

.scrolling-wrapper {
    display: flex;
    flex-direction: row;
    align-content: flex-start;
    align-items: flex-start;
    justify-content: flex-start;
    max-width: calc(100% - 30px);
    margin: 0 15px;
    height: 440px;
    position: relative;
    flex-wrap: nowrap;
    overflow-x: auto;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
}

    .scrolling-wrapper::-webkit-scrollbar {
        display: none;
    }

    .scrolling-wrapper .card {
        flex: 0 0 auto;
    }

.prev, .next {
    position: absolute;
    display: flex;
    flex-direction: row;
    align-items: center;
    align-content: center;
    height: 435px;
    width: 50px;
    /*padding: 0 10px 25px 10px;*/
    padding: 0 10px;
    background: transparent;
    color: rgba(51, 51, 51, 0.2);
    z-index: 99;
    font-size: 50px;
    cursor: pointer;
}

    .prev:hover, .next:hover {
        color: var(--brand-color);
        opacity: 0.8;
    }

.prev {
    left: 300px;
}

.next {
    right: 0px;
}

@media screen and (max-width : 760px) {
    .prev {
        display: none !important;
    }

    .next {
        display: none !important;
    }
}

.card-container {
    width: calc(100% - 30px);
    display: flex;
    flex-direction: row;
    align-content: center;
    align-items: flex-start;
    justify-content: center;
    flex-wrap: wrap;
    margin: 50px 15px 15px 15px;
}

@media screen and (max-width : 900px) {
    .controls-container {
        display: flex;
        flex-direction: column;
        align-content: center;
        align-items: center;
        justify-content: center;
        margin: 10px 0;
    }
}


.card {
    position: relative;
    width: 258px;
    min-width: 258px;
    max-width: 258px;
    height: 420px;
    overflow: hidden;
    border: 1px 1px 0px 1px solid var(--lines-color);
    border-radius: 6px;
    -webkit-border-radius: 6px;
    -moz-border-radius: 6px;
    margin: 10px;
    padding: 0;
    background-color: var(--card-bg-color);
    color: var(--card-text-color);
    box-shadow: 0 2px 2px rgba(0, 0, 0, 0.2);
    -moz-box-shadow: 0 2px 2px rgba(0, 0, 0, 0.2);
    -webkit-box-shadow: 0 2px 2px rgba(0, 0, 0, 0.2);
    transition: all 0.25s;
    cursor: pointer;
    z-index: 1;
}

    .card:hover {
        top: -3px;
        box-shadow: 0 12px 16px rgba(0, 0, 0, 0.2);
        -moz-box-shadow: 0 12px 16px rgba(0, 0, 0, 0.2);
        -webkit-box-shadow: 0 12px 16px rgba(0, 0, 0, 0.2);
    }

    .card.large {
        width: 318px;
        height: 482px;
        max-width: unset;
        max-height: unset;
        border: 1px 1px 0px 1px solid red;
    }

    .card.listview {
        width: 288px;
        height: 452px;
        max-width: unset;
        max-height: unset;
    }

@media screen and (max-width : 767px) {
    .card.large, .card.listview {
        width: 318px;
        height: 482px;
        max-width: 85vw;
        max-height: calc(85vw + 162px);
    }
}

.card-shadow, .card-shadow:hover {
    top: 0px !important;
    cursor: default !important;
}

.card-image {
    width: 100%;
    /*height: calc(100% - 165px);*/
    padding-top: 100%;
    position: relative;
    overflow: hidden;
    top: 0px;
    left: 0px;
    z-index: 1;
    border: none;
    border-radius: 6px 6px 0 0;
    margin: 0;
    border-bottom: 1px solid var(--lines-color);
    background-color: var(--blank-card-bg-color);
    background-position-y: top; /* position the image */
    background-position-x: left; /* position the image */
    background-repeat: no-repeat; /* Do not repeat the image */
    /*background-size: calc(100% - 20px); bordo bianco eliminato*/
    background-size: cover;
    z-index: 1;
}

    .card-image.reduced {
        background-color: var(--blank-card-bg-color);
        background-position: center; /* position the image */
        background-repeat: no-repeat; /* Do not repeat the image */
        /*background-size: calc(100% - 20px); bordo bianco eliminato*/
        background-size: 85%;
    }


.card-title {
    display: block;
    width: calc(100% - 30px);
    height: 40px;
    max-height: 40px;
    position: relative;
    background-color: var(--card-bg-color);
    color: var(--card-text-color);
    margin: 15px 15px 0 15px;
    font-family: var(--text-font);
    font-size: 13px;
    line-height: 18px;
    font-weight: 600;
    text-align: center;
    text-transform: uppercase;
    overflow: hidden;
    white-space: normal !important;
    opacity: 0.8;
    z-index: 2;
}

.card-partner {
    width: calc(100% - 20px);
    position: relative;
    margin-top: 25px;
    background-color: var(--card-bg-color);
    color: var(--card-brand-color);
    padding: 0 10px;
    font-family: var(--text-font);
    font-weight: 700;
    font-size: 14px;
    text-align: center;
    z-index: 2;
    text-transform: uppercase;
}

.card-description {
    display: block;
    width: calc(100% - 20px);
    height: 40px;
    max-height: 40px;
    position: relative;
    background-color: var(--card-bg-color);
    color: var(--card-text-color);
    margin: 5px 10px 0px 10px;
    font-family: var(--text-font);
    font-size: 11px;
    line-height: normal;
    font-weight: 600;
    text-align: center;
    text-transform: uppercase;
    overflow: hidden;
    white-space: normal !important;
    opacity: 0.8;
    z-index: 2;
}

.card-price-container {
    position: absolute;
    bottom: 0px;
    left: 0px;
    display: flex;
    flex-direction: row;
    justify-content: flex-start;
    align-items: center;
    height: 30px;
    min-height: 30px;
    line-height: 16px;
    width: calc(100% - 0px);
    position: absolute;
    bottom: 0px;
    left: 0px;
    margin: 0;
    padding: 7px 15px;
    font-family: var(--text-font);
    font-size: 16px;
    font-weight: 600;
    color: #FFF;
    text-align: left;
    z-index: 6;
}

.viaggi {
    background-color: orange;
}

.buonispesa {
    background-color: cornflowerblue;
}

.assicurazioni {
    background-color: #00aade;
}

.auto {
    background-color: teal;
}

.benessere {
    background-color: mediumorchid;
}

.casa {
    background-color: firebrick;
}

.salute {
    background-color: #d11149;
}

.istruzione {
    background-color: darkslateblue;
}

.cibo {
    background-color: mediumseagreen;
}

.smartmobility {
    background-color: lightseagreen;
}

.smartworking {
    background-color: lightseagreen;
}

.anziani {
    background-color: blueviolet;
}

.infanzia {
    background-color: deepskyblue;
}

.sport {
    background-color: Highlight;
}

.swim {
    background-color: Highlight;
}

.gym{
    background-color: orangered;
}

.diving {
    background-color: lightseagreen;
}

.snow {
    background-color: #00aade;
}

.racquet{
    background-color:gray;
}

.tennis {
    background-color: darkorange;
}

.sailboat {
    background-color: yellowgreen;
}

.canoe {
    background-color: steelblue;
}

.soccerball {
    background-color: lightslategrey;
}

.soggiorni {
    background-color: #fa4e2c;
}

.fiori {
    background-color: darkgreen;
}

.eventi, .places {
    background-color: #fea00a;
}

.cultura {
    background-color: mediumslateblue;
}

.gold {
    background-color: darkgoldenrod;
}

.mutui {
    background-color: darkgoldenrod;
}

.trasporti {
    background-color: forestgreen;
}

.energy {
    background-color: lightseagreen;
}

.entertainment {
    background-color: lightgreen;
}

.rent {
    background-color: coral;
}


.card-price-range {
    display: flex;
    flex-direction: row;
    justify-content: flex-start;
    width: 100%;
    background-color: transparent;
    color: #fff;
    font-family: var(--text-font);
    font-size: 16px;
    font-weight: 600;
    padding: 0;
    margin: 0;
    text-align: left;
}


.card-favourite {
    width: 16px;
    height: 16px;
    position: absolute;
    bottom: 0px;
    right: 0px;
    background-color: transparent;
    padding: 14px;
    color: #fff;
    text-align: center;
    font-size: 16px;
    z-index: 8;
}


.card-badge {
    width: 40px;
    height: 30px;
    border-radius: 50%;
    -webkit-border-radius: 50%;
    -moz-border-radius: 50%;
    position: absolute;
    top: -25px;
    right: -25px;
    text-align: center;
    vertical-align: text-bottom;
    color: #fff;
    font-family: var(--std-font);
    font-weight: bold;
    font-size: 18px;
    overflow: hidden;
    padding: 30px 20px 0 0;
    z-index: 3;
}

    .card-badge:hover {
        position: absolute;
        top: 0px;
        left: 0px;
        width: calc(100% - 40px);
        height: calc(100% - 200px);
        margin: 0;
        border: 10px solid #fff;
        border-radius: 0px;
        /*background-color: var(--tooltip-div-bg-color);*/
        color: transparent;
        z-index: 20;
    }

.card-tooltip {
    position: absolute;
    top: 0px;
    left: 0px;
    visibility: hidden;
    width: calc(100% - 40px);
    height: calc(100% - 200px);
    border-radius: 0px;
    background-color: transparent;
    color: #fff;
    text-align: left;
    padding: 20px;
    font-family: var(--std-font);
    font-weight: 400;
    font-size: 1.4rem;
    z-index: 20;
    white-space: normal;
}

.card-badge:hover .card-tooltip {
    visibility: visible;
}

.card-tooltip:hover .card-tooltip {
    visibility: visible;
}

.card-views {
    display: flex;
    flex-direction: row;
    justify-content: flex-end;
    width: 240px;
    position: absolute;
    bottom: 0px;
    right: 0px;
    background: transparent;
    padding-right: 15px;
    z-index: 7;
    font-family: var(--text-font);
    font-weight: 500;
    color: #fff;
    text-align: left;
    font-size: 16px;
    line-height: 16px;
    margin: 0 0 14px 0px;
}

.menu-icon-category {
    display: block;
    align-items: center;
    text-align: left;
    padding: 0 10px 0 0;
    width: 30px;
    font-family: "Font Awesome 6 Pro";
    font-size: 17px;
    font-weight: 900;
    background-color: transparent;
}

    .menu-icon-category.viaggi:after {
        content: "\f5ca";
    }

    .menu-icon-category.buonispesa:after {
        content: "\f06b";
    }

    .menu-icon-category.smartworking:after {
        content: "\e066";
    }

    .menu-icon-category.assicurazioni:after {
        content: "\f0e9";
    }

    .menu-icon-category.auto:after {
        content: "\f1b9";
    }

    .menu-icon-category.benessere:after {
        content: "\f5bb";
    }

    .menu-icon-category.casa:after {
        content: "\f015";
    }

    .menu-icon-category.salute:after {
        content: "\f21e";
    }

    .menu-icon-category.istruzione:after {
        content: "\f19d";
    }

    .menu-icon-category.cibo:after {
        content: "\f2e7";
    }

    .menu-icon-category.smartmobility:after {
        content: "\f206";
    }

    .menu-icon-category.anziani:after {
        content: "\f193";
    }

    .menu-icon-category.infanzia:after {
        content: "\f77d";
    }

    .menu-icon-category.sport:after {
        content: "\f5c4";
    }

    .menu-icon-category.swim:after {
        content: "\f5c4";
    }

    .menu-icon-category.gym:after {
        content: "\f44b";
    }

    .menu-icon-category.diving:after {
        content: "\e3b7";
    }

    .menu-icon-category.snow:after {
        content: "\f7c9";
    }

    .menu-icon-category.racquet:after {
        content: "\f45a";
    }

    .menu-icon-category.tennis:after {
        content: "\f45e";
    }

    .menu-icon-category.sailboat:after {
        content: "\e445";
    }

    .menu-icon-category.canoe:after {
        content: "\f1cd";
    }

    .menu-icon-category.soccerball:after {
        content: "\f1e3";
    }



.menu-icon-category.soggiorni:after {
    font-family: "Font Awesome 6 Pro";
    font-size: 20px;
    font-weight: 900;
    content: "\e174";
}

    .menu-icon-category.fiori:after {
        font-family: "Font Awesome 6 Pro";
        font-size: 20px;
        font-weight: 900;
        content: "\f801";
    }

    .menu-icon-category.eventi:after {
        content: "\f001";
    }

    .menu-icon-category.cultura:after {
        content: "\f630";
    }

    .menu-icon-category.gold:after {
        content: "\f3a5";
    }

    .menu-icon-category.mutui:after {
        content: "\f153";
    }

    .menu-icon-category.trasporti:after {
        content: "\f239";
    }

    .menu-icon-category.energy:after {
        content: "\f0eb";
    }

    .menu-icon-category.entertainment:after {
        content: "\f401";
    }

    .menu-icon-category.rent:after {
        content: "\f015";
    }


    .card-category {
        width: 34px;
        height: 34px;
        position: absolute;
        margin-top: calc(100% - 17px);
        top: 0px;
        left: calc(50% - 17px);
        border-radius: 50%;
        -webkit-border-radius: 50%;
        -moz-border-radius: 50%;
        background-color: lightgray;
        color: #fff;
        text-align: center;
        vertical-align: baseline;
        line-height: 34px;
        z-index: 20;
    }

    .card-category.viaggi {
        background-color: orange;
    }

        .card-category.viaggi:after {
            margin-left: 1px;
            font-family: "Font Awesome 6 Pro";
            font-size: 19px;
            font-weight: 900;
            content: "\f5ca";
        }

    .card-category.buonispesa {
        background-color: cornflowerblue;
    }

        .card-category.buonispesa:after {
            font-family: "Font Awesome 6 Pro";
            font-size: 20px;
            font-weight: 900;
            content: "\f06b";
        }

    .card-category.assicurazioni {
        background-color: #00aade;
    }

        .card-category.assicurazioni:after {
            font-family: "Font Awesome 6 Pro";
            font-size: 20px;
            font-weight: 900;
            content: "\f0e9";
        }

    .card-category.auto {
        background-color: teal;
    }

        .card-category.auto:after {
            font-family: "Font Awesome 6 Pro";
            font-size: 20px;
            font-weight: 900;
            content: "\f1b9";
        }

    .card-category.benessere {
        background-color: mediumorchid;
    }

        .card-category.benessere:after {
            font-family: "Font Awesome 6 Pro";
            font-size: 20px;
            font-weight: 900;
            content: "\f5bb";
        }

    .card-category.casa {
        background-color: firebrick;
    }

        .card-category.casa:after {
            font-family: "Font Awesome 6 Pro";
            font-size: 20px;
            font-weight: 900;
            content: "\f015";
        }

    .card-category.salute {
        background-color: #d11149;
    }

        .card-category.salute:after {
            margin-left: 1px;
            line-height: 36px;
            font-family: "Font Awesome 6 Pro";
            font-size: 20px;
            font-weight: 900;
            content: "\f21e";
        }

    .card-category.istruzione {
        background-color: darkslateblue;
    }

        .card-category.istruzione:after {
            font-family: "Font Awesome 6 Pro";
            margin-left: 2px;
            font-size: 20px;
            font-weight: 900;
            content: "\f19d";
        }

    .card-category.cibo {
        background-color: mediumseagreen;
    }

        .card-category.cibo:after {
            font-family: "Font Awesome 6 Pro";
            font-size: 20px;
            font-weight: 900;
            content: "\f2e7";
        }

    .card-category.smartmobility {
        background-color: lightseagreen;
    }

        .card-category.smartmobility:after {
            font-family: "Font Awesome 6 Pro";
            font-size: 20px;
            font-weight: 900;
            content: "\f206";
        }

    .card-category.smartworking {
        background-color: lightseagreen;
    }

        .card-category.smartworking:after {
            font-family: "Font Awesome 6 Pro";
            font-size: 20px;
            font-weight: 900;
            content: "\e066";
        }

    .card-category.anziani {
        background-color: blueviolet;
    }

        .card-category.anziani:after {
            font-family: "Font Awesome 6 Pro";
            font-size: 20px;
            font-weight: 900;
            content: "\f193";
        }

    .card-category.infanzia {
        background-color: deepskyblue;
    }

        .card-category.infanzia:after {
            font-family: "Font Awesome 6 Pro";
            font-size: 20px;
            font-weight: 900;
            content: "\f77d";
        }

    .card-category.sport {
        background-color: Highlight;
    }

        .card-category.sport:after {
            font-family: "Font Awesome 6 Pro";
            font-size: 19px;
            font-weight: 900;
            content: "\f5c4";
        }

    .card-category.swim {
        background-color: Highlight;
    }

        .card-category.swim:after {
            font-family: "Font Awesome 6 Pro";
            font-size: 19px;
            font-weight: 900;
            content: "\f5c4";
        }

    .card-category.gym {
        background-color: orangered;
    }

        .card-category.gym:after {
            font-family: "Font Awesome 6 Pro";
            font-size: 19px;
            font-weight: 900;
            content: "\f44b";
        }

    .card-category.diving {
        background-color: lightseagreen;
    }

        .card-category.diving:after {
            font-family: "Font Awesome 6 Pro";
            font-size: 19px;
            font-weight: 900;
            content: "\e3b7";
        }

    .card-category.sailboat {
        background-color: yellowgreen;
    }

        .card-category.sailboat:after {
            font-family: "Font Awesome 6 Pro";
            font-size: 19px;
            font-weight: 900;
            content: "\e445";
        }

    .card-category.canoe {
        background-color: steelblue;
    }

        .card-category.canoe:after {
            font-family: "Font Awesome 6 Pro";
            font-size: 19px;
            font-weight: 900;
            content: "\f1cd";
        }

    .card-category.snow {
        background-color: #00aade;
    }

        .card-category.snow:after {
            font-family: "Font Awesome 6 Pro";
            font-size: 19px;
            font-weight: 900;
            content: "\f7c9";
        }

    .card-category.racquet {
        background-color: gray;
    }

        .card-category.racquet:after {
            font-family: "Font Awesome 6 Pro";
            font-size: 19px;
            font-weight: 900;
            content: "\f45a";
        }


    .card-category.tennis {
        background-color: darkorange;
    }

        .card-category.tennis:after {
            font-family: "Font Awesome 6 Pro";
            font-size: 19px;
            font-weight: 900;
            content: "\f45e";
        }


        .card-category.soccerball {
            background-color: lightslategrey;
        }

            .card-category.soccerball:after {
                font-family: "Font Awesome 6 Pro";
                font-size: 19px;
                font-weight: 900;
                content: "\f1e3";
            }
    .card-category.soggiorni {
        background-color: #fa4e2c;
    }


        .card-category.soggiorni:after {
            font-family: "Font Awesome 6 Pro";
            font-size: 20px;
            font-weight: 900;
            content: "\e174";
        }

    .card-category.fiori {
        background-color: darkgreen;
    }

    .card-category.fiori:after {
        font-family: "Font Awesome 6 Pro";
        font-size: 20px;
        font-weight: 900;
        content: "\f801";
    }

    .card-category.eventi {
        background-color: #fea00a;
    }

        .card-category.eventi:after {
            font-family: "Font Awesome 6 Pro";
            font-size: 20px;
            font-weight: 900;
            content: "\f001";
        }

    .card-category.cultura {
        background-color: mediumslateblue;
    }

        .card-category.cultura:after {
            font-family: "Font Awesome 6 Pro";
            font-size: 20px;
            font-weight: 900;
            content: "\f630";
        }

    .card-category.gold {
        background-color: darkgoldenrod;
    }

        .card-category.gold:after {
            font-family: "Font Awesome 6 Pro";
            font-size: 20px;
            font-weight: 900;
            content: "\f3a5";
        }

    .card-category.places {
        background-color: #fea00a;
    }

        .card-category.places:after {
            font-family: "Font Awesome 6 Pro";
            font-size: 20px;
            font-weight: 900;
            content: "\f3c5";
        }

    .card-category.mutui {
        background-color: darkgoldenrod;
    }

        .card-category.mutui:after {
            font-family: "Font Awesome 6 Pro";
            font-size: 20px;
            font-weight: 900;
            content: "\f153";
        }

    .card-category.trasporti {
        background-color: forestgreen;
    }

        .card-category.trasporti:after {
            font-family: "Font Awesome 6 Pro";
            font-size: 20px;
            font-weight: 900;
            content: "\f239";
        }

    .card-category.energy {
        background-color: lightseagreen;
    }

        .card-category.energy:after {
            font-family: "Font Awesome 6 Pro";
            font-size: 20px;
            font-weight: 900;
            content: "\f0eb";
        }

        .card-category.entertainment {
            background-color: lightgreen;
        }

            .card-category.entertainment:after {
                font-family: "Font Awesome 6 Pro";
                font-size: 20px;
                font-weight: 900;
                content: "\f401";
            }
        .card-category.rent {
            background-color: coral;
        }

            .card-category.rent:after {
                font-family: "Font Awesome 6 Pro";
                font-size: 20px;
                font-weight: 900;
                content: "\f015";
            }

.card-btn {
    width: calc(100% - 30px);
    position: absolute;
    bottom: 5px;
    left: 0px;
    padding: 0px 15px;
    z-index: 6;
}


/******************  SHOP PANEL ***********************/

.shop-container {
    display: flex;
    flex-direction: column;
    /*width: 100%;*/
    height: auto;
}

#select-order {
    background-color: transparent;
    padding-left: 30px;
}

.dove {
    width: calc(100% - 37px);
    background: var(--input-bg-color) url(/images/pin.png) left no-repeat;
    color: var(--input-text-color);
    background-size: 18px;
    background-position-x: 5px;
    background-position-y: 10px;
    padding-left: 30px;
}

.gruppo {
    width: calc(100% - 37px);
    background: var(--input-bg-color) url(/images/icone/object-group-regular.svg) left no-repeat;
    color: var(--input-text-color);
    background-size: 18px;
    background-position-x: 5px;
    background-position-y: 10px;
    padding-left: 30px;
}

#search {
    width: calc(100% - 37px);
    background: var(--input-bg-color) url(/images/search.png) left no-repeat;
    color: var(--input-text-color);
    background-size: 18px;
    background-position-x: 5px;
    background-position-y: 10px;
    padding-left: 30px;
}

.credit {
    width: calc(100% - 12px);
    height: 26px;
    border-radius: 4px;
    text-align: center;
    text-decoration: none;
    padding: 5px;
    font-size: 20px;
    border: 1px solid var(--brand-color);
    color: var(--brand-color);
}

.results-container {
    display: flex;
    flex-direction: row;
    justify-content: center;
    align-items: center;
    align-content: center;
    width: 250px;
    font-size: 26px;
    font-weight: 400;
    margin: 20px;
}

.pagination-container {
    display: flex;
    flex-direction: row;
    justify-content: center;
    align-items: center;
    align-content: center;
    /*width: 250px;*/
    margin: 20px;
}

.order-container {
    display: flex;
    justify-content: center;
    align-items: center;
    align-content: center;
    width: 250px;
    background-size: 16px;
    background-position-x: 10px;
    background-position-y: 10px;
    margin: 20px;
}

.first-page, .prev-page, .next-page, .last-page {
    display: flex;
    text-align: center;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    border: 1px solid #777;
    border-radius: 50%;
    -webkit-border-radius: 50%;
    -moz-border-radius: 50%;
    color: var(--gray-text-color);
    font-size: 18px;
    background-color: transparent;
}

.first-page, .prev-page, .next-page, .last-page {
    background-position: center;
    background-repeat: no-repeat;
    background-size: 18px;
}

.current-page {
    background-color: transparent;
    text-align: center;
    align-items: center;
    justify-content: center;
    align-content: center;
    width: 70px;
    height: 36px;
    color: var(--gray-text-color);
    font-size: 18px;
    line-height: 36px;
}

.prev-page {
    background-image: url('/images/back.svg');
}

.next-page {
    margin-right: 2px;
    background-image: url('/images/next.svg');
}

.last-page {
    background-image: url('/images/last.svg');
}

.first-page {
    margin-left: 0;
    background-image: url('/images/first.svg');
}

.div-icons {
    display: flex;
    flex-direction: row;
    justify-content: center;
    align-content: center;
    width: 100%;
    text-align: center;
    font-size: .9rem;
    margin: 0 0 15px 0;
}

/*.map-icon {
    width: 46px;
    height: 46px;
    margin: 5px 0px;
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover;
    background-image: url('/images/map.png');
    cursor: pointer;
}

.grid-icon {
    width: 46px;
    height: 46px;
    margin: 5px 0;
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover;
    background-image: url('/images/grid.png');
    cursor: pointer;
}*/

.viewstyle-icon {
    width: auto;
    height: 18px;
    margin: 5px 0;
    font-size: 18px;
    text-align: left;
    color: var(--gray-text-color);
    cursor: pointer;
}

    .viewstyle-icon.active {
        color: var(--brand-color);
    }

.first-page:hover, .prev-page:hover, .next-page:hover, .last-page:hover {
    background-color: var(--enphasys-color);
    cursor: pointer;
}

.div-row {
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    align-content: center;
    width: 100%;
}

.div-row-fixed {
    display: flex;
    flex-direction: row;
    justify-content: center;
    align-content: center;
    width: 100%;
    margin: 20px 0;
}


.nowrap {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

/******************** CHECKBOX **********************/

.checkbox-container {
    display: block;
    position: relative;
    padding-left: 35px;
    margin: 7px 0;
    cursor: pointer;
    font-size: 16px;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
}

    .checkbox-container a {
        text-decoration: none;
        font-weight: bold;
        font-family: var(--text-font);
        color: var(--brand-color);
    }

    .checkbox-container input {
        position: absolute;
        opacity: 0;
        cursor: pointer;
        height: 0;
        width: 0;
    }

.checkmark {
    position: absolute;
    top: -5px;
    left: 0;
    height: 25px;
    width: 25px;
    border: 1px solid var(--input-border-color);
    border-radius: 4px;
}

.checkbox-container:hover input ~ .checkmark {
    border: 1px solid var(--brand-color);
}

.checkbox-container input:checked ~ .checkmark {
    background-color: transparent;
}

.checkmark:after {
    content: "";
    position: absolute;
    display: none;
}

.checkbox-container input:checked ~ .checkmark:after {
    display: block;
}

.checkbox-container .checkmark:after {
    left: 9px;
    top: 5px;
    width: 5px;
    height: 10px;
    border: solid var(--input-text-color);
    border-width: 0 3px 3px 0;
    -webkit-transform: rotate(45deg);
    -ms-transform: rotate(45deg);
    transform: rotate(45deg);
}

/**************************************/
/*            MAP MARKER              */
/**************************************/

.markerLine {
    display: flex;
    flex-direction: row;
    text-decoration: none;
    padding: 0;
    margin: 0 10px 10px 0;
    width: auto;
    max-width: 350px !important;
    height: auto;
    color: black;
    overflow-x: hidden;
}

    .markerLine.pic {
        /*flex: 0 0 3rem;*/
        width: 100px;
        height: 100px;
        min-width: 100px;
        min-height: 100px;
        background-size: cover;
        background-position: center;
        background-repeat: no-repeat;
        margin: 0 10px 0 0;
        padding: 0;
        border-radius: 4px;
        position: relative;
        left: 0px;
        top: 0px;
    }

    .markerLine.markerText {
        width: 100%;
        height: auto;
        text-decoration: none;
        color: inherit;
        margin: 0 0 5px 0;
        padding: 0;
        font-family: var(--std-font);
        font-weight: 600;
        text-align: left;
        color: var(--main-text-color);
        overflow: hidden;
    }

    .markerLine.markerSupplier {
        width: 100%;
        height: auto;
        min-width: 0px;
        min-height: 0px;
        text-decoration: none;
        color: inherit;
        margin: 0;
        padding: 0;
        line-height: 18px;
        font-family: var(--std-font);
        font-size: 12px;
        font-weight: 400;
        color: var(--gray-text-color);
        text-transform: uppercase;
    }

    .markerLine.markerPrice {
        width: 100%;
        height: auto;
        min-width: 0px;
        min-height: 0px;
        font-weight: bold;
        font-size: 18px;
        font-family: var(--text-font), var(--std-font);
        /*text-align: right;*/
        color: var(--price-text-color);
        margin-top: 5px;
    }

/***********************/
/*        detail       */
/***********************/

.divContainer {
    width: 100%;
    max-width: unset;
}

@media screen and (max-width : 767px) {
    .divContainer {
        width: 100%;
        max-width: calc(85vw - 2px);
    }
}

.detail-container {
    display: flex;
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    flex-direction: row;
    justify-content: center;
    align-items: flex-start;
    min-height: calc(100vh - 60px);
    padding-top: 100px;
    padding-left: 10px;
    width: calc(100% - 10px);
    border-left: 1px solid var(--lines-color);
}

.column-container {
    display: flex;
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    flex-direction: column;
    justify-content: center;
    margin: 0 20px;
}


.detail-row-container {
    display: flex;
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    min-width: 260px;
    max-width: 320px;
    flex-direction: row;
    justify-content: center;
    overflow: hidden;
}

.row-centered {
    display: flex;
    justify-content: center !important;
    text-align: center !important;
    height: auto;
}

.row-spaced {
    justify-content: space-between;
    text-align: center;
    height: auto;
}

.detail-card {
    position: relative;
    width: 100%;
    padding-top: 100%;
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center;
    margin: 20px 0;
    border: 1px solid var(--lines-color);
    border-radius: 6px;
    background-color: var(--card-bg-color);
}

    .detail-card.reduced {
        background-color: var(--blank-card-bg-color);
        background-position: center; /* position the image */
        background-repeat: no-repeat; /* Do not repeat the image */
        /*background-size: calc(100% - 20px); bordo bianco eliminato*/
        background-size: 85%;
    }

.detail-img {
    display: flex;
    width: calc(100% - 2px);
    height: calc(100% - 2px);
    /*max-width: 320px;
    min-height: 320px;*/
    background-color: var(--card-bg-color);
    background-size: cover;
    background-position: top;
    background-repeat: no-repeat;
    padding: 0;
    border-radius: 6px;
}


.detail-img-ext {
    display: flex;
    width: 100%;
    max-width: 320px;
    min-height: 320px;
    background-size: 100%;
    background-position: center;
    background-repeat: no-repeat;
    padding: 0;
    border-radius: 6px 6px 0 0;
}


.detail-img.reduced {
    background-size: 85%;
    background-position: center;
}

.detail-price {
    display: flex;
    font-family: var(--std-font);
    font-size: 24px;
    font-weight: 600;
    color: var(--price-text-color);
    margin: 0;
    margin-left: auto;
    padding: 20px;
    text-align: right;
    justify-content: flex-end;
    align-items: center;
}


.detail-info {
    display: flex;
    flex-direction: column;
    width: 40%;
    min-width: 320px;
    max-width: 500px;
    height: auto;
    margin: 35px 30px 30px 30px;
    color: var(--main-text-color);
}

.detail-option {
    display: inline-block;
    font-family: var(--text-font);
    font-size: 14px;
    line-height: 24px;
    font-weight: bold;
    padding: 0 4px;
    margin: 5px 5px 5px 0;
    min-width: 93px;
    border-radius: 5px;
    -webkit-border-radius: 5px;
    -moz-border-radius: 5px;
    text-transform: uppercase;
    text-align: center;
    background-color: rgba(0, 0, 0, 0.20);
    color: #fff;
    text-overflow: ellipsis;
    white-space: nowrap;
}

    .detail-option:hover {
        background-color: var(--button-hover);
        color: var(--button-hover-text);
        cursor: pointer;
    }

    .detail-option.selected {
        background-color: var(--std-button-color);
        color: var(--std-button-text-color);
        cursor: pointer;
    }

.detail-text {
    display: flex;
    font-family: var(--text-font);
    font-size: 0.9rem;
    line-height: 1.2rem;
    font-weight: 300;
    text-decoration: none;
    color: var(--main-text-color);
    margin: 0 0px 10px 0;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    justify-content: flex-start;
}

    .detail-text.notes {
        width: 100%;
        /*max-width: 260px;*/
        justify-content: flex-start;
    }

    .detail-text.partner {
        margin-top: 10px;
        color: var(--gray-text-color);
        text-transform: uppercase;
        font-size: 1rem;
        line-height: normal;
        font-weight: 600;
    }

.detail-title {
    font-family: var(--std-font);
    font-size: 1.7rem;
    line-height: normal;
    font-weight: 600;
    margin: 0px 0;
}

.okay {
    width: calc(100% - 20px);
    height: 40px;
    min-height: 40px;
    margin: 10px 0;
    padding: 0 10px;
    background-color: mediumseagreen;
    color: #fff;
    border-radius: 5px;
    font-family: var(--std-font);
    font-size: 18px;
    line-height: 40px;
    font-weight: 600;
}

.detail-instructions {
    font-family: var(--text-font);
    font-size: 0.9rem;
    line-height: 1.3rem;
    font-weight: 400;
    color: var(--gray-text-color);
    margin: 10px 0px 10px 0px;
    padding: 5px 0 0 0;
    border-top: 1px solid var(--lines-color);
    text-transform: uppercase;
}

.detail-map {
    margin: 10px 0 20px 0;
    border: 1px solid var(--lines-color);
    border-radius: 4px;
    border: none;
    width: 100%;
    min-height: 300px;
    box-shadow: 0 2px 2px rgba(0, 0, 0, 0.2);
    -moz-box-shadow: 0 2px 2px rgba(0, 0, 0, 0.2);
    -webkit-box-shadow: 0 2px 2px rgba(0, 0, 0, 0.2);
}

    .detail-map.customAddress {
        margin: 0;
        width: 100%;
        height: 100%;
        border: 1px solid var(--lines-color);
    }

.MsoNormal {
    font-family: var(--text-font);
}

.detail-description {
    font-family: var(--text-font);
    font-size: 0.9rem;
    line-height: 1.3rem;
    font-weight: 400;
    margin: 0 0 20px 0;
    text-align: justify;
    text-justify: auto;
}

    .detail-description ul {
        list-style-type: square;
    }

    .detail-description li {
        margin-left: 20px;
    }

.makeorder-disclaimer {
    font-family: var(--text-font);
    font-size: 10px;
    line-height: 13px;
    font-weight: 300;
    text-align: justify;
    margin: 10px 0;
}

#dummyspace {
    height: 60px;
}

@media screen and (max-width : 767px) {
    #username {
        display: none;
    }

    #right-panel {
        padding: 0;
        border: none;
    }

    #dummyspace {
        height: 0px;
    }

    .detail-container {
        display: flex;
        flex-direction: column;
        justify-content: flex-start;
        align-items: flex-start;
        min-height: calc(100vh - 60px);
        width: 100%;
        padding: 100px 0 0 0;
    }

    .detail-info, .detail-info.quotation {
        display: flex;
        flex-direction: column;
        justify-content: center;
        align-items: center;
        width: calc(100% - 40px);
        min-width: unset;
        height: auto;
        margin: 20px 20px 10px 20px;
        font-family: var(--text-font);
        font-size: 2.2rem;
        line-height: 2.5rem;
        font-weight: 300;
        color: var(--main-text-color);
    }

    .column-container {
        display: flex;
        flex-direction: column;
        justify-content: center;
        align-items: center;
        width: calc(100% - 40px);
        min-width: unset;
        height: auto;
        margin: 10px 20px;
    }

    .detail-row-container {
        min-width: unset;
        width: 100%;
        margin: 0;
    }

    .detail-text.notes {
        max-width: calc(85vw - 2px);
    }

    .detail-title, .detail-description, .detail-text {
        width: calc(100% - 20px);
        margin-left: 0px;
        margin-right: 0px;
    }

    .detail-instructions {
        width: calc(100% - 20px);
        margin-left: 0px;
        margin-right: 0px;
    }

    .detail-card {
        width: 100%;
        /*min-width: 276px;
        max-width: 300px;
        margin: 100px 0 20px 0;*/
    }

    .detail-description {
        font-size: 2.4vh;
        line-height: 3vh;
    }
}

@media screen and (max-width : 767px) {

    .left-div-open {
        position: relative;
        display: flex;
        flex-direction: column;
        align-items: center;
        top: 0px;
        left: 0px;
        z-index: 10;
        width: 100vw;
        min-width: 100vw;
        max-width: 100vw;
        min-height: 100vh;
        background-color: var(--left-div-bg-color);
        color: var(--left-div-text-color);
    }

    .left-div-content {
        position: relative;
        width: calc(100vw - 60px);
        max-width: 300px;
        padding: 100px 30px 30px 30px;
    }

    .div-closed {
        display: none;
    }
}


/******************* SPECIAL VENDORS **************************/

.special-vendor-img {
    display: flex;
    width: 240px;
    max-width: 240px;
    min-height: 240px;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    padding: 0;
    margin: 20px;
    border: 1px solid var(--lines-color);
    border-radius: 6px;
    background-color: #fff;
    box-shadow: 0 2px 2px rgba(0, 0, 0, 0.2);
    -moz-box-shadow: 0 2px 2px rgba(0, 0, 0, 0.2);
    -webkit-box-shadow: 0 2px 2px rgba(0, 0, 0, 0.2);
    cursor: pointer;
}

    .special-vendor-img:hover {
        margin-top: 10px;
        box-shadow: 0 12px 16px rgba(0, 0, 0, 0.2);
        -moz-box-shadow: 0 12px 16px rgba(0, 0, 0, 0.2);
        -webkit-box-shadow: 0 12px 16px rgba(0, 0, 0, 0.2);
    }



/***************** MENU LEFT PANEL **********************/

.menu-item {
    display: flex;
    flex-direction: row;
    padding: 8px 0;
    margin: 5px;
    width: auto;
    /*max-width: 20px;*/
    overflow: hidden;
    background-color: transparent;
    color: var(--left-div-text-color);
    border-bottom: 1px solid var(--lines-color);
    cursor: pointer;
    text-align: left;
}

    .menu-item:hover {
        background-color: transparent;
        color: var(--brand-color);
        border-bottom: 1px solid;
    }

    .menu-item.active {
        background-color: transparent;
        color: var(--brand-color);
        border-bottom: 1px solid;
    }

a.menu {
    text-decoration: none;
}

.menu-icon {
    display: block;
    align-items: center;
    text-align: left;
    padding: 0 10px 0 0;
    font-size: 17px;
    width: 30px;
}

.menu-text {
    display: block;
    align-items: center;
    text-align: left;
    font-family: var(--std-font), var(--text-font), Arial;
    font-size: 17px;
    font-weight: 500;
    text-overflow: ellipsis;
    white-space: nowrap;
    overflow: hidden;
    max-width: 200px;
}


/******************* GUI COMPONENTS ********************/
.fullscreen {
    width: calc(100% - 60px);
}

.framebody {
    display: block;
    width: calc(100vw - 380px);
    max-width: 900px;
    overflow-y: auto;
    overflow-x: hidden;
    -webkit-overflow-scrolling: touch;
}

.row {
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    align-content: center;
    /*align-items: flex-start;*/
    width: 100%;
    height: auto;
}

.vmiddle {
    align-items: center;
}

.row-container {
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    align-content: center;
    width: 100%;
    height: auto;
    overflow-y: auto;
    margin: 0;
    overflow: hidden;
}

.row-nowrap {
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    align-content: center;
    width: 100%;
    height: auto;
}

.row-scroll {
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    align-content: center;
    width: 100%;
    height: auto;
    max-height: 250px;
    overflow-y: auto;
    margin: 0;
}

@media screen and (max-width : 1024px) {
    .framebody {
        max-width: calc(100% - 80px);
    }

    .row-container {
        display: flex;
        flex-direction: column;
        justify-content: center;
        align-content: center;
        width: 100%;
        /*padding: 0 20px;*/
    }
}

@media screen and (max-width : 767px) {
    .framebody {
        width: 100%;
        /*flex-direction: column;
        overflow: auto;
        -webkit-overflow-scrolling: touch;*/
        max-width: calc(100% - 40px);
    }

    .row {
        display: flex;
        flex-direction: column;
        justify-content: center;
        align-content: center;
        align-items: flex-start;
        width: 100%;
    }

    .row-centered {
        display: flex;
        flex-direction: column;
        justify-content: center;
        align-content: center;
        width: 100%;
    }

    .centered {
        display: flex;
        flex-direction: row;
        justify-content: center;
        align-content: center;
        width: 100%;
    }
}

.sectionTitle {
    font-family: var(--std-font) !important;
    font-size: 28px;
    font-weight: 600;
    margin: 30px 0 20px 0;
    color: var(--titles-color);
}

.sectionSubtitle {
    font-family: var(--std-font);
    font-size: 18px;
    font-weight: 500;
    margin: 10px 0;
    color: var(--titles-color);
}

.row-totals {
    display: flex;
    flex-direction: row;
    width: 300px;
}

.normalText {
    font-family: var(--text-font);
    font-size: 16px;
    line-height: 18px;
    font-weight: 500;
}

.bigText {
    font-size: 28px;
    font-weight: 500;
}

.condensedText {
    font-family: var(--condensed-font);
    font-size: 18px;
    font-weight: 300;
}

.monospaceText {
    font-family: var(--monospace-font);
    font-size: 16px;
    font-weight: 300;
}

@media screen and (max-width : 760px) {
    .normalText {
        font-size: 16px;
        font-weight: 400;
        margin-top: 10px;
    }

    .bigText {
        font-size: 19px;
        font-weight: 500;
    }
}

.successo {
    width: calc(100% - 20px);
    padding: 10px;
    margin: 10px 0px;
    font-size: 20px;
    font-weight: 500;
    background-color: var(--chartColor6);
    color: #fff;
    border-radius: 4px;
}

.saldo {
    display: flex;
    flex-direction: column;
    font-family: var(--text-font);
    background-color: var(--brand-color);
    color: var(--reverse-text-color);
    border: 1px solid var(--brand-color);
    border-radius: 4px;
    padding: 20px;
    align-items: center;
}

.search {
    width: calc(100% - 42px);
    background: var(--input-bg-color) url(/images/search.png) left no-repeat;
    background-size: 18px;
    background-position-x: 10px;
    background-position-y: 10px;
    padding-left: 35px;
}

.date {
    width: calc(100% - 12px);
    background: var(--input-bg-color) url(/images/calendar.png) right no-repeat;
    background-size: 18px;
    background-position-x: calc(100% - 10px);
    padding: 5px;
    cursor: pointer;
}

.euro {
    width: calc(100% - 42px);
    background: var(--input-bg-color) url(/images/euro.png) left no-repeat;
    background-size: 16px;
    background-position-x: 5px;
    background-position-y: 10px;
    padding-left: 35px;
}

.percent {
    width: calc(100% - 42px);
    background: var(--input-bg-color) url(/images/percent.png) left no-repeat;
    background-size: 16px;
    background-position-x: 5px;
    background-position-y: 10px;
    padding-left: 35px;
}

.pwd {
    width: calc(100% - 42px);
    background: var(--input-bg-color) url(/images/key.png) left no-repeat;
    background-size: 16px;
    background-position-x: 7px;
    background-position-y: 10px;
    padding-left: 37px;
}

.employee-status, .stato-pratica {
    width: auto;
    margin-left: auto;
    margin-right: 10px;
    background-color: var(--brand-color);
    border-radius: 4px;
    padding: 5px 10px;
    color: var(--reverse-text-color);
    font-family: var(--text-font);
    font-size: 18px;
    /*min-width: 120px;*/
    text-align: center;
}

@media screen and (max-width : 760px) {
    .employee-status, .stato-pratica {
        margin: 15px 0 0 0;
    }
}

/*********************PROGRESS BAR *************************/
.progressbar-container {
    width: 100%;
    margin: 20px 0;
    justify-content: center;
}

.progressbar {
    counter-reset: step;
    width: 100%;
}

    .progressbar li {
        list-style-type: none;
        width: 33%;
        float: left;
        font-family: var(--text-font);
        font-size: 12px;
        position: relative;
        text-align: center;
        text-transform: uppercase;
        color: var(--gray-text-color);
    }

    .progressbar.three-steps li {
        width: 33%;
    }

    .progressbar.four-steps li {
        width: 25%;
    }

    .progressbar.five-steps li {
        width: 20%;
    }

    .progressbar li:before {
        width: 30px;
        height: 30px;
        content: counter(step);
        counter-increment: step;
        line-height: 30px;
        border: 2px solid var(--gray-text-color);
        display: block;
        text-align: center;
        margin: 0 auto 10px auto;
        border-radius: 50%;
        -webkit-border-radius: 50%;
        -moz-border-radius: 50%;
        background-color: #FFF;
        position: relative;
        z-index: 1;
    }

    .progressbar li:after {
        width: 100%;
        height: 2px;
        content: '';
        position: absolute;
        background-color: var(--gray-text-color);
        top: 15px;
        left: -50%;
    }

    .progressbar li:first-child:after {
        content: none;
    }

    .progressbar li.active {
        color: var(--brand-color);
    }

        .progressbar li.active:before {
            border-color: var(--brand-color);
        }

        .progressbar li.active + li:after {
            background-color: var(--brand-color);
        }


@media screen and (max-width : 900px) {
    .progressbar li {
        font-size: 10px;
    }
}


.stepsContainer {
    display: flex;
    flex-direction: row;
    width: 100%;
    align-items: flex-start;
}

@media screen and (max-width : 767px) {
    .stepsContainer {
        display: flex;
        flex-direction: column;
        /*justify-content: center;
        align-content: center;
        align-items: flex-start;*/
        width: 100%;
    }
}

.stepNumber {
    display: inline-block;
    text-align: center;
    min-width: 22px;
    min-height: 14px;
    border: 1px solid;
    border-radius: 50%;
    -webkit-border-radius: 50%;
    -moz-border-radius: 50%;
    margin: 0 10px 5px 0;
    padding: 1px;
    font-size: 13px;
}

.step {
    width: 100%;
    background-color: transparent;
    height: 30px;
    color: var(--gray-text-color);
    border-bottom: 7px solid var(--lines-color);
    margin: 10px 5px 10px 0;
    text-align: left;
    line-height: 20px;
    padding: 5px 0;
}

    .step i {
        font-size: 24px;
        margin-right: 5px;
    }

    .step.attuale {
        color: var(--brand-color);
        border-bottom: 7px solid var(--brand-color);
        font-weight: 500;
    }

    .step.done {
        color: var(--brand-color);
        border-bottom: 7px solid var(--brand-color);
    }

    .step.last {
        margin-right: 0px;
    }

.hint {
    display: block;
    list-style-type: decimal;
    margin: 0;
    padding: 0 10px 0 25px;
    text-align: left;
    color: var(--gray-text-color);
    font-weight: 500;
}

    .hint > li {
        /*list-style: decimal !important;*/
        margin-bottom: 7px;
        font-size: 13px;
    }

    .hint.attuale {
        color: var(--main-text-color);
        font-weight: 500;
    }

/****************** USER PHOTO **********************/


.previewFoto {
    width: 150px;
    height: 150px;
    margin: 10px 0;
    border: 1px solid var(--lines-color);
    /*border-radius: 50% !important;
        -webkit-border-radius: 50% !important;
        -moz-border-radius: 50% !important;*/
    border-radius: 4px !important;
    -webkit-border-radius: 4px !important;
    -moz-border-radius: 4px !important;
    background-position: center;
    background-size: contain;
    background-repeat: no-repeat;
    justify-content: center;
    text-align: center;
    overflow: hidden;
    position: relative;
    cursor: move;
}

.change-image {
    display: block;
    background-color: rgba(0, 0, 0, 0.1);
    color: #fff;
    z-index: 9999;
    position: absolute;
    top: 0;
    right: 0;
    border: none;
    cursor: pointer;
    text-align: center;
    width: 34px;
    height: 34px;
    padding: 5px;
    text-align: right;
    font-size: 24px;
}

    .change-image:hover {
        background-color: var(--brand-color);
        /*background-color: var(--std-button-color) !important;
        color: var(--std-button-text-color);
        z-index: 9999;
        position: absolute;
        padding: 10px 0;
        border-radius: 4px 4px 0 0;
        cursor: pointer;
        font-size: 24px;
        font-family: var(--text-font);
        font-weight: bold;*/
    }

.noimage {
    background-color: transparent;
    width: 100%;
    height: 100%;
    display: inline-flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    text-align: center;
    position: absolute;
    top: 0;
    left: 0;
    padding: 10px 0;
    cursor: pointer;
    opacity: 1;
    color: gray;
    font-size: 12px;
}

.cr-viewport, .cr-overlay, .cr-boundary {
    width: 100% !important;
    height: 100% !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    position: absolute !important;
    /*border-radius: 50%;
        -webkit-border-radius: 50%;
        -moz-border-radius: 50%;*/
    border-radius: 4px !important;
    -webkit-border-radius: 4px !important;
    -moz-border-radius: 4px !important;
    overflow: hidden !important;
}

@media screen and (max-width : 900px) {
    .previewFoto {
        border-radius: 4px !important;
        -webkit-border-radius: 4px !important;
        -moz-border-radius: 4px !important;
    }

    .cr-viewport, .cr-overlay, .cr-boundary {
        border-radius: 4px !important;
        -webkit-border-radius: 4px !important;
        -moz-border-radius: 4px !important;
    }
}

.previewLogo {
    width: 100%;
    height: 60px;
    margin: 0;
    border: none;
    border-radius: 4px !important;
    justify-content: center;
    text-align: center;
    overflow: hidden;
    position: relative;
    cursor: pointer;
    background-position: left;
    background-size: auto 50px;
    background-repeat: no-repeat;
}

.previewLogoSupplier {
    width: 200px;
    height: 200px;
    margin: 10px 0;
    border: 1px solid var(--lines-color);
    border-radius: 4px !important;
    -webkit-border-radius: 4px !important;
    -moz-border-radius: 4px !important;
    background-position: center;
    background-size: contain;
    background-repeat: no-repeat;
    justify-content: center;
    text-align: center;
    overflow: hidden;
    position: relative;
    cursor: move;
}

.previewCardImage {
    width: 100%;
    height: 0;
    padding-top: 100%;
    /*min-width: 268px;*/
    /*min-height: 100px;*/
    margin: 0px;
    border: 1px solid var(--lines-color);
    border-radius: 4px !important;
    -webkit-border-radius: 4px !important;
    -moz-border-radius: 4px !important;
    background-position: center;
    background-size: contain;
    background-repeat: no-repeat;
    justify-content: center;
    text-align: center;
    overflow: hidden;
    position: relative;
    cursor: move;
}

@media screen and (max-width : 767px) {
    .previewCardImage {
        min-width: unset;
        width: calc(100% - 2px);
        margin-bottom: 20px;
    }
}

.previewBanner {
    width: 100%;
    /*min-height: 253px;*/
    border: 1px solid var(--lines-color);
    border-radius: 4px !important;
    -webkit-border-radius: 4px !important;
    -moz-border-radius: 4px !important;
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
    justify-content: center;
    text-align: center;
    overflow: hidden;
    position: relative;
    cursor: pointer;
}

    .previewBanner.portrait {
        width: 100%;
        padding-top: 177.86%;
    }

    .previewBanner.landscape {
        width: 100%;
        padding-top: 48.9%;
    }

/***************** FILE UPLOAD *******************/

.name-file {
    display: inline-block;
    border: 1px solid var(--lines-color);
    border-radius: .4rem;
    -webkit-border-radius: .4rem;
    -moz-border-radius: .4rem;
    font-size: 16px;
    padding: 8px;
    font-family: var(--text-font);
    text-decoration: none;
    text-align: left !important;
    background: #fff;
    color: var(--main-text-color);
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    outline: none;
    text-transform: lowercase;
    width: 100%;
    min-width: 150px;
    /*max-width: 270px;*/
}


/***************** customize colors *******************/

.colorbox {
    height: 30px;
    padding: 5px;
    background-color: transparent;
    color: #000;
    cursor: pointer;
}


/*******************   DASHBOARD CHARTS ******************/
.myKPI {
    height: auto;
    min-height: 30px;
    margin: 0px 10px;
    color: #fff;
    border-radius: 5px;
    font-family: var(--std-font);
    font-size: 34px;
    box-shadow: 2px 2px 2px rgba(0, 0, 0, 0.2);
    -moz-box-shadow: 2px 2px 2px rgba(0, 0, 0, 0.2);
    -webkit-box-shadow: 2px 2px 2px rgba(0, 0, 0, 0.2);
    text-align: center;
    padding: 20px 0;
}

.iconKPI {
    color: rgba(255,255,255,0.5);
    margin-right: 20px;
}

.big {
    font-size: 48px;
}

.transparentText {
    color: rgba(255,255,255,0.5);
}

.warning {
    width: calc(100% - 60px);
    height: 40px;
    min-height: 40px;
    margin: 0 10px;
    padding: 0 10px 0 20px;
    background-color: var(--warning);
    color: #fff;
    border-radius: 5px;
    font-family: var(--std-font);
    font-size: 18px;
    line-height: 40px;
    font-weight: 600;
    border-left: 10px solid rgba(255,255,255,0.5);
    box-shadow: 2px 2px 2px rgba(0, 0, 0, 0.2);
    -moz-box-shadow: 2px 2px 2px rgba(0, 0, 0, 0.2);
    -webkit-box-shadow: 2px 2px 2px rgba(0, 0, 0, 0.2);
    text-overflow: ellipsis;
    white-space: nowrap;
    overflow: hidden;
}

    .warning > i {
        font-size: 22px;
        padding-right: 15px;
    }

    .warning.noncritical {
        background-color: var(--brand-color) !important;
    }

    .warning.attention {
        background-color: var(--enphasys-color) !important;
    }

.infoPopup {
    position: relative;
    width: calc(100% - 80px);
    height: auto;
    min-height: 40px;
    margin: 0 0 0 20px;
    padding: 60px 20px 20px 20px;
    background-color: var(--warning-transparent);
    color: #333;
    border-radius: 5px;
    font-family: var(--text-font);
    font-size: 18px;
    line-height: normal;
    font-weight: 500;
    /*box-shadow: 2px 2px 2px rgba(0, 0, 0, 0.2);
    -moz-box-shadow: 2px 2px 2px rgba(0, 0, 0, 0.2);
    -webkit-box-shadow: 2px 2px 2px rgba(0, 0, 0, 0.2);*/
}

    .infoPopup.title {
        position: absolute;
        top: 0;
        left: 0;
        width: calc(100% - 20px);
        height: 30px;
        min-height: 30px;
        margin: 0;
        padding: 5px 10px;
        background-color: var(--warning);
        color: #fff;
        border-radius: 5px 5px 0 0;
        font-family: var(--std-font);
        font-size: 22px;
        line-height: normal;
        font-weight: 600;
        box-shadow: none;
        -moz-box-shadow: none;
        -webkit-box-shadow: none;
        z-index: 10;
    }

.myChart {
    height: auto;
    min-height: 300px;
    margin: 0px 10px;
    color: #fff;
    border-radius: 6px;
    font-family: var(--std-font);
    font-size: 18px;
    /*box-shadow: 4px 4px 2px rgba(0, 0, 0, 0.2);
    -moz-box-shadow: 4px 4px 2px rgba(0, 0, 0, 0.2);
    -webkit-box-shadow: 4px 4px 2px rgba(0, 0, 0, 0.2);*/
}

    .myChart a {
        color: #fff;
        text-decoration: none;
        -webkit-appearance: none;
        -moz-appearance: none;
        appearance: none;
        outline: none;
    }

.Chart1 {
    background-color: var(--chartColor1);
}

.Chart2 {
    background-color: var(--chartColor2);
}

.Chart3 {
    background-color: var(--chartColor3);
}

.Chart4 {
    background-color: var(--chartColor4);
}

.Chart5 {
    background-color: var(--chartColor5);
}

.Chart6 {
    background-color: var(--chartColor6);
}

.Chart7 {
    background-color: var(--chartColor7);
}

.Chart8 {
    background-color: var(--chartColor8);
}

.Chart9 {
    background-color: var(--chartColor9);
}

.Chart10 {
    background-color: var(--chartColor10);
}

.Chart11 {
    background-color: var(--chartColor11);
}

.Chart12 {
    background-color: var(--chartColor12);
}

.dashboard-data {
    position: relative;
    height: 100%;
    text-align: left;
    margin: 0 20px 10px 20px;
    width: calc(100% - 40px);
    overflow: hidden;
}

.dashboard-title {
    text-align: left;
    font-family: var(--std-font);
    font-size: 26px;
    font-weight: 500;
    margin: 20px 20px 10px 20px;
    width: calc(100% - 40px);
    overflow: hidden;
}

.dashboard-subtitle {
    font-family: var(--text-font);
    font-size: 13px;
    font-weight: 500;
    margin: 5px 20px 0px 20px;
    width: calc(100% - 40px);
    opacity: 0.6;
}

.dashboard-text {
    font-family: var(--text-font);
    font-size: 18px;
    font-weight: 500;
    margin: 0px 20px;
    width: calc(100% - 40px);
}

    .dashboard-text.news {
        color: var(--main-text-color);
        font-family: var(--text-font);
        font-size: 13px;
        font-weight: 500;
        margin: 0px 30px;
        width: calc(100% - 60px);
        line-height: 16px;
        text-align: justify;
    }

@media screen and (max-width : 768px) {
    .myChart, .myKPI {
        margin: 15px 0px;
    }

    .warning {
        width: calc(100% - 50px);
        margin: 15px 0;
    }

    .infoPopup {
        width: calc(100% - 60px);
        margin: 10px;
    }

    .dashboard-text.news {
        color: var(--main-text-color);
        font-family: var(--text-font);
        font-size: 14px;
        font-weight: 500;
        margin: 10px 20px;
        width: calc(100% - 20px);
        height: auto;
    }
}

/********** Subscrption card ************/
.piano {
    background-color: var(--card-bg-color);
    border: 1px solid var(--lines-color);
    border-radius: 5px;
    width: 280px;
    height: 360px;
    margin: 10px;
    text-align: center;
    box-shadow: 0 2px 2px rgba(0, 0, 0, 0.2);
    -moz-box-shadow: 0 2px 2px rgba(0, 0, 0, 0.2);
    -webkit-box-shadow: 0 2px 2px rgba(0, 0, 0, 0.2);
}


.titolo-piano {
    border-radius: 5px 5px 0 0;
    height: 40px;
    line-height: 40px;
    background: var(--brand-color);
    color: var(--reverse-text-color);
    font-family: var(--std-font);
    font-weight: 500;
    font-size: 1.5rem;
    text-align: center;
}

.prezzo-piano {
    height: 50px;
    color: var(--main-text-color);
    font-family: var(--std-font);
    font-weight: 500;
    font-size: 1.8rem;
    margin: 20px 10px 20px 10px;
    line-height: 2rem;
}

.descrizione-piano {
    height: 140px;
    color: var(--main-text-color);
    font-family: var(--std-font);
    font-weight: 300;
    font-size: 1.2rem;
    margin: 20px;
    text-align: center;
}

/********************* LOGIN ***************************/

.login-page {
    width: 100vw;
    height: 100vh;
    display: flex;
    flex-direction: row;
    justify-content: center;
    align-items: center;
    margin: 0;
    overflow: auto;
}


.login-container {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: flex-start;
    height: 100%;
    min-height: 700px;
    width: 50vw;
    overflow: hidden;
    padding: 50px;
}

.loginbox {
    display: flex;
    flex-direction: column;
    justify-content: center;
    width: 380px;
    max-width: 380px;
    height: auto;
    background-color: #FFF;
    color: var(--main-text-color);
    margin: 0;
    padding: 30px;
    border-radius: 4px;
    -webkit-border-radius: 4px;
    -moz-border-radius: 4px;
    box-shadow: 0 12px 16px rgba(0, 0, 0, 0.2);
    -moz-box-shadow: 0 12px 16px rgba(0, 0, 0, 0.2);
    -webkit-box-shadow: 0 12px 16px rgba(0, 0, 0, 0.2);
}

.small-text {
    font-family: var(--text-font) !important;
    font-size: 12px !important;
}

@media screen and (max-width : 1024px) {
    .small-text {
        font-size: 10px;
    }
}

.sectionLogo {
    width: 100%;
    height: 80px;
    background: url(/images/logo-small.png) no-repeat;
    background-size: auto 50px;
    background-position: center;
}

@media screen and (max-width : 768px) {
    .login-page {
        width: 100vw;
        height: calc(100vh - 20px);
        background-image: none;
        background-color: var(--main-bg-color);
        overflow: hidden;
    }

    .login-container {
        display: flex;
        flex-direction: column;
        justify-content: center;
        align-items: center;
        height: 100%;
        min-height: 100vh;
        width: 100vw;
        padding: 0px;
        background-color: #fff;
    }

    .loginbox {
        display: flex;
        align-content: center;
        width: 100vw;
        max-width: 310px;
        height: auto;
        margin: 0;
        padding: 0;
        left: unset;
        border: none;
        background-color: transparent;
        box-shadow: unset;
        -moz-box-shadow: unset;
        -webkit-box-shadow: unset;
    }


    .sectionLogo {
        width: 100%;
        height: 42px;
        margin-top: 40px;
        background-size: auto 40px;
        background-position: center;
    }
}


.validation-summary-errors li {
    font-family: var(--text-font);
    font-weight: 400;
    color: red;
    list-style: none;
}

.validation-summary-errors {
    font-family: var(--text-font);
    font-weight: 400;
    color: red;
    list-style: none;
}

/****************** REGISTRATION *****************/

.user-img,
.supplier-img,
.consultant-img,
.employee-img {
    background-position: center;
    background-repeat: no-repeat;
    background-size: contain;
    height: 100px;
    width: 100%;
    margin: 20px 0 0 0;
}

.consultant-img {
    background-image: url(/images/registration/icone_studio.png);
}

.employee-img {
    background-image: url(/images/registration/employee.png);
}

.supplier-img {
    background-image: url(/images/registration/icona_fornitore.png);
}

.user-img {
    background-image: url(/images/registration/icona_impresa.png);
}

.register-text {
    align-items: flex-start;
    height: 100px;
    margin: 20px;
    font-size: 16px;
}

.with-border {
    margin: 0;
    border-right: 1px solid var(--lines-color);
}

@media screen and (max-width : 760px) {
    .with-border {
        border-right: none;
        border-bottom: 1px solid var(--lines-color);
    }

    .register-text {
        align-items: flex-start;
        height: auto;
        margin: 40px 20px;
        font-size: 16px;
    }
}

/************************* ADV DASHBOARD EMPLOYEE ****************************/

#employeeSlider {
    height: calc((50vw - 100px) * 0.5625);
    min-height: 330px;
    max-height: calc((100vw - 100px) / 4);
    overflow: hidden;
}

.slideDiv {
    height: calc((50vw - 100px) * 0.5625);
    min-height: 330px;
    max-height: calc((100vw - 100px) / 4);
}

#advSlides {
    width: 100%;
    height: 100%;
    position: relative;
    margin: 0px;
    padding: 0px;
    border-radius: 6px;
    overflow: hidden;
}

@media screen and (max-width : 1024px) {
    #employeeSlider {
        width: calc(100vw - 10px);
        height: calc((100vw - 10px) / 2.04);
    }
}


@media screen and (max-width : 767px) {
    #employeeSlider {
        width: calc(100vw - 20px);
        height: calc((100vw - 20px) / 2.04);
        min-height: unset;
        max-height: unset;
        margin: 0px;
        overflow: hidden;
    }

    .slideDiv {
        /*width: calc(100vw - 20px);*/
        height: calc(100vw - 20px);
        min-height: calc(100vw - 20px);
    }
}

.advSlide {
    display: block;
    position: absolute;
    left: 0;
    top: 0;
    margin: 0;
    padding: 0;
    width: 100%;
    height: 100%;
    text-align: center;
    background-size: cover;
    background-position: center;
    color: #fff;
    border-radius: 6px;
    cursor: pointer;
    z-index: 0;
}

    .advSlide a {
        text-decoration: none;
        -webkit-appearance: none;
        -moz-appearance: none;
        appearance: none;
        outline: none;
        color: var(--reverse-text-color);
    }


.advImage {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-size: cover;
    background-position: center;
}

.shadowed {
    background-color: rgba(0,0,0,0.3);
}

.dashboard-container {
    margin-top: 100px;
    display: flex;
    flex-direction: column;
    width: 100%;
    min-width: 100%;
    min-height: calc(100vh - 160px);
    background-color: var(--main-bg-color);
    color: var(--main-text-color);
}

.space-left-right {
    width: calc(100% - 20px) !important;
    margin: 0px 10px 0px 10px;
}

@media screen and (max-width: 1024px) {
    .space-left-right {
        width: calc(100% - 20px) !important;
        padding: 0;
        margin: 0px 10px;
    }
}

/*@media screen and (orientation: portrait) {
        .banner-portrait {
            display: block;
        }

        .banner-landscape {
            display: none;
        }
    }

    @media screen and (orientation: landscape) {
        .banner-portrait {
            display: none;
        }
    }*/



.defaultOrderImg {
    position: relative;
    overflow: hidden;
    background-color: rgba(255, 255, 255, 1);
    background-image: url(/images/logo.png);
    background-position: center;
    background-size: 90%;
    background-repeat: no-repeat;
    width: 84px;
    min-width: 84px;
    height: 84px;
    min-height: 84px;
    margin: 10px 10px 0 20px;
    border: 2px solid rgba(255, 255, 255, 1);
    border-radius: 4px;
    -webkit-border-radius: 4px;
    -moz-border-radius: 4px;
    padding: 0px;
}

.myOrderImg {
    position: absolute;
    top: 0;
    left: 0;
    /*background: rgba(255, 255, 255, 0.5);*/
    width: 84px;
    height: 84px;
    /*margin: 10px 10px 0 20px;*/
    /*border: 3px solid rgba(255, 255, 255, 1);*/
    border-radius: 4px;
    -webkit-border-radius: 4px;
    -moz-border-radius: 4px;
    padding: 0px;
}

.myOrdersDetails {
    display: flex;
    flex-direction: column;
    /*width: 100%;*/
    text-align: left;
    justify-content: center;
    /*align-items: flex-start;*/
    /*height: 100px;*/
    /*line-height: 14px;*/
    /*margin: 5px 0 0 0;*/
}

.myPersonalInfo {
    display: flex;
    flex-direction: row;
    justify-content: flex-start;
    flex-wrap: nowrap;
    width: 100%;
    text-decoration: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    outline: none;
}

.myPhoto {
    background: rgba(255, 255, 255, 0.3);
    width: 84px;
    min-width: 84px;
    height: 84px;
    margin: 20px 10px 10px 20px;
    border: 3px solid #fff;
    border-radius: 50%;
    -webkit-border-radius: 50%;
    -moz-border-radius: 50%;
    text-align: center;
    line-height: 50px;
    vertical-align: middle;
    padding: 0px;
    background-image: url(/images/user.svg);
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
}

.myDetails {
    display: flex;
    flex-direction: column;
    text-align: left;
    justify-content: center;
    align-items: flex-start;
    height: 100px;
    margin: 15px 0;
}

.dashboard-myOrdersContainer {
    display: flex;
    flex-direction: row;
    /*justify-content: flex-start;*/
    /*flex-wrap: nowrap;
    width: 100%;*/
}

.dashboard-myOrderName, .dashboard-boldText {
    font-family: var(--text-font);
    font-size: 13px;
    line-height: 14px;
    font-weight: bold;
    margin-bottom: 5px;
}

.dashboard-myOrderText, .dashboard-normalText {
    font-family: var(--text-font);
    font-size: 13px;
    line-height: 14px;
    margin-bottom: 3px;
    font-weight: 300;
}



.dashboard-icon {
    font-size: 40px;
    color: rgba(255,255,255,0.5);
    margin: 20px 0;
}

.cornice {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-content: center;
    align-items: center;
    width: 70%;
    max-width: 800px;
    height: 30vh;
    max-height: 300px;
    color: #fff;
    padding: 10px;
    border: 1px solid #FFF;
}

@media screen and (max-width : 760px) {
    .cornice {
        border: none;
    }
}

.scopri {
    display: inline-block;
    border: 1px solid #FFF;
    border-radius: 4px;
    -webkit-border-radius: 4px;
    -moz-border-radius: 4px;
    font-size: 20px;
    line-height: 20px;
    padding: 10px 15px;
    margin-top: 20px;
    cursor: pointer;
    width: auto;
    max-width: 250px;
    height: auto;
    font-family: var(--std-font), var(--text-font);
    text-decoration: none;
    letter-spacing: 2px;
    text-align: center !important;
    background: transparent;
    color: #FFF;
    font-weight: 500;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    outline: none;
    text-transform: uppercase;
}

    .scopri:hover {
        background: #FFF;
        color: #333;
    }

/******************** CONVENZIONI NON ATTIVE ******************/

.backgroundFull {
    display: flex;
    flex-direction: row;
    justify-content: center;
    align-items: center;
    margin: 80px 0 0 0;
    padding: 0;
    width: 100%;
    height: calc(100vh - 140px);
    text-align: center;
    background-size: cover;
    background-position: 50% 50%;
    color: #fff;
    font-family: var(--std-font);
    font-size: 3vh;
}

.PayoffCentrale {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    padding: 0 30px;
    width: calc(100% - 60px);
    height: calc(100vh - 140px);
    font-family: var(--std-font);
    font-size: 4vh;
    justify-content: center;
    align-content: center;
    font-weight: 600;
}

/******************* SEZIONE HTML TEXT EDITOR *****************/

.htmleditor *[ng-click] {
    cursor: pointer;
}

.htmleditor {
    display: block;
    width: calc(100% - 2px);
    /*height: 310px;*/
    margin: 5px 5px 10px 0px;
    background-color: #fff;
    color: var(--main-text-color);
    border: 1px solid var(--lines-color);
    border-radius: 4px;
    pointer-events: none;
}

    .htmleditor [contenteditable] {
        height: 260px;
        pointer-events: auto;
        background-color: #fff;
        color: var(--main-text-color);
        overflow-y: auto;
        text-align: left;
        text-decoration: none;
        margin: 5px 5px 5px 5px;
        padding: 5px 5px 5px 5px;
        font-family: var(--text-font);
        font-size: 16px;
    }

        .htmleditor [contenteditable] ul {
            padding-left: 20px;
        }

        .htmleditor [contenteditable] ol {
            padding-left: 20px;
        }

        .htmleditor [contenteditable]:focus {
            -webkit-appearance: none;
            -moz-appearance: none;
            appearance: none;
            outline: none;
        }

    .htmleditor:hover {
        -webkit-appearance: none;
        -moz-appearance: none;
        appearance: none;
        outline: none;
        border: 1px solid var(--brand-color);
        border-radius: 4px;
    }



.html-editor-style-toolbar {
    padding: 5px 5px 5px 5px;
    pointer-events: auto;
}

    .html-editor-style-toolbar ul li {
        display: inline;
    }


/*********************************/
/*            Pricing            */
/*********************************/

.pricingTable {
    display: flex;
    flex-direction: row;
    width: 100%;
    align-content: center;
    align-items: flex-start;
    justify-content: center;
    flex-wrap: wrap;
}

.pricingTitle {
    font-family: var(--std-font);
    font-weight: 500;
    font-size: 3rem;
    line-height: 38px;
    color: #fff;
    text-align: center;
    margin: 120px 30px 0 30px;
}

.pricingSubTitle {
    font-family: var(--std-font);
    font-weight: 500;
    font-size: 18px;
    line-height: 28px;
    color: #fff;
    text-align: center;
    margin: 0;
}

.pricingPlan {
    position: relative;
    justify-content: center;
    text-align: center;
    background-color: #FFF;
    border: 1px solid #dbdbdb;
    border-radius: 6px;
    width: 290px;
    height: 500px;
    margin: 10px;
    box-shadow: 0 12px 16px rgba(0, 0, 0, 0.2);
    -moz-box-shadow: 0 12px 16px rgba(0, 0, 0, 0.2);
    -webkit-box-shadow: 0 12px 16px rgba(0, 0, 0, 0.2);
}

.pricingName {
    height: 40px;
    line-height: 40px;
    background: var(--brand-color);
    color: #fff;
    font-family: var(--std-font);
    font-weight: 500;
    font-size: 1.5rem;
    border-top-left-radius: 4px;
    border-top-right-radius: 4px;
    /*padding: 5px 5px 30px 5px;*/
}

.price {
    height: auto;
    max-height: 50px;
    color: #222222;
    font-family: var(--text-font);
    font-weight: 600;
    font-size: 40px;
    margin: 10px 10px 0px 10px;
}

.cents {
    font-size: 20px;
    font-weight: bold;
}

.priceDetail {
    height: auto;
    color: #333333;
    font-family: var(--text-font);
    font-weight: 300;
    font-size: 16px;
    line-height: 20px;
    margin: 10px 20px 0 20px;
    text-align: center;
}

.promo {
    width: 290px;
    font-family: var(--std-font);
    font-weight: 500;
    font-size: 16px;
    line-height: 22px;
    color: #fff;
    text-align: center;
    margin: 0;
}

@media screen and (max-width:768px) {

    .pricingPlan {
        width: calc(100% - 2px);
        max-width: 320px;
        margin: 0;
    }
}

@media screen and (max-width:1024px) {

    .pricingTable {
        width: 100%;
        max-width: 700px;
    }

    .pricingTitle {
        font-size: 2.1rem;
        text-align: center;
    }
}


/********************* SLIDER BAR **************************/

.optionTitle {
    color: var(--main-text-color);
    font-family: var(--std-font);
    font-weight: 500;
    font-size: 18px;
    margin: 15px 0 5px 0;
    /*margin: 30px 0 5px 25px;*/
    text-align: center;
}

.option {
    display: flex;
    flex-direction: row;
    /*justify-content: center;
    align-content: center;*/
    height: auto;
    margin: 0 0 0 25px;
}

.counter {
    font-family: var(--text-font);
    font-weight: 500;
    font-size: 30px;
    width: 90px;
    min-width: 90px;
    /*height: 100px;*/
    color: #333;
    border: 1px solid #ddd;
    border-radius: 5px;
    padding: 0px 10px;
    text-align: center;
}


input[type='range'] {
    -webkit-appearance: none;
    width: 250px;
    height: 35px;
    background-color: transparent;
    outline: none;
}

    input[type='range']::-webkit-slider-runnable-track {
        -webkit-appearance: none;
        appearance: none;
        border-radius: 5px;
        background: var(--bg-slider);
        outline: none;
        /*box-shadow: inset 1px 1px 1px rgba(000,000,000,0.10);*/
        height: 8px;
        vertical-align: middle;
        border: none;
        cursor: pointer;
    }

    input[type='range']::-webkit-slider-thumb {
        -webkit-appearance: none;
        border-radius: 100%;
        background-color: #00aade;
        /*box-shadow: inset 0 0 0 4px #CCC, inset 0 0 4px #CCC, inset 0 0 0 4px #CCC;*/
        height: 22px;
        width: 22px;
        vertical-align: middle;
        border: none;
        cursor: pointer;
        margin-top: -6px;
    }

        input[type='range']::-webkit-slider-thumb:hover {
            background: #00d7de;
        }

    input[type='range']:active::-webkit-slider-thumb {
        background: #00d7de;
    }

    input[type='range']::-moz-range-track {
        -moz-appearance: none;
        border-radius: 5px;
        /*box-shadow: inset 1px 1px 1px rgba(000,000,000,0.10);*/
        background-color: var(--bg-slider);
        height: 8px;
        vertical-align: middle;
        margin: 0;
        padding: 0;
        border: none;
        cursor: pointer;
    }

    input[type='range']::-moz-range-thumb {
        -moz-appearance: none;
        border-radius: 100%;
        background-color: #00aade;
        /*box-shadow: inset 0 0 0 4px #CCC, inset 0 0 4px #CCC, inset 0 0 0 4px #CCC;*/
        height: 22px;
        width: 22px;
        vertical-align: middle;
        border: none;
        cursor: pointer;
        margin-top: -6px;
    }

        input[type='range']::-moz-range-thumb:hover {
            background: #00d7de;
        }

    input[type='range']:active::-moz-range-thumb {
        background: #00d7de;
    }

input[type=range]::-ms-track {
    width: 100%;
    height: 8px;
    cursor: pointer;
    animate: 0.2s;
    background: transparent;
    border-color: transparent;
    /*border-width: 39px 0;*/
    color: transparent;
}

input[type=range]::-ms-fill-lower {
    background: #bbb;
    /*border: 0px solid #000101;*/
    border-radius: 5px;
    /*box-shadow: 0px 0px 0px #000000, 0px 0px 0px #0d0d0d;*/
}

input[type=range]::-ms-fill-upper {
    background: #ddd;
    /*border: 0px solid #000101;*/
    border-radius: 5px;
    /*box-shadow: 0px 0px 0px #000000, 0px 0px 0px #0d0d0d;*/
}

input[type=range]::-ms-thumb {
    /*box-shadow: inset 0 0 0 4px #CCC, inset 0 0 4px #CCC, inset 0 0 0 4px #CCC;*/
    /*border: 0px solid #000000;*/
    height: 22px;
    width: 22px;
    border-radius: 100%;
    background: #00aade;
    cursor: pointer;
    margin-top: -2px;
}

/********************************  FAQ  **************************************/

.accordion {
    background-color: transparent;
    color: #444;
    cursor: pointer;
    padding: 18px 0;
    width: calc(100% - 15px);
    text-align: left;
    border: none;
    outline: none;
    transition: 0.4s;
    font-family: var(--std-font);
    font-size: 18px;
    font-weight: 600;
    line-height: 20px;
}

    .accordion.active, .accordion:hover {
        color: var(--brand-color);
    }

    .accordion:after {
        content: "\f105";
        font-family: "Font Awesome 6 Pro";
        font-size: 20px;
        color: #777;
        float: right;
        margin-left: 20px;
    }

    .accordion.infoarrow:after {
        content: "\f059";
        font-family: "Font Awesome 6 Pro";
        font-size: 20px;
        color: #777;
        float: right;
        margin-left: 20px;
    }

    .accordion.active:after {
        content: "\f107";
    }

    .accordion.infoarrow.active:after {
        content: "\f059";
        font-family: "Font Awesome 6 Pro";
        color: #777;
        font-weight: 400;
        float: right;
        margin-left: 20px;
    }

    .accordion.not-clickable {
        cursor: initial;
    }
        .accordion.not-clickable:hover {
            color: #444;
        }

        .accordion.not-clickable:after {
            content: none;
        }

.list-accordion li {
    color: #444;
    cursor: pointer;
    padding: 0 8px 0 8px;
    width: calc(100% - 15px);
    text-align: left;
    border: none;
    outline: none;
    transition: 0.4s;
    font-family: var(--std-font);
    font-size: 18px;
    font-weight: 600;
    line-height: 20px;
}

.faqPanel {
    font-family: var(--std-font);
    font-size: 18px;
    font-weight: 300;
    text-align: left;
    padding: 0;
    background-color: transparent;
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.2s ease-out;
}

    .faqPanel.noborder {
        border-bottom: none;
    }

    .faqPanel.withborder {
        border-bottom: 1px solid var(--lines-color);
    }

.accordion.withborder {
    border-bottom: 1px solid var(--lines-color);
}

.bgPanel {
    visibility: hidden;
    background: #fff;
    border: 1px solid var(--lines-color);
    border-radius: 6px;
    width: calc(100% - 55px);
}

/******************************* REGISTRATION ***********************************/
.registrationTitle {
    font-family: var(--std-font) !important;
    font-size: 28px;
    font-weight: 600;
    margin: 20px 0 20px 0;
    color: var(--titles-color);
}

.registration-box {
    position: relative;
    width: 100vw;
    max-width: 940px;
    height: 640px;
    margin-top: 0px;
    overflow: hidden;
    font-family: var(--std-font);
    -webkit-overflow-scrolling: touch;
    background-color: #fff;
    border: 0px solid var(--lines-color);
    border-radius: 6px;
    -webkit-border-radius: 6px;
    -moz-border-radius: 6px;
    box-shadow: 0 12px 16px rgba(0, 0, 0, 0.2);
    -moz-box-shadow: 0 12px 16px rgba(0, 0, 0, 0.2);
    -webkit-box-shadow: 0 12px 16px rgba(0, 0, 0, 0.2);
}

.box-left {
    position: relative;
    display: flex;
    flex-direction: column;
    width: 40vw;
    /*height: 100%;*/
    padding: 0 20px;
    background-image: var(--gradient06);
    background-size: 100%;
    font-family: var(--std-font);
}

.box-left-payoff {
    display: flex;
    flex-direction: column;
    width: 90%;
    height: calc(100% - 60px);
    padding-top: 60px;
    margin-left: 20px;
    justify-content: center;
    font-family: var(--std-font);
    font-weight: bold;
    font-size: 44px;
    color: #fff;
}

.box-left-logo {
    position: absolute;
    top: 30px;
    width: 90%;
    height: auto;
    padding: 0;
    margin-left: 20px;
}

.box-right {
    overflow: hidden;
    display: flex;
    flex-direction: column;
    width: 50vw;
    height: 100%;
    padding: 0 25px 0 25px;
}


@media screen and (max-width : 1024px) {
    .registration-box {
        width: 100vw;
        max-width: 940px;
        margin-top: 0px;
        overflow-x: hidden;
        -webkit-overflow-scrolling: touch;
        background-color: #fff;
        border: 0px solid var(--lines-color);
        border-radius: 6px;
        -webkit-border-radius: 6px;
        -moz-border-radius: 6px;
        box-shadow: 0 12px 16px rgba(0, 0, 0, 0.2);
        -moz-box-shadow: 0 12px 16px rgba(0, 0, 0, 0.2);
        -webkit-box-shadow: 0 12px 16px rgba(0, 0, 0, 0.2);
    }

    .box-left-payoff {
        display: flex;
        flex-direction: column;
        width: 80%;
        min-height: 370px;
        margin-left: 10%;
        justify-content: center;
        font-family: var(--std-font) !important;
        font-weight: bold;
        font-size: 40px;
        color: #fff;
    }


    .box-left-logo {
        position: absolute;
        top: 30px;
        width: 80%;
        height: auto;
        padding: 0;
        margin-left: 10%;
        margin-bottom: 20px;
    }
}


@media screen and (max-width : 768px) {
    .registration-box {
        flex-direction: column;
        width: 100vw;
        align-items: center;
        overflow-x: hidden;
        max-width: 100vw;
        height: auto;
        min-height: 100vh;
        margin-top: 0px;
        overflow: auto;
        -webkit-overflow-scrolling: touch;
        background-color: #fff;
        border: 0px solid var(--lines-color);
        border-radius: unset;
        -webkit-border-radius: unset;
        -moz-border-radius: unset;
        box-shadow: unset;
        -moz-box-shadow: unset;
        -webkit-box-shadow: unset;
    }

    .box-left {
        display: flex;
        overflow-x: hidden;
        flex-direction: column;
        width: 100%;
        height: auto;
        padding: 20px 10px 30px 10px;
        background-image: var(--gradient06);
        background-size: 100%;
    }

    .box-left-payoff {
        display: flex;
        overflow-x: hidden;
        flex-direction: column;
        width: 80%;
        margin-left: 10%;
        justify-content: center;
        font-family: var(--std-font);
        font-weight: bold;
        font-size: 40px;
        color: #fff;
    }

    .box-right {
        display: flex;
        overflow-x: hidden;
        flex-direction: column;
        width: 80%;
        height: 100%;
        min-height: unset;
        padding: 10px;
        margin-right: 5px;
    }
}

/**********************  TABLE INPORT ERRORS **********************/
.myTable {
    width: calc(100% - 20px);
    padding: 10px;
    margin: 10px 0;
    font-family: var(--text-font);
    font-weight: 300;
    font-size: 15px;
    background-color: #FFF;
    color: var(--main-text-color);
    text-align: left;
    border-radius: 6px;
    -webkit-border-radius: 6px;
    -moz-border-radius: 6px;
    border-collapse: collapse;
}

    .myTable td {
        /*border-bottom: 1px solid var(--lines-color);*/
        border: 1px solid var(--lines-color);
        padding: 4px;
        /*padding: 10px 10px 10px 0;*/
        vertical-align: middle;
    }

    .myTable th {
        /*border-bottom: 1px solid var(--lines-color);
        padding: 10px 10px 10px 0;*/
        border: 1px solid var(--lines-color);
        padding: 4px;
        color: var(--brand-color);
        text-align: left;
        font-weight: 500;
    }


.w10 {
    width: 10%;
}

.w20 {
    width: 20%;
}


/**********************  TABLE INVOICES TO SDI ERRORS **********************/
/* WRAPPER SCROLLABILE */
.table-wrapper-fixed {
    max-height: 500px;
    overflow-y: auto;
    border: 1px solid var(--lines-color);
    margin: 10px 0;
    position: relative;
}

/* TABELLA BASE */
.myTableFixedScroll {
    width: 100%;
    font-family: var(--text-font);
    font-weight: 300;
    font-size: 15px;
    background-color: #FFF;
    color: var(--main-text-color);
    text-align: left;
    border-collapse: collapse;
    table-layout: fixed;
}

    /* INTESTAZIONE STICKY */
    .myTableFixedScroll th {
        position: sticky;
        top: 0;
        background-color: #FFF;
        z-index: 2;
        color: var(--brand-color);
        text-align: left;
        font-weight: 500;
        padding: 10px 12px;
        border-bottom: 2px solid var(--lines-color);
        border-right: 1px solid var(--lines-color);
    }

    /* CELLE */
    .myTableFixedScroll td {
        padding: 10px 12px;
        vertical-align: top;
        border-right: 1px solid var(--lines-color);
        border-bottom: 1px solid var(--lines-color);
        word-wrap: break-word;
        white-space: normal;
    }

/* COLONNE */
.col-idfattura {
    width: 8%;
    min-width: 120px;
}



/******************************* ICON CART **************************************/

.iconCartContainer {
    display: flex;
    flex-direction: row;
    justify-content: flex-start;
    align-items: center;
    text-align: left;
}

.iconCartText {
    display: flex;
    flex-direction: column;
    text-transform: uppercase;
    font-family: var(--text-font);
    font-size: 22px;
    font-weight: 500;
    margin-left: 7px;
    margin-right: 15px;
    text-align: left;
    align-items: flex-start;
}

.iconCart {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    min-width: 36px;
    min-height: 36px;
    color: #fff;
    font-size: 24px;
    /*border: 3px solid var(--brand-color);*/
    border-radius: 50%;
    padding: 5px;
    text-align: center;
    vertical-align: middle;
    margin: 10px 0;
}

.iconCart-beneficy {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 46px;
    height: 46px;
    min-width: 46px;
    min-height: 46px;
    color: #fff;
    font-size: 24px;
    border-radius: 50%;
    text-align: center;
    vertical-align: middle;
    margin: 10px 0;
    background-image: url(/images/iconBeneficy-01.png);
    background-position: center;
    background-size: 46px;
    background-repeat: no-repeat;
    overflow: hidden;
}

@media screen and (max-width : 1024px) {
    .iconCartText {
        font-size: 17px;
        margin-left: 5px;
        margin-right: 5px;
    }
}

.testoIncorniciato {
    position: relative;
    width: calc(100% - 52px);
    border: 1px solid var(--brand-color);
    border-radius: 4px;
    -webkit-border-radius: 4px;
    -moz-border-radius: 4px;
    padding: 20px;
    margin: 10px 0 20px 0;
    /*font-family: var(--std-font);*/
}

    .testoIncorniciato > .title {
        display: block;
        color: var(--brand-color);
        margin: -32px 0 10px -10px;
        width: 175px;
        background-color: var(--main-bg-color);
        text-align: center;
        vertical-align: top;
        font-size: 15px;
    }

        .testoIncorniciato > .title i {
            font-size: 20px;
            margin: 0px 5px;
        }

.divSelected {
    display: flex;
    flex-direction: row;
    align-items: center;
    width: calc(100% - 20px);
    padding: 10px;
    margin: 10px 10px 10px 0;
    font-size: 20px;
    font-weight: 500;
    background-color: var(--brand-color);
    color: #fff;
    border-radius: 4px;
}

.iconSelected {
    color: #fff;
    margin: 0 10px 0 0;
    font-size: 36px;
}

/**** INNER TICKET TABLE ***/
.innerTicketTable table, th, td {
    border-collapse: collapse;
    border: 1px solid lightgray
}

.innerTicketTable td {
    padding: 5px;
}


/**************+ SALUTE SEMPLICE ***********/
.salute-semplice {
}

    .salute-semplice h3 {
        text-transform: uppercase;
    }

    .salute-semplice a {
        background: transparent;
        display: inline-block;
        border: none;
        width: auto;
        margin: 10px 0px;
        padding: 0;
        font-family: var(--std-font);
        font-size: 14px;
        font-weight: bold;
        text-decoration: none;
        letter-spacing: 2px;
        text-align: left !important;
        color: var(--main-text-color) !important;
        cursor: pointer;
        -webkit-appearance: none;
        -moz-appearance: none;
        appearance: none;
        outline: none;
        text-transform: uppercase;
    }

    .salute-semplice ul, ol {
        list-style-type: square;
        padding-left: 20px;
    }

    .salute-semplice li {
        padding: 5px;
    }

/*** CALENDAR ***/

bfcy-calendar {
    float: left;
    display: block;
    box-sizing: border-box;
    -moz-box-sizing: border-box;
    background: white;
    min-width: 300px;
    border: solid 1px #CCC;
    margin-bottom: 10px;
}

    bfcy-calendar > div.calendar-header {
        float: left;
        width: 100%;
        background: var(--brand-color);
        height: 40px;
        color: white;
    }

        bfcy-calendar > div.calendar-header > * {
            height: 40px;
            line-height: 40px !important;
            display: inline-block;
            vertical-align: middle;
        }

        bfcy-calendar > div.calendar-header > i {
            float: left;
            width: 40px;
            font-size: 1.125em;
            font-weight: bold;
            position: relative;
            box-sizing: border-box;
            -moz-box-sizing: border-box;
            padding: 0 10px;
            cursor: pointer;
        }

            bfcy-calendar > div.calendar-header > i.fa-angle-left {
                text-align: left;
            }

            bfcy-calendar > div.calendar-header > i.fa-angle-right {
                text-align: right;
                margin-left: -40px;
            }

        bfcy-calendar > div.calendar-header > span {
            float: left;
            width: 100%;
            font-weight: bold;
            text-transform: uppercase;
            box-sizing: border-box;
            -moz-box-sizing: border-box;
            padding-left: 50px;
            margin-left: -40px;
            text-align: center;
            padding-right: 40px;
            color: inherit;
        }

    bfcy-calendar > div.calendar-week {
        float: left;
        width: 100%;
        border-top: solid 1px #CCC;
    }

        bfcy-calendar > div.calendar-week:first-child {
            border-top: none;
        }

        bfcy-calendar > div.calendar-week > span.calendar-day {
            float: left;
            width: 14.285714285714%;
            box-sizing: border-box;
            -moz-box-sizing: border-box;
            border-left: solid 1px #CCC;
            font-size: 0.75em;
            text-align: center;
            text-transform: uppercase;
            height: 30px;
            line-height: 30px !important;
            display: inline-block;
            vertical-align: middle;
            background: white;
            cursor: pointer;
            color: black;
        }

            bfcy-calendar > div.calendar-week > span.calendar-day:first-child {
                border-left: none;
            }

            bfcy-calendar > div.calendar-week > span.calendar-day.today {
                background: #E3F2FF;
            }

            bfcy-calendar > div.calendar-week > span.calendar-day.different-month {
                color: #C0C0C0;
            }

            bfcy-calendar > div.calendar-week > span.calendar-day.selected {
                background: var(--brand-color);
                color: white;
            }

        bfcy-calendar > div.calendar-week.names > span {
            color: #2875C7;
            font-weight: bold;
        }

.calendar-weekend {
    background-color: lightgray !important;
    color: gray !important;
}


/*** MUSEMENT *****/
.full-width {
    width: 100% !important;
}

.bg-reduced {
    width: calc(100% - 40px) !important;
}


.accordion-max-card-width {
    max-width: 318px;
    min-width: 318px;
}

.col-20-musement {
    font-family: inherit;
    width: calc(20% - 10px);
    margin: 2px 10px 2px 0px;
}

.col-60-musement {
    font-family: inherit;
    width: calc(60% - 10px);
    margin: 2px 10px 2px 0px;
}

.row-musement {
    flex-direction: row !important;
}


/** NEWS POPUP DASHBOARD** */

.popup-dashboard {
    position: absolute;
    top: 80px;
    z-index: 999999;
}
