/* === Header principale unificato (template PHP child) === */

/* Logo */
#header .logo img {
    height: 60px !important;
    width: auto;
}

/* Barra di ricerca header */
.header-search-wrapper {
    flex: 1;
    display: flex;
    align-items: center;
    height: 100%;
}

.header-search-form {
    position: relative;
    display: flex;
    align-items: center;
    width: 100%;
}

.header-search-input {
    flex: 1;
    padding: 10px 45px 10px 15px;
    border: 1px solid #ddd;
    border-radius: 4px;
    font-size: 14px;
    outline: none;
    transition: border-color 0.3s ease;
}

.header-search-input:focus {
    border-color: #E74338;
}

.header-search-submit {
    position: absolute;
    right: 5px;
    top: 50%;
    transform: translateY(-50%);
    background: transparent;
    border: none;
    padding: 8px 12px;
    cursor: pointer;
    color: #666;
    transition: color 0.3s ease;
    display: flex;
    align-items: center;
    justify-content: center;
}

.header-search-submit:hover {
    color: #E74338;
}

.header-search-submit i {
    font-size: 16px;
}

/* Dropdown risultati ricerca */
.header-search-wrapper {
    position: relative;
}

/* Disponibilità variazione prodotto: più spazio sopra/sotto il testo */
.woocommerce-variation-availability p.stock,
.woocommerce-variation-availability .stock {
    margin: 20px 0;
}

.header-search-dropdown {
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background: #fff;
    border: 1px solid #ddd;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
    max-height: 70vh;
    overflow-y: auto;
    z-index: 9999;
    display: none;
    margin-top: 10px;
    min-width: 450px;
}

/* Mini-cart e icona carrello sempre visibili (struttura: #mini-cart .cart-head .cart-icon i.minicart-icon) */
#mini-cart,
#mini-cart.mini-cart,
.mini-cart .cart-head,
.mini-cart .cart-icon {
    display: inline-flex !important;
    visibility: visible !important;
    opacity: 1 !important;
    align-items: center !important;
}
.mini-cart .minicart-icon,
.mini-cart .porto-icon-cart-thick,
.mini-cart i.minicart-icon {
    display: inline-block !important;
    visibility: visible !important;
    opacity: 1 !important;
    width: 28px !important;
    height: 22px !important;
    font-size: 22px !important;
    vertical-align: middle !important;
    font-family: "porto" !important; /* icon font: glyph da Porto-Font */
}

/* Icona “default” (minicart-icon-default): disegnata a bordi, non font (quando tema usa icona semplice) */
#mini-cart .minicart-icon-default,
.mini-cart .minicart-icon-default {
    display: inline-block !important;
    visibility: visible !important;
    opacity: 1 !important;
    width: 28px !important;
    height: 22px !important;
    border: 2px solid currentColor !important;
    border-radius: 0 0 6px 6px !important;
    position: relative !important;
    margin: 2px 2px 0 !important;
    vertical-align: middle !important;
    font-family: inherit !important;
}
#mini-cart .minicart-icon-default:before,
.mini-cart .minicart-icon-default:before {
    content: "" !important;
    position: absolute !important;
    width: 14px !important;
    height: 12px !important;
    border: 2px solid currentColor !important;
    border-bottom: none !important;
    border-radius: 5px 5px 0 0 !important;
    left: 4px !important;
    top: -10px !important;
    margin: 0 !important;
}
/* Porto su desktop nasconde l’icona per minicart-inline: ripristinare visibilità */
@media (min-width: 992px) {
    #mini-cart.minicart-inline .minicart-icon,
    #mini-cart.minicart-inline .porto-icon-cart-thick,
    #mini-cart.minicart-inline .cart-icon {
        display: inline-block !important;
    }
}
.mini-cart .cart-items {
    display: inline-block !important;
    visibility: visible !important;
}

/* Mini-cart dropdown: mostrare "Visualizza carrello" sopra "Pagamento" (Porto nasconde il primo bottone) */
#mini-cart:not(.minicart-offcanvas) .woocommerce-mini-cart__buttons.buttons > a:first-child,
#mini-cart .widget_shopping_cart_content .buttons > a.wc-forward:first-of-type {
    display: inline-block !important;
}

/* Mini-cart: bottoni in colonna e stile unificato */
#mini-cart .woocommerce-mini-cart__buttons.buttons,
#mini-cart .widget_shopping_cart_content .buttons {
    display: flex !important;
    flex-direction: column !important;
    gap: 10px;
}
#mini-cart .buttons a,
#mini-cart .woocommerce-mini-cart__buttons.buttons a,
#mini-cart .widget_shopping_cart_content .buttons a {
    font: 600 0.75rem / 1.5 var(--porto-add-to-cart-ff, var(--porto-body-ff)), sans-serif;
    letter-spacing: 0.025em;
    text-transform: uppercase;
    padding: 0.875rem 1.5rem;
    border-radius: 2px;
    float: none;
    width: 100% !important;
    margin-bottom: 0;
    text-align: center;
    transition: color 0.2s ease-in-out, background-color 0.2s ease-in-out, border-color 0.2s ease-in-out;
}

/* Dropdown: Visualizza carrello = secondario, Pagamento = primario (rosso) */
#mini-cart:not(.minicart-offcanvas) .buttons a:first-child {
    background: #fff;
    color: #333;
    border: 1px solid #ddd;
}
#mini-cart:not(.minicart-offcanvas) .buttons a:first-child:hover {
    background: #f5f5f5;
    border-color: #ccc;
}
#mini-cart:not(.minicart-offcanvas) .buttons a.checkout {
    background: #E74338;
    color: #fff;
    border: 1px solid #E74338;
}
#mini-cart:not(.minicart-offcanvas) .buttons a.checkout:hover {
    background: #d63a30;
    color: #fff;
    border-color: #d63a30;
}

