/* =======================
   Font-face declarations
   ======================= */
*,
*::before,
*::after {
  box-sizing: border-box;
}

@font-face {
  font-family: 'NeueHaasDisplay';
  src: url('../fonts/NeueHaasDisplay-200.ttf') format('truetype');
  font-weight: 200;
  font-style: normal;
}

@font-face {
  font-family: 'NeueHaasDisplay';
  src: url('../fonts/NeueHaasDisplay-300.ttf') format('truetype');
  font-weight: 300;
  font-style: normal;
}

@font-face {
  font-family: 'NeueHaasDisplay';
  src: url('../fonts/NeueHaasDisplay-400.ttf') format('truetype');
  font-weight: 400;
  font-style: normal;
}

@font-face {
  font-family: 'NeueHaasDisplay';
  src: url('../fonts/NeueHaasDisplay-500.ttf') format('truetype');
  font-weight: 500;
  font-style: normal;
}

@font-face {
  font-family: 'NeueHaasDisplay';
  src: url('../fonts/NeueHaasDisplay-600.ttf') format('truetype');
  font-weight: 600;
  font-style: normal;
}

@font-face {
  font-family: 'NeueHaasDisplay';
  src: url('../fonts/NeueHaasDisplay-700.ttf') format('truetype');
  font-weight: 700;
  font-style: normal;
}


@font-face {
  font-family: 'CaeciliaLTPro45Light';
  src: url('../fonts/CaeciliaLTPro45Light.ttf') format('truetype');
  font-weight: normal;
  font-style: normal;
}

/* =======================
   CSS Custom Properties
   ======================= */

:root {
  /* Palette di colori */
  --color-primary: #000000;       /* nero scuro */
  --color-secondary: #940a2b;     /* rosso AM */
  --color-accent: #e5922e;        /* arancio/moderato */
  --color-background: #ffffff;    /* bianco puro */
  --color-background-grey: #eeeeee;    /* grigio chiaro */
  --color-text: #333333;          /* grigio scuro per il testo principale */
  --color-text-light: #777777;    /* grigio medio per testi secondari */
  --color-border: #dddddd;        /* grigio chiaro per bordi */

  /* Tipografia */
  /*--font-body: 'CaeciliaLTPro45Light', sans-serif;*/
  --font-body: 'NeueHaasDisplay', sans-serif;
  --font-heading: 'NeueHaasDisplay', sans-serif;

  --font-size-base: 16px;
  --font-size-small: 0.875rem;  /* ≈14px */
  --font-size-large: 1.25rem;   /* ≈20px */

  --line-height-base: 1.6;
  --line-height-heading: 1.2;
}

/* =======================
   Base styles
   ======================= */

html {
  font-size: var(--font-size-base);
  line-height: var(--line-height-base);
  font-family: var(--font-body);
  color: var(--color-text);
  background-color: var(--color-background);
}

body {
  margin: 0;
  padding: 0;
  color: #000;
  font-family: 'NeueHaasDisplay';
  font-weight: normal;
  font-size: 14px;
}

/* Headings */
h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-heading);
  font-weight: 600;
  line-height: var(--line-height-heading);
  color: var(--color-primary);
  margin-top: 1.5rem;
  margin-bottom: 0.5rem;
}

h1 { font-size: 2rem; }
h2 { font-size: 1.75rem; }
h3 { font-size: 1.5rem; }
h4 { font-size: 1.25rem; }
h5 { font-size: 1rem; }
h6 { font-size: 0.875rem; }

/* Paragraph */
p {
  font-family: var(--font-body);
  margin-bottom: 1rem;
  color: var(--color-primary);
  letter-spacing: .05em;
}

/* Links */
a {
  color: var(--color-primary);
  text-decoration: underline;
}
a:hover {
  color: var(--color-primary);
  text-decoration: underline;
}

.customer-welcome, .customer-welcome * {
  display: none !important;
}

.panel.header ul.header.links a {
  color: var(--color-primary);
  transition: all .4s;
}
.level0.active a,
.level0.has-active a {
  border-color: #940a2b !important;
}
.panel.header ul.header.links a {
  color: var(--color-primary) !important;
  opacity: .8;
}
.panel.header ul.header.links a:hover {
  opacity: 1;
  text-decoration: underline;
}
.action.search {
  padding: 0 !important;
}

.font-bold{
  font-weight: bold;
}

a:visited, .alink:visited{
  color: #000;
}

input[type="text"], input[type="password"], input[type="url"], input[type="tel"], input[type="search"], input[type="number"], input[type*="date"], input[type="email"]{

  font-family: 'NeueHaasDisplay';
}

/* Buttons */
button,
.btn,
.action.primary,
.action-primary {
  font-family: var(--font-heading);
  font-size: 1rem;
  padding: 0.3em .8em;
  color: var(--color-background);
  background: var(--color-primary);
  border: 1px solid var(--color-primary);
  border-radius: 50px !important;
  cursor: pointer;
  transition: all .4s;
}
button:hover,
.btn:hover,
.action.primary:hover,
.action-primary:hover {
  opacity: .8;
  background: var(--color-primary);
  border: 1px solid var(--color-primary);
  color: #fff;
}
/*button.action.secondary {
  font-family: var(--font-heading);
  font-size: 1rem;
  padding: 0.3em .8em;
  color: var(--color-primary);
  background: #FFF;
  border: 1px solid var(--color-primary);
  border-radius: 50px !important;
  cursor: pointer;
  transition: all .4s;
}
button.action.secondary span {
  color: var(--color-primary);
}*/

/* Container */
.container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 1rem;
}

/* Header and Footer */
.header,
div .page-header .panel.wrapper {
  background-color: var(--color-background);
}
.customer-account-index li.customer-welcome.active .header.links li:first-child {
  display: none;
}
.customer-welcome .action.switch::after {
  color: var(--color-primary) !important;
}

