/* ========================================
   FERRUFFICIO HOMEPAGE - CSS COMPLETO
   Tema Algori Shop (html font-size: 10px)
   ======================================== */

/* Variabili Colori */
:root {
    --ferrufficio-orange: #FF6600;
    --ferrufficio-orange-hover: #e55a00;
    --ferrufficio-green: #2C5F2D;
    --ferrufficio-green-hover: #234a24;
    --ferrufficio-light-bg: #f8f9fa;
    --ferrufficio-white: #ffffff;
    --ferrufficio-text: #333333;
    --ferrufficio-text-light: #666666;
}

/* ===========================================
   FONT GLOBALE - Source Sans Pro (come sito online)
   =========================================== */
@import url('https://fonts.googleapis.com/css2?family=Source+Sans+Pro:wght@300;400;600;700&display=swap');

body,
html,
* {
    font-family: "Source Sans Pro", "HelveticaNeue-Light", "Helvetica Neue Light", "Helvetica Neue", Helvetica, Arial, "Lucida Grande", sans-serif !important;
}

/* Escludi icone dalla regola font */
.fa, .fas, .far, .fab, .fal,
[class*="dashicons"],
[class*="icon"],
.star-rating::before,
.star-rating span::before {
    font-family: inherit !important;
}

/* ========================================
   FIX LAYOUT TEMA ALGORI SHOP
   Rimuove sidebar e linee verticali
   ======================================== */

/* Homepage: main content full width, nascondi sidebar */
.page-id-17 #primary.content-area,
.page-id-17 main.site-main {
    width: 100% !important;
    max-width: 100% !important;
    flex: 0 0 100% !important;
    float: none !important;
    margin: 0 !important;
    padding: 0 !important;
    border: none !important;
}

/* Nascondi sidebar sulla homepage */
.page-id-17 #secondary.sidebar,
.page-id-17 aside.widget-area {
    display: none !important;
}

/* Rimuovi bordi dai contenitori del tema */
.page-id-17 .site-content,
.page-id-17 #content,
.page-id-17 .content-area,
.page-id-17 .site-main,
.page-id-17 .entry-content,
.page-id-17 .post-content,
.page-id-17 article {
    border: none !important;
    box-shadow: none !important;
    outline: none !important;
    max-width: 100% !important;
    width: 100% !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
}

/* Rimuovi pseudo-elementi che potrebbero creare linee */
.page-id-17 .site-content::before,
.page-id-17 .site-content::after,
.page-id-17 #primary::before,
.page-id-17 #primary::after,
.page-id-17 .entry-content::before,
.page-id-17 .entry-content::after {
    display: none !important;
    border: none !important;
}

/* Container Base */
.ferrufficio-homepage-elegant {
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue", sans-serif;
    line-height: 1.6;
    color: var(--ferrufficio-text);
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    border: none !important;
    box-shadow: none !important;
}

/* Rimuovi bordi/linee verticali da tutti gli elementi interni */
.ferrufficio-homepage-elegant *,
.ferrufficio-homepage-elegant section,
.ferrufficio-homepage-elegant .container,
.ferrufficio-homepage-elegant .row,
.ferrufficio-homepage-elegant .col-md-6 {
    border-left: none !important;
    border-right: none !important;
}

/* Eccezione: mantieni bordi sulle card */
.ferrufficio-homepage-elegant .why-card-elegant {
    border: 1px solid #e0e0e0 !important;
    box-shadow: none !important;
}

.ferrufficio-homepage-elegant .why-card-elegant:hover {
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.1) !important;
}

/* Eccezione: mantieni ombra sulle immagini */
.ferrufficio-homepage-elegant .home-service-photo img {
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.15) !important;
}

.ferrufficio-homepage-elegant .container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 20px;
    text-align: center;
}

/* Centra tutto il contenuto della homepage */
.ferrufficio-homepage-elegant section {
    width: 100%;
    margin-left: auto;
    margin-right: auto;
}

/* ========================================
   HERO SECTION
   ======================================== */
.home-hero-photo {
        margin-top: 20px !important;
    background-size: cover !important;
    background-position: center 20% !important;
    background-repeat: no-repeat !important;
    min-height: 550px !important;
    display: flex !important;
    align-items: center !important;
    position: relative !important;
    margin-left: calc(-50vw + 50%) !important;
    margin-right: calc(-50vw + 50%) !important;
    width: 100vw !important;
    margin-top: -30px !important;
}

.hero-overlay-photo {
    background: rgba(0, 0, 0, 0.55) !important;
    width: 100% !important;
    min-height: 550px !important;
    display: flex !important;
    align-items: center !important;
    padding: 100px 0 !important;
}

.home-hero-photo .container {
    max-width: 1100px !important;
    margin: 0 auto !important;
    padding: 0 30px !important;
    text-align: center !important;
}

/* Titolo H1 - 48px (4.8rem con base 10px) */
.home-hero-photo h1 {
    font-size: 4.8rem !important;
    font-weight: 700 !important;
    line-height: 1.15 !important;
    color: #ffffff !important;
    text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.5) !important;
    margin-bottom: 25px !important;
    letter-spacing: -0.5px !important;
}

/* Sottotitolo - 24px (2.4rem con base 10px) */
.home-hero-photo .hero-lead {
    font-size: 2.4rem !important;
    font-weight: 500 !important;
    line-height: 1.5 !important;
    color: #ffffff !important;
    text-shadow: 1px 1px 3px rgba(0, 0, 0, 0.5) !important;
    margin-bottom: 20px !important;
}

/* Testo descrittivo - 20px, CENTRATO e GRASSETTO */
.home-hero-photo .hero-text {
    font-size: 2rem !important;
    font-weight: 600 !important;
    line-height: 1.7 !important;
    color: #e8e8e8 !important;
    text-shadow: 1px 1px 2px rgba(0, 0, 0, 0.5) !important;
    margin-bottom: 35px !important;
    text-align: center !important;
    max-width: 900px !important;
    margin-left: auto !important;
    margin-right: auto !important;
}

.hero-ctas {
    display: flex !important;
    justify-content: center !important;
    gap: 20px !important;
    flex-wrap: wrap !important;
}

/* ========================================
   BUTTONS
   ======================================== */
.btn-primary-large {
    background-color: var(--ferrufficio-orange) !important;
    color: #ffffff !important;
    padding: 16px 35px !important;
    border-radius: 5px !important;
    text-decoration: none !important;
    font-weight: 600 !important;
    font-size: 1.8rem !important;
    display: inline-block !important;
    transition: all 0.3s ease !important;
    border: none !important;
}

.btn-primary-large:hover {
    background-color: var(--ferrufficio-orange-hover) !important;
    color: #ffffff !important;
    transform: translateY(-2px);
    box-shadow: 0 4px 15px rgba(255, 101, 0, 0.4);
}

.btn-secondary-outline {
    background-color: #ffffff !important;
    color: var(--ferrufficio-green) !important;
    padding: 14px 35px !important;
    border: 2px solid var(--ferrufficio-green) !important;
    border-radius: 5px !important;
    text-decoration: none !important;
    font-weight: 600 !important;
    font-size: 1.8rem !important;
    display: inline-block !important;
    transition: all 0.3s ease !important;
}

.btn-secondary-outline:hover {
    background-color: var(--ferrufficio-green) !important;
    color: #ffffff !important;
}

.btn-service-home {
    display: inline-block;
    background-color: var(--ferrufficio-green);
    color: #ffffff !important;
    padding: 14px 30px;
    font-size: 1.6rem;
    font-weight: 600;
    text-decoration: none;
    border-radius: 6px;
    transition: all 0.3s ease;
    margin-top: 20px;
}

.btn-service-home:hover {
    background-color: var(--ferrufficio-green-hover);
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(44, 95, 45, 0.3);
    color: #ffffff !important;
    text-decoration: none;
}

/* ========================================
   WHY US SECTION - Card con bordo
   ======================================== */
.home-why-us {
    padding: 80px 0;
    background-color: var(--ferrufficio-white);
}

.home-why-us h2 {
    text-align: center;
    font-size: 3.6rem;
    font-weight: 700;
    color: var(--ferrufficio-green);
    margin-bottom: 50px;
}

.why-grid-elegant {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 30px;
    max-width: 1200px;
    margin: 0 auto;
}

.why-card-elegant {
    background: var(--ferrufficio-white);
    border: 1px solid #e0e0e0;
    border-radius: 12px;
    padding: 30px 25px;
    text-align: center;
    transition: all 0.3s ease;
}

.why-card-elegant:hover {
    transform: translateY(-5px);
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.1);
    border-color: var(--ferrufficio-green);
}

.why-icon-elegant {
    margin-bottom: 20px;
}

.why-icon-elegant svg {
    width: 64px;
    height: 64px;
}

.why-card-elegant h3 {
    font-size: 2rem;
    font-weight: 700;
    color: var(--ferrufficio-green);
    margin-bottom: 15px;
}

.why-card-elegant p {
    font-size: 1.5rem;
    color: var(--ferrufficio-text-light);
    line-height: 1.6;
    margin: 0;
}

.why-card-elegant a {
    color: var(--ferrufficio-orange);
    text-decoration: none;
}

.why-card-elegant a:hover {
    text-decoration: underline;
}

/* ========================================
   SERVICE SECTIONS - Immagine + Testo
   ======================================== */
.home-service-photo {
    padding: 80px 0;
}

.home-service-photo.bg-light-home {
    background-color: var(--ferrufficio-light-bg);
}

.home-service-photo .container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 20px;
}

.home-service-photo .row {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    margin: 0 -15px;
}

/* Alternanza immagine sx/dx - come pagina Servizi */
.home-service-photo .row.flex-row-reverse {
    flex-direction: row-reverse;
}

.home-service-photo .col-md-6 {
    flex: 0 0 50%;
    max-width: 50%;
    padding: 0 15px;
}

.home-service-photo img {
    width: 100%;
    height: auto;
    border-radius: 12px;
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.15);
}

.home-service-photo h2 {
    font-size: 3.2rem;
    font-weight: 700;
    color: var(--ferrufficio-green);
    margin-bottom: 20px;
    text-align: left;
}

.service-intro-home {
    font-size: 1.8rem;
    color: var(--ferrufficio-text-light);
    margin-bottom: 25px;
    line-height: 1.7;
    text-align: left;
}

/* Testo sezioni servizi allineato a sinistra */
.home-service-photo .col-md-6 {
    text-align: left;
}

/* Feature list con check verdi e linea separatrice */
.feature-list-elegant {
    list-style: none;
    padding: 0;
    margin: 0 0 25px 0;
}

.feature-list-elegant li {
    position: relative;
    padding-left: 35px;
    padding-bottom: 12px;
    margin-bottom: 12px;
    font-size: 1.6rem;
    color: var(--ferrufficio-text);
    border-bottom: 1px solid #e0e0e0;
}

.feature-list-elegant li:last-child {
    border-bottom: none;
    margin-bottom: 0;
    padding-bottom: 0;
}

.feature-list-elegant li::before {
    content: "✓";
    position: absolute;
    left: 0;
    color: var(--ferrufficio-green);
    font-weight: 700;
    font-size: 1.8rem;
}

/* ========================================
   MONITORING SECTION - Sfondo bianco
   ======================================== */
.home-monitoring {
    padding: 80px 0;
    background-color: var(--ferrufficio-white);
    text-align: center;
}

.home-monitoring h2 {
    font-size: 3.6rem;
    font-weight: 700;
    color: var(--ferrufficio-green);
    margin-bottom: 15px;
}

.section-subtitle-home {
    font-size: 2rem;
    color: var(--ferrufficio-text-light);
    margin-bottom: 25px;
}

.monitoring-text {
    font-size: 1.8rem;
    color: var(--ferrufficio-text-light);
    max-width: 800px;
    margin: 0 auto;
    line-height: 1.8;
}

/* ========================================
   CTA FINALE - Sfondo grigio chiaro
   ======================================== */
.home-cta-final {
    padding: 80px 0;
    background-color: var(--ferrufficio-light-bg);
    text-align: center;
}

.home-cta-final h2 {
    font-size: 3.6rem;
    font-weight: 700;
    color: var(--ferrufficio-green);
    margin-bottom: 20px;
}

.home-cta-final p {
    font-size: 1.8rem;
    color: var(--ferrufficio-text-light);
    max-width: 700px;
    margin: 0 auto 15px;
    line-height: 1.7;
}

.home-cta-final a:not(.btn-primary-large) {
    color: var(--ferrufficio-orange);
    text-decoration: none;
}

.home-cta-final a:not(.btn-primary-large):hover {
    text-decoration: underline;
}

.cta-note {
    font-size: 1.6rem !important;
    font-style: italic;
    margin-bottom: 30px !important;
}

/* ========================================
   HEADER - Allineamento CENTRATO (default e fixed)
   ======================================== */

/* Disabilita TUTTE le transizioni/animazioni */
.navbar.basic,
.navbar.basic.default,
.navbar.basic.fixed,
.navbar.basic *,
.navbar.basic.default *,
.navbar.basic.fixed * {
    transition: none !important;
    animation: none !important;
}

/* NAVBAR - Altezza fissa 96px */
.navbar.basic,
.navbar.basic.default,
.navbar.basic.fixed {
    min-height: 96px !important;
    height: 96px !important;
    padding: 0 !important;
    margin: 0 !important;
}

/* NAVBAR-HEADER - Flex container CENTRATO */
.navbar.basic .navbar-header,
.navbar.basic.default .navbar-header,
.navbar.basic.fixed .navbar-header {
    min-height: 96px !important;
    height: 96px !important;
    padding: 0 !important;
    margin: 0 !important;
    display: flex !important;
    align-items: center !important;
}

/* CONTAINER dentro navbar-header - CENTRATO */
.navbar.basic .navbar-header .container,
.navbar.basic.default .navbar-header .container,
.navbar.basic.fixed .navbar-header .container {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    height: 96px !important;
}