#mini-cart.minicart-offcanvas .buttons a,
.minicart-offcanvas .widget_shopping_cart .buttons a {
    background: #e7e7e7;
    color: #222529;
}
#mini-cart.minicart-offcanvas .buttons a:focus,
#mini-cart.minicart-offcanvas .buttons a:hover,
.minicart-offcanvas .widget_shopping_cart .buttons a:focus,
.minicart-offcanvas .widget_shopping_cart .buttons a:hover {
    background: #f1f1f1;
    color: #222529;
}

.header-search-dropdown.show {
    display: block;
}

/* Lista risultati compatta - layout orizzontale */
.header-search-dropdown .search-results-list {
    list-style: none;
    margin: 0;
    padding: 0;
    width: 100%;
}

.header-search-dropdown .search-result-item {
    border-bottom: 1px solid #f0f0f0;
    width: 100%;
}

.header-search-dropdown .search-result-item:last-child {
    border-bottom: none;
}

.header-search-dropdown .search-result-link {
    display: flex;
    align-items: center;
    padding: 12px 15px;
    width: 100%;
    text-decoration: none;
    color: inherit;
    transition: background-color 0.2s ease;
}

.header-search-dropdown .search-result-link:hover {
    background-color: #f8f8f8;
}

/* Immagine piccola a sinistra */
.header-search-dropdown .search-result-image {
    flex-shrink: 0;
    width: 60px;
    height: 60px;
    margin-right: 12px;
    border-radius: 4px;
    overflow: hidden;
    background-color: #f5f5f5;
}

.header-search-dropdown .search-result-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.header-search-dropdown .search-result-placeholder {
    width: 100%;
    height: 100%;
    background-color: #e0e0e0;
}

/* Contenuto a destra */
.header-search-dropdown .search-result-content {
    flex: 1;
    min-width: 0; /* Permette al testo di troncare */
}

.header-search-dropdown .search-result-category {
    color: #888;
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-bottom: 4px;
    display: block;
    line-height: 1.2;
}

.header-search-dropdown .search-result-title {
    font-size: 14px;
    font-weight: 600;
    margin: 0 0 6px 0;
    color: #333;
    line-height: 1.3;
    display: -webkit-box;
    -webkit-line-clamp: 1;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.header-search-dropdown .search-result-info {
    display: flex;
    align-items: center;
    flex-wrap: nowrap;
    gap: 10px;
    font-size: 12px;
    color: #666;
    white-space: nowrap;
    overflow: hidden;
}

.header-search-dropdown .search-result-attr {
    flex-shrink: 0;
    white-space: nowrap;
}

.header-search-dropdown .search-result-attr {
    display: inline-flex;
    align-items: center;
    gap: 4px;
}

.header-search-dropdown .search-result-attr i {
    font-size: 11px;
    color: #E74338;
}

.header-search-dropdown .search-result-separator {
    color: #999;
    font-size: 12px;
    font-weight: 400;
    margin: 0 4px;
    flex-shrink: 0;
}

.header-search-dropdown .search-result-price {
    margin-left: auto;
    font-weight: 600;
    color: #E74338;
    font-size: 12px;
    white-space: nowrap;
    flex-shrink: 0;
}


.header-search-dropdown .search-result-price .price {
    font-size: 12px;
}

.header-search-dropdown .search-result-price .cost-prefix {
    font-size: 10px;
    display: inline;
}

.header-search-dropdown .search-result-price .cost-value {
    font-size: 14px;
    display: inline;
}

.header-search-dropdown .search-result-price .cost-suffix {
    font-size: 10px;
    display: inline;
}

/* Prezzo scontato (cost-value) nella searchbar header: rosso */
.header-search-dropdown .search-result-price .cost-value .woocommerce-Price-amount {
    color: #E74338 !important;
}

/* Prezzo pieno barrato nella searchbar header */
.header-search-dropdown .price .cost-regular {
    font-size: 12px;
    font-weight: 400;
    color: rgba(231, 67, 56, 0.6);
    text-decoration: line-through;
    white-space: nowrap;
}

/* Loading e messaggi */
.search-loading,
.search-no-results,
.search-error {
    padding: 20px;
    text-align: center;
    color: #666;
    font-size: 14px;
}

.search-error {
    color: #E74338;
}

/* Responsive barra di ricerca */
@media (max-width: 991px) {
    .header-search-wrapper {
        margin-left: 15px;
    }
    
    .header-search-input {
        padding: 8px 40px 8px 12px;
        font-size: 13px;
    }
    
    .header-search-dropdown .search-result-link {
        padding: 10px 12px;
    }
    
    .header-search-dropdown .search-result-image {
        width: 50px;
        height: 50px;
        margin-right: 10px;
    }
    
    .header-search-dropdown {
        max-height: 60vh;
    }
}

@media (max-width: 767px) {
    .header-search-wrapper {
        margin-left: 10px;
    }
    
    .header-search-input {
        padding: 6px 35px 6px 10px;
        font-size: 12px;
    }
    
    .header-search-submit {
        padding: 6px 10px;
    }
    
    .header-search-submit i {
        font-size: 14px;
    }
    
    .header-search-dropdown .search-result-link {
        padding: 8px 10px;
    }
    
    .header-search-dropdown .search-result-image {
        width: 45px;
        height: 45px;
        margin-right: 8px;
    }
    
    .header-search-dropdown .search-result-title {
        font-size: 13px;
    }
    
    .header-search-dropdown .search-result-info {
        font-size: 11px;
        gap: 8px;
    }
    
    .header-search-dropdown .search-result-price {
        font-size: 12px;
    }
    
    .header-search-dropdown {
        max-height: 50vh;
    }
}

@media (max-width: 575px) {
    .header-search-wrapper {
        display: none; /* Nascondi su mobile molto piccolo */
    }
}

/* Contenitore principale header: una sola riga (logo | menu | icone) */
#header.header-builder-p .header-main.header-body {
    padding: 10px 0 0 0;
}