.footer,
.footer.content {
  background-color: var(--color-background);
  color: var(--color-text-light);
  padding: 2rem 0 0 0;
  font-size: var(--font-size-small);
}
/* Forms */
#search, #search:focus {
  border: 1px solid var(--color-primary);
  border-radius: 100px;
  color: var(--color-primary);
  box-shadow: none;
}
#newsletter, #newsletter:focus {
  border: 1px solid var(--color-primary);
  border-radius: 100px 0 0 100px;
  color: var(--color-primary);
  box-shadow: none;
  height: 43px;
}
div .block.newsletter .field .control::before {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  font-size: 16px;
  line-height: 41px;
  color: var(--color-primary);
  content: '\e61d';
  font-family: 'luma-icons';
  margin: 0 0 0 8px;
  vertical-align: middle;
  display: inline-block;
  font-weight: normal;
  overflow: hidden;
  speak: none;
  text-align: center;
}
div .block-search .action.search::before {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  font-size: 18px;
  line-height: 36px;
  color: var(--color-primary);
  content: '\e615';
  font-family: 'luma-icons';
  margin: 0;
  vertical-align: top;
  display: inline-block;
  font-weight: normal;
  overflow: hidden;

  text-align: center;
}

/* STILI ALTROMERCATO */
.message.error{
  font-size: 14px;
}

.message.success > *:first-child:before{
  left:-9px;
  font-size: 18px;
}

#search{
  font-size: 14px;
}

/* generici */
button[type="submit"] {
  padding-left: 44px !important;
  padding-right: 44px !important;
}
.text-center{
  text-align: center;
}

.font-bold{
  font-weight: bold;
}

.sidebar.sidebar-additional{
  display: none;
}

.message.info{
  font-size: 16px;
}

.checkout-payment-method .payment-option-content .form-discount{
  display: flex;
  width: 350px;
}
.transaction-secured, .policy {
  display: none !important;
}
.page-title-wrapper .action.print {
  display: none;
}

.checkout-payment-method .payment-option-content .form-discount .actions-toolbar .primary .action:not(:focus){
  height: 33px;
  margin-top: 3px;
  display: flex;
  align-items: center;
  background-color: #000;
  color: #fff;
  box-shadow: none;
}

.checkout-payment-method .payment-option-inner{
  width: 230px;
}

/* header */
@media screen and (min-width:768px), print{
  .navigation .level0.parent > .level-top{
    padding-right: 20px;
    display: flex !important;
    align-items: start;
    height: 62px;
    padding-top:10px;
  }
}

.navigation .level0.parent > .level-top span.ui-menu-icon{
  order:2;
  position: unset;
  right: unset;
  display: flex;
  padding-left: 10px;
}

.navigation .level0.parent > .level-top span:not(.ui-menu-icon){
  max-width: 160px;
  display: block;
  line-height: 1.5;
  padding-bottom: 10px;
  letter-spacing: .05em;
}
.navigation ul {
  padding: 0 8px;
  display: flex;
  justify-content: space-between;
}
.header.panel > .header.links > .customer-welcome + .authorization-link{
  display: inline-block;
}

.header.panel > .header.links{
  color: #000000;
}
.logged-in {
  font-weight: bold;
}
.form.minisearch .field.search label{
      display: none;
}

label[for="newsletter"]{
  span{
    display: none;
  }
}

.navigation li.level0{
  font-size: 14px;
}

.navigation .level0 .submenu a {
  text-decoration: none;
  letter-spacing: .05em;
}

.navigation .level0 > .level-top {
  color: #000 !important;
  text-transform: initial;
  font-weight: bold;
}

.breadcrumbs a {
  font-size: 14px;
  color: #000000;
}

.breadcrumbs strong{
  color: #000000;
  letter-spacing: .05em;
}

.breadcrumbs .items > li{
  font-size: 14px;
}

.breadcrumbs .items > li a:hover{
  /*padding-bottom: 2px;
  border-bottom: 1px solid #000000;*/
  text-decoration: none;
  cursor: pointer;
  color: #000000;
}

.breadcrumbs .items > li.item.product{
  color: #000000;
}

.breadcrumbs .items > li.item.home a:hover{
color: #000000;
}

.breadcrumbs .item:not(:last-child):after{
  margin-top:2x;
}

.breadcrumbs a:visited{
  color: #000000;
}

.breadcrumbs .item:not(:last-child):after{
  content: " > ";
    margin: 0 3px;
    color: #000;
    font-size: 14px;
}

.page-layout-2columns-left .main{
  border-radius: 5px;
  padding-right: 2%;
}

.minicart-wrapper .action.showcart .counter.qty{
  font-size: 16px;
  background: #000;
}

.minicart-wrapper .action.close{
  top: 5px;
  right: 5px;
}

/* ----------------- */
/* CARRELLO VIRTUALE */
/* ----------------- */
.virtual-cart-body{
  display: flex;
  font-size: 16px;
}
.virtual-cart-summary-box-wrapper.fixed {
  position: fixed;
    top: 20px;
    background-color: #fff;
    width: 305px;
}

.virtual_cart-index-index h1{
  font-size: 30px;
  font-weight: 600;
  text-align: center;
}
.virtual-cart-body .product-info{
  text-decoration: none;
  display: flex;
  align-items: center;
  color: #000;
}
.edit-cart-wrapper strong {
  display: block;
  margin-top: 30px;
}
.virtual-cart-body .product-info .p-image-wrapper{
  width: 84px;
  height: 84px;
  border:1px solid #f5f5f5;
  margin-right: 10px;
  display: flex;
    align-items: center;
    justify-content: center;
}

.virtual-cart-body .product-info img{
  height: 60px;
  padding: 10px;
}

.virtual-cart-body .product-info .p-name{
display:flex;
flex-direction:column;
font-weight: 600;
font-family: 'NeueHaasDisplay';
font-size: 16px;

}

.virtual-cart-body .product-info .p-name small{
  font-weight: 300;
  font-size: 10px;
}

.virtual-cart-body .first-col{
  padding-left: 0;
}

.virtual-cart-productlist-col{
  flex: 1;
  padding-right:15px;
}

.virtual-cart-productlist thead{
  border: none;
}

.virtual-cart-productlist tbody tr{
  border-bottom: 2px solid #CFCFCF;
}

.virtual-cart-productlist tbody tr:last-child{
  border-bottom: none;
}

.virtual-cart-productlist tbody td{
  vertical-align: middle;
  padding: 20px 0;
  font-size: 16px;
  font-weight: 600;
}