/* SITE-BRANDING wrapper - CENTRATO */
.navbar.basic .site-branding,
.navbar.basic .site-branding.basic-wrapper,
.navbar.basic.default .site-branding,
.navbar.basic.fixed .site-branding {
    display: flex !important;
    align-items: center !important;
    height: 96px !important;
}

/* LOGO LINK - CENTRATO */
.navbar.basic .navbar-brand,
.navbar.basic .custom-logo-link,
.navbar.basic .custom-logo-link.navbar-brand,
.navbar.basic.default .navbar-brand,
.navbar.basic.fixed .navbar-brand {
    display: flex !important;
    align-items: center !important;
    padding: 0 !important;
    margin: 0 !important;
    height: auto !important;
}

/* LOGO IMG - dimensioni fisse 76px x 238px */
.navbar.basic .navbar-brand img,
.navbar.basic .custom-logo,
.navbar.basic.default .navbar-brand img,
.navbar.basic.default .custom-logo,
.navbar.basic.fixed .navbar-brand img,
.navbar.basic.fixed .custom-logo {
    height: 76px !important;
    width: 238px !important;
    max-height: 76px !important;
    max-width: 238px !important;
    min-height: 76px !important;
    min-width: 238px !important;
    object-fit: contain !important;
    vertical-align: middle !important;
    margin: 0 !important;
}

/* NAVIGAZIONE - CENTRATA */
.navbar.basic .main-navigation,
.navbar.basic .navbar-collapse,
.navbar.basic.default .main-navigation,
.navbar.basic.fixed .main-navigation {
    display: flex !important;
    align-items: center !important;
    height: 96px !important;
}

/* NAVBAR-NAV ul - stessi stili per default e fixed */
.navbar.basic .navbar-nav,
.navbar.basic.default .navbar-nav,
.navbar.basic.fixed .navbar-nav {
    display: flex !important;
    align-items: center !important;
    margin: 0 !important;
    padding: 0 !important;
}

/* MENU LI */
.navbar.basic .navbar-nav > li,
.navbar.basic.default .navbar-nav > li,
.navbar.basic.fixed .navbar-nav > li {
    display: flex !important;
    align-items: center !important;
}

/* MENU LINKS - STESSO padding della .fixed del tema (19px 10px) */
.navbar.basic .navbar-nav > li > a,
.navbar.basic.default .navbar-nav > li > a,
.navbar.basic.fixed .navbar-nav > li > a {
    padding: 19px 10px !important;
    font-size: 14px !important;
    line-height: 1.4 !important;
    color: #666666 !important;
    text-transform: capitalize !important;
    text-decoration: none !important;
    border-bottom: none !important;
}

/* MENU LINKS - Voce attiva (current) in blu */
.navbar.basic .navbar-nav > li.active > a,
.navbar.basic .navbar-nav > li.current-menu-item > a,
.navbar.basic .navbar-nav > li.current_page_item > a,
.navbar.basic.default .navbar-nav > li.active > a,
.navbar.basic.fixed .navbar-nav > li.active > a {
    color: rgb(63, 141, 191) !important;
}

/* MENU LI - Rimuovi linee sotto */
.navbar.basic .navbar-nav > li,
.navbar.basic.default .navbar-nav > li,
.navbar.basic.fixed .navbar-nav > li {
    border-bottom: none !important;
}

/* HEADER STICKY/FIXED - Forza position fixed */
.site-header.navbar.basic,
.site-header.navbar.basic.default {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    z-index: 8000 !important;
    background-color: #ffffff !important;
}

/* ========================================
   MOBILE MENU HAMBURGER
   ======================================== */

/* Bottone hamburger - nascosto su desktop */
.navbar.basic .responsive-menu,
.navbar.basic .btn.responsive-menu {
    display: none !important;
}

/* Mobile: mostra hamburger e nascondi menu */
@media (max-width: 768px) {
    /* Header mobile - altezza ridotta */
    .navbar.basic,
    .navbar.basic.default,
    .navbar.basic.fixed {
        min-height: 70px !important;
        height: 70px !important;
    }

    .navbar.basic .navbar-header,
    .navbar.basic.default .navbar-header,
    .navbar.basic.fixed .navbar-header {
        min-height: 70px !important;
        height: 70px !important;
    }

    .navbar.basic .navbar-header .container {
        height: 70px !important;
        padding: 0 15px !important;
    }

    /* Logo più piccolo su mobile */
    .navbar.basic .navbar-brand img,
    .navbar.basic .custom-logo {
        height: 50px !important;
        width: auto !important;
        max-width: 160px !important;
        min-height: 50px !important;
        min-width: auto !important;
    }

    /* Mostra bottone hamburger - DISCRETO */
    .navbar.basic .responsive-menu,
    .navbar.basic .btn.responsive-menu {
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        width: 32px !important;
        height: 32px !important;
        background: transparent !important;
        border: none !important;
        color: #333 !important;
        font-size: 20px !important;
        cursor: pointer !important;
        position: absolute !important;
        right: 15px !important;
        top: 50% !important;
        transform: translateY(-50%) !important;
        z-index: 1001 !important;
        order: 3 !important;
        padding: 0 !important;
    }

    .navbar.basic .responsive-menu:hover {
        color: var(--ferrufficio-orange) !important;
        background: transparent !important;
    }

    .navbar.basic .responsive-menu .fa-bars,
    .navbar.basic .responsive-menu i {
        color: #333 !important;
        font-size: 20px !important;
    }

    .navbar.basic .responsive-menu:hover .fa-bars,
    .navbar.basic .responsive-menu:hover i {
        color: var(--ferrufficio-orange) !important;
    }

    /* Fallback per icona hamburger se FontAwesome non carica */
    .navbar.basic .responsive-menu .fa-bars:before,
    .navbar.basic .responsive-menu i.fa-bars:before {
        content: "☰" !important;
        font-family: inherit !important;
        font-style: normal !important;
        font-size: 20px !important;
        color: inherit !important;
    }

    /* Nasconde elementi WooCommerce/carrello azzurri nell'header mobile */
    .navbar.basic .the-cart-contents,
    .navbar.basic .algori-shop-woocommerce-header-cart-link {
        display: none !important;
    }

    /* Site branding - position relative per il bottone absolute */
    .navbar.basic .site-branding,
    .navbar.basic .site-branding.basic-wrapper {
        position: relative !important;
        width: 100% !important;
        justify-content: flex-start !important;
        height: 70px !important;
    }

    /* Nascondi menu su mobile (collapsed) - IMPORTANTE: senza .in = nascosto */
    .navbar.basic .main-navigation.navbar-collapse,
    .navbar.basic .navbar-collapse,
    #site-navigation.navbar-collapse {
        display: none !important;
        position: absolute !important;
        top: 70px !important;
        left: 0 !important;
        right: 0 !important;
        width: 100% !important;
        background: #fff !important;
        box-shadow: 0 4px 10px rgba(0,0,0,0.15) !important;
        z-index: 1000 !important;
        height: auto !important;
        flex-direction: column !important;
        padding: 0 !important;
        overflow: hidden !important;
        float: none !important;
    }

    /* Menu aperto (quando Bootstrap aggiunge .in) */
    .navbar.basic .navbar-collapse.in,
    .navbar.basic .main-navigation.navbar-collapse.in,
    #site-navigation.navbar-collapse.in {
        display: flex !important;
        overflow: visible !important;
        position: absolute !important;
        top: 70px !important;
        left: 0 !important;
        right: 0 !important;
        width: 100% !important;
        height: auto !important;
        max-height: none !important;
        bottom: auto !important;
    }

    /* Menu items verticali - COMPATTO */
    .navbar.basic .navbar-nav {
        flex-direction: column !important;
        width: 100% !important;
        padding: 5px 0 !important;
    }

    .navbar.basic .navbar-nav > li {
        width: 100% !important;
        border-bottom: 1px solid #f0f0f0 !important;
    }

    .navbar.basic .navbar-nav > li:last-child {
        border-bottom: none !important;
    }

    .navbar.basic .navbar-nav > li > a {
        padding: 10px 15px !important;
        width: 100% !important;
        text-align: left !important;
        font-size: 14px !important;
        font-weight: 400 !important;
    }
}
        color: #333 !important;
    }

    .navbar.basic .navbar-nav > li > a:hover {
        background: #f8f8f8 !important;
        color: var(--ferrufficio-orange) !important;
    }

    /* Carrello nascosto nel menu mobile (già nell'header) */
    .navbar.basic .algori-shop-woocommerce-header-cart-link {
        display: none !important;
    }
}

/* ========================================
   RESPONSIVE
   ======================================== */
@media (max-width: 1024px) {
    .why-grid-elegant {
        grid-template-columns: repeat(2, 1fr);
    }

    .home-hero-photo h1 {
        font-size: 3.8rem !important;
    }

    .home-hero-photo .hero-lead {
        font-size: 2rem !important;
    }
}

@media (max-width: 768px) {
    .why-grid-elegant {
        grid-template-columns: 1fr;
    }

    .home-service-photo .col-md-6 {
        flex: 0 0 100%;
        max-width: 100%;
        margin-bottom: 30px;
    }

    .home-service-photo .col-md-6.order-md-1,
    .home-service-photo .col-md-6.order-md-2 {
        order: 0;
    }

    .home-hero-photo {
        margin-top: 20px !important;
        min-height: 450px !important;
    }

    .hero-overlay-photo {
        min-height: 450px !important;
    }

    .home-hero-photo h1 {
        font-size: 3.2rem !important;
    }

    .home-hero-photo .hero-lead {
        font-size: 1.8rem !important;
    }

    .home-hero-photo .hero-text {
        font-size: 1.6rem !important;
    }

    .hero-ctas {
        flex-direction: column !important;
        align-items: center !important;
    }

    .btn-primary-large,
    .btn-secondary-outline {
        width: 100% !important;
        max-width: 300px !important;
        text-align: center !important;
    }

    .home-why-us h2,
    .home-monitoring h2,
    .home-cta-final h2 {
        font-size: 2.8rem;
    }

    .home-service-photo h2 {
        font-size: 2.6rem;
    }
}

@media (max-width: 480px) {
    .home-hero-photo h1 {
        font-size: 3rem !important;
    }

    .home-hero-photo .hero-lead {
        font-size: 1.8rem !important;
    }

    .home-hero-photo .hero-text {
        font-size: 1.4rem !important;
    }
}

/* ========================================
   PAGINA CHI SIAMO
   ======================================== */

/* Fix layout pagina Chi Siamo (ID 22) */
.page-id-22 #primary.content-area,
.page-id-22 main.site-main {
    width: 100% !important;
    max-width: 100% !important;
    flex: 0 0 100% !important;
    float: none !important;
    margin: 0 !important;
    padding: 0 !important;
    border: none !important;
}

.page-id-22 #secondary.sidebar,
.page-id-22 aside.widget-area {
    display: none !important;
}

/* Nascondi banner blu titolo pagina */
.page-id-22 .gradient-wrapper.page-title,
.page-id-22 .gradient-wrapper,
.page-id-22 .page-header,
.page-id-22 .entry-header,
.page-id-22 .page-title-section,
.page-id-22 header.entry-header,
.page-id-22 .algflavor-page-header,
.page-id-22 .flavor-page-header,
.page-id-22 .woocommerce-products-header,
.page-id-22 h1.entry-title,
.page-id-22 .entry-title {
    display: none !important;
}

.page-id-22 .site-content,
.page-id-22 #content,
.page-id-22 .content-area,
.page-id-22 .site-main,
.page-id-22 .entry-content,
.page-id-22 .post-content,
.page-id-22 article {
    border: none !important;
    box-shadow: none !important;
    outline: none !important;
    max-width: 100% !important;
    width: 100% !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
}

.page-id-22 .site-content::before,
.page-id-22 .site-content::after,
.page-id-22 #primary::before,
.page-id-22 #primary::after,
.page-id-22 .entry-content::before,
.page-id-22 .entry-content::after {
    display: none !important;
    border: none !important;
}

/* Container Chi Siamo */
.ferrufficio-chi-siamo {
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue", sans-serif;
    line-height: 1.6;
    color: var(--ferrufficio-text);
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    border: none !important;
    box-shadow: none !important;
}

.ferrufficio-chi-siamo section,
.ferrufficio-chi-siamo .container,
.ferrufficio-chi-siamo .row,
.ferrufficio-chi-siamo .col-md-5,
.ferrufficio-chi-siamo .col-md-7 {
    border-left: none !important;
    border-right: none !important;
}

.ferrufficio-chi-siamo .container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 20px;
}

/* Hero Chi Siamo - Full Width */
.chi-siamo-hero {
    background-size: cover !important;
    background-position: center !important;
    background-repeat: no-repeat !important;
    min-height: 450px !important;
    display: flex !important;
    align-items: center !important;
    position: relative !important;
    margin-left: calc(-50vw + 50%) !important;
    margin-right: calc(-50vw + 50%) !important;
    width: 100vw !important;
    margin-top: -120px !important;
}

.hero-overlay-chi-siamo {
    background: linear-gradient(135deg, rgba(0, 0, 0, 0.45) 0%, rgba(0, 0, 0, 0.55) 100%) !important;
    width: 100% !important;
    min-height: 450px !important;
    display: flex !important;
    align-items: center !important;
    padding: 80px 0 !important;
}

.chi-siamo-hero .container {
    max-width: 1000px !important;
    margin: 0 auto !important;
    padding: 0 30px !important;
    text-align: center !important;
}

.chi-siamo-hero h1 {
    font-size: 4.2rem !important;
    font-weight: 700 !important;
    line-height: 1.2 !important;
    color: #ffffff !important;
    text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.5) !important;
    margin-bottom: 25px !important;
}

.chi-siamo-hero .hero-lead {
    font-size: 2rem !important;
    line-height: 1.7 !important;
    color: #ffffff !important;
    text-shadow: 1px 1px 3px rgba(0, 0, 0, 0.5) !important;
    max-width: 900px !important;
    margin: 0 auto !important;
    opacity: 0.95;
}

/* Partnership Section */
.chi-siamo-partnership {
    padding: 50px 0;
    background-color: var(--ferrufficio-white);
    text-align: center;
}