/* FORZA LAYOUT 3 COLONNE: left (sinistra) | center (centro) | right (destra) */
#header.header-builder-p .header-container.header-unified-row,
.header-container.header-unified-row,
#header .header-container.header-unified-row {
    display: grid !important;
    grid-template-columns: 1fr auto 1fr !important;
    align-items: center !important;
    gap: 30px !important;
    width: 100% !important;
    padding: 20px 0 !important;
}

#header.header-builder-p .header-container.header-unified-row > div,
.header-container.header-unified-row > div,
#header .header-container.header-unified-row > div {
    display: flex !important;
    align-items: center !important;
}

/* Left - allineata a sinistra */
#header.header-builder-p .header-left,
.header-container.header-unified-row .header-left,
#header .header-left {
    justify-content: flex-start !important;
    justify-self: start !important;
    order: 1 !important;
    width: 80% !important;
    gap: 24px !important;
}



/* Center - larghezza necessaria, centrato */
#header.header-builder-p .header-center,
.header-container.header-unified-row .header-center,
#header .header-center {
    justify-content: center !important;
    justify-self: center !important;
    text-align: center !important;
    order: 2 !important;
    width: auto !important;
}

/* Right - allineata a destra */
#header.header-builder-p .header-right,
.header-container.header-unified-row .header-right,
#header .header-right {
    justify-content: flex-end !important;
    justify-self: end !important;
    display: flex !important;
    align-items: center !important;
    order: 3 !important;
}

/* Custom mega menu wrapper */
.header-main-menu-wrapper {
    width: 100%;
    text-align: center;
}

#header.header-builder-p .header-right .header-main-icons,
.header-main-icons {
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    justify-content: flex-end !important;
    flex-wrap: nowrap !important;
    width: auto !important;
}

#header.header-builder-p .header-right .header-main-icons > *,
.header-main-icons > * {
    display: inline-flex !important;
    flex-shrink: 0 !important;
    white-space: nowrap !important;
    width: auto !important;
    max-width: none !important;
}

.gt_float_switcher .gt-selected .gt-current-lang {
    padding: 10px 0px 10px 15px !important;
}

.header-gtranslate .gt_float_switcher .gt_options,
.header-main-icons .header-gtranslate .gt_options,
#header .header-gtranslate .gt_options,
.gt_float_switcher .gt_options {
    box-shadow: none !important;
    top: auto !important;
    right: auto !important;
    position: absolute !important;
}

/* Nascondi il widget GTranslate flottante di default */
#gt_float_wrapper {
    display: none !important;
}

/* GTranslate widget nel header */
.header-gtranslate {
    display: inline-flex !important;
    align-items: center !important;
    margin-right: 10px !important;
}

.header-gtranslate .gt_float_switcher,
.gt_float_switcher {
    position: static !important;
    opacity: 1 !important;
    box-shadow: none !important;
}

.header-gtranslate #gt_float_wrapper {
    position: static !important;
    display: inline-flex !important;
    align-items: center !important;
}

.header-gtranslate .gt-selected {
    display: flex !important;
    align-items: center !important;
}

.header-gtranslate .gt-current-lang {
    display: flex !important;
    align-items: center !important;
    gap: 5px !important;
    cursor: pointer !important;
}

.header-gtranslate .gt-current-lang img {
    width: 24px !important;
    height: auto !important;
}

.header-gtranslate .gt_options {
    position: absolute !important;
    top: 100% !important;
    right: 0 !important;
    background: #fff !important;
    box-shadow: 0 4px 12px rgba(0,0,0,0.15) !important;
    border-radius: 4px !important;
    padding: 10px 0 !important;
    z-index: 9999 !important;
}

.header-gtranslate .gt_options a {
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
    padding: 8px 15px !important;
    color: #333 !important;
    text-decoration: none !important;
}

.header-gtranslate .gt_options a:hover {
    background: #f5f5f5 !important;
}

.header-gtranslate .gt_options img {
    width: 20px !important;
    height: auto !important;
}

/* Mobile: nascondi GTranslate in header, mostra nel pannello menu in basso a sinistra */
@media (max-width: 991px) {
    .header-right .header-gtranslate {
        display: none !important;
    }

    .custom-mobile-menu-panel {
        display: flex;
        flex-direction: column;
    }

    .custom-mobile-menu-content {
        flex: 1 1 auto;
        padding-bottom: 20px;
    }

    .custom-mobile-gtranslate {
        padding: 10px 20px 20px;
        align-self: flex-start;
    }

    .custom-mobile-gtranslate .gt_options {
        left: 0 !important;
        right: auto !important;
    }
}

/* Forza mini-cart inline */
#header.header-builder-p .header-right .header-main-icons .mini-cart,
.header-main-icons .mini-cart {
    display: inline-flex !important;
    flex-shrink: 0 !important;
    width: auto !important;
    max-width: none !important;
    vertical-align: middle !important;
    position: relative !important;
}

