/*
Theme Name: Veno Shop
Theme URI: https://veno.es
Author: LLiquida
Description: Un tema a blocchi custom by Veno
Version: 1.0.0
Requires at least: 6.2
Tested up to: 6.4
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: veno-shop
*/
html {scroll-behavior: smooth;}

html *{
    box-sizing: border-box;
}
body{
	background: #fff;
	color: #1e293b;
	font-family: 'Inter', Helvetica, Arial, sans-serif;
	font-weight: 400;
    position: relative;
}

h1, h2, h3, h4, h5, h6,
.veno-stripe-price{
    letter-spacing: -0.02em;
    margin: 0;
    margin-bottom: 1rem;
}

h1 strong, h2 strong, 
h1 b, h2 b{
    font-weight: 900;
}
h3 strong,
h3 b{
	font-weight: 700;
}

b, strong{
	font-weight: 600;
}

a{
    text-decoration: none;
    color: var(--wp--preset--color--primary);
}
:where(.wp-site-blocks) > *{
	margin-block-start: 0;
}

.logged-in .hero-guest { display: none; }
body:not(.logged-in) .hero-logged { display: none; }

.wp-block-list{
    padding: 0;
    padding-left: 1em;
}


/* Custom Navigation Styles */
.navbar-veno-shop {
    position: fixed !important;
    top: 0;
    left: 0;
    right: 0;
    width: 100%;
    background-color: transparent;
    transition: background-color 0.3s ease-in-out, backdrop-filter 0.3s ease-in-out, padding 0.3s ease-in-out;
    padding: 0.5rem 0;
    z-index: 1030;
}
/* Fix for mobile menu collapse background when scrolled */
@media (max-width: 991.98px) {
    .navbar-veno-shop {
        padding: 1rem;
    }
}
.navbar-veno-shop .wp-block-navigation .has-child .wp-block-navigation__submenu-container{
     border: none;
     position: relative;
     align-items: center;
     background-color: transparent;
}

.navbar-veno-shop .wp-block-navigation .has-child .wp-block-navigation__submenu-container .wp-block-navigation-item{
    background-color: transparent;
}

.navbar-veno-shop .wp-block-navigation .wp-block-navigation-item.has-child{
    flex-direction: column;
    width: 100%;
}
.navbar-veno-shop .wp-block-navigation .wp-block-navigation-item.has-child::after{
    content: "+";
    display: inline-block;
    color: #fff;
    position: absolute;
    right: 1rem;
    top: 1rem;
}

.navbar-veno-shop .wp-block-navigation .wp-block-navigation-item.has-child .wp-block-navigation__submenu-icon{
    display: none;
}

.navbar-veno-shop::before{
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0; bottom: 0;
  z-index: -1; /* Fondamentale: sta dietro al contenuto del genitore */
      backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
}

@media screen and (min-width: 992px) {
    .navbar-veno-shop .wp-block-navigation .has-child .wp-block-navigation__submenu-container{
        position: absolute;
        align-items: normal;
        background-color: rgba(255, 255, 255, 0.5) !important;
        backdrop-filter: blur(10px);
        -webkit-backdrop-filter: blur(10px);
    }
    .navbar-veno-shop::before{
          backdrop-filter: none;
        -webkit-backdrop-filter: none;
    }

    .navbar-veno-shop  .wp-block-navigation .wp-block-navigation-item.has-child{
        flex-direction: row;
        width: auto;
    }
}

/* Adjust top position if admin bar is present */
.admin-bar .navbar-veno-shop {
    top: 32px;
}

@media screen and (max-width: 782px) {
    .admin-bar .navbar-veno-shop {
        top: 46px;
    }
}

.navbar-veno-shop.scrolled{
    background-color: rgba(80, 50, 200, 0.4) !important;

}

.navbar-veno-shop.scrolled::before{
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
}

/* Base styles for navigation links within navbar-veno-shop */
.navbar-veno-shop .wp-block-navigation .wp-block-navigation-item__content {
    color: #fff !important;
    position: relative;
    padding: 1rem 2rem !important;
    text-decoration: none !important;
    transition: color 0.3s ease;
    text-transform: uppercase;
    font-size: 0.9rem;
	letter-spacing: 1px;
}

.navbar-veno-shop .wp-block-navigation .current-menu-item .wp-block-navigation-item__content::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 1rem;
    right: 1rem;
    height: 4px;
    background-color: var(--wp--preset--color--primary); /* #F1FF00 Primary Yellow from theme.json */
    transition: transform 0.3s ease;
}

