:root {
    --primario: #cc0303;
    --grigio: #eeeeee;
}

body {
    font-size: 16px;
    color: #515151;
    font-family: 'Gantari', sans-serif;
}

.contenuto {
    width: 100%;
    max-width: unset;
    padding: 2%;
}

#banner img {
    max-height: 400px;
    object-fit: cover;
}

.titolo {
    padding-bottom: 50px;
}

.categoria a {
    padding: 10px;
    border: solid 0.5px #cacbcd;
    display: block;
    position: relative;
    min-height: 70px;
    color: #333;
    text-decoration: none;
    font-size: 18px;
    line-height: 44px;
}

.categoria a:hover {
    font-weight: 600;
}

.prodotto a {
    padding: 10px;
    border: solid 1px #cacbcd!important;
    border-radius: 4px;
    display: block;
    position: relative;
    color: rgb(32, 32, 32);
    text-decoration: none !important;
}

.prodotto a:hover {
    border-radius: 5px;
    bottom: 2px;
    box-shadow: 0 5px 10px 0 rgb(42 49 57 / 20%);
    text-decoration: none;
    border-bottom-color: var(--primario)!important;
}

.prodotto {
    padding: 10px;
}

.prodotto a img {
    max-width: 100%;
    display: block;
    width: 300px;
    margin: auto;
    height: 300px;
    object-fit: contain;
}

.prodotto a .titolo {
    font-size: 13px;
    overflow: hidden;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    line-clamp: 3;
    -webkit-box-orient: vertical;
    text-transform: uppercase;
    height: 60px;
}

.prodotto a .prezzo {
    font-size: 20px;
    font-weight: 500;
    color: var(--primario);
}


/* sovrascrittura bs*/

.row {
    --bs-gutter-x: unset !important;
}


/* css */

img {
    max-width: 100%;
    display: block;
}

#header * {
    text-align: center;
}

#header .menu div {
    min-height: 30px;
    max-height: 60px;
    align-items: center;
}

.user-menu div {
    justify-content: center;
}

#footer {
    text-align: center;
    background: var(--grigio);
    color: #fff;
}

#footer small {
    text-align: center;
    display: block;
}

.filtri ul {
    display: block;
    list-style: none !important;
    padding-left: 13px;
    padding-bottom: 20px;
    border-bottom: solid 0.5px #cfcfcf;
    width: 80%;
    font-size: 13px;
}

.filtri label.t {
    padding: 0 0 2px;
    font-size: 12px;
    text-transform: uppercase;
    color: #b6b6b6;
    font-weight: 700;
    padding: 10px 0;
}

.att_lab {
    cursor: pointer;
    padding-left: 20px;
}

.filtri ul li {
    padding-bottom: 3px;
    position: relative;
}

.filter_checkbox {
    display: inline-block;
    border: 2px solid #c1c7d7;
    text-align: left;
    background: #fff;
    vertical-align: middle;
    border-radius: 3px;
    cursor: pointer;
    width: 16px;
    height: 16px;
    top: 0;
    border-radius: 10px;
    position: absolute;
}

#l {
    display: none;
}

.loader_visibile {
    position: absolute;
    width: 100%;
    height: 100vh;
    display: block !important;
    background: #ffffff70;
    z-index: 1;
    text-align: center;
    padding-top: calc(100vh - 50%);
}

.disabled * {
    pointer-events: none;
    opacity: 0.6;
}

.only_mobile {
    /* display: none; */
}

.ep_box_order_filter {
    font-size: 14px;
    font-family: Muli, Arial, sans-serif;
    position: relative;
    z-index: 2;
    padding: 10px;
    height: 60px;
    background: #f0f0f0;
    border-radius: 7px;
    margin-bottom: 16px;
    font-size: 12px;
}

dl.ep_list_orderby {
    position: relative;
    display: inline-block;
    vertical-align: top;
    padding-right: 1.5%;
    width: 48%;
}

.ep_box_order_filter .ep_openFilter {
    position: relative;
    display: inline-block;
    vertical-align: top;
    width: 50%;
    height: 100%;
    text-align: center;
    font-size: 14px;
    border-left: 1px solid #cacbcd;
    cursor: pointer;
}