.partnership-text {
    font-size: 1.8rem;
    color: var(--ferrufficio-text-light);
    line-height: 1.8;
    max-width: 900px;
    margin: 0 auto;
}

.partnership-text strong {
    color: var(--ferrufficio-text);
}

/* Mission Section */
.chi-siamo-mission {
    padding: 80px 0;
    background-color: var(--ferrufficio-white);
}

.chi-siamo-mission .row {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    margin: 0 -15px;
}

.chi-siamo-mission .col-md-7 {
    flex: 0 0 58.333%;
    max-width: 58.333%;
    padding: 0 15px;
}

.chi-siamo-mission .col-md-5 {
    flex: 0 0 41.667%;
    max-width: 41.667%;
    padding: 0 15px;
}

.chi-siamo-mission h2 {
    font-size: 3.6rem;
    font-weight: 700;
    color: var(--ferrufficio-green);
    margin-bottom: 25px;
    text-align: left;
}

.mission-text {
    font-size: 1.8rem;
    color: var(--ferrufficio-text-light);
    line-height: 1.8;
    margin-bottom: 20px;
    text-align: left;
}

.mission-text a {
    color: #0066cc;
    text-decoration: none;
}

.mission-text a:hover {
    text-decoration: underline;
}

.chi-siamo-mission img {
    width: 100%;
    height: auto;
    border-radius: 12px;
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.15);
}

/* Values Section */
.chi-siamo-values {
    padding: 80px 0;
    background-color: var(--ferrufficio-white);
}

.chi-siamo-values h2 {
    font-size: 3.6rem;
    font-weight: 700;
    color: var(--ferrufficio-text);
    margin-bottom: 50px;
    text-align: center;
}

.values-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 30px;
    max-width: 1200px;
    margin: 0 auto;
}

.value-card {
    background: var(--ferrufficio-white);
    border: 1px solid #e0e0e0 !important;
    border-left: 1px solid #e0e0e0 !important;
    border-right: 1px solid #e0e0e0 !important;
    border-radius: 12px;
    padding: 40px 30px;
    text-align: center;
    transition: all 0.3s ease;
}

.value-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.1);
    border-color: var(--ferrufficio-green);
}

.value-icon {
    margin-bottom: 25px;
}

.value-icon svg {
    width: 64px;
    height: 64px;
}

.value-card h3 {
    font-size: 2.2rem;
    font-weight: 700;
    color: var(--ferrufficio-text);
    margin-bottom: 15px;
}

.value-card p {
    font-size: 1.5rem;
    color: var(--ferrufficio-text-light);
    line-height: 1.7;
    margin: 0;
}

.value-card a {
    color: #0066cc;
    text-decoration: none;
}

.value-card a:hover {
    text-decoration: underline;
}

/* CTA Section Chi Siamo */
.chi-siamo-cta {
    padding: 80px 0;
    background-color: var(--ferrufficio-white);
    text-align: center;
}

.chi-siamo-cta h2 {
    font-size: 3.2rem;
    font-weight: 700;
    color: var(--ferrufficio-text);
    margin-bottom: 20px;
}

.chi-siamo-cta p {
    font-size: 1.8rem;
    color: var(--ferrufficio-text-light);
    line-height: 1.7;
    margin-bottom: 30px;
}

.chi-siamo-cta a:not(.btn-primary-large) {
    color: #0066cc;
    text-decoration: none;
}

.chi-siamo-cta a:not(.btn-primary-large):hover {
    text-decoration: underline;
}

/* Responsive Chi Siamo */
@media (max-width: 1024px) {
    .values-grid {
        grid-template-columns: repeat(3, 1fr);
    }

    .chi-siamo-hero h1 {
        font-size: 3.6rem !important;
    }
}

@media (max-width: 768px) {
    .values-grid {
        grid-template-columns: 1fr;
    }

    .chi-siamo-mission .col-md-7,
    .chi-siamo-mission .col-md-5 {
        flex: 0 0 100%;
        max-width: 100%;
        margin-bottom: 30px;
    }

    .chi-siamo-hero {
        min-height: 400px !important;
    }

    .hero-overlay-chi-siamo {
        min-height: 400px !important;
    }

    .chi-siamo-hero h1 {
        font-size: 3rem !important;
    }

    .chi-siamo-hero .hero-lead {
        font-size: 1.8rem !important;
    }

    .chi-siamo-mission h2,
    .chi-siamo-values h2 {
        font-size: 2.8rem;
        text-align: center;
    }

    .mission-text {
        text-align: center;
    }

    .chi-siamo-cta h2 {
        font-size: 2.6rem;
    }
}

/* ========================================
   PAGINA SERVIZI (ID 23)
   ======================================== */

/* Fix layout pagina Servizi */
.page-id-23 #primary.content-area,
.page-id-23 main.site-main {
    width: 100% !important;
    max-width: 100% !important;
    flex: 0 0 100% !important;
    float: none !important;
    margin: 0 !important;
    padding: 0 !important;
    border: none !important;
}

.page-id-23 #secondary.sidebar,
.page-id-23 aside.widget-area {
    display: none !important;
}

/* Nascondi banner blu titolo pagina */
.page-id-23 .gradient-wrapper.page-title,
.page-id-23 .gradient-wrapper,
.page-id-23 .page-header,
.page-id-23 .entry-header,
.page-id-23 .page-title-section,
.page-id-23 header.entry-header,
.page-id-23 .algflavor-page-header,
.page-id-23 .flavor-page-header,
.page-id-23 .woocommerce-products-header,
.page-id-23 h1.entry-title,
.page-id-23 .entry-title {
    display: none !important;
}

.page-id-23 .site-content,
.page-id-23 #content,
.page-id-23 .content-area,
.page-id-23 .site-main,
.page-id-23 .entry-content,
.page-id-23 .post-content,
.page-id-23 article {
    border: none !important;
    box-shadow: none !important;
    outline: none !important;
    max-width: 100% !important;
    width: 100% !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
}

/* Container Servizi */
.ferrufficio-servizi {
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue", sans-serif;
    line-height: 1.6;
    color: var(--ferrufficio-text);
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    border: none !important;
    box-shadow: none !important;
}

.ferrufficio-servizi .container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 20px;
}

/* Hero Servizi - Full Width */
.servizi-hero {
    background-size: cover !important;
    background-position: center !important;
    background-repeat: no-repeat !important;
    min-height: 450px !important;
    display: flex !important;
    align-items: center !important;
    position: relative !important;
    margin-left: calc(-50vw + 50%) !important;
    margin-right: calc(-50vw + 50%) !important;
    width: 100vw !important;
    margin-top: -120px !important;
}

.hero-overlay-servizi {
    background: linear-gradient(135deg, rgba(0, 0, 0, 0.6) 0%, rgba(0, 0, 0, 0.4) 100%) !important;
    width: 100% !important;
    min-height: 450px !important;
    display: flex !important;
    align-items: center !important;
    padding: 80px 0 !important;
}

.servizi-hero .container {
    max-width: 1000px !important;
    margin: 0 auto !important;
    padding: 0 30px !important;
    text-align: center !important;
}

.servizi-hero h1 {
    font-size: 4.8rem !important;
    font-weight: 700 !important;
    line-height: 1.2 !important;
    color: #ffffff !important;
    text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.5) !important;
    margin-bottom: 25px !important;
}

.servizi-hero .hero-lead {
    font-size: 2rem !important;
    line-height: 1.7 !important;
    color: #ffffff !important;
    text-shadow: 1px 1px 3px rgba(0, 0, 0, 0.5) !important;
    max-width: 900px !important;
    margin: 0 auto !important;
    opacity: 0.95;
}

/* Sezioni Servizi - Stile Alternato */
.servizi-section {
    padding: 80px 0;
    background-color: var(--ferrufficio-white);
}

.servizi-section.bg-light-servizi {
    background-color: var(--ferrufficio-light-bg);
}

.servizi-section .row {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    margin: 0 -15px;
}

/* Classe per invertire l'ordine delle colonne (immagine a destra) */
.servizi-section .row.flex-md-row-reverse {
    flex-direction: row-reverse;
}

.servizi-section .col-md-6 {
    flex: 0 0 50%;
    max-width: 50%;
    padding: 0 15px;
}

.servizi-section img {
    width: 100%;
    height: auto;
    border-radius: 12px;
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.15);
}

.servizi-section h2 {
    font-size: 3.2rem;
    font-weight: 700;
    color: var(--ferrufficio-green);
    margin-bottom: 20px;
}

.servizi-intro {
    font-size: 1.8rem;
    color: var(--ferrufficio-text-light);
    margin-bottom: 25px;
    line-height: 1.7;
}

.servizi-intro a {
    color: var(--ferrufficio-orange);
    text-decoration: none;
}

.servizi-intro a:hover {
    text-decoration: underline;
}

/* Lista Feature Servizi con Frecce Arancioni */
.servizi-feature-list {
    list-style: none;
    padding: 0;
    margin: 0 0 25px 0;
}

.servizi-feature-list li {
    position: relative;
    padding-left: 30px;
    margin-bottom: 15px;
    font-size: 1.6rem;
    color: var(--ferrufficio-text);
    line-height: 1.6;
    border-bottom: 1px solid #e5e5e5;
    padding-bottom: 15px;
}

.servizi-feature-list li:last-child {
    border-bottom: none;
    margin-bottom: 0;
    padding-bottom: 0;
}

.servizi-feature-list li::before {
    content: "→";
    position: absolute;
    left: 0;
    color: var(--ferrufficio-orange);
    font-weight: 700;
    font-size: 1.8rem;
}

.servizi-feature-list .feature-title {
    color: var(--ferrufficio-orange);
    font-weight: 700;
}

.servizi-feature-list a {
    color: var(--ferrufficio-orange);
    text-decoration: none;
}

.servizi-feature-list a:hover {
    text-decoration: underline;
}

/* Pulsanti Servizi */
.btn-servizi-orange {
    display: inline-block;
    background-color: var(--ferrufficio-orange);
    color: #ffffff !important;
    padding: 16px 35px;
    font-size: 1.6rem;
    font-weight: 600;
    text-decoration: none;
    border-radius: 6px;
    transition: all 0.3s ease;
    margin-top: 10px;
}

.btn-servizi-orange:hover {
    background-color: var(--ferrufficio-orange-hover);
    transform: translateY(-2px);
    box-shadow: 0 4px 15px rgba(255, 101, 0, 0.4);
    color: #ffffff !important;
    text-decoration: none;
}

.btn-servizi-green {
    display: inline-block;
    background-color: var(--ferrufficio-green);
    color: #ffffff !important;
    padding: 16px 35px;
    font-size: 1.6rem;
    font-weight: 600;
    text-decoration: none;
    border-radius: 6px;
    transition: all 0.3s ease;
    margin-top: 10px;
}

.btn-servizi-green:hover {
    background-color: var(--ferrufficio-green-hover);
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(44, 95, 45, 0.3);
    color: #ffffff !important;
    text-decoration: none;
}