.navbar-veno-shop .navbar-toggler,
.navbar-veno-shop .navbar-toggler:hover,
.navbar-veno-shop .navbar-toggler:active,
.navbar-veno-shop .navbar-toggler:focus{
	border: none;
	outline: none;
	box-shadow: none;
}


:root {
  --bs-body-bg: #fff;
  --bs-body-color: #212529;
  --bs-border-color: #dee2e6;
  --bs-border-radius: 0.375rem;
  --bs-primary: #0d6efd;
  --bs-focus-ring-color: rgba(13, 110, 253, 0.25);
}

/* Versione Dark Mode */
[data-bs-theme="dark"] {
  --bs-body-bg: #212529;
  --bs-body-color: #dee2e6;
  --bs-border-color: #495057;
}



.form-control {
  display: block;
  width: 100%;
  padding: 0.375rem 0.75rem;
  font-size: 1rem;
  font-weight: 400;
  line-height: 1.5;
  color: var(--bs-body-color);
  background-color: var(--bs-body-bg);
  background-clip: padding-box;
  border: 1px solid var(--bs-border-color);
  appearance: none; /* Rimuove stile iOS/Android */
  border-radius: var(--bs-border-radius);
  transition: border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
  box-sizing: border-box;
}

.form-control:focus {
  color: var(--bs-body-color);
  background-color: var(--bs-body-bg);
  border-color: #86b7fe;
  outline: 0;
  box-shadow: 0 0 0 0.25rem var(--bs-focus-ring-color);
}

.form-control::placeholder {
  color: #6c757d;
  opacity: 1;
}

.form-control:disabled {
  background-color: #e9ecef;
  opacity: 1;
}


.form-select {
  display: block;
  width: 100%;
  padding: 0.375rem 2.25rem 0.375rem 0.75rem;
  font-size: 1rem;
  font-weight: 400;
  line-height: 1.5;
  color: var(--bs-body-color);
  background-color: var(--bs-body-bg);
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill='none' stroke='%23343a40' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m2 5 6 6 6-6'/%3e%3c/svg%3e");
  background-repeat: no-repeat;
  background-position: right 0.75rem center;
  background-size: 16px 12px;
  border: 1px solid var(--bs-border-color);
  border-radius: var(--bs-border-radius);
  appearance: none;
}

.form-select:focus {
  border-color: #86b7fe;
  outline: 0;
  box-shadow: 0 0 0 0.25rem var(--bs-focus-ring-color);
}




.form-check {
  display: block;
  min-height: 1.5rem;
  padding-left: 1.5em;
  margin-bottom: 0.125rem;
}

.form-check-input {
  width: 1em;
  height: 1em;
  margin-top: 0.25em;
  vertical-align: top;
  background-color: var(--bs-body-bg);
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  border: 1px solid var(--bs-border-color);
  appearance: none;
  print-color-adjust: exact;
}

/* Checkbox quadrato */
.form-check-input[type="checkbox"] {
  border-radius: 0.25em;
}

/* Radio tondo */
.form-check-input[type="radio"] {
  border-radius: 50%;
}

/* Stato selezionato (Checked) */
.form-check-input:checked {
  background-color: var(--bs-primary);
  border-color: var(--bs-primary);
}

/* Icona della spunta (SVG bianco) */
.form-check-input[type="checkbox"]:checked {
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20'%3e%3cpath fill='none' stroke='%23fff' stroke-linecap='round' stroke-linejoin='round' stroke-width='3' d='m6 10 3 3 6-6'/%3e%3c/svg%3e");
}

/* Icona del pallino radio (SVG bianco) */
.form-check-input[type="radio"]:checked {
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='-4 -4 8 8'%3e%3ccircle r='2' fill='%23fff'/%3e%3c/svg%3e");
}


.form-switch {
  padding-left: 2.5em;
}

.form-switch .form-check-input {
  width: 2em;
  margin-left: -2.5em;
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='-4 -4 8 8'%3e%3ccircle r='3' fill='rgba(0, 0, 0, 0.25)'/%3e%3c/svg%3e");
  background-position: left center;
  border-radius: 2em;
  transition: background-position 0.15s ease-in-out;
}