/* Cart head deve essere inline */
#header.header-builder-p .header-right .header-main-icons .mini-cart .cart-head,
.header-main-icons .mini-cart .cart-head {
    display: inline-flex !important;
    align-items: center !important;
    width: auto !important;
}

/* Forza mobile-toggle inline */
#header.header-builder-p .header-right .header-main-icons .mobile-toggle,
.header-main-icons .mobile-toggle {
    display: inline-flex !important;
    flex-shrink: 0 !important;
    width: auto !important;
    vertical-align: middle !important;
}

/* Nascondi toggle mobile su desktop */
@media (min-width: 992px) {
    .header-main-icons .mobile-toggle {
        display: none !important;
    }
}

/* Mostra toggle mobile solo su mobile (ma nascondilo su iPad verticale e più piccoli perché abbiamo il nostro hamburger custom) */
@media (max-width: 991px) {
    .header-main-icons .mobile-toggle {
        display: inline-flex !important;
    }
}

/* Nascondi toggle mobile di Porto da 991px in giù (usiamo il nostro hamburger custom) */
@media (max-width: 991px) {
    .header-main-icons .mobile-toggle {
        display: none !important;
    }
}

/* Mega menu CATEGORIE: rimuovi bordo top blu e freccetta nel dropdown (header PHP) */
#header.header-builder-p .mega-menu.menu-hover-line > li.menu-item > a:before,
#header.header-builder-p .mega-menu.menu-hover-underline > li.menu-item > a:before {
    display: none !important;
    opacity: 0 !important;
    content: none !important;
}

#header.header-builder-p .mega-menu .wide .popup {
    border-top: 0 !important;
}

#header.header-builder-p .mega-menu .wide .popup::before,
#header.header-builder-p .mega-menu .wide .popup::after {
    display: none !important;
    content: none !important;
    border: 0 !important;
    border-width: 0 !important;
}

/* Header fixed in alto */
#header,
#header.header-builder-p,
header#header,
header#header.header-builder-p,
.header-wrapper #header {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    width: 100% !important;
    z-index: 9999 !important;
    background-color: #ffffff !important;
}

/* Header wrapper non deve interferire */
.header-wrapper {
    position: static !important;
}

    #main {
        padding-top: 160px !important;
    }

    @media (max-width: 767px) {
        #main {
            padding-top: 100px !important;
        }
    }

#header.header-builder-p .header-wrapper,
#header.header-builder-p .header-main.header-body {
    z-index: inherit;
}

/* Mega menu sotto l'header: z-index più basso del header stesso */
#header.header-builder-p .mega-menu .popup {
    z-index: 10 !important;
}

/* Stile voci menu header: testo nero, hover nero con sottolineatura rossa */
.header-main-menu-wrapper .main-menu.mega-menu > li.menu-item > a {
    position: relative;
    color: #111111 !important;
    text-decoration: none !important;
}

.header-main-menu-wrapper .main-menu.mega-menu > li.menu-item > a::after {
    content: "";
    position: absolute;
    left: 0;
    bottom: -5px;
    width: 0;
    height: 2px;
    background-color: #e74338;
    transition: width 0.25s ease;
}

.header-main-menu-wrapper .main-menu.mega-menu > li.menu-item:hover > a,
.header-main-menu-wrapper .main-menu.mega-menu > li.menu-item.active > a {
    color: #111111 !important;
}

.header-main-menu-wrapper .main-menu.mega-menu > li.menu-item:hover > a::after,
.header-main-menu-wrapper .main-menu.mega-menu > li.menu-item.active > a::after {
    width: 100%;
}

/* Allineamento social header come footer */
.elementor-element[data-id="121f7d3"] .share-links,
.elementor-element[data-id="90c83c4"] .share-links {
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    justify-content: flex-end !important;
    gap: 10px !important;
    flex-wrap: wrap !important;
}

.elementor-element[data-id="121f7d3"] .share-links a,
.elementor-element[data-id="90c83c4"] .share-links a {
    margin: 0 !important;
    width: 32px !important;
    height: 32px !important;
    min-width: 32px !important;
    min-height: 32px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    text-indent: -9999px !important;
    overflow: hidden !important;
    position: relative !important;
}

.elementor-element[data-id="121f7d3"] .share-links a::before,
.elementor-element[data-id="90c83c4"] .share-links a::before {
    text-indent: 0 !important;
    font-size: 14px !important;
    position: absolute !important;
    z-index: 2 !important;
    color: inherit !important;
    transition: color 0.3s ease !important;
}

/* Su desktop: rosso in hover con sfondo bianco */
@media (min-width: 769px) {
    .elementor-element[data-id="121f7d3"] .share-links a:hover::before,
    .elementor-element[data-id="90c83c4"] .share-links a:hover::before,
    .elementor-element[data-id="121f7d3"] .share-links a:hover,
    .elementor-element[data-id="90c83c4"] .share-links a:hover {
        color: #E74338 !important;
        background-color: #fff !important;
        background: #fff !important;
        transition: color 0.3s ease !important;
    }
}