/* CTA Finale Servizi - Sfondo Verde */
.servizi-cta-final {
    padding: 80px 0;
    background: linear-gradient(135deg, var(--ferrufficio-green) 0%, #1e4620 100%);
    text-align: center;
}

.servizi-cta-final h2 {
    font-size: 3.2rem;
    font-weight: 700;
    color: #ffffff;
    margin-bottom: 20px;
}

.servizi-cta-final p {
    font-size: 1.8rem;
    color: rgba(255, 255, 255, 0.9);
    max-width: 700px;
    margin: 0 auto 30px;
    line-height: 1.7;
}

.servizi-cta-final p a {
    color: #ffffff;
    text-decoration: underline;
}

.servizi-cta-final p a:hover {
    color: var(--ferrufficio-orange);
}

.cta-buttons {
    display: flex;
    gap: 20px;
    justify-content: center;
    flex-wrap: wrap;
}

.btn-cta-outline {
    display: inline-block;
    background-color: transparent;
    color: #ffffff !important;
    padding: 18px 40px;
    font-size: 1.8rem;
    font-weight: 600;
    text-decoration: none;
    border-radius: 8px;
    border: 2px solid #ffffff;
    transition: all 0.3s ease;
}

.btn-cta-outline:hover {
    background-color: #ffffff;
    color: var(--ferrufficio-green) !important;
    text-decoration: none;
}

.btn-cta-solid {
    display: inline-block;
    background-color: var(--ferrufficio-orange);
    color: #ffffff !important;
    padding: 18px 40px;
    font-size: 1.8rem;
    font-weight: 600;
    text-decoration: none;
    border-radius: 8px;
    border: 2px solid var(--ferrufficio-orange);
    transition: all 0.3s ease;
}

.btn-cta-solid:hover {
    background-color: var(--ferrufficio-orange-hover);
    border-color: var(--ferrufficio-orange-hover);
    transform: translateY(-2px);
    box-shadow: 0 4px 15px rgba(255, 101, 0, 0.4);
    color: #ffffff !important;
    text-decoration: none;
}

/* CTA Finale Servizi - Sfondo Grigio Chiaro (alternativa senza verde) */
.servizi-cta-final-light {
    padding: 80px 0;
    background-color: var(--ferrufficio-light-bg);
    text-align: center;
}

.servizi-cta-final-light h2 {
    font-size: 3.2rem;
    font-weight: 700;
    color: var(--ferrufficio-green);
    margin-bottom: 20px;
}

.servizi-cta-final-light p {
    font-size: 1.8rem;
    color: var(--ferrufficio-text-light);
    max-width: 700px;
    margin: 0 auto 30px;
    line-height: 1.7;
}

.servizi-cta-final-light p a {
    color: var(--ferrufficio-orange);
    text-decoration: none;
}

.servizi-cta-final-light p a:hover {
    text-decoration: underline;
}

.cta-buttons-light {
    display: flex;
    gap: 20px;
    justify-content: center;
    flex-wrap: wrap;
}

.btn-cta-outline-dark {
    display: inline-block;
    background-color: transparent;
    color: var(--ferrufficio-green) !important;
    padding: 18px 40px;
    font-size: 1.8rem;
    font-weight: 600;
    text-decoration: none;
    border-radius: 8px;
    border: 2px solid var(--ferrufficio-green);
    transition: all 0.3s ease;
}

.btn-cta-outline-dark:hover {
    background-color: var(--ferrufficio-green);
    color: #ffffff !important;
    text-decoration: none;
}

/* Responsive Servizi */
@media (max-width: 1024px) {
    .servizi-hero h1 {
        font-size: 3.6rem !important;
    }

    .servizi-section h2 {
        font-size: 2.8rem;
    }
}

@media (max-width: 768px) {
    .servizi-section .col-md-6 {
        flex: 0 0 100%;
        max-width: 100%;
        margin-bottom: 30px;
    }

    .servizi-section .row.flex-md-row-reverse {
        flex-direction: column;
    }

    .servizi-hero {
        min-height: 400px !important;
    }

    .hero-overlay-servizi {
        min-height: 400px !important;
    }

    .servizi-hero h1 {
        font-size: 3rem !important;
    }

    .servizi-hero .hero-lead {
        font-size: 1.8rem !important;
    }

    .servizi-section h2 {
        font-size: 2.4rem;
    }

    .servizi-cta-final h2,
    .servizi-cta-final-light h2 {
        font-size: 2.4rem;
    }

    .cta-buttons,
    .cta-buttons-light {
        flex-direction: column;
        align-items: center;
    }

    .btn-cta-outline,
    .btn-cta-outline-dark,
    .btn-cta-solid {
        width: 100%;
        max-width: 300px;
        text-align: center;
    }
}

/* ========================================
   PAGINA CONTATTI (ID 24)
   ======================================== */

/* Fix layout pagina Contatti */
.page-id-24 #primary.content-area,
.page-id-24 main.site-main {
    width: 100% !important;
    max-width: 100% !important;
    flex: 0 0 100% !important;
    float: none !important;
    margin: 0 !important;
    padding: 0 !important;
    border: none !important;
}

.page-id-24 #secondary.sidebar,
.page-id-24 aside.widget-area {
    display: none !important;
}

/* Nascondi banner blu titolo pagina */
.page-id-24 .gradient-wrapper.page-title,
.page-id-24 .gradient-wrapper,
.page-id-24 .page-header,
.page-id-24 .entry-header,
.page-id-24 .page-title-section,
.page-id-24 header.entry-header,
.page-id-24 .algflavor-page-header,
.page-id-24 .flavor-page-header,
.page-id-24 .woocommerce-products-header,
.page-id-24 h1.entry-title,
.page-id-24 .entry-title {
    display: none !important;
}

.page-id-24 .site-content,
.page-id-24 #content,
.page-id-24 .content-area,
.page-id-24 .site-main,
.page-id-24 .entry-content,
.page-id-24 .post-content,
.page-id-24 article {
    border: none !important;
    box-shadow: none !important;
    outline: none !important;
    max-width: 100% !important;
    width: 100% !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
}

/* Container Contatti */
.ferrufficio-contatti {
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue", sans-serif;
    line-height: 1.6;
    color: var(--ferrufficio-text);
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    border: none !important;
    box-shadow: none !important;
}

.ferrufficio-contatti .container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 20px;
}

/* Hero Contatti - Full Width */
.contatti-hero {
    background-size: cover !important;
    background-position: center !important;
    background-repeat: no-repeat !important;
    min-height: 400px !important;
    display: flex !important;
    align-items: center !important;
    position: relative !important;
    margin-left: calc(-50vw + 50%) !important;
    margin-right: calc(-50vw + 50%) !important;
    width: 100vw !important;
    margin-top: -100px !important;
}

.hero-overlay-contatti {
    background: linear-gradient(135deg, rgba(0, 0, 0, 0.6) 0%, rgba(0, 0, 0, 0.4) 100%) !important;
    width: 100% !important;
    min-height: 400px !important;
    display: flex !important;
    align-items: center !important;
    padding: 80px 0 !important;
}

.contatti-hero .container {
    max-width: 1000px !important;
    margin: 0 auto !important;
    padding: 0 30px !important;
    text-align: center !important;
}

.contatti-hero h1 {
    font-size: 4.8rem !important;
    font-weight: 700 !important;
    line-height: 1.2 !important;
    color: #ffffff !important;
    text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.5) !important;
    margin-bottom: 25px !important;
}

.contatti-hero .hero-lead {
    font-size: 2rem !important;
    line-height: 1.7 !important;
    color: #ffffff !important;
    text-shadow: 1px 1px 3px rgba(0, 0, 0, 0.5) !important;
    max-width: 800px !important;
    margin: 0 auto !important;
    opacity: 0.95;
}

/* Sezione Principale Contatti */
.contatti-main {
    padding: 80px 0;
    background-color: var(--ferrufficio-white);
}

.contatti-main .row {
    display: flex;
    flex-wrap: wrap;
    margin: 0 -20px;
}

.contatti-main .col-md-5 {
    flex: 0 0 40%;
    max-width: 40%;
    padding: 0 20px;
}

.contatti-main .col-md-7 {
    flex: 0 0 60%;
    max-width: 60%;
    padding: 0 20px;
}

/* Box Informazioni */
.info-box {
    background: var(--ferrufficio-light-bg);
    padding: 40px;
    border-radius: 12px;
    height: 100%;
}

.info-box h2 {
    font-size: 2.4rem;
    font-weight: 700;
    color: var(--ferrufficio-green);
    margin-bottom: 30px;
}

.info-item {
    display: flex;
    align-items: flex-start;
    margin-bottom: 25px;
    padding-bottom: 25px;
    border-bottom: 1px solid #e0e0e0;
}

.info-item:last-child {
    margin-bottom: 0;
    padding-bottom: 0;
    border-bottom: none;
}

.info-icon {
    flex-shrink: 0;
    width: 50px;
    height: 50px;
    background: var(--ferrufficio-green);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-right: 20px;
}

.info-icon svg {
    width: 24px;
    height: 24px;
    stroke: #ffffff;
}

.info-content h3 {
    font-size: 1.6rem;
    font-weight: 700;
    color: var(--ferrufficio-text);
    margin-bottom: 5px;
}

.info-content p {
    font-size: 1.6rem;
    color: var(--ferrufficio-text-light);
    line-height: 1.6;
    margin: 0;
}

.info-content a {
    color: var(--ferrufficio-orange);
    text-decoration: none;
    font-weight: 600;
}

.info-content a:hover {
    text-decoration: underline;
}

/* Box Form */
.form-box {
    background: var(--ferrufficio-white);
    padding: 40px;
    border: 1px solid #e0e0e0;
    border-radius: 12px;
}

.form-box h2 {
    font-size: 2.4rem;
    font-weight: 700;
    color: var(--ferrufficio-green);
    margin-bottom: 10px;
}

.form-intro {
    font-size: 1.6rem;
    color: var(--ferrufficio-text-light);
    margin-bottom: 30px;
}

/* Form Styles */
.contatti-form .form-row {
    display: flex;
    gap: 20px;
    margin-bottom: 0;
}

.contatti-form .form-group {
    margin-bottom: 20px;
}

.contatti-form .form-group.half {
    flex: 1;
}

.contatti-form label {
    display: block;
    font-size: 1.4rem;
    font-weight: 600;
    color: var(--ferrufficio-text);
    margin-bottom: 8px;
}

.contatti-form input[type="text"],
.contatti-form input[type="email"],
.contatti-form input[type="tel"],
.contatti-form select,
.contatti-form textarea {
    width: 100%;
    padding: 14px 16px;
    font-size: 1.6rem;
    border: 1px solid #d0d0d0;
    border-radius: 6px;
    background: #ffffff;
    transition: border-color 0.3s ease, box-shadow 0.3s ease;
}

.contatti-form input:focus,
.contatti-form select:focus,
.contatti-form textarea:focus {
    outline: none;
    border-color: var(--ferrufficio-green);
    box-shadow: 0 0 0 3px rgba(44, 95, 45, 0.1);
}

.contatti-form textarea {
    resize: vertical;
    min-height: 120px;
}

.contatti-form select {
    cursor: pointer;
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23333' d='M6 8L1 3h10z'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 16px center;
    padding: 0 40px 0 16px !important;
    color: #333333 !important;
    line-height: 50px !important;
    height: 50px !important;
    vertical-align: middle;
}

/* Fix select option text visibility */
.contatti-form select option {
    color: #333333 !important;
    background: #ffffff;
    padding: 10px;
    line-height: 1.5;
}

.contatti-form select option:first-child {
    color: #666666 !important;
}

/* Checkbox */
.checkbox-group {
    display: flex;
    align-items: flex-start;
    gap: 10px;
}

.checkbox-group input[type="checkbox"] {
    width: 20px;
    height: 20px;
    margin-top: 2px;
    cursor: pointer;
}

.checkbox-group label {
    font-size: 1.4rem;
    font-weight: 400 !important;
    color: var(--ferrufficio-text-light);
    margin-bottom: 0;
    cursor: pointer;
}

.checkbox-group a {
    color: var(--ferrufficio-orange);
    text-decoration: none;
}

.checkbox-group a:hover {
    text-decoration: underline;
}

/* Submit Button */
.btn-submit {
    display: inline-block;
    background-color: var(--ferrufficio-orange);
    color: #ffffff !important;
    padding: 16px 40px;
    font-size: 1.8rem;
    font-weight: 600;
    text-decoration: none;
    border: none;
    border-radius: 6px;
    cursor: pointer;
    transition: all 0.3s ease;
    margin-top: 10px;
}

.btn-submit:hover {
    background-color: var(--ferrufficio-orange-hover);
    transform: translateY(-2px);
    box-shadow: 0 4px 15px rgba(255, 101, 0, 0.4);
}

/* Sezione Mappa */
.contatti-mappa {
    background-color: var(--ferrufficio-light-bg);
}

.mappa-container {
    width: 100%;
    margin-left: calc(-50vw + 50%);
    margin-right: calc(-50vw + 50%);
    width: 100vw;
}

.mappa-container iframe {
    display: block;
    width: 100%;
    height: 400px;
    border: none;
}

/* CTA Finale Contatti */
.contatti-cta {
    padding: 80px 0;
    background-color: var(--ferrufficio-white);
    text-align: center;
}

.contatti-cta h2 {
    font-size: 3.2rem;
    font-weight: 700;
    color: var(--ferrufficio-text);
    margin-bottom: 20px;
}

.contatti-cta p {
    font-size: 1.8rem;
    color: var(--ferrufficio-text-light);
    line-height: 1.7;
    margin-bottom: 30px;
}

.contatti-cta a:not(.btn-primary-large) {
    color: var(--ferrufficio-orange);
    text-decoration: none;
    font-weight: 600;
}

.contatti-cta a:not(.btn-primary-large):hover {
    text-decoration: underline;
}

/* Responsive Contatti */
@media (max-width: 1024px) {
    .contatti-hero h1 {
        font-size: 3.6rem !important;
    }

    .info-box h2,
    .form-box h2 {
        font-size: 2.2rem;
    }
}

@media (max-width: 768px) {
    .contatti-main .col-md-5,
    .contatti-main .col-md-7 {
        flex: 0 0 100%;
        max-width: 100%;
        margin-bottom: 30px;
    }

    .contatti-form .form-row {
        flex-direction: column;
        gap: 0;
    }

    .contatti-hero {
        min-height: 350px !important;
    }

    .hero-overlay-contatti {
        min-height: 350px !important;
    }

    .contatti-hero h1 {
        font-size: 3rem !important;
    }

    .contatti-hero .hero-lead {
        font-size: 1.8rem !important;
    }

    .info-box,
    .form-box {
        padding: 30px 20px;
    }

    .contatti-cta h2 {
        font-size: 2.4rem;
    }

    .mappa-container iframe {
        height: 300px;
    }
}

/* ========================================
   FOOTER FERRUFFICIO - Compatto & Elegante
   ======================================== */

/* Nascondi il footer originale del tema */
.site-footer,
footer.site-footer,
#colophon,
.footer-widget-area,
.footer-widgets,
.site-info {
    display: none !important;
}

/* Nuovo Footer Ferrufficio */
.ferrufficio-footer {
    background-color: #1a1a1a;
    color: #ffffff;
    padding: 0;
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue", sans-serif;
    position: relative;
    z-index: 100;
}

.footer-main {
    display: flex;
    align-items: center;
    justify-content: space-between;
    max-width: 1400px;
    margin: 0 auto;
    padding: 18px 30px;
    flex-wrap: wrap;
    gap: 15px;
}

/* Logo e Brand */
.footer-brand {
    display: flex;
    align-items: center;
    gap: 12px;
}

.footer-brand img {
    height: 35px;
    width: auto;
}

.footer-brand-text {
    font-size: 1.3rem;
    color: #b0b0b0;
    line-height: 1.4;
}

.footer-brand-text strong {
    color: #ffffff;
    font-weight: 600;
}

/* Info Contatto */
.footer-contact {
    display: flex;
    align-items: center;
    gap: 30px;
    flex-wrap: wrap;
}

.footer-contact-item {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 1.4rem;
    color: #d0d0d0;
}

.footer-contact-item svg {
    width: 16px;
    height: 16px;
    stroke: var(--ferrufficio-orange);
    flex-shrink: 0;
}

.footer-contact-item a {
    color: #ffffff;
    text-decoration: none;
    transition: color 0.3s ease;
}

.footer-contact-item a:hover {
    color: var(--ferrufficio-orange);
}

/* Link Utili */
.footer-links {
    display: flex;
    align-items: center;
    gap: 25px;
    flex-wrap: wrap;
}

.footer-links a {
    font-size: 1.4rem;
    color: #d0d0d0;
    text-decoration: none;
    transition: color 0.3s ease;
    position: relative;
    font-weight: 400 !important;
}

.footer-links a:hover {
    color: var(--ferrufficio-orange);
}