.virtual-cart-productlist thead td{
  font-size: 14px;
  font-weight: 400;
  padding-bottom: 0;
}

.virtual-cart-subtotal{
  margin-top:30px;
}

.virtual-cart-products, .virtual-cart-shipping{
  margin-bottom: 5px;
  margin-top: 5px;
}

.virtual-cart-summary-list{
  display: flex;
  flex-direction: column;
  font-size: 16px;
}

.virtual-cart-summary-item{
  display: flex;
}

.virtual-cart-summary-item .virtual-cart-summary-item-label{
  width: 200px;
  font-size: 16px;
  font-weight: 400;
}

.virtual-cart-summary-item .virtual-cart-summary-item-value{
  flex:1;
  text-align: right;
}

.virtual-cart-productlist .subtotal small{
  font-size: 12px;
  font-weight: 400;
}


.virtual-cart-summary-col{
  width: 320px;
  padding-left:15px;
}

.virtual-cart-summary-box{
  padding:18px;
  border-radius: 12px;
  border: 1px solid #888484;
  background: #FFF;
}

.virtual-cart-summary-box h2{
  margin-top:0;
  font-size: 18px;
  font-weight: 600;
  margin-bottom:30px;
}

.virtual-cart-summary-box .virtual-cart-total{
  border-top:1px solid #888484;
  padding-top: 5px;
}

.virtual-cart-summary-box .virtual-cart-total .virtual-cart-summary-item-label,.virtual-cart-summary-item-value {
  font-size: 16px;
  font-weight: 600;
}

.virtual-cart-summary-box .btn-checkout{
  background-color: #000;
  border-radius: 50px;
  color: #fff;
  text-decoration: none;
  display: inline-flex;
    align-items: center;
    justify-content: center;
  text-decoration: none;
  margin:auto;
  margin-top: 15px;
  height: 40px;
  width: 194px;
  cursor: pointer;
  transition: all .4s;
  font-size: 14px;
  font-weight: 600;
}

.edit-cart-wrapper{
  text-align: center;
}

.edit-cart-wrapper a{
  height: 40px;
  border:1px solid #000;
  background-color: transparent;
  border-radius: 50px;
  text-align: center;
  margin: 20px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  color: #000;
  width: 194px;
  font-size: 14px;
  cursor: pointer;
  transition: all .4s;
}
.cart-container .form-cart {
  float: none !important;
}
#shipping-method-summary {
  font-size: 14px;
  display: flex;
  justify-content: space-between;
  padding-bottom: 5px;
}
.carrier-amount {
  font-weight: bold;
}

/* -------------------------- */
/* RIEPILOGO CARRELLO POPOVER */
/* -------------------------- */

.minicart-wrapper.active .block-minicart{
  font-size: 16px;
}

.minicart-items .product-item-pricing .label,
.item-qty.cart-item-qty {
  font-size: 14px;
}

.minicart-wrapper .minicart-widgets{
  display: none;
}

.minicart-items .product-item{
  padding: 15px 0;
}

.checkout-payment-method .payment-method-content > .actions-toolbar > .primary .action.primary{
  font-size: 14px !important;
  font-weight: 600;
}


/* ------------ */
/* product list */
/* ------------ */


body.page-products .page-main > .page-title-wrapper .page-title{
      margin: 0;
    text-align: left;
    padding-left: 280px;
    margin-bottom: 20px;
    font-size: 24px;
}

body.page-products .sidebar.sidebar-main{
  margin-top: 64px;
}

body.page-products .filter-options-content a{
  text-decoration: none;
  padding-bottom: 5px;
  letter-spacing: .05em;
}

body.page-products .filter-options-content a:hover{
  text-decoration: underline;
  background-color: transparent;
}

.action-tocart-wrapper{
  position: relative;
}

.message.success{
  padding: 9px 20px 12px 25px;
  font-size: 1.1rem;
}

.message.success > *:first-child:before{
  font-size: 21px;
}

.toolbar-amount{
  font-size: 16px;
}

.products{
  margin:0;
}

.products.wrapper{
  background-color: #EEEEEE;
  margin: 0;
  padding: 26px;
  border-radius: 5px;
}

body.page-products .block-subtitle.filter-subtitle{
  display: none;
}

.page-products .product-item-info{
  background-color: #fff;
  padding: 20px 10px;
  width: 100%;
}

.abs-visually-hidden-desktop-s, .products-grid .product-item-info:not(:hover):not(.active) .product-item-inner{
  border: 0;
        /* clip: rect(0, 0, 0, 0); */
        height: auto;
        margin: 0;
        overflow: unset;
        padding: 0;
        position: relative;
        width: 100%;
        display: block;
}

.page-products .product-item-inner{
  width: 100%;
}

.page-products .products-grid .product-item-inner:before{
  content:none;
}

.products-grid .product-item-actions{
  margin:0;
}

.list.products-list .product-item-info{
  background-color: #fff;
  border-radius: 3px;
}

.list.products-list ol{
  display: flex;
  flex-direction: column;
  gap: 15px;
  padding: 0;
}

.list.products-list ol li .product-item-info{
  display: flex;
  width: 100%;
  gap: 25px;
  align-items: center;
  padding: 15px 20px;
  position: relative;
}

.list.products-list .product-item-photo{
  width: 100px;
  display: flex;
  padding: 0;
}

.list.products-list .product-item-details{
  flex-grow: 1;
  position: relative;
  display: flex;
    align-self: start;
}

.list.products-list .product-item-name{
  margin-top: 0;
}

.list.products-list .action.tocart.primary{
  background-color: #000;
  border:none;
  display: flex;
  align-items: center;
  gap: 10px;
  height: 40px;
  font-size: 14px;
  padding-right: 60px !important;
}

.action-tocart-wrapper::after{
  -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    font-size: 19px;
    line-height: 31px;
    content: '\e611';
    font-family: 'luma-icons';
    margin: 0;
    vertical-align: top;
    display: inline-block;
    font-weight: normal;
    overflow: hidden;
    speak: none;
    text-align: center;
    position: absolute;
    top: 3px;
    right: 36px;
    color: #fff;

}

.column.main .product-item{
  border-radius: 3px;
}

