@charset "UTF-8";
/* CSS Document */

:root {
    --black : #000000;
    --white : #FFFFFF;
    --red : #7E0C2B;
    --red-rgb: 126, 12, 43;
    --grey : #D5D5D5;
    --dark-grey : #525252;
    --light-grey : #F4F6F7;
}

body {
    margin: 0;
    padding: 0;
    font-family: 'Plus Jakarta Sans', sans-serif;
    font-weight: 400;
    overflow-x: hidden;
    color: var(--dark-grey);
    font-size: 16px;
    letter-spacing: 0.8px;
}

.ivy {
    font-family: "ivymode", sans-serif;
}

:focus,
:active {
    outline: none !important;
}

:hover {
    -webkit-transition: all .3s ease-in-out;
    -moz-transition: all .3s ease-in-out;
    -ms-transition: all .3s ease-in-out;
    -o-transition: all .3s ease-in-out;
    transition: all .3s ease-in-out;
}

table {
        max-width: 100%;
}

img {
    border: none;
}

a {
    text-decoration: none !important;
    color: inherit;
}

a:hover {
    color: inherit;
}

input[type=number]::-webkit-inner-spin-button,
input[type=number]::-webkit-outer-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

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

h1,
h2,
h3,
h4,
h5,
h6 {
  color: black;
  font-family: "ivymode", sans-serif;
}

.clear {
    clear: both;
}

.p-mb-0 p {
    margin-bottom: 0;
}
.strong-600 strong{
    font-weight: 600;
}
.cursor-pointer  {
    cursor: pointer;
}

.small,
.small p {
    font-size: .875em;
}

.x-small,
.x-small p {
    font-size: 0.775em;
}

.bg-opacity-35 {
    --bs-bg-opacity: 0.35;
}



.mh-550 {
    min-height: 550px;
}
/*border*/
.border-red {
    border: 1px solid var(--red);
}

/*end border*/

/*button*/
.btn-outline-red {
    border: 1px solid var(--red);
    color: var(--red);
    background-color: transparent;
    border-radius: 0;
}

.btn-outline-red:hover,
.btn-outline-red:focus,
.btn-outline-red:focus-visible,
.btn-outline-red:focus-within {
    border: 1px solid var(--red);
    color: var(--white);
    background-color: var(--red);
    border-radius: 0;
}

.btn-solid-red {
    border: 1px solid var(--red);
    color: var(--white);
    border-radius: 0;
    background-color: var(--red);
}

.btn-solid-red:hover,
.btn-solid-red:focus,
.btn-solid-red:focus-visible,
.btn-solid-red:focus-within {
    border: 1px solid var(--red);
    color: var(--red);
    border-radius: 0;
    background-color: white;
}
.btn-outline-grey {
    border: 1px solid var(--grey);
    color: var(--dark-grey);
    border-radius: 0;
    background-color: var(--white);
}

.btn-outline-grey:hover,
.btn-outline-grey:focus,
.btn-outline-grey:focus-visible,
.btn-outline-grey:focus-within {
    border: 1px solid var(--dark-grey);
    color: var(--dark-grey);
    border-radius: 0;
    background-color: var(--light-grey);
}
.btn-list-catalogo {
    border: 0;
    font-family: "ivymode", sans-serif;
    color: var(--dark-grey);
    border-radius: 0;
    background-color: var(--white);
}

.btn-list-catalogo:hover,
.btn-list-catalogo:focus,
.btn-list-catalogo:focus-visible,
.btn-list-catalogo.active,
.btn-list-catalogo:focus-within {
    border: 0;
    color: var(--dark-grey);
    text-decoration: underline !important;
    border-radius: 0;
    background-color: var(--light-grey);
}
.btn-close:hover,
.btn-close:focus,
.btn-close:focus-visible,
.btn-close:focus-within {
    border: 0;
    box-shadow: none !important;
}
/*end button*/

/*text color*/
.text-red {
    color: var(--red);
}
.text-grey {
    color: var(--grey);
}
.text-dark-grey {
    color: var(--dark-grey);
}
/*end text color*/


/*background color*/
.bg-grey {
    background: var(--grey);
}
.bg-light-grey {
    background: var(--light-grey);
}
.bg-red {
    background: var(--red);
}

/*end text color*/

/*
.bag-icon:not(.empty)::after {
  position: absolute;
  top: 60%;
  left: 100%;
  transform: translate(-50%, 0%);
  height: 18px;
  width: 18px;
  border-radius: 50%;
  background-color: var(--red);
  content: "1";
  color: var(--white);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
}
*/

.dropdown-item {
  transition: all 0.1s ease-in-out;
}
.dropdown-item:hover,
.dropdown-item.active,
.dropdown-item:active {
  background-color: var(--red);
  color: var(--white);
}

.nav-link.active,
.nav-link:hover {
  color: var(--red);
}

.form-search .btn-open-search,
.form-search .btn-open-search:focus,
.form-search .btn-search,
.form-search .btn-search:focus {
  border: none;
}