dl.ep_list_orderby dd:not(.ep_active) {
    max-height: 0;
    padding-top: 0;
    padding-bottom: 0;
    overflow: hidden;
    padding: 0px !important;
}

dl.ep_list_orderby.ep_active dd {
    position: relative;
    background: #fff;
    box-shadow: 0 6px 6px 0 rgb(42 49 57 / 20%);
    max-height: 40px;
    display: block;
    padding: 12px 10px;
    transition: all .5s;
    padding: 7px !important;
}

dd {
    margin: 0;
    padding: 7px !important;
}

.visibile {
    display: unset !important;
}

#filtri_attivi_list {
    list-style: none;
    margin: 0;
    display: inline-block;
    max-height: 10px;
    margin: 0px !important;
    padding: 0px !important;
}

#filtri_attivi_list li {
    text-transform: uppercase;
    position: relative;
    display: inline-block;
    margin: 6px 3px;
    padding: 5px 25px 5px 15px;
    text-align: center;
    background: #f0f0f0;
    border-radius: 20px;
    cursor: pointer;
    font-size: 12px;
}

.only_mobile {
    display: none;
}

@media only screen and (max-width: 768px) {
    .filtri {
        display: none;
        z-index: 1000;
        background: #fff;
        height: 100%;
        padding: 5%;
    }
    .only_mobile {
        display: block;
    }
}

.prod-slide {
    max-height: 400px;
    object-fit: scale-down;
    margin-bottom: 50px;
}

.hide {
    display: none !important;
}

#recensioni {
    color: #000;
    position: relative;
    font-style: italic;
    font-weight: 600;
    font-size: 18px;
    cursor: pointer;
}

#descrizione {
    white-space: break-spaces;
    padding-top: 20px;
    padding-bottom: 40px;
}

.categoria {
    padding: 5px;
}

#consigliato-prezzi {
    zoom: 2;
    padding: 20px 0px;
}

#consigliato-prezzi #consigliato {
    text-align: right;
}

#spedizione svg {
    position: absolute;
    zoom: 1.5;
    left: 0;
}

#spedizione {
    position: relative;
    padding-left: 50px;
}

#acquista>div {
    position: relative;
}

.acquista {
    padding: 10px 30px;
    border-radius: none;
    width: 100%;
    background: #c10017;
    background-color: #c10017;
}

#pull svg {
    margin-right: 10px;
}

.input {
    position: relative;
    margin-top: 5px;
    margin-bottom: 25px;
}

.input el {
    font-size: 11px;
    font-style: oblique;
    color: #333;
    margin-left: 25px;
    position: absolute;
}

.label {
    position: absolute;
    left: 16px;
    pointer-events: none;
    color: #888;
    transition: all .22s;
    transform: translateY(-50%);
    display: block;
    background-color: #ffffff;
    padding: 0px 10px;
    top: 20px;
    font-size: 14px;
    z-index: 1111;
}

input:valid+.label {
    background-color: #cc0303;
    color: #fff;
    opacity: 1;
    top: -9px;
    transform: translateY(0);
    font-size: 12px;
}

input:focus+.label {
    background-color: #cc0303;
    color: #fff;
    opacity: 1;
    top: -9px;
    transform: translateY(0);
    opacity: 1;
    font-size: 12px;
}

.lab {
    position: absolute;
    left: 16px;
    pointer-events: none;
    color: #000;
    transition: all .22s;
    transform: translateY(-50%);
    display: block;
    background-color: #ffffff;
    padding: 0px 10px;
    top: 20px;
    font-size: 14px;
    z-index: 1111;
}

input.on+.lab {
    background-color: #cc0303;
    color: #fff;
    opacity: 1;
    top: -9px;
    transform: translateY(0);
    opacity: 1;
    font-size: 12px;
}

input:focus+.lab {
    background-color: #cc0303;
    color: #fff;
    opacity: 1;
    top: -9px;
    transform: translateY(0);
    opacity: 1;
    font-size: 12px;
}

 ::-webkit-input-placeholder {
    color: #000;
    font-size: 14px;
    padding: 0px 10px;
}

 ::placeholder {
    color: #000;
    font-size: 14px;
    padding: 0px 10px;
}