.product-item-name, .product.name a{
  font-size: 16px;
  font-weight: 600;
}

.toolbar.toolbar-products .sorter-label{
  font-size: 14px;
  letter-spacing: .05em;
}

.products-grid .product-item-info:hover, .products-grid .product-item-info.active{
  box-shadow: none;
  border:none;
  margin: auto;
  padding: 20px 10px;

}

.page-products .product-item-link,.page-products .product-item-name > a:visited{
  color: #000;
}

.page-products .product-item-link:hover{
  color: #000;
  text-decoration: none;
}

.page-products .product-item-actions{
  display: flex;
}

.page-products .product-item-actions .actions-primary{
  margin-left: auto;
}

.page-products .product-item-actions .actions-primary .quantity{
  display: flex;
  align-items: center;
}

.page-products .product-item-actions .actions-primary .quantity label{
  width: 120px;
  font-size: 16px;
  font-weight: 400;
}

.page-products .product-item-actions .actions-primary .quantity [name="qty"],
.page-products .product-item-actions .actions-primary .quantity .qty-selector {
  width: 60px;
  text-align: center;
  border:1px solid #DBDBDBEE;
  border-radius: 4px;
}

.page-products .product-item-actions .actions-primary .tocart-form{
  display: flex;
  gap:30px;
}

.page-products .product-item .actions-secondary{
  position: absolute;
  top: 0px;
  right: 0px;
}

.page-products .product-item .actions-secondary span{
display: none;
}

.page-products .product-item .price-box{
  margin:0;
  margin-top:10px;
  line-height: 1;
}

.page-products .product-item .price-box .price{
  font-size: 16px;
  font-weight: 600;
}

.page-products .toolbar select{
  background-color: transparent;
    border-radius: 5px;
    border: 1px solid #DBDBDBEE;
    box-shadow: none;
}

/* modale pagina listing - start */
.catalog-product-view .message-success.success.message,
.page-products .message-success.success.message {
  display: none !important;
  position: fixed;
  z-index: 10;
  right: 0;
  max-width: 240px;
  background: #FFF;
  border: 1px solid #000;
  padding: 25px;
  color: #000;
}
.catalog-product-view .modal-header,
.page-products .modal-header {
  display: flex;
  gap: 15px;
  align-items: center;
  text-align: left;
}
.catalog-product-view .modal-custom,
.page-products .modal-custom {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0,0,0,0.6);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 9999;
}
.catalog-product-view .modal-content,
.page-products .modal-content {
  background: #fff;
  padding: 25px 25px 44px 25px;
  width: 420px;
  max-width: 90%;
  border-radius: 0;
  position: relative;
  text-align: center;
}
.catalog-product-view .modal-close,
.page-products .modal-close {
  position: absolute;
  top: 0;
  right: 0;
  font-size: 25px;
  border: none;
  background: transparent;
  cursor: pointer;
  color: #000;
}
.catalog-product-view .modal-close:hover,
.page-products .modal-close:hover {
  opacity: .8;
  background: transparent;
  border: none;
  color: #000;
}
.catalog-product-view .modal-product-image,
.page-products .modal-product-image {
  max-width: 58px;
  margin-bottom: 15px;
  border-radius: 100px;
  border: 2px solid green;
}
.catalog-product-view .modal-product-wrapper,
.page-products .modal-product-wrapper {
  position: relative;
}
.catalog-product-view .modal-product-wrapper::after,
.page-products .modal-product-wrapper::after {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  font-size: 17px;
  line-height: 24px;
  color: #006400;
  content: '\e60e';
  font-family: 'luma-icons';
  margin: -12px 0 0;
  vertical-align: middle;
  display: inline-block;
  font-weight: normal;
  overflow: hidden;
  speak: none;
  right: -2px;
  bottom: 20px;
  width: fit-content;
  position: absolute;
  text-align: center;
  background: #FFF;
  border-radius: 50px;
}
.catalog-product-view .modal-product-name,
.page-products .modal-product-name {
  font-family: var(--font-body);
  margin-bottom: 30px;
  color: var(--color-primary);
  letter-spacing: .05em;
  margin-top: 16px;
}
.catalog-product-view .modal-actions,
.page-products .modal-actions {
  margin-top: 20px;
  display: flex;
  justify-content: space-around;
  flex-wrap: nowrap;
  gap: 20px;
}
.catalog-product-view .modal-actions .action.primary,
.page-products .modal-actions .action.primary {
  background: #FFF !important;
  color: #000;
  line-height: 2;
  border: 1px solid #000 !important;
}
.catalog-product-view .modal-actions a, .modal-actions button,
.page-products .modal-actions a, .modal-actions button {
  width: 100%;
  max-width: 208px;
  font-size: 14px !important;
  font-weight: normal !important;
}

/* modale pagina listing - end */



/* --------- */
/* categoria */
/* --------- */
.filter-label {
  display: none;
}
.filter .filter-current-subtitle {
  border: none;
  display: block;
  padding-bottom: 10px;
  text-transform: uppercase;
  line-height: 1.4;
}
.filter-options-content {
  margin: 0;
  padding: 10px;
  display: initial !important;
}
.filter-options-title {
  cursor: initial;
  font-weight: 600;
  margin: 0;
  overflow: hidden;
  padding: 0;
  position: relative;
  text-transform: uppercase;
  word-break: break-all;
  z-index: 1;
  display: block;
  text-decoration: none;
  pointer-events: none;
}
.filter-options-title::after {
  position: absolute;
  right: 13px;
  top: 12px;
  display: none;
}
.product-item-actions .actions-primary > .stock.unavailable{
  color: #B90000;
  font-size: 14px;
  font-weight: 400;
  letter-spacing: 0.28px;
}

.filter-options-title{
  font-size: 16px;
}

.filter-content .item{
  font-size: 16px;
  letter-spacing: 0.05em;
}
.filter-label {
  font-weight: 400;
}

.stock.unavailable {
  color: #B90000;
  font-size: 14px;
  font-weight: 400 !important;
  letter-spacing: 0.28px;
  text-transform: initial !important;
}

.products.wrapper ~ .toolbar .limiter{
  font-size: 16px;
  margin-top: 10px;
}

.products.wrapper ~ .toolbar .pages{
  margin-top: 40px;
}