.footer-links a::after {
    content: '';
    position: absolute;
    bottom: -2px;
    left: 0;
    width: 0;
    height: 1px;
    background: var(--ferrufficio-orange);
    transition: width 0.3s ease;
}

.footer-links a:hover::after {
    width: 100%;
}

/* Linea Copyright */
.footer-bottom {
    background-color: #111111;
    padding: 12px 30px;
    text-align: center;
}

.footer-copyright {
    font-size: 1.2rem;
    color: #888888;
    margin: 0;
}

.footer-copyright a {
    color: #aaaaaa;
    text-decoration: none;
    font-weight: 400 !important;
}

.footer-copyright a:hover {
    color: var(--ferrufficio-orange);
}

/* Responsive Footer */
@media (max-width: 1024px) {
    .footer-main {
        flex-direction: column;
        text-align: center;
        gap: 20px;
        padding: 25px 20px;
    }

    .footer-brand {
        flex-direction: column;
        gap: 8px;
    }

    .footer-contact {
        justify-content: center;
    }

    .footer-links {
        justify-content: center;
    }
}

@media (max-width: 600px) {
    .footer-contact {
        flex-direction: column;
        gap: 12px;
    }

    .footer-links {
        flex-direction: column;
        gap: 12px;
    }

    .footer-bottom {
        padding: 15px 15px 40px 15px !important;
        height: auto !important;
        min-height: auto !important;
    }

    .footer-copyright {
        font-size: 11px !important;
        line-height: 1.6 !important;
        word-wrap: break-word !important;
        overflow-wrap: break-word !important;
    }

    /* Nasconde paginazione in fondo su mobile (già presente in alto) */
    .columns-3 nav.woocommerce-pagination,
    .columns-4 nav.woocommerce-pagination,
    div.columns-3 > nav.woocommerce-pagination,
    div.columns-4 > nav.woocommerce-pagination {
        display: none !important;
    }
}

/* ========================================
   PAGINA GARANZIA E QUALITÀ (ID 89)
   ======================================== */

/* Fix layout pagina Garanzia */
.page-id-89 #primary.content-area,
.page-id-89 main.site-main {
    width: 100% !important;
    max-width: 100% !important;
    flex: 0 0 100% !important;
    float: none !important;
    margin: 0 !important;
    padding: 0 !important;
    border: none !important;
}

.page-id-89 #secondary.sidebar,
.page-id-89 aside.widget-area {
    display: none !important;
}

/* Nascondi banner blu titolo pagina */
.page-id-89 .gradient-wrapper.page-title,
.page-id-89 .gradient-wrapper,
.page-id-89 .page-header,
.page-id-89 .entry-header,
.page-id-89 .page-title-section,
.page-id-89 header.entry-header,
.page-id-89 .algflavor-page-header,
.page-id-89 .flavor-page-header,
.page-id-89 .woocommerce-products-header,
.page-id-89 h1.entry-title,
.page-id-89 .entry-title {
    display: none !important;
}

.page-id-89 .site-content,
.page-id-89 #content,
.page-id-89 .content-area,
.page-id-89 .site-main,
.page-id-89 .entry-content,
.page-id-89 .post-content,
.page-id-89 article {
    border: none !important;
    box-shadow: none !important;
    outline: none !important;
    max-width: 100% !important;
    width: 100% !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
}

.page-id-89 .site-content::before,
.page-id-89 .site-content::after,
.page-id-89 #primary::before,
.page-id-89 #primary::after,
.page-id-89 .entry-content::before,
.page-id-89 .entry-content::after,
.page-id-89 article::before,
.page-id-89 article::after,
.page-id-89 .hentry::before,
.page-id-89 .hentry::after {
    display: none !important;
    content: none !important;
    border: none !important;
}

/* Nasconde entry-footer (riga sopra il footer) */
.page-id-89 .entry-footer,
.page-id-89 footer.entry-footer,
.page-id-89 .post-navigation,
.page-id-89 .nav-links {
    display: none !important;
}

.page-id-89 .gradient-wrapper.page-title,
.page-id-89 .gradient-wrapper,
.page-id-89 .page-header,
.page-id-89 .entry-header,
.page-id-89 header.entry-header,
.page-id-89 h1.entry-title,
.page-id-89 .entry-title {
    display: none !important;
}

/* Container Garanzia */
.ferrufficio-garanzia {
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue", sans-serif;
    line-height: 1.6;
    color: var(--ferrufficio-text);
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    border: none !important;
    box-shadow: none !important;
}

/* Rimuovi bordi verticali - come page-id-22 */
.ferrufficio-garanzia section,
.ferrufficio-garanzia .container,
.ferrufficio-garanzia .row,
.ferrufficio-garanzia .col-md-6 {
    border-left: none !important;
    border-right: none !important;
}

.ferrufficio-garanzia .container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 20px;
}

/* Hero Garanzia */
.garanzia-hero {
    background-size: cover !important;
    background-position: center !important;
    background-repeat: no-repeat !important;
    min-height: 400px !important;
    display: flex !important;
    align-items: center !important;
    position: relative !important;
    margin-left: calc(-50vw + 50%) !important;
    margin-right: calc(-50vw + 50%) !important;
    width: 100vw !important;
    margin-top: -85px !important;
}

.hero-overlay-garanzia {
    background: linear-gradient(135deg, rgba(0, 0, 0, 0.7) 0%, rgba(0, 0, 0, 0.5) 100%) !important;
    width: 100% !important;
    min-height: 400px !important;
    display: flex !important;
    align-items: center !important;
    padding: 80px 0 !important;
}

.garanzia-hero .container {
    max-width: 1000px !important;
    text-align: center !important;
}

.garanzia-hero h1 {
    font-size: 4.8rem !important;
    font-weight: 700 !important;
    color: #ffffff !important;
    text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.5) !important;
    margin-bottom: 25px !important;
}

.garanzia-hero .hero-lead {
    font-size: 2rem !important;
    color: #ffffff !important;
    text-shadow: 1px 1px 3px rgba(0, 0, 0, 0.5) !important;
    max-width: 800px !important;
    margin: 0 auto !important;
    opacity: 0.95;
}

/* Intro Section */
.garanzia-intro-section {
    padding: 70px 0;
    background: var(--ferrufficio-white);
    text-align: center;
}

.intro-content {
    max-width: 800px;
    margin: 0 auto;
}

.intro-content h2 {
    font-size: 3.2rem;
    font-weight: 700;
    color: var(--ferrufficio-green);
    margin-bottom: 20px;
}

.intro-content p {
    font-size: 1.8rem;
    color: var(--ferrufficio-text-light);
    line-height: 1.8;
}

/* Grading Section */
.garanzia-grading {
    padding: 80px 0;
}

.bg-light-garanzia {
    background-color: var(--ferrufficio-light-bg);
}

.section-title {
    font-size: 3.2rem;
    font-weight: 700;
    color: var(--ferrufficio-text);
    text-align: center;
    margin-bottom: 15px;
}

.section-subtitle {
    font-size: 1.8rem;
    color: var(--ferrufficio-text-light);
    text-align: center;
    margin-bottom: 50px;
}

/* Grading Grid */
.grading-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 20px;
    max-width: 1100px;
    margin: 0 auto;
    padding: 0 15px;
}

.grade-card {
    background: var(--ferrufficio-white);
    border-radius: 12px;
    padding: 35px 25px;
    text-align: center;
    box-shadow: 0 5px 20px rgba(0, 0, 0, 0.08);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
    border-top: 4px solid;
}

.grade-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.12);
}

