        /* Stili per tab PAREGGI */
        .status-card {
            background: var(--bg-secondary);
            border: 2px solid var(--border-color);
            border-radius: 15px;
            padding: 25px;
            box-shadow: var(--shadow-md);
        }

        .status-header {
            display: flex;
            align-items: center;
            gap: 15px;
            margin-bottom: 20px;
            font-size: 1.3em;
            font-weight: bold;
        }

        .status-header #statusIcon {
            font-size: 1.5em;
        }

        .status-header #statusText {
            flex: 1;
        }

        /* COS-001: Status header wrappa su mobile (bottoni a capo sotto il titolo) */
        @media (max-width: 768px) {
            .status-card {
                padding: 15px;
            }

            .status-header {
                flex-wrap: wrap;
                font-size: 1.1em;
            }

            .status-header > div:last-child {
                width: 100%;
            }
        }

        .btn-refresh {
            background: transparent;
            border: 2px solid var(--border-color);
            border-radius: 8px;
            padding: 8px 12px;
            font-size: 1.2em;
            cursor: pointer;
            transition: all 0.2s ease;
        }

        .btn-refresh:hover {
            background: var(--table-hover);
            transform: rotate(180deg);
        }

        .status-details {
            display: grid;
            gap: 15px;
            margin-top: 20px;
            padding-top: 20px;
            border-top: 1px solid var(--border-color);
        }

        .status-item {
            display: flex;
            justify-content: space-between;
            align-items: center;
            padding: 10px;
            background: var(--bg-primary);
            border-radius: 8px;
        }

        .status-in-corso {
            border-left: 5px solid var(--color-warning);
        }

        .status-completato {
            border-left: 5px solid var(--color-success);
        }

        .status-errore {
            border-left: 5px solid var(--color-danger);
        }

        .status-no-calcolo {
            border-left: 5px solid #9e9e9e;
        }

        /* Puzzle View Styles */
        .puzzle-container {
            padding: 20px;
        }

        .puzzle-header {
            margin-bottom: 30px;
        }

        .puzzle-stats {
            display: flex;
            gap: 20px;
            margin-bottom: 20px;
            flex-wrap: wrap;
        }

        .puzzle-stat-card {
            background: var(--bg-secondary);
            border: 2px solid var(--border-color);
            border-radius: 12px;
            padding: 15px 20px;
            min-width: 180px;
            text-align: center;
            box-shadow: var(--shadow-sm);
        }

        .puzzle-stat-card.highlight {
            border-color: var(--accent-primary);
            background: linear-gradient(135deg, var(--bg-secondary) 0%, rgba(46, 125, 50, 0.1) 100%);
        }

        .puzzle-stat-label {
            font-size: 0.85em;
            color: var(--text-secondary);
            margin-bottom: 8px;
            transition: opacity 0.3s ease;
        }

        .puzzle-stat-value {
            font-size: 1.8em;
            font-weight: bold;
            color: var(--accent-primary);
            transition: opacity 0.3s ease;
        }

        /* Loading state per puzzle stat-card */
        .puzzle-stat-card.is-loading {
            position: relative;
            min-height: 80px;
        }

        .puzzle-stat-card.is-loading .puzzle-stat-value,
        .puzzle-stat-card.is-loading .puzzle-stat-label {
            opacity: 0;
            pointer-events: none;
        }

        .puzzle-stat-card .skeleton-wrapper {
            display: none;
            position: absolute;
            top: 50%;
            left: 50%;
            transform: translate(-50%, -50%);
            width: 70%;
        }

        .puzzle-stat-card.is-loading .skeleton-wrapper {
            display: block;
        }

        .puzzle-layout {
            display: grid;
            grid-template-columns: 1fr 1fr;
            gap: 20px;
            margin-bottom: 20px;
        }

        @media (max-width: 1280px) {
            .puzzle-layout {
                grid-template-columns: 1fr !important; /* Override inline style */
            }
        }

        .puzzle-column {
            background: var(--bg-secondary);
            border: 2px solid var(--border-color);
            border-radius: 12px;
            padding: 20px;
            box-shadow: var(--shadow-sm);
        }

        /* MOB-003: Rompicapo adattato a mobile */
        @media (max-width: 768px) {
            .puzzle-layout {
                /* grid-template-columns: 1fr gia' in media query 1280px */
                gap: 12px !important;
            }

            .puzzle-column {
                padding: 12px;
            }

            /* Azioni puzzle: stack verticale su mobile */
            .puzzle-actions {
                flex-direction: column !important;
                gap: 12px !important;
                padding: 12px !important;
            }

            .puzzle-selection-info {
                width: 100%;
            }

            /* Bottoni azioni puzzle: wrap su mobile */
            .puzzle-actions > div:last-child {
                flex-wrap: wrap !important;
                width: 100%;
            }

            .puzzle-actions button {
                flex: 1;
                min-width: 100px;
                min-height: 44px;
            }

            /* Filtri puzzle: compatti su mobile */
            .puzzle-filters {
                padding: 10px !important;
            }

            .puzzle-filters input[type="text"],
            .puzzle-filters input[type="number"] {
                width: 100% !important;
                max-width: none;
            }

            /* Header colonna puzzle: stack verticale */
            .puzzle-column > div:first-child {
                flex-direction: column !important;
                gap: 8px !important;
            }

            .puzzle-column input[type="text"] {
                width: 100% !important;
            }

            /* Puzzle items compatti */
            .puzzle-item {
                padding: 10px;
                gap: 8px;
            }

            /* Lista puzzle: altezza ridotta su mobile */
            .puzzle-list {
                max-height: 400px !important;
            }

            /* COS-002: Stat cards - ridotte per mobile (no overflow "0 elementi") */
            .puzzle-stats {
                flex-wrap: wrap !important;
                gap: 8px !important;
            }

            .puzzle-stat-card {
                flex: 1;
                min-width: 0;
                padding: 10px 8px;
            }

            .puzzle-stat-value {
                font-size: 1.2em;
            }
        }

        .puzzle-list {
            display: flex;
            flex-direction: column;
            gap: 10px;
        }

        .puzzle-item {
            background: var(--bg-primary);
            border: 2px solid var(--border-color);
            border-radius: 8px;
            padding: 15px;
            cursor: pointer;
            transition: all 0.2s ease;
            display: flex;
            align-items: flex-start;
            gap: 12px;
        }

        .puzzle-item:hover {
            border-color: var(--accent-primary);
            box-shadow: var(--shadow-md);
            transform: translateY(-2px);
        }

        .puzzle-item.selected {
            border-color: var(--accent-primary);
            background: rgba(46, 125, 50, 0.1);
            box-shadow: 0 0 0 3px rgba(46, 125, 50, 0.2);
        }

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

        .puzzle-item-content {
            flex: 1;
        }

        .puzzle-item-header {
            display: flex;
            justify-content: space-between;
            align-items: center;
            margin-bottom: 8px;
        }

        .puzzle-item-name {
            font-weight: bold;
            color: var(--text-primary);
            font-size: 1.05em;
            display: flex;
            align-items: center;
            flex-wrap: wrap;
        }
        
        .puzzle-code-link {
            color: var(--portal-primary);
            text-decoration: none;
            font-weight: 600;
            margin-left: 6px;
            padding: 2px 6px;
            border-radius: 4px;
            transition: all 0.2s ease;
            display: inline-block;
            cursor: pointer;
            border: 1px solid transparent;
        }
        
        .puzzle-code-link:hover {
            background: var(--table-hover);
            text-decoration: underline;
            border-color: var(--portal-primary);
            transform: scale(1.05);
        }
        
        [data-theme="dark"] .puzzle-code-link {
            color: #88dd88;
        }

        [data-theme="dark"] .puzzle-code-link:hover {
            background: rgba(136, 221, 136, 0.2);
            border-color: #88dd88;
        }

        .puzzle-item-amount {
            font-size: 1.2em;
            font-weight: bold;
            color: var(--accent-primary);
        }

        .puzzle-item-details {
            font-size: 0.9em;
            color: var(--text-secondary);
            display: flex;
            gap: 15px;
            flex-wrap: wrap;
        }

        .puzzle-item-detail {
            display: flex;
            align-items: center;
            gap: 5px;
        }

        .puzzle-item-actions {
            display: flex;
            gap: 5px;
        }

        .puzzle-item-btn {
            background: transparent;
            border: 1px solid var(--border-color);
            border-radius: 4px;
            padding: 4px 8px;
            cursor: pointer;
            font-size: 0.85em;
            transition: all 0.2s ease;
        }

        .puzzle-item-btn:hover {
            background: var(--accent-primary);
            color: white;
            border-color: var(--accent-primary);
        }

        .puzzle-actions {
            background: var(--bg-secondary);
            padding: 20px;
            border-radius: 12px;
            border: 2px solid var(--border-color);
            display: flex;
            justify-content: space-between;
            align-items: center;
            flex-wrap: wrap;
            gap: 15px;
        }

        .puzzle-selection-info {
            font-size: 1.05em;
            color: var(--text-primary);
        }

        .puzzle-actions button:disabled {
            opacity: 0.5;
            cursor: not-allowed;
        }

        [data-theme="dark"] .puzzle-item {
            background: var(--bg-primary);
            border-color: var(--border-color);
        }

        [data-theme="dark"] .puzzle-item.selected {
            background: rgba(76, 175, 80, 0.15);
            border-color: var(--accent-primary);
        }

        /* Color coding per GIR FEST e FE: solo importo */
        .puzzle-item[data-tipo-gir^="FEST"] .puzzle-item-amount {
            background: rgba(255, 152, 0, 0.2) !important; /* Arancione per FEST */
            padding: 4px 8px;
            border-radius: 4px;
            border-left: 3px solid #ff9800;
            font-weight: 600;
        }

        .puzzle-item[data-tipo-gir^="FE"]:not([data-tipo-gir^="FEST"]) .puzzle-item-amount {
            background: rgba(156, 39, 176, 0.2) !important; /* Viola per FE */
            padding: 4px 8px;
            border-radius: 4px;
            border-left: 3px solid var(--color-tipo-fe);
            font-weight: 600;
        }

        [data-theme="dark"] .puzzle-item[data-tipo-gir^="FEST"] .puzzle-item-amount {
            background: rgba(255, 152, 0, 0.3) !important;
        }

        [data-theme="dark"] .puzzle-item[data-tipo-gir^="FE"]:not([data-tipo-gir^="FEST"]) .puzzle-item-amount {
            background: rgba(156, 39, 176, 0.3) !important;
        }

        /* Color coding per RESTITUZIONE CAPARRA: solo importo rosso */
        .puzzle-item[data-restituzione="true"] .puzzle-item-amount {
            background: rgba(244, 67, 54, 0.2); /* Rosso chiaro */
            color: #c62828; /* Rosso scuro */
            padding: 4px 8px;
            border-radius: 4px;
            border-left: 3px solid #d32f2f;
            font-weight: 600;
        }

        [data-theme="dark"] .puzzle-item[data-restituzione="true"] .puzzle-item-amount {
            background: rgba(244, 67, 54, 0.3);
            color: #ef5350;
        }

        .pareggi-list, .unmatched-section, .duplicates-section {
            margin-top: 40px;
        }

        .pareggi-list h3, .unmatched-section h3, .duplicates-section h3 {
            margin-bottom: 20px;
            color: var(--text-primary);
            font-size: 1.5em;
        }

        .pareggi-table {
            display: grid;
            gap: 15px;
        }

        /* Stili per visualizzazione compatta gruppi */
        .pareggio-group-summary {
            padding: 8px 0;
            border-bottom: 1px solid var(--border-color);
            margin-bottom: 8px;
        }
        
        .pareggio-group-details {
            padding: 8px 0;
            border-top: 1px solid var(--border-color);
            margin-top: 8px;
        }
        
        .group-toggle-btn {
            transition: all 0.2s ease;
        }
        
        .group-toggle-btn:hover {
            opacity: 0.9;
            transform: scale(1.05);
        }
        
        .pareggio-dare, .pareggio-avere {
            padding: 15px;
            border-radius: 8px;
        }

        .pareggio-dare {
            background: #ffebee;
            border-left: 4px solid #c62828;
        }

        [data-theme="dark"] .pareggio-dare {
            background: #4a2a2a;
            border-left-color: #dd8888;
        }

        .pareggio-avere {
            background: #e8f5e9;
            border-left: 4px solid var(--portal-primary);
        }
        
        /* Pareggi avere con colori portale dinamici */
        body[data-portal="she"] .pareggio-avere {
            background: #e3f2fd;
            border-left-color: var(--portal-primary);
        }
        
        body[data-portal="hp"] .pareggio-avere {
            background: #ffebee;
            border-left-color: var(--portal-primary);
        }
        
        [data-theme="dark"] .pareggio-avere {
            background: #2a4a2a;
            border-left-color: var(--portal-tertiary);
        }
        
        [data-theme="dark"] body[data-portal="she"] .pareggio-avere {
            background: #2a3a4a;
            border-left-color: var(--portal-tertiary);
        }
        
        [data-theme="dark"] body[data-portal="hp"] .pareggio-avere {
            background: #4a2a2a;
            border-left-color: var(--portal-tertiary);
        }

        .pareggio-header {
            font-weight: bold;
            margin-bottom: 10px;
            color: var(--text-primary);
        }

        .pareggio-item {
            margin: 5px 0;
            color: var(--text-secondary);
        }

        .pareggio-amount {
            font-size: 1.2em;
            font-weight: bold;
            margin-top: 10px;
            color: var(--text-primary);
        }

        .confidence-high {
            background: rgba(var(--portal-primary-rgb, 46, 125, 50), 0.2);
            color: var(--portal-primary);
        }
        
        /* Confidence high con colori portale dinamici */
        body[data-portal="she"] .confidence-high {
            background: rgba(37, 99, 235, 0.2);
            color: var(--portal-primary);
        }
        
        body[data-portal="hp"] .confidence-high {
            background: rgba(107, 26, 10, 0.2);
            color: var(--portal-primary);
        }

        .confidence-medium {
            background: #fff9c4;
            color: #f57f17;
        }

        .confidence-low {
            background: #ffccbc;
            color: #d84315;
        }

        .unmatched-tabs, .duplicates-tabs {
            display: flex;
            gap: 10px;
            margin-bottom: 20px;
        }

        .unmatched-tab, .duplicates-tab {
            padding: 10px 20px;
            background: var(--bg-secondary);
            border: 2px solid var(--border-color);
            border-radius: 8px;
            cursor: pointer;
            transition: all 0.2s ease;
        }

        .unmatched-tab.active, .duplicates-tab.active {
            background: var(--accent-primary);
            color: var(--text-inverse);
            border-color: var(--accent-primary);
        }

        .unmatched-list, .duplicates-list {
            display: grid;
            gap: 10px;
        }

        .unmatched-item, .duplicate-item {
            padding: 15px;
            background: var(--bg-secondary);
            border-radius: 8px;
            border: 1px solid var(--border-color);
        }

        .badge-small {
            display: inline-block;
            background: var(--accent-primary);
            color: white;
            border-radius: 10px;
            padding: 2px 8px;
            font-size: 0.8em;
            font-weight: bold;
            margin-left: 5px;
        }



        /* Leggera compattazione di alcune colonne nel corpo tabella */
        td[data-field="canale"],
        td[data-field="circuito"] {
            font-size: 0.95em;
        }

        /* Colonne non editabili ma clickabili (ID e ⛳️) */
        .non-editable-link,
        .pareggio-cell {
            cursor: pointer;
            user-select: none;
        }

        .non-editable-link:hover,
        .pareggio-cell:hover {
            opacity: 0.8;
        }

        /* Previeni edit su colonne ID e ⛳️ */
        .non-editable-link.editing,
        .pareggio-cell.editing {
            pointer-events: none;
        }
        /* Icona orologio/clock della prima colonna più piccola */
        td:first-child .clock-icon,
        .clock-icon {
            transform: scale(0.8);
        }

        .table-container {
            overflow-x: auto;
            /* overscroll-behavior: contain SPOSTATO in media query 768px (BUG-001: bloccava scroll desktop) */
            margin-top: 0; /* Rimosso per eliminare spazio verde */
        }

        table {
            width: 100%;
            border-collapse: collapse;
            font-size: 0.95em;
        }

        thead {
            background: var(--table-header-bg);
            color: var(--text-inverse);
        }

        th {
            padding: 15px;
            text-align: left;
            font-weight: 600;
            position: sticky;
            top: 0;
            z-index: 10;
            background: var(--table-header-bg);
            color: inherit;
            box-shadow: 0 2px 4px rgba(0, 0, 0, 0.3);
            border-bottom: 1px solid var(--border-color);
            border-right: 1px solid var(--border-color);
        }


        
        /* Header tabella: testo bianco in light mode */
        :root thead th,
        thead th {
            color: var(--text-inverse);
        }
        
        /* Header tabella in dark mode: VERDE CHIARO sfondo, VERDE SCURO testo */
        [data-theme="dark"] thead {
            background: #b8d4b8;
            color: #1a2a1a;
        }

        [data-theme="dark"] thead th {
            background: #b8d4b8;
            color: #1a2a1a;
            font-weight: 700;
            text-transform: uppercase;
            letter-spacing: 0.5px;
            font-size: 0.85em;
        }

        td {
            padding: 12px 15px;
            border-bottom: 1px solid var(--border-color);
            color: var(--text-primary);
        }

        /* NOTE: colonna contenuta, scroll per note lunghe (S319) */
        td[data-field="note"] {
            max-width: 250px;
            white-space: normal;
            word-break: break-word;
            line-height: 1.35;
        }

        /* NOTE: wrapper div per scroll (max-height su td non funziona) */
        td[data-field="note"] .note-content {
            max-height: 4em;
            overflow-y: auto;
        }

        /* NOTE editing: nascondi wrapper, textarea prende il controllo (S319) */
        td[data-field="note"].editing .note-content {
            display: none;
        }

        /* Nascondi colonna Data Conferma (senza rompere gli indici delle colonne) */
        th.col-data-conferma,
        td[data-field="data_conferma_bonifici"] {
            display: none;
        }
        
        /* Nascondi colonna Numero (senza rompere gli indici delle colonne) */
        th.col-numero,
        td.col-numero {
            display: none;
        }

        /* Riduci margini/padding su schermi piccoli e usa tutta la larghezza */
        @media (max-width: 1280px) {
            .content { padding: 16px; }
            .header-actions { margin-right: 40px; }
            table { font-size: 0.9em; }
            th, td { padding: 10px 12px; }
        }
        
        /* Bordi verde chiaro in dark mode (stesso del header) */
        [data-theme="dark"] td {
            border-bottom: 1px solid #b8d4b8;
        }

        tbody tr:nth-child(even) {
            background: var(--table-row-even);
        }

        tbody tr:nth-child(odd) {
            background: var(--table-row-odd);
        }

        tbody tr:hover {
            background: var(--table-hover);
        }

        /* Color coding per CIRCUITO (colonna Canale, nth-child(8) dopo insertBefore pareggio) */
        tbody tr[data-circuito="MASTERCARD"] td:nth-child(8) {
            background: var(--color-mastercard) !important;
            font-weight: 500;
        }

        tbody tr[data-circuito="VISA"] td:nth-child(8) {
            background: var(--color-visa) !important;
            font-weight: 500;
        }

        tbody tr[data-circuito="BONIFICO"] td:nth-child(8) {
            background: var(--color-bonifico) !important;
            font-weight: 500;
        }

        tbody tr[data-circuito="CONTANTI"] td:nth-child(8) {
            background: var(--color-contanti) !important;
            font-weight: 500;
        }

        tbody tr[data-circuito="POS"] td:nth-child(8) {
            background: var(--color-pos) !important;
            font-weight: 500;
        }

        tbody tr[data-circuito="CARTA"] td:nth-child(8) {
            background: var(--color-carta) !important;
            font-weight: 500;
        }

        tbody tr[data-circuito="BANCOMAT"] td:nth-child(8) {
            background: var(--color-bancomat) !important;
            font-weight: 500;
        }

        tbody tr[data-circuito="VOUCHER"] td:nth-child(8) {
            background: var(--color-voucher) !important;
            font-weight: 500;
        }

        tbody tr[data-circuito="CAPARRA"] td:nth-child(8) {
            background: var(--color-caparra) !important;
            font-weight: 500;
        }

        tbody tr[data-circuito="BONUS"] td:nth-child(8) {
            background: var(--color-bonus) !important;
            font-weight: 500;
        }

        /* Color coding per STAGIONE */
        tbody tr[data-stagione*="ESTATE"] td:nth-child(10) {
            background: var(--color-estate) !important;
            font-weight: 500;
        }

        tbody tr[data-stagione*="INVERNO"] td:nth-child(10) {
            background: var(--color-inverno) !important;
            font-weight: 500;
        }

        /* Color coding per HOTEL */
        tbody tr[data-hotel="NL"] td:nth-child(11) {
            background: var(--color-hotel-nl) !important;
            font-weight: 500;
            color: var(--text-primary);
        }

        tbody tr[data-hotel="HP"] td:nth-child(11) {
            background: var(--color-hotel-hp) !important;
            font-weight: 500;
        }

        tbody tr[data-hotel="SHE"] td:nth-child(11) {
            background: var(--color-hotel-she) !important;
            font-weight: 500;
        }

        /* Color coding per RESTITUZIONE CAPARRA: colonna Totale rossa */
        /* JI-P1-02: data-field="totale" invece di nth-child (robusto) */
        tbody tr[data-restituzione="true"] td[data-field="totale"] {
            background: rgba(244, 67, 54, 0.15) !important; /* Rosso chiaro */
            color: #c62828 !important; /* Rosso scuro */
            font-weight: 600;
            border-left: 3px solid #d32f2f;
        }

        [data-theme="dark"] tbody tr[data-restituzione="true"] td[data-field="totale"] {
            background: rgba(244, 67, 54, 0.25) !important;
            color: #ef5350 !important;
        }

        .stats {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
            gap: 20px;
            margin-bottom: 30px;
        }

        .stat-card {
            background: linear-gradient(135deg, #81c784 0%, #66bb6a 100%);
            color: white;
            padding: 20px;
            border-radius: 12px;
            text-align: center;
            box-shadow: 0 4px 12px rgba(129, 199, 132, 0.3);
        }

        .stat-card h3 {
            font-size: 2em;
            margin-bottom: 5px;
        }

        .stat-card p {
            opacity: 0.9;
        }

        /* Statistiche Quadratura */
        .quadratura-stats {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
            gap: 15px;
            margin-bottom: 20px;
        }

        .stat-card-quadratura {
            background: var(--bg-secondary);
            border: 2px solid var(--border-color);
            border-radius: 12px;
            padding: 20px;
            text-align: center;
            box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
            transition: all 0.3s ease;
        }

        .stat-card-quadratura:hover {
            transform: translateY(-2px);
            box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
        }

        .stat-card-quadratura.highlight {
            border-color: var(--accent-primary);
            background: linear-gradient(135deg, var(--bg-secondary) 0%, rgba(0, 97, 0, 0.1) 100%);
        }

        .stat-card-quadratura .stat-label {
            font-size: 0.85em;
            color: var(--text-secondary);
            text-transform: uppercase;
            letter-spacing: 0.5px;
            margin-bottom: 10px;
            font-weight: 600;
        }

        .stat-card-quadratura .stat-value {
            font-size: 2em;
            font-weight: bold;
            color: var(--accent-primary);
            margin-bottom: 5px;
        }

        .stat-card-quadratura .stat-value.error {
            color: #d9534f;
        }

        .stat-card-quadratura .stat-total {
            font-size: 0.85em;
            margin-top: 8px;
        }
        
        .stat-card-quadratura .stat-details {
            margin-top: 10px;
            padding-top: 10px;
            border-top: 1px solid var(--border-color);
            font-size: 0.8em;
            color: var(--text-secondary);
            line-height: 1.6;
        }
        
        .stat-card-quadratura .stat-details-item {
            margin: 4px 0;
        }
        
        .stat-card-quadratura .stat-details-item strong {
            color: var(--text-primary);
            font-weight: 600;
        }

        .stat-card-quadratura .stat-percent {
            font-size: 1.2em;
            font-weight: bold;
            color: var(--accent-primary);
            margin-top: 10px;
            padding-top: 10px;
            border-top: 1px solid var(--border-color);
        }

        [data-theme="dark"] .stat-card-quadratura.highlight {
            background: linear-gradient(135deg, #1a2a1a 0%, rgba(76, 175, 80, 0.2) 100%);
        }

        .actions {
            display: flex;
            gap: 15px;
            margin-top: 20px;
            flex-wrap: wrap;
        }

        .filters {
            background: var(--bg-secondary);
            border: 1px solid var(--border-color);
            padding: 16px 20px;
            border-radius: 12px;
            margin-bottom: 8px;
            display: flex;
            gap: 16px;
            flex-wrap: wrap;
            align-items: flex-end;
            box-shadow: var(--shadow-sm);
            transition: all 0.3s ease;
            position: sticky;
            top: 12px; /* resta visibile durante lo scroll */
            z-index: 50;
        }
        
        /* Filtri in dark mode: sfondo verde chiaro */
        [data-theme="dark"] .filters {
            background: #344a34;
            border-color: #3d5040;
        }

        /* STRUCT-002: Raggruppamento visivo filtri */
        .filter-section {
            display: flex;
            gap: 12px;
            align-items: flex-end;
            padding-right: 16px;
            border-right: 1px solid var(--border-color);
            position: relative;
        }
        .filter-section:last-child {
            border-right: none;
            padding-right: 0;
        }
        .filter-section-label {
            position: absolute;
            top: -10px;
            left: 4px;
            font-size: 0.65em;
            font-weight: 700;
            text-transform: uppercase;
            letter-spacing: 0.08em;
            color: var(--text-secondary);
            opacity: 0.7;
        }

        .filter-group {
            display: flex;
            flex-direction: column;
            gap: 5px;
        }

        .filter-group label {
            font-weight: 500;
            color: var(--text-secondary);
            font-size: 0.85em;
            text-transform: uppercase;
            letter-spacing: 0.5px;
        }
        
        /* ========================================
           IDEA-003: Campo ricerca full-text
           ======================================== */

        /* Sezione ricerca: allineata con gli altri filter-section */
        .filter-section-search {
            align-items: center;
            gap: 6px;
        }

        /* Wrapper: posizione relativa per icona e pulsante clear */
        .search-field-wrapper {
            position: relative;
            display: flex;
            align-items: center;
            min-width: 200px;
        }

        /* Icona lente (posizionata a sinistra nell'input) */
        .search-field-icon {
            position: absolute;
            left: 10px;
            font-size: 0.9em;
            color: var(--text-secondary);
            pointer-events: none;
            line-height: 1;
        }

        /* Input ricerca */
        .search-field-input {
            width: 100%;
            padding: 8px 32px 8px 32px;
            border: 1px solid var(--border-color);
            border-radius: 6px;
            background: var(--bg-secondary);
            color: var(--text-primary);
            font-size: 0.9em;
            font-family: inherit;
            min-height: 38px;
            transition: border-color 0.2s ease, box-shadow 0.2s ease;
            /* Rimuove la X nativa del browser su type=search */
            -webkit-appearance: none;
            appearance: none;
        }

        .search-field-input::-webkit-search-cancel-button {
            display: none;
        }

        .search-field-input::placeholder {
            color: var(--text-secondary);
            opacity: 0.7;
        }

        .search-field-input:focus {
            outline: none;
            border-color: var(--accent-primary);
            box-shadow: 0 0 0 2px var(--color-success-light);
        }

        /* Pulsante clear (x) a destra */
        .search-field-clear {
            position: absolute;
            right: 6px;
            display: flex;
            align-items: center;
            justify-content: center;
            width: 22px;
            height: 22px;
            border: none;
            background: var(--bg-tertiary);
            color: var(--text-secondary);
            border-radius: 50%;
            cursor: pointer;
            font-size: 0.75em;
            line-height: 1;
            transition: background 0.15s ease, color 0.15s ease;
        }

        .search-field-clear:hover {
            background: var(--color-danger);
            color: var(--text-inverse);
        }

        /* Live region ARIA: visualmente nascosta, accessibile agli screen reader */
        .search-status-aria {
            position: absolute;
            width: 1px;
            height: 1px;
            padding: 0;
            margin: -1px;
            overflow: hidden;
            clip: rect(0, 0, 0, 0);
            white-space: nowrap;
            border: 0;
        }

        /* Multi-select custom component */
        .multi-select-wrapper {
            position: relative;
            display: inline-block;
            width: 100%;
        }
        
        .multi-select-button {
            width: 100%;
            padding: 8px 12px;
            background: var(--bg-secondary);
            border: 1px solid var(--border-color);
            border-radius: 6px;
            cursor: pointer;
            font-size: 0.9em;
            color: var(--text-primary);
            text-align: left;
            display: flex;
            justify-content: space-between;
            align-items: center;
            transition: all 0.2s ease;
            min-height: 38px;
        }
        
        .multi-select-button:hover {
            border-color: var(--accent-primary);
            background: var(--table-hover);
        }
        
        .multi-select-button span:first-child {
            flex: 1;
            font-size: 0.9em;
            font-weight: 500;
            white-space: nowrap;
            overflow: hidden;
            text-overflow: ellipsis;
        }
        
        .multi-select-button::after {
            content: '▼';
            font-size: 0.7em;
            transition: transform 0.2s ease;
            margin-left: 8px;
            flex-shrink: 0;
        }
        
        .multi-select-wrapper.open .multi-select-button::after {
            transform: rotate(180deg);
        }
        
        .multi-select-dropdown {
            position: absolute;
            top: 100%;
            left: 0;
            min-width: 200px;
            width: max-content;
            max-width: 300px;
            margin-top: 4px;
            background: var(--bg-secondary);
            border: 1px solid var(--border-color);
            border-radius: 6px;
            box-shadow: var(--shadow-md);
            z-index: 1000;
            max-height: 200px;
            overflow-y: auto;
            display: none;
        }
        
        .multi-select-wrapper.open .multi-select-dropdown {
            display: block;
        }
        
        .multi-select-option {
            padding: 10px 14px;
            display: flex;
            align-items: center;
            gap: 10px;
            cursor: pointer;
            transition: background 0.2s ease;
            min-height: 38px;
            white-space: nowrap;
        }
        
        .multi-select-option:hover {
            background: var(--table-hover);
        }
        
        .multi-select-option input[type="checkbox"] {
            cursor: pointer;
            width: 18px;
            height: 18px;
            flex-shrink: 0;
        }
        
        .multi-select-option label {
            cursor: pointer;
            flex: 1;
            font-weight: normal;
            text-transform: none;
            letter-spacing: normal;
            font-size: 0.9em;
            margin: 0;
            line-height: 1.4;
            white-space: nowrap;
        }
        
        .multi-select-selected-count {
            font-size: 0.8em;
            color: var(--accent-primary);
            font-weight: 600;
            margin-left: 8px;
            flex-shrink: 0;
        }

        .filter-group select,
        .filter-group input {
            padding: 8px 12px;
            border: 1px solid var(--border-color);
            border-radius: 8px;
            font-size: 0.9em;
            background: var(--bg-secondary);
            color: var(--text-primary);
            transition: border-color 0.15s ease;
        }
        
        .filter-group select:focus,
        .filter-group input:focus {
            outline: none;
            border-color: var(--accent-primary);
            box-shadow: 0 0 0 3px rgba(var(--accent-primary-rgb, 46, 125, 50), 0.1);
        }

        /* ========================================
           RESP-003: Tabelle horizontal scroll + sticky prima colonna
           Pattern Booking.com: scroll orizzontale con colonna di riferimento fissa
           ======================================== */
        @media (max-width: 768px) {
            /* Forza scroll orizzontale + font compatto + fluidita' touch */
            table {
                min-width: 800px;
                font-size: 0.88em;
                touch-action: manipulation; /* Elimina 300ms tap delay, mantiene pinch-to-zoom */
            }

            /* Prima colonna (checkbox): sticky left + background esplicito */
            th:first-child {
                left: 0;
                z-index: 15; /* Sopra altri th sticky (10) e td sticky (5) */
                background: var(--table-header-bg);
                /* Ombra combinata: destra (sticky left) + sotto (sticky top) */
                box-shadow: 2px 0 4px rgba(0, 0, 0, 0.1), 0 2px 4px rgba(0, 0, 0, 0.3);
            }

            [data-theme="dark"] th:first-child {
                background: #b8d4b8;
                box-shadow: 2px 0 4px rgba(0, 0, 0, 0.3), 0 2px 4px rgba(0, 0, 0, 0.4);
            }

            td:first-child {
                position: sticky;
                left: 0;
                z-index: 5;
                box-shadow: 2px 0 4px rgba(0, 0, 0, 0.1);
            }

            [data-theme="dark"] td:first-child {
                box-shadow: 2px 0 4px rgba(0, 0, 0, 0.3);
            }

            /* Background solido su sticky cells (evita see-through durante scroll) */
            tbody tr:nth-child(even) td:first-child {
                background: var(--table-row-even);
            }

            tbody tr:nth-child(odd) td:first-child {
                background: var(--table-row-odd);
            }

            tbody tr:hover td:first-child {
                background: var(--table-hover);
            }

            /* M03: Righe compatte su mobile (era 10px 8px / 8px 10px) */
            th {
                padding: 7px 8px;
                font-size: 0.82em;
            }

            td {
                padding: 6px 8px;
                font-size: 0.85em;
                line-height: 1.3;
            }

            /* M02: Tronca colonne nome con ellipsis su mobile */
            td[data-field="nome"],
            td[data-field="nome_gir"] {
                max-width: 150px;
                white-space: nowrap;
                overflow: hidden;
                text-overflow: ellipsis;
            }

            /* M08: Respiro visivo tra filtri e tabella */
            .table-container {
                margin-top: 8px;
                border-bottom-left-radius: 8px;
                border-bottom-right-radius: 8px;
                scrollbar-width: none; /* Scrollbar nascosta su mobile - piu' pulito */
                overscroll-behavior: contain; /* Previene rimbalzo tabella->pagina SOLO su mobile (era globale: bloccava scroll desktop!) */
            }
            .table-container::-webkit-scrollbar {
                display: none; /* Safari fallback */
            }

            /* Note troncate su mobile - tap sulla cella per leggere tutto */
            td[data-field="note"] {
                max-width: 120px;
                white-space: nowrap;
                overflow: hidden;
                text-overflow: ellipsis;
            }

            /* Celle non editabili: previeni selezione testo accidentale */
            .hotel-cell,
            .stagione-cell,
            td.row-select-cell,
            td.row-action {
                user-select: none;
                -webkit-user-select: none;
            }

            /* MOB-002: POS tabella scroll orizzontale su mobile */
            .pos-table-wrapper {
                overflow-x: auto !important; /* Override inline overflow:hidden */
            }

            .pos-table {
                min-width: 600px; /* POS ha 7 colonne vs 10+ delle tabelle principali (800px) */
            }
        }

        /* ========================================
           RESP-005: Filtri responsive su mobile
           Su mobile i filtri diventano colonna: non sticky (occuperebbe troppo),
           sezioni full-width con separatore bottom, label inline visibile
           ======================================== */
        @media (max-width: 768px) {
            /* Contenitore filtri: colonna, NON sticky su mobile */
            .filters {
                flex-direction: column;
                position: relative;
                top: auto;
                padding: 12px;
                gap: 8px;
            }

            /* Ogni sezione occupa tutta la larghezza */
            .filter-section {
                flex-direction: column;
                align-items: stretch;
                width: 100%;
                padding-right: 0;
                padding-bottom: 10px;
                border-right: none;
                border-bottom: 1px solid var(--border-color);
                gap: 8px;
            }

            .filter-section:last-child {
                border-bottom: none;
                padding-bottom: 0;
            }

            /* Label: da absolute a inline, visibile come titolo sezione */
            .filter-section-label {
                position: static;
                display: block;
                font-size: 0.7em;
                font-weight: 700;
                text-transform: uppercase;
                letter-spacing: 0.08em;
                color: var(--text-secondary);
                background: var(--bg-secondary);
                padding: 2px 6px;
                border-radius: 4px;
                opacity: 1;
                align-self: flex-start;
            }

            /* Sezione azioni: row wrappato per tenerla compatta */
            .filter-section[data-filter-section="azioni"] {
                flex-direction: row;
                flex-wrap: wrap;
                align-items: center;
                gap: 10px;
            }

            /* filter-group dentro azioni si adatta orizzontalmente */
            .filter-section[data-filter-section="azioni"] .filter-group {
                flex-direction: row;
                align-items: center;
                gap: 8px;
            }

            /* Sezioni dati e periodo: filter-group a row wrappati */
            .filter-section[data-filter-section="dati"],
            .filter-section[data-filter-section="periodo"] {
                flex-direction: row;
                flex-wrap: wrap;
                align-items: flex-start;
                gap: 10px;
            }

            .filter-section[data-filter-section="dati"] .filter-group,
            .filter-section[data-filter-section="periodo"] .filter-group {
                flex: 1 1 140px;
                min-width: 130px;
            }

            /* Touch targets: select e input min 44px */
            .filter-group select,
            .filter-group input {
                min-height: 44px;
                font-size: 1em;
            }

            /* Multi-select button: touch target 44px */
            .multi-select-button {
                min-height: 44px;
            }

            /* IDEA-003: Ricerca mobile: piena larghezza */
            .filter-section-search {
                border-right: none;
                border-top: 1px solid var(--border-color);
                padding-top: 10px;
                width: 100%;
            }

            .search-field-wrapper {
                width: 100%;
            }

            .search-field-input {
                min-height: 44px;
                font-size: 1em;
            }
        }