/* --------------------- */
/* paginazione categoria */
/* --------------------- */
.pages{
  margin-top: 30px;
}

ul.items.pages-items{
  display: flex;
}

.pages .item{
  border:1px solid #D1D5DB;
  color: #000;
  border-radius: 8px;
  width: 40px;
  height: 40px;
  font-size: 16px;
  display: flex;
    justify-content: center;
    align-items: center;
}

.pages .item.current{
background: var(--color-primary);
}
.pages a.page {
  color: var(--color-primary);
}
.pages strong.page{
 background: none;
 font-size: 16px;
 font-weight: normal;
}
.pages strong.page {
  line-height: 3rem;
  letter-spacing: normal;
  color: #FFF;
}

.pages .action.next, .pages .action.previous{
  margin: 0;
    box-shadow: none;
    padding: 0;
    background-color: transparent;
    border: none;
}

.pages a.page:visited{
  color: #000;
}


/* --------------- */
/* pagina prodotto */
/* --------------- */
.fotorama__stage {
  max-height: 465px;
}
.fotorama--fullscreen .fotorama__stage {
  max-height: none;
}

.catalog-product-view .column.main{
  background-color: #fff;
}

.catalog-product-view .fotorama{
  border:1px solid #A8A8A8;
}

.catalog-product-view .price-iva{
  font-size: 18px;
  font-weight: 400;
}

.catalog-product-view .price-additional-info {
  font-size: 14px;
  font-weight: 400;
}

.catalog-product-view .price-box{
  margin-bottom: 20px;
}

.catalog-product-view .price-box .price{
  font-size: 45px;
  font-family: 'NeueHaasDisplay';
  font-weight: 400;
}

.catalog-product-view #qty {
  background-color: #eee;
  min-width: 70px;
  border: none;
  border-radius: 16px;
  max-width: fit-content;
}

.catalog-product-view [for="qty"] {
  font-weight: 700;
  font-size: 18px;
  font-family: 'NeueHaasDisplay';
  margin-right: 10px;
}

.catalog-product-view .action.primary{
  background-color: #000;
  border:none;
}

.catalog-product-view .action.primary:hover{
  background: #000;
}

.product-format {
  margin-bottom: 30px;
}

.catalog-product-view .links a{
  font-size: 14px;
}

.catalog-product-view .sku{
  font-size: 16px;
  font-weight: 400;
  color: #707070;
  margin-bottom: 20px;
}

.catalog-product-view .min-qty{
  font-size: 14px;
  color: #000000;
  font-weight: 600;
  margin-bottom: 20px;
}

.catalog-product-view h1{
  font-size: 20px;
  margin: 10px 0 20px 0;
}

.catalog-product-view .form-button-section{
  margin-top: 20px;
}

.catalog-product-view .links{
  display: flex;
  gap: 30px;
  margin-top:50px;
}


/* -------- */
/* CARRELLO */
/* -------- */
.cart-empty {
  text-align: center;
  background: #f0f0f0;
  max-width: 650px;
  margin: 0 auto;
  border-radius: 20px;
  padding: 20px 20px 10px 20px;
}

.cart-empty p {
  font-weight: bold;
}
.cart-summary > .title{
  font-size: 20px;
  font-weight: 700;
}

.cart-summary .block > .title{
  font-size: 16px;
  border: none;
}

.cart.table-wrapper .product-item-name{
  font-size: 16px;
  font-weight: 600;
  font-family: 'NeueHaasDisplay';
  margin: 0;
}

.price-including-tax .price, .price-excluding-tax .price{
  color: #000;
  font-size: 16px;
}

.cart.table-wrapper .cart thead tr th.col{
  border-bottom: none;
  font-size: 16px;
}

cart.table-wrapper .product-image-wrapper .product-image-photo{
  border: 1px solid #eee;
}

.cart.table-wrapper .item .col.item{
  vertical-align: middle;
  padding: 20px 0 !important;
}

.cart.table-wrapper .product-item-photo{
  width: 66px !important;
  height: 66px !important;
  position: relative !important;
  left: unset !important;
  max-width: unset !important;
  top: unset !important;
  display: inline-block !important;
  padding-right: 0 !important;
  vertical-align: middle !important;
  margin-right: 15px;
}

.cart.table-wrapper .product-item-sku{
  line-height: 1;
  font-size: 10px;
  font-weight: 300;
}

.cart.table-wrapper .product-item-details{
  display: inline-block !important;
  padding-bottom: 0 !important;
  width: auto !important;
  vertical-align: middle !important;
}

.product-item-details .product-sku{
  color: #000;
  font-size: 10px;
  font-weight: 300;
  letter-spacing: .05em;
}

.product-item-details .product-min-q{
  font-size: 14px;
  font-weight: 400;
  margin-top: 5px;
  letter-spacing: .05em;
}

.cart.items.table .product-image-container{
  aspect-ratio: unset;
  width: 66px;
  height: 66px;
  display: flex;
  align-items: center;
  justify-content: center;
  border:1px solid #eee;
  padding: 10px;
}

.cart-summary .checkout-methods-items .action.primary.checkout{
  font-size: 16px;
  height: 36px;
  padding: 0;
}

.cart.table-wrapper .actions-toolbar{
  text-align: right;
  padding-bottom: 5px;
}

.cart.table-wrapper .actions-toolbar > .action-edit:before, .cart.table-wrapper .actions-toolbar > .action-delete:before{
  color: #000;
}

.cart.table-wrapper .actions-toolbar > .action-edit, .cart.table-wrapper .actions-toolbar > .action-delete{
  position: relative;
  top: unset;
  right: unset;
}

.cart-totals .grand strong{
  font-size: 16px;
}

.cart-totals tbody .mark, .cart-totals tfoot .mark{
  font-size: 16px;
}

.cart-totals tbody .amount{
  font-size: 16px;
}

.cart-summary{
  background-color: transparent;
  border:2px solid #ccc;
  border-radius: 10px;
}

.cart-totals .grand .amount{
  padding: 0;
}

.cart-totals{
  border:none;
}

.cart-totals .grand th{
  padding: 0;
}

.card-totals .totals.shipping .mark{
  padding-bottom: 10px;
}