input[type="search"]::-webkit-search-cancel-button {
  display: none;
}

.form-search input {
  border-bottom: 0 !important;
  transition: all 0.3s ease-in-out;
}
.form-search .close-btn::after {
  content: "\f00d";
  font-family: "Font Awesome 5 Pro";
  font-size: 14px;
  font-weight: 500;
  color: var(--red);
  cursor: pointer;
}
.form-search:not(.show-times) .close-btn::after {
  display: none;
}
.form-search input:focus {
  border-bottom: 3px solid var(--red) !important;
}
.navbar-toggler:focus {
  box-shadow: none;
}

.border-right-custom::after {
  content: "";
  display: block;
  min-height: 20px;
  height: 75%;
  width: 1px;
  background-color: var(--bs-border-color);
  position: absolute;
  right: -0.75rem;
  top: 50%;
  transform: translateY(-50%);
}
.chevron-dropdown::after {
  content: "\f107";
  font-family: "Font Awesome 5 Pro";
  font-weight: 600;
  border: none;
}

.breadcrumb-item + .breadcrumb-item::before {
    content: var(--bs-breadcrumb-divider, "-");
    color: black;
}

/* swiper home  */
.swiper {
    width: 100%;
    height: 100%;
}

.swiper-slide {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
}

.swiper-prodotti-pagination .swiper-button-prev::after,
.swiper-prodotti-pagination .swiper-button-next::after,
.swiperTestataHome .swiper-button-prev:after,
.swiperTestataHome .swiper-button-next:after {
    font-family: "Font Awesome 5 Pro";
    font-size: 40px;
    font-weight: 300;
}
.swiperTestataHome .swiper-button-prev:after {
    content: "\f104";
}
.swiperTestataHome .swiper-button-next:after {
    content: "\f107";
}
.swiperTestataHome .swiper-button-next {
    right: auto;
    left: 50%;
    top: auto;
    bottom: 1rem;
}
.swiperTestataHome .swiper-horizontal > .swiper-pagination-bullets,
.swiperTestataHome .swiper-pagination-bullets.swiper-pagination-horizontal {
    left: calc((100% - 318px) / 2 + 0.75rem);
    width: auto;
    bottom: 4.5rem;
}
.swiperTestataHome .swiper-pagination {
    display: flex;
    align-items: center;
    column-gap: 0.5rem;
}
.swiperTestataHome .swiper-pagination-bullet {
    color: white;
    font-size: 10px;
    width: fit-content;
    height: fit-content;
    border-radius: 0;
    background: none;
    opacity: var(--swiper-pagination-bullet-inactive-opacity, 0.8);
    position: relative;
    /* transition: all .3s ease-in-out; */
}
.swiperTestataHome .swiper-pagination-bullet-active {
    opacity: 1;
    background: none;
    font-size: 13px;
    padding-right: 35px;
}

.swiperTestataHome .swiper-pagination > .swiper-pagination-bullet:last-child.swiper-pagination-bullet-active {
    padding-left: 35px;
}

.swiperTestataHome .swiper-pagination-bullet::after {
    content: "";
    width: 30px;
    height: 1px;
    background-color: white;
    opacity: 0;
    position: absolute;
    right: -5px;
    top: 50%;
    transform: translateY(-50%) scaleX(0);
    transform-origin: left;
    transition: transform 0.3s ease-in-out;
}
.swiperTestataHome .swiper-pagination > .swiper-pagination-bullet:last-child::after {
    left: -5px;
    transform-origin: right;
}
.swiperTestataHome .swiper-pagination-bullet.swiper-pagination-bullet-active::after {
    opacity: 1;
    transform: translateY(-50%) scaleX(1);
}
/* end swiper home  */

/*form*/
.form-control{
    border-radius: 0 !important;
}

.form-control::placeholder,
.form-select {
    font-size: 15px;
    color: var(--dark-grey);
}

.form-check-input[type="checkbox"] {
    border-radius: 50%;
}
.form-check-input[type="checkbox"] + label {
    font-size: 12px;
}

.form-check-input:focus,
.form-select:focus,
.form-control:focus {
    border-color: rgba(var(--red-rgb), 0.25);
    box-shadow: 0 0 0 0.25rem rgb(255 10 77 / 23%);
}

.form-check-input:checked {
    background-color: var(--red);
    border-color: var(--red);
}

.form-check-input {
    cursor: pointer;
}

/*modal*/
.modal .btn-close {
    background: transparent var(--bs-btn-close-bg) right / 1em auto no-repeat !important;
}
/*end modal*/
.zoom-img img{
    transition: all 0.3s ease-in-out;
}

.zoom-img:hover  img {
    transform: scale(1.05);
}
/*prodotti dettaglio*/