.grade-n { border-top-color: #2c5f2d; }
.grade-a { border-top-color: #4a90d9; }
.grade-b { border-top-color: #f5a623; }
.grade-c { border-top-color: #888888; }

.grade-badge {
    width: 60px;
    height: 60px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 2.8rem;
    font-weight: 700;
    color: #ffffff;
    margin: 0 auto 20px;
}

.grade-n .grade-badge { background: #2c5f2d; }
.grade-a .grade-badge { background: #4a90d9; }
.grade-b .grade-badge { background: #f5a623; }
.grade-c .grade-badge { background: #888888; }

.grade-card h3 {
    font-size: 2rem;
    font-weight: 700;
    color: var(--ferrufficio-text);
    margin-bottom: 12px;
}

.grade-desc {
    font-size: 1.5rem;
    color: var(--ferrufficio-text-light);
    line-height: 1.6;
    margin-bottom: 20px;
    min-height: 70px;
}

.grade-warranty {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding-top: 15px;
    border-top: 1px solid #e0e0e0;
}

.grade-warranty svg {
    width: 20px;
    height: 20px;
    stroke: var(--ferrufficio-green);
}

.grade-warranty span {
    font-size: 1.4rem;
    color: var(--ferrufficio-text);
}

.grade-warranty strong {
    color: var(--ferrufficio-green);
}

/* Copertura Section */
.garanzia-copertura {
    padding: 80px 0;
    background: var(--ferrufficio-white);
}

.garanzia-copertura .row {
    display: flex;
    flex-wrap: wrap;
    gap: 30px;
}

.garanzia-copertura .col-md-6 {
    flex: 1;
    min-width: 300px;
}

.copertura-box {
    padding: 35px;
    border-radius: 12px;
    height: 100%;
}

.copertura-si {
    background: linear-gradient(135deg, #e8f5e9 0%, #f1f8e9 100%);
    border: 1px solid #c8e6c9;
}

.copertura-no {
    background: linear-gradient(135deg, #ffebee 0%, #fce4ec 100%);
    border: 1px solid #ffcdd2;
}

.copertura-header {
    display: flex;
    align-items: center;
    gap: 15px;
    margin-bottom: 25px;
}

.copertura-header svg {
    width: 40px;
    height: 40px;
    flex-shrink: 0;
}

.copertura-si .copertura-header svg {
    stroke: var(--ferrufficio-green);
}

.copertura-no .copertura-header svg {
    stroke: #d32f2f;
}

.copertura-header h3 {
    font-size: 2.2rem;
    font-weight: 700;
    margin: 0;
}

.copertura-si .copertura-header h3 {
    color: var(--ferrufficio-green);
}

.copertura-no .copertura-header h3 {
    color: #c62828;
}

.copertura-box ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

.copertura-box li {
    font-size: 1.6rem;
    color: var(--ferrufficio-text);
    padding: 10px 0;
    padding-left: 30px;
    position: relative;
    border-bottom: 1px solid rgba(0,0,0,0.08);
}

.copertura-box li:last-child {
    border-bottom: none;
}

.copertura-si li::before {
    content: '✓';
    position: absolute;
    left: 0;
    color: var(--ferrufficio-green);
    font-weight: 700;
}

.copertura-no li::before {
    content: '✕';
    position: absolute;
    left: 0;
    color: #d32f2f;
    font-weight: 700;
}

/* Vantaggi Section */
.garanzia-vantaggi {
    padding: 80px 0;
}

.vantaggi-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 30px;
    margin-top: 50px;
}

.vantaggio-item {
    text-align: center;
    padding: 30px 20px;
}

.vantaggio-icon {
    width: 70px;
    height: 70px;
    background: var(--ferrufficio-green);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 20px;
}

.vantaggio-icon svg {
    width: 32px;
    height: 32px;
    stroke: #ffffff;
}

.vantaggio-item h4 {
    font-size: 1.8rem;
    font-weight: 700;
    color: var(--ferrufficio-text);
    margin-bottom: 10px;
}

.vantaggio-item p {
    font-size: 1.5rem;
    color: var(--ferrufficio-text-light);
    line-height: 1.6;
}

/* CTA Section */
.garanzia-cta {
    padding: 80px 0;
    background: var(--ferrufficio-white);
    text-align: center;
}

.garanzia-cta h2 {
    font-size: 3.2rem;
    font-weight: 700;
    color: var(--ferrufficio-text);
    margin-bottom: 15px;
}

.garanzia-cta p {
    font-size: 1.8rem;
    color: var(--ferrufficio-text-light);
    margin-bottom: 30px;
    max-width: 600px;
    margin-left: auto;
    margin-right: auto;
}

.garanzia-cta .cta-buttons {
    display: flex;
    justify-content: center;
    gap: 20px;
    flex-wrap: wrap;
}

.btn-cta-primary {
    display: inline-block;
    background: var(--ferrufficio-orange);
    color: #ffffff !important;
    padding: 16px 35px;
    font-size: 1.7rem;
    font-weight: 600;
    text-decoration: none;
    border-radius: 6px;
    transition: all 0.3s ease;
}

.btn-cta-primary:hover {
    background: var(--ferrufficio-orange-hover);
    transform: translateY(-2px);
}

.btn-cta-secondary {
    display: inline-block;
    background: transparent;
    color: var(--ferrufficio-green) !important;
    padding: 16px 35px;
    font-size: 1.7rem;
    font-weight: 600;
    text-decoration: none;
    border: 2px solid var(--ferrufficio-green) !important;
    border-top: 2px solid var(--ferrufficio-green) !important;
    border-bottom: 2px solid var(--ferrufficio-green) !important;
    border-left: 2px solid var(--ferrufficio-green) !important;
    border-right: 2px solid var(--ferrufficio-green) !important;
    border-radius: 6px;
    transition: all 0.3s ease;
}

.btn-cta-secondary:hover {
    background: var(--ferrufficio-green);
    color: #ffffff !important;
}

/* Responsive Garanzia */
@media (max-width: 1024px) {
    .grading-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .vantaggi-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .garanzia-hero h1 {
        font-size: 3.6rem !important;
    }
}

@media (max-width: 768px) {
    .grading-grid {
        grid-template-columns: 1fr;
        max-width: 400px;
        margin: 0 auto;
    }

    .vantaggi-grid {
        grid-template-columns: 1fr;
        max-width: 400px;
        margin: 0 auto;
    }

    .garanzia-copertura .col-md-6 {
        flex: 0 0 100%;
    }

    .garanzia-hero {
        min-height: 350px !important;
    }

    .hero-overlay-garanzia {
        min-height: 350px !important;
    }

    .garanzia-hero h1 {
        font-size: 3rem !important;
    }

    .garanzia-hero .hero-lead {
        font-size: 1.8rem !important;
    }

    .section-title {
        font-size: 2.6rem;
    }

    .intro-content h2 {
        font-size: 2.6rem;
    }

    .garanzia-cta h2 {
        font-size: 2.4rem;
    }

    .grade-desc {
        min-height: auto;
    }
}

/* ========================================
   PAGINA SHOP / NEGOZIO (page-id-5 + WooCommerce)
   ======================================== */

/* Fix layout pagina Shop */
.page-id-5 #primary.content-area,
.page-id-5 main.site-main,
.woocommerce-page #primary.content-area,
.woocommerce-page main.site-main {
    width: 100% !important;
    max-width: 100% !important;
    flex: 0 0 100% !important;
    float: none !important;
    margin: 0 !important;
    padding: 0 !important;
    border: none !important;
}

body.woocommerce-shop #secondary.sidebar,
body.woocommerce-shop aside.widget-area,
body.post-type-archive-product #secondary.sidebar,
body.post-type-archive-product aside.widget-area {
    display: none !important;
}

/* Nascondi banner blu/viola con titolo prodotto (prima del contenuto) */
body.woocommerce-shop .gradient-wrapper.page-title,
body.woocommerce-shop .gradient-wrapper,
body.woocommerce-shop .page-header,
body.post-type-archive-product .gradient-wrapper.page-title,
body.post-type-archive-product .gradient-wrapper,
body.post-type-archive-product .page-header,
.woocommerce-page .gradient-wrapper.page-title,
.woocommerce-page .gradient-wrapper,
body.woocommerce .gradient-wrapper.page-title,
body.woocommerce .gradient-wrapper,
/* Nascondi l'hero viola hardcoded nel tema - usiamo quello con immagine */
.ferrufficio-shop-hero {
    display: none !important;
}

/* Mostra l'header WooCommerce ma rimuovi il suo sfondo - USA CLASSI WOOCOMMERCE ARCHIVE */
body.woocommerce-shop .woocommerce-products-header,
body.post-type-archive-product .woocommerce-products-header,
body.woocommerce-shop header.woocommerce-products-header,
body.post-type-archive-product header.woocommerce-products-header {
    margin-top: -30px !important;
    display: block !important;
    background: none !important;
    background-image: none !important;
    padding: 0 !important;
    margin-bottom: 0 !important; margin-left: 0 !important; margin-right: 0 !important;
}

/* Override globale per WooCommerce breadcrumb sulla pagina shop */
body.woocommerce-shop .woocommerce-breadcrumb,
body.post-type-archive-product .woocommerce-breadcrumb {
    display: none !important;
}

/* Nascondi il titolo H1 che mostra nome prodotto */
body.woocommerce-shop .woocommerce-products-header__title,
body.woocommerce-shop h1.woocommerce-products-header__title,
body.post-type-archive-product .woocommerce-products-header__title,
body.post-type-archive-product h1.woocommerce-products-header__title,
.woocommerce-page h1.woocommerce-products-header__title {
    display: none !important;
}

body.woocommerce-shop .site-content,
body.woocommerce-shop #content,
body.woocommerce-shop .content-area,
body.woocommerce-shop .site-main,
body.woocommerce-shop .entry-content,
body.woocommerce-shop .post-content,
body.woocommerce-shop article,
body.post-type-archive-product .site-content,
body.post-type-archive-product #content,
body.post-type-archive-product .content-area,
body.post-type-archive-product .site-main,
body.post-type-archive-product .entry-content,
body.post-type-archive-product .post-content,
body.post-type-archive-product article {
    border: none !important;
    box-shadow: none !important;
    outline: none !important;
    max-width: 100% !important;
    width: 100% !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
}

/* Rimuovi offset sulla pagina Shop per avvicinare hero al menu */
body.woocommerce-shop .offset,
body.post-type-archive-product .offset {
    display: none !important;
    height: 0 !important;
    padding: 0 !important;
}

/* Hero Banner Shop */
.shop-hero-banner {
        margin-top: 20px !important;
    background-size: cover !important;
    background-position: center !important;
    background-repeat: no-repeat !important;
    min-height: 350px !important;
    display: flex !important;
    align-items: center !important;
    position: relative !important;
    margin-left: calc(-50vw + 50%) !important;
    margin-right: calc(-50vw + 50%) !important;
    width: 100vw !important;
    margin-top: 5px !important;
}

.shop-hero-overlay {
    background: linear-gradient(135deg, rgba(0, 0, 0, 0.6) 0%, rgba(0, 0, 0, 0.4) 100%) !important;
    width: 100% !important;
    min-height: 350px !important;
    display: flex !important;
    align-items: center !important;
    padding: 60px 0 !important;
}

.shop-hero-banner .container {
    max-width: 1000px !important;
    margin: 0 auto !important;
    padding: 0 30px !important;
    text-align: center !important;
}

.shop-hero-banner h1 {
    font-size: 4.2rem !important;
    font-weight: 700 !important;
    line-height: 1.2 !important;
    color: #ffffff !important;
    text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.5) !important;
    margin-bottom: 20px !important;
}

.shop-hero-banner .hero-lead {
    font-size: 1.9rem !important;
    line-height: 1.7 !important;
    color: #ffffff !important;
    text-shadow: 1px 1px 3px rgba(0, 0, 0, 0.5) !important;
    max-width: 800px !important;
    margin: 0 auto !important;
    opacity: 0.95;
}

/* Responsive Shop Hero */
@media (max-width: 768px) {
    .shop-hero-banner {
        margin-top: 20px !important;
        min-height: 280px !important;
    }

    .shop-hero-overlay {
        min-height: 280px !important;
    }

    .shop-hero-banner h1 {
        font-size: 2.8rem !important;
    }

    .shop-hero-banner .hero-lead {
        font-size: 1.6rem !important;
    }
}

/* ========================================
   PRIVACY POLICY PAGE (page-id-3)
   ======================================== */

/* Nascondi banda blu/teal */
body.page-id-3 .gradient-wrapper.page-title {
    display: none !important;
}

/* Rimuovi bordo del box */
body.page-id-3 article,
body.page-id-3 article .entry-content,
body.page-id-3 .site-main,
body.page-id-3 .content-area,
body.page-id-3 main {
    border: none !important;
    box-shadow: none !important;
    outline: none !important;
}

/* Aggiungi spazio sopra il contenuto per il titolo */
body.page-id-3 .post-content {
    padding-top: 15px !important;
}

/* ========================================
   SEZIONE CATEGORIE SHOP
   Stile griglia con miniature
   ======================================== */

.shop-categories-section {
    padding: 50px 0 !important;
    background: var(--ferrufficio-light-bg) !important;
}

.shop-categories-section .container {
    max-width: 1200px !important;
    margin: 0 auto !important;
    padding: 0 20px !important;
}

.shop-categories-section .section-title {
    text-align: center !important;
    font-size: 2.8rem !important;
    color: var(--ferrufficio-text) !important;
    margin-bottom: 40px !important;
    font-weight: 700 !important;
}

/* Griglia categorie WooCommerce */
.woocommerce ul.products.columns-4 {
    display: grid !important;
    grid-template-columns: repeat(4, 1fr) !important;
    gap: 25px !important;
    padding: 0 !important;
    margin: 0 !important;
    list-style: none !important;
}

/* Singola card categoria */
body.woocommerce-shop ul.products li.product-category,
body.post-type-archive-product ul.products li.product-category {
    background: #fff !important;
    border-radius: 12px !important;
    overflow: hidden !important;
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.08) !important;
    transition: transform 0.3s ease, box-shadow 0.3s ease !important;
    margin: 0 !important;
    padding: 0 !important;
}

body.woocommerce-shop ul.products li.product-category:hover,
body.post-type-archive-product ul.products li.product-category:hover {
    transform: translateY(-8px) !important;
    box-shadow: 0 12px 30px rgba(0, 0, 0, 0.15) !important;
}

/* Link categoria */
body.woocommerce-shop ul.products li.product-category a,
body.post-type-archive-product ul.products li.product-category a {
    display: block !important;
    text-decoration: none !important;
    color: inherit !important;
}

/* Immagine categoria */
body.woocommerce-shop ul.products li.product-category a img,
body.post-type-archive-product ul.products li.product-category a img {
    width: 100% !important;
    height: 180px !important;
    object-fit: cover !important;
    display: block !important;
}

/* Nome categoria */
body.woocommerce-shop ul.products li.product-category h2.woocommerce-loop-category__title,
body.post-type-archive-product ul.products li.product-category h2.woocommerce-loop-category__title {
    padding: 18px 15px !important;
    margin: 0 !important;
    font-size: 1.6rem !important;
    font-weight: 600 !important;
    color: var(--ferrufficio-text) !important;
    text-align: center !important;
    background: #fff !important;
}

/* Conteggio prodotti */
body.woocommerce-shop ul.products li.product-category .count,
body.post-type-archive-product ul.products li.product-category .count {
    display: block !important;
    font-size: 1.2rem !important;
    color: var(--ferrufficio-text-light) !important;
    margin-top: 5px !important;
}

/* Responsive categorie */
@media (max-width: 992px) {
    .woocommerce ul.products.columns-4 {
        grid-template-columns: repeat(3, 1fr) !important;
    }
}

@media (max-width: 768px) {
    .woocommerce ul.products.columns-4 {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 15px !important;
    }

    .shop-categories-section .section-title {
        font-size: 2.2rem !important;
    }

    body.woocommerce-shop ul.products li.product-category a img,
    body.post-type-archive-product ul.products li.product-category a img {
        height: 140px !important;
    }
}

@media (max-width: 480px) {
    .woocommerce ul.products.columns-4 {
        grid-template-columns: 1fr !important;
    }
}

/* ========================================
   GRIGLIA CATEGORIE FERRUFFICIO (via PHP hook)
   ======================================== */

.ferrufficio-categories-grid {
    padding: 25px 0 !important;
    background: transparent !important;
    margin-bottom: 25px !important;
    max-width: 100% !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    border-radius: 0 !important;
}

.ferrufficio-categories-grid .categories-title {
    text-align: center !important;
    font-size: 2rem !important;
    color: var(--ferrufficio-text) !important;
    margin-bottom: 20px !important;
    font-weight: 700 !important;
}

.ferrufficio-categories-grid .categories-container {
    display: flex !important;
    flex-wrap: wrap !important;
    justify-content: space-between !important;
    gap: 0 !important;
    max-width: 1143px !important;
    margin: 0 auto !important;
    padding: 0 !important;
    position: relative !important;
    left: -35.5px !important;
}

.ferrufficio-categories-grid .category-card {
    background: #fff !important;
    border-radius: 10px !important;
    overflow: hidden !important;
    box-shadow: 0 3px 10px rgba(0, 0, 0, 0.08) !important;
    transition: transform 0.3s ease, box-shadow 0.3s ease !important;
    text-decoration: none !important;
    display: block !important;
    width: 115px !important;
    min-width: 100px !important;
    max-width: 115px !important;
}

.ferrufficio-categories-grid .category-card:hover {
    transform: translateY(-5px) !important;
    box-shadow: 0 8px 20px rgba(0, 0, 0, 0.15) !important;
}

.ferrufficio-categories-grid .category-image {
    width: 100% !important;
    height: 80px !important;
    background-size: cover !important;
    background-position: center !important;
    background-repeat: no-repeat !important;
}

.ferrufficio-categories-grid .category-info {
    padding: 8px 5px !important;
    text-align: center !important;
}

.ferrufficio-categories-grid .category-info h3 {
    margin: 0 0 2px 0 !important;
    font-size: 1.1rem !important;
    font-weight: 600 !important;
    color: var(--ferrufficio-text) !important;
    line-height: 1.2 !important;
}

.ferrufficio-categories-grid .category-info .count {
    font-size: 0.95rem !important;
    color: var(--ferrufficio-text-light) !important;
}

/* Responsive griglia categorie */
@media (max-width: 1200px) {
    .ferrufficio-categories-grid .category-card {
        width: calc(20% - 12px) !important;
        max-width: 160px !important;
    }
}

@media (max-width: 768px) {
    .ferrufficio-categories-grid .category-card {
        width: calc(33.33% - 10px) !important;
        max-width: none !important;
        min-width: unset !important;
    }

    .ferrufficio-categories-grid .categories-title {
        font-size: 1.5rem !important;
    }

    .ferrufficio-categories-grid .category-image {
        height: 85px !important;
    }

    .ferrufficio-categories-grid .category-info h3 {
        font-size: 0.9rem !important;
    }

    .ferrufficio-categories-grid .category-info .count {
        font-size: 0.8rem !important;
    }
}

@media (max-width: 480px) {
    .ferrufficio-categories-grid {
        padding: 20px 10px !important;
    }

    .ferrufficio-categories-grid .categories-container {
        gap: 10px !important;
    }

    .ferrufficio-categories-grid .category-card {
        width: calc(33.33% - 8px) !important;
        min-width: 95px !important;
    }

    .ferrufficio-categories-grid .categories-title {
        font-size: 1.3rem !important;
        margin-bottom: 15px !important;
    }

    .ferrufficio-categories-grid .category-image {
        height: 75px !important;
    }

    .ferrufficio-categories-grid .category-info {
        padding: 6px 4px !important;
    }

    .ferrufficio-categories-grid .category-info h3 {
        font-size: 0.8rem !important;
        font-weight: 600 !important;
    }

    .ferrufficio-categories-grid .category-info .count {
        font-size: 0.7rem !important;
    }
}

/* ========================================
   GRIGLIA CATEGORIE SU PAGINE CATEGORIA
   (Evidenzia categoria attiva)
   ======================================== */

.ferrufficio-category-page {
    padding-top: 15px !important;
}

.ferrufficio-categories-grid .category-card.active {
    border: 3px solid var(--ferrufficio-orange) !important;
    transform: translateY(-3px) !important;
    box-shadow: 0 8px 20px rgba(255, 102, 0, 0.25) !important;
}

.ferrufficio-categories-grid .category-card.active .category-info h3 {
    color: var(--ferrufficio-orange) !important;
}

/* ========================================
   FIX CARD PRODOTTI - BORDI COMPLETI
   Tema Algori Shop - classi specifiche
   ======================================== */

/* Card prodotto - Algori Shop theme classes */
.algori-shop-woocommerce-item,
.isotope-item.product,
li.item.product,
li.product.type-product,
body.woocommerce ul.products li.product,
body.woocommerce-page ul.products li.product,
.woocommerce ul.products li.product:not(.product-category),
ul.products li.product {
    background: #fff !important;
    border: 2px solid #e0e0e0 !important;
    border-radius: 12px !important;
    overflow: hidden !important;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08) !important;
    transition: transform 0.3s ease, box-shadow 0.3s ease, border-color 0.3s ease !important;
    padding: 0 !important;
    margin-bottom: 20px !important;
    display: flex !important;
    flex-direction: column !important;
}

.algori-shop-woocommerce-item:hover,
.isotope-item.product:hover,
li.item.product:hover,
li.product.type-product:hover,
body.woocommerce ul.products li.product:hover,
body.woocommerce-page ul.products li.product:hover,
.woocommerce ul.products li.product:not(.product-category):hover,
ul.products li.product:hover {
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.12) !important;
    border-color: var(--ferrufficio-orange) !important;
}

/* Contenitore immagine prodotto */
.algori-shop-woocommerce-item figure,
.isotope-item.product figure,
li.item.product figure,
body.woocommerce ul.products li.product figure,
body.woocommerce-page ul.products li.product figure,
ul.products li.product figure {
    display: block !important;
    overflow: hidden !important;
    background: #fff !important;
    margin: 0 !important;
    padding: 0 !important;
}

/* Wrapper link immagine */
.algori-shop-woocommerce-item figure > a,
.isotope-item.product figure > a,
li.item.product figure > a,
body.woocommerce ul.products li.product figure > a,
body.woocommerce-page ul.products li.product figure > a,
ul.products li.product figure > a {
    display: block !important;
    padding: 10px !important;
    background: #fff !important;
}

/* Immagine prodotto - altezza fissa per uniformità */
.algori-shop-woocommerce-item img,
.isotope-item.product img,
li.item.product img,
body.woocommerce ul.products li.product img,
body.woocommerce-page ul.products li.product img,
ul.products li.product img {
    width: 100% !important;
    height: 200px !important;
    object-fit: contain !important;
    display: block !important;
    margin: 0 auto !important;
    padding: 0 !important;
    box-sizing: border-box !important;
    background: #fff !important;
}

/* Info prodotto container */
body.woocommerce ul.products li.product > div,
body.woocommerce-page ul.products li.product > div,
ul.products li.product > div {
    padding: 0 15px 15px !important;
    flex-grow: 1 !important;
    display: flex !important;
    flex-direction: column !important;
}

/* Titolo prodotto - Stile Storefront */
body.woocommerce ul.products li.product .woocommerce-loop-product__title,
body.woocommerce ul.products li.product h2.woocommerce-loop-product__title,
body.woocommerce ul.products li.product h3,
body.woocommerce-page ul.products li.product .woocommerce-loop-product__title,
ul.products li.product .woocommerce-loop-product__title,
ul.products li.product h3 {
    padding: 10px 15px 5px !important;
    margin: 0 !important;
    font-size: 16px !important;
    color: #333333 !important;
    line-height: 1.2 !important;
    min-height: 60px !important;
    display: -webkit-box !important;
    -webkit-line-clamp: 3 !important;
    -webkit-box-orient: vertical !important;
    overflow: hidden !important;
    text-align: center !important;
}

/* Link dentro i titoli prodotto - stessi stili del titolo */
body.woocommerce ul.products li.product h3 a,
body.woocommerce-page ul.products li.product h3 a,
ul.products li.product h3 a,
ul.products li.product .woocommerce-loop-product__title a,
li.algori-shop-woocommerce-item h3,
li.algori-shop-woocommerce-item h3 a,
li.product.algori-shop-woocommerce-item h3 a,
.algori-shop-woocommerce-item h3 a {
    font-size: 16px !important;
    color: #333333 !important;
    line-height: 1.2 !important;
    text-decoration: none !important;
}

/* Prezzo prodotto */
body.woocommerce ul.products li.product .price,
body.woocommerce-page ul.products li.product .price,
ul.products li.product .price,
li.algori-shop-woocommerce-item .price,
li.algori-shop-woocommerce-item .price .amount,
li.algori-shop-woocommerce-item .price bdi,
li.product .price .woocommerce-Price-amount,
li.product .price .woocommerce-Price-amount bdi {
    padding: 5px 15px 10px !important;
    margin: 0 !important;
    font-size: 16px !important;
    color: var(--ferrufficio-orange) !important;
    text-align: center !important;
}

/* Pulsante aggiungi al carrello - Stile Storefront */
body.woocommerce ul.products li.product .button,
body.woocommerce ul.products li.product .add_to_cart_button,
body.woocommerce ul.products li.product .btn,
body.woocommerce ul.products li.product button.btn,
body.woocommerce-page ul.products li.product .button,
body.woocommerce-page ul.products li.product .btn,
ul.products li.product .button,
ul.products li.product .add_to_cart_button,
ul.products li.product .btn,
ul.products li.product button.add_to_cart_button,
.woocommerce ul.products li.product a.button,
.woocommerce ul.products li.product button.button,
li.algori-shop-woocommerce-item .add_to_cart_button,
li.algori-shop-woocommerce-item button.button,
li.algori-shop-woocommerce-item .button,
li.algori-shop-woocommerce-item .btn,
li.algori-shop-woocommerce-item .btn.btn-block,
li.product .btn.add_to_cart_button {
    margin: auto 15px 15px !important;
    padding: 10px 15px !important;
    background-color: #FF6600 !important;
    color: #fff !important;
    border: none !important;
    border-radius: 4px !important;
    font-weight: 600 !important;
    text-transform: none !important;
    font-size: 14px !important;
    cursor: pointer !important;
    transition: background-color 0.3s ease !important;
    display: block !important;
    text-align: center !important;
    text-decoration: none !important;
    width: calc(100% - 30px) !important;
}

body.woocommerce ul.products li.product .button:hover,
body.woocommerce ul.products li.product .add_to_cart_button:hover,
body.woocommerce ul.products li.product .btn:hover,
body.woocommerce-page ul.products li.product .button:hover,
body.woocommerce-page ul.products li.product .btn:hover,
ul.products li.product .button:hover,
ul.products li.product .add_to_cart_button:hover,
ul.products li.product .btn:hover {
    background-color: #e55a00 !important;
}

/* Responsive product cards */
@media (max-width: 768px) {
    body.woocommerce ul.products li.product img,
    body.woocommerce-page ul.products li.product img,
    ul.products li.product img {
        height: 150px !important;
    }

    body.woocommerce ul.products li.product .woocommerce-loop-product__title,
    ul.products li.product .woocommerce-loop-product__title,
    ul.products li.product h3 {
        font-size: 1.2rem !important;
        min-height: 40px !important;
    }
}

/* ===========================================
   PRIVACY POLICY - Impaginazione
   =========================================== */
body.page-id-3 article {
    max-width: 800px !important;
    margin: 0 auto !important;
    padding: 30px 40px !important;
    background: #fff !important;
}

body.page-id-3 h1 {
    font-size: 28px !important;
    color: #2c2d33 !important;
    margin-bottom: 30px !important;
    padding-bottom: 15px !important;
    border-bottom: 2px solid #2c2d33 !important;
}

body.page-id-3 h2 {
    font-size: 18px !important;
    color: #2c2d33 !important;
    margin-top: 30px !important;
    margin-bottom: 12px !important;
    padding-bottom: 8px !important;
    border-bottom: 1px solid #e0e0e0 !important;
}

body.page-id-3 p {
    font-size: 15px !important;
    line-height: 1.7 !important;
    color: #444 !important;
    margin-bottom: 15px !important;
    text-align: justify !important;
}

body.page-id-3 ul {
    margin: 15px 0 20px 25px !important;
    padding: 0 !important;
}

body.page-id-3 li {
    font-size: 15px !important;
    line-height: 1.6 !important;
    color: #444 !important;
    margin-bottom: 8px !important;
    padding-left: 5px !important;
}

body.page-id-3 strong {
    color: #2c2d33 !important;
}

body.page-id-3 article a {
    color: var(--ferrufficio-orange) !important;
}

body.page-id-3 article a:hover {
    text-decoration: underline !important;
}

body.page-id-3 em {
    color: #666 !important;
    font-size: 14px !important;
}

/* ===========================================
   BREADCRUMB - Shop & Category Pages
   =========================================== */

/* Breadcrumb styling */
.ferrufficio-breadcrumb {
    display: block !important;
    font-size: 13px !important;
    color: #666 !important;
    margin: 5px 0 15px 0 !important;
    padding: 0 !important;
}

.ferrufficio-breadcrumb a {
    color: var(--ferrufficio-orange) !important;
    text-decoration: none !important;
}

.ferrufficio-breadcrumb a:hover {
    text-decoration: underline !important;
}

.ferrufficio-breadcrumb span {
    color: #666 !important;
}

/* ===========================================
   FILTER BAR - Allineamento con griglia prodotti
   =========================================== */
.ferrufficio-filter-bar {
    max-width: 1143px !important;
    width: 1143px !important;
    margin-left: auto !important;
    margin-right: auto !important;
    position: relative !important;
    left: -37.5px !important;
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    padding: 0 !important;
}

/* ===========================================
   SHOP PAGE - Ordering & Results on same line
   =========================================== */

/* Container for ordering and result count */
body.woocommerce-shop .woocommerce-ordering,
body.post-type-archive-product .woocommerce-ordering,
body.tax-product_cat .woocommerce-ordering {
    display: inline-block !important;
    float: none !important;
    vertical-align: middle !important;
    margin-right: 15px !important;
}

body.woocommerce-shop .woocommerce-result-count,
body.post-type-archive-product .woocommerce-result-count,
body.tax-product_cat .woocommerce-result-count {
    display: inline-block !important;
    float: none !important;
    vertical-align: middle !important;
    font-size: 14px !important;
    color: #666 !important;
}

/* Pagination - small style, aligned right */
body.woocommerce-shop .woocommerce-pagination,
body.post-type-archive-product .woocommerce-pagination,
body.tax-product_cat .woocommerce-pagination {
    display: inline-flex !important;
    float: none !important;
    margin: 0 !important;
    padding: 0 !important;
    margin-left: auto !important;
}

body.woocommerce-shop .woocommerce-pagination ul,
body.post-type-archive-product .woocommerce-pagination ul,
body.tax-product_cat .woocommerce-pagination ul {
    display: flex !important;
    list-style: none !important;
    margin: 0 !important;
    padding: 0 !important;
    gap: 5px !important;
    border: none !important;
}

body.woocommerce-shop .woocommerce-pagination ul li,
body.post-type-archive-product .woocommerce-pagination ul li,
body.tax-product_cat .woocommerce-pagination ul li {
    margin: 0 !important;
    padding: 0 !important;
    border: none !important;
}

body.woocommerce-shop .woocommerce-pagination ul li span,
body.woocommerce-shop .woocommerce-pagination ul li a,
body.post-type-archive-product .woocommerce-pagination ul li span,
body.post-type-archive-product .woocommerce-pagination ul li a,
body.tax-product_cat .woocommerce-pagination ul li span,
body.tax-product_cat .woocommerce-pagination ul li a {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-width: 28px !important;
    height: 28px !important;
    padding: 0 8px !important;
    font-size: 13px !important;
    text-decoration: none !important;
    color: #666 !important;
    background: #fff !important;
    border: 1px solid #ddd !important;
    border-radius: 3px !important;
}

body.woocommerce-shop .woocommerce-pagination ul li span.current,
body.post-type-archive-product .woocommerce-pagination ul li span.current,
body.tax-product_cat .woocommerce-pagination ul li span.current {
    color: #333 !important;
    border-color: #333 !important;
}

body.woocommerce-shop .woocommerce-pagination ul li a:hover,
body.post-type-archive-product .woocommerce-pagination ul li a:hover,
body.tax-product_cat .woocommerce-pagination ul li a:hover {
    color: #333 !important;
    border-color: #999 !important;
}

/* Bottom pagination - same style, positioned at end of products */
.woocommerce-pagination-bottom {
    margin-top: 30px !important;
    margin-bottom: 30px !important;
    padding-right: 65px !important;
    display: flex !important;
    justify-content: flex-end !important;
}

/* ========================================
   RIMOZIONE OVERLAY AZZURRO HOVER PRODOTTI
   Mantiene solo lo zoom immagine
   ======================================== */

/* Nasconde completamente l'overlay azzurro al hover */
.icon-overlay a .icn-more,
.icon-overlay a:hover .icn-more {
    display: none !important;
    opacity: 0 !important;
    visibility: hidden !important;
}

/* Nasconde anche l'icona lente dentro l'overlay */
.icon-overlay a .icn-more:before,
.icon-overlay a:hover .icn-more:before {
    display: none !important;
}

/* ========================================
   FIX MOBILE - Menu Hamburger e Filter Bar
   ======================================== */
@media (max-width: 768px) {
    /* FIX 1: Menu hamburger - posizione e dimensioni corrette */
    body .navbar.basic .navbar-collapse.in,
    body .navbar.basic .main-navigation.navbar-collapse.in,
    body #site-navigation.navbar-collapse.in,
    body .main-navigation.navbar-collapse.in,
    body .navbar-collapse.pull-right.in,
    body #site-navigation.pull-right.in,
    .navbar-collapse.in,
    #site-navigation.in {
        position: absolute !important;
        top: 70px !important;
        left: 0 !important;
        right: 0 !important;
        bottom: auto !important;
        height: auto !important;
        max-height: none !important;
        min-height: 0 !important;
        width: 100% !important;
        float: none !important;
        overflow: visible !important;
        background: #fff !important;
        box-shadow: 0 4px 12px rgba(0,0,0,0.15) !important;
        z-index: 9999 !important;
        padding: 0 !important;
        margin: 0 !important;
    }

    /* Navbar-nav lista delle voci */
    body .navbar.basic .navbar-collapse.in .navbar-nav,
    body #site-navigation.navbar-collapse.in .navbar-nav,
    .navbar-collapse.in .navbar-nav,
    #site-navigation.in .navbar-nav {
        display: block !important;
        width: 100% !important;
        padding: 0 !important;
        margin: 0 !important;
        float: none !important;
    }

    /* Voci menu a tutta larghezza */
    .navbar-collapse.in .navbar-nav > li,
    #site-navigation.in .navbar-nav > li {
        display: block !important;
        width: 100% !important;
        float: none !important;
        border-bottom: 1px solid #eee !important;
    }

    .navbar-collapse.in .navbar-nav > li:last-child,
    #site-navigation.in .navbar-nav > li:last-child {
        border-bottom: none !important;
    }

    /* Link menu con padding e larghezza completa */
    .navbar-collapse.in .navbar-nav > li > a,
    #site-navigation.in .navbar-nav > li > a {
        display: block !important;
        width: 100% !important;
        padding: 15px 20px !important;
        font-size: 16px !important;
        color: #333 !important;
        text-align: left !important;
        text-decoration: none !important;
    }

    .navbar-collapse.in .navbar-nav > li > a:hover,
    #site-navigation.in .navbar-nav > li > a:hover {
        background: #f8f9fa !important;
        color: #FF6600 !important;
    }

    /* FIX 2: Filter bar shop/categorie - layout verticale su mobile */
    .ferrufficio-filter-bar {
        flex-direction: column !important;
        align-items: flex-start !important;
        padding-right: 0 !important;
        gap: 10px !important;
    }

    /* Ordinamento e risultati su righe separate */
    .ferrufficio-filter-bar .woocommerce-ordering {
        width: 100% !important;
        margin: 0 !important;
    }

    .ferrufficio-filter-bar .woocommerce-ordering select {
        width: 100% !important;
        max-width: 100% !important;
    }

    .ferrufficio-filter-bar .woocommerce-result-count {
        margin: 0 !important;
        font-size: 13px !important;
    }

    /* Paginazione sotto, centrata */
    .ferrufficio-filter-bar .woocommerce-pagination {
        width: 100% !important;
        justify-content: flex-start !important;
        margin-left: 0 !important;
        margin-top: 5px !important;
        position: static !important;
        top: auto !important;
    }

    /* Breadcrumb mobile - wrap text */
    .ferrufficio-breadcrumb {
        font-size: 12px !important;
        line-height: 1.4 !important;
        word-wrap: break-word !important;
    }

    /* Titolo pagina più piccolo su mobile */
    .ferrufficio-page-title {
        font-size: 24px !important;
    }

    /* Descrizione categoria più piccola */
    .ferrufficio-page-description {
        font-size: 14px !important;
        font-weight: 400 !important;
    }
}
    }
}