.action.multicheckout{
  font-size: 16px;
  text-decoration: none;
}

.cart.table-wrapper .cart > .item{
   border-bottom: 2px solid #ccc;
}

.cart.table-wrapper .col.qty{
  padding: 0;
  vertical-align: middle;
}

.cart.table-wrapper .cart tbody td{
  padding: 0;
  vertical-align: middle;
}

.checkout-cart-index .page-title-wrapper{
  width: 100%;
    text-align: center;
}

.checkout-cart-index h1{
font-size: 26px;
}

.cart-summary .block .title strong{
  font-size: 16px;
}

.cart-summary .block .fieldset .field{
  font-size: 16px;
}

.cart-summary .block .fieldset .field:not(.choice) > .label{
  font-size: 16px;
}

#co-shipping-method-form .item-title{
  font-size: 16px;
}

.cart-summary .block .item-options .field .radio + .label{
  font-size: 16px;
}

#block-discount-heading{
  font-size: 16px;
}

.cart.table-wrapper .product-image-wrapper{

}
.cart.table-wrapper .col.qty .input-text {
  height: 36px;
  margin-top: 0;
  text-align: center;
  width: 60px;
}

/* -------- */
/* minicart */
/* -------- */
.minicart-items-wrapper{
  border: none;
}

.block-minicart .block-content > .actions{
  margin-top: 0;
}

.minicart-items .product-item-name{
  margin-bottom: 0;
}

.minicart-items .product-item-details .price-excluding-tax{
  margin: 0;
  font-size: 16px;
    margin-top: 10px;
}

.minicart-items .item-qty{
  height: 24px;
}

/* -------- */
/* shipping */
/* -------- */
.opc-block-summary .items-in-cart > .title{
  border-bottom: none;
}

.opc-block-summary .items-in-cart > .title strong{
  font-size: 16px;
  padding: 0;
  padding-bottom: 5px;
}

.opc-block-summary > .title{
  padding-bottom: 0;
}

.opc-block-summary .product-item .product-item-name-block{
  font-size: 14px;
}


#customer-email-fieldset .field.required{
  margin-bottom: 0;
}

.opc-wrapper .form-login{
  padding-bottom: 0 !important;
}

.checkout-shipping-method .actions-toolbar .action.primary.button{
  height: 36px;
  padding: 0;
  font-size: 16px;
  padding: 0px 17px;
}

.checkout-shipping-method .step-title{
  font-size: 26px;
}

.checkout-payment-method .payment-method._active .payment-method-content{
  font-size: 16px;
}

.opc-progress-bar-item > span{
  padding: 0;
font-size: 1.3rem;
}

.opc-wrapper .step-title{
  font-size: 1.6rem;
}


.minicart-items .product-item-name{
  font-size: 14px;
}

.minicart-items .product-item-name a{
  font-size: 14px;
  color: #000;
  margin: 0;
}

#store-selector .form-continue .actions-toolbar .action.primary, .order-review-form .action.primary, .order-review-form .action.primary, .bundle-actions .action.primary.customize, .bundle-options-container .block-bundle-summary .box-tocart .action.primary, .box-tocart .action.tocart, .cart-summary .checkout-methods-items .action.primary.checkout, .block-minicart .block-content > .actions > .primary .action.primary, .methods-shipping .actions-toolbar .action.primary, .block-authentication .action.action-register, .block-authentication .action.action-login, .checkout-payment-method .payment-method-content > .actions-toolbar > .primary .action.primary, .form-address-edit .actions-toolbar .action.primary, .box-tocart .action.instant-purchase, .multicheckout .action.primary{
  height: 36px;
  padding: 0 17px;
  font-size: 1.2rem;
}

.opc-wrapper .step-title, .opc-block-shipping-information .shipping-information-title, .opc-block-summary > .title, .checkout-agreements-items .checkout-agreements-item-title{
  font-size: 1.2rem;
}

.opc-block-shipping-information .shipping-information-content{
  font-size: 16px;
}

.payment-method _active{
  font-size: 16px;
}

.opc-block-shipping-information .shipping-information-title .action-edit{
  top:2px;
}

/* riepilog e pagamento */
.cart-totals .grand strong, .opc-block-summary .table-totals .grand strong{
  font-size: 16px;
}

.cart-totals tbody .mark, .cart-totals tfoot .mark, .opc-block-summary .table-totals tbody .mark, .opc-block-summary .table-totals tfoot .mark{
  font-size: 16px;
}

.cart-totals tbody .amount, .cart-totals tfoot .amount, .opc-block-summary .table-totals tbody .amount, .opc-block-summary .table-totals tfoot .amount{
  font-size: 16px;
}

.cart-totals, .opc-block-summary .table-totals{
  border-top: none;
}

.opc-block-summary .items-in-cart > .title:after{
  top: 13px;
}

.opc-block-summary .product-item .product-item-inner{
  font-size: 16px;
}

.opc-block-summary .product-item .cart-price{
  font-size: 16px;
}

.opc-block-summary .product-item .price{
  font-size: 16px;
}

/* pagamento ok */

.checkout-success{
  text-align: center;
}
.payment-option._collapsible.opc-payment-additional.discount-code {
  pointer-events: none;
}
.action.primary.continue{
  border-radius: 10px;
  border-radius: 21px;
    padding-right: 40px;
    padding-left: 40px;
}

@media screen and (min-width:768px), print{
  .page-main > .page-title-wrapper .page-title{
    text-align: center;
    width: 100%;
    display:block;
  }
}

/* sidebar */
.sidebar.sidebar-additional{
  font-size: 16px;
}

/* CUSTOMERS */
body.account{

}
.magento-payments-review .block .box-title > span, .paypal-review .block .box-title > span, .account .column.main .block:not(.widget) .box-title > span, .multicheckout .box-title > span, .magento-rma-guest-returns .column.main .block:not(.widget) .box-title > span, [class^='sales-guest-'] .column.main .block:not(.widget) .box-title > span, .sales-guest-view .column.main .block:not(.widget) .box-title > span{
  font-size: 1.3rem;
}
.account .page-title-wrapper .page-title{
  width: 100%;
  text-align: left;
  font-size: 30px !important;
}

