        /* ========================================
           SMID FACTORY v31 - FLUENT DESIGN 2
           Microsoft Fluent Design System
           ======================================== */
        
        * { margin: 0; padding: 0; box-sizing: border-box; }
        
        :root {
            /* Fluent Design 2 - Primary Palette */
            --fluent-primary: #0078D4;
            --fluent-primary-hover: #106EBE;
            --fluent-primary-pressed: #005A9E;
            --fluent-primary-light: #DEECF9;
            --fluent-primary-lighter: #EFF6FC;
            
            /* Background Colors */
            --fluent-bg: #F3F2F1;
            --fluent-bg-secondary: #FAF9F8;
            --fluent-bg-card: #FFFFFF;
            --fluent-bg-elevated: #FFFFFF;
            --fluent-bg-hover: #F5F5F5;
            --fluent-bg-pressed: #EDEBE9;
            --fluent-bg-input: #FFFFFF;
            --fluent-bg-disabled: #F3F2F1;
            
            /* Text Colors */
            --fluent-text-primary: #323130;
            --fluent-text-secondary: #605E5C;
            --fluent-text-disabled: #A19F9D;
            --fluent-text-on-accent: #FFFFFF;
            --fluent-text-link: #0078D4;
            
            /* Border Colors */
            --fluent-border: #EDEBE9;
            --fluent-border-strong: #8A8886;
            --fluent-border-subtle: #F3F2F1;
            --fluent-border-focus: #0078D4;
            
            /* Status Colors */
            --fluent-success: #107C10;
            --fluent-success-bg: #DFF6DD;
            --fluent-warning: #FFB900;
            --fluent-warning-bg: #FFF4CE;
            --fluent-error: #D13438;
            --fluent-error-bg: #FDE7E9;
            --fluent-info: #0078D4;
            --fluent-info-bg: #DEECF9;
            
            /* Anno Colors */
            --anno-2025: #0078D4;
            --anno-2025-bg: #DEECF9;
            --anno-2026: #107C10;
            --anno-2026-bg: #DFF6DD;
            --anno-2027: #D83B01;
            --anno-2027-bg: #FED9CC;
            --anno-2028: #8764B8;
            --anno-2028-bg: #E8E0F0;
            
            /* Shadows - Fluent Elevation */
            --shadow-2: 0 1.6px 3.6px rgba(0,0,0,0.13), 0 0.3px 0.9px rgba(0,0,0,0.11);
            --shadow-4: 0 3.2px 7.2px rgba(0,0,0,0.13), 0 0.6px 1.8px rgba(0,0,0,0.11);
            --shadow-8: 0 6.4px 14.4px rgba(0,0,0,0.13), 0 1.2px 3.6px rgba(0,0,0,0.11);
            --shadow-16: 0 12.8px 28.8px rgba(0,0,0,0.13), 0 2.4px 7.2px rgba(0,0,0,0.11);
            --shadow-64: 0 25.6px 57.6px rgba(0,0,0,0.22), 0 4.8px 14.4px rgba(0,0,0,0.18);
            
            /* Sizing */
            --sidebar-width: 240px;
            --header-height: 48px;
            --border-radius-sm: 4px;
            --border-radius-md: 8px;
            --border-radius-lg: 12px;
            
            /* Spacing */
            --spacing-xs: 4px;
            --spacing-sm: 8px;
            --spacing-md: 12px;
            --spacing-lg: 16px;
            --spacing-xl: 24px;
            --spacing-xxl: 32px;
            
            /* Typography */
            --font-family: 'Segoe UI', -apple-system, BlinkMacSystemFont, 'Roboto', 'Helvetica Neue', sans-serif;
            --font-size-xs: 10px;
            --font-size-sm: 12px;
            --font-size-base: 14px;
            --font-size-md: 16px;
            --font-size-lg: 18px;
            --font-size-xl: 20px;
            --font-size-xxl: 24px;
            --font-size-xxxl: 28px;
            
            /* Transitions */
            --transition-fast: 0.1s ease;
            --transition-normal: 0.2s ease;
            --transition-slow: 0.3s ease;
        }
        
        /* ========== BASE STYLES ========== */
        html {
            font-size: 14px;
            -webkit-font-smoothing: antialiased;
            -moz-osx-font-smoothing: grayscale;
        }
        
        body {
            font-family: var(--font-family);
            font-size: var(--font-size-base);
            line-height: 1.5;
            color: var(--fluent-text-primary);
            background: var(--fluent-bg);
            /* v99.30.5: rimosso text-transform:uppercase globale - ora uppercase solo dove serve */
        }
        
        /* Custom Scrollbar - Fluent Style */
        ::-webkit-scrollbar {
            width: 8px;
            height: 8px;
        }
        ::-webkit-scrollbar-track {
            background: transparent;
        }
        ::-webkit-scrollbar-thumb {
            background: #C8C6C4;
            border-radius: 4px;
        }
        ::-webkit-scrollbar-thumb:hover {
            background: #A19F9D;
        }
        
        /* ========== LOGIN PAGE ========== */
        .login-container {
            min-height: 100vh;
            display: flex;
            align-items: center;
            justify-content: center;
            background: linear-gradient(135deg, #0078D4 0%, #106EBE 50%, #005A9E 100%);
            padding: var(--spacing-lg);
        }
        
        .login-box {
            background: var(--fluent-bg-card);
            padding: var(--spacing-xxl);
            border-radius: var(--border-radius-md);
            box-shadow: var(--shadow-64);
            width: 100%;
            max-width: 400px;
        }
        
        .login-box h1 {
            text-align: center;
            font-size: var(--font-size-xxl);
            font-weight: 600;
            color: var(--fluent-text-primary);
            margin-bottom: var(--spacing-xxl);
        }
        
        .login-box input {
            width: 100%;
            padding: 10px 14px;
            margin-bottom: var(--spacing-lg);
            border: 1px solid var(--fluent-border);
            border-radius: var(--border-radius-sm);
            font-size: var(--font-size-base);
            font-family: var(--font-family);
            background: var(--fluent-bg-input);
            color: var(--fluent-text-primary);
            transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
        }
        
        .login-box input:focus {
            outline: none;
            border-color: var(--fluent-primary);
            box-shadow: 0 0 0 1px var(--fluent-primary);
        }
        
        .login-box input::placeholder {
            color: var(--fluent-text-disabled);
        }
        
        .login-box button {
            width: 100%;
            padding: 12px 20px;
            background: var(--fluent-primary);
            color: var(--fluent-text-on-accent);
            border: none;
            border-radius: var(--border-radius-sm);
            font-size: var(--font-size-base);
            font-weight: 600;
            font-family: var(--font-family);
            cursor: pointer;
            transition: background var(--transition-fast);
        }
        
        .login-box button:hover {
            background: var(--fluent-primary-hover);
        }
        
        .login-box button:active {
            background: var(--fluent-primary-pressed);
        }
        
        .login-box .toggle-pwd-btn {
            width: auto;
            padding: 0;
            background: none;
            color: var(--fluent-text-secondary, #666);
            border: none;
            position: absolute;
            right: 10px;
            top: 50%;
            transform: translateY(-60%);
            font-size: 18px;
            cursor: pointer;
            line-height: 1;
        }
        .login-box .toggle-pwd-btn:hover {
            background: none;
            color: var(--fluent-text-primary);
        }
        .pwd-wrapper {
            position: relative;
            margin-bottom: var(--spacing-lg);
        }
        .pwd-wrapper input {
            margin-bottom: 0 !important;
            padding-right: 40px !important;
            box-sizing: border-box;
        }
        .login-error {
            display: none;
            background: var(--fluent-error-bg);
            color: var(--fluent-error);
            padding: var(--spacing-md);
            border-radius: var(--border-radius-sm);
            margin-bottom: var(--spacing-lg);
            font-size: var(--font-size-sm);
            border-left: 3px solid var(--fluent-error);
        }
        
        /* Year Card (legacy) */
        .year-card {
            background: var(--fluent-bg-card);
            border: 1px solid var(--fluent-border);
            border-radius: var(--border-radius-md);
            padding: var(--spacing-lg);
            cursor: pointer;
            text-align: center;
            min-width: 120px;
            transition: all var(--transition-normal);
        }
        
        .year-card:hover:not(.disabled) {
            transform: translateY(-4px);
            box-shadow: var(--shadow-8);
        }
        
        .year-card.disabled {
            opacity: 0.5;
            cursor: not-allowed;
        }
        
        .year-card .year-number {
            font-size: var(--font-size-xxl);
            font-weight: 700;
        }
        
        .year-card .year-status {
            display: inline-block;
            padding: 4px 12px;
            border-radius: 20px;
            font-size: var(--font-size-xs);
            font-weight: 600;
            margin-top: var(--spacing-sm);
        }
        
        /* ========== APP CONTAINER ========== */
        .app-container { display: none; }
        
        /* ========== SIDEBAR ========== */
        .sidebar {
            position: fixed;
            left: 0;
            top: 0;
            bottom: 0;
            width: var(--sidebar-width);
            background: var(--fluent-bg-secondary);
            border-right: 1px solid var(--fluent-border);
            display: flex;
            flex-direction: column;
            z-index: 100;
            overflow: hidden;
        }
        
        .sidebar-header {
            padding: var(--spacing-lg);
            border-bottom: 1px solid var(--fluent-border);
            background: var(--fluent-bg-card);
        }
        
        .sidebar-header .title-row {
            display: flex;
            align-items: center;
            gap: var(--spacing-sm);
            flex-wrap: wrap;
        }
        
        .sidebar-header h2 {
            font-size: var(--font-size-md);
            font-weight: 600;
            color: var(--fluent-text-primary);
            margin: 0;
        }
        
        .sidebar-header .env-badge {
            display: inline-block;
            padding: 2px 8px;
            border-radius: 4px;
            font-size: var(--font-size-xs);
            font-weight: 600;
            background: var(--fluent-info-bg);
            color: var(--fluent-info);
            text-transform: uppercase;
        }
        
        .sidebar-header .anno-badge {
            display: inline-block;
            padding: 4px 12px;
            border-radius: var(--border-radius-sm);
            font-size: var(--font-size-sm);
            font-weight: 600;
            cursor: pointer;
            transition: all var(--transition-fast);
        }
        
        .sidebar-header .anno-badge:hover {
            filter: brightness(0.95);
        }
        
        .sidebar-header .user-header-info {
            margin-top: var(--spacing-md);
            padding-top: var(--spacing-md);
            border-top: 1px solid var(--fluent-border);
        }
        
        .sidebar-header .user-username {
            font-size: var(--font-size-sm);
            font-weight: 600;
            color: var(--fluent-text-primary);
        }
        
        .sidebar-header .user-fullname {
            font-size: var(--font-size-xs);
            color: var(--fluent-text-secondary);
        }
        
        .btn-shutdown {
            display: flex;
            align-items: center;
            gap: var(--spacing-xs);
            padding: 6px 12px;
            margin-top: var(--spacing-sm);
            background: transparent;
            border: 1px solid var(--fluent-border);
            border-radius: var(--border-radius-sm);
            font-size: var(--font-size-xs);
            color: var(--fluent-text-secondary);
            cursor: pointer;
            transition: all var(--transition-fast);
        }
        
        .btn-shutdown:hover {
            background: var(--fluent-error-bg);
            border-color: var(--fluent-error);
            color: var(--fluent-error);
        }
        
        /* Connection Status */
        .connection-status {
            display: flex;
            align-items: center;
            gap: var(--spacing-xs);
            padding: 6px 10px;
            border-radius: var(--border-radius-sm);
            font-size: var(--font-size-xs);
            margin-top: var(--spacing-sm);
        }
        
        .connection-status.online {
            background: var(--fluent-success-bg);
            color: var(--fluent-success);
        }
        
        .connection-status.offline {
            background: var(--fluent-error-bg);
            color: var(--fluent-error);
        }
        
        .connection-status.reconnecting {
            background: var(--fluent-warning-bg);
            color: #996600;
        }
        
        .connection-dot {
            width: 8px;
            height: 8px;
            border-radius: 50%;
        }
        
        .connection-status.online .connection-dot { background: var(--fluent-success); }
        .connection-status.offline .connection-dot { background: var(--fluent-error); }
        .connection-status.reconnecting .connection-dot { background: var(--fluent-warning); animation: pulse 1s infinite; }
        
        @keyframes pulse {
            0%, 100% { opacity: 1; }
            50% { opacity: 0.4; }
        }
        
        /* Navigation Menu */
        .nav-menu {
            flex: 1;
            overflow-y: auto;
            padding: var(--spacing-sm) 0;
        }
        
        .nav-menu::-webkit-scrollbar { width: 6px; }
        .nav-menu::-webkit-scrollbar-track { background: transparent; }
        .nav-menu::-webkit-scrollbar-thumb { background: #C8C6C4; border-radius: 3px; }
        .nav-menu::-webkit-scrollbar-thumb:hover { background: #A19F9D; }
        
        .nav-section {
            padding: var(--spacing-sm) var(--spacing-lg);
            font-size: var(--font-size-xs);
            font-weight: 600;
            color: var(--fluent-text-secondary);
            text-transform: uppercase;
            letter-spacing: 0.5px;
        }
        
        .nav-item {
            display: flex;
            align-items: center;
            gap: var(--spacing-sm);
            padding: 10px var(--spacing-lg);
            color: var(--fluent-text-primary);
            font-size: var(--font-size-sm);
            cursor: pointer;
            transition: all var(--transition-fast);
            border-left: 3px solid transparent;
            text-transform: uppercase;
        }
        
        .nav-item:hover {
            background: var(--fluent-bg-hover);
        }
        
        .nav-item.active {
            background: var(--fluent-primary-light);
            color: var(--fluent-primary);
            border-left-color: var(--fluent-primary);
            font-weight: 600;
        }
        
        /* Report Submenu */
        .nav-item-report {
            display: flex;
            align-items: center;
            justify-content: space-between;
            padding: 10px var(--spacing-lg);
            color: var(--fluent-text-primary);
            font-size: var(--font-size-sm);
            cursor: pointer;
            border-left: 3px solid transparent;
        }
        
        .nav-item-report:hover {
            background: var(--fluent-bg-hover);
        }
        
        .report-submenu {
            display: none;
            background: var(--fluent-bg-card);
            border-top: 1px solid var(--fluent-border);
            border-bottom: 1px solid var(--fluent-border);
        }
        
        .report-submenu.open {
            display: block;
        }
        
        .submenu-header {
            padding: var(--spacing-sm) var(--spacing-xl);
            font-size: var(--font-size-xs);
            font-weight: 600;
            color: var(--fluent-text-secondary);
            background: var(--fluent-bg);
            text-transform: uppercase;
        }
        
        .submenu-item {
            padding: 8px var(--spacing-xl);
            font-size: var(--font-size-sm);
            color: var(--fluent-text-primary);
            cursor: pointer;
            transition: all var(--transition-fast);
        }
        
        .submenu-item:hover {
            background: var(--fluent-primary-light);
            color: var(--fluent-primary);
        }
        
        .submenu-item.active {
            background: var(--fluent-primary-light);
            color: var(--fluent-primary);
            font-weight: 600;
        }
        
        /* ========== MAIN CONTENT ========== */
        .main-content {
            margin-left: var(--sidebar-width);
            min-height: 100vh;
            padding: var(--spacing-xl);
            background: var(--fluent-bg);
        }
        
        .page { display: none; }
        .page.active { display: block; animation: fadeIn 0.2s ease-out; }
        
        /* v99.30.6: Fade-in transition */
        @keyframes fadeIn {
            from { opacity: 0; transform: translateY(6px); }
            to { opacity: 1; transform: translateY(0); }
        }
        
        .page-header {
            margin-bottom: var(--spacing-xl);
            padding-bottom: var(--spacing-lg);
            border-bottom: 1px solid var(--fluent-border);
        }
        
        .page-header h1 {
            font-size: var(--font-size-xxl);
            font-weight: 600;
            color: var(--fluent-text-primary);
            margin: 0;
            text-transform: uppercase;
        }
        
        /* ========== CARDS ========== */
        .card {
            background: var(--fluent-bg-card);
            border: 1px solid var(--fluent-border);
            border-radius: var(--border-radius-md);
            padding: var(--spacing-lg);
            margin-bottom: var(--spacing-lg);
            box-shadow: var(--shadow-2);
        }
        
        .card h3 {
            font-size: var(--font-size-md);
            font-weight: 600;
            color: var(--fluent-text-primary);
            margin-bottom: var(--spacing-md);
            padding-bottom: var(--spacing-sm);
            border-bottom: 1px solid var(--fluent-border);
        }
        
        /* Stats Grid */
        .stats-grid {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
            gap: var(--spacing-lg);
            margin-bottom: var(--spacing-xl);
        }
        
        .stat-card {
            background: var(--fluent-bg-card);
            border: 1px solid var(--fluent-border);
            border-radius: var(--border-radius-md);
            padding: var(--spacing-lg);
            box-shadow: var(--shadow-2);
            transition: all var(--transition-normal);
            animation: fadeIn 0.25s ease-out;
        }
        
        .stat-card:hover {
            box-shadow: var(--shadow-4);
        }
        
        .stat-card h3 {
            font-size: var(--font-size-sm);
            font-weight: 400;
            color: var(--fluent-text-secondary);
            margin: 0 0 var(--spacing-sm) 0;
            border: none;
            padding: 0;
            text-transform: uppercase;
        }
        
        .stat-card .value {
            font-size: var(--font-size-xxl);
            font-weight: 600;
            color: var(--fluent-text-primary);
        }
        
        .stat-card .value.positive { color: var(--fluent-success); }
        .stat-card .value.negative { color: var(--fluent-error); }
        .stat-card .value.warning { color: #996600; }
        
        /* ========== TABLES ========== */
        .table-container {
            background: var(--fluent-bg-card);
            border: 1px solid var(--fluent-border);
            border-radius: var(--border-radius-md);
            overflow: hidden;
            box-shadow: var(--shadow-2);
        }
        
        table {
            width: 100%;
            border-collapse: collapse;
            font-size: var(--font-size-sm);
        }
        
        th {
            background: var(--fluent-bg-secondary);
            padding: 12px var(--spacing-md);
            text-align: left;
            font-weight: 600;
            color: var(--fluent-text-primary);
            border-bottom: 1px solid var(--fluent-border);
            position: sticky;
            top: 0;
            white-space: nowrap;
            text-transform: uppercase;
        }
        
        td {
            padding: 10px var(--spacing-md);
            border-bottom: 1px solid var(--fluent-border-subtle);
            color: var(--fluent-text-primary);
        }
        
        tr:hover td {
            background: var(--fluent-bg-hover);
        }
        
        tr:last-child td {
            border-bottom: none;
        }
        
        .truncate {
            max-width: 180px;
            overflow: hidden;
            text-overflow: ellipsis;
            white-space: nowrap;
        }
        
        .num {
            text-align: right;
            font-variant-numeric: tabular-nums;
        }
        
        .font-mono {
            font-family: 'SF Mono', 'Consolas', 'Monaco', monospace;
            font-size: var(--font-size-xs);
        }
        
        .font-bold {
            font-weight: 600;
        }
        
        .text-success { color: var(--fluent-success); }
        .text-danger { color: var(--fluent-error); }
        .text-warning { color: #996600; }
        .text-info { color: var(--fluent-info); }
        .text-muted { color: var(--fluent-text-secondary); }
        .text-center { text-align: center; }
        
        /* ========== BADGES ========== */
        .badge {
            display: inline-flex;
            align-items: center;
            padding: 4px 10px;
            border-radius: 4px;
            font-size: var(--font-size-xs);
            font-weight: 600;
            white-space: nowrap;
        }
        
        .badge-success {
            background: var(--fluent-success-bg);
            color: var(--fluent-success);
        }
        
        .badge-warning {
            background: var(--fluent-warning-bg);
            color: #996600;
        }
        
        .badge-danger {
            background: var(--fluent-error-bg);
            color: var(--fluent-error);
        }
        
        .badge-info {
            background: var(--fluent-info-bg);
            color: var(--fluent-info);
        }
        
        .badge-secondary {
            background: #E0E0E0;
            color: #616161;
        }
        
        .badge-primary {
            background: #E3F2FD;
            color: #1565C0;
        }
        
        .badge-purple {
            background: #F3E5F5;
            color: #7B1FA2;
        }
        
        /* ========== BUTTONS ========== */
        .btn {
            display: inline-flex;
            align-items: center;
            justify-content: center;
            gap: var(--spacing-xs);
            padding: 8px 16px;
            border: 1px solid transparent;
            border-radius: var(--border-radius-sm);
            font-size: var(--font-size-sm);
            font-weight: 600;
            font-family: var(--font-family);
            cursor: pointer;
            transition: all var(--transition-fast);
            text-decoration: none;
            white-space: nowrap;
            text-transform: uppercase;
        }
        
        .btn:disabled {
            opacity: 0.5;
            cursor: not-allowed;
        }
        
        .btn-primary {
            background: var(--fluent-primary);
            color: var(--fluent-text-on-accent);
            border-color: var(--fluent-primary);
        }
        
        .btn-primary:hover:not(:disabled) {
            background: var(--fluent-primary-hover);
            border-color: var(--fluent-primary-hover);
        }
        
        .btn-primary:active:not(:disabled) {
            background: var(--fluent-primary-pressed);
        }
        
        .btn-success {
            background: var(--fluent-success);
            color: var(--fluent-text-on-accent);
            border-color: var(--fluent-success);
        }
        
        .btn-success:hover:not(:disabled) {
            background: #0E6B0E;
            border-color: #0E6B0E;
        }
        
        .btn-warning {
            background: var(--fluent-warning);
            color: #323130;
            border-color: var(--fluent-warning);
        }
        
        .btn-danger {
            background: var(--fluent-error);
            color: var(--fluent-text-on-accent);
            border-color: var(--fluent-error);
        }
        
        .btn-danger:hover:not(:disabled) {
            background: #B52D30;
            border-color: #B52D30;
        }
        
        .btn-outline {
            background: transparent;
            color: var(--fluent-text-primary);
            border-color: var(--fluent-border-strong);
        }
        
        .btn-outline:hover:not(:disabled) {
            background: var(--fluent-bg-hover);
            border-color: var(--fluent-text-secondary);
        }
        
        .btn-sm {
            padding: 4px 10px;
            font-size: var(--font-size-xs);
        }
        
        .btn-sm:hover {
            background: var(--fluent-bg-hover);
        }
        
        .btn-icon {
            padding: 6px;
            min-width: 32px;
            height: 32px;
        }
        
        /* ========== FORMS ========== */
        .form-group {
            margin-bottom: var(--spacing-lg);
        }
        
        .form-group label {
            display: block;
            font-size: var(--font-size-sm);
            font-weight: 600;
            color: var(--fluent-text-primary);
            margin-bottom: var(--spacing-xs);
            text-transform: uppercase;
        }
        
        .form-group input,
        .form-group select,
        .form-group textarea {
            width: 100%;
            padding: 8px 12px;
            border: 1px solid var(--fluent-border);
            border-radius: var(--border-radius-sm);
            font-size: var(--font-size-sm);
            font-family: var(--font-family);
            background: var(--fluent-bg-input);
            color: var(--fluent-text-primary);
            transition: all var(--transition-fast);
        }
        
        .form-group input:focus,
        .form-group select:focus,
        .form-group textarea:focus {
            outline: none;
            border-color: var(--fluent-primary);
            box-shadow: 0 0 0 1px var(--fluent-primary);
        }
        
        .form-group input:disabled,
        .form-group select:disabled {
            background: var(--fluent-bg-disabled);
            color: var(--fluent-text-disabled);
            cursor: not-allowed;
        }
        
        .form-group input::placeholder {
            color: var(--fluent-text-disabled);
        }
        
        .form-row {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
            gap: var(--spacing-lg);
        }
        
        @media (max-width: 768px) {
            .form-row {
                grid-template-columns: 1fr;
            }
        }
        
        /* Filters */
        .filters {
            display: flex;
            flex-wrap: wrap;
            gap: var(--spacing-md);
            align-items: flex-end;
            margin-bottom: var(--spacing-lg);
            padding: var(--spacing-lg);
            background: var(--fluent-bg-card);
            border: 1px solid var(--fluent-border);
            border-radius: var(--border-radius-md);
        }
        
        .filters label {
            display: block;
            font-size: var(--font-size-xs);
            font-weight: 600;
            color: var(--fluent-text-secondary);
            margin-bottom: var(--spacing-xs);
            text-transform: uppercase;
        }
        
        .filters select,
        .filters input {
            padding: 8px 12px;
            border: 1px solid var(--fluent-border);
            border-radius: var(--border-radius-sm);
            font-size: var(--font-size-sm);
            font-family: var(--font-family);
            background: var(--fluent-bg-input);
            min-width: 150px;
        }
        
        .filters select:focus,
        .filters input:focus {
            outline: none;
            border-color: var(--fluent-primary);
            box-shadow: 0 0 0 1px var(--fluent-primary);
        }
        
        /* ========== MODALS ========== */
        .modal-overlay {
            display: none;
            position: fixed;
            top: 0;
            left: 0;
            right: 0;
            bottom: 0;
            background: rgba(0, 0, 0, 0.4);
            z-index: 1000;
            align-items: center;
            justify-content: center;
            padding: var(--spacing-lg);
        }
        
        .modal-overlay.active {
            display: flex;
        }
        
        .modal {
            background: var(--fluent-bg-card);
            border-radius: var(--border-radius-md);
            box-shadow: var(--shadow-64);
            width: 100%;
            max-width: 600px;
            max-height: 90vh;
            overflow: hidden;
            display: flex;
            flex-direction: column;
            animation: modalSlideIn 0.2s ease;
        }
        
        @keyframes modalSlideIn {
            from {
                opacity: 0;
                transform: translateY(-20px);
            }
            to {
                opacity: 1;
                transform: translateY(0);
            }
        }
        
        .modal-header {
            display: flex;
            align-items: center;
            justify-content: space-between;
            padding: var(--spacing-lg) var(--spacing-xl);
            border-bottom: 1px solid var(--fluent-border);
            background: var(--fluent-bg-secondary);
            flex-shrink: 0;
        }
        
        .modal-header h2 {
            font-size: var(--font-size-lg);
            font-weight: 600;
            color: var(--fluent-text-primary);
            margin: 0;
            text-transform: uppercase;
        }
        
        .modal-close {
            background: transparent;
            border: none;
            font-size: 24px;
            color: var(--fluent-text-secondary);
            cursor: pointer;
            padding: 4px;
            line-height: 1;
            border-radius: var(--border-radius-sm);
            transition: all var(--transition-fast);
        }
        
        .modal-close:hover {
            background: var(--fluent-bg-hover);
            color: var(--fluent-text-primary);
        }
        
        .modal-body {
            padding: var(--spacing-xl);
            overflow-y: auto;
            flex: 1;
        }
        
        .modal-footer {
            display: flex;
            justify-content: flex-end;
            gap: var(--spacing-sm);
            padding: var(--spacing-lg) var(--spacing-xl);
            border-top: 1px solid var(--fluent-border);
            background: var(--fluent-bg-secondary);
            flex-shrink: 0;
        }
        
        /* ========== TIMESHEET ========== */
        .ts-grid-v11 {
            display: grid;
            grid-template-columns: repeat(auto-fill, minmax(70px, 1fr));
            gap: var(--spacing-sm);
        }
        
        .ts-day-v11 {
            border: 1px solid var(--fluent-border);
            border-radius: var(--border-radius-sm);
            padding: var(--spacing-sm);
            text-align: center;
            background: var(--fluent-bg-card);
            transition: all var(--transition-fast);
        }
        
        .ts-day-v11:hover {
            border-color: var(--fluent-primary);
        }
        
        .ts-day-v11 input {
            width: 100%;
            padding: 4px;
            border: 1px solid var(--fluent-border);
            border-radius: var(--border-radius-sm);
            text-align: center;
            font-size: var(--font-size-sm);
            margin-top: var(--spacing-xs);
        }
        
        .ts-day-v11 input:focus {
            outline: none;
            border-color: var(--fluent-primary);
        }
        
        /* ========== ALLOCAZIONE ========== */
        #allocTotali {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
            gap: var(--spacing-md);
            margin-bottom: var(--spacing-xl);
        }
        
        /* ========== REPORT STYLES ========== */
        .report-filters {
            display: flex;
            flex-wrap: wrap;
            gap: var(--spacing-md);
            padding: var(--spacing-lg);
            background: var(--fluent-bg-card);
            border: 1px solid var(--fluent-border);
            border-radius: var(--border-radius-md);
            margin-bottom: var(--spacing-lg);
        }
        
        .report-kpis {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
            gap: var(--spacing-md);
            margin-bottom: var(--spacing-xl);
        }
        
        .kpi-card {
            background: var(--fluent-bg-card);
            border: 1px solid var(--fluent-border);
            border-radius: var(--border-radius-md);
            padding: var(--spacing-lg);
            display: flex;
            align-items: center;
            gap: var(--spacing-md);
            box-shadow: var(--shadow-2);
        }
        
        .kpi-icon {
            width: 48px;
            height: 48px;
            border-radius: var(--border-radius-md);
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 24px;
            background: var(--fluent-primary-light);
        }
        
        .kpi-value {
            font-size: var(--font-size-xl);
            font-weight: 600;
            color: var(--fluent-text-primary);
        }
        
        .kpi-label {
            font-size: var(--font-size-xs);
            color: var(--fluent-text-secondary);
        }
        
        .report-totals-grid {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
            gap: var(--spacing-md);
            margin-bottom: var(--spacing-lg);
        }
        
        .report-total-card {
            background: var(--fluent-bg-card);
            border: 1px solid var(--fluent-border);
            border-radius: var(--border-radius-md);
            padding: var(--spacing-md);
            text-align: center;
        }
        
        .total-label {
            font-size: var(--font-size-xs);
            color: var(--fluent-text-secondary);
            margin-bottom: var(--spacing-xs);
        }
        
        .total-value {
            font-size: var(--font-size-lg);
            font-weight: 600;
            color: var(--fluent-text-primary);
        }
        
        .report-table-container {
            background: var(--fluent-bg-card);
            border: 1px solid var(--fluent-border);
            border-radius: var(--border-radius-md);
            overflow: hidden;
        }
        
        .report-trend-section {
            margin-top: var(--spacing-xl);
        }
        
        .report-trend-section h3 {
            font-size: var(--font-size-md);
            font-weight: 600;
            margin-bottom: var(--spacing-md);
        }
        
        .trend-chart {
            background: var(--fluent-bg-card);
            border: 1px solid var(--fluent-border);
            border-radius: var(--border-radius-md);
            padding: var(--spacing-lg);
        }
        
        .trend-bar-container {
            display: flex;
            align-items: center;
            gap: var(--spacing-md);
            margin-bottom: var(--spacing-sm);
        }
        
        .trend-bar {
            height: 24px;
            background: var(--fluent-primary);
            border-radius: var(--border-radius-sm);
            transition: width var(--transition-slow);
        }
        
        .trend-label {
            font-size: var(--font-size-sm);
            color: var(--fluent-text-secondary);
            min-width: 60px;
        }
        
        .loading-spinner {
            display: flex;
            align-items: center;
            justify-content: center;
            padding: var(--spacing-xxl);
            color: var(--fluent-text-secondary);
        }
        
        .no-data {
            text-align: center;
            padding: var(--spacing-xxl);
            color: var(--fluent-text-secondary);
        }
        
        .report-header-left h1 {
            font-size: var(--font-size-xxl);
            font-weight: 600;
        }
        
        /* COGE Export */
        .coge-export {
            background: linear-gradient(135deg, var(--fluent-success-bg) 0%, #C8E6C9 100%);
            font-weight: 600;
        }
        
        .coge-export:hover {
            background: linear-gradient(135deg, #C8E6C9 0%, var(--fluent-success-bg) 100%);
        }
        
        /* ========== ANNO SELECT PAGE FLUENT ========== */
        /* v85.2: Layout compatto per evitare scroll */
        .anno-select-page {
            min-height: 100vh;
            background: var(--fluent-bg);
            display: flex;
            flex-direction: column;
            padding: var(--spacing-lg);
        }
        
        .anno-select-header {
            display: flex;
            justify-content: space-between;
            align-items: center;
            max-width: 900px;
            margin: 0 auto var(--spacing-lg);
            width: 100%;
        }
        
        .anno-select-logo {
            font-size: var(--font-size-md);
            font-weight: 600;
            color: var(--fluent-text-primary);
            flex: 1;
            text-align: left;
        }
        
        .anno-select-title-header {
            flex: 1;
            text-align: center;
            font-size: 20px;
            font-weight: bold;
            color: #0078D4;
        }
        
        .anno-select-user {
            display: flex;
            align-items: center;
            gap: var(--spacing-sm);
            color: var(--fluent-text-secondary);
            flex: 1;
            justify-content: flex-end;
            font-size: var(--font-size-sm);
        }
        
        .anno-select-title {
            text-align: center;
            margin-bottom: var(--spacing-lg);
        }
        
        .anno-select-title h1 {
            font-size: var(--font-size-xxl);
            font-weight: 600;
            color: var(--fluent-text-primary);
            margin-bottom: var(--spacing-xs);
        }
        
        .anno-select-title p {
            font-size: var(--font-size-sm);
            color: var(--fluent-text-secondary);
        }
        
        /* v85.2: Griglia anni compatta su 2 righe - no scroll a schermo intero */
        .anni-cards-grid {
            display: grid;
            grid-template-columns: repeat(2, 1fr);
            gap: var(--spacing-lg);
            max-width: 820px;
            margin: 0 auto;
            width: 100%;
        }
        
        .anno-card-fluent {
            background: var(--fluent-bg-card);
            border: 1px solid var(--fluent-border);
            border-radius: var(--border-radius-md);
            padding: var(--spacing-md) var(--spacing-lg);
            cursor: pointer;
            transition: all var(--transition-normal);
            position: relative;
            overflow: hidden;
            box-shadow: var(--shadow-2);
        }
        
        .anno-card-fluent::before {
            content: '';
            position: absolute;
            left: 0;
            top: 0;
            bottom: 0;
            width: 4px;
        }
        
        .anno-card-fluent[data-anno="2025"]::before { background: var(--anno-2025); }
        .anno-card-fluent[data-anno="2026"]::before { background: var(--anno-2026); }
        .anno-card-fluent[data-anno="2027"]::before { background: var(--anno-2027); }
        .anno-card-fluent[data-anno="2028"]::before { background: var(--anno-2028); }
        
        .anno-card-fluent:hover {
            box-shadow: var(--shadow-8);
            transform: translateY(-2px);
        }
        
        .anno-card-header {
            display: flex;
            align-items: center;
            gap: var(--spacing-md);
            margin-bottom: var(--spacing-sm);
        }
        
        .anno-card-icon {
            width: 36px;
            height: 36px;
            border-radius: var(--border-radius-sm);
            display: flex;
            align-items: center;
            justify-content: center;
        }
        
        .anno-card-icon svg {
            width: 22px;
            height: 22px;
        }
        
        .anno-card-fluent[data-anno="2025"] .anno-card-icon { background: var(--anno-2025-bg); }
        .anno-card-fluent[data-anno="2026"] .anno-card-icon { background: var(--anno-2026-bg); }
        .anno-card-fluent[data-anno="2027"] .anno-card-icon { background: var(--anno-2027-bg); }
        .anno-card-fluent[data-anno="2028"] .anno-card-icon { background: var(--anno-2028-bg); }
        
        /* v78: Stili per card anni non editabili (2027, 2028) */
        .anno-card-fluent.anno-disabled {
            opacity: 0.7;
            cursor: not-allowed;
            pointer-events: none;
        }
        .anno-card-fluent.anno-disabled:hover {
            transform: none;
            box-shadow: var(--shadow-4);
        }
        .anno-card-fluent.anno-disabled .anno-card-action {
            display: none;
        }
        
        .anno-card-year {
            font-size: var(--font-size-xl);
            font-weight: 600;
            color: var(--fluent-text-primary);
        }
        
        .anno-card-label {
            font-size: var(--font-size-xs);
            color: var(--fluent-text-secondary);
        }
        
        .anno-card-stats {
            display: grid;
            grid-template-columns: 1fr 1fr;
            gap: var(--spacing-sm);
            margin-bottom: var(--spacing-sm);
        }
        
        .anno-stat {
            text-align: center;
            padding: var(--spacing-xs) var(--spacing-sm);
            background: var(--fluent-bg);
            border-radius: var(--border-radius-sm);
        }
        
        .anno-stat-value {
            font-size: var(--font-size-md);
            font-weight: 600;
            color: var(--fluent-text-primary);
        }
        
        .anno-stat-label {
            font-size: 9px;
            color: var(--fluent-text-secondary);
            text-transform: uppercase;
        }
        
        .anno-card-footer {
            display: flex;
            justify-content: space-between;
            align-items: center;
        }
        
        .anno-status-badge {
            display: inline-flex;
            align-items: center;
            gap: 4px;
            padding: 2px 8px;
            border-radius: var(--border-radius-sm);
            font-size: var(--font-size-xs);
            font-weight: 600;
        }
        
        .anno-status-badge.active {
            background: var(--fluent-success-bg);
            color: var(--fluent-success);
        }
        
        .anno-status-badge.closed {
            background: var(--fluent-bg);
            color: var(--fluent-text-secondary);
        }
        
        /* v78: Stile per anni non editabili */
        .anno-status-badge.warning {
            background: #fef3c7;
            color: #92400e;
        }
        
        .anno-card-action {
            display: flex;
            align-items: center;
            gap: 4px;
            font-weight: 600;
            font-size: var(--font-size-sm);
            color: var(--fluent-primary);
        }
        
        .anno-card-action::after {
            content: '→';
            transition: transform var(--transition-fast);
        }
        
        .anno-card-fluent:hover .anno-card-action::after {
            transform: translateX(4px);
        }
        
        /* ========== HOMEPAGE CONTAINER ========== */
        .homepage-container {
            display: none;
            min-height: 100vh;
            background: var(--fluent-bg);
        }
        
        .homepage-container.active {
            display: block;
        }
        
        .homepage-header {
            position: fixed;
            top: 0;
            left: 0;
            right: 0;
            height: 56px;
            background: var(--fluent-bg-card);
            border-bottom: 1px solid var(--fluent-border);
            display: flex;
            align-items: center;
            justify-content: space-between;
            padding: 0 var(--spacing-xl);
            z-index: 1000;
            box-shadow: var(--shadow-2);
        }
        
        .homepage-header-left {
            flex: 1;
            display: flex;
            align-items: center;
        }
        
        .homepage-header-center {
            flex: 1;
            text-align: center;
            font-size: 20px;
            font-weight: bold;
            color: #0078D4;
        }
        
        .homepage-header-right {
            flex: 1;
            display: flex;
            align-items: center;
            justify-content: flex-end;
            gap: 10px;
        }
        
        .homepage-logo {
            display: flex;
            align-items: center;
            gap: var(--spacing-sm);
            font-size: var(--font-size-md);
            font-weight: 600;
            cursor: pointer;
            color: var(--fluent-text-primary);
        }
        
        .homepage-anno-btn {
            display: flex;
            align-items: center;
            gap: var(--spacing-sm);
            padding: 8px 16px;
            background: var(--fluent-primary-light);
            border: none;
            border-radius: var(--border-radius-sm);
            font-size: var(--font-size-sm);
            font-weight: 600;
            color: var(--fluent-primary);
            cursor: pointer;
            font-family: var(--font-family);
            transition: all var(--transition-fast);
        }
        
        .homepage-anno-btn:hover {
            background: #CCE0F3;
        }
        
        .homepage-user-btn {
            display: flex;
            align-items: center;
            gap: var(--spacing-sm);
            padding: 6px 12px;
            background: transparent;
            border: none;
            border-radius: var(--border-radius-sm);
            cursor: pointer;
            font-family: var(--font-family);
            transition: all var(--transition-fast);
        }
        
        .homepage-user-btn:hover {
            background: var(--fluent-bg-hover);
        }
        
        .homepage-user-avatar {
            width: 32px;
            height: 32px;
            border-radius: 50%;
            background: var(--fluent-primary);
            color: var(--fluent-text-on-accent);
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: var(--font-size-sm);
            font-weight: 600;
        }
        
        .homepage-content {
            padding-top: 80px;
            padding-left: var(--spacing-xxl);
            padding-right: var(--spacing-xxl);
            padding-bottom: var(--spacing-xxl);
            max-width: 1400px;
            margin: 0 auto;
        }
        
        .homepage-welcome {
            margin-bottom: var(--spacing-xxl);
        }
        
        .homepage-welcome h1 {
            font-size: var(--font-size-xxxl);
            font-weight: 600;
            color: var(--fluent-text-primary);
            margin-bottom: var(--spacing-xs);
        }
        
        .homepage-welcome p {
            font-size: var(--font-size-md);
            color: var(--fluent-text-secondary);
        }
        
        .modules-grid {
            display: grid;
            grid-template-columns: repeat(3, 1fr);
            gap: var(--spacing-lg);
            max-width: 900px;
            margin: 0 auto;
        }
        
        /* v96: Griglia 2x2 per dipendenti (4 o meno riquadri) */
        .modules-grid.grid-compact {
            grid-template-columns: repeat(2, 1fr);
            max-width: 600px;
        }
        
        .module-tile {
            background: var(--fluent-bg-card);
            border: 1px solid var(--fluent-border);
            border-radius: var(--border-radius-md);
            padding: var(--spacing-xl);
            cursor: pointer;
            transition: all var(--transition-normal);
            text-align: center;
            min-height: 140px;
            display: flex;
            flex-direction: column;
            align-items: center;
            justify-content: center;
            box-shadow: var(--shadow-2);
            animation: fadeIn 0.25s ease-out;
        }
        
        .module-tile:hover {
            box-shadow: var(--shadow-4);
            transform: translateY(-4px);
            border-color: var(--fluent-primary);
        }
        
        .module-tile-icon {
            display: flex;
            align-items: center;
            justify-content: center;
            width: 48px;
            height: 48px;
            margin-bottom: var(--spacing-md);
            transition: transform var(--transition-fast);
        }
        
        .module-tile-icon svg {
            width: 40px;
            height: 40px;
        }
        
        .module-tile:hover .module-tile-icon {
            transform: scale(1.1);
        }
        
        .module-tile-title {
            font-size: var(--font-size-sm);
            font-weight: 600;
            color: var(--fluent-text-primary);
            text-transform: uppercase;
        }
        
        .module-tile:hover .module-tile-title {
            color: var(--fluent-primary);
        }
        
        /* ========== MODULE FULLSCREEN HEADER ========== */
        .module-fullscreen-header {
            position: fixed;
            top: 0;
            left: 0;
            right: 0;
            height: 56px;
            background: var(--fluent-bg-card);
            border-bottom: 1px solid var(--fluent-border);
            display: none;
            align-items: center;
            justify-content: space-between;
            padding: 0 var(--spacing-xl);
            z-index: 1001;
            box-shadow: var(--shadow-2);
        }

        /* v99.40.7: Banner ambiente locale — sposta tutti gli elementi fixed */
        body.has-env-banner .sidebar,
        body.has-env-banner .homepage-header,
        body.has-env-banner .module-fullscreen-header {
            top: 34px;
        }
        body.has-env-banner #app {
            margin-top: 34px;
        }
        body.has-env-banner .anno-select-page {
            padding-top: calc(var(--spacing-lg) + 34px);
        }
        
        .module-fullscreen-header.active {
            display: flex;
        }
        
        .btn-back-home {
            background: transparent;
            border: none;
            font-size: var(--font-size-sm);
            color: var(--fluent-primary);
            cursor: pointer;
            padding: 8px 12px;
            border-radius: var(--border-radius-sm);
            margin-right: var(--spacing-lg);
            font-family: var(--font-family);
            font-weight: 600;
            transition: all var(--transition-fast);
        }
        
        .btn-back-home:hover {
            background: var(--fluent-primary-light);
        }
        
        .module-breadcrumb {
            display: flex;
            align-items: center;
            gap: var(--spacing-sm);
            font-size: var(--font-size-sm);
            text-transform: uppercase;
        }
        
        .breadcrumb-item {
            color: var(--fluent-text-secondary);
            cursor: pointer;
        }
        
        .breadcrumb-item:hover {
            color: var(--fluent-primary);
        }
        
        .breadcrumb-sep {
            color: var(--fluent-text-disabled);
        }
        
        .breadcrumb-current {
            color: var(--fluent-text-primary);
            font-weight: 500;
        }
        
        .module-title-header {
            display: flex;
            align-items: center;
            gap: var(--spacing-sm);
        }
        
        .module-title-icon {
            display: flex;
            align-items: center;
            justify-content: center;
            width: 24px;
            height: 24px;
        }
        
        .module-title-icon svg {
            width: 24px;
            height: 24px;
        }
        
        .module-title-name {
            font-size: var(--font-size-md);
            font-weight: 600;
            color: var(--fluent-text-primary);
            text-transform: uppercase;
        }
        
        /* Layout Modes */
        .homepage-mode .sidebar {
            display: none !important;
        }
        
        .homepage-mode .main-content {
            margin-left: 0 !important;
        }
        
        .homepage-mode .app-container {
            display: none;
        }
        
        .module-mode .homepage-container {
            display: none !important;
        }
        
        .module-mode .app-container {
            display: block;
        }
        
        .module-mode .sidebar {
            display: none !important;
        }
        
        .module-mode .main-content {
            margin-left: 0 !important;
            padding-top: 70px !important;
        }
        
        .module-mode .module-fullscreen-header {
            display: flex !important;
        }
        
        /* ========== DROPDOWNS ========== */
        .hp-dropdown {
            position: relative;
            display: inline-block;
        }
        
        .hp-dropdown-menu {
            position: absolute;
            top: 100%;
            right: 0;
            min-width: 200px;
            background: var(--fluent-bg-card);
            border: 1px solid var(--fluent-border);
            border-radius: var(--border-radius-md);
            box-shadow: var(--shadow-16);
            z-index: 1100;
            padding: var(--spacing-xs) 0;
            display: none;
            margin-top: var(--spacing-xs);
        }
        
        .hp-dropdown-menu.show {
            display: block;
        }
        
        .hp-dropdown-item {
            display: block;
            width: 100%;
            padding: 10px var(--spacing-lg);
            text-align: left;
            background: none;
            border: none;
            font-size: var(--font-size-sm);
            font-family: var(--font-family);
            color: var(--fluent-text-primary);
            cursor: pointer;
            transition: all var(--transition-fast);
        }
        
        .hp-dropdown-item:hover {
            background: var(--fluent-bg-hover);
        }
        
        .hp-dropdown-divider {
            height: 1px;
            background: var(--fluent-border);
            margin: var(--spacing-xs) 0;
        }
        
        /* ========== RESPONSIVE ========== */
        @media (max-width: 1024px) {
            .sidebar {
                width: 200px;
            }
            .main-content {
                margin-left: 200px;
            }
        }
        
        /* v99.30.5: Hamburger menu mobile */
        .hamburger-btn {
            display: none;
            position: fixed;
            top: 12px;
            left: 12px;
            z-index: 1100;
            background: var(--fluent-bg-card);
            border: 1px solid var(--fluent-border);
            border-radius: var(--border-radius-sm);
            width: 40px;
            height: 40px;
            align-items: center;
            justify-content: center;
            font-size: 20px;
            cursor: pointer;
            box-shadow: var(--shadow-2);
            color: var(--fluent-text-primary);
        }
        .sidebar-overlay {
            display: none;
            position: fixed;
            top: 0;
            left: 0;
            right: 0;
            bottom: 0;
            background: rgba(0,0,0,0.4);
            z-index: 99;
        }
        .sidebar-overlay.active {
            display: block;
        }

        @media (max-width: 768px) {
            .hamburger-btn {
                display: flex;
            }
            .sidebar {
                transform: translateX(-100%);
                transition: transform 0.25s ease;
                z-index: 200;
            }
            .sidebar.mobile-open {
                transform: translateX(0);
            }
            .main-content {
                margin-left: 0;
                padding: var(--spacing-lg);
                padding-top: 60px;
            }
            .stats-grid {
                grid-template-columns: 1fr;
            }
            .modules-grid {
                grid-template-columns: repeat(2, 1fr);
            }
            .homepage-content {
                padding-left: var(--spacing-lg);
                padding-right: var(--spacing-lg);
            }
            .anni-cards-grid {
                grid-template-columns: 1fr;
            }
            .module-fullscreen-header {
                padding-left: 60px;
            }
        }
        
        @media (max-width: 480px) {
            .modules-grid {
                grid-template-columns: 1fr;
            }
        }
        
        /* v99.31.2: Dashboard classes (ex inline styles) */
        .dashboard-header-cards {
            display: grid;
            grid-template-columns: repeat(4, 1fr);
            gap: 16px;
            margin-bottom: 24px;
        }
        .dash-card {
            color: #fff;
            padding: 20px;
            border-radius: 12px;
            text-align: center;
        }
        .dash-card-blue { background: linear-gradient(135deg, #3b82f6, #1d4ed8); }
        .dash-card-purple { background: linear-gradient(135deg, #8b5cf6, #6d28d9); }
        .dash-card-amber { background: linear-gradient(135deg, #f59e0b, #d97706); }
        .dash-card-green { background: linear-gradient(135deg, #10b981, #059669); }
        .dash-card .dash-num { font-size: 32px; font-weight: 700; }
        .dash-card .dash-label { font-size: 14px; opacity: 0.9; }
        .dash-two-col { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; margin-bottom: 24px; }
        .dash-section-green { border-left: 4px solid #10b981; }
        .dash-section-red { border-left: 4px solid #ef4444; }
        .dash-section-indigo { border-left: 4px solid #6366f1; }
        .dash-section-title { margin: 0 0 16px 0; display: flex; align-items: center; gap: 8px; }
        .dash-section-title.green { color: #10b981; }
        .dash-section-title.red { color: #ef4444; }
        .dash-section-title.indigo { color: #6366f1; }
        .dash-section-subtitle { font-size: 12px; font-weight: normal; color: #666; }
        .dash-table { font-size: 13px; }
        .dash-row-highlight-green { background: #f0fdf4; }
        .dash-row-highlight-red { background: #fef2f2; }
        .dash-row-total-green { background: #dcfce7; font-weight: 600; }
        .dash-row-total-red { background: #fee2e2; font-weight: 600; }
        .dash-bold { font-weight: 600; }
        .dash-sub { padding-left: 24px; color: #666; }
        .dash-val-green { font-weight: 600; color: #10b981; }
        .dash-val-red { font-weight: 600; color: #ef4444; }
        .dash-val-muted { color: #666; }
        .dash-total-val-green { color: #10b981; font-size: 15px; }
        .dash-total-val-red { color: #ef4444; font-size: 15px; }
        .dash-iva-note { font-size: 10px; color: #888; }
        .dash-iva-link { cursor: pointer; text-decoration: underline dotted; }
        .dash-kpi-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
        .dash-kpi-card { padding: 16px; border-radius: 8px; text-align: center; }
        .dash-kpi-card.ebitda { background: #f5f3ff; }
        .dash-kpi-card.margine { background: #f0fdf4; }
        .dash-kpi-card.utile { background: #fef3c7; }
        .dash-kpi-card.roi { background: #fce7f3; }
        .dash-kpi-label { font-size: 11px; font-weight: 600; margin-bottom: 4px; }
        .dash-kpi-label.ebitda { color: #6366f1; }
        .dash-kpi-label.margine { color: #10b981; }
        .dash-kpi-label.utile { color: #d97706; }
        .dash-kpi-label.roi { color: #db2777; }
        .dash-kpi-value { font-size: 24px; font-weight: 700; }
        .dash-kpi-value.ebitda { color: #4f46e5; }
        .dash-kpi-value.margine { color: #059669; }
        .dash-kpi-value.utile { color: #b45309; }
        .dash-kpi-value.roi { color: #be185d; }
        .dash-kpi-sub { font-size: 12px; color: #666; }
        .dash-edit-input { font-size: 18px; text-align: right; }

        /* v99.31.2: Custom confirm dialog */
        .smid-confirm-overlay {
            position: fixed;
            top: 0; left: 0; right: 0; bottom: 0;
            background: rgba(0,0,0,0.45);
            z-index: 10002;
            display: flex;
            align-items: center;
            justify-content: center;
            animation: fadeIn 0.15s ease-out;
        }
        .smid-confirm-box {
            background: var(--fluent-bg-card);
            border-radius: var(--border-radius-md);
            box-shadow: var(--shadow-64);
            width: 100%;
            max-width: 420px;
            padding: 24px;
            animation: modalSlideIn 0.15s ease;
        }
        .smid-confirm-msg {
            font-size: 14px;
            color: var(--fluent-text-primary);
            line-height: 1.5;
            margin-bottom: 20px;
            white-space: pre-line;
        }
        .smid-confirm-actions {
            display: flex;
            justify-content: flex-end;
            gap: 8px;
        }

        /* v99.31.2: Accessibility - focus visible */
        *:focus-visible {
            outline: 2px solid var(--fluent-primary);
            outline-offset: 2px;
        }
        button:focus-visible, .btn:focus-visible, .nav-item:focus-visible {
            outline: 2px solid var(--fluent-primary);
            outline-offset: 2px;
            border-radius: var(--border-radius-sm);
        }
        .sr-only {
            position: absolute;
            width: 1px;
            height: 1px;
            padding: 0;
            margin: -1px;
            overflow: hidden;
            clip: rect(0,0,0,0);
            white-space: nowrap;
            border: 0;
        }

        /* v99.30.7: Nav icons SVG */
        .nav-icon {
            display: inline-flex;
            align-items: center;
            justify-content: center;
            width: 18px;
            height: 18px;
            flex-shrink: 0;
        }
        .nav-icon svg {
            width: 18px;
            height: 18px;
        }
        .submenu-icon {
            display: inline-flex;
            align-items: center;
            width: 14px;
            height: 14px;
            flex-shrink: 0;
        }
        .submenu-icon svg {
            width: 14px;
            height: 14px;
        }

        /* v99.30.7: Table search bar */
        .table-search-bar {
            display: flex;
            align-items: center;
            gap: var(--spacing-sm);
            margin-bottom: var(--spacing-md);
            padding: 8px 12px;
            background: var(--fluent-bg-secondary);
            border: 1px solid var(--fluent-border);
            border-radius: var(--border-radius-sm);
        }
        .table-search-bar input {
            flex: 1;
            border: none;
            background: transparent;
            font-size: var(--font-size-sm);
            font-family: var(--font-family);
            color: var(--fluent-text-primary);
            outline: none;
            padding: 4px 0;
        }
        .table-search-bar input::placeholder {
            color: var(--fluent-text-disabled);
        }
        .table-search-icon {
            color: var(--fluent-text-secondary);
            font-size: 14px;
            flex-shrink: 0;
        }
        .table-search-count {
            font-size: var(--font-size-xs);
            color: var(--fluent-text-secondary);
            white-space: nowrap;
        }

        /* v99.30.7: Sortable table headers */
        th.sortable {
            cursor: pointer;
            user-select: none;
            position: relative;
            padding-right: 20px;
        }
        th.sortable:hover {
            background: var(--fluent-bg-hover);
        }
        th.sortable::after {
            content: '⇅';
            position: absolute;
            right: 6px;
            font-size: 10px;
            color: var(--fluent-text-disabled);
        }
        th.sortable.sort-asc::after {
            content: '▲';
            color: var(--fluent-primary);
        }
        th.sortable.sort-desc::after {
            content: '▼';
            color: var(--fluent-primary);
        }

        /* v99.30.6: Scroll-to-top button */
        .scroll-top-btn {
            position: fixed;
            bottom: 24px;
            right: 24px;
            z-index: 900;
            width: 40px;
            height: 40px;
            border-radius: 50%;
            background: var(--fluent-primary);
            color: white;
            border: none;
            font-size: 18px;
            cursor: pointer;
            box-shadow: var(--shadow-8);
            opacity: 0;
            visibility: hidden;
            transition: opacity 0.2s, visibility 0.2s, transform 0.2s;
            display: flex;
            align-items: center;
            justify-content: center;
        }
        .scroll-top-btn.visible {
            opacity: 1;
            visibility: visible;
        }
        .scroll-top-btn:hover {
            background: var(--fluent-primary-hover);
            transform: translateY(-2px);
        }

        /* v99.30.6: Tooltip CSS personalizzato */
        .smid-tooltip {
            position: fixed;
            z-index: 10001;
            padding: 6px 12px;
            background: var(--fluent-text-primary, #1a1a1a);
            color: #fff;
            font-size: 12px;
            font-weight: 400;
            text-transform: none;
            border-radius: var(--border-radius-sm, 4px);
            box-shadow: var(--shadow-8);
            pointer-events: none;
            opacity: 0;
            transition: opacity 0.15s;
            max-width: 250px;
            white-space: nowrap;
        }
        .smid-tooltip.show {
            opacity: 1;
        }

        /* ========== PRINT ========== */
        @media print {
            .sidebar, .report-filters, .report-actions, .nav-menu,
            .homepage-header, .module-fullscreen-header,
            .table-search-bar, .scroll-top-btn, .hamburger-btn {
                display: none !important;
            }
            .main-content {
                margin-left: 0 !important;
                padding-top: 0 !important;
            }
            .report-table {
                font-size: 10px;
            }
        }

        /* v98: Toast Notifications */
        .toast-container {
            position: fixed;
            top: 20px;
            right: 20px;
            z-index: 10000;
            display: flex;
            flex-direction: column;
            gap: 10px;
            pointer-events: none;
        }
        .toast {
            display: flex;
            align-items: center;
            gap: 12px;
            padding: 14px 20px;
            border-radius: 10px;
            box-shadow: 0 4px 12px rgba(0,0,0,0.15);
            font-size: 14px;
            font-weight: 500;
            animation: toastSlideIn 0.3s ease-out;
            pointer-events: auto;
            max-width: 400px;
        }
        .toast.hiding {
            animation: toastSlideOut 0.3s ease-in forwards;
        }
        .toast-success {
            background: linear-gradient(135deg, #10b981 0%, #059669 100%);
            color: white;
        }
        .toast-error {
            background: linear-gradient(135deg, #ef4444 0%, #dc2626 100%);
            color: white;
        }
        .toast-warning {
            background: linear-gradient(135deg, #f59e0b 0%, #d97706 100%);
            color: white;
        }
        .toast-info {
            background: linear-gradient(135deg, #3b82f6 0%, #2563eb 100%);
            color: white;
        }
        .toast-icon {
            font-size: 20px;
            flex-shrink: 0;
        }
        .toast-message {
            flex: 1;
            line-height: 1.4;
        }
        .toast-close {
            background: rgba(255,255,255,0.2);
            border: none;
            color: white;
            width: 24px;
            height: 24px;
            border-radius: 50%;
            cursor: pointer;
            font-size: 14px;
            display: flex;
            align-items: center;
            justify-content: center;
            flex-shrink: 0;
            transition: background 0.2s;
        }
        .toast-close:hover {
            background: rgba(255,255,255,0.3);
        }
        @keyframes toastSlideIn {
            from { transform: translateX(100%); opacity: 0; }
            to { transform: translateX(0); opacity: 1; }
        }
        @keyframes toastSlideOut {
            from { transform: translateX(0); opacity: 1; }
            to { transform: translateX(100%); opacity: 0; }
        }

        /* v98: Drag & Drop Zone */
        .drop-zone {
            border: 2px dashed #cbd5e1;
            border-radius: 12px;
            padding: 30px 20px;
            text-align: center;
            transition: all 0.3s ease;
            cursor: pointer;
            background: #f8fafc;
        }
        .drop-zone:hover {
            border-color: #0078D4;
            background: #eff6ff;
        }
        .drop-zone.drag-over {
            border-color: #0078D4;
            background: #dbeafe;
            transform: scale(1.02);
        }
        .drop-zone-icon {
            font-size: 40px;
            margin-bottom: 10px;
        }
        .drop-zone-text {
            color: #64748b;
            font-size: 14px;
        }
        .drop-zone-text strong {
            color: #0078D4;
        }
        .drop-zone input[type="file"] {
            display: none;
        }
        .drop-zone-preview {
            margin-top: 15px;
            padding: 10px;
            background: white;
            border-radius: 8px;
            display: none;
            align-items: center;
            gap: 10px;
        }
        .drop-zone-preview.has-file {
            display: flex;
        }
        .drop-zone-preview-icon {
            font-size: 24px;
        }
        .drop-zone-preview-name {
            flex: 1;
            font-size: 13px;
            color: #334155;
            overflow: hidden;
            text-overflow: ellipsis;
            white-space: nowrap;
        }
        .drop-zone-preview-remove {
            background: #fee2e2;
            border: none;
            color: #dc2626;
            width: 24px;
            height: 24px;
            border-radius: 50%;
            cursor: pointer;
            font-size: 12px;
        }
        /* v99.19: Stili TAB Modal Fornitore */
        .forn-tab.active { color: #0078D4 !important; border-bottom-color: #0078D4 !important; background: #fff !important; }
        .cli-tab.active { color: #0078D4 !important; border-bottom-color: #0078D4 !important; background: #fff !important; }
        /* v99.80.20.14.1: area drag&drop esplicita per upload file (Offerte/Ordini/Benestare) */
        .cli-dropzone { display:flex; flex-direction:column; align-items:center; justify-content:center; gap:6px; padding:18px 14px; border:2px dashed #cbd5e1; border-radius:8px; background:#f8fafc; cursor:pointer; transition:all .15s ease; text-align:center; }
        .cli-dropzone:hover { background:#eff6ff; border-color:#93c5fd; }
        .cli-dropzone.dragover { background:#dbeafe; border-color:#3b82f6; box-shadow:0 0 0 3px rgba(59,130,246,.2); }
        .cli-dropzone .cli-dropzone-icon { font-size:24px; line-height:1; color:#64748b; }
        .cli-dropzone .cli-dropzone-text { font-size:13px; color:#475569; font-weight:600; }
        .cli-dropzone .cli-dropzone-hint { font-size:11px; color:#94a3b8; }
        .cli-dropzone .cli-dropzone-filename { font-size:12px; color:#0369a1; font-weight:600; padding:4px 10px; background:#fff; border:1px solid #bfdbfe; border-radius:4px; margin-top:4px; max-width:100%; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
        .forn-tab:hover:not(.active) { background: #eef2f6 !important; color: #333 !important; }
        .forn-tab.disabled { opacity: 0.4; pointer-events: none; }
        .forn-doc-drop { border: 2px dashed #ccc; border-radius: 8px; padding: 20px; text-align: center; color: #999; transition: all 0.2s; cursor: pointer; margin-bottom: 12px; }
        .forn-doc-drop.dragover { border-color: #0078D4; background: #f0f7ff; color: #0078D4; }
        .forn-doc-table { width: 100%; border-collapse: collapse; font-size: 13px; }
        .forn-doc-table th { background: #f5f5f5; padding: 8px 10px; text-align: left; font-weight: 600; border-bottom: 2px solid #e0e0e0; }
        .forn-doc-table td { padding: 7px 10px; border-bottom: 1px solid #eee; }
        .forn-doc-table tr:hover { background: #f8f9fa; }
        .forn-progetto-card { background: #fff; border: 1px solid #e0e0e0; border-radius: 8px; padding: 12px; margin-bottom: 10px; }
        .forn-progetto-card:hover { border-color: #0078D4; }
        .forn-commessa-row { display: flex; align-items: center; gap: 8px; padding: 5px 0; font-size: 13px; border-bottom: 1px solid #f0f0f0; }
    
        /* v99.46.31: Selettore fatturato */
        .smid-selector-card {
            cursor:pointer;
            background:var(--bg-card);
            border:2px solid var(--border);
            border-radius:12px;
            padding:32px 40px;
            min-width:240px;
            text-align:center;
            transition:all .2s;
        }