 @import url('https://fonts.googleapis.com/css2?family=Bebas+Neue&family=DM+Sans:wght@300;400;500;600&family=DM+Mono:wght@400;500&display=swap'); :root { --bg: #0b0f1a; --surface: #131929; --surface2: #1a2236; --border: #232e45; --accent: #e8441a; --accent2: #f5a623; --green: #22c55e; --red: #ef4444; --blue: #3b82f6; --purple: #a855f7; --teal: #14b8a6; --text: #e8eaf0; --muted: #6b7a99; --card-radius: 12px; }
 * { box-sizing: border-box; margin: 0; padding: 0; }
 body { background: var(--bg); color: var(--text); font-family: 'DM Sans', sans-serif; min-height: 100vh; overflow-x: hidden; }
 /* ===== UPLOAD HUB / HOME OPERATIVA ===== */
 #upload-hub { min-height: 100vh; display: flex; flex-direction: column; align-items: center; justify-content: center; padding: 40px 24px 60px; background: radial-gradient(ellipse at 40% 20%, #1a2744 0%, var(--bg) 60%); }
 .hub-header-row { width: 100%; max-width: 1100px; display: flex; align-items: center; justify-content: space-between; margin-bottom: 36px; flex-wrap: wrap; gap: 16px; }
 .hub-home-grid { display: grid; grid-template-columns: 1fr; gap: 20px; width: 100%; max-width: 860px; }
 .hub-panel { display: flex; flex-direction: column; }
 /* KPI card — always shown, with no-data state handled via content */
 .hub-panel-kpi { background: var(--surface); border: 1px solid var(--border); border-radius: var(--card-radius); padding: 22px; cursor: pointer; transition: border-color 0.2s, box-shadow 0.2s, transform 0.15s; position: relative; overflow: hidden; flex: 1; }
 .hub-panel-kpi::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px; }
 #hub-kpi-edison::before  { background: var(--accent); }
 #hub-kpi-windtre::before { background: #00a0e0; }
 .hub-panel-kpi:hover { transform: translateY(-3px); }
 #hub-kpi-edison:hover  { border-color: rgba(232,68,26,0.5); box-shadow: 0 8px 32px rgba(232,68,26,0.12); }
 #hub-kpi-windtre:hover { border-color: rgba(0,160,224,0.5); box-shadow: 0 8px 32px rgba(0,160,224,0.12); }
 /* Disabled state (no data) */
 .hub-panel-kpi.no-data { cursor: default; opacity: 0.75; transform: none !important; box-shadow: none !important; border-color: var(--border) !important; }
 .hub-panel-kpi-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 18px; }
 .hub-panel-arrow { font-family: 'Bebas Neue', sans-serif; font-size: 22px; color: var(--accent); opacity: 0; transition: opacity 0.2s, transform 0.2s; }
 .hub-panel-arrow.wt { color: #00a0e0; }
 .hub-panel-kpi:not(.no-data):hover .hub-panel-arrow { opacity: 1; transform: translateX(4px); }
 /* KPI table */
 .hub-kpi-table { width: 100%; border-collapse: collapse; }
 .hub-kpi-table th { text-align: left; font-size: 10px; font-weight: 600; letter-spacing: 1.2px; text-transform: uppercase; color: var(--muted); padding: 0 8px 8px 0; border-bottom: 1px solid var(--border); white-space: nowrap; }
 .hub-kpi-table th:first-child { padding-left: 0; }
 .hub-kpi-table td { padding: 7px 8px 7px 0; border-bottom: 1px solid rgba(35,46,69,0.4); font-family: 'DM Mono', monospace; font-size: 13px; vertical-align: middle; white-space: nowrap; }
 .hub-kpi-table td:first-child { padding-left: 0; }
 .hub-kpi-table tr:last-child td { border-bottom: none; font-weight: 600; }
 .hub-kpi-row-label { font-family: 'DM Sans', sans-serif; font-size: 12px; font-weight: 600; color: var(--text); }
 /* No-data placeholder inside card */
 .hub-no-data-msg { padding: 28px 0 20px; text-align: center; color: var(--muted); font-size: 13px; line-height: 1.8; }
 /* KPI card footer */
 .hub-panel-kpi-footer { margin-top: 14px; padding-top: 10px; border-top: 1px solid var(--border); display: flex; align-items: center; justify-content: flex-end; gap: 10px; min-height: 36px; }
 /* Home button in topbar */
 .btn-home { background: var(--surface2); border: 1px solid var(--border); color: var(--muted); padding: 8px 16px; border-radius: 6px; font-family: 'Bebas Neue', sans-serif; font-size: 14px; letter-spacing: 1.5px; cursor: pointer; transition: all 0.2s; display: flex; align-items: center; gap: 6px; }
 .btn-home:hover { color: var(--text); border-color: var(--muted); }
 /* Shared hub element styles */
 .hub-client-badge { width: 36px; height: 36px; border-radius: 8px; display: flex; align-items: center; justify-content: center; font-family: 'Bebas Neue', sans-serif; font-size: 18px; color: #fff; flex-shrink: 0; }
 .hub-client-name { font-family: 'Bebas Neue', sans-serif; font-size: 20px; letter-spacing: 2px; color: var(--accent); }
 .hub-client-tag  { font-size: 11px; letter-spacing: 0.5px; }
 .hub-client-status { font-size: 11px; font-weight: 600; letter-spacing: 1px; text-transform: uppercase; }
 .hub-launch-btn { display: inline-flex; align-items: center; justify-content: center; gap: 8px; padding: 11px 22px; border: none; border-radius: 8px; font-family: 'Bebas Neue', sans-serif; font-size: 15px; letter-spacing: 2px; cursor: pointer; transition: all 0.2s; opacity: 0.35; pointer-events: none; }
 .hub-launch-btn:not([disabled]) { opacity: 1; pointer-events: all; }
 .hub-launch-btn:not([disabled]):hover { transform: translateY(-2px); }
 .hub-launch-edison  { background: var(--accent); color: #fff; }
 .hub-launch-windtre { background: #00a0e0; color: #fff; }
 .hub-launch-edison:not([disabled]):hover  { box-shadow: 0 6px 20px rgba(232,68,26,0.4); }
 .hub-launch-windtre:not([disabled]):hover { box-shadow: 0 6px 20px rgba(0,160,224,0.4); }
 .hub-launch-badge { width: 20px; height: 20px; border-radius: 4px; display: inline-flex; align-items: center; justify-content: center; font-size: 12px; background: rgba(255,255,255,0.25); }
 /* ===== CLIENT SELECTOR SCREEN ===== */
 #client-screen { min-height: 100vh; display: flex; flex-direction: column; align-items: center; justify-content: center; padding: 40px 24px; background: radial-gradient(ellipse at 50% 30%, #1a2744 0%, var(--bg) 60%); }
 .client-title { font-family: 'Bebas Neue', sans-serif; font-size: clamp(36px, 6vw, 72px); letter-spacing: 6px; text-align: center; margin-bottom: 12px; }
 .client-subtitle { color: var(--muted); font-size: 15px; text-align: center; margin-bottom: 56px; max-width: 500px; line-height: 1.6; }
 .client-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; width: 100%; max-width: 720px; }
 @media (max-width: 600px) { .client-grid { grid-template-columns: 1fr; }
 }
 .client-card { background: var(--surface); border: 2px solid var(--border); border-radius: 16px; padding: 40px 32px; text-align: center; cursor: pointer; transition: all 0.25s; position: relative; overflow: hidden; }
 .client-card::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 4px; transition: opacity 0.25s; }
 .client-card.edison::before { background: var(--accent); }
 .client-card.windtre::before { background: #00a0e0; }
 .client-card:hover { transform: translateY(-4px); background: var(--surface2); }
 .client-card.edison:hover { border-color: var(--accent); box-shadow: 0 12px 40px rgba(232,68,26,0.2); }
 .client-card.windtre:hover { border-color: #00a0e0; box-shadow: 0 12px 40px rgba(0,160,224,0.2); }
 .client-card-badge { width: 64px; height: 64px; border-radius: 14px; display: flex; align-items: center; justify-content: center; font-family: 'Bebas Neue', sans-serif; font-size: 26px; letter-spacing: 1px; margin: 0 auto 18px; }
 .client-card.edison .client-card-badge { background: var(--accent); color: #fff; }
 .client-card.windtre .client-card-badge { background: #00a0e0; color: #fff; }
 .client-card-name { font-family: 'Bebas Neue', sans-serif; font-size: 28px; letter-spacing: 3px; margin-bottom: 8px; }
 .client-card.edison .client-card-name { color: var(--accent); }
 .client-card.windtre .client-card-name { color: #00a0e0; }
 .client-card-desc { font-size: 12px; color: var(--muted); line-height: 1.6; }
 .client-card-tag { display: inline-block; margin-top: 14px; padding: 4px 10px; border-radius: 4px; font-size: 10px; font-weight: 600; letter-spacing: 1px; text-transform: uppercase; }
 .client-card.edison .client-card-tag { background: rgba(232,68,26,0.1); color: var(--accent); }
 .client-card.windtre .client-card-tag { background: rgba(0,160,224,0.1); color: #00a0e0; }
 /* WINDTRE color overrides */
 .windtre-theme { --wt-accent: #00a0e0; --wt-accent2: #ff6b00; }
 /* ===== WINDTRE UPLOAD SCREEN ===== */
 #wt-upload-screen { min-height: 100vh; display: none; flex-direction: column; align-items: center; justify-content: center; padding: 40px 24px; background: radial-gradient(ellipse at 70% 20%, #0d1f2d 0%, var(--bg) 60%); }
 /* ===== WINDTRE DASHBOARD ===== */
 #wt-dashboard-screen { display: none; min-height: 100vh; }
 .tab-btn.tab-wt-activity.active { border-bottom-color: #00a0e0; }
 .activity-badge.wt { background: rgba(0,160,224,0.08); border-color: rgba(0,160,224,0.3); color: #00a0e0; }
 .summary-card.wt::before { background: #00a0e0; }
 .summary-card.wt-orange::before { background: #ff6b00; }
 .wt-pill-green { background: rgba(34,197,94,0.15); color: var(--green); }
 .wt-pill-red { background: rgba(239,68,68,0.15); color: var(--red); }
 .wt-pill-blue { background: rgba(0,160,224,0.15); color: #00a0e0; }
 .wt-pill-orange { background: rgba(255,107,0,0.15); color: #ff6b00; }
 .wt-reg-table td { padding: 4px 4px; vertical-align: middle; }
 .wt-reg-table input { margin: 0; }
 .wt-detail-section { margin-bottom: 32px; }
 .wt-attivita-section { background: var(--surface); border: 1px solid var(--border); border-radius: var(--card-radius); overflow: hidden; margin-bottom: 24px; }
 .wt-attivita-header { padding: 14px 20px; background: var(--surface2); border-bottom: 1px solid var(--border); display: flex; align-items: center; justify-content: space-between; gap: 12px; }
 .wt-attivita-title { font-family: 'Bebas Neue', sans-serif; font-size: 17px; letter-spacing: 2px; color: #00a0e0; }
 tbody tr:last-child td.wt-total { background: rgba(0,160,224,0.05); color: #00a0e0; }
 /* ===== UPLOAD SCREEN (EDISON) ===== */
 #upload-screen { min-height: 100vh; display: flex; flex-direction: column; align-items: center; justify-content: center; padding: 40px 24px; background: radial-gradient(ellipse at 30% 20%, #1a2744 0%, var(--bg) 60%); }
 .logo-area { display: flex; align-items: center; gap: 14px; margin-bottom: 48px; }
 .logo-badge { width: 48px; height: 48px; background: var(--accent); border-radius: 10px; display: flex; align-items: center; justify-content: center; font-family: 'Bebas Neue', sans-serif; font-size: 22px; color: #fff; letter-spacing: 1px; }
 .logo-text { font-family: 'Bebas Neue', sans-serif; font-size: 28px; letter-spacing: 3px; color: var(--text); }
 .logo-text span { color: var(--accent); }
 .upload-title { font-family: 'Bebas Neue', sans-serif; font-size: clamp(36px, 6vw, 64px); letter-spacing: 4px; text-align: center; line-height: 1.1; margin-bottom: 16px; }
 .upload-subtitle { color: var(--muted); font-size: 15px; text-align: center; margin-bottom: 56px; max-width: 520px; line-height: 1.6; }
 .upload-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; width: 100%; max-width: 700px; margin-bottom: 32px; }
 @media (max-width: 600px) { .upload-grid { grid-template-columns: 1fr; }
 }
 .upload-zone { border: 2px dashed var(--border); border-radius: var(--card-radius); padding: 32px 24px; text-align: center; cursor: pointer; transition: all 0.2s; background: var(--surface); position: relative; }
 .upload-zone:hover, .upload-zone.drag-over { border-color: var(--accent); background: rgba(232,68,26,0.06); }
 .upload-zone.loaded { border-color: var(--green); background: rgba(34,197,94,0.05); }
 .upload-zone input[type=file] { position: absolute; inset: 0; opacity: 0; cursor: pointer; width: 100%; height: 100%; }
 .upload-icon { font-size: 32px; margin-bottom: 12px; }
 .upload-label { font-size: 13px; font-weight: 600; letter-spacing: 1.5px; text-transform: uppercase; color: var(--muted); margin-bottom: 8px; }
 .upload-name { font-family: 'DM Mono', monospace; font-size: 12px; color: var(--accent2); margin-top: 8px; word-break: break-all; }
 .upload-hint { font-size: 12px; color: var(--muted); margin-top: 4px; }
 .btn-analyze { background: var(--accent); color: #fff; border: none; padding: 16px 48px; font-family: 'Bebas Neue', sans-serif; font-size: 20px; letter-spacing: 3px; border-radius: 8px; cursor: pointer; transition: all 0.2s; opacity: 0.4; pointer-events: none; }
 .btn-analyze.ready { opacity: 1; pointer-events: all; }
 .btn-analyze.ready:hover { transform: translateY(-2px); box-shadow: 0 8px 24px rgba(232,68,26,0.4); }
 /* ===== TABS ===== */
 .tab-bar { display: flex; gap: 4px; padding: 0 32px; border-bottom: 1px solid var(--border); background: var(--surface); overflow-x: auto; }
 .tab-btn { background: none; border: none; color: var(--muted); font-family: 'Bebas Neue', sans-serif; font-size: 16px; letter-spacing: 2px; padding: 14px 20px; cursor: pointer; border-bottom: 3px solid transparent; transition: all 0.2s; white-space: nowrap; }
 .tab-btn:hover { color: var(--text); }
 .tab-btn.active { color: var(--text); border-bottom-color: var(--accent); }
 .tab-btn.tab-winback.active { border-bottom-color: var(--purple); }
 .tab-btn.tab-consolidated.active { border-bottom-color: var(--teal); }
 .tab-dot { display: inline-block; width: 8px; height: 8px; border-radius: 50%; margin-right: 8px; vertical-align: middle; }
 /* ===== DASHBOARD ===== */
 #dashboard-screen { display: none; min-height: 100vh; }
 .topbar { background: var(--surface); border-bottom: 1px solid var(--border); padding: 16px 32px; display: flex; align-items: center; justify-content: space-between; position: sticky; top: 0; z-index: 100; }
 .topbar-left { display: flex; align-items: center; gap: 16px; }
 .topbar-logo { font-family: 'Bebas Neue', sans-serif; font-size: 22px; letter-spacing: 3px; }
 .topbar-logo span { color: var(--accent); }
 .topbar-divider { width: 1px; height: 24px; background: var(--border); }
 .topbar-subtitle { font-size: 13px; color: var(--muted); font-weight: 500; letter-spacing: 0.5px; }
 .btn-reset { background: var(--surface2); border: 1px solid var(--border); color: var(--muted); padding: 8px 18px; border-radius: 6px; font-size: 13px; cursor: pointer; transition: all 0.2s; font-family: 'DM Sans', sans-serif; }
 .btn-reset:hover { color: var(--text); border-color: var(--accent); }
 .tab-panel { display: none; }
 .tab-panel.active { display: block; }
 .dashboard-body { padding: 32px; max-width: 1400px; margin: 0 auto; }
 .section-title { font-family: 'Bebas Neue', sans-serif; font-size: 22px; letter-spacing: 3px; color: var(--muted); margin-bottom: 16px; padding-bottom: 8px; border-bottom: 1px solid var(--border); }
 .section-title span { color: var(--accent); }
 .section-title span.purple { color: var(--purple); }
 .section-title span.teal { color: var(--teal); }
 /* Activity badge */
 .activity-badge { display: inline-flex; align-items: center; gap: 8px; padding: 6px 14px; border-radius: 6px; font-family: 'Bebas Neue', sans-serif; font-size: 15px; letter-spacing: 2px; margin-bottom: 24px; border: 1px solid; }
 .activity-badge.reconnection { background: rgba(232,68,26,0.08); border-color: rgba(232,68,26,0.3); color: var(--accent); }
 .activity-badge.winback { background: rgba(168,85,247,0.08); border-color: rgba(168,85,247,0.3); color: var(--purple); }
 .activity-badge.consolidated { background: rgba(20,184,166,0.08); border-color: rgba(20,184,166,0.3); color: var(--teal); }
 /* KPI Summary Cards */
 .summary-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; margin-bottom: 32px; }
 @media (max-width: 900px) { .summary-grid { grid-template-columns: repeat(2, 1fr); }
 .dashboard-body { padding: 16px; }
 .topbar { padding: 12px 16px; }
 .tab-bar { padding: 0 16px; }
 }
 .summary-card { background: var(--surface); border: 1px solid var(--border); border-radius: var(--card-radius); padding: 20px; position: relative; overflow: hidden; }
 .summary-card::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px; background: var(--accent); }
 .summary-card.green::before { background: var(--green); }
 .summary-card.blue::before { background: var(--blue); }
 .summary-card.orange::before { background: var(--accent2); }
 .summary-card.purple::before { background: var(--purple); }
 .summary-card.teal::before { background: var(--teal); }
 .card-label { font-size: 11px; font-weight: 600; letter-spacing: 1.5px; text-transform: uppercase; color: var(--muted); margin-bottom: 8px; }
 .card-value { font-family: 'Bebas Neue', sans-serif; font-size: 42px; line-height: 1; letter-spacing: 1px; color: var(--text); }
 .card-sub { font-size: 12px; color: var(--muted); margin-top: 6px; }
 /* Tables */
 .tables-section { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; margin-bottom: 32px; }
 @media (max-width: 1000px) { .tables-section { grid-template-columns: 1fr; }
 }
 .table-card { background: var(--surface); border: 1px solid var(--border); border-radius: var(--card-radius); overflow: hidden; }
 .table-card-header { padding: 16px 20px; background: var(--surface2); border-bottom: 1px solid var(--border); font-family: 'Bebas Neue', sans-serif; font-size: 17px; letter-spacing: 2px; color: var(--text); }
 table { width: 100%; border-collapse: collapse; }
 thead th { padding: 10px 14px; text-align: left; font-size: 10px; font-weight: 600; letter-spacing: 1.5px; text-transform: uppercase; color: var(--muted); background: var(--surface2); border-bottom: 1px solid var(--border); white-space: nowrap; }
 tbody td { padding: 11px 14px; font-size: 13px; border-bottom: 1px solid rgba(35,46,69,0.5); font-family: 'DM Mono', monospace; white-space: nowrap; }
 tbody tr:last-child td { border-bottom: none; background: rgba(232,68,26,0.05); font-weight: 600; color: var(--accent2); }
 tbody tr:hover:not(:last-child) td { background: rgba(255,255,255,0.02); }
 .sede-name { font-family: 'DM Sans', sans-serif; font-weight: 600; font-size: 13px; color: var(--text); }
 .pill { display: inline-block; padding: 3px 8px; border-radius: 4px; font-size: 11px; font-weight: 600; }
 .pill-green { background: rgba(34,197,94,0.15); color: var(--green); }
 .pill-red { background: rgba(239,68,68,0.15); color: var(--red); }
 .pill-orange { background: rgba(245,166,35,0.15); color: var(--accent2); }
 .pill-blue { background: rgba(59,130,246,0.15); color: var(--blue); }
 .pill-purple { background: rgba(168,85,247,0.15); color: var(--purple); }
 /* Progress bar */
 .progress-wrap { display: flex; align-items: center; gap: 8px; }
 .progress-bar { flex: 1; height: 6px; background: var(--border); border-radius: 3px; overflow: hidden; min-width: 60px; }
 .progress-fill { height: 100%; border-radius: 3px; transition: width 0.8s cubic-bezier(.4,0,.2,1); }
 .progress-label { font-family: 'DM Mono', monospace; font-size: 12px; min-width: 42px; text-align: right; }
 /* Cross KPI */
 .cross-card { background: var(--surface); border: 1px solid var(--border); border-radius: var(--card-radius); overflow: hidden; margin-bottom: 32px; }
 /* Sede detail cards */
 .sede-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 16px; margin-bottom: 32px; }
 .sede-card { background: var(--surface); border: 1px solid var(--border); border-radius: var(--card-radius); padding: 20px; transition: border-color 0.2s; }
 .sede-card:hover { border-color: rgba(232,68,26,0.4); }
 .sede-card-name { font-family: 'Bebas Neue', sans-serif; font-size: 22px; letter-spacing: 2px; margin-bottom: 16px; display: flex; align-items: center; gap: 10px; }
 .sede-dot { width: 10px; height: 10px; border-radius: 50%; background: var(--accent); display: inline-block; }
 .sede-metrics { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
 .sede-metric { background: var(--surface2); border-radius: 8px; padding: 12px; }
 .sede-metric-label { font-size: 10px; font-weight: 600; letter-spacing: 1px; text-transform: uppercase; color: var(--muted); margin-bottom: 4px; }
 .sede-metric-value { font-family: 'Bebas Neue', sans-serif; font-size: 28px; letter-spacing: 1px; }
 .stat-row { display: flex; justify-content: space-between; align-items: center; padding: 6px 0; border-bottom: 1px solid rgba(35,46,69,0.5); font-size: 13px; }
 .stat-row:last-child { border-bottom: none; }
 .stat-key { color: var(--muted); }
 .stat-val { font-family: 'DM Mono', monospace; font-weight: 500; }
 .alert-banner { background: rgba(232,68,26,0.1); border: 1px solid rgba(232,68,26,0.3); border-radius: 8px; padding: 12px 16px; font-size: 13px; color: var(--accent2); margin-bottom: 24px; }
 /* Consolidated comparison */
 .comparison-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; margin-bottom: 32px; }
 @media (max-width: 800px) { .comparison-grid { grid-template-columns: 1fr; }
 }
 .comparison-card { background: var(--surface); border: 1px solid var(--border); border-radius: var(--card-radius); overflow: hidden; }
 .comparison-header { padding: 14px 20px; background: var(--surface2); border-bottom: 1px solid var(--border); font-family: 'Bebas Neue', sans-serif; font-size: 18px; letter-spacing: 2px; display: flex; align-items: center; gap: 10px; }
 .comparison-header .dot { width: 10px; height: 10px; border-radius: 50%; display: inline-block; }
 /* ===== OPERATOR MAPPING SCREEN ===== */
 #mapping-screen { display: none; min-height: 100vh; flex-direction: column; align-items: center; padding: 40px 24px 60px; background: radial-gradient(ellipse at 70% 80%, #1a1535 0%, var(--bg) 60%); }
 .mapping-header { width: 100%; max-width: 860px; margin-bottom: 32px; }
 .mapping-title { font-family: 'Bebas Neue', sans-serif; font-size: clamp(28px, 4vw, 48px); letter-spacing: 4px; margin-bottom: 10px; }
 .mapping-title span { color: var(--purple); }
 .mapping-subtitle { color: var(--muted); font-size: 14px; line-height: 1.6; max-width: 600px; }
 .mapping-subtitle strong { color: var(--accent2); }
 .mapping-card { background: var(--surface); border: 1px solid var(--border); border-radius: var(--card-radius); overflow: hidden; width: 100%; max-width: 860px; margin-bottom: 24px; }
 .mapping-card-header { padding: 14px 20px; background: var(--surface2); border-bottom: 1px solid var(--border); display: flex; align-items: center; justify-content: space-between; }
 .mapping-card-title { font-family: 'Bebas Neue', sans-serif; font-size: 17px; letter-spacing: 2px; color: var(--text); }
 .mapping-count { font-family: 'DM Mono', monospace; font-size: 12px; color: var(--muted); }
 .mapping-table-wrap { overflow-x: auto; }
 .mapping-table { width: 100%; border-collapse: collapse; }
 .mapping-table thead th { padding: 10px 16px; text-align: left; font-size: 10px; font-weight: 600; letter-spacing: 1.5px; text-transform: uppercase; color: var(--muted); background: var(--surface2); border-bottom: 1px solid var(--border); white-space: nowrap; }
 .mapping-table tbody td { padding: 10px 16px; border-bottom: 1px solid rgba(35,46,69,0.5); font-size: 13px; vertical-align: middle; }
 .mapping-table tbody tr:last-child td { border-bottom: none; }
 .mapping-table tbody tr:hover td { background: rgba(255,255,255,0.02); }
 .op-name { font-family: 'DM Mono', monospace; font-size: 12px; color: var(--accent2); }
 .op-name.system-op { color: var(--muted); font-style: italic; }
 .op-stats { font-family: 'DM Mono', monospace; font-size: 12px; color: var(--muted); }
 .sede-select { background: var(--surface2); border: 1px solid var(--border); color: var(--text); padding: 7px 12px; border-radius: 6px; font-size: 13px; font-family: 'DM Sans', sans-serif; cursor: pointer; transition: border-color 0.2s; min-width: 180px; }
 .sede-select:focus { outline: none; border-color: var(--purple); }
 .sede-select.assigned { border-color: rgba(168,85,247,0.4); background: rgba(168,85,247,0.05); }
 .sede-select.locked { opacity: 0.55; cursor: default; pointer-events: none; border-color: var(--border); background: var(--surface2); }
 /* Sede manager */
 .sede-manager { background: var(--surface); border: 1px solid var(--border); border-radius: var(--card-radius); width: 100%; max-width: 860px; margin-bottom: 24px; overflow: hidden; }
 .sede-manager-header { padding: 14px 20px; background: var(--surface2); border-bottom: 1px solid var(--border); font-family: 'Bebas Neue', sans-serif; font-size: 17px; letter-spacing: 2px; }
 .sede-manager-body { padding: 16px 20px; display: flex; flex-wrap: wrap; gap: 10px; align-items: center; }
 .sede-chip { display: inline-flex; align-items: center; gap: 8px; background: var(--surface2); border: 1px solid var(--border); border-radius: 6px; padding: 6px 12px; font-size: 13px; font-weight: 500; }
 .sede-chip .remove-sede { background: none; border: none; color: var(--muted); cursor: pointer; font-size: 16px; padding: 0; line-height: 1; transition: color 0.15s; }
 .sede-chip .remove-sede:hover { color: var(--red); }
 .add-sede-row { display: flex; gap: 10px; align-items: center; }
 .add-sede-input { background: var(--surface2); border: 1px solid var(--border); color: var(--text); padding: 7px 12px; border-radius: 6px; font-size: 13px; font-family: 'DM Sans', sans-serif; width: 200px; transition: border-color 0.2s; }
 .add-sede-input:focus { outline: none; border-color: var(--purple); }
 .btn-add-sede { background: rgba(168,85,247,0.15); border: 1px solid rgba(168,85,247,0.3); color: var(--purple); padding: 7px 16px; border-radius: 6px; font-size: 13px; font-weight: 600; cursor: pointer; transition: all 0.2s; font-family: 'DM Sans', sans-serif; }
 .btn-add-sede:hover { background: rgba(168,85,247,0.25); border-color: var(--purple); }
 .mapping-actions { width: 100%; max-width: 860px; display: flex; gap: 12px; justify-content: flex-end; }
 .btn-mapping-back { background: var(--surface2); border: 1px solid var(--border); color: var(--muted); padding: 13px 28px; border-radius: 8px; font-family: 'Bebas Neue', sans-serif; font-size: 17px; letter-spacing: 2px; cursor: pointer; transition: all 0.2s; }
 .btn-mapping-back:hover { color: var(--text); border-color: var(--muted); }
 .btn-mapping-confirm { background: var(--purple); border: none; color: #fff; padding: 13px 36px; border-radius: 8px; font-family: 'Bebas Neue', sans-serif; font-size: 17px; letter-spacing: 2px; cursor: pointer; transition: all 0.2s; }
 .btn-mapping-confirm:hover { transform: translateY(-2px); box-shadow: 0 8px 24px rgba(168,85,247,0.4); }
 .unassigned-warning { background: rgba(245,166,35,0.08); border: 1px solid rgba(245,166,35,0.25); border-radius: 8px; padding: 10px 16px; font-size: 12px; color: var(--accent2); width: 100%; max-width: 860px; margin-bottom: 16px; display: none; }
 /* ===== UNIFIED ADMIN MODAL ===== */
 .admin-modal-header { display: flex; align-items: center; justify-content: space-between; padding: 20px 24px 16px; border-bottom: 1px solid var(--border); flex-shrink: 0; }
 .admin-modal-tabs { display: flex; gap: 2px; padding: 10px 16px 0; border-bottom: 1px solid var(--border); background: var(--surface2); flex-shrink: 0; flex-wrap: wrap; }
 .admin-modal-tab { background: none; border: none; color: var(--muted); font-family: 'Bebas Neue', sans-serif; font-size: 13px; letter-spacing: 1.5px; padding: 8px 14px; cursor: pointer; border-bottom: 3px solid transparent; transition: all 0.2s; display: flex; align-items: center; gap: 6px; white-space: nowrap; }
 .admin-modal-tab:hover { color: var(--text); }
 .admin-modal-tab.active { color: var(--text); border-bottom-color: var(--accent2); }
 .admin-modal-panel { display: none; padding: 20px 24px; overflow-y: auto; flex: 1; }
 .admin-modal-panel.active { display: block; }
 .admin-reg-section { margin-bottom: 20px; padding-bottom: 18px; border-bottom: 1px solid var(--border); }
 .admin-reg-section:last-of-type { border-bottom: none; }
 .admin-reg-title { font-family: 'Bebas Neue', sans-serif; font-size: 13px; letter-spacing: 2px; margin-bottom: 6px; display: flex; align-items: center; justify-content: space-between; }
 /* ===== ADMIN / LOGIN MODAL ===== */
 .modal-overlay { display: none; position: fixed; inset: 0; background: rgba(0,0,0,0.82); backdrop-filter: blur(4px); -webkit-backdrop-filter: blur(4px); z-index: 500; overflow-y: auto; }
 .modal-overlay.open { display: flex; align-items: center; justify-content: center; }
 #admin-login-modal.open { display: flex; align-items: center; justify-content: center; }
 /* Config panel overlay — scrolls from top */
 #admin-modal.open { align-items: flex-start; justify-content: center; padding: 20px 12px; }
 /* Config panel: centered, con max-height per scroll interno */
 #admin-config-panel { margin: 0 auto 24px; flex-shrink: 0; width: min(1100px, 96vw); max-height: calc(100vh - 40px); display: flex; flex-direction: column; }
 .modal-box { background: var(--surface); border: 1px solid var(--border); border-radius: 16px; padding: 36px 40px; width: 100%; max-width: 420px; position: relative; }
 .modal-title { font-family: 'Bebas Neue', sans-serif; font-size: 26px; letter-spacing: 3px; margin-bottom: 6px; }
 .modal-title span { color: var(--accent2); }
 .modal-subtitle { font-size: 13px; color: var(--muted); margin-bottom: 28px; }
 .modal-field { margin-bottom: 16px; }
 .modal-label { font-size: 11px; font-weight: 600; letter-spacing: 1.5px; text-transform: uppercase; color: var(--muted); display: block; margin-bottom: 6px; }
 .modal-input { width: 100%; background: var(--surface2); border: 1px solid var(--border); color: var(--text); padding: 10px 14px; border-radius: 8px; font-size: 14px; font-family: 'DM Sans', sans-serif; transition: border-color 0.2s; }
 .modal-input:focus { outline: none; border-color: var(--accent2); }
 .modal-error { background: rgba(239,68,68,0.1); border: 1px solid rgba(239,68,68,0.3); border-radius: 6px; padding: 8px 12px; font-size: 12px; color: var(--red); margin-bottom: 16px; display: none; }
 .btn-modal-confirm { width: 100%; background: var(--accent2); border: none; color: #0b0f1a; padding: 12px; border-radius: 8px; font-family: 'Bebas Neue', sans-serif; font-size: 18px; letter-spacing: 3px; cursor: pointer; transition: all 0.2s; margin-top: 4px; }
 .btn-modal-confirm:hover { opacity: 0.88; }
 .btn-modal-close { position: absolute; top: 14px; right: 16px; background: none; border: none; color: var(--muted); font-size: 20px; cursor: pointer; transition: color 0.15s; }
 .btn-modal-close:hover { color: var(--text); }
 /* ===== ADMIN PANEL SCREEN ===== */
 #admin-screen { display: none; min-height: 100vh; flex-direction: column; align-items: center; padding: 40px 24px 60px; background: radial-gradient(ellipse at 80% 10%, #1a1a10 0%, var(--bg) 60%); }
 .admin-header { width: 100%; max-width: 900px; display: flex; align-items: flex-start; justify-content: space-between; margin-bottom: 32px; flex-wrap: wrap; gap: 16px; }
 .admin-title { font-family: 'Bebas Neue', sans-serif; font-size: clamp(26px, 4vw, 44px); letter-spacing: 4px; }
 .admin-title span { color: var(--accent2); }
 .btn-admin-back { background: var(--surface2); border: 1px solid var(--border); color: var(--muted); padding: 10px 20px; border-radius: 8px; font-family: 'Bebas Neue', sans-serif; font-size: 15px; letter-spacing: 2px; cursor: pointer; transition: all 0.2s; white-space: nowrap; }
 .btn-admin-back:hover { color: var(--text); border-color: var(--muted); }
 .admin-card { background: var(--surface); border: 1px solid var(--border); border-radius: var(--card-radius); overflow: hidden; width: 100%; max-width: 900px; margin-bottom: 24px; }
 .admin-card-header { padding: 14px 20px; background: var(--surface2); border-bottom: 1px solid var(--border); display: flex; align-items: center; justify-content: space-between; gap: 12px; flex-wrap: wrap; }
 .admin-card-title { font-family: 'Bebas Neue', sans-serif; font-size: 17px; letter-spacing: 2px; }
 .admin-card-title span { color: var(--accent2); }
 .admin-table { width: 100%; border-collapse: collapse; }
 .admin-table thead th { padding: 10px 16px; text-align: left; font-size: 10px; font-weight: 600; letter-spacing: 1.5px; text-transform: uppercase; color: var(--muted); background: var(--surface2); border-bottom: 1px solid var(--border); white-space: nowrap; }
 .admin-table tbody td { padding: 9px 16px; border-bottom: 1px solid rgba(35,46,69,0.5); font-size: 13px; vertical-align: middle; }
 .admin-table tbody tr:last-child td { border-bottom: none; }
 .admin-table tbody tr:hover td { background: rgba(255,255,255,0.02); }
 .obj-input { background: var(--surface2); border: 1px solid var(--border); color: var(--text); padding: 6px 10px; border-radius: 6px; font-size: 13px; font-family: 'DM Mono', monospace; width: 90px; text-align: right; transition: border-color 0.2s; }
 .obj-input:focus { outline: none; border-color: var(--accent2); }
 .obj-input-pct { display: inline-flex; align-items: center; gap: 4px; }
 .obj-input-pct span { font-size: 13px; color: var(--muted); font-family: 'DM Mono', monospace; }
 .btn-add-row { background: rgba(245,166,35,0.12); border: 1px solid rgba(245,166,35,0.25); color: var(--accent2); padding: 6px 14px; border-radius: 6px; font-size: 12px; font-weight: 600; cursor: pointer; transition: all 0.2s; font-family: 'DM Sans', sans-serif; white-space: nowrap; }
 .btn-add-row:hover { background: rgba(245,166,35,0.2); border-color: var(--accent2); }
 .btn-remove-row { background: none; border: none; color: var(--muted); cursor: pointer; font-size: 16px; padding: 2px 6px; border-radius: 4px; transition: all 0.15s; line-height: 1; }
 .btn-remove-row:hover { color: var(--red); background: rgba(239,68,68,0.1); }
 .admin-select { background: var(--surface2); border: 1px solid var(--border); color: var(--text); padding: 5px 8px; border-radius: 6px; font-size: 12px; font-family: 'DM Sans', sans-serif; cursor: pointer; min-width: 100px; width: 100%; transition: border-color 0.2s; }
 .admin-select:focus { outline: none; border-color: var(--accent2); }
 .btn-save-admin { background: var(--accent2); border: none; color: #0b0f1a; padding: 13px 40px; border-radius: 8px; font-family: 'Bebas Neue', sans-serif; font-size: 18px; letter-spacing: 3px; cursor: pointer; transition: all 0.2s; }
 .btn-save-admin:hover { opacity: 0.88; transform: translateY(-1px); }
 .admin-save-row { width: 100%; max-width: 900px; display: flex; justify-content: flex-end; gap: 12px; }
 .admin-info-badge { display: inline-flex; align-items: center; gap: 8px; padding: 5px 12px; border-radius: 6px; font-size: 12px; font-weight: 500; background: rgba(245,166,35,0.08); border: 1px solid rgba(245,166,35,0.2); color: var(--accent2); }
 /* Settings button in topbar */
 .btn-settings { background: var(--surface2); border: 1px solid var(--border); color: var(--muted); padding: 8px 14px; border-radius: 6px; font-size: 13px; cursor: pointer; transition: all 0.2s; font-family: 'DM Sans', sans-serif; display: flex; align-items: center; gap: 6px; }
 .btn-settings:hover { color: var(--accent2); border-color: var(--accent2); }
 /* Loading */
 #loading { display: none; position: fixed; inset: 0; background: rgba(11,15,26,0.9); z-index: 999; align-items: center; justify-content: center; flex-direction: column; gap: 16px; }
 .spinner { width: 40px; height: 40px; border: 3px solid var(--border); border-top-color: var(--accent); border-radius: 50%; animation: spin 0.8s linear infinite; }
 @keyframes spin { to { transform: rotate(360deg); } }
 .loading-text { font-family: 'Bebas Neue', sans-serif; font-size: 18px; letter-spacing: 3px; color: var(--muted); }
 /* ===== NEW ADMIN PANEL — 3 CARDS ===== */
 .admin-modal-config { background: var(--surface); border: 1px solid var(--border); border-radius: 16px; width: min(1100px, 96vw); max-height: calc(100vh - 40px); display: flex; flex-direction: column; overflow: hidden; /* il contenuto scorrerà nel pannello */
 }
 /* top bar */
 .adm-topbar { display: flex; align-items: center; justify-content: space-between; padding: 16px 24px; border-bottom: 1px solid var(--border); flex-shrink: 0; background: var(--surface2); border-radius: 16px 16px 0 0; }
 .adm-topbar-title { font-family: 'Bebas Neue', sans-serif; font-size: 20px; letter-spacing: 3px; }
 .adm-role-badge { display: inline-flex; align-items: center; gap: 6px; padding: 4px 10px; border-radius: 20px; font-size: 11px; font-weight: 600; letter-spacing: 1px; text-transform: uppercase; }
 .adm-role-super { background: rgba(245,166,35,0.15); color: var(--accent2); border: 1px solid rgba(245,166,35,0.3); }
 .adm-role-manager { background: rgba(59,130,246,0.15); color: var(--blue); border: 1px solid rgba(59,130,246,0.3); }
 .adm-role-it { background: rgba(34,197,94,0.15); color: var(--green); border: 1px solid rgba(34,197,94,0.3); }
 .adm-role-tl { background: rgba(168,85,247,0.15); color: var(--purple); border: 1px solid rgba(168,85,247,0.3); }
 /* Selezione clienti Team Leader */
 .tl-clients-wrap { display: none; flex-direction: column; gap: 8px; margin-top: 2px; }
 .tl-clients-wrap.visible { display: flex; }
 .tl-clients-info { font-size: 11px; color: var(--muted); line-height: 1.5; padding: 8px 10px; background: rgba(168,85,247,0.06); border: 1px solid rgba(168,85,247,0.2); border-radius: 6px; }
 .tl-client-checks { display: flex; gap: 10px; flex-wrap: wrap; }
 .tl-client-check { display: flex; align-items: center; gap: 7px; padding: 9px 14px; border-radius: 8px; border: 1.5px solid var(--border); background: var(--surface2); cursor: pointer; transition: all 0.18s; font-family: 'Bebas Neue', sans-serif; font-size: 14px; letter-spacing: 1.5px; user-select: none; flex: 1; justify-content: center; }
 .tl-client-check:has(input:checked).edison-check { border-color: rgba(232,68,26,0.6); background: rgba(232,68,26,0.1); color: var(--accent); }
 .tl-client-check:has(input:checked).wind-check { border-color: rgba(0,160,224,0.6); background: rgba(0,160,224,0.1); color: #00a0e0; }
 .tl-client-check:has(input:checked).tim-check  { border-color: rgba(0,48,135,0.6); background: rgba(0,48,135,0.1); color: #003087; }
 .tl-client-check input[type=checkbox] { accent-color: var(--purple); width: 14px; height: 14px; cursor: pointer; }
 /* Lista utenti: mostra cliente TL */
 .cred-user-clients { display: flex; gap: 4px; margin-top: 3px; flex-wrap: wrap; }
 .cred-client-pill { font-size: 9px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase; padding: 2px 6px; border-radius: 3px; }
 .cred-client-pill.edison { background: rgba(232,68,26,0.15); color: var(--accent); }
 .cred-client-pill.wind   { background: rgba(0,160,224,0.15); color: #00a0e0; }
 /* tab bar */
 .adm-tabs { flex-shrink: 0; display: flex; gap: 2px; padding: 0 20px; border-bottom: 1px solid var(--border); background: var(--surface); overflow-x: auto; }
 .adm-tab { background: none; border: none; color: var(--muted); font-family: 'Bebas Neue', sans-serif; font-size: 13px; letter-spacing: 1.5px; padding: 12px 18px 10px; cursor: pointer; border-bottom: 3px solid transparent; transition: all 0.2s; display: flex; align-items: center; gap: 7px; white-space: nowrap; flex-shrink: 0; }
 .adm-tab:hover { color: var(--text); }
 .adm-tab.active { color: var(--text); border-bottom-color: var(--accent2); }
 .adm-tab-icon { width: 18px; height: 18px; border-radius: 4px; display: inline-flex; align-items: center; justify-content: center; font-size: 10px; font-family: 'Bebas Neue', sans-serif; color: #fff; flex-shrink: 0; }
 /* panel body */
 .adm-panel { display: none; padding: 20px 24px; overflow-y: auto; flex: 1; /* max-height è gestita dal container padre */
 }
 .adm-panel.active { display: block; }
 /* ─── Pannello Manager ─── */
 .pm-client-block { margin-bottom: 16px; border: 1px solid var(--border); border-radius: 10px; overflow: hidden; }
 .pm-client-header { display: flex; align-items: center; justify-content: space-between; padding: 10px 16px; background: var(--surface2); cursor: pointer; user-select: none; gap: 10px; }
 .pm-client-header:hover { background: rgba(255,255,255,0.03); }
 .pm-client-name { font-family: 'Bebas Neue', sans-serif; font-size: 15px; letter-spacing: 2px; display: flex; align-items: center; gap: 8px; }
 .pm-chevron { font-size: 12px; color: var(--muted); transition: transform 0.2s; }
 .pm-client-body { display: none; padding: 0 16px 12px; }
 .pm-client-body.open { display: block; }
 .pm-att-block { margin-top: 10px; border: 1px solid rgba(35,46,69,0.6); border-radius: 7px; overflow: hidden; }
 .pm-att-header { display: flex; align-items: center; justify-content: space-between; padding: 7px 12px; background: rgba(26,34,54,0.6); cursor: pointer; user-select: none; font-family: 'Bebas Neue', sans-serif; font-size: 13px; letter-spacing: 1.5px; color: var(--muted); gap: 8px; }
 .pm-att-header:hover { background: rgba(26,34,54,0.9); color: var(--text); }
 .pm-att-body { display: none; }
 .pm-att-body.open { display: block; }
 .pm-att-body table { width: 100%; border-collapse: collapse; }
 .pm-att-body th { font-size: 10px; letter-spacing: 1px; text-transform: uppercase; color: var(--muted); font-weight: 600; padding: 6px 12px; border-bottom: 1px solid var(--border); text-align: left; }
 .pm-att-body td { padding: 6px 12px; border-bottom: 1px solid rgba(35,46,69,0.3); vertical-align: middle; }
 .pm-att-body tr:last-child td { border-bottom: none; }
 /* ─── Associazioni Operative ─── */
 .ao-client-block { margin-bottom: 14px; border: 1px solid var(--border); border-radius: 10px; overflow: hidden; }
 .ao-client-header { display: flex; align-items: center; justify-content: space-between; padding: 10px 16px; background: var(--surface2); cursor: pointer; user-select: none; font-family: 'Bebas Neue', sans-serif; font-size: 15px; letter-spacing: 2px; gap: 10px; }
 .ao-client-header:hover { background: rgba(255,255,255,0.03); }
 .ao-client-body { display: none; padding: 12px 16px; }
 .ao-client-body.open { display: block; }
 .ao-section { margin-bottom: 14px; padding-bottom: 14px; border-bottom: 1px solid rgba(35,46,69,0.5); }
 .ao-section:last-child { border-bottom: none; margin-bottom: 0; }
 .ao-section-title { font-family: 'Bebas Neue', sans-serif; font-size: 11px; letter-spacing: 2px; color: var(--muted); margin-bottom: 8px; display: flex; align-items: center; justify-content: space-between; }
 /* anomaly box */
 .ao-anomaly-box { margin-top: 20px; border: 1px solid rgba(239,68,68,0.3); border-radius: 8px; overflow: hidden; }
 .ao-anomaly-header { padding: 10px 16px; background: rgba(239,68,68,0.08); display: flex; align-items: center; justify-content: space-between; font-family: 'Bebas Neue', sans-serif; font-size: 13px; letter-spacing: 2px; color: var(--red); cursor: pointer; }
 .ao-anomaly-body { display: none; padding: 12px 16px; }
 .ao-anomaly-body.open { display: block; }
 .ao-anomaly-item { display: flex; align-items: flex-start; gap: 8px; padding: 5px 0; border-bottom: 1px solid rgba(35,46,69,0.3); font-size: 12px; line-height: 1.5; }
 .ao-anomaly-item:last-child { border-bottom: none; }
 .ao-anomaly-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--red); flex-shrink: 0; margin-top: 5px; }
 .ao-anomaly-type { font-size: 10px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase; color: var(--red); padding: 1px 5px; border-radius: 3px; background: rgba(239,68,68,0.12); white-space: nowrap; flex-shrink: 0; }
 .ao-no-anomaly { text-align: center; padding: 16px; font-size: 12px; color: var(--green); }
 /* ─── Credenziali ─── */
 .cred-section { max-width: 420px; }
 .cred-user-list { margin-bottom: 20px; }
 /* .cred-user-row: see definition below */
 .adm-save-bar { display: flex; justify-content: space-between; align-items: center; margin-top: 14px; padding-top: 12px; border-top: 1px solid var(--border); }
 /* ===== EDITING PANEL ===== */
 .ed-section { margin-bottom: 28px; padding-bottom: 22px; border-bottom: 1px solid var(--border); }
 .ed-section:last-child { border-bottom: none; margin-bottom: 0; }
 .ed-section-title { font-family: 'Bebas Neue', sans-serif; font-size: 14px; letter-spacing: 2.5px; color: var(--accent2); margin-bottom: 14px; display: flex; align-items: center; gap: 8px; }
 .ed-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 12px; }
 /* Editing panel color grid: max 3 cols to stay readable */
 #editing-panel-root .ed-grid { grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); }
 .ed-field { display: flex; flex-direction: column; gap: 5px; }
 .ed-label { font-size: 10px; font-weight: 700; letter-spacing: 1.2px; text-transform: uppercase; color: var(--muted); }
 .ed-input { background: var(--surface2); border: 1px solid var(--border); border-radius: 6px; color: var(--text); padding: 7px 10px; font-family: 'DM Sans', sans-serif; font-size: 13px; transition: border-color 0.2s; width: 100%; }
 .ed-input:focus { outline: none; border-color: var(--accent2); }
 .ed-color-row { display: flex; align-items: center; gap: 8px; }
 .ed-color-swatch { width: 32px; height: 32px; border-radius: 6px; border: 1px solid var(--border); cursor: pointer; flex-shrink: 0; overflow: hidden; position: relative; }
 .ed-color-swatch input[type=color] { position: absolute; inset: -4px; width: calc(100% + 8px); height: calc(100% + 8px); border: none; padding: 0; cursor: pointer; opacity: 0; }
 .ed-hex-input { font-family: 'DM Mono', monospace; font-size: 12px; width: 90px; padding: 6px 8px; background: var(--surface2); border: 1px solid var(--border); border-radius: 6px; color: var(--text); text-transform: uppercase; }
 .ed-hex-input:focus { outline: none; border-color: var(--accent2); }
 .ed-font-preview { font-size: 11px; color: var(--muted); margin-top: 2px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
 .ed-theme-preset { display: inline-flex; align-items: center; gap: 6px; padding: 6px 12px; border: 1px solid var(--border); border-radius: 20px; background: var(--surface2); cursor: pointer; font-size: 12px; font-weight: 600; transition: all 0.15s; color: var(--text); }
 .ed-theme-preset:hover { border-color: var(--accent2); }
 .ed-preview-bar { margin-top: 14px; padding: 12px 16px; background: var(--surface2); border: 1px solid var(--border); border-radius: 8px; font-size: 12px; color: var(--muted); line-height: 1.7; }
 .ed-range-row { display: flex; align-items: center; gap: 10px; }
 .ed-range-row input[type=range] { flex: 1; accent-color: var(--accent2); }
 .ed-range-val { font-family: 'DM Mono', monospace; font-size: 12px; color: var(--text); min-width: 36px; text-align: right; }
 /* ===== DATE FILTER BAR ===== */
 .date-filter-bar { display: flex; align-items: center; gap: 8px; padding: 10px 32px; background: var(--surface2); border-bottom: 1px solid var(--border); flex-wrap: wrap; }
 .df-label { font-family: 'Bebas Neue', sans-serif; font-size: 12px; letter-spacing: 1.5px; color: var(--muted); white-space: nowrap; flex-shrink: 0; }
 .df-input { background: var(--surface); border: 1px solid var(--border); border-radius: 6px; color: var(--text); padding: 5px 9px; font-family: 'DM Mono', monospace; font-size: 12px; cursor: pointer; transition: border-color 0.2s; color-scheme: dark; }
 .df-input:focus { outline: none; border-color: var(--accent2); }
 .df-sep { color: var(--muted); font-size: 13px; flex-shrink: 0; }
 .df-preset { background: var(--surface); border: 1px solid var(--border); border-radius: 5px; color: var(--muted); padding: 4px 10px; font-family: 'Bebas Neue', sans-serif; font-size: 11px; letter-spacing: 1px; cursor: pointer; transition: all 0.15s; white-space: nowrap; }
 .df-preset:hover { color: var(--text); border-color: var(--accent2); }
 .df-preset.active { background: rgba(245,166,35,0.15); border-color: var(--accent2); color: var(--accent2); }
 .df-apply { background: var(--accent2); border: none; border-radius: 6px; color: #000; padding: 5px 14px; font-family: 'Bebas Neue', sans-serif; font-size: 12px; letter-spacing: 1.5px; cursor: pointer; transition: opacity 0.15s; white-space: nowrap; flex-shrink: 0; }
 .df-apply:hover { opacity: 0.85; }
 .df-active-badge { display: none; align-items: center; gap: 5px; background: rgba(245,166,35,0.12); border: 1px solid rgba(245,166,35,0.3); border-radius: 12px; padding: 3px 10px; font-size: 11px; color: var(--accent2); font-family: 'DM Mono', monospace; white-space: nowrap; }
 .df-active-badge.visible { display: inline-flex; }
 .df-clear { background: none; border: none; color: var(--muted); cursor: pointer; font-size: 14px; padding: 0 0 0 4px; line-height: 1; }
 .df-clear:hover { color: var(--red); }
 /* ── Import XLS utenti ── */
 .cred-import-zone { border: 2px dashed var(--border); border-radius: 10px; padding: 18px 20px; text-align: center; cursor: pointer; transition: all 0.2s; background: var(--surface2); position: relative; margin-bottom: 4px; }
 .cred-import-zone:hover, .cred-import-zone.drag-over { border-color: var(--purple); background: rgba(168,85,247,0.06); }
 .cred-import-zone.loaded { border-color: var(--green); background: rgba(34,197,94,0.05); }
 .cred-import-zone input[type=file] { position: absolute; inset: 0; opacity: 0; cursor: pointer; width: 100%; height: 100%; }
 .cred-import-hint { font-size: 11px; color: var(--muted); margin-top: 4px; line-height: 1.5; }
 /* ── Tabella utenti importati in attesa di associazione ── */
 .cred-pending-table { width: 100%; border-collapse: collapse; font-size: 12px; margin-top: 8px; }
 .cred-pending-table th { text-align: left; font-size: 10px; font-weight: 600; letter-spacing: 1px; text-transform: uppercase; color: var(--muted); padding: 0 8px 8px 0; border-bottom: 1px solid var(--border); }
 .cred-pending-table td { padding: 8px 8px 8px 0; border-bottom: 1px solid rgba(35,46,69,0.4); vertical-align: middle; }
 .cred-pending-table tr:last-child td { border-bottom: none; }
 .cred-pending-table select { background: var(--surface2); border: 1px solid var(--border); border-radius: 5px; color: var(--text); font-size: 11px; padding: 4px 8px; cursor: pointer; }
 .cred-pending-badge { display: inline-block; padding: 2px 7px; border-radius: 4px; font-size: 9px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase; }
 .cred-pending-badge.new    { background: rgba(34,197,94,0.15); color: var(--green); }
 .cred-pending-badge.update { background: rgba(245,166,35,0.15); color: var(--accent2); }
 /* ── Lista utenti editabile ── */
 .cred-user-row { display: flex; align-items: flex-start; gap: 10px; padding: 10px 0; border-bottom: 1px solid rgba(35,46,69,0.5); }
 .cred-user-row:last-child { border-bottom: none; }
 .cred-role-dot { width: 9px; height: 9px; border-radius: 50%; margin-top: 5px; flex-shrink: 0; }
 .cred-user-expand { flex: 1; cursor: pointer; }
 .cred-user-edit-row { display: none; margin-top: 10px; flex-direction: column; gap: 8px; background: var(--surface2); border: 1px solid var(--border); border-radius: 8px; padding: 12px 14px; }
 .cred-user-edit-row.open { display: flex; }
 .cred-edit-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
 .cred-edit-input { width: 100%; background: var(--surface); border: 1px solid var(--border); border-radius: 6px; color: var(--text); font-size: 12px; padding: 7px 10px; outline: none; transition: border-color 0.2s; }
 .cred-edit-input:focus { border-color: var(--accent); }
 .cred-edit-label { font-size: 10px; font-weight: 600; letter-spacing: 1px; color: var(--muted); text-transform: uppercase; margin-bottom: 3px; }
 .cred-edit-actions { display: flex; gap: 6px; justify-content: flex-end; margin-top: 4px; }
 .btn-cred-save { background: var(--accent); color: #fff; border: none; border-radius: 6px; font-family: 'Bebas Neue', sans-serif; font-size: 12px; letter-spacing: 1.5px; padding: 6px 14px; cursor: pointer; transition: opacity 0.2s; }
 .btn-cred-save:hover { opacity: 0.85; }
 .btn-cred-cancel { background: none; color: var(--muted); border: 1px solid var(--border); border-radius: 6px; font-family: 'Bebas Neue', sans-serif; font-size: 12px; letter-spacing: 1.5px; padding: 6px 12px; cursor: pointer; transition: all 0.2s; }
 .btn-cred-cancel:hover { color: var(--text); border-color: var(--muted); }
 .cred-tl-checks-edit { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 4px; }
 .cred-tl-check-edit { display: flex; align-items: center; gap: 6px; padding: 6px 12px; border-radius: 6px; border: 1px solid var(--border); background: var(--surface); font-family: 'Bebas Neue', sans-serif; font-size: 12px; letter-spacing: 1.5px; cursor: pointer; transition: all 0.18s; user-select: none; flex: 1; justify-content: center; }
 .cred-tl-check-edit:has(input:checked).edison-check { border-color: rgba(232,68,26,0.6); background: rgba(232,68,26,0.1); color: var(--accent); }
 .cred-tl-check-edit:has(input:checked).wind-check   { border-color: rgba(0,160,224,0.6); background: rgba(0,160,224,0.1); color: #00a0e0; }
 .cred-tl-check-edit:has(input:checked).tim-check    { border-color: rgba(0,48,135,0.6); background: rgba(0,48,135,0.1); color: #003087; }
 .cred-tl-check-edit input[type=checkbox] { accent-color: var(--purple); width: 13px; height: 13px; cursor: pointer; }
 /* ===== WELCOME / LANDING SCREEN ===== */
 #welcome-screen { min-height: 100vh; display: flex; flex-direction: column; align-items: center; justify-content: center; padding: 40px 24px; background: radial-gradient(ellipse at 50% 30%, #111e3a 0%, var(--bg) 65%); position: relative; overflow: hidden; }
 /* decorative glow blobs */
 #welcome-screen::before, #welcome-screen::after { content: ''; position: absolute; border-radius: 50%; filter: blur(90px); opacity: 0.18; pointer-events: none; }
 #welcome-screen::before { width: 500px; height: 500px; background: var(--accent); top: -100px; left: -100px; }
 #welcome-screen::after { width: 420px; height: 420px; background: #00a0e0; bottom: -80px; right: -80px; }
 .welcome-logo { display: flex; align-items: center; gap: 14px; margin-bottom: 48px; animation: wFadeUp 0.6s ease both; }
 .welcome-logo-badge { width: 56px; height: 56px; background: linear-gradient(135deg, var(--accent), #f5a623); border-radius: 14px; display: flex; align-items: center; justify-content: center; font-family: 'Bebas Neue', sans-serif; font-size: 26px; color: #fff; letter-spacing: 1px; box-shadow: 0 8px 32px rgba(232,68,26,0.35); }
 .welcome-logo-text { font-family: 'Bebas Neue', sans-serif; font-size: 32px; letter-spacing: 4px; color: var(--text); line-height: 1; }
 .welcome-logo-text span { color: var(--accent); }
 .welcome-logo-sub { font-size: 11px; letter-spacing: 3px; color: var(--muted); margin-top: 4px; }
 .welcome-card { background: var(--surface); border: 1px solid var(--border); border-radius: 20px; padding: 44px 48px 48px; width: 100%; max-width: 480px; text-align: center; position: relative; z-index: 1; box-shadow: 0 24px 80px rgba(0,0,0,0.4); animation: wFadeUp 0.6s 0.1s ease both; }
 .welcome-title { font-family: 'Bebas Neue', sans-serif; font-size: clamp(32px, 5vw, 52px); letter-spacing: 5px; line-height: 1.05; margin-bottom: 10px; background: linear-gradient(135deg, var(--text) 60%, var(--muted)); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }
 .welcome-subtitle { font-size: 13px; color: var(--muted); letter-spacing: 0.5px; margin-bottom: 36px; line-height: 1.6; }
 .welcome-select-label { font-family: 'Bebas Neue', sans-serif; font-size: 12px; letter-spacing: 2.5px; color: var(--muted); text-align: left; display: block; margin-bottom: 8px; }
 .welcome-select-wrap { position: relative; margin-bottom: 28px; }
 .welcome-select { width: 100%; appearance: none; -webkit-appearance: none; background: var(--surface2); border: 1.5px solid var(--border); border-radius: 10px; color: var(--text); font-family: 'Bebas Neue', sans-serif; font-size: 18px; letter-spacing: 3px; padding: 14px 44px 14px 18px; cursor: pointer; transition: border-color 0.2s, box-shadow 0.2s; outline: none; }
 .welcome-select:focus { border-color: var(--accent); box-shadow: 0 0 0 3px rgba(232,68,26,0.15); }
 .welcome-select-arrow { position: absolute; right: 16px; top: 50%; transform: translateY(-50%); pointer-events: none; color: var(--muted); font-size: 14px; }
 .welcome-select option { background: #1a2236; }
 /* Client indicator dots */
 .welcome-client-dots { display: flex; justify-content: center; gap: 12px; margin-bottom: 32px; }
 .welcome-dot { display: flex; align-items: center; gap: 7px; font-family: 'Bebas Neue', sans-serif; font-size: 13px; letter-spacing: 2px; padding: 6px 14px; border-radius: 20px; border: 1px solid var(--border); color: var(--muted); background: var(--surface2); transition: all 0.25s; opacity: 0.45; }
 .welcome-dot .dot-pip { width: 8px; height: 8px; border-radius: 50%; }
 .welcome-dot.active { opacity: 1; }
 .welcome-dot.edison.active { border-color: rgba(232,68,26,0.5); color: var(--accent); background: rgba(232,68,26,0.08); }
 .welcome-dot.windtre.active { border-color: rgba(0,160,224,0.5); color: #00a0e0; background: rgba(0,160,224,0.08); }
 .welcome-dot.tutti.active { border-color: rgba(168,85,247,0.5); color: var(--purple); background: rgba(168,85,247,0.08); }
 .welcome-cta { background: var(--accent); color: #fff; border: none; width: 100%; padding: 16px; border-radius: 10px; font-family: 'Bebas Neue', sans-serif; font-size: 20px; letter-spacing: 3px; cursor: pointer; transition: all 0.2s; opacity: 0.35; pointer-events: none; }
 .welcome-cta.ready { opacity: 1; pointer-events: all; }
 .welcome-cta.ready:hover { transform: translateY(-2px); box-shadow: 0 10px 32px rgba(232,68,26,0.4); }
 .welcome-footer { margin-top: 24px; font-size: 11px; color: var(--muted); letter-spacing: 1px; animation: wFadeUp 0.6s 0.2s ease both; }
 /* Divisore dentro la card */
 .welcome-divider { height: 1px; background: var(--border); margin: 28px 0 22px; }
 /* Quick actions (Gestisci File / Admin) */
 .welcome-quick-actions { display: flex; flex-direction: column; gap: 10px; }
 .welcome-quick-btn { display: flex; align-items: center; gap: 14px; width: 100%; background: var(--surface2); border: 1px solid var(--border); border-radius: 10px; padding: 13px 16px; cursor: pointer; text-align: left; transition: border-color 0.2s, background 0.2s, transform 0.15s; color: var(--text); }
 .welcome-quick-btn:hover { background: #202d47; border-color: var(--muted); transform: translateY(-1px); }
 .wqa-icon { font-size: 20px; flex-shrink: 0; width: 36px; height: 36px; display: flex; align-items: center; justify-content: center; background: var(--surface); border-radius: 8px; border: 1px solid var(--border); }
 .wqa-label { font-family: 'Bebas Neue', sans-serif; font-size: 14px; letter-spacing: 2px; color: var(--text); line-height: 1; margin-bottom: 3px; }
 .wqa-sub { font-size: 11px; color: var(--muted); line-height: 1.3; }
 /* ── Step transizione dentro la welcome-card ── */
 .welcome-step { transition: opacity 0.25s, transform 0.25s; }
 .welcome-step.hidden { display: none; }
 /* ── Input login ── */
 .welcome-input { width: 100%; background: var(--surface2); border: 1.5px solid var(--border); border-radius: 8px; color: var(--text); font-family: 'DM Sans', sans-serif; font-size: 14px; padding: 12px 14px; outline: none; transition: border-color 0.2s, box-shadow 0.2s; margin-top: 6px; }
 .welcome-input:focus { border-color: var(--accent); box-shadow: 0 0 0 3px rgba(232,68,26,0.13); }
 .welcome-input-label { font-size: 11px; font-weight: 600; letter-spacing: 1.5px; text-transform: uppercase; color: var(--muted); display: block; margin-top: 14px; }
 .welcome-input-label:first-child { margin-top: 0; }
 .welcome-login-error { display: none; font-size: 12px; color: var(--red); background: rgba(239,68,68,0.08); border: 1px solid rgba(239,68,68,0.25); border-radius: 6px; padding: 9px 12px; margin-top: 12px; text-align: center; }
 .welcome-login-error.visible { display: block; }
 /* ── Griglia clienti (step 2) ── */
 .welcome-clients-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-bottom: 4px; }
 .welcome-clients-grid.single { grid-template-columns: 1fr; }
 .welcome-client-card { background: var(--surface2); border: 1.5px solid var(--border); border-radius: 12px; padding: 20px 16px 18px; text-align: center; cursor: pointer; transition: all 0.22s; position: relative; overflow: hidden; }
 .welcome-client-card::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px; transition: opacity 0.2s; }
 .welcome-client-card.edison::before  { background: var(--accent); }
 .welcome-client-card.wind::before    { background: #00a0e0; }
 .welcome-client-card.tutti::before   { background: var(--purple); }
 .welcome-client-card.tim::before     { background: var(--tim,#003087); }
 .welcome-client-card.tim:hover       { border-color: rgba(0,48,135,0.5); box-shadow: 0 8px 28px rgba(0,48,135,0.2); }
 .welcome-client-card:hover { transform: translateY(-3px); background: #1e2c45; }
 .welcome-client-card.edison:hover  { border-color: rgba(232,68,26,0.5); box-shadow: 0 8px 28px rgba(232,68,26,0.15); }
 .welcome-client-card.wind:hover    { border-color: rgba(0,160,224,0.5); box-shadow: 0 8px 28px rgba(0,160,224,0.15); }
 .welcome-client-card.tutti:hover   { border-color: rgba(168,85,247,0.5); box-shadow: 0 8px 28px rgba(168,85,247,0.15); }
 .welcome-client-card-badge { width: 48px; height: 48px; border-radius: 12px; margin: 0 auto 12px; display: flex; align-items: center; justify-content: center; font-family: 'Bebas Neue', sans-serif; font-size: 20px; color: #fff; letter-spacing: 1px; }
 .welcome-client-card-logo { display: flex; align-items: center; justify-content: center; height: 60px; margin: 0 auto 14px; }
 .welcome-client-card-logo img { max-width: 100%; max-height: 60px; width: auto; height: auto; object-fit: contain; filter: brightness(1.1); }
 .welcome-client-card.edison .welcome-client-card-badge  { background: var(--accent); }
 .welcome-client-card.wind   .welcome-client-card-badge  { background: #00a0e0; }
 .welcome-client-card.tutti  .welcome-client-card-badge  { background: var(--purple); }
 .welcome-client-card-name { font-family: 'Bebas Neue', sans-serif; font-size: 18px; letter-spacing: 2.5px; margin-bottom: 4px; }
 .welcome-client-card.edison .welcome-client-card-name { color: var(--accent); }
 .welcome-client-card.wind   .welcome-client-card-name { color: #00a0e0; }
 .welcome-client-card.tutti  .welcome-client-card-name { color: var(--purple); }
 .welcome-client-card-sub { font-size: 10px; color: var(--muted); letter-spacing: 0.5px; line-height: 1.4; }
 /* ── Barra utente loggato ── */
 .welcome-user-bar { display: flex; align-items: center; justify-content: space-between; margin-bottom: 20px; padding: 10px 14px; background: var(--surface2); border: 1px solid var(--border); border-radius: 8px; }
 .welcome-user-info { display: flex; align-items: center; gap: 9px; }
 .welcome-user-avatar { width: 30px; height: 30px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-family: 'Bebas Neue', sans-serif; font-size: 14px; color: #fff; flex-shrink: 0; }
 .welcome-user-name { font-size: 13px; font-weight: 600; }
 .welcome-user-role { font-size: 10px; color: var(--muted); letter-spacing: 1px; text-transform: uppercase; margin-top: 1px; }
 .welcome-logout-btn { background: none; border: 1px solid var(--border); border-radius: 6px; color: var(--muted); font-family: 'Bebas Neue', sans-serif; font-size: 11px; letter-spacing: 1.5px; padding: 5px 10px; cursor: pointer; transition: all 0.18s; }
 .welcome-logout-btn:hover { color: var(--red); border-color: rgba(239,68,68,0.4); }
 /* ── Azioni rapide admin (step 2, solo ruoli abilitati) ── */
 .welcome-admin-actions { display: none; margin-top: 16px; gap: 8px; flex-direction: column; }
 .welcome-admin-actions.visible { display: flex; }
 /* ── Recupero password ── */
 .ws-recover-msg { display: none; font-size: 12px; padding: 9px 12px; border-radius: 6px; margin-top: 10px; text-align: center; }
 .ws-recover-msg.error   { background: rgba(239,68,68,0.08); border: 1px solid rgba(239,68,68,0.25); color: var(--red); }
 .ws-recover-msg.success { background: rgba(34,197,94,0.08); border: 1px solid rgba(34,197,94,0.25); color: var(--green); }
 .ws-recover-msg.visible { display: block; }
 .ws-back-link { background: none; border: none; color: var(--muted); font-size: 11px; cursor: pointer; letter-spacing: 0.5px; text-decoration: underline; text-underline-offset: 3px; padding: 0; margin-top: 10px; display: inline-block; transition: color 0.15s; }
 .ws-back-link:hover { color: var(--text); }
 @keyframes wFadeUp { from { opacity: 0; transform: translateY(20px); }
 to   { opacity: 1; transform: translateY(0); }
 }
 /* ── Utility: inline letter badge ── */
 .badge-sm  { width:18px;height:18px;border-radius:4px;display:inline-flex;align-items:center;justify-content:center;font-family:'Bebas Neue',sans-serif;font-size:11px;color:#fff;flex-shrink:0 }
 .badge-md  { width:22px;height:22px;border-radius:5px;display:inline-flex;align-items:center;justify-content:center;font-family:'Bebas Neue',sans-serif;font-size:12px;color:#fff }
 .badge-lg  { width:36px;height:36px;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;font-family:'Bebas Neue',sans-serif;font-size:18px;color:#fff;flex-shrink:0 }
 .flex-gap8 { display:flex;align-items:center;gap:8px }
 /* ── Consolidated table cells ── */
 .consol-td-key { padding:11px 14px;color:var(--muted);font-size:12px;font-weight:600;letter-spacing:1px;text-transform:uppercase;border-top:1px solid var(--border) }
 .consol-td-val { padding:11px 14px;font-family:'DM Mono',monospace;font-size:14px;border-top:1px solid var(--border) }
 /* ── Prodotti panel ── */
 .prod-name-cell { font-family:'DM Mono',monospace;font-size:12px;max-width:220px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap }


  /* ── TIM client ── */
  :root { --tim: #003087; --tim-light: #1a4db3; }
  #hub-kpi-tim::before  { background: var(--tim); }
  #hub-kpi-tim:hover    { border-color: rgba(0,48,135,0.5); box-shadow: 0 8px 32px rgba(0,48,135,0.15); }
  .hub-panel-arrow.tim  { color: var(--tim); }
  .summary-card.tim::before { background: var(--tim); }
  .wt-pill-tim  { background: rgba(0,48,135,0.15); color: var(--tim); }
  .tim-total td { background: rgba(0,48,135,0.05); color: var(--tim); }
  #wt-dashboard-screen .topbar-logo span.tim-span { color: var(--tim); }

/* ===== Premium Visual Refresh ===== */
:root {
  --bg: #060913;
  --surface: rgba(11, 18, 34, 0.84);
  --surface2: rgba(16, 26, 46, 0.9);
  --surface3: rgba(26, 40, 68, 0.92);
  --border: rgba(128, 155, 207, 0.14);
  --border-strong: rgba(171, 197, 246, 0.22);
  --text: #eef4ff;
  --muted: #8b9bb8;
  --card-radius: 18px;
  --shadow-soft: 0 24px 80px rgba(0, 0, 0, 0.24);
  --shadow-hard: 0 36px 110px rgba(0, 0, 0, 0.42);
  --glow-orange: rgba(232, 68, 26, 0.2);
  --glow-blue: rgba(0, 160, 224, 0.18);
  --glow-gold: rgba(245, 166, 35, 0.2);
}

html {
  scroll-behavior: smooth;
}

body {
  position: relative;
  isolation: isolate;
  background:
    radial-gradient(circle at 14% 18%, rgba(232, 68, 26, 0.15), transparent 28%),
    radial-gradient(circle at 82% 16%, rgba(0, 160, 224, 0.16), transparent 24%),
    radial-gradient(circle at 50% 100%, rgba(245, 166, 35, 0.08), transparent 32%),
    linear-gradient(180deg, #08101f 0%, #060913 54%, #05070f 100%);
}

body::before,
body::after {
  content: '';
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: -2;
}

body::before {
  background:
    linear-gradient(rgba(255, 255, 255, 0.018) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255, 255, 255, 0.018) 1px, transparent 1px);
  background-size: 56px 56px;
  mask-image: radial-gradient(circle at center, #000 34%, transparent 86%);
  opacity: 0.34;
}

body::after {
  inset: auto -14vw -24vh auto;
  width: 44vw;
  height: 44vw;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(245, 166, 35, 0.12), transparent 68%);
  filter: blur(40px);
  z-index: -1;
}

*::-webkit-scrollbar {
  width: 10px;
  height: 10px;
}

*::-webkit-scrollbar-track {
  background: rgba(9, 14, 26, 0.7);
}

*::-webkit-scrollbar-thumb {
  background: rgba(120, 142, 184, 0.34);
  border-radius: 999px;
  border: 2px solid rgba(9, 14, 26, 0.7);
}

*::-webkit-scrollbar-thumb:hover {
  background: rgba(160, 184, 232, 0.44);
}

#welcome-screen,
#upload-hub,
#client-screen,
#upload-screen,
#wt-upload-screen,
#mapping-screen,
#admin-screen,
#wt-dashboard-screen {
  position: relative;
  background: transparent;
}

.welcome-logo,
.logo-area,
.hub-header-row,
.mapping-header,
.admin-header,
.dashboard-body,
.summary-grid > .summary-card,
.tables-section > .table-card,
.comparison-grid > .comparison-card,
.sede-grid > .sede-card,
.hub-home-grid > .hub-panel,
.client-grid > .client-card,
.welcome-clients-grid > .welcome-client-card {
  animation: premiumRise 0.72s cubic-bezier(0.22, 1, 0.36, 1) both;
}

.summary-grid > .summary-card:nth-child(2),
.hub-home-grid > .hub-panel:nth-child(2),
.client-grid > .client-card:nth-child(2),
.welcome-clients-grid > .welcome-client-card:nth-child(2) {
  animation-delay: 0.06s;
}

.summary-grid > .summary-card:nth-child(3),
.hub-home-grid > .hub-panel:nth-child(3),
.client-grid > .client-card:nth-child(3),
.welcome-clients-grid > .welcome-client-card:nth-child(3) {
  animation-delay: 0.12s;
}

.summary-grid > .summary-card:nth-child(4),
.hub-home-grid > .hub-panel:nth-child(4),
.client-grid > .client-card:nth-child(4),
.welcome-clients-grid > .welcome-client-card:nth-child(4) {
  animation-delay: 0.18s;
}

.hub-header-row,
.topbar,
.tab-bar,
.admin-modal-tabs,
.adm-tabs,
.welcome-card,
.hub-panel-kpi,
.client-card,
.upload-zone,
.summary-card,
.table-card,
.cross-card,
.comparison-card,
.sede-card,
.mapping-card,
.admin-card,
.modal-box,
.admin-modal-config,
.wt-attivita-section,
.sede-manager,
.welcome-user-bar,
.welcome-client-card,
.cred-user-edit-row,
.adm-panel-card,
.cred-import-zone,
.ao-box {
  background:
    linear-gradient(180deg, rgba(18, 28, 49, 0.9) 0%, rgba(10, 16, 30, 0.96) 100%);
  border: 1px solid var(--border);
  box-shadow: var(--shadow-soft);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
}

.topbar {
  background: rgba(7, 11, 22, 0.76);
  border-bottom-color: rgba(148, 173, 225, 0.14);
  box-shadow: 0 18px 60px rgba(0, 0, 0, 0.26);
}

.topbar::after {
  content: '';
  position: absolute;
  inset: auto 0 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.1), transparent);
}

.topbar-logo {
  font-size: 24px;
  letter-spacing: 4px;
}

.topbar-divider {
  height: 32px;
  background: linear-gradient(180deg, transparent, rgba(255, 255, 255, 0.14), transparent);
}

.topbar-subtitle {
  font-size: 12px;
  letter-spacing: 1px;
  text-transform: uppercase;
}

.topbar-executive {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  flex: 1 1 340px;
  flex-wrap: wrap;
}

.topbar-actions {
  display: flex;
  gap: 8px;
  align-items: center;
  flex-shrink: 0;
}

.exec-pill {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  min-width: 122px;
  padding: 9px 12px;
  border-radius: 14px;
  border: 1px solid rgba(148, 173, 225, 0.14);
  background: rgba(15, 24, 43, 0.72);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.03);
}

.exec-pill-icon {
  width: 28px;
  height: 28px;
  border-radius: 9px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(255, 255, 255, 0.06);
  font-size: 13px;
  flex-shrink: 0;
}

.exec-pill-copy {
  min-width: 0;
}

.exec-pill-label {
  font-size: 9px;
  text-transform: uppercase;
  letter-spacing: 1.4px;
  color: rgba(171, 189, 219, 0.72);
  margin-bottom: 2px;
}

.exec-pill-value {
  font-family: 'Bebas Neue', sans-serif;
  letter-spacing: 1.6px;
  font-size: 16px;
  color: var(--text);
  line-height: 1;
  white-space: nowrap;
}

.exec-pill.live {
  border-color: rgba(34, 197, 94, 0.2);
}

.exec-pill.live .exec-pill-icon,
.card-badge.live,
.card-delta.live,
.card-meter-fill.live {
  background: rgba(34, 197, 94, 0.16);
  color: var(--green);
}

.exec-pill.accent .exec-pill-icon,
.card-badge.accent,
.card-delta.accent,
.card-meter-fill.accent {
  background: rgba(245, 166, 35, 0.16);
  color: var(--accent2);
}

.exec-pill.up .exec-pill-icon,
.card-badge.up,
.card-delta.up,
.card-meter-fill.up {
  background: rgba(34, 197, 94, 0.16);
  color: var(--green);
}

.exec-pill.down .exec-pill-icon,
.card-badge.down,
.card-delta.down,
.card-meter-fill.down {
  background: rgba(239, 68, 68, 0.16);
  color: var(--red);
}

.exec-pill.blue .exec-pill-icon,
.card-badge.blue,
.card-delta.blue,
.card-meter-fill.blue {
  background: rgba(59, 130, 246, 0.16);
  color: var(--blue);
}

.exec-pill.purple .exec-pill-icon,
.card-badge.purple,
.card-delta.purple,
.card-meter-fill.purple {
  background: rgba(168, 85, 247, 0.16);
  color: var(--purple);
}

.exec-pill.neutral .exec-pill-icon,
.card-badge.neutral,
.card-delta.neutral,
.card-meter-fill.neutral {
  background: rgba(255, 255, 255, 0.08);
  color: rgba(230, 238, 255, 0.86);
}

.tab-bar {
  width: calc(100% - 48px);
  max-width: 1400px;
  margin: 18px auto 0;
  padding: 8px;
  border-radius: 18px;
  border-bottom: 1px solid var(--border);
  background: rgba(8, 13, 25, 0.72);
  overflow-x: auto;
}

.tab-btn,
.admin-modal-tab,
.adm-tab {
  border: none;
  border-radius: 12px;
  transition: transform 0.18s ease, color 0.18s ease, background 0.18s ease, box-shadow 0.18s ease;
}

.tab-btn {
  padding: 13px 18px;
}

.tab-btn:hover,
.admin-modal-tab:hover,
.adm-tab:hover {
  transform: translateY(-1px);
}

.tab-btn.active,
.admin-modal-tab.active,
.adm-tab.active {
  color: var(--text);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0.02));
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.06), 0 12px 30px rgba(0, 0, 0, 0.2);
}

.dashboard-body {
  max-width: 1440px;
  padding: 30px 28px 60px;
}

.section-title {
  position: relative;
  font-size: 26px;
  letter-spacing: 3.6px;
  margin-bottom: 20px;
  padding-bottom: 14px;
  border-bottom: none;
  color: rgba(213, 224, 247, 0.7);
}

.section-title::after {
  content: '';
  position: absolute;
  left: 0;
  bottom: 0;
  width: 96px;
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--accent), rgba(255, 255, 255, 0));
}

.section-title span {
  text-shadow: 0 0 26px rgba(255, 255, 255, 0.08);
}

.welcome-card,
.hub-panel-kpi,
.client-card,
.upload-zone,
.summary-card,
.table-card,
.comparison-card,
.sede-card,
.mapping-card,
.admin-card,
.modal-box,
.wt-attivita-section,
.welcome-client-card {
  position: relative;
  overflow: hidden;
}

.welcome-card::before,
.hub-panel-kpi::after,
.summary-card::after,
.table-card::before,
.comparison-card::before,
.sede-card::before,
.upload-zone::before,
.client-card::after,
.welcome-client-card::after {
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(circle at top right, rgba(255, 255, 255, 0.09), transparent 34%);
  opacity: 0.85;
}

.summary-card::before,
.hub-panel-kpi::before,
.client-card::before,
.welcome-client-card::before {
  height: 4px;
}

.welcome-card {
  max-width: 520px;
  border-radius: 28px;
  box-shadow: var(--shadow-hard), inset 0 1px 0 rgba(255, 255, 255, 0.05);
}

.welcome-card::before {
  content: '';
  position: absolute;
  inset: 0 0 auto;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.16), transparent);
}

.welcome-logo {
  margin-bottom: 34px;
}

.welcome-logo-badge,
.logo-badge {
  box-shadow: 0 18px 38px rgba(232, 68, 26, 0.28), 0 0 0 1px rgba(255, 255, 255, 0.08);
}

.welcome-logo-text,
.logo-text {
  text-shadow: 0 10px 36px rgba(0, 0, 0, 0.2);
}

.welcome-subtitle,
.upload-subtitle,
.client-subtitle,
.mapping-subtitle,
.modal-subtitle {
  color: rgba(168, 184, 214, 0.9);
}

.welcome-input,
.welcome-select,
.modal-input,
.obj-input,
.admin-select,
.sede-select,
.add-sede-input,
.df-input,
.cred-edit-input,
.filter-select {
  background: rgba(15, 24, 43, 0.9);
  border-color: rgba(134, 163, 214, 0.16);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.03);
}

.welcome-input:focus,
.welcome-select:focus,
.modal-input:focus,
.obj-input:focus,
.admin-select:focus,
.sede-select:focus,
.add-sede-input:focus,
.df-input:focus,
.cred-edit-input:focus,
.filter-select:focus {
  border-color: rgba(245, 166, 35, 0.8);
  box-shadow: 0 0 0 4px rgba(245, 166, 35, 0.12), inset 0 1px 0 rgba(255, 255, 255, 0.05);
  outline: none;
}

.welcome-cta,
.btn-modal-confirm,
.btn-save-admin,
.btn-mapping-confirm,
.df-apply {
  background: linear-gradient(135deg, #ff5d2b 0%, #ff7b1b 60%, #ffbd4f 100%);
  color: #fff;
  box-shadow: 0 18px 36px rgba(232, 68, 26, 0.28);
}

.welcome-cta.ready:hover,
.btn-modal-confirm:hover,
.btn-save-admin:hover,
.btn-mapping-confirm:hover,
.df-apply:hover {
  transform: translateY(-2px);
  box-shadow: 0 22px 44px rgba(232, 68, 26, 0.34);
}

.welcome-quick-btn,
.btn-home,
.btn-settings,
.btn-admin-back,
.btn-mapping-back {
  background: rgba(14, 23, 42, 0.84);
  border-color: rgba(134, 163, 214, 0.14);
}

.welcome-quick-btn:hover,
.btn-home:hover,
.btn-settings:hover,
.btn-admin-back:hover,
.btn-mapping-back:hover {
  border-color: rgba(245, 166, 35, 0.32);
  box-shadow: 0 14px 28px rgba(0, 0, 0, 0.16);
}

.welcome-clients-grid,
.summary-grid,
.sede-grid,
.comparison-grid,
.tables-section,
.client-grid {
  gap: 18px;
}

.welcome-client-card,
.client-card,
.hub-panel-kpi,
.upload-zone,
.summary-card,
.table-card,
.comparison-card,
.sede-card,
.mapping-card,
.admin-card,
.modal-box,
.wt-attivita-section {
  border-color: rgba(134, 163, 214, 0.14);
  box-shadow: var(--shadow-soft), inset 0 1px 0 rgba(255, 255, 255, 0.04);
  transition:
    transform 0.25s ease,
    box-shadow 0.25s ease,
    border-color 0.25s ease,
    background 0.25s ease;
}

.welcome-client-card:hover,
.client-card:hover,
.hub-panel-kpi:not(.no-data):hover,
.upload-zone:hover,
.upload-zone.drag-over,
.summary-card:hover,
.table-card:hover,
.comparison-card:hover,
.sede-card:hover,
.mapping-card:hover,
.admin-card:hover,
.wt-attivita-section:hover {
  transform: translateY(-6px);
  border-color: var(--border-strong);
  box-shadow: var(--shadow-hard), inset 0 1px 0 rgba(255, 255, 255, 0.05);
}

.hub-header-row {
  padding: 18px 22px;
  border-radius: 24px;
}

.hub-panel-kpi {
  border-radius: 22px;
}

.hub-panel-kpi::before,
.summary-card::before,
.welcome-client-card::before,
.client-card::before {
  box-shadow: 0 0 18px rgba(255, 255, 255, 0.12);
}

.hub-panel-kpi-footer {
  border-top-color: rgba(148, 173, 225, 0.12);
}

.upload-zone {
  border-style: solid;
  min-height: 220px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.upload-zone.loaded {
  border-color: rgba(34, 197, 94, 0.42);
  box-shadow: 0 24px 80px rgba(10, 20, 14, 0.28);
}

.upload-icon {
  font-size: 40px;
}

.summary-card {
  min-height: 158px;
  border-radius: 22px;
}

.card-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 6px;
}

.card-label {
  font-size: 10px;
  letter-spacing: 1.8px;
}

.card-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 24px;
  padding: 4px 9px;
  border-radius: 999px;
  font-size: 9px;
  letter-spacing: 1.2px;
  text-transform: uppercase;
  font-weight: 700;
  white-space: nowrap;
}

.card-value-row {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 14px;
}

.card-value {
  font-size: clamp(44px, 4vw, 58px);
  text-shadow: 0 12px 36px rgba(0, 0, 0, 0.28);
}

.card-delta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 5px 10px;
  border-radius: 999px;
  font-family: 'DM Mono', monospace;
  font-size: 11px;
  font-weight: 600;
  line-height: 1;
  white-space: nowrap;
}

.card-sub {
  font-size: 12px;
  color: rgba(179, 195, 225, 0.86);
}

.card-meter {
  position: relative;
  margin-top: 14px;
  height: 7px;
  border-radius: 999px;
  overflow: hidden;
  background: rgba(121, 143, 184, 0.12);
}

.card-meter-fill {
  height: 100%;
  border-radius: inherit;
  box-shadow: 0 0 24px rgba(255, 255, 255, 0.18);
}

.card-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-top: 10px;
  font-family: 'DM Mono', monospace;
  font-size: 10px;
  letter-spacing: 0.3px;
  color: rgba(171, 189, 219, 0.76);
}

.card-meta span:last-child {
  text-align: right;
}

.table-card,
.cross-card,
.comparison-card,
.mapping-card,
.admin-card,
.wt-attivita-section,
.sede-manager {
  border-radius: 22px;
}

.table-card-header,
.comparison-header,
.mapping-card-header,
.admin-card-header,
.wt-attivita-header,
.sede-manager-header,
.adm-topbar {
  background: linear-gradient(180deg, rgba(24, 37, 63, 0.92), rgba(15, 24, 43, 0.92));
  border-bottom-color: rgba(148, 173, 225, 0.12);
}

thead th,
.mapping-table thead th,
.admin-table thead th {
  background: rgba(17, 27, 46, 0.82);
  color: rgba(171, 189, 219, 0.8);
  border-bottom-color: rgba(148, 173, 225, 0.12);
}

tbody td,
.mapping-table tbody td,
.admin-table tbody td {
  border-bottom-color: rgba(148, 173, 225, 0.08);
}

tbody tr:hover:not(:last-child) td,
.mapping-table tbody tr:hover td,
.admin-table tbody tr:hover td {
  background: rgba(255, 255, 255, 0.028);
}

tbody tr:last-child td {
  background: linear-gradient(90deg, rgba(245, 166, 35, 0.1), rgba(245, 166, 35, 0.02));
}

.progress-bar {
  height: 8px;
  border-radius: 999px;
  background: rgba(121, 143, 184, 0.12);
}

.progress-fill {
  box-shadow: 0 0 22px rgba(255, 255, 255, 0.18);
}

.sede-card {
  border-radius: 22px;
}

.sede-card-name {
  font-size: 24px;
}

.sede-metric {
  background: rgba(16, 26, 46, 0.82);
  border: 1px solid rgba(134, 163, 214, 0.12);
  border-radius: 14px;
}

.activity-badge,
.adm-role-badge,
.df-active-badge,
.admin-info-badge,
.unassigned-warning {
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}

.modal-overlay {
  background: rgba(2, 6, 16, 0.72);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
}

.modal-box {
  border-radius: 24px;
}

#loading {
  background:
    radial-gradient(circle at top, rgba(232, 68, 26, 0.12), transparent 28%),
    rgba(4, 7, 15, 0.9);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
}

.spinner {
  width: 52px;
  height: 52px;
  border-width: 4px;
  box-shadow: 0 0 30px rgba(232, 68, 26, 0.15);
}

.loading-text {
  letter-spacing: 4px;
}

@keyframes premiumRise {
  from {
    opacity: 0;
    transform: translateY(18px) scale(0.985);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

@media (max-width: 900px) {
  .tab-bar {
    width: calc(100% - 24px);
    margin-top: 12px;
    padding: 6px;
    border-radius: 16px;
  }

  .dashboard-body {
    padding: 22px 12px 42px;
  }

  .topbar-executive {
    order: 3;
    width: 100%;
    justify-content: flex-start;
  }

  .topbar-actions {
    margin-left: auto;
  }

  .exec-pill {
    min-width: 0;
    flex: 1 1 145px;
  }

  .section-title {
    font-size: 22px;
    letter-spacing: 3px;
  }

  .welcome-card {
    padding: 34px 22px 28px;
    border-radius: 24px;
  }

  .hub-header-row,
  .topbar {
    padding: 14px 16px;
  }

  .card-value-row {
    align-items: flex-start;
    flex-direction: column;
  }

  .summary-card,
  .client-card,
  .welcome-client-card,
  .upload-zone {
    min-height: auto;
  }
}

@media (max-width: 1180px) {
  .topbar {
    flex-wrap: wrap;
    align-items: flex-start;
    gap: 12px;
  }

  .topbar-left {
    flex: 1 1 100%;
    min-width: 0;
  }

  .topbar-subtitle {
    white-space: normal;
    line-height: 1.45;
  }

  .topbar-executive {
    justify-content: flex-start;
    flex: 1 1 100%;
  }

  .topbar-actions {
    width: 100%;
    justify-content: flex-end;
  }

  .date-filter-bar {
    padding: 12px 18px;
  }

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

  .hub-home-grid {
    max-width: 100%;
  }

  .hub-panel-kpi-header {
    gap: 14px;
    align-items: flex-start;
  }

  .adm-panel,
  .admin-modal-panel {
    padding: 18px 18px;
  }
}

@media (max-width: 820px) {
  .topbar-logo {
    font-size: 21px;
    letter-spacing: 3px;
  }

  .topbar-divider {
    display: none;
  }

  .topbar-actions {
    gap: 10px;
    justify-content: stretch;
  }

  .topbar-actions .btn-home,
  .topbar-actions .btn-settings {
    flex: 1 1 0;
    justify-content: center;
  }

  .date-filter-bar {
    flex-direction: column;
    align-items: stretch;
    gap: 10px;
  }

  .df-label,
  .df-sep {
    display: none;
  }

  .df-input,
  .df-preset,
  .df-apply,
  .df-active-badge {
    width: 100%;
    justify-content: center;
  }

  .df-active-badge {
    justify-content: space-between;
  }

  .summary-grid,
  .welcome-clients-grid,
  .client-grid,
  .sede-grid {
    grid-template-columns: 1fr;
  }

  .comparison-grid,
  .tables-section {
    grid-template-columns: 1fr;
  }

  .hub-header-row {
    padding: 16px;
  }

  .hub-header-row > div:last-child {
    width: 100%;
    justify-content: stretch;
  }

  .hub-header-row .btn-home {
    flex: 1 1 0;
    justify-content: center;
  }

  .hub-kpi-table {
    min-width: 660px;
  }

  .table-card,
  .cross-card,
  .comparison-card,
  .mapping-card,
  .admin-card,
  .wt-attivita-section,
  .sede-manager {
    overflow-x: auto;
  }

  table,
  .mapping-table,
  .admin-table {
    min-width: 640px;
  }

  .welcome-user-bar {
    flex-direction: column;
    align-items: flex-start;
    gap: 10px;
  }

  .welcome-logout-btn {
    width: 100%;
  }

  .modal-box {
    padding: 24px 18px;
  }

  #admin-modal.open {
    padding: 10px 8px;
  }

  #admin-config-panel,
  .admin-modal-config {
    width: min(100vw - 16px, 1100px);
    max-height: calc(100vh - 20px);
    border-radius: 20px;
  }

  .adm-topbar {
    flex-wrap: wrap;
    gap: 12px;
    padding: 14px 16px;
  }

  .adm-tabs,
  .admin-modal-tabs,
  .tab-bar {
    scrollbar-width: thin;
  }

  .cred-edit-grid,
  .pm-grid,
  .ao-grid {
    grid-template-columns: 1fr;
  }

  .mapping-actions,
  .admin-save-row {
    width: 100%;
    flex-direction: column;
  }

  .btn-mapping-back,
  .btn-mapping-confirm,
  .btn-save-admin {
    width: 100%;
    justify-content: center;
  }
}

@media (max-width: 640px) {
  body {
    font-size: 13px;
  }

  #welcome-screen,
  #upload-hub,
  #client-screen,
  #upload-screen,
  #wt-upload-screen,
  #mapping-screen,
  #admin-screen {
    padding-left: 14px;
    padding-right: 14px;
  }

  .welcome-card {
    max-width: 100%;
    padding: 26px 16px 22px;
  }

  .welcome-logo {
    width: 100%;
    justify-content: center;
    text-align: left;
    gap: 10px;
  }

  .welcome-logo-text {
    font-size: 27px;
    letter-spacing: 3px;
  }

  .welcome-logo-sub {
    letter-spacing: 1.7px;
  }

  .upload-title,
  .client-title,
  .mapping-title,
  .admin-title {
    letter-spacing: 2.5px;
  }

  .section-title {
    font-size: 20px;
    letter-spacing: 2.4px;
  }

  .card-value {
    font-size: clamp(34px, 11vw, 44px);
  }

  .card-meta {
    flex-direction: column;
    align-items: flex-start;
    gap: 6px;
  }

  .card-meta span:last-child {
    text-align: left;
  }

  .exec-pill {
    flex: 1 1 100%;
  }

  .tab-btn,
  .adm-tab,
  .admin-modal-tab {
    font-size: 12px;
    letter-spacing: 1.2px;
    padding: 11px 14px;
  }

  .dashboard-body {
    padding: 18px 10px 36px;
  }

  .activity-badge {
    width: 100%;
    justify-content: center;
    text-align: center;
  }

  .hub-panel-kpi,
  .summary-card,
  .sede-card,
  .mapping-card,
  .admin-card,
  .table-card,
  .comparison-card {
    border-radius: 18px;
  }

  .upload-zone {
    min-height: 180px;
    padding: 24px 18px;
  }

  .upload-icon {
    font-size: 34px;
  }

  .client-card,
  .welcome-client-card {
    padding: 18px 14px;
  }

  .client-card-name,
  .welcome-client-card-name,
  .sede-card-name {
    letter-spacing: 1.8px;
  }

  .sede-metrics {
    grid-template-columns: 1fr;
  }

  .adm-panel {
    padding: 14px 12px;
  }

  .adm-panel-card,
  .cred-user-edit-row {
    padding: 12px;
  }
}

@media (max-width: 480px) {
  .topbar {
    padding: 12px;
  }

  .topbar-actions {
    flex-direction: column;
  }

  .topbar-actions .btn-home,
  .topbar-actions .btn-settings {
    width: 100%;
  }

  .topbar-logo {
    font-size: 19px;
    letter-spacing: 2px;
  }

  .topbar-subtitle {
    font-size: 11px;
  }

  .welcome-title {
    letter-spacing: 3px;
  }

  .welcome-input,
  .modal-input,
  .df-input,
  .filter-select {
    font-size: 16px;
  }

  .card-head {
    flex-direction: column;
    align-items: flex-start;
  }

  .card-badge,
  .card-delta {
    white-space: normal;
  }

  .table-card-header,
  .comparison-header,
  .mapping-card-header,
  .admin-card-header,
  .wt-attivita-header,
  .sede-manager-header {
    padding: 12px 14px;
    font-size: 15px;
    letter-spacing: 1.4px;
  }

  thead th,
  tbody td,
  .mapping-table thead th,
  .mapping-table tbody td,
  .admin-table thead th,
  .admin-table tbody td {
    padding-left: 10px;
    padding-right: 10px;
  }

  .hub-kpi-table {
    min-width: 600px;
  }

  table,
  .mapping-table,
  .admin-table {
    min-width: 580px;
  }
}

/* ===== Admin Modal Responsive Fix ===== */
.adm-topbar-main,
.cred-user-head,
.ao-client-title-wrap,
.prod-client-title {
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
  flex-wrap: wrap;
}

.cred-user-main {
  flex: 1;
  min-width: 0;
}

.cred-manual-actions,
.cred-import-actions,
.prod-panel-actions,
.adm-inline-actions {
  display: flex;
  align-items: center;
  gap: 8px;
}

.cred-manual-actions,
.cred-import-actions,
.prod-panel-actions {
  justify-content: flex-end;
}

.cred-import-actions {
  margin-top: 12px;
}

.adm-inline-actions {
  justify-content: flex-end;
  gap: 10px;
  margin-top: 10px;
}

.adm-inline-actions-split {
  justify-content: space-between;
}

.adm-table-wrap,
.pm-att-table-wrap,
.prod-table-wrap {
  width: 100%;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

.ao-sede-add-row {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 14px;
}

#admin-config-panel,
.admin-modal-config,
.adm-panel,
.ao-client-body,
.pm-client-body,
.cred-user-edit-row,
.prod-client-body {
  min-width: 0;
}

.pm-att-body table,
.admin-table,
.mapping-table,
.cred-pending-table,
.prod-table {
  min-width: 620px;
}

.pm-att-actions {
  padding: 8px 12px 0;
}

.cred-user-row {
  align-items: flex-start;
}

.prod-client-block {
  margin-bottom: 16px;
  border-radius: 18px;
  overflow: hidden;
  border: 1px solid var(--border);
  background: linear-gradient(180deg, rgba(18, 28, 49, 0.9) 0%, rgba(10, 16, 30, 0.96) 100%);
  box-shadow: var(--shadow-soft);
}

.prod-client-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 14px 16px;
  background: rgba(16, 26, 46, 0.88);
  cursor: pointer;
  user-select: none;
}

.prod-client-body {
  display: none;
  padding: 16px;
}

.prod-client-body.open {
  display: block;
}

.prod-client-title {
  color: var(--text);
  font-family: 'Bebas Neue', sans-serif;
  font-size: 18px;
  letter-spacing: 2px;
}

.prod-client-summary {
  font-family: 'DM Sans', sans-serif;
  font-size: 11px;
  font-weight: 400;
  color: var(--muted);
  letter-spacing: 0;
}

.prod-client-meta {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-left: auto;
  flex-shrink: 0;
}

.prod-client-count {
  font-family: 'DM Mono', monospace;
  font-size: 11px;
  color: var(--muted);
}

.prod-stats-bar {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  margin-bottom: 14px;
}

.prod-stat {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 10px;
  border-radius: 10px;
  border: 1px solid var(--border);
  background: rgba(16, 26, 46, 0.82);
  font-size: 11px;
  color: var(--muted);
}

.prod-refresh-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 9px 14px;
  border-radius: 10px;
  border: 1px solid rgba(59, 130, 246, 0.24);
  background: rgba(59, 130, 246, 0.08);
  color: var(--blue);
  font-family: 'Bebas Neue', sans-serif;
  font-size: 12px;
  letter-spacing: 1.6px;
  cursor: pointer;
  transition: all 0.18s ease;
}

.prod-refresh-btn:hover {
  border-color: rgba(59, 130, 246, 0.45);
  background: rgba(59, 130, 246, 0.14);
}

.prod-search {
  width: 100%;
  margin-bottom: 12px;
  padding: 10px 12px;
  border-radius: 10px;
  border: 1px solid var(--border);
  background: rgba(16, 26, 46, 0.82);
  color: var(--text);
  font-size: 13px;
}

.prod-search:focus {
  outline: none;
  border-color: var(--accent2);
}

.prod-table {
  width: 100%;
  border-collapse: collapse;
  min-width: 720px;
}

.prod-table th,
.prod-table td {
  padding: 10px 12px;
  border-bottom: 1px solid rgba(35, 46, 69, 0.5);
  vertical-align: middle;
}

.prod-table th {
  text-align: left;
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--muted);
  background: rgba(16, 26, 46, 0.88);
  white-space: nowrap;
}

.prod-type-select {
  width: 100%;
  min-width: 90px;
  padding: 7px 10px;
  border-radius: 8px;
  border: 1px solid var(--border);
  background: rgba(16, 26, 46, 0.82);
  color: var(--text);
  font-size: 12px;
}

.prod-type-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 4px 8px;
  border-radius: 999px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 1px;
  text-transform: uppercase;
}

.prod-type-auto {
  background: rgba(59, 130, 246, 0.14);
  color: var(--blue);
}

@media (max-width: 900px) {
  #admin-modal.open {
    padding: 0;
  }

  #admin-config-panel,
  .admin-modal-config {
    width: 100vw;
    max-width: 100vw;
    min-height: 100dvh;
    max-height: 100dvh;
    margin: 0;
    border-radius: 0;
    border-left: none;
    border-right: none;
  }

  .adm-topbar {
    position: sticky;
    top: 0;
    z-index: 6;
    border-radius: 0;
  }

  .adm-tabs {
    position: sticky;
    top: 72px;
    z-index: 5;
    padding: 6px 10px 0;
    gap: 8px;
  }

  .adm-panel {
    padding: 14px 12px 18px;
  }

  .cred-section {
    max-width: none;
    width: 100%;
  }

  .cred-user-row,
  .pm-client-header,
  .ao-client-header,
  .pm-att-header,
  .ao-section-title,
  .ao-anomaly-header,
  .prod-client-header,
  .adm-save-bar {
    flex-wrap: wrap;
  }

  .cred-user-row > .btn-remove-row {
    margin-left: auto;
  }

  .ao-sede-add-row,
  .cred-manual-actions,
  .cred-import-actions,
  .adm-inline-actions,
  .prod-panel-actions {
    flex-direction: column;
    align-items: stretch;
  }

  .adm-inline-actions-split {
    justify-content: stretch;
  }

  .ao-sede-add-row .btn-add-row,
  .cred-manual-actions .btn-save-admin,
  .cred-import-actions .btn-cred-cancel,
  .cred-import-actions .btn-cred-save,
  .adm-inline-actions .btn-save-admin,
  .adm-inline-actions .btn-mapping-back,
  .prod-panel-actions .prod-refresh-btn {
    width: 100%;
    justify-content: center;
  }

  .prod-client-meta {
    width: 100%;
    margin-left: 0;
    justify-content: space-between;
  }

  .prod-stats-bar {
    align-items: stretch;
  }

  .prod-stats-bar .prod-stat:last-of-type {
    margin-left: 0 !important;
  }
}

@media (max-width: 640px) {
  .adm-topbar {
    padding: 12px;
  }

  .adm-topbar-title {
    font-size: 18px;
    letter-spacing: 2px;
  }

  .adm-role-badge {
    width: 100%;
    justify-content: center;
  }

  .adm-tabs {
    top: 74px;
    padding: 6px 8px 0;
  }

  .adm-tab {
    font-size: 11px;
    letter-spacing: 1px;
    padding: 10px 12px;
  }

  .cred-edit-actions,
  .tl-client-checks,
  .cred-tl-checks-edit {
    flex-direction: column;
    align-items: stretch;
  }

  .tl-client-check,
  .cred-tl-check-edit {
    width: 100%;
  }

  .prod-client-body,
  .ao-client-body,
  .pm-client-body {
    padding-left: 12px;
    padding-right: 12px;
  }

  .prod-client-title {
    font-size: 16px;
    letter-spacing: 1.5px;
  }

  .prod-client-summary {
    width: 100%;
  }
}