.account .order-number{
  font-size: 16px;
}

.customer-account-index .page-wrapper{
  background: #f0f0f0;
}

.customer-account-index .block.block-dashboard-info{
  background-color: #fff;
    border-radius: 10px;
    padding: 15px 30px;
}
.block.block-dashboard-info strong {
  font-weight: 500;
}

.customer-account-index .box-informations{
  display: flex;
    flex-direction: column;
    gap: 15px;
}

.customer-account-index .box-informations .box-title span{
  font-size: 14px !important;
  letter-spacing: .05em;
}

.customer-account-index .box-informations .box-content{
  flex:1;
  font-weight: normal;
}

.customer-account-index .single-information{
  display: flex;
  align-items: center;
  padding: 0;
  border-bottom: 2px solid #eee;
  padding-bottom: 8px;
}

.customer-account-index .box-title{
  width: 320px;
}

.customer-account-index .box-actions{
  text-align: right;
}

.account.page-layout-2columns-left .column.main{
  float:none !important;
  margin: auto;
}

.account .table-wrapper{
  border-bottom: none;
}

.account .table-wrapper .block-shopping-cart-icon{
  border-radius: 50%;
  border:1px solid #000;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 50px;
  width: 50px;
}

.account .table-wrapper .block-shopping-cart-icon i{
  font-size: 30px;
}

.account .table > tbody > tr > td{
  border: none;
  height: 50px;
  vertical-align: middle;
  padding: 0;
  padding-bottom: 15px;
}

.account .table-wrapper.orders-recent{
  margin-top: 0;
  width: 100%;
}
.table-wrapper.orders-recent small {
  font-size: 14px;
  letter-spacing: 0.05em;
}

.account .table .action.order{
  border-radius: 30px;
  background-color: #000;
  color: #fff;
  text-decoration: none;
  height: 38px;
  width: 130px;
  display: inline-block;
  padding: 10px;
  font-weight: 600;
}

.account .table .col.id{
  font-size: 14px;
}

.account .table .col.total{
  font-weight: bold;
  text-align: center;
}

.account .table .col.actions{
  text-align: center;
}

.account .column.main .block:not(.widget) .block-title{
  border-bottom: none;
  margin-bottom: 0;
  padding-bottom: 0;
  width: 40%;
  align-items: center;
  justify-content: start;
  display: flex;
}

.account .block-dashboard-orders{
  display: flex;
  min-height: 300px;
  background-color: #fff;
    border-radius: 10px;
    padding: 15px 30px;
}

.account .block-dashboard-orders .block-title.order h2{
  font-size: 30px;
}
.account .box-actions .action.edit {
  font-size: 14px;
  font-weight: 400;
  letter-spacing: .065em;
}
.account .column.main h2{
  margin-bottom: 0;
}

.account .block-last-order-list{
  flex:1;
  display: flex;
  align-items: center;
}

.account .page-header{
  background-color: #fff !important;
}

/* order details */
.order-details-items .product-item-name{
  font-size: 20px;
}

.account .column.main .block:not(.widget) .block-title > strong{
font-size: 20px;
}

.account .column.main .block:not(.widget) .box-title > span{
  font-size: 18px;
}

.account .order-status{
  margin-top: 30px;
}

/* LOGIN PAGE */
.customer-account-login .login-container{
  width: 450px;
  max-width: 100%;
  margin: auto;
  font-size: 16px;
}
.primary .login {
  margin: 0 !important;
}
.fieldset.login .primary {
  width: 100%;
  display: flex !important;
  justify-content: center !important;
}
.login-container .fieldset::after {
  margin: 10px 0 0;
  content: attr(data-hasrequired);
  display: block;
  letter-spacing: normal;
  word-spacing: normal;
  color: #e02b27;
  font-size: 1.2rem;
  display: none;
}
#login-form .secondary {
  margin-bottom: 45px;
}
.customer-account-login .login-container input[type='email'], .customer-account-login .login-container input#password {
  width: 100%;
  border-radius: 30px;
  border:2px solid #eee;
  height: 40px;
}

.customer-account-login .login-container .fieldset > .field > .control{
  width: 100%;
}

.customer-account-login .login-container .block-customer-login{
  width: 100%;
}

.block-customer-login .block-title{
  display: none;
}

.customer-account-login .login-container .block .block-title{
  text-align: center;
}

.customer-account-login .login-container .label span{
  padding-left: 9px;
  font-size: 14px;
}

.customer-account-login .login-container .fieldset:after{
  font-size: 14px;
}

.actions-toolbar > .primary:last-child{
  display: flex;
}


/* password dimenticata */
.customer-account-forgotpassword{
  font-size: 16px;
}

.customer-account-forgotpassword input[type='email']{
  width: 100%;
    border-radius: 12px;
    border: 2px solid #eee;
    height: 40px;
}

.form.password.forget .fieldset:after{
  font-size: 16px;
}

.form.password.reset{
  font-size: 16px;
}

div.mage-error{
  font-size: 16px;
}

/* checkout-onepage-success */
.checkout-success{
  font-size: 16px;
}

.checkout-onepage-success h1{
  margin-bottom: 15px;
}

.checkout-onepage-success .action.print{
  float: none;
    margin-top: 0;
    margin-bottom: 30px;
    width: 100%;
    text-align: center;
}

.checkout-onepage-success .primary{
  width: 100%;
  display: flex;
  justify-content: center;
}

.checkout-onepage-success .page-main > .page-title-wrapper .page-title + .action{
  float: none;
}

.cart-empty{
  font-size: 16px;
}


/* ------ */
/* FOOTER */
/* ------ */
.col-3.footer-menu {
  width: auto;
}
.full-width.menus {
  padding-bottom: 10px;
}
.social-button:visited,
.social-button:hover {
  color: #FFF;
  text-decoration: none;
  opacity: .8;
}
.social-line{
  display: flex;
  gap:8px;
  justify-content: flex-end;
  margin-bottom: 15px;
}
.footer.content {
  border-top: 1px solid var(--color-border) !important;
}
.social-button{
  border-radius: 50%;
    background-color: #000;
    width: 24px;
    display: flex;
    height: 24px;
    color: #fff;
    align-items: center;
    justify-content: center;
    text-decoration: none;
}