/* Su mobile: centra i social e colora direttamente in rosso */
@media (max-width: 991px) {
    .elementor-element[data-id="121f7d3"] .share-links,
    .elementor-element[data-id="90c83c4"] .share-links {
        justify-content: center !important;
        gap: 15px !important;
    }
    
    .elementor-element[data-id="121f7d3"] .share-links a,
    .elementor-element[data-id="90c83c4"] .share-links a {
        width: 36px !important;
        height: 36px !important;
    }
    
    /* Colore rosso direttamente su mobile */
    .elementor-element[data-id="121f7d3"] .share-links a::before,
    .elementor-element[data-id="90c83c4"] .share-links a::before,
    .elementor-element[data-id="121f7d3"] .share-links a,
    .elementor-element[data-id="90c83c4"] .share-links a {
        color: #E74338 !important;
    }
}

    .elementor-12 .elementor-element.elementor-element-121f7d3 {
    width: 130px !important;
    padding-right: 10px !important;
    }

/* Padding left per container telefoni header */
.elementor-element[data-id="0c62937"] {
    padding-left: 10px !important;
}

.elementor-12 .elementor-element.elementor-element-0c62937 {
    width: 300px !important;
}

/* Allineamento menu al centro */
.elementor-element[data-id="fc8618e"] .elementor-widget-container {
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    width: 100% !important;
    text-align: center !important;
}

.elementor-element[data-id="fc8618e"] #menu-main-menu {
    display: inline-flex !important;
    justify-content: center !important;
    align-items: center !important;
    margin: 0 auto !important;
    text-align: center !important;
    flex-wrap: wrap !important;
}

.elementor-element[data-id="fc8618e"] #menu-main-menu > li {
    display: inline-block !important;
    vertical-align: middle !important;
    float: none !important;
}

/* Centra il contenuto del container flex Elementor */
.e-con.e-flex > .e-con-inner {
    justify-content: center !important;
}

/* === Mega menu "CATEGORIE": rimuovi dettagli blu + migliora spaziatura colonne === */
/* Rimuove linea/underline blu del tipo menu-hover-line / menu-hover-underline */
.elementor-element[data-id="fc8618e"] .mega-menu.menu-hover-line > li.menu-item > a:before,
.elementor-element[data-id="fc8618e"] .mega-menu.menu-hover-underline > li.menu-item > a:before {
    display: none !important;
    opacity: 0 !important;
    content: none !important;
}

/* Rimuove bordo blu superiore del popup wide e l’eventuale triangolino */
.elementor-element[data-id="fc8618e"] .mega-menu .wide .popup {
    border-top: 0 !important;
}
.elementor-element[data-id="fc8618e"] .mega-menu .wide .popup::before,
.elementor-element[data-id="fc8618e"] .mega-menu .wide .popup::after {
    display: none !important;
    content: none !important;
    border: 0 !important;
    border-width: 0 !important;
}

/* Spaziatura e layout colonne del mega menu (evita testi “attaccati”) */
.elementor-element[data-id="fc8618e"] .mega-menu .wide .popup > .inner {
    padding: 18px 22px !important;
}

.elementor-element[data-id="fc8618e"] .porto-wide-sub-menu {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 16px 42px !important;
    align-items: flex-start !important;
}

.elementor-element[data-id="fc8618e"] .porto-wide-sub-menu > li.sub {
    padding: 0 !important;
    flex: 0 0 170px !important; /* larghezza fissa della colonna */
    min-width: 170px !important;
}

.elementor-element[data-id="fc8618e"] .porto-wide-sub-menu > li.sub > a {
    margin-bottom: 8px !important;
    padding-bottom: 6px !important;
}

.elementor-element[data-id="fc8618e"] .porto-wide-sub-menu > li.sub > ul.sub-menu > li > a {
    white-space: nowrap !important;
}

/* === Wishlist & Account: icona che “si apre” mostrando il testo in hover (desktop) === */
@media (min-width: 769px) {
    /* Contenitore base icone wishlist / account */
    .my-wishlist,
    .my-account {
        position: relative !important;
        display: inline-flex !important;
        align-items: center !important;
        justify-content: center !important;
        padding: 8px 10px !important;
        gap: 0 !important;
        white-space: nowrap !important;
        transition: all 0.3s ease !important;
    }

    /* Nasconde eventuale testo diretto dentro il link (mostriamo solo l’icona) */
    .my-wishlist span,
    .my-account span {
        display: none !important;
    }

    /* Testo wishlist che compare in hover */
    .my-wishlist::after {
        content: "Lista dei desideri" !important;
        display: inline-block !important;
        max-width: 0 !important;
        overflow: hidden !important;
        opacity: 0 !important;
        white-space: nowrap !important;
        margin-left: 0 !important;
        font-size: 0.9em !important;
        font-weight: 500 !important;
        transition: max-width 0.3s ease, opacity 0.3s ease, margin-left 0.3s ease !important;
    }

    .my-wishlist:hover::after {
        max-width: 200px !important;
        opacity: 1 !important;
        margin-left: 8px !important;
    }

    /* Testo account che compare in hover */
    .my-account::after {
        content: "Il mio account" !important;
        display: inline-block !important;
        max-width: 0 !important;
        overflow: hidden !important;
        opacity: 0 !important;
        white-space: nowrap !important;
        margin-left: 0 !important;
        font-size: 0.9em !important;
        font-weight: 500 !important;
        transition: max-width 0.3s ease, opacity 0.3s ease, margin-left 0.3s ease !important;
    }

    .my-account:hover::after {
        max-width: 200px !important;
        opacity: 1 !important;
        margin-left: 8px !important;
    }
}

#header .header-container.container,
#header .header-container .container,
.header-container.container,
.header-container.header-unified-row .container {
    max-width: 100vw !important;
    padding: 20px !important;
}

