    :root {
      --bg-primary: #ffffff; --bg-secondary: #f8f9fb; --bg-card: #ffffff;
      --bg-hover: #f1f3f7; --border: #e2e5eb; --border-light: #ebeef2;
      --text-primary: #1a1f2e; --text-secondary: #5a6178; --text-muted: #8b90a0;
      --accent: #1a5fb4; --accent-hover: #1752a0; --accent-light: #e8f0fc; --accent-bg: rgba(26,95,180,0.06);
      --danger: #d93025; --danger-bg: rgba(217,48,37,0.08);
      --success: #188038; --success-bg: rgba(24,128,56,0.08);
      --warning: #b05e0a; --warning-bg: rgba(176,94,10,0.08);
      --radius: 10px; --radius-lg: 16px;
      --shadow: 0 1px 3px rgba(0,0,0,0.08), 0 4px 12px rgba(0,0,0,0.04);
      --shadow-lg: 0 8px 40px rgba(0,0,0,0.15), 0 2px 10px rgba(0,0,0,0.08);
    }
    * { margin:0; padding:0; box-sizing:border-box; }
    body { font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif; background:var(--bg-secondary); color:var(--text-primary); min-height:100vh; line-height:1.5; }
    .header { background:#ffffff; border-bottom:1px solid var(--border); padding:14px 28px; display:flex; justify-content:space-between; align-items:center; position:sticky; top:0; z-index:100; box-shadow:0 1px 4px rgba(0,0,0,0.08); }
    .logo { font-size:19px; font-weight:700; color:var(--text-primary); display:flex; align-items:center; gap:12px; }
    .logo-icon { width:38px; height:38px; background:var(--accent); border-radius:10px; display:flex; align-items:center; justify-content:center; color:#fff; font-size:16px; font-weight:800; }
    .header-info { font-size:12px; color:var(--text-muted); }
    .nav { display:flex; background:#ffffff; border-bottom:1px solid var(--border); padding:0 28px; gap:0; overflow:visible; }
    .nav-btn { padding:13px 22px; background:none; border:none; color:var(--text-secondary); cursor:pointer; font-size:13px; font-weight:500; border-bottom:2px solid transparent; transition:0.2s; white-space:nowrap; }
    .nav-btn:hover { color:var(--text-primary); background:var(--bg-hover); border-bottom:2px solid rgba(26,95,180,0.3); }
    .nav-btn.active { color:var(--accent); border-bottom:3px solid var(--accent); font-weight:600; }
    .main { max-width:1200px; margin:0 auto; padding:24px; }
    .toolbar { display:flex; justify-content:space-between; align-items:center; margin-bottom:20px; flex-wrap:wrap; gap:12px; }
    .toolbar h2 { font-size:18px; font-weight:600; }
    .search-box { padding:12px 16px; height:48px; background:#fff; border:1px solid var(--border); border-radius:var(--radius); color:var(--text-primary); font-size:14px; width:260px; outline:none; transition:0.2s; }
    .search-box:focus { border-color:var(--accent); box-shadow:0 0 0 3px var(--accent-light); }
    .search-box::placeholder { color:var(--text-muted); }
    .btn { padding:8px 16px; border-radius:var(--radius); border:none; cursor:pointer; font-size:13px; font-weight:500; transition:all 0.2s ease; }
    .btn-primary { background:linear-gradient(135deg, #1a5fb4, #3584e4); color:#fff; box-shadow:0 2px 8px rgba(26,95,180,0.25); }
    .btn-primary:hover { box-shadow:0 4px 16px rgba(26,95,180,0.4); transform:translateY(-1px); background:linear-gradient(135deg, #1752a0, #2f78d4); }
    .btn-danger { background:var(--danger-bg); color:var(--danger); transition:all 0.2s ease; }
    .btn-danger:hover { background:var(--danger); color:#fff; transform:translateY(-1px); }
    .btn-success { background:var(--success-bg); color:var(--success); transition:all 0.2s ease; }
    .btn-success:hover { background:var(--success); color:#fff; transform:translateY(-1px); }
    .btn-sm { padding:5px 10px; font-size:12px; }
    .btn-ghost { background:transparent; color:var(--text-secondary); border:1px solid var(--border); transition:all 0.2s ease; }
    .btn-ghost:hover { background:var(--bg-hover); color:var(--text-primary); transform:translateY(-1px); }
    table { width:100%; border-collapse:collapse; }
    thead th { text-align:left; padding:11px 14px; font-size:11px; text-transform:uppercase; letter-spacing:0.6px; color:var(--text-muted); border-bottom:2px solid var(--border); font-weight:600; background:#f8f9fb; }
    tbody td { padding:11px 14px; font-size:13px; border-bottom:1px solid var(--border-light); vertical-align:middle; }
    tbody tr:hover { background:var(--bg-hover); }
    .badge { padding:3px 10px; border-radius:20px; font-size:11px; font-weight:600; display:inline-block; }
    .badge-success { background:var(--success-bg); color:var(--success); }
    .badge-warning { background:var(--warning-bg); color:var(--warning); }
    .badge-danger { background:var(--danger-bg); color:var(--danger); }
    .badge-info { background:var(--accent-bg); color:var(--accent); }
    .card { background:var(--bg-card); border:1px solid var(--border); border-radius:12px; padding:0; margin-bottom:16px; box-shadow:0 2px 8px rgba(0,0,0,0.06); overflow-x:auto; transition:box-shadow 0.2s; }
    .card:hover { box-shadow:0 4px 16px rgba(0,0,0,0.1); }
    .stats { display:grid; grid-template-columns:repeat(5, 1fr); gap:16px; margin-bottom:24px; }
    .stat-card { background:#fff; border:1px solid var(--border); border-radius:12px; padding:18px 20px; box-shadow:0 2px 8px rgba(0,0,0,0.06); transition:all 0.25s ease; display:flex; align-items:center; gap:14px; min-height:80px; }
    .stat-card:hover { box-shadow:0 6px 20px rgba(0,0,0,0.1); transform:translateY(-2px); }
    .stat-icon { width:44px; height:44px; border-radius:12px; display:flex; align-items:center; justify-content:center; font-size:20px; flex-shrink:0; }
    .stat-content { flex:1; min-width:0; }
    .stat-label { font-size:11px; text-transform:uppercase; letter-spacing:0.6px; color:var(--text-muted); margin-bottom:4px; font-weight:600; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
    .stat-value { font-size:26px; font-weight:700; letter-spacing:-0.5px; }
    .dash-section { background:#fff; border:1px solid var(--border); border-radius:12px; padding:20px; box-shadow:0 2px 8px rgba(0,0,0,0.06); transition:box-shadow 0.2s; }
    .dash-section:hover { box-shadow:0 4px 16px rgba(0,0,0,0.1); }
    .dash-section-header { display:flex; justify-content:space-between; align-items:center; margin-bottom:16px; }
    .dash-section-header h3 { font-size:15px; font-weight:600; display:flex; align-items:center; gap:8px; }
    .dash-section-header .dash-count { font-size:11px; background:var(--accent-bg); color:var(--accent); padding:2px 8px; border-radius:20px; font-weight:600; }
    .dash-section-header a { font-size:12px; color:var(--accent); text-decoration:none; font-weight:600; }
    .dash-section-header a:hover { text-decoration:underline; }
    .dash-row { display:flex; justify-content:space-between; align-items:center; padding:10px 0; border-bottom:1px solid var(--border-light); transition:background 0.15s; }
    .dash-row:last-child { border-bottom:none; }
    .dash-row:hover { background:var(--bg-hover); margin:0 -12px; padding:10px 12px; border-radius:8px; }
    .dash-empty { text-align:center; padding:24px 16px; color:var(--text-muted); font-size:13px; }
    .dash-empty-icon { font-size:28px; margin-bottom:8px; display:block; }
    @keyframes dashFadeUp { from { opacity:0; transform:translateY(12px); } to { opacity:1; transform:translateY(0); } }
    .dash-animate { animation:dashFadeUp 0.4s ease both; }
    .dash-animate-1 { animation-delay:0.05s; }
    .dash-animate-2 { animation-delay:0.1s; }
    .dash-animate-3 { animation-delay:0.15s; }
    .dash-animate-4 { animation-delay:0.2s; }
    .dash-animate-5 { animation-delay:0.25s; }
    @keyframes sectionFadeIn { from { opacity:0; } to { opacity:1; } }
    /* Scadenze widget */
    .scad-cat-chip { display:inline-flex; align-items:center; gap:4px; padding:4px 12px; border-radius:20px; font-size:11px; font-weight:600; border:1px solid var(--border); background:var(--bg-secondary); color:var(--text-secondary); cursor:pointer; transition:all 0.15s; white-space:nowrap; }
    .scad-cat-chip:hover { border-color:var(--accent); color:var(--accent); }
    .scad-cat-chip.active { background:var(--chip-color,var(--accent)); border-color:var(--chip-color,var(--accent)); color:#fff; }
    .scad-cat-n { font-size:10px; opacity:0.8; }
    .scad-row { display:flex; align-items:center; gap:12px; padding:10px 8px; border-bottom:1px solid var(--border-light,#ebeef2); transition:all 0.15s; border-radius:8px; }
    .scad-row:last-child { border-bottom:none; }
    .scad-row:hover { background:var(--bg-hover,#f8f9fb); box-shadow:0 2px 8px rgba(0,0,0,0.06); }
    .scad-days { min-width:48px; text-align:center; flex-shrink:0; }
    .scad-days-num { font-size:22px; font-weight:800; line-height:1; }
    .scad-days-label { font-size:9px; text-transform:uppercase; opacity:0.7; letter-spacing:0.5px; }
    .scad-icon { width:36px; height:36px; border-radius:10px; display:flex; align-items:center; justify-content:center; font-size:18px; flex-shrink:0; }
    .scad-info { flex:1; min-width:0; }
    .scad-tipo { font-size:13px; font-weight:600; color:var(--text-primary); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
    .scad-desc { font-size:11px; color:var(--text-muted); margin-top:1px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
    .scad-data { font-size:10px; color:var(--text-muted); margin-top:2px; }
    .scad-importo { font-size:14px; font-weight:700; color:var(--danger); white-space:nowrap; flex-shrink:0; }
    .scad-arrow { font-size:20px; color:var(--text-muted); opacity:0.4; flex-shrink:0; }
    @keyframes scadPulse { 0%,100% { box-shadow:0 0 0 0 rgba(217,48,37,0); } 50% { box-shadow:0 0 0 3px rgba(217,48,37,0.15); } }
    .scad-pulsar { animation:scadPulse 2s ease-in-out infinite; }
    @media (max-width:768px) {
      .scad-row { flex-wrap:wrap; gap:8px; }
      .scad-days { min-width:40px; }
      .scad-days-num { font-size:18px; }
      .scad-info { min-width:calc(100% - 120px); }
    }
    /* FullCalendar overrides */
    .fc { font-family:inherit; font-size:13px; }
    .fc .fc-toolbar-title { font-size:18px; font-weight:700; }
    .fc .fc-button { border-radius:8px; font-size:12px; padding:6px 12px; font-weight:600; border:1px solid var(--border); background:#fff; color:var(--text-primary); }
    .fc .fc-button:hover { background:var(--bg-hover,#f4f5f7); }
    .fc .fc-button-primary:not(:disabled).fc-button-active, .fc .fc-button-primary:not(:disabled):active { background:var(--accent); color:#fff; border-color:var(--accent); }
    .fc .fc-daygrid-day-top { padding:4px 6px; }
    .fc .fc-daygrid-day.fc-day-today { background:rgba(26,95,180,0.06); }
    .fc .fc-daygrid-day-number { font-size:13px; font-weight:500; }
    .fc .fc-event { border-radius:4px; padding:2px 6px; font-size:11px; border:none; cursor:pointer; }
    .fc .fc-event:hover { opacity:0.85; }
    .fc .fc-more-link { font-size:11px; font-weight:600; color:var(--accent); }
    .fc .fc-col-header-cell-cushion { font-size:12px; font-weight:600; text-transform:uppercase; color:var(--text-muted); }
    .fc-theme-standard td, .fc-theme-standard th { border-color:var(--border-light,#ebeef2); }
    .fc-theme-standard .fc-scrollgrid { border-color:var(--border-light,#ebeef2); border-radius:8px; overflow:hidden; }
    @media (max-width:768px) {
      #cal-layout { grid-template-columns:1fr !important; }
      #cal-sidebar { order:2; }
      .fc .fc-toolbar { flex-direction:column; gap:8px; }
      .fc .fc-toolbar-title { font-size:16px; }
    }
    /* Global search */
    .search-global-wrap { position:relative; flex:0 1 400px; }
    .search-global-box { position:relative; display:flex; align-items:center; }
    .search-global-icon { position:absolute; left:12px; color:var(--text-muted); pointer-events:none; }
    .search-global-input { width:100%; height:38px; padding:0 40px 0 36px; border:1px solid var(--border); border-radius:10px; font-size:13px; background:var(--bg-secondary,#f8f9fb); transition:all 0.2s; outline:none; }
    .search-global-input:focus { border-color:var(--accent); background:#fff; box-shadow:0 0 0 3px rgba(26,95,180,0.1); }
    .search-global-kbd { position:absolute; right:10px; font-size:10px; color:var(--text-muted); background:var(--bg-secondary,#ebeef2); padding:2px 6px; border-radius:4px; border:1px solid var(--border); font-family:inherit; pointer-events:none; }
    .search-global-dropdown { display:none; position:absolute; top:calc(100% + 4px); left:0; right:0; background:#fff; border:1px solid var(--border); border-radius:12px; box-shadow:0 8px 30px rgba(0,0,0,0.15); max-height:420px; overflow-y:auto; z-index:200; }
    .search-cat-header { padding:8px 16px 4px; font-size:11px; font-weight:700; color:var(--text-muted); text-transform:uppercase; letter-spacing:0.5px; display:flex; align-items:center; gap:6px; border-top:1px solid var(--border-light,#ebeef2); }
    .search-cat-header:first-child { border-top:none; }
    .search-cat-count { font-size:10px; background:var(--bg-secondary); padding:1px 6px; border-radius:10px; }
    .search-result-item { display:flex; align-items:center; gap:10px; padding:8px 16px; cursor:pointer; transition:background 0.1s; }
    .search-result-item:hover, .search-result-active { background:var(--bg-hover,#f4f5f7); }
    .search-result-icon { font-size:18px; flex-shrink:0; width:28px; text-align:center; }
    .search-result-text { flex:1; min-width:0; }
    .search-result-title { font-size:13px; font-weight:600; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
    .search-result-sub { font-size:11px; color:var(--text-muted); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; margin-top:1px; }
    .search-result-arrow { font-size:18px; color:var(--text-muted); opacity:0.3; flex-shrink:0; }
    .search-mobile-btn { display:none; background:none; border:none; cursor:pointer; color:var(--text-muted); padding:8px; }
    .search-mobile-overlay { position:fixed; top:0; left:0; right:0; bottom:0; background:#fff; z-index:10000; }
    @media (max-width:768px) {
      .search-global-wrap { display:none !important; }
      .search-mobile-btn { display:block !important; }
    }
    .scad-badge { padding:3px 10px; border-radius:20px; font-size:11px; font-weight:600; display:inline-block; }
    .scad-green { background:rgba(24,128,56,0.08); color:#188038; }
    .scad-yellow { background:rgba(176,94,10,0.08); color:#b05e0a; }
    .scad-red { background:rgba(217,48,37,0.08); color:#d93025; }
    .verifica-star { font-size:14px; cursor:help; }
    .analisi-panel { background:var(--bg-secondary); border:1px solid var(--border); border-radius:12px; padding:20px; margin-top:16px; }
    .analisi-badge-level { display:inline-flex; align-items:center; gap:4px; padding:4px 12px; border-radius:20px; font-size:11px; font-weight:600; }
    .analisi-badge-ocr { background:rgba(90,97,120,0.1); color:var(--text-secondary); }
    .analisi-badge-ai { background:rgba(26,95,180,0.1); color:var(--accent); }
    .analisi-score { display:inline-flex; align-items:center; justify-content:center; width:52px; height:52px; border-radius:50%; font-size:18px; font-weight:800; border:3px solid; }
    .analisi-score-green { color:var(--success); border-color:var(--success); background:rgba(24,128,56,0.06); }
    .analisi-score-yellow { color:var(--warning); border-color:var(--warning); background:rgba(176,94,10,0.06); }
    .analisi-score-red { color:var(--danger); border-color:var(--danger); background:rgba(217,48,37,0.06); }
    .analisi-campo { display:flex; align-items:flex-start; gap:8px; padding:6px 0; font-size:13px; border-bottom:1px solid var(--border-light); }
    .analisi-campo:last-child { border-bottom:none; }
    .analisi-campo-icon { font-size:14px; flex-shrink:0; margin-top:1px; }
    .analisi-anomalia { padding:8px 12px; border-radius:8px; font-size:12px; margin-bottom:6px; }
    .analisi-anomalia-critica { background:var(--danger-bg); border-left:3px solid var(--danger); }
    .analisi-anomalia-importante { background:var(--warning-bg); border-left:3px solid var(--warning); }
    .analisi-anomalia-minore { background:var(--accent-light); border-left:3px solid var(--accent); }
    .modal-overlay { display:none; position:fixed; inset:0; background:rgba(0,0,0,0.35); z-index:200; align-items:center; justify-content:center; backdrop-filter:blur(2px); }
    .modal-overlay.active { display:flex; animation:overlayFadeIn 0.2s ease both; }
    @keyframes overlayFadeIn { from { opacity:0; } to { opacity:1; } }
    @keyframes modalScaleIn { from { opacity:0; transform:scale(0.95) translateY(10px); } to { opacity:1; transform:scale(1) translateY(0); } }
    .modal { background:#fff; border:1px solid var(--border); border-radius:var(--radius-lg); padding:28px; width:90%; max-width:560px; max-height:85vh; overflow-y:auto; box-shadow:var(--shadow-lg); animation:modalScaleIn 0.2s ease-out both; }
    .modal h3 { margin-bottom:20px; font-size:17px; font-weight:600; }
    .form-group { margin-bottom:16px; }
    .form-group label { display:block; font-size:12px; color:var(--text-secondary); margin-bottom:5px; font-weight:600; }
    .form-group input, .form-group select, .form-group textarea { width:100%; padding:12px 16px; height:44px; background:#fff; border:1px solid var(--border); border-radius:10px; color:var(--text-primary); font-size:14px; outline:none; transition:0.2s; }
    .form-group textarea { height:auto; }
    .form-group select { cursor:pointer; }
    .form-group input:focus, .form-group select:focus, .form-group textarea:focus { border-color:var(--accent); box-shadow:0 0 0 3px rgba(26,95,180,0.15); }
    .form-group textarea { min-height:60px; resize:vertical; padding:12px 16px; }
    .form-row { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
    .form-actions { display:flex; gap:10px; justify-content:flex-end; margin-top:24px; padding-top:16px; border-top:1px solid var(--border-light); }
    .empty { text-align:center; padding:48px; color:var(--text-muted); }
    .section { display:none; }
    .section.active { display:block; animation:sectionFadeIn 0.25s ease both; }
    #toast-container { position:fixed; top:16px; right:16px; z-index:300; }
    .toast { padding:12px 18px; border-radius:var(--radius); margin-bottom:8px; font-size:13px; font-weight:500; animation:slideIn 0.3s; box-shadow:var(--shadow-lg); }
    .toast.success { background:#f0faf3; color:var(--success); border:1px solid rgba(24,128,56,0.2); }
    .toast.error { background:#fef2f1; color:var(--danger); border:1px solid rgba(217,48,37,0.2); }
    .toast.info { background:var(--accent-light); color:var(--accent); border:1px solid rgba(26,95,180,0.2); }
    @keyframes slideIn { from { transform:translateX(100%); opacity:0; } to { transform:translateX(0); opacity:1; } }
    .priority-high { border-left:3px solid var(--danger); }
    .row-done { opacity:0.45; }
    .actions { display:flex; gap:6px; }
    /* RESPONSIVE */
    @media(max-width:768px) {
      .form-row { grid-template-columns:1fr !important; }
      .toolbar { flex-direction:column; align-items:stretch; }
      .toolbar h2 { margin-bottom:8px; font-size:16px; }
      .toolbar-actions { display:flex; gap:8px; flex-wrap:wrap; }
      .search-box { width:100% !important; }
      .main { padding:12px; }
      .stats { grid-template-columns:1fr 1fr !important; gap:8px !important; }
      .stat-card { padding:10px 12px; gap:10px; min-height:auto; }
      .stat-icon { width:28px; height:28px; font-size:14px; border-radius:8px; }
      .stat-value { font-size:20px; }
      .stat-label { font-size:10px; }
      .card { border-radius:var(--radius); overflow-x:auto; -webkit-overflow-scrolling:touch; }
      table { min-width:600px; }
      thead th { padding:8px 10px; font-size:10px; }
      tbody td { padding:8px 10px; font-size:12px; }
      .btn { padding:8px 14px; font-size:12px; min-height:44px; -webkit-tap-highlight-color:transparent; }
      .btn-sm { padding:6px 10px; font-size:11px; min-height:36px; }
      .actions { gap:4px; }
      .modal-overlay.active { align-items:flex-end; }
      .modal { padding:20px; width:100%; max-width:100%; max-height:90vh; border-radius:var(--radius-lg) var(--radius-lg) 0 0; animation:modalSlideUp 0.3s ease both; }
      @keyframes modalSlideUp { from { transform:translateY(100%); } to { transform:translateY(0); } }
      .modal h3 { font-size:16px; margin-bottom:14px; }
      .form-group label { font-size:12px; }
      .form-group input, .form-group select, .form-group textarea { font-size:16px; height:48px; }
      .form-actions { flex-direction:column; }
      .form-actions .btn { width:100%; padding:14px; }
      .login-box { padding:28px 24px; width:95%; }
      .login-box h2 { font-size:22px; }
      .login-lang-select { top:12px; right:12px; }
      .login-footer { font-size:10px; padding:0 16px; }
      .tooltip-box { width:260px; right:-20px; }
      .empty { padding:24px; font-size:13px; }
      .dash-empty-icon { font-size:24px; }
      #cruscotto-grid, #cruscotto-grid2 { grid-template-columns:1fr !important; gap:12px !important; }
      .dash-section { padding:12px; }
      .dash-section-header h3 { font-size:14px; }
      .doc-tab { padding:8px 12px; font-size:12px; }
      .live-header { flex-direction:column; gap:8px; align-items:flex-start; }
      .live-steps { flex-wrap:wrap; }
      .live-step { padding:6px 12px; font-size:12px; }
      .live-body { padding:12px; }
      .live-vote-row { flex-direction:column; align-items:flex-start; gap:6px; padding:12px 8px; }
      .vote-btn { padding:8px 16px; }
      #piano-cards-grid { grid-template-columns:1fr 1fr !important; }
      #piano-usage-bars { grid-template-columns:1fr !important; }
      #toast-container { top:auto; bottom:16px; right:8px; left:8px; }
      .toast { font-size:14px; }
    }
    @media(max-width:480px) {
      .stats { grid-template-columns:1fr 1fr !important; gap:8px !important; }
      .stat-card { padding:8px 10px; }
      .stat-value { font-size:18px; }
      .stat-icon { width:24px; height:24px; font-size:12px; }
      table { min-width:500px; }
      .login-box { padding:24px 20px; }
      .login-box .form-row { grid-template-columns:1fr; }
      .login-logo-icon { width:48px; height:48px; font-size:22px; border-radius:12px; }
      .login-box h2 { font-size:20px; }
      #piano-cards-grid { grid-template-columns:1fr !important; }
    }
    /* Hover only on pointer devices */
    @media(hover:hover) {
      .stat-card:hover { box-shadow:0 6px 20px rgba(0,0,0,0.1); transform:translateY(-2px); }
      .card:hover { box-shadow:0 4px 16px rgba(0,0,0,0.1); }
      .dash-section:hover { box-shadow:0 4px 16px rgba(0,0,0,0.1); }
    }
    @media(hover:none) {
      .stat-card:hover, .card:hover, .dash-section:hover { box-shadow:none; transform:none; }
      .btn-primary:hover, .btn-danger:hover, .btn-success:hover, .btn-ghost:hover { transform:none; }
    }
    .login-page { display:flex; flex-direction:column; align-items:center; justify-content:center; min-height:100vh; gap:20px; background:linear-gradient(135deg, #0f1729 0%, #1a2744 50%, #1e3a5f 100%); position:relative; overflow:hidden; }
    .login-page::before { content:''; position:absolute; inset:0; background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.03'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E"); z-index:0; }
    .login-page .login-box { position:relative; z-index:1; }
    .login-box { background:#fff; padding:44px 40px; border-radius:var(--radius-lg); box-shadow:0 8px 40px rgba(0,0,0,0.25), 0 2px 10px rgba(0,0,0,0.1); width:420px; max-width:92%; animation:loginAppear 0.6s cubic-bezier(0.16,1,0.3,1) both; }
    @keyframes loginAppear { from { opacity:0; transform:translateY(30px); } to { opacity:1; transform:translateY(0); } }
    .login-box h2 { text-align:center; margin-bottom:6px; font-size:26px; font-weight:800; color:var(--text-primary); letter-spacing:-0.3px; }
    .login-box .subtitle { text-align:center; color:var(--text-muted); font-size:14px; margin-bottom:28px; letter-spacing:2px; text-transform:uppercase; font-weight:500; }
    .login-box .form-group { margin-bottom:16px; }
    .login-box .form-group .input-icon-wrap { position:relative; }
    .login-box .form-group .input-icon-wrap input { padding-left:42px; }
    .login-box .form-group .input-icon-wrap .input-icon { position:absolute; left:14px; top:50%; transform:translateY(-50%); color:var(--text-muted); pointer-events:none; }
    .login-box .form-group .input-icon-wrap .input-icon svg { width:16px; height:16px; display:block; }
    .login-box .btn-primary { width:100%; padding:13px; font-size:15px; font-weight:600; }
    .login-error { color:var(--danger); font-size:12px; text-align:center; margin-top:12px; display:none; }
    .login-logo-icon { width:64px; height:64px; background:linear-gradient(135deg, #1a5fb4, #3584e4); border-radius:16px; display:flex; align-items:center; justify-content:center; color:#fff; font-size:28px; font-weight:800; margin:0 auto 18px; box-shadow:0 4px 20px rgba(26,95,180,0.35); }
    .login-lang-select { position:absolute; top:16px; right:16px; padding:4px 8px; border:1px solid var(--border-light); border-radius:6px; font-size:11px; color:var(--text-muted); background:#fff; cursor:pointer; opacity:0.7; transition:opacity 0.2s; }
    .login-lang-select:hover { opacity:1; }
    .login-footer { text-align:center; margin-top:24px; font-size:11px; color:rgba(255,255,255,0.4); position:relative; z-index:1; }
    .pw-strength-bar { height:4px; background:var(--border-light); border-radius:2px; margin-top:6px; overflow:hidden; }
    .pw-strength-fill { height:100%; border-radius:2px; transition:width 0.3s, background 0.3s; width:0%; }
    .pw-strength-label { font-size:11px; margin-top:3px; min-height:16px; }
    .confirm-banner { background:var(--warning-bg); border:1px solid rgba(176,94,10,0.2); border-radius:var(--radius-lg); padding:16px 20px; margin-bottom:20px; }
    .confirm-banner strong { color:var(--warning); }
    .user-bar { display:flex; align-items:center; gap:12px; font-size:12px; color:var(--text-muted); }
    .user-bar .ruolo-badge { font-size:10px; padding:2px 8px; }
    .scadenza-alert { color:var(--danger); font-weight:600; }
    .scadenza-warning { color:var(--warning); font-weight:600; }
    .hidden { display:none !important; }
    .live-panel { display:none; position:fixed; inset:0; background:var(--bg-secondary); z-index:500; overflow-y:auto; }
    .live-panel.active { display:block; }
    .live-header { background:#fff; border-bottom:2px solid var(--accent); padding:12px 24px; display:flex; justify-content:space-between; align-items:center; position:sticky; top:0; z-index:10; }
    .live-header h2 { font-size:16px; }
    .live-steps { display:flex; gap:0; margin:0; }
    .live-step { padding:8px 20px; font-size:13px; font-weight:500; color:var(--text-muted); border-bottom:3px solid transparent; cursor:pointer; }
    .live-step.active { color:var(--accent); border-bottom-color:var(--accent); font-weight:700; }
    .live-step.done { color:var(--success); }
    .live-body { max-width:1000px; margin:0 auto; padding:24px; }
    .live-quorum { padding:16px 20px; border-radius:var(--radius-lg); margin-bottom:20px; font-size:14px; }
    .live-quorum.ok { background:var(--success-bg); border:1px solid rgba(24,128,56,0.2); }
    .live-quorum.no { background:var(--danger-bg); border:1px solid rgba(217,48,37,0.2); }
    .live-vote-row { display:flex; justify-content:space-between; align-items:center; padding:10px 12px; border-bottom:1px solid var(--border-light); }
    .live-vote-row:hover { background:var(--bg-hover); }
    .vote-btn { padding:6px 14px; border:1px solid var(--border); border-radius:var(--radius); background:#fff; cursor:pointer; font-size:12px; font-weight:600; transition:all 0.2s ease; }
    .vote-btn.sel-fav { background:var(--success); color:#fff; border-color:var(--success); }
    .vote-btn.sel-con { background:var(--danger); color:#fff; border-color:var(--danger); }
    .vote-btn.sel-ast { background:var(--warning-bg); color:var(--warning); border-color:var(--warning); }
    .ocr-progress { width:100%; height:4px; background:var(--border-light); border-radius:2px; margin-top:6px; overflow:hidden; }
    .ocr-progress-bar { height:100%; background:var(--accent); border-radius:2px; transition:width 0.3s; width:0%; }
    .ocr-tag { display:inline-block; padding:2px 8px; background:var(--accent-light); color:var(--accent); border-radius:4px; font-size:11px; margin:2px; cursor:pointer; }
    .ocr-tag:hover { background:var(--accent); color:#fff; }
    .doc-tab { padding:10px 18px; background:none; border:none; color:var(--text-secondary); cursor:pointer; font-size:13px; font-weight:500; border-bottom:2px solid transparent; margin-bottom:-2px; transition:0.2s; white-space:nowrap; }
    .doc-tab:hover { color:var(--text-primary); background:var(--bg-hover); }
    .doc-tab.active { color:var(--accent); border-bottom-color:var(--accent); font-weight:600; }
    /* NAV DROPDOWN */
    .nav-dropdown { position:relative; }
    .nav-dropdown-btn { padding:13px 22px; background:none; border:none; color:var(--text-secondary); cursor:pointer; font-size:13px; font-weight:500; border-bottom:2px solid transparent; transition:0.2s; white-space:nowrap; display:flex; align-items:center; gap:5px; }
    .nav-dropdown-btn:hover { color:var(--text-primary); background:var(--bg-hover); border-bottom:2px solid rgba(26,95,180,0.3); }
    .nav-dropdown-btn.active { color:var(--accent); border-bottom:3px solid var(--accent); font-weight:600; }
    .nav-dropdown-btn svg { width:12px; height:12px; transition:transform 0.2s; }
    .nav-dropdown.open .nav-dropdown-btn svg { transform:rotate(180deg); }
    .nav-dropdown-menu { display:none; position:absolute; top:100%; left:0; background:#fff; border:1px solid var(--border); border-radius:0 0 var(--radius-lg) var(--radius-lg); box-shadow:var(--shadow-lg); min-width:200px; z-index:120; padding:4px 0; }
    .nav-dropdown.open .nav-dropdown-menu { display:block; }
    .nav-dropdown-menu button { display:block; width:100%; text-align:left; padding:10px 18px; background:none; border:none; color:var(--text-secondary); cursor:pointer; font-size:13px; font-weight:500; transition:0.15s; }
    .nav-dropdown-menu button:hover { background:var(--bg-hover); color:var(--text-primary); }
    .nav-dropdown-menu button.active { color:var(--accent); font-weight:600; }
    /* HAMBURGER */
    .hamburger { display:none; background:none; border:none; cursor:pointer; padding:8px; color:var(--text-primary); -webkit-tap-highlight-color:transparent; }
    .hamburger svg { width:24px; height:24px; }
    /* MOBILE DRAWER */
    .drawer-overlay { display:none; position:fixed; inset:0; background:rgba(0,0,0,0.5); z-index:400; }
    .drawer-overlay.open { display:block; }
    .drawer { position:fixed; top:0; right:0; bottom:0; width:280px; max-width:85vw; background:#fff; z-index:410; transform:translateX(100%); transition:transform 0.3s ease; overflow-y:auto; -webkit-overflow-scrolling:touch; display:flex; flex-direction:column; box-shadow:-4px 0 20px rgba(0,0,0,0.15); }
    .drawer.open { transform:translateX(0); }
    .drawer-header { padding:20px 16px; border-bottom:1px solid var(--border); display:flex; justify-content:space-between; align-items:flex-start; }
    .drawer-user { font-size:14px; font-weight:600; color:var(--text-primary); word-break:break-all; }
    .drawer-badges { margin-top:6px; display:flex; gap:6px; }
    .drawer-close { background:none; border:none; font-size:28px; color:var(--text-muted); cursor:pointer; padding:0 4px; line-height:1; -webkit-tap-highlight-color:transparent; }
    .drawer-nav { flex:1; overflow-y:auto; padding:8px 0; }
    .drawer-nav-item { display:block; width:100%; text-align:left; padding:12px 16px; background:none; border:none; color:var(--text-secondary); cursor:pointer; font-size:14px; font-weight:500; transition:0.15s; -webkit-tap-highlight-color:transparent; border-left:3px solid transparent; }
    .drawer-nav-item:hover, .drawer-nav-item:active { background:var(--bg-hover); color:var(--text-primary); }
    .drawer-nav-item.active { color:var(--accent); background:var(--accent-light); border-left-color:var(--accent); font-weight:600; }
    .drawer-nav-separator { height:1px; background:var(--border); margin:8px 16px; }
    .drawer-nav-label { padding:12px 16px 4px; font-size:11px; text-transform:uppercase; letter-spacing:0.8px; color:var(--text-muted); font-weight:600; }
    .drawer-footer { padding:12px 16px; border-top:1px solid var(--border); }
    .desktop-only { display:flex; }
    @media(max-width:768px) {
      .hamburger { display:block; }
      .desktop-only { display:none !important; }
      .nav { display:none !important; }
      .header { padding:10px 12px; }
      .logo { font-size:16px; gap:8px; }
      .logo-icon { width:32px; height:32px; font-size:14px; }
      .logo-subtitle { display:none; }
    }
    @media(max-width:1024px) { #cruscotto-grid,#cruscotto-grid2{grid-template-columns:1fr!important} }
    @media(max-width:768px) { #cruscotto-grid,#cruscotto-grid2{grid-template-columns:1fr!important} }
    .cruscotto-row { display:flex; justify-content:space-between; align-items:center; padding:8px 0; border-bottom:1px solid var(--border-light); font-size:13px; }
    .cruscotto-row:last-child { border-bottom:none; }
    .cruscotto-count { font-weight:700; font-size:15px; }
    .cruscotto-bar { height:6px; background:var(--border-light); border-radius:3px; margin-top:4px; overflow:hidden; }
    .cruscotto-bar-fill { height:100%; border-radius:3px; }
    .tooltip-wrap { position:relative; display:inline-block; }
    .tooltip-box { display:none; position:absolute; bottom:calc(100% + 10px); right:0; width:340px; background:#fff; border:1px solid var(--border); border-radius:var(--radius-lg); padding:16px 18px; box-shadow:var(--shadow-lg); z-index:150; font-size:12px; line-height:1.6; color:var(--text-secondary); }
    .tooltip-box::after { content:''; position:absolute; top:100%; right:20px; border:7px solid transparent; border-top-color:#fff; }
    .tooltip-box::before { content:''; position:absolute; top:100%; right:19px; border:8px solid transparent; border-top-color:var(--border); }
    .tooltip-wrap:hover .tooltip-box { display:block; }
    .tooltip-box h4 { font-size:13px; color:var(--text-primary); margin-bottom:8px; }
    .tooltip-box ul { margin:0; padding-left:16px; }
    .tooltip-box li { margin-bottom:4px; }
    .tooltip-box .tip-section { margin-top:10px; padding-top:8px; border-top:1px solid var(--border-light); }
    /* CAPACITOR / SAFE AREA (iPhone notch) */
    @supports(padding-top: env(safe-area-inset-top)) {
      .capacitor-app .header { padding-top:calc(14px + env(safe-area-inset-top)); }
      .capacitor-app .login-page { padding-top:env(safe-area-inset-top); padding-bottom:env(safe-area-inset-bottom); }
      .capacitor-app .drawer { padding-top:env(safe-area-inset-top); }
      .capacitor-app .drawer-footer { padding-bottom:calc(12px + env(safe-area-inset-bottom)); }
      .capacitor-app .modal { padding-bottom:calc(28px + env(safe-area-inset-bottom)); }
      .capacitor-app .form-actions .btn:last-child { margin-bottom:env(safe-area-inset-bottom); }
      body.capacitor-app { padding-left:env(safe-area-inset-left); padding-right:env(safe-area-inset-right); }
    }
    .capacitor-app .login-footer { display:none; }
    /* OAUTH BUTTONS */
    .oauth-divider { display:flex; align-items:center; gap:12px; margin:22px 0 18px; color:var(--text-muted); font-size:12px; font-weight:500; }
    .oauth-divider::before, .oauth-divider::after { content:''; flex:1; height:1px; background:linear-gradient(90deg, transparent, var(--border), transparent); }
    .oauth-btn { display:flex; align-items:center; justify-content:center; gap:10px; width:100%; padding:12px 16px; border-radius:10px; font-size:14px; font-weight:500; cursor:pointer; transition:all 0.25s ease; border:1px solid; text-decoration:none; }
    .oauth-btn-google { background:#fff; color:#1f1f1f; border-color:#dadce0; }
    .oauth-btn-google:hover { background:#f7f8f8; box-shadow:0 2px 8px rgba(0,0,0,0.12); transform:translateY(-1px); }
    .oauth-btn-google svg { width:18px; height:18px; }

    /* ===== IMMOBILI TABS ===== */
    .imm-tabs { display:flex; gap:0; border-bottom:2px solid var(--border); margin:-4px -24px 16px; padding:0 24px; overflow-x:auto; -webkit-overflow-scrolling:touch; scrollbar-width:none; }
    .imm-tabs::-webkit-scrollbar { display:none; }
    .imm-tab { padding:10px 16px; border:none; background:none; font-size:12px; font-weight:600; color:var(--text-muted); cursor:pointer; border-bottom:2px solid transparent; margin-bottom:-2px; white-space:nowrap; transition:all 0.15s; position:relative; }
    .imm-tab:hover { color:var(--text-primary); }
    .imm-tab.active { color:var(--accent); border-bottom-color:var(--accent); }
    .imm-tab .imm-tab-badge { position:absolute; top:4px; right:4px; width:8px; height:8px; border-radius:50%; background:var(--danger); display:none; }
    .imm-tab.has-error .imm-tab-badge { display:block; }
    .imm-tab-panel { display:none; }
    .imm-tab-panel.active { display:block; }
    @media(max-width:768px) { .imm-tabs { margin:-4px -16px 12px; padding:0 16px; } .imm-tab { padding:8px 12px; font-size:11px; } }

    /* ===== AFFITTI BREVI ===== */
    .ab-tab-btn { padding:10px 20px; border:none; background:none; font-size:13px; font-weight:600; color:var(--text-muted); cursor:pointer; border-bottom:2px solid transparent; transition:all 0.2s; }
    .ab-tab-btn:hover { color:var(--text-primary); }
    .ab-tab-btn.active { color:#FF5A5F; border-bottom-color:#FF5A5F; }
    .ab-cal-grid { display:grid; grid-template-columns:repeat(7,1fr); gap:1px; background:var(--border); border:1px solid var(--border); border-radius:var(--radius); overflow:hidden; }
    .ab-cal-header { padding:8px 4px; text-align:center; font-size:11px; font-weight:700; text-transform:uppercase; color:var(--text-muted); background:var(--bg-secondary); }
    .ab-cal-day { min-height:80px; padding:4px 6px; background:var(--bg-card); cursor:pointer; transition:background 0.15s; position:relative; }
    .ab-cal-day:hover { background:var(--bg-hover); }
    .ab-cal-empty { background:var(--bg-secondary); cursor:default; }
    .ab-cal-empty:hover { background:var(--bg-secondary); }
    .ab-cal-today { background:var(--accent-light) !important; }
    .ab-cal-today .ab-cal-num { color:var(--accent); font-weight:700; }
    .ab-cal-num { font-size:12px; font-weight:600; color:var(--text-secondary); display:block; margin-bottom:2px; }
    .ab-cal-event { font-size:10px; padding:2px 4px; border-radius:3px; margin-bottom:1px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
    .ab-cal-more { font-size:10px; color:var(--text-muted); }
    .ab-cal-legend { display:flex; gap:16px; margin-top:12px; font-size:12px; color:var(--text-secondary); align-items:center; }
    .ab-legend-dot { display:inline-block; width:10px; height:10px; border-radius:50%; margin-right:4px; vertical-align:middle; }
    .badge-secondary { background:var(--bg-secondary); color:var(--text-secondary); }
    @media(max-width:768px) {
      .ab-cal-day { min-height:50px; padding:2px; }
      .ab-cal-event { font-size:8px; padding:1px 2px; }
      .ab-cal-num { font-size:10px; }
    }

    /* ===== PORTALE CONDOMINO ===== */
    .portale-nav { display:flex; gap:4px; margin-bottom:20px; background:#fff; border-radius:var(--radius-lg); padding:6px; box-shadow:var(--shadow); overflow-x:auto; }
    .portale-nav-btn { display:flex; flex-direction:column; align-items:center; gap:2px; padding:10px 16px; background:none; border:none; cursor:pointer; border-radius:var(--radius); color:var(--text-muted); font-size:11px; font-weight:500; transition:all 0.2s; white-space:nowrap; position:relative; min-width:0; flex:1; }
    .portale-nav-btn svg { stroke:var(--text-muted); transition:0.2s; }
    .portale-nav-btn:hover { background:var(--bg-hover); color:var(--text-primary); }
    .portale-nav-btn:hover svg { stroke:var(--text-primary); }
    .portale-nav-btn.active { background:var(--accent-light); color:var(--accent); font-weight:600; }
    .portale-nav-btn.active svg { stroke:var(--accent); }
    .portale-badge { position:absolute; top:4px; right:8px; background:var(--danger); color:#fff; font-size:10px; font-weight:700; min-width:18px; height:18px; line-height:18px; text-align:center; border-radius:9px; padding:0 5px; }
    .portale-grid { display:grid; gap:12px; margin-bottom:16px; }
    .portale-grid-3 { grid-template-columns:repeat(3, 1fr); }
    .portale-card { background:#fff; border-radius:var(--radius-lg); padding:20px; box-shadow:0 1px 3px rgba(0,0,0,0.06); border:1px solid var(--border-light); transition:all 0.2s; }
    .portale-card-clickable { cursor:pointer; }
    .portale-card-clickable:hover { box-shadow:var(--shadow); transform:translateY(-1px); }
    .portale-card-row { display:flex; align-items:center; gap:16px; }
    .portale-card-icon { width:44px; height:44px; border-radius:12px; display:flex; align-items:center; justify-content:center; flex-shrink:0; }
    .portale-banner-danger { background:rgba(217,48,37,0.06); border:1px solid rgba(217,48,37,0.2); border-radius:var(--radius-lg); padding:16px 20px; margin-bottom:16px; display:flex; align-items:center; gap:12px; color:var(--danger); cursor:pointer; font-size:14px; transition:0.2s; }
    .portale-banner-danger:hover { background:rgba(217,48,37,0.1); }

    @media(max-width:768px) {
      .portale-nav { position:fixed; bottom:0; left:0; right:0; z-index:200; border-radius:0; margin:0; padding:4px 2px; box-shadow:0 -2px 10px rgba(0,0,0,0.1); }
      .portale-nav-btn { padding:6px 4px; font-size:10px; }
      .portale-nav-btn svg { width:18px; height:18px; }
      .portale-grid-3 { grid-template-columns:1fr; }
      #portale-content { padding-bottom:80px; }
    }

    /* ===== CHATBOT AI ===== */
    .chatbot-fab {
      position:fixed; bottom:20px; right:20px; width:60px; height:60px;
      border-radius:50%; background:linear-gradient(135deg,#1a5fb4,#3584e4);
      color:#fff; display:flex; align-items:center; justify-content:center;
      cursor:pointer; box-shadow:0 4px 20px rgba(26,95,180,0.4);
      z-index:1000; transition:all 0.3s; border:none;
      animation: chatbot-pulse 3s ease-in-out infinite;
    }
    .chatbot-fab:hover { transform:scale(1.08); box-shadow:0 6px 28px rgba(26,95,180,0.5); }
    .chatbot-fab.hidden { transform:scale(0); opacity:0; pointer-events:none; }
    .chatbot-fab-badge {
      position:absolute; top:-2px; right:-2px; background:#fff; color:#1a5fb4;
      font-size:10px; font-weight:800; padding:2px 6px; border-radius:8px;
      box-shadow:0 1px 4px rgba(0,0,0,0.15);
    }
    @keyframes chatbot-pulse {
      0%, 100% { box-shadow:0 4px 20px rgba(26,95,180,0.4); }
      50% { box-shadow:0 4px 30px rgba(26,95,180,0.6); }
    }

    .chatbot-panel {
      position:fixed; bottom:0; right:0; width:380px; height:calc(100vh - 20px);
      max-height:680px; background:var(--bg-primary, #fff); border-radius:16px 0 0 0;
      box-shadow:-4px 0 30px rgba(0,0,0,0.15); z-index:1001;
      display:flex; flex-direction:column;
      transform:translateX(100%); transition:transform 0.3s cubic-bezier(0.4,0,0.2,1);
      overflow:hidden;
    }
    .chatbot-panel.open { transform:translateX(0); }

    .chatbot-header {
      background:linear-gradient(135deg,#0f1729,#1a2744); color:#fff;
      padding:16px 20px; display:flex; align-items:center; justify-content:space-between;
      flex-shrink:0;
    }
    .chatbot-avatar-sm {
      width:36px; height:36px; border-radius:10px;
      background:linear-gradient(135deg,#1a5fb4,#3584e4);
      display:flex; align-items:center; justify-content:center; color:#fff;
    }
    .chatbot-close {
      background:none; border:none; color:#fff; font-size:24px; cursor:pointer;
      opacity:0.7; transition:0.2s; padding:0; line-height:1;
    }
    .chatbot-close:hover { opacity:1; }

    .chatbot-messages {
      flex:1; overflow-y:auto; padding:16px; display:flex; flex-direction:column; gap:8px;
      scroll-behavior:smooth;
    }

    .chatbot-msg { display:flex; flex-direction:column; animation:chatbot-fadein 0.3s ease; }
    .chatbot-msg-user { align-items:flex-end; }
    .chatbot-msg-ai { align-items:flex-start; }
    @keyframes chatbot-fadein { from { opacity:0; transform:translateY(8px); } to { opacity:1; transform:translateY(0); } }

    .chatbot-ai-row { display:flex; align-items:flex-start; gap:8px; max-width:90%; }
    .chatbot-avatar-tiny {
      width:24px; height:24px; min-width:24px; border-radius:6px;
      background:var(--bg-tertiary, #e8eaed); display:flex; align-items:center; justify-content:center;
      color:var(--text-muted, #5a6178); flex-shrink:0; margin-top:2px;
    }

    .chatbot-bubble {
      padding:10px 14px; border-radius:18px; font-size:13.5px; line-height:1.55;
      word-wrap:break-word; max-width:85%;
    }
    .chatbot-bubble-user {
      background:linear-gradient(135deg,#1a5fb4,#3584e4); color:#fff;
      border-bottom-right-radius:4px;
    }
    .chatbot-bubble-ai {
      background:var(--bg-tertiary, #f0f2f5); color:var(--text-primary, #1a1f2e);
      border-bottom-left-radius:4px;
    }
    .chatbot-time { font-size:10px; color:var(--text-muted, #8b90a0); margin-top:2px; padding:0 4px; }
    .chatbot-time-right { text-align:right; }

    /* Typing indicator */
    .chatbot-typing { display:flex; align-items:center; gap:4px; padding:12px 18px; }
    .chatbot-typing span {
      width:8px; height:8px; border-radius:50%; background:var(--text-muted, #8b90a0);
      animation:chatbot-dot 1.4s ease-in-out infinite;
    }
    .chatbot-typing span:nth-child(2) { animation-delay:0.2s; }
    .chatbot-typing span:nth-child(3) { animation-delay:0.4s; }
    @keyframes chatbot-dot {
      0%, 80%, 100% { opacity:0.3; transform:scale(0.8); }
      40% { opacity:1; transform:scale(1.1); }
    }

    /* Suggestions */
    .chatbot-suggestions {
      padding:8px 16px; display:flex; flex-wrap:wrap; gap:6px; flex-shrink:0;
      border-top:1px solid var(--border-light, #ebeef2);
    }
    .chatbot-chip {
      background:var(--bg-primary, #fff); border:1px solid var(--border, #ddd);
      border-radius:20px; padding:6px 14px; font-size:12px; cursor:pointer;
      color:var(--text-primary, #333); transition:all 0.2s; white-space:nowrap;
    }
    .chatbot-chip:hover { border-color:var(--accent, #1a5fb4); color:var(--accent, #1a5fb4); background:var(--accent-light, rgba(26,95,180,0.06)); }

    /* Input area */
    .chatbot-input-area {
      padding:12px 16px; display:flex; align-items:flex-end; gap:8px;
      border-top:1px solid var(--border-light, #ebeef2); flex-shrink:0;
      background:var(--bg-primary, #fff);
    }
    .chatbot-input {
      flex:1; border:1px solid var(--border, #ddd); border-radius:20px; padding:10px 16px;
      font-size:13.5px; resize:none; outline:none; max-height:100px; min-height:40px;
      line-height:1.4; font-family:inherit; background:var(--bg-secondary, #f8f9fb);
      color:var(--text-primary, #333); transition:border-color 0.2s;
    }
    .chatbot-input:focus { border-color:var(--accent, #1a5fb4); }
    .chatbot-input::placeholder { color:var(--text-muted, #8b90a0); }
    .chatbot-send {
      width:40px; height:40px; border-radius:50%; border:none;
      background:var(--accent, #1a5fb4); color:#fff; cursor:pointer;
      display:flex; align-items:center; justify-content:center;
      transition:all 0.2s; flex-shrink:0;
    }
    .chatbot-send:disabled { background:var(--bg-tertiary, #e8eaed); color:var(--text-muted, #8b90a0); cursor:default; }
    .chatbot-send:not(:disabled):hover { background:#3584e4; transform:scale(1.05); }

    .chatbot-footer {
      padding:8px 16px; font-size:10px; color:var(--text-muted, #8b90a0);
      text-align:center; flex-shrink:0; background:var(--bg-primary, #fff);
      border-top:1px solid var(--border-light, #ebeef2);
    }

    /* Mobile */
    @media(max-width:768px) {
      .chatbot-fab { bottom:80px; right:16px; width:54px; height:54px; }
      .chatbot-panel {
        width:100%; height:100vh; max-height:100vh;
        border-radius:0; top:0; bottom:0;
      }
    }

    /* ===== IMPORT MASSIVO ===== */
    .imp-steps { display:flex; gap:0; margin-bottom:24px; border-bottom:1px solid var(--border); padding-bottom:0; }
    .imp-step { flex:1; display:flex; flex-direction:column; align-items:center; gap:6px; padding:12px 8px; position:relative; color:var(--text-muted); font-size:12px; border-bottom:3px solid transparent; transition:0.2s; }
    .imp-step-num { width:28px; height:28px; border-radius:50%; background:var(--bg-hover); color:var(--text-muted); display:flex; align-items:center; justify-content:center; font-weight:700; font-size:13px; border:2px solid var(--border); }
    .imp-step-lbl { font-weight:500; }
    .imp-step.active { color:var(--accent); border-bottom-color:var(--accent); }
    .imp-step.active .imp-step-num { background:var(--accent); color:#fff; border-color:var(--accent); }
    .imp-step.done { color:var(--success); }
    .imp-step.done .imp-step-num { background:var(--success); color:#fff; border-color:var(--success); }

    .imp-cards { display:grid; grid-template-columns:repeat(auto-fit, minmax(240px, 1fr)); gap:16px; }
    .imp-card { background:#fff; border:2px solid var(--border); border-radius:14px; padding:24px 20px; cursor:pointer; transition:all 0.2s; text-align:center; }
    .imp-card:hover { border-color:var(--accent); box-shadow:0 6px 20px rgba(26,95,180,0.12); transform:translateY(-2px); }
    .imp-card.selected { border-color:var(--accent); background:var(--accent-bg); }
    .imp-card-icon { font-size:42px; margin-bottom:10px; }
    .imp-card-title { font-size:17px; font-weight:700; color:var(--text-primary); margin-bottom:4px; }
    .imp-card-sub { font-size:12px; color:var(--text-secondary); margin-bottom:14px; }
    .imp-card-link { font-size:12px; color:var(--accent); text-decoration:none; font-weight:600; }
    .imp-card-link:hover { text-decoration:underline; }

    .imp-drop { border:2px dashed var(--border); border-radius:14px; padding:44px 24px; text-align:center; background:var(--bg-secondary); transition:0.2s; cursor:pointer; }
    .imp-drop.drag { border-color:var(--accent); background:var(--accent-bg); }
    .imp-drop-icon { font-size:56px; margin-bottom:12px; opacity:0.7; }
    .imp-drop-title { font-size:17px; font-weight:700; color:var(--text-primary); margin-bottom:6px; }
    .imp-drop-sub { font-size:12px; color:var(--text-secondary); }

    .imp-file-row { display:flex; align-items:center; gap:14px; padding:16px; background:var(--bg-secondary); border-radius:10px; border:1px solid var(--border); }
    .imp-file-ico { font-size:32px; }
    .imp-file-meta { flex:1; }
    .imp-file-name { font-weight:600; color:var(--text-primary); margin-bottom:4px; }
    .imp-file-sub { font-size:12px; color:var(--text-secondary); }

    #imp-mapping-table select { width:100%; padding:8px 10px; border:1px solid var(--border); border-radius:8px; font-size:13px; }
    #imp-preview-table th { background:var(--bg-hover); font-weight:600; font-size:12px; padding:8px 10px; }
    #imp-preview-table td { padding:8px 10px; font-size:12px; border-top:1px solid var(--border-light); }
    #imp-preview-table tr.imp-row-ok { background:rgba(24,128,56,0.04); }
    #imp-preview-table tr.imp-row-err { background:rgba(217,48,37,0.06); }
    .imp-req-asterisk { color:var(--danger); font-weight:700; margin-left:3px; }

    .imp-summary { padding:12px 16px; border-radius:10px; background:var(--bg-secondary); border:1px solid var(--border); font-size:13px; color:var(--text-secondary); }
    .imp-summary strong { color:var(--text-primary); }

    .imp-result-cards { display:grid; grid-template-columns:repeat(auto-fit, minmax(200px, 1fr)); gap:14px; }
    .imp-result-card { padding:22px 18px; border-radius:12px; text-align:center; border:1px solid var(--border); }
    .imp-result-card.ok { background:var(--success-bg); border-color:rgba(24,128,56,0.25); }
    .imp-result-card.warn { background:var(--warning-bg); border-color:rgba(176,94,10,0.25); }
    .imp-result-card.err { background:var(--danger-bg); border-color:rgba(217,48,37,0.25); }
    .imp-result-num { font-size:36px; font-weight:800; margin-bottom:4px; }
    .imp-result-card.ok .imp-result-num { color:var(--success); }
    .imp-result-card.warn .imp-result-num { color:var(--warning); }
    .imp-result-card.err .imp-result-num { color:var(--danger); }
    .imp-result-lbl { font-size:13px; font-weight:600; color:var(--text-secondary); }

    .imp-err-list { max-height:300px; overflow-y:auto; border:1px solid var(--border); border-radius:10px; padding:0; }
    .imp-err-item { padding:10px 14px; border-bottom:1px solid var(--border-light); font-size:13px; display:flex; gap:12px; }
    .imp-err-item:last-child { border-bottom:none; }
    .imp-err-row { font-weight:700; color:var(--danger); min-width:64px; }

    .imp-spinner { display:inline-block; width:48px; height:48px; border:4px solid var(--border); border-top-color:var(--accent); border-radius:50%; animation:imp-spin 0.9s linear infinite; }
    @keyframes imp-spin { to { transform:rotate(360deg); } }

    @media (max-width: 680px) {
      .imp-step-lbl { display:none; }
      .imp-cards { grid-template-columns:1fr; }
      .imp-result-cards { grid-template-columns:1fr; }
    }

    /* ===== HELP PANEL ===== */
    #help-fab {
      position:fixed; right:22px; bottom:22px; z-index:9999;
      width:52px; height:52px; border-radius:50%;
      background:linear-gradient(135deg,#1a5fb4,#3584e4); color:#fff;
      border:none; font-size:24px; font-weight:700; cursor:pointer;
      box-shadow:0 4px 14px rgba(26,95,180,0.4);
      transition:all 0.2s;
    }
    #help-fab:hover { transform:scale(1.08); box-shadow:0 6px 20px rgba(26,95,180,0.5); }
    #help-panel-overlay { position:fixed; inset:0; z-index:9998; pointer-events:none; }
    #help-panel-overlay.open { pointer-events:auto; }
    .help-backdrop {
      position:absolute; inset:0; background:rgba(10,15,30,0.4);
      opacity:0; transition:opacity 0.2s;
    }
    #help-panel-overlay.open .help-backdrop { opacity:1; }
    .help-panel {
      position:absolute; right:0; top:0; height:100%; width:min(480px, 92vw);
      background:#fff; box-shadow:-4px 0 24px rgba(0,0,0,0.15);
      display:flex; flex-direction:column;
      transform:translateX(100%); transition:transform 0.25s ease-out;
    }
    #help-panel-overlay.open .help-panel { transform:translateX(0); }
    .help-panel-head {
      display:flex; align-items:center; gap:8px; padding:14px 18px;
      border-bottom:1px solid var(--border);
    }
    .help-panel-body { flex:1; overflow-y:auto; padding:18px 22px; }
    .help-panel-content { font-size:14px; line-height:1.7; color:#333; }
    .help-panel-content h3 { font-size:16px; font-weight:700; margin:16px 0 8px; color:#1a2744; }
    .help-panel-content ol { margin:0 0 14px 22px; }
    .help-panel-content ol li { margin-bottom:8px; }
    .help-panel-content ul { margin:0 0 14px 22px; }
    .help-panel-content .g-tip {
      background:#fff8e1; border-left:4px solid #f59e0b;
      padding:10px 14px; margin:14px 0; border-radius:0 6px 6px 0;
      font-size:13px; color:#5a4410;
    }
    .help-panel-content a { color:var(--accent); font-weight:500; }
    .help-panel-content strong { color:#1a2744; }
    @media(max-width:520px) {
      #help-fab { right:16px; bottom:16px; width:48px; height:48px; font-size:22px; }
    }

    /* ===== ALLOGGIATI WEB ===== */
    .alg-alert-scaduti {
      padding:14px 18px; border-radius:10px; margin-bottom:12px;
      background:var(--danger-bg); border:2px solid var(--danger);
      color:var(--danger); font-size:14px; font-weight:600;
      display:flex; align-items:center; gap:10px;
      animation:alg-pulse 2s infinite;
    }
    .alg-alert-oggi {
      padding:12px 16px; border-radius:10px; margin-bottom:12px;
      background:var(--warning-bg); border:1px solid var(--warning);
      color:var(--warning); font-size:13px; font-weight:500;
    }
    @keyframes alg-pulse {
      0%, 100% { box-shadow:0 0 0 0 rgba(217,48,37,0.35); }
      50% { box-shadow:0 0 0 8px rgba(217,48,37,0); }
    }
    .alg-tab-btn {
      background:none; border:none; padding:14px 20px; cursor:pointer;
      font-size:14px; font-weight:500; color:var(--text-muted);
      border-bottom:3px solid transparent; transition:0.2s;
      white-space:nowrap;
    }
    .alg-tab-btn:hover { color:var(--text-primary); background:var(--bg-hover); }
    .alg-tab-btn.active { color:var(--accent); border-bottom-color:var(--accent); font-weight:600; }
    .alg-badge-stato {
      display:inline-block; padding:3px 10px; border-radius:12px; font-size:11px; font-weight:600;
    }
    .alg-badge-da_inviare { background:var(--danger-bg); color:var(--danger); }
    .alg-badge-generato { background:var(--warning-bg); color:var(--warning); }
    .alg-badge-inviato { background:var(--success-bg); color:var(--success); }
    .alg-badge-errore { background:#7a1d1d; color:#fff; }
    @media (max-width: 680px) {
      .alg-tab-btn { padding:10px 14px; font-size:13px; }
    }

    /* ===== PORTALE FORNITORI ===== */
    .pf-accent-bar {
      height:4px; background:linear-gradient(90deg,#b05e0a,#EF9F27,#b05e0a);
      border-radius:2px; margin-bottom:16px;
    }
    @keyframes pf-pulse {
      0%, 100% { opacity:1; }
      50% { opacity:0.5; }
    }