/* ========================================
   PAGINE LOCALITA' - MINI HERO BANNER
   Vigevano, Novara, Mortara, Abbiategrasso, Cassolnovo
   ======================================== */

/* Nascondi banner blu gradient per le pagine località */
body.page-id-920 .gradient-wrapper.page-title,
body.page-id-920 .gradient-wrapper,
body.page-id-921 .gradient-wrapper.page-title,
body.page-id-921 .gradient-wrapper,
body.page-id-922 .gradient-wrapper.page-title,
body.page-id-922 .gradient-wrapper,
body.page-id-923 .gradient-wrapper.page-title,
body.page-id-923 .gradient-wrapper,
body.page-id-924 .gradient-wrapper.page-title,
body.page-id-924 .gradient-wrapper {
    display: none !important;
}

/* Mini Hero Banner per pagine località */
.localita-mini-hero {
    background-image: url('/wp-content/uploads/2025/12/categories/cat-ricambi-scaled.jpg') !important;
    background-size: cover !important;
    background-position: center center !important;
    min-height: 180px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    position: relative !important;
    margin-left: calc(-50vw + 50%) !important;
    margin-right: calc(-50vw + 50%) !important;
    width: 100vw !important;
    margin-top: -30px !important;
    margin-bottom: 40px !important;
}