/* === Top Bar Elementor (Social, Marquee, Contatti) === */
.elementor-element-7195705,
.elementor-element[data-id="7195705"],
#header .elementor-element-7195705 {
    background-color: #2c2c2c !important;
    padding: 12px 0 !important;
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
}

.elementor-element-7195705 .e-con-inner,
.elementor-element[data-id="7195705"] .e-con-inner {
    display: grid !important;
    grid-template-columns: auto 1fr auto !important;
    align-items: center !important;
    gap: 40px !important;
    max-width: 100% !important;
    visibility: visible !important;
    padding: 0 20px !important;
}

/* Prima colonna: Social */
.elementor-element-7195705 .e-con-inner > .elementor-element-121f7d3,
.elementor-element[data-id="7195705"] .e-con-inner > .elementor-element-121f7d3 {
    display: flex !important;
    justify-content: flex-start !important;
    align-items: center !important;
    visibility: visible !important;
    opacity: 1 !important;
    order: 1 !important;
}

/* Seconda colonna: Marquee testo */
.elementor-element-7195705 .e-con-inner > .elementor-element-0139e4e,
.elementor-element[data-id="7195705"] .e-con-inner > .elementor-element-0139e4e {
    display: block !important;
    justify-content: center !important;
    align-items: center !important;
    visibility: visible !important;
    opacity: 1 !important;
    order: 2 !important;
    overflow: hidden !important;
    width: 100% !important;
}

ul.products li {
    margin-bottom: unset !important;
}

/* Terza colonna: Telefoni */
.elementor-element-7195705 .e-con-inner > .elementor-element-0c62937,
.elementor-element[data-id="7195705"] .e-con-inner > .elementor-element-0c62937 {
    display: flex !important;
    flex-direction: row !important;
    justify-content: flex-end !important;
    align-items: center !important;
    gap: 20px !important;
    visibility: visible !important;
    opacity: 1 !important;
    order: 3 !important;
}

/* Assicura che i telefoni siano affiancati */
.elementor-element-7195705 .elementor-element-0c62937 > .elementor-widget,
.elementor-element[data-id="7195705"] .elementor-element-0c62937 > .elementor-widget {
    display: flex !important;
    flex-shrink: 0 !important;
}

.elementor-element-7195705 .e-con-inner > *,
.elementor-element[data-id="7195705"] .e-con-inner > * {
    visibility: visible !important;
    opacity: 1 !important;
}

/* Escludi container marquee dalla regola flex generale */
.elementor-element-7195705 .e-con-inner > *:not(.elementor-element-0139e4e),
.elementor-element[data-id="7195705"] .e-con-inner > *:not(.elementor-element-0139e4e) {
    display: flex !important;
    align-items: center !important;
}

/* Social Icons - Sfondo bianco */
.elementor-element-7195705 .share-links,
.elementor-element[data-id="7195705"] .share-links {
    display: flex !important;
    align-items: center !important;
    visibility: visible !important;
}

.elementor-element-7195705 .share-links a,
.elementor-element[data-id="7195705"] .share-links a {
    background-color: #ffffff !important;
    color: #2c2c2c !important;
    width: 36px !important;
    height: 36px !important;
    border-radius: 50% !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    margin-right: 10px !important;
    transition: all 0.3s ease !important;
    visibility: visible !important;
    opacity: 1 !important;
}

.elementor-element-7195705 .share-links a:hover {
    transform: scale(1.1) !important;
    opacity: 0.9 !important;
}

/* Marquee Text - Bianco */
.elementor-element-7195705 .porto-u-heading,
.elementor-element-7195705 .marquee,
.elementor-element[data-id="7195705"] .porto-u-heading,
.elementor-element[data-id="7195705"] .marquee {
    color: #ffffff !important;
    font-size: 14px !important;
    text-transform: uppercase !important;
    letter-spacing: 0.5px !important;
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
    white-space: nowrap !important;
    overflow: hidden !important;
}

/* Container marquee - deve avere overflow hidden */
.elementor-element-7195705 .porto-u-main-heading,
.elementor-element[data-id="7195705"] .porto-u-main-heading {
    overflow: hidden !important;
    width: 100% !important;
    position: relative !important;
}

/* Wrapper marquee - container per animazione JS */
.elementor-element-7195705 .js-marquee-wrapper,
.elementor-element[data-id="7195705"] .js-marquee-wrapper {
    display: block !important;
    visibility: visible !important;
    overflow: hidden !important;
    width: 100% !important;
    position: relative !important;
}

/* Nascondi elementi duplicati del marquee finché JS non è caricato */
.elementor-element-7195705 .js-marquee-wrapper:not(.marquee-js-ready) .js-marquee:not(:first-child),
.elementor-element[data-id="7195705"] .js-marquee-wrapper:not(.marquee-js-ready) .js-marquee:not(:first-child) {
    display: none !important;
}

/* Quando JS è pronto, nascondi tutti gli elementi originali */
.elementor-element-7195705 .js-marquee-wrapper.marquee-js-ready .js-marquee,
.elementor-element[data-id="7195705"] .js-marquee-wrapper.marquee-js-ready .js-marquee {
    display: none !important;
}

/* Container animazione marquee */
.elementor-element-7195705 .marquee-animation-container,
.elementor-element[data-id="7195705"] .marquee-animation-container {
    display: flex !important;
    white-space: nowrap !important;
    will-change: transform !important;
}