.form-switch .form-check-input:checked {
  background-position: right center;
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='-4 -4 8 8'%3e%3ccircle r='3' fill='%23fff'/%3e%3c/svg%3e");
}

.is-style-spotlight-bg,
.is-style-spotlight-blue,
.is-style-spotlight-green,
.is-style-spotlight-orange {
    text-shadow: 0 4px 15px rgba(0,0,0,0.3);
    margin: 0;
    padding: 0;
    color: #fff;
    position: relative;
    overflow: hidden;
    clip-path: inset(0); 
    contain: paint;
    z-index: 0;
    /* FIX 1: Isola il contesto di stacking per evitare glitch con i filtri */
    isolation: isolate; 
    /* FIX 2: Evita micro-spostamenti del contenitore */
    -webkit-transform: translateZ(0);
    transform: translateZ(0);
}

.is-style-spotlight-bg::before,
.is-style-spotlight-blue::before,
.is-style-spotlight-green::before,
.is-style-spotlight-orange::before {
    content: "";
    position: absolute;
    top: -30%; /* Aumentato leggermente per sicurezza */
    left: -30%;
    width: 160%; /* Aumentato leggermente */
    height: 160%;
    z-index: -2;
    /* FIX 2: Usa translate3d per attivare la GPU */
    animation: moveSpotlights 12s ease-in-out infinite alternate;
    will-change: transform;
    /* FIX 3: Previene flickering durante la rotazione/traslazione */
    backface-visibility: hidden;
    -webkit-backface-visibility: hidden;
    background-size: 80%;
    background-repeat: no-repeat;
}

.is-style-spotlight-blue::before {
    background-color: #030612;
    background-image: 
    radial-gradient(circle at 20% 45%, rgba(0, 0, 0, 0.75) 0%, rgba(0, 0, 0, 0) 50%), 
    radial-gradient(circle at 50% 90%, rgba(5, 4, 24, 0.55) 0%, rgba(5, 4, 24, 0) 45%), 
    radial-gradient(circle at 10% 20%, rgba(0, 16, 26, 0.85) 0%, rgba(0, 16, 26, 0) 40%), 
    radial-gradient(circle at 70% 50%, rgba(16, 29, 82, 0.5) 0%, rgba(16, 29, 82, 0) 40%), 
    radial-gradient(circle at 50% 50%, rgba(16, 100, 188, 0.58) 0%, rgba(16, 100, 188, 0) 45%);
}

.is-style-spotlight-green::before {
  background-color: #030612;
  background-image: 
    radial-gradient(circle at 20% 45%, rgba(8, 255, 127, 0.75) 0%, rgba(8, 255, 127, 0) 50%),
    radial-gradient(circle at 50% 90%, rgba(38, 58, 221, 0.35) 0%, rgba(38, 58, 221, 0) 45%),
    radial-gradient(circle at 10% 20%, rgba(0, 159, 255, 0.85) 0%, rgba(0, 159, 255, 0) 40%),
    radial-gradient(circle at 70% 10%, rgba(0, 112, 255, 0.5) 0%, rgba(0, 112, 255, 0) 40%),
    radial-gradient(circle at 50% 50%, rgba(35, 130, 231, 0.5) 0%, rgba(35, 130, 231, 0) 45%);
}

.is-style-spotlight-orange::before {
    background-color: #0b0312;
    background-image: 
        /* Rosso vivido */
        radial-gradient(circle at 20% 45%, rgba(255, 6, 6, 0.75) 0%, rgba(255, 6, 6, 0) 50%), 
        /* Arancio (questo era già a 0 opacità nel tuo codice, l'ho mantenuto coerente) */
        radial-gradient(circle at 50% 90%, rgba(255, 179, 0, 0) 0%, rgba(255, 179, 0, 0) 45%), 
        /* Arancio bruciato */
        radial-gradient(circle at 10% 20%, rgba(255, 143, 0, 1) 0%, rgba(255, 143, 0, 0) 40%), 
        /* Rosso puro */
        radial-gradient(circle at 70% 10%, rgba(255, 0, 0, 0.62) 0%, rgba(255, 0, 0, 0) 40%), 
        /* Sfondo scuro rossastro */
        radial-gradient(circle at 50% 50%, rgba(87, 2, 2, 0.28) 0%, rgba(87, 2, 2, 0) 45%);
}
.is-style-spotlight-bg::before {
  background-color: #030712;
  background-image: 
    radial-gradient(circle at 20% 45%, rgba(255, 0, 64, 0.8) 0%, rgba(255, 0, 64, 0) 50%), 
    radial-gradient(circle at 50% 90%, rgba(143, 15, 231, 0.77) 0%, rgba(143, 15, 231, 0) 45%), 
    radial-gradient(circle at 10% 20%, rgba(151, 25, 231, 0.6) 0%, rgba(151, 25, 231, 0) 40%), 
    radial-gradient(circle at 70% 10%, rgba(129, 35, 231, 0.5) 0%, rgba(129, 35, 231, 0) 40%), 
    /* NUOVO PUNTO: Copre l'angolo basso-destra */
    radial-gradient(circle at 85% 85%, rgba(3, 7, 18, 0.4) 0%, rgba(143, 15, 231, 0) 50%),
    radial-gradient(circle at 50% 50%, rgba(3, 7, 18, 0.5) 0%, rgba(231, 35, 153, 0) 45%);
}