/* Overlay scuro per leggibilità testo */
.localita-mini-hero::before {
    content: '' !important;
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    background: linear-gradient(135deg, rgba(0, 0, 0, 0.5) 0%, rgba(0, 0, 0, 0.6) 100%) !important;
    z-index: 1 !important;
}

/* Contenitore titolo centrato */
.localita-mini-hero .hero-content {
    position: relative !important;
    z-index: 2 !important;
    text-align: center !important;
    padding: 20px !important;
}

/* Titolo H1 nel mini hero */
.localita-mini-hero h1 {
    font-family: 'Source Sans Pro', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif !important;
    font-size: 2.4rem !important;
    font-weight: 600 !important;
    color: #ffffff !important;
    text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.5) !important;
    margin: 0 !important;
    padding: 0 !important;
    line-height: 1.2 !important;
}

/* Contenuto pagina località */
.localita-content {
    font-family: 'Source Sans Pro', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif !important;
    max-width: 1100px !important;
    margin: 0 auto !important;
    padding: 0 20px 60px !important;
    color: #333333 !important;
    line-height: 1.7 !important;
}

.localita-content h2 {
    font-family: 'Source Sans Pro', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif !important;
    font-size: 2.4rem !important;
    font-weight: 600 !important;
    color: #333333 !important;
    margin: 40px 0 20px !important;
    padding-bottom: 10px !important;
    border-bottom: 2px solid var(--ferrufficio-orange, #FF6600) !important;
}

.localita-content h3 {
    font-family: 'Source Sans Pro', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif !important;
    font-size: 1.8rem !important;
    font-weight: 600 !important;
    color: #333333 !important;
    margin: 30px 0 15px !important;
}

.localita-content p {
    font-family: 'Source Sans Pro', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif !important;
    font-size: 1.25rem !important;
    color: #555555 !important;
    margin-bottom: 15px !important;
    line-height: 1.7 !important;
}

.localita-content ul {
    font-family: 'Source Sans Pro', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif !important;
    margin: 15px 0 25px 20px !important;
    padding: 0 !important;
}

.localita-content ul li {
    font-size: 1.25rem !important;
    color: #555555 !important;
    margin-bottom: 10px !important;
    line-height: 1.6 !important;
}

.localita-content strong {
    color: #333333 !important;
    font-weight: 600 !important;
}

/* CTA Button località */
.localita-cta {
    display: inline-block !important;
    background: var(--ferrufficio-orange, #FF6600) !important;
    color: #ffffff !important;
    padding: 14px 35px !important;
    font-size: 1.1rem !important;
    font-weight: 600 !important;
    text-decoration: none !important;
    border-radius: 6px !important;
    transition: all 0.3s ease !important;
    margin-top: 20px !important;
}

.localita-cta:hover {
    background: var(--ferrufficio-orange-hover, #e55a00) !important;
    color: #ffffff !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 4px 15px rgba(255, 102, 0, 0.3) !important;
}

/* Sezione contatti località */
.localita-contatti {
    background: #f8f9fa !important;
    padding: 30px !important;
    border-radius: 10px !important;
    margin: 40px 0 !important;
}

.localita-contatti h3 {
    margin-top: 0 !important;
    border-bottom: none !important;
}

/* Mappa Google iframe */
.localita-content iframe {
    max-width: 100% !important;
    border-radius: 10px !important;
    margin: 20px 0 !important;
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1) !important;
}

/* Responsive mini hero località */
@media (max-width: 768px) {
    .localita-mini-hero {
        min-height: 140px !important;
        margin-top: -20px !important;
    }

    .localita-mini-hero h1 {
        font-size: 1.8rem !important;
    }

    .localita-content {
        padding: 0 15px 40px !important;
    }

    .localita-content h2 {
        font-size: 1.5rem !important;
    }

    .localita-content h3 {
        font-size: 1.2rem !important;
    }
}

/* ========================================
   CARRELLO - FIX LAYOUT E NASCONDI DESCRIZIONE
   ======================================== */

/* Nascondi descrizione prodotto nel carrello (WooCommerce Blocks) */
.wc-block-cart-items__row p,
.wc-block-cart-item__product p,
.wc-block-components-product-name + p,
.wc-block-cart-item__wrap p,
table.wc-block-cart-items td p,
.wc-block-cart-items p:not(.wc-block-components-product-name),
.woocommerce-cart-form .product-name p,
.woocommerce table.cart .product-name p,
.cart_item .product-name p {
    display: none !important;
}

/* Contenitore quantità compatto con layout inline */
.wc-block-components-quantity-selector {
    display: inline-flex !important;
    flex-direction: row !important;
    align-items: center !important;
    max-width: 100px !important;
    border: 1px solid #ddd !important;
    border-radius: 4px !important;
    overflow: hidden !important;
}

/* Input quantità più piccolo */
.wc-block-components-quantity-selector__input {
    width: 36px !important;
    max-width: 36px !important;
    min-width: 36px !important;
    padding: 4px 2px !important;
    font-size: 14px !important;
    text-align: center !important;
    border: none !important;
    border-left: 1px solid #ddd !important;
    border-right: 1px solid #ddd !important;
    -moz-appearance: textfield !important;
    order: 2 !important;
}

/* Nascondi frecce input number */
.wc-block-components-quantity-selector__input::-webkit-outer-spin-button,
.wc-block-components-quantity-selector__input::-webkit-inner-spin-button {
    -webkit-appearance: none !important;
    margin: 0 !important;
}

/* Bottone meno a sinistra */
.wc-block-components-quantity-selector__button--minus {
    order: 1 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 28px !important;
    min-width: 28px !important;
    height: 32px !important;
    padding: 0 !important;
    border: none !important;
    background: #f5f5f5 !important;
    color: #333 !important;
    font-size: 16px !important;
    cursor: pointer !important;
}

/* Bottone più a destra */
.wc-block-components-quantity-selector__button--plus {
    order: 3 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 28px !important;
    min-width: 28px !important;
    height: 32px !important;
    padding: 0 !important;
    border: none !important;
    background: #f5f5f5 !important;
    color: #333 !important;
    font-size: 16px !important;
    cursor: pointer !important;
}

/* Hover sui bottoni */
.wc-block-components-quantity-selector__button:hover:not(:disabled) {
    background: #e0e0e0 !important;
}

/* Bottoni disabilitati */
.wc-block-components-quantity-selector__button:disabled {
    opacity: 0.4 !important;
    cursor: not-allowed !important;
}

/* Bottone rimuovi articolo - visibile */
.wc-block-cart-item__remove-link,
button[aria-label*="Rimuovi"]:not(.wc-block-components-quantity-selector__button) {
    display: inline-block !important;
    visibility: visible !important;
    opacity: 1 !important;
    color: #dc3545 !important;
    font-size: 13px !important;
    margin-top: 8px !important;
    background: none !important;
    border: none !important;
    cursor: pointer !important;
    text-decoration: underline !important;
}

/* ========================================
   ZONE SERVITE - FIX MOBILE RESPONSIVE
   ======================================== */

/* Contenitore badge zone */
.zone-badges {
    display: flex !important;
    flex-wrap: wrap !important;
    justify-content: center !important;
    gap: 12px !important;
    padding: 0 15px !important;
}

/* Badge zone - stile base */
.zone-badges a {
    display: inline-block !important;
    margin: 5px !important;
    white-space: nowrap !important;
    text-align: center !important;
}

/* Mobile: layout verticale per tutti gli smartphone */
@media (max-width: 600px) {
    .zone-badges {
        flex-direction: column !important;
        align-items: center !important;
        gap: 10px !important;
        padding: 0 10px !important;
    }

    .zone-badges a {
        display: block !important;
        width: auto !important;
        min-width: 200px !important;
        max-width: 280px !important;
        padding: 12px 24px !important;
        text-align: center !important;
        box-sizing: border-box !important;
        margin: 0 !important;
    }

    .home-zone-servite h2 {
        font-size: 22px !important;
        padding: 0 15px !important;
    }

    .home-zone-servite p {
        font-size: 15px !important;
        padding: 0 15px !important;
    }
}

/* Extra small mobile */
@media (max-width: 360px) {
    .zone-badges a {
        min-width: 180px !important;
        padding: 10px 20px !important;
        font-size: 14px !important;
        font-weight: 400 !important;
    }
}

/* ========================================
   MOBILE FIX - 29 Dicembre 2025
   ======================================== */
@media (max-width: 768px) {
    
    /* === SPAZIO LOGO-BANNER === */
    
    /* Homepage */
    .home-hero-photo {
        margin-top: 20px !important;
    }
    
    /* Chi Siamo, Servizi, Contatti */
    .chi-siamo-hero,
    .servizi-hero,
    .contatti-hero {
        margin-top: 20px !important;
    }
    
    /* === MENU HAMBURGER === */
    
    .navbar-header::after {
        display: none !important;
    }
    
    .responsive-menu {
        display: flex !important;
        visibility: visible !important;
    }
}

/* ========================================
   SHOP MOBILE FIX EXTRA - 29 Dicembre 2025
   ======================================== */
@media (max-width: 768px) {
    /* Negozio / Shop - spazio logo-banner */
    .ferrufficio-shop-hero {
        margin-top: 40px !important;
        padding-top: 70px !important;
    }

    /* Categorie negozio centrate */
    .ferrufficio-categories-grid {
        padding: 0 10px !important;
        overflow: visible !important;
    }

    .categories-container {
        display: flex !important;
        flex-wrap: wrap !important;
        justify-content: center !important;
        gap: 8px !important;
        padding: 0 5px !important;
    }

    .category-card {
        width: calc(33.33% - 10px) !important;
        min-width: 85px !important;
        margin: 0 !important;
    }

    /* Menu hamburger shop */
    button.navbar-toggle {
        display: flex !important;
        visibility: visible !important;
    }
}