/* Item marquee - ogni copia del testo */
.elementor-element-7195705 .marquee-item,
.elementor-element[data-id="7195705"] .marquee-item {
    color: #ffffff !important;
    font-size: 14px !important;
    text-transform: uppercase !important;
    letter-spacing: 0.5px !important;
    display: inline-block !important;
    white-space: nowrap !important;
    padding-right: 50px !important; /* Spazio tra le copie */
    flex-shrink: 0 !important;
}

/* Phone Numbers - Bianco */
.elementor-element-7195705 .porto-sicon-box,
.elementor-element[data-id="7195705"] .porto-sicon-box {
    color: #ffffff !important;
    display: flex !important;
    visibility: visible !important;
    opacity: 1 !important;
}

.elementor-element-7195705 .porto-sicon-box p,
.elementor-element-7195705 .porto-sicon-header p,
.elementor-element[data-id="7195705"] .porto-sicon-box p,
.elementor-element[data-id="7195705"] .porto-sicon-header p {
    color: #ffffff !important;
    font-size: 14px !important;
    margin: 0 !important;
    visibility: visible !important;
    opacity: 1 !important;
}

.elementor-element-7195705 .porto-icon,
.elementor-element-7195705 .porto-icon i,
.elementor-element-7195705 .Simple-Line-Icons-screen-smartphone,
.elementor-element-7195705 .porto-icon-phone-1,
.elementor-element[data-id="7195705"] .porto-icon,
.elementor-element[data-id="7195705"] .porto-icon i,
.elementor-element[data-id="7195705"] .Simple-Line-Icons-screen-smartphone,
.elementor-element[data-id="7195705"] .porto-icon-phone-1 {
    color: #ffffff !important;
    font-size: 18px !important;
    visibility: visible !important;
    opacity: 1 !important;
}

.elementor-element-7195705 .porto-sicon-box-link,
.elementor-element[data-id="7195705"] .porto-sicon-box-link {
    text-decoration: none !important;
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
    visibility: visible !important;
    opacity: 1 !important;
}

/* Assicura visibilità di tutti gli elementi */
.elementor-element-7195705 .elementor-widget,
.elementor-element[data-id="7195705"] .elementor-widget,
/* Widget container generale - flex per allineamento */
.elementor-element-7195705 .elementor-widget-container,
.elementor-element[data-id="7195705"] .elementor-widget-container {
    display: flex !important;
    align-items: center !important;
    visibility: visible !important;
    opacity: 1 !important;
}

/* Widget container marquee - deve essere block per permettere animazione */
.elementor-element-7195705 .elementor-element-9505852 .elementor-widget-container,
.elementor-element[data-id="7195705"] .elementor-element-9505852 .elementor-widget-container {
    display: block !important;
    align-items: unset !important;
}

/* Layout responsive */
@media (max-width: 991px) {
    .elementor-element-7195705 .e-con-inner {
        flex-wrap: wrap !important;
        gap: 15px !important;
    }
    
    .elementor-element-7195705 .elementor-hidden-mobile {
        display: none !important;
    }
}


/* Nascondi barra informativa (top bar) da 991px in giù */
@media (max-width: 991px) {
    .elementor-element-7195705,
    .elementor-element[data-id="7195705"],
    #header .elementor-element-7195705 {
        display: none !important;
        visibility: hidden !important;
        opacity: 0 !important;
    }
}

/* Nascondi toolbar WordPress nella pagina risultati ricerca */
body.search #wpadminbar {
    display: none !important;
}

.header-search-form{
    margin-bottom: 0 !important;
}

/* =============================================
   CUSTOM MOBILE MENU - Hamburger
   ============================================= */

/* Hamburger button - nascosto su desktop */
.custom-mobile-menu-toggle {
    display: none;
    background: transparent;
    border: none;
    cursor: pointer;
    padding: 8px;
    flex-direction: column;
    justify-content: space-around;
    width: 40px !important;
    height: 40px;
    z-index: 2;
    position: relative;
    margin-left: 10px;
    align-items: center;
}

.custom-mobile-menu-toggle .hamburger-line {
    width: 100%;
    height: 3px;
    background-color: #111;
    border-radius: 2px;
    transition: all 0.3s ease;
    display: block;
}


.custom-mobile-menu-toggle.active .hamburger-line:nth-child(1) {
    transform: rotate(45deg) translate(8px, 8px);
}

.custom-mobile-menu-toggle.active .hamburger-line:nth-child(2) {
    opacity: 0;
}

.custom-mobile-menu-toggle.active .hamburger-line:nth-child(3) {
    transform: rotate(-45deg) translate(7px, -7px);
}

/* Mostra hamburger e nascondi menu desktop da 991px in giù */
@media (max-width: 991px) {
    .custom-mobile-menu-toggle {
        display: flex;
    }
    
    /* Nascondi menu desktop su mobile */
    .custom-desktop-menu {
        display: none !important;
    }
}

/* Nascondi hamburger e mostra menu desktop da 992px in su */
@media (min-width: 992px) {
    .custom-mobile-menu-toggle {
        display: none !important;
    }
    
    .custom-desktop-menu {
        display: block !important;
    }
}

/* =============================================
   CUSTOM MOBILE MENU - Panel Offcanvas
   ============================================= */

/* Overlay scuro */
.custom-mobile-menu-overlay {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: rgba(0, 0, 0, 0.5);
    z-index: 9998;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.3s ease, visibility 0.3s ease;
}

.custom-mobile-menu-overlay.active {
    opacity: 1;
    visibility: visible;
}