/* FIX 4: Ottimizzazione del Backdrop Filter */
.is-style-spotlight-bg::after,
.is-style-spotlight-blue::after,
.is-style-spotlight-green::after,
.is-style-spotlight-orange::after {
    z-index: -1;
    content: "";
    position: absolute;
    /* Estendi leggermente oltre i bordi per evitare che il blur "scopra" i pixel sottostanti */
    top: -10px; left: -10px; right: -10px; bottom: -10px;
    backdrop-filter: blur(70px) saturate(1.2);
    -webkit-backdrop-filter: blur(70px) saturate(1.2);
    pointer-events: none;
    /* Forza la GPU anche qui */
    transform: translateZ(0);
}

/* FIX 5: Modifica l'animazione per usare translate3d */
@keyframes moveSpotlights {
    0% {
        transform: translate3d(0, 0, 0);
    }
    70% {
        transform: translate3d(5%, 10%, 0);
    }
    100% {
        transform: translate3d(-5%, 15%, 0);
    }
}



.veno-col{
max-width: 850px;
  min-width: 60%;
  flex: 1 1 0%;
box-sizing: border-box;
}
.veno-col-sm{
max-width: 760px;
  flex: 1 1 0%;
box-sizing: border-box;
}
.position-relative{
position:relative;
}

.h-100{
height: 100%;
}

.form-control {
  display: block;
  width: 100%;
  padding: .375rem .75rem;
  font-size: 1rem;
  font-weight: 400;
  line-height: 1.5;
  color: var(--bs-body-color);
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background-clip: padding-box;
  border: 1px solid #d2d2d2;
  border-radius: 4px;
  transition: border-color .15s ease-in-out,box-shadow .15s ease-in-out;
box-sizing: border-box;
}

.wc-block-components-product-image{
aspect-ratio: 16/9 !important;
}


.form-select {
  --bs-form-select-bg-img: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill='none' stroke='%23343a40' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m2 5 6 6 6-6'/%3e%3c/svg%3e");
  display: block;
  width: 100%;
  padding: .375rem 2.25rem .375rem .75rem;
  font-size: 1rem;
  font-weight: 400;
  line-height: 1.5;
  color: var(--bs-body-color);
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background-color: var(--bs-body-bg);
  background-image: var(--bs-form-select-bg-img),var(--bs-form-select-bg-icon,none);
  background-repeat: no-repeat;
  background-position: right .75rem center;
  background-size: 16px 12px;
  border: 1px solid #d2d2d2;
  border-radius: var(--bs-border-radius);
  transition: border-color .15s ease-in-out,box-shadow .15s ease-in-out;
box-sizing: border-box;
}


.wc-block-next-previous-buttons__button {
  height: 40px;
  width: 40px;
  padding: 0;
  z-index: 22;
  cursor: pointer;
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: 50%;
  border: none;
  outline: none;
  background-color: rgba(255, 255, 255, 0.15);
  backdrop-filter: blur(12px) saturate(180%);
  -webkit-backdrop-filter: blur(12px) saturate(180%);
  background-image: linear-gradient(135deg, rgba(255, 255, 255, 0.3) 0%, rgba(255, 255, 255, 0) 60%);
  border: 1px solid rgba(255, 255, 255, 0.2);
  box-shadow:
    0 4px 12px rgba(0, 0, 0, 0.2),
    inset 0 1px 0 rgba(255, 255, 255, 0.3),
    inset 0 -1px 0 rgba(0, 0, 0, 0.1);
  color: #fff;
  font-size: 16px;
  transition: all 0.3s cubic-bezier(0.25, 0.8, 0.25, 1);
}

