/**
 * WARNING: Do not change this file. Your changes will be lost.
 * 2025-11-25 16:33:30 */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,500;0,600;0,700;0,800;0,900;1,400;1,500;1,600;1,700;1,800;1,900&display=swap');body.boxed {
}
@media (min-width: 768px) {
    .page-layout-1column .product-info-main, .page-layout-2columns-left .product-info-main, .page-layout-2columns-right .product-info-main, .page-layout-3columns .product-info-main,.page-product-downloadable .product-options-bottom {
        width: 57.17%;
    }
    .page-layout-1column .product.media, .page-layout-2columns-left .product.media, .page-layout-2columns-right .product.media, .page-layout-3columns .product.media,.page-product-downloadable .product-options-wrapper {
        width: 40.83%;
    }

    .page-layout-1column .column.main > .custom-block ~ .product-info-main, .page-layout-2columns-left .column.main > .custom-block ~ .product-info-main, .page-layout-2columns-right .column.main > .custom-block ~ .product-info-main, .page-layout-3columns .column.main > .custom-block ~ .product-info-main {
        width: 42.8775%;
    }
    .page-layout-1column .column.main > .custom-block ~ .product.media, .page-layout-2columns-left .column.main > .custom-block ~ .product.media, .page-layout-2columns-right .column.main > .custom-block ~ .product.media, .page-layout-3columns .column.main > .custom-block ~ .product.media {
        width: 30.6225%;
    }
}

/* ==========================================================================
   MASTER CSS CUSTOM - NONSOLODIVISE (FINAL ARCHITECT EDITION)
   ========================================================================== */

/* --------------------------------------------------------------------------
   1. BASE STYLES & GLOBAL FIXES
   -------------------------------------------------------------------------- */
/* FIX CRITICO: Previene lo scroll orizzontale */
body, html {
    overflow-x: hidden !important;
    width: 100%;
}

.layout-fullwidth .container, 
.layout-fullwidth .block.category.event, 
.layout-fullwidth .footer.content, 
.layout-fullwidth .header.content, 
.layout-fullwidth .navigation, 
.layout-fullwidth .page-main, 
.layout-fullwidth .page-wrapper>.breadcrumbs >ul, 
.layout-fullwidth .page-wrapper>.page-bottom, 
.layout-fullwidth .page-wrapper>.widget, 
.layout-fullwidth .top-container {
    padding-left: 4.27vw; padding-right: 4.27vw;
}

@media (max-width: 575px){ html { font-size: 13.7143px; } body { font-size: 12px; line-height: 21px; } }