/* Panel menu mobile */
.custom-mobile-menu-panel {
    position: fixed;
    top: 0;
    right: -100%;
    max-width: 450px;
    height: 100vh;
    background-color: #fff;
    z-index: 9999;
    overflow-y: auto;
    transition: right 0.3s ease;
    box-shadow: -2px 0 10px rgba(0, 0, 0, 0.1);
}

.custom-mobile-menu-panel.active {
    right: 0;
}

/* Su telefono (< 448px) il panel occupa 100vw; su tablet (min-width 448px) resta 85% / max 400px */
@media (max-width: 447px) {
    .custom-mobile-menu-panel {
        width: 100vw;
        max-width: none;
    }
}

/* Header del panel con pulsante chiusura */
.custom-mobile-menu-header {
    display: flex;
    justify-content: flex-end;
    align-items: center;
    padding: 15px 20px;
    position: sticky;
    top: 0;
    background-color: #fff;
    z-index: 10;
}

.custom-mobile-menu-close {
    background: transparent;
    border: none;
    font-size: 32px;
    color: #111;
    cursor: pointer;
    padding: 0;
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: color 0.3s ease;
}

.custom-mobile-menu-close:hover {
    color: #E74338;
}

.custom-mobile-menu-close .close-icon {
    line-height: 1;
}

.close-icon{
    transform: unset !important;
}
/* Contenuto del menu mobile */
.custom-mobile-menu-content {
    padding: 0;
}

/* Search desktop in .header-left: occupa tutto lo spazio disponibile */
.header-left .custom-menu-search.custom-desktop-search {
    flex: 1 1 auto !important;
    min-width: 0;
}
.header-left .custom-menu-search.custom-desktop-search .header-search-form {
    width: 100% !important;
}
.header-left .custom-menu-search.custom-desktop-search .header-search-input {
    width: 100% !important;
    min-width: 0;
}

/* Mobile: searchbar fissa al centro in alto, sotto l'header */
@media (max-width: 991px) {
    .header-left .custom-menu-search.custom-desktop-search {
        position: fixed;
        left: 100px;
        transform: none;
        width: 50vw;
        max-width: 600px;
        z-index: 9999;
    }
}

/* Su schermi telefono più stretti: search un po' più compatta (40vw) */
@media (max-width: 575px) {
    .header-left .custom-menu-search.custom-desktop-search {
        width: 40vw;
    }
}

/* Nel panel mobile nascondi la search del mega menu (evita duplicato con custom-mobile-menu-search) */
.custom-mobile-menu-panel .custom-menu-search {
    display: none !important;
}

/* Search bar solo mobile (prima della lista menu) */
.custom-mobile-menu-search {
    padding: 15px 20px;
    position: relative;
}

/* Dropdown risultati ricerca AJAX nel menu mobile */
.custom-mobile-menu-search .header-search-dropdown {
    max-height: 50vh;
    overflow-y: auto;
    margin-top: 0;
    max-width: 100vw;
    min-width: 0;
}

.custom-mobile-menu-search .header-search-dropdown .search-results-list.products {
    max-width: 100vw;
}

/* Dropdown risultati della search desktop (affianco al logo) su mobile:
   fisso sotto l'header, a tutta larghezza */
@media (max-width: 600px) {
    .header-search-dropdown .search-result-item {
        max-width: 100vw;
        box-sizing: border-box;
    }

    .header-search-dropdown{
        margin-top: 0 !important;
        border: none !important;
        box-shadow: unset !important;
    }

    .header-left .custom-menu-search.custom-desktop-search .header-search-dropdown {
        position: fixed;
        top: 100px;
        left: 0;
        width: 100vw;
        max-width: 100vw;
        z-index: 9998;
    }
}

.custom-mobile-search-form {
    display: flex;
    align-items: center;
    gap: 0;
    background: #f5f5f5;
    border-radius: 8px;
    overflow: hidden;
    border: 1px solid #e0e0e0;
    margin-bottom: 0;
}

.custom-mobile-search-input {
    flex: 1;
    padding: 12px 14px;
    border: none;
    background: transparent;
    font-size: 15px;
    color: #222;
}

.custom-mobile-search-input::placeholder {
    color: #888;
}

.custom-mobile-search-input:focus {
    outline: none;
}

/* Stili menu mobile - usa gli stili esistenti del mega-menu.css */
.custom-mobile-menu-panel .custom-mega-menu {
    display: block;
    width: 100%;
}

.custom-mobile-menu-panel .custom-menu-list {
    flex-direction: column;
    gap: 0;
    width: 100%;
}

.custom-mobile-menu-panel .custom-menu-item {
    width: 100%;
    border-bottom: 1px solid #eee;
}

.custom-mobile-menu-panel .custom-menu-link {
    padding: 15px 20px;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

/* Su mobile: CATEGORIE + / CATEGORIE - (testo unico aggiornato da JS) */

.custom-mobile-menu-panel .custom-mega-dropdown {
    position: static;
    opacity: 1;
    visibility: visible;
    transform: none;
    box-shadow: none;
    padding: 0;
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.3s ease;
}

.custom-mobile-menu-panel .custom-menu-item-has-mega.mega-open .custom-mega-dropdown {
    max-height: 2000px;
}

.custom-mobile-menu-panel .custom-mega-columns {
    grid-template-columns: 1fr;
    gap: 20px;
    padding: 0 20px;
}

.custom-mobile-menu-panel .custom-mega-column {
    width: 100%;
}

.custom-mobile-menu-panel .custom-mega-category {
    margin-bottom: 20px;
}

/* Blocca scroll del body quando menu è aperto */
body.mobile-menu-open {
    overflow: hidden;
}