.metodi {
    border: 1px solid #cacbcd;
    border-radius: 5px;
    padding: 10px 15px;
    min-height: 90px;
    width: 100%;
    position: relative;
    margin-bottom: 10px;
    cursor: pointer;
}

.metodi .form-check-input {
    position: absolute;
    top: calc(50% - 20px);
}

.form-check-input {
    zoom: 1.6;
}

.metodi label {
    padding-left: 50px;
    cursor: pointer;
}

.green_bck {
    position: absolute;
    right: 2px;
    top: 10px;
    background: green;
    color: #fff;
    padding: 3px 12px;
    line-height: 1;
    zoom: 0.8;
    text-transform: uppercase;
    font-weight: 600;
}

.according {
    margin-bottom: 10px;
}

.according button {
    display: block;
    width: 100%;
    text-align: left;
    position: relative;
    padding: 0px;
    font-weight: 500;
}

.according button:focus {
    box-shadow: none;
}

.according button svg {
    position: absolute;
    right: 10px;
    zoom: 1.5;
}

.according .btn.collpsed svg {
    transform: rotate(180deg);
}

.according .btn svg {
    transform: rotate(0);
}

.img-footer img {
    display: inline-block;
    max-width: 16%;
}

.boxed_brd {
    margin-bottom: 30px;
    padding: 20px 30px;
    border: solid 0.5px #cacbcd;
    border-radius: 10px;
}

.container-fluid {
    padding: 0;
}

.conferma {
    display: block;
    width: 100%;
    font-size: 20px;
    background-color: #c10017;
    background: #c10017;
    border: solid 0.5px #c10017;
}

#riepilogo_ordine small {
    margin-top: 10px;
    font-size: 11px;
    color: #515151;
    font-style: italic;
    line-height: 12px;
    display: block;
}

#riepilogo_ordine table {
    display: block;
    width: 100%;
}

#riepilogo_ordine table tr td:nth-child(odd) {
    width: 100%;
}

#riepilogo_ordine table tr td:nth-child(even) {
    text-align: right;
}

.promo-bar {
    padding: 5px;
}

#innerPromo {
    text-align: center;
    color: #fff;
    font-size: 14px;
}

#innerPromo a {
    color: #fff;
}

.open_mobile_menu {
    display: none;
}

#menu_ul {
    display: block;
    list-style: none;
    margin-top: 10px;
    margin-bottom: 10px;
    position: relative;
    overflow: auto;
    white-space: nowrap;
}

#menu_ul::-webkit-scrollbar {
    display: none;
}

#menu_ul li {
    display: inline;
    padding: 5px 10px;
}

#menu_ul li a {
    text-decoration: none;
    color: #333;
}

#menu_ul li a:hover {
    font-weight: 600;
}

#menu_ul.show {
    display: block !important;
}

.only-mobile {
    display: none;
}

.only-desk {
    display: block;
}

#gdesk .col-md-6 {
    margin-bottom: 15px;
}

#gdesk img {
    max-height: 300px;
    height: 300px;
    object-fit: contain;
    width: auto;
    margin-bottom: 5px;
}

.galleria {
    padding-right: 30px;
    border-right: solid 0.5px #cacbcd;
    position: relative;
    padding: 0 20px;
}

.destro {
    padding-left: 30px;
}

#acquista {
    position: fixed;
    right: 0px;
    top: 0px;
    width: 0%;
    transition: all 0.5s;
    z-index: 1000;
    height: 100%;
    overflow: auto;
    box-shadow: 10px 0px 100px 1000px #00000050;
    opacity: 0;
}

#acquista.show {
    width: 50%;
    opacity: 1;
}

.green-alert {
    border: #008000;
    background-color: #b9f3b9;
    color: #008000;
    font-weight: 500;
    padding: 10px 20px;
}

#ricerca {
    margin-top: 5px;
    border-radius: 50px !important;
    transition: all 0.5s;
}