/* TYPOGRAPHY */
h1, h2, h3, h4, h5, h6 { color: #222529; letter-spacing: normal; }
h2 { font-family: Poppins,sans-serif; font-weight: 700; font-size: 30px; line-height: 40px; letter-spacing: -.3px; color: #302e2a; margin: 0 0 32px 0; }
h3 { font-family: Poppins,sans-serif; font-weight: 700; font-size: 25px; line-height: 32px; color: #222329; margin: 0 0 20px 0; }
h4 { font-family: Poppins,sans-serif; font-weight: 700; font-size: 20px; line-height: 27px; color: #222329; margin: 0 0 14px 0; }
h5 { font-family: Poppins,sans-serif; font-weight: 700; font-size: 14px; line-height: 20px; color: #222329; margin: 0 0 14px 0; }
h6 { font-family: Poppins,sans-serif; font-weight: 600; font-size: 13px; line-height: 18px; color: #222329; margin: 0 0 14px 0; }
p { letter-spacing: 0; }

/* COLORS & BUTTONS */
html .heading-secondary, html .lnk-secondary, html .text-color-secondary { color: #ff7272; }
html .action.primary, html .btn { font-family: Poppins; font-weight: 700; line-height: 1.42857; padding: .8em 2em; }
html .action.primary { color: #fff; background-color: #000; border-color: #000 #000 #000; }
html .btn-modern { text-transform: uppercase; font-size: .75rem; padding: .75rem 1.5rem; font-weight: 600; height: auto; }
.btn-modern.btn-xl { font-size: 1.125em; font-weight: 700; padding: 1.125em 2.75em; }
.btn-flat { padding: 0!important; background: none!important; border: none!important; border-bottom: 1px solid transparent!important; box-shadow: none!important; text-transform: uppercase; font-size: .75rem; }
html .btn-dark { color: #fff; background-color: #222529; border-color: #222529 #222529 #0b0c0e; }
html .btn-light { color: #222529; background-color: #fff; border-color: #fff #fff #e6e6e6; }
html .background-color-secondary { background-color: #ff7272!important; }

/* --------------------------------------------------------------------------
   2. HEADER & NAVIGATION
   -------------------------------------------------------------------------- */
.cms-index-index .page-header.type3 { background-color: transparent; position: absolute; width: 100%; }
.page-header.type3 .navigation .level0 .level-top { font-family: Poppins; }
.page-header, .header, .header-v1, .header-v2, .header-v3, .header-v4, .header-v5, .header .header-content, .header .header-top, .header .header-middle, .header .header-bottom { background: #FFFFFF !important; border-bottom: 1px solid #e5e5e5 !important; }

@media (min-width: 1701px) { .page-header.type3 .navigation:not(.side-megamenu) .level0 .level-top { padding: 15px 15px !important; font-size: 13px !important; } }
@media (min-width: 1651px) and (max-width: 1700px) { .page-header.type3 .navigation:not(.side-megamenu) .level0 .level-top { padding: 15px 10px !important; font-size: 12px !important; } }
@media (min-width: 1200px) and (max-width: 1650px) { .page-header.type3 .navigation:not(.side-megamenu) .level0 .level-top { padding: 12px 6px !important; font-size: 12px !important; letter-spacing: -0.4px !important; font-weight: 700 !important; } }
@media (min-width: 992px) and (max-width: 1199px) { .page-header.type3 .navigation:not(.side-megamenu) .level0 .level-top { padding-left: 2px !important; padding-right: 2px !important; font-size: 10px !important; letter-spacing: -0.5px !important; text-transform: uppercase !important; } .header-right-wrapper .search-toggler, .header-right-wrapper .minicart-wrapper { margin-left: 5px !important; } }

/* --------------------------------------------------------------------------
   3. BREADCRUMBS & GENERAL BLOCKS
   -------------------------------------------------------------------------- */
.page-wrapper > .breadcrumbs { border-bottom: 1px solid #dfdfdf; margin-bottom: 35px; }
.page-wrapper > .breadcrumbs .items { font-size: 10px; font-weight: 700; letter-spacing: 1px; }
.page-wrapper > .breadcrumbs .items>li.home a { width: auto; text-indent: 0; }
.page-wrapper > .breadcrumbs .items>li.home a:after {display: none;}
.catalog-category-view .sidebar.sidebar-main .sidebar-content,.catalogsearch-result-index .sidebar.sidebar-main .sidebar-content { border: none; }
.sidebar .sidebar-content .block-category-list, .side-custom-block .custom-block,.filter-options-item,.filter-actions { padding: 0; margin-bottom: 30px; border: none; }
.filter-current {padding: 0;}
.block-category-list .block-title, .side-custom-block .custom-block h2, .filter-options-title,.filter .filter-current-subtitle { border-bottom: 2px solid #dfdfdf; font-family: Oswald; font-size: 14px; font-weight: 700; letter-spacing: .05em; line-height: 1; padding: 10px 0; margin-bottom: 10px; }
.block-category-list .block-title { padding-top: 0; }
.block-category-list .block-content ol li a { font-size: 12px; }
.side-custom-block .custom-block:last-child { margin-bottom: 0; }
.side-custom-block .custom-block h5 { margin-top: 0 !important; }
.prev-next-products a { font-size: 22px; width: 40px; height: 40px; line-height: 23px; padding: 9px; margin-left: 5px; border-radius: 30px; display: inline-block; text-align: center; text-decoration: none; color: #FFFF; background-color:  #222529; }
/* --------------------------------------------------------------------------
   4. SLIDERS & PRODUCT CARDS (SQUARED DESIGN)
   -------------------------------------------------------------------------- */
.owl-carousel .owl-stage-outer, 
.products-slider .owl-stage-outer, 
.product-carousel .owl-stage-outer { 
    overflow: visible !important; 
    padding-top: 10px !important; 
    padding-bottom: 40px !important; 
    margin-bottom: -40px !important; 
}

.product-item-info {
    background-color: #ffffff !important;
    /* Bordo più leggero per pulizia */
    border: 1px solid #eaeaea !important; 
    border-radius: 8px !important; /* Raggio leggermente ridotto per look più professionale */
    padding: 15px !important;
    /* Ombra molto più leggera (5% opacity invece di 15%) */
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.05) !important; 
    position: relative !important;
    z-index: 5 !important;
    transition: all 0.3s cubic-bezier(0.25, 0.8, 0.25, 1) !important; /* Animazione più fluida */
}

.product-item-info:hover {
    transform: translateY(-5px) !important;
    /* Ombra hover più diffusa ma sempre delicata (12%) */
    box-shadow: 0 15px 30px rgba(0, 0, 0, 0.12) !important; 
    z-index: 10 !important;
    /* Bordo colorato al passaggio (facoltativo, rimuovi se vuoi solo ombra) */
    border-color: #eaeaea !important; 
}

.product-item { 
    padding: 0 10px !important; 
    margin-bottom: 10px !important; 
}

/* Fix Mobile */
@media (max-width: 768px) { 
    .product-item-info { 
        padding: 10px !important; 
        box-shadow: 0 5px 15px rgba(0, 0, 0, 0.1) !important; 
        border-radius: 0 !important; /* Sicurezza extra per mobile */
    } 
    .owl-carousel .owl-stage-outer { 
        padding-bottom: 30px !important; 
        margin-bottom: -30px !important; 
    } 
}

/* Griglia Desktop */
@media screen and (min-width: 768px) { 
    @media (min-width: 1200px), print { 
        .products-grid.columns6 .product-item { 
            width: 16.66666667%; 
            margin: 20px; 
            padding: 20px; 
        } 
    } 
}

/* Home Ads / Banner promozionali sotto slider */
#home_ads { 
    position: relative; 
    width: 100vw; 
    left: 50%; 
    margin-left: -50vw; 
    padding-left: 15px !important; 
    padding-right: 15px !important; 
    max-width: none !important; 
}

/* Se anche le immagini dentro i banner promozionali avevano angoli, questo li toglie */
.porto-ibanner, .porto-ibanner img {
    border-radius: 0 !important;
}

@media (max-width: 767px) { 
    #home_ads { 
        width: auto !important; 
        left: auto !important; 
        margin-left: -15px !important; 
        margin-right: -15px !important; 
    } 
}
/* --------------------------------------------------------------------------
   5. TACTIKO TICKER (Green Corporate Version)
   -------------------------------------------------------------------------- */
div.widget.block.block-static-block:has(.tactiko-ticker-wrap),
div.widget.block-static-block:has(.tactiko-ticker-wrap) {
    margin: 0 !important; padding: 0 !important; position: relative !important; z-index: 1 !important;
}

.tactiko-ticker-wrap {
    display: block !important; position: relative !important; width: 100%;
    height: 32px; line-height: 32px;
    background-color: #077932; /* Verde Aziendale */
    overflow: hidden; box-shadow: 0 2px 5px rgba(0,0,0,0.2);
    border-bottom: 1px solid #055824;
    z-index: 1 !important; margin: 0 !important; padding: 0 !important;
}
.sticky-header .tactiko-ticker-wrap { display: none !important; }

/* Fallback per browser vecchi */
@supports not selector(:has(a)) {
    .tactiko-ticker-wrap { margin-top: -30px !important; margin-bottom: -1em !important; }
    .widget.block-static-block { z-index: 1 !important; }
}

.tactiko-ticker-wrap .ticker-content { display: flex; width: fit-content; animation: tactiko-scroll 35s linear infinite; padding-left: 0; }

.tactiko-ticker-wrap .ticker-item { 
    white-space: nowrap; color: #ffffff; 
    font-family: 'Chakra Petch', sans-serif; 
    font-weight: 600; font-size: 11px;
    text-transform: uppercase; letter-spacing: 1.5px; 
    padding: 0 40px; display: flex; align-items: center; 
}

.tactiko-ticker-wrap .ticker-item i { font-size: 10px; margin-left: 40px; color: rgba(255,255,255,0.6); }

@keyframes tactiko-scroll { 0% { transform: translateX(0); } 100% { transform: translateX(-50%); } }

.tactiko-ticker-wrap:hover .ticker-content { animation-play-state: paused; }

@media (max-width: 768px) { 
    .tactiko-ticker-wrap { height: 32px !important; line-height: 32px !important; } 
    .tactiko-ticker-wrap .ticker-item { font-size: 10px; padding: 0 20px; } 
}

/* --------------------------------------------------------------------------
   6. CLEANUP & GHOST ELEMENTS
   -------------------------------------------------------------------------- */
.promo-banner-strip, .block-promo-banner, .page-wrapper > .notices-wrapper, .page-wrapper > noscript, .page-wrapper > .global-notices {
    display: none !important; height: 0 !important; margin: 0 !important; padding: 0 !important;
}
body { margin: 0 !important; padding: 0 !important; }
.page-wrapper { margin-top: 0 !important; padding-top: 0 !important; }
.header-container { margin-top: 0 !important; padding-top: 0 !important; top: 0 !important; }
.page-wrapper > .page.messages .messages { display: block !important; position: relative !important; z-index: 20 !important; margin: 0 !important; padding: 10px !important; }

/* --------------------------------------------------------------------------
   7. FOOTER
   -------------------------------------------------------------------------- */
.footer .widget,.widget { margin-bottom: 1.875rem; margin-top: 1.875rem; }
.footer .widget:first-child,.widget:first-child { margin-top: 0; }
.footer .widgettitle, .footer .widget-title { font-size: 1.1666em; font-weight: 700; }
.widget.contact-info ul, .widget.contact-info li { line-height: 1.8; }
.footer .follow-us .share-links a:not(:hover) { background: none; color: #525252; border: none; font-size: 18px; }
.footer .newsletter input,.footer .newsletter .action.subscribe { border-radius: 0; }
.footer .newsletter input { background: #f4f4f4; min-width: 271px; padding: 8px 12px; }
.footer .newsletter .action.subscribe { padding: .533rem .933rem; line-height: 1.42857; background-color: #222529; }
.footer .row.d-inline-flex { white-space: nowrap; margin-left: -3vw; margin-right: -3vw; }
.footer .row.d-inline-flex>div { padding-left: 3vw; padding-right: 3vw; }
.footer-middle > .container { padding-bottom: 1.55rem; }
.footer-middle > .container::after { left: 4.27vw; right: 4.27vw; border-color: #e7e7e7; }
.footer .contact-info .contact-details strong { color: #000; }
.footer-middle .widget.follow-us { display: none; }
.footer .footer-bottom { padding: 1.5rem 0 2rem; font-size: 1em; }
.page-footer .footer-top { width: 100vw; left: 50%; margin-left: -50vw; position: relative; }

/* --------------------------------------------------------------------------
   8. LAYOUT ARCHITECTURE & SIDEBAR (NATIVE FIX)
   -------------------------------------------------------------------------- */

/* A. DESKTOP (>= 992px) */
@media (min-width: 992px) {
    .page-layout-2columns-left .columns {
        display: -webkit-box !important; display: -ms-flexbox !important; display: flex !important;
        flex-wrap: wrap !important; flexDirection: row !important; justify-content: space-between !important;
    }
    .page-layout-2columns-left .sidebar-main,
    .page-layout-2columns-right .sidebar-main {
        -webkit-box-ordinal-group: 2 !important; order: 1 !important;
        width: 22% !important; flex: 0 0 22% !important;
        position: static !important; 
        display: block !important;
        padding-right: 20px !important;
        border-right: 1px solid #eee;
        z-index: 1 !important;
    }
    .page-layout-2columns-left .column.main {
        -webkit-box-ordinal-group: 3 !important; order: 2 !important;
        width: 76% !important; flex: 0 0 76% !important;
        padding-left: 20px !important;
    }
    /* Nascondi elementi mobile */
    .mobile-sidebar-overlay, .sidebar-overlay { display: none !important; }
}

/* B. MOBILE (< 992px) - SIDEBAR NATIVA */
@media (max-width: 991px) {
    
    /* 1. RESET LAYOUT */
    .page-layout-2columns-left .columns { display: block !important; }
    
    /* 2. SIDEBAR FISSA (OFF-CANVAS) */
    .sidebar-main {
        display: block !important;
        position: fixed !important;
        top: 0 !important; left: 0 !important; bottom: 0 !important;
        
        width: 280px !important;
        max-width: 85vw !important;
        height: 100vh !important;
        
        background: #ffffff !important;
        z-index: 999999 !important; /* Sopra tutto */
        
        overflow-y: auto !important;
        box-shadow: 5px 0 15px rgba(0,0,0,0.3) !important;
        margin: 0 !important; padding: 20px !important;
        
        /* Metodo TRANSFORM per evitare il "taglio" dei contenuti */
        transform: translateX(-110%);
        transition: transform 0.3s ease-in-out;
    }

    /* 3. APERTURA (Attivata da JS) */
    body.sidebar-opened .sidebar-main,
    .sidebar-main.active,
    .sidebar-main.open {
        transform: translateX(0) !important; /* Scivola dentro da sinistra */
    }

    /* 4. OVERLAY SCURO */
    .mobile-sidebar-overlay {
        position: fixed; top: 0; left: 0; width: 100vw; height: 100vh;
        background: rgba(0,0,0,0.6);
        z-index: 999990; /* Sotto la sidebar */
        display: none;
        backdrop-filter: blur(2px);
    }

    /* 5. FIX VISIBILITÀ CONTENUTI (Porto Hidden Fix) */
    .sidebar-main .block, 
    .sidebar-main .block-content,
    .sidebar-main .filter-options {
        display: block !important;
        visibility: visible !important;
        height: auto !important;
        overflow: visible !important;
    }
    
    /* Nascondiamo il titolo "FILTRA" duplicato */
    .sidebar-main .block.filter .filter-title { display: none !important; }
}

/* --------------------------------------------------------------------------
   9. TACTIKO GHOST BUTTONS
   -------------------------------------------------------------------------- */
body.cms-index-index .page-wrapper button.btn-modern.btn-dark,
body.cms-index-index .page-wrapper a.btn-modern.btn-dark,
body.cms-index-index .page-wrapper .owl-item .btn-modern,
body.cms-index-index .banner-content .btn-modern {
    background-color: transparent !important;
    background-image: none !important;
    border: 2px solid #ffffff !important;
    color: #ffffff !important;
    font-family: 'Chakra Petch', sans-serif !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: 2px !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    transition: all 0.3s ease-in-out !important;
}

body.cms-index-index .page-wrapper button.btn-modern.btn-dark:hover,
body.cms-index-index .page-wrapper a.btn-modern.btn-dark:hover,
body.cms-index-index .page-wrapper .owl-item .btn-modern:hover {
    background-color: #ffffff !important;
    border-color: #ffffff !important;
    color: #000000 !important;
    text-decoration: none !important;
    transform: translateY(-3px);
    box-shadow: 0 5px 15px rgba(0,0,0,0.3) !important;
}

body.cms-index-index .btn-modern i,
body.cms-index-index .btn-modern.btn-dark i {
    color: inherit !important;
    padding-left: 5px !important;
}

/* ==============================================
   CLEANUP: RIMOZIONE LISTA CATEGORIE SIDEBAR
   ============================================== */
body.catalog-category-view .sidebar .block-category-list {
    display: none !important;
}

/* ==============================================
   CLEANUP: RIMOZIONE SIDE MEGAMENU (MENU VERTICALE)
   ============================================== */
body.catalog-category-view .sidebar-main .side-megamenu,
body.catalog-category-view .sidebar-main .navigation.side-megamenu {
    display: none !important;
}


/* banner nuovo*/ 

/* --- TACTIKO PROMO BANNER (WARRIOR STYLE) --- */
.tactiko-promo-section {
    position: relative;
    width: 100vw;
    left: 50%;
    margin-left: -50vw;
    /* Altezza fissa come da richiesta, regolabile */
    height: 600px; 
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    display: flex;
    align-items: center;
    /* Spazio sopra e sotto per separarlo dalle altre sezioni */
    margin-top: 60px;
    margin-bottom: 60px;
}

.tactiko-promo-overlay {
    position: absolute; top: 0; left: 0; right: 0; bottom: 0;
    background: rgba(0, 0, 0, 0.35); /* Leggero scurimento per leggerezza testo */
    z-index: 1;
}

.tactiko-promo-content {
    position: relative;
    z-index: 10;
    width: 100%;
}

/* SINISTRA: Testi */
.promo-subtitle {
    font-family: 'Oxanium', sans-serif; /* Font tecnico */
    color: #fff;
    font-size: 14px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 2px;
    margin-bottom: 10px;
    display: block;
}

.promo-title {
    font-family: 'Chakra Petch', sans-serif;
    font-weight: 700;
    font-style: italic; /* Chiave del design */
    color: #fff;
    font-size: 65px;
    line-height: 0.9;
    text-transform: uppercase;
    margin-bottom: 30px;
}

/* Bottone Bianco */
.btn-tactiko-white {
    background-color: #fff;
    color: #000;
    font-family: 'Chakra Petch', sans-serif;
    font-weight: 700;
    text-transform: uppercase;
    padding: 12px 35px;
    border: none;
    border-radius: 0; /* Angoli vivi */
    font-size: 14px;
    letter-spacing: 1px;
    transition: all 0.3s ease;
}

.btn-tactiko-white:hover {
    background-color: #000;
    color: #fff;
}

/* DESTRA: Grafica 50% OFF */
.promo-discount-wrapper {
    display: flex;
    align-items: center;
    justify-content: flex-end; /* Allinea a destra */
    position: relative;
}

.discount-box {
    position: relative;
    display: inline-flex;
    align-items: center;
    border-top: 3px solid #d32f2f; /* Linea Rossa Sopra */
    border-bottom: 3px solid #d32f2f; /* Linea Rossa Sotto */
    padding: 10px 0;
}

.discount-upto {
    writing-mode: vertical-rl; /* Testo Verticale */
    transform: rotate(180deg); /* Ruota per leggere dal basso verso l'alto */
    color: #fff;
    font-family: 'Oxanium', sans-serif;
    font-size: 12px;
    font-weight: 600;
    letter-spacing: 2px;
    margin-left: 15px; /* Spazio dai numeri */
    text-transform: uppercase;
}

.discount-number {
    font-family: 'Chakra Petch', sans-serif;
    font-weight: 700;
    font-size: 80px;
    line-height: 1;
    color: transparent; /* Testo trasparente */
    -webkit-text-stroke: 2px #fff; /* Bordo bianco */
    text-transform: uppercase;
    margin-left: 10px;
}

/* RESPONSIVE */
@media (max-width: 992px) {
    .tactiko-promo-section { height: 500px; }
    .promo-title { font-size: 50px; }
    .discount-number { font-size: 60px; }
}

@media (max-width: 768px) {
    .tactiko-promo-section { height: auto; padding: 60px 0; }
    .promo-discount-wrapper { justify-content: flex-start; margin-top: 40px; }
    .promo-title { font-size: 40px; }
    .discount-box { padding: 5px 0; }
    .discount-number { font-size: 50px; }
}