.newsletter.eyeAbleSkipFontSize{
  display:none;
}
.g-c-flexo{
  display: flex;
  width: 80%;
  gap:50px;
}

.footer-menu{
  display: flex;
  flex-direction: column;
}

.footer-menu a{
  text-decoration: none;
  margin-bottom: 3px;
  letter-spacing: .05em;
}

.certificazioni{
  width: 170px;
}

.full-width.subf{
  background-color: #eee;
    line-height: 1.2em;
    padding: 20px 0;
    font-weight: 600;
    letter-spacing: .5px;
    color: #000;
    font-size: 12px;
    line-height: 19px;
    margin-top:15px;
}

.page-footer{
  width: 100%;
}

.footer.content{
  width: 100% !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
  max-width: unset !important;
}

.footer.content .container{
  width: 100%;
  display: flex;
}

.footer.content .col-2{
  display: flex;
  flex-direction: column;
}

.footer.content .footer-menu{
  display: flex;
  align-items: flex-start;
}

.footer-menu h6{
  margin-top:0;
}

/* Pagina di Checkout - start */
.opc-progress-bar {
  text-align: center;
}
.opc-progress-bar-item._active::before {
  background: #940a2b !important;
  border-color: #940a2b !important;
  content: none;
}
.opc-progress-bar-item._active > span::before {
  background: #940a2b !important;
  border-color: #940a2b !important;
  content: none;
}
html .opc-progress-bar-item._active > span::after {
  border-color: #940a2b !important;
  content: '\e610';
  font-family: 'luma-icons';
  content: none;
}
.opc-wrapper .shipping-address-item.selected-item::after {
  background: green !important;
  color: #fff;
  content: '\e610';
  font-family: 'luma-icons';
  height: 27px;
  width: 29px;
  font-size: 19px;
  line-height: 21px;
  padding-top: 2px;
  position: absolute;
  right: -7px;
  text-align: center;
  top: -12px;
  border-radius: 50px;
  font-size: 16px;
}
.opc-progress-bar-item {
  margin: 0 0 10px;
  max-width: 615px;
  display: inline-block;
  position: relative;
  text-align: center;
  vertical-align: top;
  width: 100%;
}
.opc-progress-bar {
  margin-top: 70px;
}
.opc-progress-bar-item:first-child::before {
  border-radius: 0 0 0 0;
}
.opc-wrapper .shipping-address-item.selected-item {
  border-color: green;
}
.checkout-index-index .modal-popup .form-shipping-address {
  max-width: 565px;
  margin: 0 auto;
}
.modal-popup.new-shipping-address-modal.modal-slide._inner-scroll._show {
  max-width: 900px;
  margin: 0 auto;
}
.opc-progress-bar-item > span::before, .opc-progress-bar-item > span::after {
  font-size: 17px !important;
}
.opc-progress-bar-item._complete span {
  color: var(--color-primary);
}
.cvv-input-container.input-container,
.exp-input-container.input-container,
.pan-input-container.input-container,
.cardholder-input-container.input-container {
  width: 100% !important;
}
.schemes {
  display: none;
}
.col-carrier {
  display: none;
}
.selected-shipping-method {
    font-weight: bold;
    background-color: #f5f5f5;
}
.table-checkout-shipping-method td {
    padding: 20px !important;
}
.table-checkout-shipping-method tr:not(.selected-shipping-method) {
  display: none;
}

/* Pagina di Checkout - end */

/* -------------------- */
/* MOBILE MOBILE MOBILE */
/* -------------------- */
@media screen and (max-width:1220px){
  body.page-products .page-main > .page-title-wrapper .page-title{
    padding: 0;
    width: 100%;
    text-align: center;
  }
}

@media screen and (max-width:880px){
  .products.wrapper{
    padding: 15px;
  }
}

@media screen and (max-width:850px){
  .page-products .product-item-actions .actions-primary .tocart-form{
    flex-direction: column;
  }
}

@media (min-width: 768px), print {
        .header.panel > .header.links > .customer-welcome + .authorization-link {
            display: inline-block !important;
        }

        .account.page-layout-2columns-left .column.main{
          width: 82% !important;
        }
}

@media screen and (max-width:450px){
  .product-item .action.towishlist{
    position: absolute;

  }

}

.checkout-billing-address {
  display: none;
}

.actions-toolbar .action.action-delete + .action.action-delete {
  display: none;
}

body.checkout-index-index.page-layout-checkout .column.main {
	display: flex;
  flex-wrap: wrap;
}
body.checkout-index-index.page-layout-checkout .checkout-container {
	width: 66.6666%;
}
body.checkout-index-index.page-layout-checkout .opc-wrapper {
	width: 100%;
}
body.checkout-index-index.page-layout-checkout .opc-progress-bar {
	width: 142%;
}
body.checkout-index-index.page-layout-checkout .custom-checkout-sidebar-wrapper {
	width: 33.3333%;
	padding-top: 119px;
	padding-left: 30px;
}
body.checkout-index-index.page-layout-checkout .virtual-cart-summary-col {
	width: 100%;
	padding: 0;
}

.custom-checkout-customerinfo-wrapper .box-informations{
  display: flex;
    flex-direction: column;
    gap: 15px;
}

.custom-checkout-customerinfo-wrapper .box-informations .box-title span{
  font-size: 14px !important;
  letter-spacing: .05em;
}

.custom-checkout-customerinfo-wrapper .box-informations .box-content{
  flex:1;
  font-weight: normal;
}

.custom-checkout-customerinfo-wrapper .single-information{
  display: flex;
  align-items: center;
  padding: 0;
  border-bottom: 2px solid #eee;
  padding-bottom: 8px;
}

.custom-checkout-customerinfo-wrapper .box-title{
  width: 320px;
}

.custom-checkout-customerinfo-wrapper .box-actions{
  text-align: right;
}

.custom-checkout-customerinfo-wrapper h2 {
  margin-bottom: 20px;
}
.custom-checkout-customerinfo-wrapper {
  width: 100%;
}

.product-image-wrapper {
  overflow: visible;
}
.product-image-photo:hover {
  transform: scale(2);
}
.p-image-wrapper img:hover {
  transform: scale(3);
}