.counter {
    height: 50px;
    max-width: 420px;
}
.counter button {
    width: 50px;
    position: relative;
}
.counter button::after {
    content: "";
    height: 30px;
    width: 1px;
    background-color: var(--bs-border-color);
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
}
.counter button.sub::after {
    left: 50px;
}
.counter button.add::after {
    right: 50px;
}
.counter > * {
    border: 0;
}
.counter .quantity {
    flex: 1 0 50%;
    font-size: 12px;
    vertical-align: middle;
}
.prodotto .prezzo::after {
    content: "(IVA esclusa)";
    color: var(--red);
    font-size: 13px;
    font-weight: 400;
    position: absolute;
    top: 100%;
    right: 0;
    width: fit-content;
}

.prodotto .btn-carrello {
    max-width: 400px;
}

.swiper-prodotti-pagination .swiper-button-prev::after {
    content: "\f104";
}
.swiper-prodotti-pagination .swiper-button-next::after {
    content: "\f105";
}
.swiper-prodotti-pagination .swiper-button-prev::after,
.swiper-prodotti-pagination .swiper-button-next::after {
    color: #525252;
    font-size: 30px;
}
.swiperVantaggi .swiper-pagination-bullet,
.swiperPanettoni .swiper-pagination-bullet,
.swiperProdottiVetrina .swiper-pagination-bullet,
.swiperProdotti .swiper-pagination-bullet {
    width: 10px;
    height: 10px;
    background: white;
    border: 1px solid var(--bs-border-color);
    opacity: 1;
}
.swiperVantaggi .swiper-pagination-bullet-active,
.swiperPanettoni .swiper-pagination-bullet-active,
.swiperProdottiVetrina .swiper-pagination-bullet-active,
.swiperProdotti .swiper-pagination-bullet-active {
    background: var(--bs-border-color);
}

.swiper-prodotti-pagination .swiper-button-prev { left: -27px; }   /* regola come vuoi */
.swiper-prodotti-pagination .swiper-button-next { right: -35px; }


/*swiper thumb dettaglio prodotto*/
.swiper-container {
    display: flex;
    gap: 10px;
    width: 100%;
    height: 400px;
}

.swiperFotoProdotto {
    flex: 1;
    height: 100%;
    order: 2;
}

.swiperThumb {
    width: 120px;
    height: 100%;
    order: 1;
}

.swiper-slide {
    display: flex;
    justify-content: center;
    align-items: center;
}

.swiper-slide img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.swiperThumb .swiper-slide {
    opacity: 0.4;
    cursor: pointer;
}

.swiperThumb .swiper-slide-thumb-active {
    opacity: 1;
}

.nav-pills .nav-link.active {
    background-color: var(--light-grey);
    border-radius: 0;
}
.nav-pills .nav-link:hover {
    background-color: var(--light-grey);
    border-radius: 0;
}
.accordion-button:not(.collapsed) {
    background-color:var(--light-grey) !important;
    box-shadow: none !important;
    color: var(--dark-grey) ;
}
.accordion-button:focus {
    box-shadow: none !important;
}

.swiperVantaggi .bg-overlay {
    background-image: linear-gradient(to top, rgba(0, 0, 0, 0.6), transparent);
}

.swiperVantaggi .swiper-slide .hvr-img {
    transition: all 0.3s ease-in-out;
    transform: scale(1.05);
}

.swiperVantaggi .swiper-slide:hover  .hvr-img {
    transform: scale(1.05) translateX(-8px);
}

.menu-user.dropdown-menu-end[data-bs-popper] {
    right: 50% !important;
    transform: translateX(50%) !important;
    top: 39px !important;
}
.dropdown li {
    list-style-type: none;
}
/*carrello*/
.group-varianti .radio-custom input[type="radio"]:checked + label {
    color:var(--red) !important;
    outline: 1px solid var(--red);
}
.input-spinner-wrapper {
    justify-content: space-between !important;
    width: 100% !important;
}

.input-spinner-wrapper button:first-child {
    border: 0;
    background: white;
    border-right: 1px solid var(--grey);
    border-radius: 0;
    padding: 2% 4% 2% 2%;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: none !important;
}

.input-spinner-wrapper button:last-child {
    border: 0;
    background: white;
    border-left: 1px solid var(--grey);
    border-radius: 0;
    padding: 2% 2% 2% 4%;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: none !important;
}
.box-add-cart .prezzo .num {
    color: var(--red);
    font-size: 25px;
}

.box-add-cart .prezzo .num2 {
    color: var(--red);
     font-size: 25px;
}
.prezzo  {
    display: flex;
}

.active > .page-link, .page-link.active{
    background-color: var(--red);
    border-color: var(--red);
}
.page-link{
    color: var(--red);
}
.page-link:hover {
    color: var(--red);
    background-color: var(--light-grey);
}



/**/

/* .choices-h-100 .choices,
.choices-h-100 .choices__list,
.choices-h-100 .choices__item,
.choices-h-100 .choices__inner{
    height: 100% !important;
}


.choices-h-100 .choices__item{
    display: flex;
    align-items: center;
}

.form-floating > .form-control-plaintext:focus, .form-floating > .form-control-plaintext:not(:placeholder-shown), .form-floating > .form-control:focus, .form-floating > .form-control:not(:placeholder-shown) {
    padding-top: 1.825rem !important;
}
 */






