.wc-block-next-previous-buttons__button:focus-visible {
  outline: 2px solid rgba(0, 122, 255, 0.7);
  outline-offset: 2px;
}

.wc-block-next-previous-buttons__button svg {
  fill: currentColor;
}
.text-nowrap{
white-space:nowrap;
}

/* Contenitore della form di ordinamento */
.woocommerce-ordering {
    margin-bottom: 2em;
}

/* Stile del select */
.woocommerce-ordering select.orderby {
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    background-color: #f9fafb;
    border: 1px solid #e2e8f0;
    border-radius: 12px;
    padding: 12px 40px 12px 20px;
    font-size: 14px;
    font-weight: 500;
    color: #1f2937;
    cursor: pointer;
    transition: all 0.3s ease;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%236b7280'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M19 9l-7 7-7-7'%3E%3C/path%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 15px center;
    background-size: 18px;
    outline: none;
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.05);
}

/* Effetto Hover */
.woocommerce-ordering select.orderby:hover {
    border-color: #3b82f6; /* Colore brand blu */
    background-color: #ffffff;
}

/* Effetto Focus */
.woocommerce-ordering select.orderby:focus {
    border-color: #3b82f6;
    box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1);
}

ul, ol{
padding: 0;
padding-left: 1em;
}
ul.wc-block-product-gallery-large-image__container{
    padding: 0;
}
.wp-block-details summary{
    font-size: var(--wp--preset--font-size--medium);
    padding: 1rem;
    outline:none;
    border: 1px solid #dadada;
}
.wp-block-details p{
    padding: 1rem;
}
.wp-block-image img {
  vertical-align: center;
}


del {
    text-decoration: none; /* Rimuoviamo la linea originale brutta */
    position: relative;
    display: inline-block; /* Necessario per il posizionamento della linea */
    transform: scale(0.8);
    vertical-align: sub;
    opacity: 0.7; /* Opzionale: rende la linea meno aggressiva */
    line-height: 1;
}

del::after {
  content: "";
  position: absolute;
  left: 0;
  top: 50%; /* Posiziona al centro esatto */
  transform: translateY(-50%) rotate(-4deg);
  width: 100%;
  height: 1.5px; /* Puoi decidere lo spessore (es. 1px, 1.5px, 2px) */
  background-color: #333; /* Prende lo stesso colore del testo */

}

ins{
    display: inline-block;
    color: inherit;
    text-decoration: none;
    line-height: 1;
}

.woocommerce-account .woocommerce-MyAccount-navigation li{
    padding: 0;
}
.woocommerce-account .woocommerce-MyAccount-navigation li a{
   padding: 0.5rem 1rem;
   display: block;
   border-left: 2px solid transparent;
    text-decoration: none;
}
.woocommerce-account .woocommerce-MyAccount-navigation li.is-active a{
    text-decoration: none;
    border-color: rgba(100, 100, 100, 0.6);
}
.woocommerce-account .woocommerce-MyAccount-navigation li a:hover{
    text-decoration: none;
}
.woocommerce-account .woocommerce-MyAccount-content,
.woocommerce-account .woocommerce-MyAccount-navigation{
    float: none;
    padding: 1rem;
}
.woocommerce-account .woocommerce{
    display: flex;
    flex-wrap: wrap;
}
.woocommerce-account .woocommerce-MyAccount-navigation > ul{
    position: sticky;
    top: 2rem;
    border: 1px solid var(--wp--preset--color--secondary);
    padding: 1rem;
    border-radius: 4px;
}

.woocommerce-account .woocommerce-MyAccount-navigation{
}

.veno-purchase-card{
    border: 1px solid var(--wp--preset--color--secondary);
    border-radius: 4px;
    box-shadow: none;
}

.taxonomy-product_tag a{
    display: inline-block;
    background-color: var(--wp--preset--color--primary);
    color: #fff;
    font-size: 80%;
    font-weight: 300;
    margin-right: 4px;
    margin-bottom: 4px;
    border-radius: 4px;
    padding: 0.3em 0.6em;
    line-height: 1;
}


.taxonomy-product_tag .wp-block-post-terms__separator{
    display: none;
}





.vbox-backdrop{
    backdrop-filter: blur(8px);
}