@media only screen and (max-width: 600px) {
    #acquista.show {
        width: 100%;
    }
    .destro {
        padding-left: 10px;
    }
    .galleria {
        padding-right: unset;
        border-right: none;
    }
    .destro {
        padding-left: unset;
    }
    .only-mobile {
        display: block;
    }
    .only-desk {
        display: none;
    }
    .open_mobile_menu {
        display: unset;
    }
    #menu_ul {
        /* display: none;*/
    }
    #menu_ul li {
        display: inline;
        padding: 10px 10px;
        font-size: 16px;
        border-right: solid 0.5px #cacbcd;
    }
    #menu_ul li:last-child {
        border-right: none;
    }
}

#prodotti_simili a {
    text-decoration: none;
    color: #515151;
}

#prodotti_simili img {
    height: 250px;
}

#prodotti_simili .titolo {
    overflow: hidden;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    line-clamp: 3;
    -webkit-box-orient: vertical;
    text-transform: uppercase;
    height: 60px;
}

#prodotti_simili .prezzo {
    color: #c10017;
    font-weight: 600;
}

.open_mobile_menu {
    padding: 10px;
    background: none;
    border: none;
}


/* IMG ZOOM */

img[data-action="zoom"] {
    cursor: pointer;
    cursor: -webkit-zoom-in;
    cursor: -moz-zoom-in;
}

.zoom-img,
.zoom-img-wrap {
    position: relative;
    z-index: 666;
    -webkit-transition: all 300ms;
    -o-transition: all 300ms;
    transition: all 300ms;
}

img.zoom-img {
    cursor: pointer;
    cursor: -webkit-zoom-out;
    cursor: -moz-zoom-out;
}

.zoom-overlay {
    z-index: 420;
    background: #fff;
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    pointer-events: none;
    filter: "alpha(opacity=0)";
    opacity: 0;
    -webkit-transition: opacity 300ms;
    -o-transition: opacity 300ms;
    transition: opacity 300ms;
}

.zoom-overlay-open .zoom-overlay {
    filter: "alpha(opacity=100)";
    opacity: 1;
}

.zoom-overlay-open,
.zoom-overlay-transitioning {
    cursor: default;
}

.swiper-button-next {
    right: 0px !important;
}

.swiper-button-prev {
    left: 0px !important;
}

.s_100 {
    width: 100% !important;
    display: block !important;
    margin-bottom: 20px;
}

.s-click {
    cursor: pointer;
}

#recensioni_prodotto .contenitore {
    background-color: #fff;
}

#recensioni_prodotto button.close {
    background-color: none;
    background: none;
    border: none;
}

.check-label {
    display: none;
}

.label-check {
    padding: 2px 10px;
    background-color: #cacbcd;
    color: #000;
    border-radius: 20px;
}

.check-label:checked+.label-check {
    background-color: #cc0303;
    color: #fff;
}

#stelle div {
    display: inline-flex;
}

.riga_rev svg {
    top: 20px;
    left: 0px;
    position: absolute;
}

.riga_rev .rev {
    padding: 10px 2%;
}

.riga_rev .star {
    color: #cc0303;
    font-weight: 600;
}

.riga_rev {
    position: relative;
    padding-bottom: 10px;
    border-top: solid 0.5px #b6b6b6;
}

.bv-content-rating {
    zoom: 1!important;
    display: inline-block!important;
}

.bv-rating-stars {
    font-style: normal;
    position: relative!important;
    display: block!important;
    overflow: hidden!important;
    border: none !important;
}

.bv-rating-stars-off {
    font-size: 20px!important;
    color: #d3d2d2!important;
}

.bv-rating-stars-on {
    font-size: 20px!important;
    color: #c10017!important;
    margin-top: -30px!important;
}

.bv-rating-stars-on {
    position: relative!important;
    float: left!important;
    white-space: nowrap!important;
}

.riga-cat {
    position: relative;
}

.riga-cat:hover::after {
    content: ' \2192';
    position: absolute;
    right: 20px;
    top: 28px;
}

#sezioni_account {}

#sezioni_account li {
    cursor: pointer;
}

.bold {
    font-weight: 600;
}

.ordine_line {
    border: solid 1px #b6b6b6;
    border-radius: 2px;
}

.ridotto .dettaglio {
    display: none;
}