:root{color-scheme:light;--bg: #ffffff;--bg-secondary: #f8fafc;--text: #1e293b;--text-secondary: #64748b;--text-tertiary: #94a3b8;--primary: #2563eb;--primary-light: #3b82f6;--primary-dark: #1e40af;--border: #e2e8f0;--success: #10b981;--error: #ef4444;--shadow: 0 4px 24px rgba(15, 23, 42, .08);--shadow-card: 0 1px 3px rgba(15, 23, 42, .06), 0 8px 24px rgba(37, 99, 235, .06);--radius: 14px;--radius-sm: 10px;--sidebar-bg: linear-gradient(180deg, #0f172a 0%, #1e293b 100%);--sidebar-accent: #2563eb;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif}*{box-sizing:border-box}html,body{margin:0;min-height:100%}body{background:var(--bg-secondary);color:var(--text);line-height:1.5;-webkit-font-smoothing:antialiased}a{color:var(--primary)}.app-shell{display:grid;grid-template-columns:280px minmax(0,1fr);min-height:100vh;height:100vh;max-height:100vh}.sidebar{background:var(--sidebar-bg);color:#f8fafc;padding:0;display:flex;flex-direction:column;min-height:0;overflow:hidden;border-right:1px solid rgba(37,99,235,.2);box-shadow:4px 0 32px #0f172a1f}.main-panel{min-height:0;overflow:hidden;display:flex;flex-direction:column;background:var(--bg-secondary)}.main-panel .content{flex:1;overflow-y:auto;min-height:0;-webkit-overflow-scrolling:touch}.sidebar-brand{padding:20px 20px 16px;border-bottom:1px solid rgba(255,255,255,.08);flex-shrink:0}.sidebar-brand-logo{display:block;width:200px;max-width:100%;height:auto}.sidebar-brand .tagline{margin:6px 0 0;font-size:.7rem;text-transform:uppercase;letter-spacing:.12em;color:var(--text-tertiary);opacity:.9}.sidebar-brand .accent-bar{height:3px;width:48px;margin-top:14px;border-radius:999px;background:linear-gradient(90deg,var(--primary),var(--primary-light))}.sidebar-nav{display:flex;flex-direction:column;gap:4px;padding:16px 12px;flex:1;min-height:0;overflow-y:auto;overflow-x:hidden}.sidebar-nav a{color:#cbd5e1;text-decoration:none;padding:11px 14px;border-radius:var(--radius-sm);font-weight:500;font-size:.95rem;display:flex;align-items:center;gap:10px;transition:background .15s,color .15s}.sidebar-nav a:hover{background:#ffffff0f;color:#fff}.sidebar-nav a.active{background:linear-gradient(135deg,#2563eb59,#3b82f633);color:#fff;box-shadow:inset 0 0 0 1px #3b82f659}.sidebar-nav a .nav-icon{font-size:1.1rem;opacity:.9}.sidebar-footer{flex-shrink:0;margin-top:auto;padding:16px 20px 20px;border-top:1px solid rgba(255,255,255,.08);background:linear-gradient(180deg,transparent 0%,rgba(15,23,42,.5) 20%)}.sidebar-footer .user-line{margin:0 0 10px;font-size:.9rem;color:#e2e8f0;font-weight:500;word-break:break-word}.sidebar-footer .soft{font-size:.65rem;text-transform:uppercase;letter-spacing:.14em;color:#94a3b8;margin:0 0 8px}.btn-logout{width:100%;box-sizing:border-box;padding:10px 14px;border-radius:var(--radius-sm);font-weight:600;font:inherit;cursor:pointer;border:1px solid rgba(255,255,255,.22);background:#ffffff1a;color:#f8fafc}.btn-logout:hover{background:#ffffff29;border-color:#ffffff4d}.content{padding:28px 32px 40px;max-width:1200px;margin:0 auto;width:100%}.page-section{animation:fadeIn .35s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}.page-header{display:flex;flex-wrap:wrap;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:24px}.page-title{margin:0;font-size:1.65rem;font-weight:800;letter-spacing:-.03em;color:var(--text)}.page-subtitle{margin:8px 0 0;color:var(--text-secondary);font-size:.98rem;max-width:640px}.page-header-actions{display:flex;gap:10px;align-items:center}.section-heading{margin:32px 0 16px;font-size:1.1rem;font-weight:700;color:var(--text)}.card{background:var(--bg);border-radius:var(--radius);padding:20px;border:1px solid var(--border);box-shadow:var(--shadow-card)}.card-title{margin:0 0 14px;font-size:1rem;font-weight:700;color:var(--text)}.hint-card h4{margin:0 0 8px;font-size:.95rem}.small{font-size:.85rem}.grid{margin-top:8px;display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}.stat{transition:transform .2s ease}.stat:hover{transform:translateY(-2px)}.stat h3{margin:0;font-size:.85rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em}.stat p{font-size:2.1rem;margin:10px 0 0;font-weight:800;background:linear-gradient(135deg,var(--primary-dark),var(--primary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.dash-links{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:14px;margin-top:20px}.dash-link{display:block;padding:18px 20px;border-radius:var(--radius);border:1px solid var(--border);background:var(--bg);text-decoration:none;color:inherit;box-shadow:var(--shadow-card);transition:box-shadow .2s,border-color .2s}.dash-link:hover{border-color:#2563eb59;box-shadow:0 8px 28px #2563eb1f}.dash-link strong{display:block;font-size:1.05rem;color:var(--text);margin-bottom:4px}.dash-link span{font-size:.88rem;color:var(--text-secondary)}.dashboard-modern{display:grid;gap:18px}.dashboard-hero{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:16px;padding:22px 24px;background:linear-gradient(125deg,#2563eb1a,#3b82f608 45%,#fff);border:1px solid rgba(37,99,235,.24)}.dashboard-kicker{margin:0 0 4px;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--primary-dark)}.dashboard-hero-title{margin:0;font-size:1.35rem;line-height:1.2;letter-spacing:-.02em}.dashboard-hero-subtitle{margin:8px 0 0;max-width:700px;color:var(--text-secondary);font-size:.94rem}.dashboard-hero-actions{display:grid;justify-items:end;gap:8px}.dashboard-kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:14px}.dashboard-kpi{border:1px solid var(--border);box-shadow:var(--shadow-card);border-top-width:3px}.dashboard-kpi--blue{border-top-color:#2563eb}.dashboard-kpi--violet{border-top-color:#7c3aed}.dashboard-kpi--emerald{border-top-color:#10b981}.dashboard-kpi--amber{border-top-color:#f59e0b}.dashboard-kpi-label{margin:0;color:var(--text-secondary);font-size:.78rem;text-transform:uppercase;letter-spacing:.05em;font-weight:700}.dashboard-kpi-value{margin:10px 0 8px;font-size:2rem;line-height:1;font-weight:800;letter-spacing:-.03em}.dashboard-kpi-value--blue{color:#2563eb}.dashboard-kpi-value--violet{color:#7c3aed}.dashboard-kpi-value--emerald{color:#059669}.dashboard-kpi-value--amber{color:#d97706}.dashboard-kpi-meta{margin:0;color:var(--text-secondary);font-size:.86rem}.dashboard-left-column{display:flex;flex-direction:column;gap:12px;min-width:0}.dashboard-support-banner{display:flex;align-items:center;gap:14px;padding:16px 20px;border-radius:14px;background:linear-gradient(135deg,#1d4ed8,#2563eb 60%,#3b82f6);color:#fff;text-decoration:none;border:1px solid rgba(255,255,255,.15);box-shadow:0 4px 20px #2563eb4d;transition:box-shadow .18s ease,transform .18s ease}.dashboard-support-banner:hover{box-shadow:0 8px 28px #2563eb73;transform:translateY(-1px)}.dashboard-support-icon{font-size:1.5rem;flex-shrink:0}.dashboard-support-body{flex:1;display:flex;flex-direction:column;gap:2px}.dashboard-support-body strong{font-size:.9rem;font-weight:700;color:#fff}.dashboard-support-body span{font-size:.8rem;color:#ffffffbf}.dashboard-support-arrow{font-size:1.1rem;opacity:.8;flex-shrink:0}.dashboard-main-row{display:grid;grid-template-columns:minmax(300px,1fr) minmax(300px,1.05fr);gap:16px;align-items:start}.dashboard-quick-column{display:flex;flex-direction:column;min-width:0}.dashboard-quick-heading{margin:0 0 12px;padding-top:2px}.dashboard-actions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}.dashboard-actions-grid--aside{grid-template-columns:1fr 1fr;gap:10px}.dashboard-actions-sections{display:flex;flex-direction:column;gap:10px}.dashboard-action-section{border-radius:14px;padding:14px;border:1px solid transparent}.dashboard-action-section-label{display:block;font-size:.72rem;font-weight:800;letter-spacing:.07em;text-transform:uppercase;margin-bottom:10px;opacity:.75}.dashboard-action-section-cards{display:grid;grid-template-columns:1fr 1fr;gap:8px}.dashboard-action-section--blue{background:#2563eb0f;border-color:#2563eb2e}.dashboard-action-section--blue .dashboard-action-section-label{color:#1d4ed8}.dashboard-action-section--violet{background:#7c3aed0f;border-color:#7c3aed2e}.dashboard-action-section--violet .dashboard-action-section-label{color:#6d28d9}.dashboard-action-section--emerald{background:#10b9810f;border-color:#10b98133}.dashboard-action-section--emerald .dashboard-action-section-label{color:#047857}.dashboard-priority-card{padding:20px 22px;display:flex;flex-direction:column;border:1px solid rgba(37,99,235,.18);box-shadow:0 6px 28px #2563eb14}.dashboard-panel-title{margin:0 0 14px;font-size:1rem;font-weight:800;letter-spacing:-.01em}.dashboard-priority-body{min-width:0}.dashboard-priority-btn-lg{display:inline-flex;align-items:center;justify-content:center;padding:16px 26px;font-size:1.05rem;font-weight:700;border-radius:12px;min-height:54px;min-width:190px;text-decoration:none;text-align:center;box-sizing:border-box;transition:background .18s ease,color .18s ease,border-color .18s ease,box-shadow .18s ease}a.btn-secondary.dashboard-priority-btn-lg:visited{color:var(--text)}a.btn-secondary.dashboard-priority-btn-lg:hover{background:linear-gradient(135deg,var(--primary-dark) 0%,var(--primary) 100%);color:#fff;border-color:var(--primary-dark);box-shadow:0 6px 20px #2563eb66}.dashboard-priority-row{display:grid;grid-template-columns:auto minmax(0,1fr) auto;gap:16px 18px;align-items:center;padding:18px 0;border-top:1px solid var(--border)}.dashboard-priority-row:first-of-type{border-top:0;padding-top:2px}.priority-dot{width:10px;height:10px;border-radius:999px}.priority-dot.low{background:var(--success)}.priority-dot.medium{background:#f59e0b}.priority-dot.high{background:var(--error)}.dashboard-priority-title{margin:0 0 2px;font-size:.92rem;font-weight:700}.dashboard-priority-text{margin:0;font-size:.84rem;color:var(--text-secondary)}.dashboard-action-card{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:7px;text-decoration:none;color:inherit;background:#ffffffbf;border:1px solid rgba(255,255,255,.9);border-radius:10px;padding:16px 10px;text-align:center;transition:transform .15s ease,box-shadow .15s ease,background .15s ease}.dashboard-action-card:hover{transform:translateY(-2px);background:#fff;box-shadow:0 6px 18px #0000001a}.dashboard-action-icon{font-size:1.5rem;line-height:1}.dashboard-action-card strong{display:block;font-size:.85rem;font-weight:700;letter-spacing:-.01em}@media(max-width:720px){.dashboard-hero{padding:18px 16px}.dashboard-hero-actions{justify-items:start;width:100%}.dashboard-kpi-value{font-size:1.7rem}.dashboard-main-row{grid-template-columns:1fr}.dashboard-quick-heading{margin-top:4px}.dashboard-actions-grid--aside{grid-template-columns:repeat(3,1fr)}.dashboard-action-section-cards{grid-template-columns:1fr 1fr}.dashboard-priority-row{grid-template-columns:auto 1fr;align-items:start}.dashboard-priority-btn-lg{grid-column:1 / -1;width:100%;min-width:0}}.muted{color:var(--text-secondary)}.error{color:#b91c1c}.error-banner{margin:16px 0 0;padding:12px 14px;border-radius:var(--radius-sm);background:#fef2f2;color:#991b1b;border:1px solid #fecaca}.success-banner{margin:16px 0 0;padding:12px 14px;border-radius:var(--radius-sm);background:#ecfdf5;color:#065f46;border:1px solid #a7f3d0}.toolbar{margin:16px 0;display:flex;flex-wrap:wrap;gap:10px;align-items:center}.toolbar input{min-width:220px;flex:1;max-width:400px}.groups-members-head{display:flex;align-items:baseline;justify-content:space-between;gap:10px;margin-bottom:10px}.groups-members-search{margin-bottom:12px}.groups-members-search input{max-width:520px}.groups-members-list{display:grid;grid-template-columns:1fr;gap:8px;max-height:360px;overflow-y:auto;padding-right:4px}.groups-member-row{display:grid;grid-template-columns:auto minmax(180px,1fr) minmax(220px,1fr) minmax(120px,auto);align-items:center;gap:12px;margin:0;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-secondary);cursor:pointer}.groups-member-row:hover{border-color:#2563eb66;background:#f1f5ff}.groups-member-checkbox{width:16px!important;height:16px!important;margin:0;flex:0 0 auto;accent-color:var(--primary)}.groups-member-main{font-weight:600;color:var(--text);min-width:0}.groups-member-meta{color:var(--text-secondary);font-size:.86rem;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.timbrature-summary{display:flex;align-items:center;gap:0;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;margin-bottom:20px}.timbrature-summary-stat{display:flex;flex-direction:column;align-items:center;padding:16px 24px;flex:1;min-width:100px}.timbrature-summary-stat--in .timbrature-summary-value{color:#16a34a}.timbrature-summary-stat--out .timbrature-summary-value{color:#dc2626}.timbrature-summary-value{font-size:2rem;font-weight:800;line-height:1;font-variant-numeric:tabular-nums;color:var(--text)}.timbrature-summary-label{font-size:.75rem;color:var(--text-secondary);margin-top:4px;text-transform:uppercase;letter-spacing:.04em;font-weight:600}.timbrature-summary-divider{width:1px;align-self:stretch;background:var(--border)}.timbrature-section-count--in{color:#16a34a;font-weight:700}.timbrature-section-count--out{color:#dc2626;opacity:.85;font-weight:600}.timbrature-topbar{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:16px}.timbrature-live-status{display:flex;align-items:center;gap:8px;min-width:0}.timbrature-live-dot{width:10px;height:10px;border-radius:50%;background:#22c55e;box-shadow:0 0 #22c55e80;animation:timbrature-live-pulse 1.4s ease-in-out infinite;flex-shrink:0}@keyframes timbrature-live-pulse{0%,to{opacity:1;box-shadow:0 0 #22c55e73}50%{opacity:.75;box-shadow:0 0 0 8px #22c55e00}}.timbrature-live-label{font-weight:700;font-size:.9rem;color:var(--text)}.timbrature-storico-icon{font-size:1rem;line-height:1}.timbrature-live-updated{font-size:.8rem}.timbrature-date-nav{display:flex;align-items:stretch;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;background:var(--bg);flex-shrink:0}.timbrature-date-nav-arrow{display:flex;align-items:center;justify-content:center;padding:0 14px;background:none;border:none;font-size:1.4rem;font-weight:300;cursor:pointer;color:var(--text-secondary);transition:background .15s,color .15s;line-height:1;min-width:40px}.timbrature-date-nav-arrow:hover:not(:disabled){background:var(--bg-secondary);color:var(--primary)}.timbrature-date-nav-arrow:disabled{opacity:.25;cursor:not-allowed}.timbrature-date-nav-center{display:flex;align-items:stretch;border-left:1px solid var(--border);border-right:1px solid var(--border)}.timbrature-date-nav-input{width:auto!important;min-width:150px;border:none!important;box-shadow:none!important;background:transparent;font:inherit;font-weight:700;font-size:.95rem;color:var(--text);cursor:pointer;padding:10px 16px;text-align:center}.timbrature-topbar-actions{display:flex;gap:8px;align-items:center;margin-left:auto}.timbrature-live-search{min-width:200px;flex:1;max-width:320px}.timbrature-table-wrap{overflow-x:auto;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg)}.timbrature-table{width:100%;border-collapse:collapse;font-size:.88rem;table-layout:auto}.timbrature-table thead{position:sticky;top:0;z-index:1;background:var(--bg-secondary)}.timbrature-table th{padding:9px 12px;text-align:left;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);border-bottom:2px solid var(--border);white-space:nowrap}.timbrature-table th:first-child{width:110px}.timbrature-table th:nth-child(4){width:100px}.timbrature-table th:nth-child(5),.timbrature-table th:nth-child(6),.timbrature-table th:nth-child(7){width:80px}.timbrature-table th:last-child{width:1%;white-space:nowrap}.timbrature-table td{padding:8px 12px;border-bottom:1px solid var(--border);color:var(--text);vertical-align:middle}.timbrature-table-row{cursor:pointer;transition:background .12s}.timbrature-table-row--in{background:#22c55e0a}.timbrature-table-row--in:hover{background:#22c55e17}.timbrature-table-row--out{background:var(--bg)}.timbrature-table-row--out:hover{background:var(--bg-secondary)}.timbrature-table-row--absent{background:var(--bg)}.timbrature-table-row--absent td{color:var(--text-secondary)}.timbrature-table-row--absent:hover{background:var(--bg-secondary)}.t-status{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:20px;font-size:.75rem;font-weight:700;white-space:nowrap;letter-spacing:.02em}.t-status--in{background:#22c55e26;color:#15803d}.t-status-dot{width:7px;height:7px;border-radius:50%;background:#22c55e;flex-shrink:0;animation:timbrature-live-pulse 1.4s ease-in-out infinite}.t-status--out{background:#ef44441a;color:#b91c1c}.t-status--absent{background:#f59e0b1a;color:#b45309}.timbrature-table-code{font-family:monospace;font-size:.85rem;color:var(--text-secondary)}.timbrature-table-time{font-variant-numeric:tabular-nums;font-weight:600;white-space:nowrap}.timbrature-table-time--empty{color:var(--text-tertiary);font-weight:400}.timbrature-table-section td{padding:10px 16px 8px;background:var(--bg-secondary);border-top:2px solid var(--border);border-bottom:1px solid var(--border)}.timbrature-table-section--absent td{background:#94a3b80f;border-top-color:#94a3b84d}.timbrature-table-section-name{font-weight:700;font-size:.88rem;color:var(--text);margin-right:12px}.timbrature-table-section-counts{display:inline-flex;gap:10px;font-size:.8rem}.badge-in,.badge-out{font-size:.7rem;font-weight:800;letter-spacing:.04em;padding:4px 8px;border-radius:6px;text-transform:uppercase}.badge-in{background:#22c55e33;color:#15803d}.badge-out{background:#ef444433;color:#b91c1c}.badge-absent{font-size:.7rem;font-weight:800;letter-spacing:.04em;padding:4px 8px;border-radius:6px;text-transform:uppercase;background:#94a3b82e;color:var(--text-secondary)}.timbrature-filters-bar{display:flex;flex-wrap:wrap;gap:12px;align-items:flex-end;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;margin-bottom:20px}.timbrature-filter-group{display:flex;flex-direction:column;gap:4px;flex:1;min-width:160px;max-width:260px}.timbrature-filter-group--commessa{max-width:200px}.timbrature-filter-label{display:block;font-size:.75rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin:0}.timbrature-filter-input{width:100%}.timbrature-filter-select{width:100%;cursor:pointer}.timbrature-filter-reset{align-self:flex-end;padding:10px 14px;font-size:.82rem;font-weight:600;color:var(--text-secondary);background:none;border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;white-space:nowrap;transition:background .15s,color .15s,border-color .15s;margin-bottom:1px}.timbrature-filter-reset:hover{background:#ef44440f;color:var(--error);border-color:var(--error)}.timbrature-date-picker-wrap{display:flex;flex-direction:column;gap:3px}.timbrature-date-input{width:auto;padding:8px 12px;font-size:.92rem}.timbrature-live-label--storico{font-weight:600;font-size:.9rem;color:var(--text-secondary);font-style:italic}.timbrature-summary-stat--absent .timbrature-summary-value{color:#d97706}.mt-summary-row{display:flex;gap:0;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;margin-bottom:20px}.mt-summary-stat{display:flex;flex-direction:column;align-items:center;padding:16px 28px;flex:1}.mt-summary-stat+.mt-summary-stat{border-left:1px solid var(--border)}.mt-summary-value{font-size:2rem;font-weight:800;line-height:1;font-variant-numeric:tabular-nums}.mt-summary-label{font-size:.75rem;color:var(--text-secondary);margin-top:4px;text-transform:uppercase;letter-spacing:.04em;font-weight:600}.mt-summary-stat--assente .mt-summary-value{color:#d97706}.mt-summary-stat--presente .mt-summary-value{color:#16a34a}.mt-summary-stat--uscito .mt-summary-value{color:var(--text-secondary)}.mt-row--assente{background:#fbbf2414}.mt-row--assente:hover{background:#fbbf2426!important}.mt-row--presente{background:#22c55e0d}.mt-row--uscito{background:var(--bg)}.t-status--assente{background:#fbbf242e;color:#92400e}.mt-col-actions{width:1%;white-space:nowrap;vertical-align:middle}.mt-actions{display:flex;gap:5px;flex-wrap:nowrap;align-items:center}.mt-btn{padding:5px 11px;font-size:.78rem;font-weight:700;white-space:nowrap;border-radius:var(--radius-sm);border:1px solid transparent;cursor:pointer;transition:filter .12s,opacity .12s}.mt-btn--ingresso,.mt-btn--uscita,.mt-btn--pausa{background:var(--bg-secondary);color:var(--text-secondary);border-color:var(--border)}.mt-btn--ingresso:hover,.mt-btn--uscita:hover,.mt-btn--pausa:hover{background:var(--primary);color:#fff;border-color:var(--primary);filter:none}.mt-btn--giustifica{background:#fbbf2426;color:#92400e;border:1px solid rgba(251,191,36,.4);border-radius:var(--radius-sm);padding:6px 12px;font-size:.8rem;font-weight:600;cursor:pointer;transition:background .15s}.mt-btn--giustifica:hover{background:#fbbf244d}.mt-note-cell{max-width:160px}.mt-note{display:block;font-size:.82rem;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:140px}.mt-modal-overlay{position:fixed;inset:0;background:#0f172a73;z-index:100;display:flex;align-items:center;justify-content:center;padding:20px}.mt-modal{width:100%;max-width:480px;padding:0;overflow:hidden;animation:fadeIn .18s ease}.mt-modal-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:20px 24px 16px;border-bottom:1px solid var(--border)}.mt-modal-title{margin:0 0 4px;font-size:1.05rem;font-weight:800}.mt-modal-close{background:none;border:none;font-size:1.1rem;color:var(--text-secondary);cursor:pointer;padding:2px 6px;border-radius:6px;flex-shrink:0;transition:background .12s}.mt-modal-close:hover{background:var(--bg-secondary);color:var(--text)}.mt-modal-body{padding:20px 24px;display:flex;flex-direction:column;gap:14px}.mt-modal-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.mt-modal-toggle-group{display:grid;grid-template-columns:1fr 1fr;gap:8px}.mt-modal-toggle{padding:10px 14px;border-radius:var(--radius-sm);border:1.5px solid var(--border);background:var(--bg-secondary);color:var(--text-secondary);font-size:.875rem;font-weight:500;cursor:pointer;transition:background .15s,color .15s,border-color .15s;text-align:center}.mt-modal-toggle--active{background:var(--primary);color:#fff;border-color:var(--primary)}.mt-modal-toggle--danger{color:#dc2626;border-color:#dc26264d;background:#dc26260d}.mt-modal-toggle--danger-active{background:#dc2626;color:#fff;border-color:#dc2626}.mt-modal-error{margin:0 24px}.mt-modal-footer{display:flex;justify-content:flex-end;gap:10px;padding:16px 24px;border-top:1px solid var(--border);background:var(--bg-secondary)}.seg-detail{padding:28px 32px;animation:fadeIn .2s ease}.seg-detail-header{display:flex;align-items:center;gap:12px;margin-bottom:24px;flex-wrap:wrap}.seg-detail-meta{display:grid;grid-template-columns:1fr 1fr;gap:28px}@media(max-width:700px){.seg-detail-meta{grid-template-columns:1fr}}.seg-detail-section{display:flex;flex-direction:column;gap:12px}.seg-detail-title{margin:0;font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary);padding-bottom:6px;border-bottom:1px solid var(--border)}.seg-dl{display:grid;grid-template-columns:auto 1fr;gap:6px 16px;margin:0;font-size:.9rem}.seg-dl dt{color:var(--text-secondary);font-weight:600;white-space:nowrap}.seg-dl dd{margin:0;color:var(--text)}.seg-dl-time{display:flex;align-items:center;gap:8px;font-variant-numeric:tabular-nums;font-weight:600}.seg-edit-btn{flex-shrink:0}.seg-descrizione{margin:0;padding:12px 14px;background:#f59e0b12;border-left:3px solid #f59e0b;border-radius:0 var(--radius-sm) var(--radius-sm) 0;font-size:.9rem;color:var(--text);white-space:pre-wrap;word-break:break-word}.seg-flags{display:flex;flex-wrap:wrap;gap:6px}.seg-flag{font-size:.72rem;font-weight:700;padding:3px 8px;border-radius:4px;background:#ef44441a;color:#b91c1c;text-transform:uppercase;letter-spacing:.04em}.seg-descrizione-cell{max-width:260px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:.85rem;color:var(--text-secondary)}.user-create-form{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;align-items:end;margin-bottom:20px}.user-create-form .full-row{grid-column:1 / -1}@media(max-width:720px){.user-create-form{grid-template-columns:1fr}}.user-create-hint{margin:0;font-size:.88rem;color:var(--text-secondary)}.table{width:100%;border-collapse:collapse;background:var(--bg);border-radius:var(--radius);overflow:hidden;border:1px solid var(--border);box-shadow:var(--shadow-card)}.table th,.table td{text-align:left;padding:14px 16px;border-bottom:1px solid var(--border);vertical-align:middle}.table th{background:var(--bg-secondary);font-size:.78rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);font-weight:600}.table tbody tr:hover{background:#f8fafc}input,textarea,select,button{font:inherit}input,textarea,select{width:100%;border:1px solid var(--border);border-radius:var(--radius-sm);padding:11px 14px;background:var(--bg);color:var(--text);transition:border-color .15s,box-shadow .15s}input:focus,textarea:focus,select:focus{outline:none;border-color:#2563eb8c;box-shadow:0 0 0 3px #2563eb26}label{display:block;font-size:.88rem;font-weight:600;color:var(--text);margin-bottom:6px}button{border:none;border-radius:var(--radius-sm);padding:11px 18px;cursor:pointer;font-weight:600;transition:opacity .15s,transform .1s}button:disabled{opacity:.55;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-light) 100%);color:#fff;box-shadow:0 4px 14px #2563eb59}.btn-primary:hover:not(:disabled){filter:brightness(1.05)}a.btn-primary,a.btn-primary:visited{color:#fff;text-decoration:none;display:inline-flex;align-items:center;padding:11px 18px;border-radius:var(--radius-sm);cursor:pointer;font-weight:600;box-sizing:border-box}.btn-secondary{background:var(--bg-secondary);color:var(--text);border:1px solid var(--border)}a.btn-secondary,a.btn-secondary:visited{display:inline-flex;align-items:center;padding:11px 18px;border-radius:var(--radius-sm);font-weight:600;font-size:1rem;text-decoration:none;background:var(--bg-secondary);color:var(--text);border:1px solid var(--border);cursor:pointer;box-sizing:border-box}a.btn-secondary:hover{opacity:.85}button.danger,.btn-danger{background:#dc2626;color:#fff}.btn-danger:hover:not(:disabled){background:#b91c1c}.export-card .preset-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:8px;margin-bottom:16px}.btn-preset{padding:10px 12px;font-size:.82rem;font-weight:600;background:var(--bg-secondary);color:var(--text);border:1px solid var(--border);border-radius:var(--radius-sm)}.btn-preset:hover{border-color:#2563eb66;color:var(--primary)}.btn-preset.active{background:linear-gradient(135deg,#2563eb1f,#3b82f614);border-color:var(--primary);color:var(--primary-dark)}.form-row-dates{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:8px}.range-hint{margin:0 0 16px;font-size:.9rem}.format-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.radio-tile{display:flex;align-items:flex-start;gap:12px;padding:14px 16px;border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;background:var(--bg-secondary);transition:border-color .15s}.radio-tile:has(input:checked){border-color:var(--primary);background:#2563eb0f}.radio-tile input{width:auto;margin-top:4px}.radio-tile strong{display:block;color:var(--text)}.radio-tile small{display:block;color:var(--text-secondary);font-weight:400;margin-top:4px}.form-actions{margin-top:24px;padding-top:8px}.export-filters-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:8px;margin-bottom:14px}.export-filters-reset{background:none;border:1px dashed var(--border);border-radius:var(--radius-sm);padding:5px 12px;font-size:.82rem;font-weight:600;color:var(--text-secondary);cursor:pointer;transition:color .15s,border-color .15s}.export-filters-reset:hover{color:var(--error);border-color:var(--error)}.export-filters-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px;margin-bottom:8px}.export-filters-grid label:last-child{grid-column:1 / -1}.export-filters-info{margin:6px 0 0}.ss-wrap{position:relative}.ss-input-wrap{position:relative;display:flex;align-items:center}.ss-input{width:100%!important;padding-right:32px!important;cursor:pointer}.ss-wrap--open .ss-input{border-color:#2563eb8c;box-shadow:0 0 0 3px #2563eb26;cursor:text}.ss-clear,.ss-chevron{position:absolute;right:10px;background:none;border:none;padding:0;font-size:.85rem;color:var(--text-tertiary);cursor:pointer;line-height:1;pointer-events:auto}.ss-clear:hover{color:var(--error)}.ss-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;z-index:50;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--shadow);max-height:240px;overflow-y:auto;list-style:none;margin:0;padding:4px 0}.ss-option{padding:9px 14px;font-size:.88rem;cursor:pointer;color:var(--text);transition:background .1s;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ss-option:hover{background:var(--bg-secondary)}.ss-option--selected{background:#2563eb14;color:var(--primary);font-weight:600}.ss-option--empty{color:var(--text-tertiary);font-style:italic;cursor:default}.ss-option--empty:hover{background:none}.ss-option--check,.ss-option--all{display:flex;align-items:center;gap:10px}.ss-option--all{border-bottom:1px solid var(--border);font-weight:600;color:var(--text-secondary);font-size:.82rem}.ss-checkbox{width:15px!important;height:15px;flex-shrink:0;accent-color:var(--primary);cursor:pointer;margin:0;padding:0}.auth-shell{min-height:100vh;display:grid;place-items:center;padding:24px;background:linear-gradient(165deg,#eff6ff 0%,var(--bg-secondary) 45%,#f8fafc 100%)}.auth-shell--login{place-items:center;padding:32px 20px;background:linear-gradient(165deg,#1e3a8a 0%,var(--primary-dark) 35%,var(--primary) 70%,var(--primary-light) 100%);overflow:hidden}.auth-shell--login:before{content:"";position:fixed;width:700px;height:700px;border-radius:50%;background:radial-gradient(circle at center,rgba(255,255,255,.18) 0%,rgba(255,255,255,.07) 45%,transparent 70%);top:-280px;left:-220px;pointer-events:none;filter:blur(48px);will-change:transform;animation:loginBlob1 16s ease-in-out infinite alternate}.auth-shell--login:after{content:"";position:fixed;width:580px;height:580px;border-radius:50%;background:radial-gradient(circle at center,rgba(255,255,255,.14) 0%,rgba(255,255,255,.05) 45%,transparent 70%);bottom:-200px;right:-180px;pointer-events:none;filter:blur(56px);will-change:transform;animation:loginBlob2 20s ease-in-out infinite alternate}@keyframes loginBlob1{0%{transform:translate(0) scale(1)}25%{transform:translate(100px,60px) scale(1.08)}50%{transform:translate(60px,140px) scale(.96)}75%{transform:translate(180px,80px) scale(1.04)}to{transform:translate(120px,200px) scale(1.1)}}@keyframes loginBlob2{0%{transform:translate(0) scale(1)}25%{transform:translate(-80px,-50px) scale(1.06)}50%{transform:translate(-160px,-30px) scale(.94)}75%{transform:translate(-60px,-120px) scale(1.08)}to{transform:translate(-130px,-80px) scale(.98)}}.auth-card{width:100%;max-width:420px;display:flex;flex-direction:column;gap:14px;border:1px solid var(--border);box-shadow:var(--shadow-card);position:relative;overflow:hidden}.auth-card--floating{max-width:460px;width:100%;margin:0;padding:36px 40px 40px;gap:0;background:#fff;border:1px solid rgba(37,99,235,.1);border-radius:18px;box-shadow:0 2px 4px #0f172a0a,0 20px 48px #0f172a1f,0 0 0 1px #2563eb0f;z-index:1}.auth-card--floating .auth-brand-logo{width:min(280px,82vw)}.auth-card--floating .auth-brand{gap:12px;margin-bottom:8px}.auth-card--floating .auth-logo{font-size:.8rem;letter-spacing:.16em}.auth-intro{text-align:center;margin-bottom:24px}.auth-card--floating .auth-intro h1{margin:0 0 8px;font-size:1.75rem;font-weight:800;letter-spacing:-.03em;color:var(--text)}.auth-intro-text{margin:0;font-size:.98rem;line-height:1.45}.auth-fields{display:flex;flex-direction:column;gap:18px;margin-bottom:8px}.auth-password-wrap{position:relative;margin-top:8px}.auth-password-wrap input{margin-top:0;padding-right:52px;width:100%}.auth-password-toggle{position:absolute;right:10px;top:50%;transform:translateY(-50%);width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:none;border:none;color:var(--text-tertiary);cursor:pointer;border-radius:8px;padding:0;box-shadow:none;transition:color .15s,background .15s}.auth-password-toggle:hover{color:var(--text-secondary);background:var(--bg-secondary)}.auth-card--floating .auth-fields label{margin-bottom:0;font-size:.9rem;font-weight:600;color:var(--text)}.auth-card--floating .auth-fields input{margin-top:8px;padding:14px 16px;font-size:1.05rem;border-radius:var(--radius-sm)}.auth-card--floating .auth-fields input::placeholder{color:var(--text-tertiary)}.auth-error{margin:4px 0 0;padding:10px 12px;border-radius:var(--radius-sm);background:#fef2f2;border:1px solid #fecaca;font-size:.9rem}.auth-success{margin:4px 0 0;padding:10px 12px;border-radius:var(--radius-sm);background:#f0fdf4;border:1px solid #bbf7d0;color:#166534;font-size:.9rem}.auth-submit{width:100%;margin-top:12px;padding:16px 24px;font-size:1.08rem;font-weight:700;border-radius:var(--radius-sm)}.auth-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--primary),var(--primary-light),#0ea5e9)}.auth-card--floating:before{display:none}.auth-card h1{margin:4px 0 0;font-size:1.5rem;font-weight:800;letter-spacing:-.02em}.auth-brand{display:flex;flex-direction:column;align-items:center;gap:10px;margin-bottom:4px}.auth-brand-logo{width:min(260px,88vw);height:auto;max-width:100%;display:block}.auth-logo{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.14em;color:var(--primary);margin:0;text-align:center}.inline-form{display:grid;grid-template-columns:1fr 1fr auto;gap:10px;align-items:end}@media(max-width:720px){.inline-form{grid-template-columns:1fr}}.checkbox-row{display:flex;flex-wrap:wrap;gap:18px}.centered{display:grid;place-items:center;min-height:100vh;color:var(--text-secondary)}.table-link{font-weight:600;color:var(--primary);text-decoration:none}.table-link:hover{text-decoration:underline}.qr-detail-card,.qr-server-card{margin-top:20px}.presenze-card{margin-top:20px;display:flex;flex-direction:column;gap:16px}.presenze-card-head{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.presenze-date-input{padding:6px 10px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-secondary);color:var(--text);font:inherit;font-size:.9rem}.presenze-summary{display:flex;align-items:center;gap:8px;flex-wrap:wrap;font-size:.9rem;padding:10px 14px;background:var(--bg-secondary);border-radius:var(--radius-sm);border:1px solid var(--border)}.presenze-summary-item{color:var(--text)}.presenze-summary-in strong{color:#16a34a}.presenze-summary-sep{color:var(--text-secondary)}.presenze-list{display:flex;flex-direction:column;gap:10px}.presenze-employee{border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden}.presenze-employee-header{display:flex;align-items:center;gap:12px;padding:12px 14px;background:var(--bg-secondary)}.presenze-avatar{width:40px;height:40px;border-radius:50%;background:var(--primary);color:#fff;display:grid;place-items:center;font-size:.8rem;font-weight:700;flex-shrink:0}.presenze-employee-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.presenze-employee-name{font-weight:700;font-size:.95rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.presenze-employee-meta{font-size:.78rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.presenze-employee-right{display:flex;flex-direction:column;align-items:flex-end;gap:4px;flex-shrink:0}.presenze-status{font-size:.75rem;font-weight:700;padding:3px 8px;border-radius:99px;white-space:nowrap}.presenze-status--in{background:#16a34a26;color:#15803d}.presenze-status--out{background:#64748b1f;color:var(--text-secondary)}.presenze-total{font-size:.8rem;font-variant-numeric:tabular-nums}.presenze-sessions{display:flex;flex-direction:column;gap:0;border-top:1px solid var(--border)}.presenze-session{display:grid;grid-template-columns:auto 20px auto 1fr;align-items:center;gap:8px;padding:8px 14px;font-size:.85rem;border-bottom:1px solid var(--border);font-variant-numeric:tabular-nums}.presenze-session:last-child{border-bottom:none}.presenze-session-in,.presenze-session-out{display:flex;align-items:center;gap:6px}.presenze-session-arrow{color:var(--text-secondary);font-size:.75rem}.presenze-session-dur{text-align:right;font-size:.8rem}.presenze-pagination{display:flex;align-items:center;justify-content:center;gap:12px;padding-top:4px}.presenze-page-label{font-size:.85rem;min-width:100px;text-align:center}.qr-frame{display:flex;justify-content:center;padding:20px;background:var(--bg-secondary);border-radius:var(--radius-sm);border:1px solid var(--border)}.qr-image{display:block;image-rendering:pixelated}.qr-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px}.qr-regen-wrap{margin-top:18px;padding-top:14px;border-top:1px dashed var(--border);display:flex;justify-content:flex-start}.btn-qr-regen{background:linear-gradient(135deg,#f97316,#ef4444);color:#fff;box-shadow:0 6px 16px #ef444447}.btn-qr-regen:hover:not(:disabled){filter:brightness(1.04)}.link-button{background:none;border:none;padding:0;font:inherit;font-weight:600;color:var(--primary);cursor:pointer;text-align:left}.link-button:hover{text-decoration:underline}.server-regen-form{margin-top:16px;display:flex;flex-direction:column;gap:12px}.server-regen-form code{font-size:.8rem;background:var(--bg-secondary);padding:2px 6px;border-radius:4px}@media(max-width:980px){.app-shell{grid-template-columns:1fr;grid-template-rows:auto 1fr;height:auto;max-height:none;min-height:100vh}.sidebar{flex-direction:column;flex-wrap:nowrap;overflow:visible;border-right:none;border-bottom:1px solid rgba(37,99,235,.2);max-height:none}.sidebar-nav{flex-direction:row;flex-wrap:wrap;overflow-x:auto;overflow-y:visible;padding:12px;flex:0 1 auto;max-height:none}.sidebar-nav a{white-space:nowrap}.sidebar-footer{flex-direction:column;align-items:stretch;gap:10px}.main-panel{overflow:visible;min-height:0;flex:1}.main-panel .content{overflow-y:visible}.content{padding:20px 16px 32px}.format-row,.form-row-dates{grid-template-columns:1fr}.notifiche-toggles{flex-direction:column;align-items:stretch}.notifiche-list-head{flex-direction:column;align-items:flex-start;gap:12px}.btn-monitor{white-space:normal;text-align:left}.groups-member-row{grid-template-columns:auto minmax(0,1fr);align-items:start}.groups-member-main,.groups-member-meta{grid-column:2}}.notifiche-page .notifiche-form{margin-bottom:0;border-radius:var(--radius)}.notifiche-form-collapsible{margin-bottom:24px}.btn-nuova-notifica{display:block;width:fit-content;margin-bottom:16px;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-light) 100%);color:#fff;border:none;border-radius:var(--radius-sm);padding:12px 22px;font-size:.95rem;font-weight:700;cursor:pointer;box-shadow:0 4px 14px #2563eb59;transition:filter .15s,box-shadow .15s,transform .1s;white-space:nowrap}.btn-nuova-notifica:hover{filter:brightness(1.07);box-shadow:0 6px 20px #2563eb73;transform:translateY(-1px)}.btn-nuova-notifica.is-open{background:var(--bg-secondary);color:var(--text-secondary);box-shadow:none;border:1px solid var(--border)}.btn-nuova-notifica.is-open:hover{filter:none;transform:none;background:var(--bg);color:var(--text)}.notifiche-monitor-banner{display:flex;align-items:center;gap:16px;background:linear-gradient(135deg,#2563eb0f,#3b82f608);border:1px solid rgba(37,99,235,.18);border-radius:var(--radius);padding:16px 20px;margin:-8px 0 24px}.notifiche-monitor-banner-icon{flex-shrink:0;width:48px;height:48px;border-radius:var(--radius-sm);background:linear-gradient(135deg,var(--primary) 0%,var(--primary-light) 100%);color:#fff;display:flex;align-items:center;justify-content:center}.notifiche-monitor-banner-body{flex:1;display:flex;flex-direction:column;gap:3px;min-width:0}.notifiche-monitor-banner-title{font-weight:700;font-size:.95rem;color:var(--text)}.notifiche-monitor-banner-sub{font-size:.82rem;color:var(--text-muted, #64748b)}.notifiche-monitor-banner-btn{flex-shrink:0;text-decoration:none;display:inline-flex;align-items:center;white-space:nowrap}@media(max-width:540px){.notifiche-monitor-banner{flex-wrap:wrap}.notifiche-monitor-banner-btn{width:100%;justify-content:center}}.notifiche-form-title{margin:0 0 18px;font-size:1.05rem;font-weight:700;color:var(--text)}.notifiche-form-grid{display:flex;flex-direction:column;gap:14px}.notifiche-field-full{display:flex;flex-direction:column;gap:6px}.notifiche-toggles{display:flex;flex-wrap:wrap;gap:12px;margin-top:14px}.notifiche-toggle{display:inline-flex;align-items:center;gap:10px;padding:12px 16px;border:2px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;background:var(--bg-secondary);transition:border-color .15s,background .15s,box-shadow .15s;-webkit-user-select:none;user-select:none}.notifiche-toggle:hover{border-color:#2563eb59}.notifiche-toggle.active{border-color:var(--primary);background:#2563eb12;box-shadow:0 0 0 1px #2563eb26}.notifiche-toggle input[type=checkbox]{width:1.15rem;height:1.15rem;accent-color:var(--primary);cursor:pointer;flex-shrink:0}.users-table .users-expand-td{padding:0!important;border-bottom:2px solid rgba(37,99,235,.12)}.users-row{transition:background .12s}.users-row:hover td{background:var(--bg-secondary)}.users-row--expanded td{background:#2563eb08}.users-expand-btn{width:28px;height:28px;border-radius:6px;border:1px solid var(--border);background:none;cursor:pointer;font-size:1.1rem;font-weight:700;color:var(--text-secondary);display:flex;align-items:center;justify-content:center;transition:transform .2s,background .15s,color .15s;box-shadow:none;padding:0;line-height:1}.users-expand-btn--open{transform:rotate(90deg);background:#2563eb14;color:var(--primary);border-color:#2563eb40}.users-name-cell{display:flex;align-items:center;gap:12px}.users-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--primary-light));color:#fff;font-size:.72rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;letter-spacing:.03em}.users-fullname{font-weight:600;font-size:.95rem;color:var(--text)}.users-email{font-size:.82rem}.users-role-badge{display:inline-block;padding:3px 10px;border-radius:12px;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em}.users-role-admin{background:#ef44441a;color:#dc2626}.users-role-manager{background:#f59e0b1a;color:#d97706}.users-role-dipendente{background:#2563eb1a;color:var(--primary-dark)}.users-status{display:inline-block;padding:3px 10px;border-radius:12px;font-size:.8rem;font-weight:600}.users-status--active{background:#10b9811a;color:#059669}.users-status--inactive{background:#64748b1a;color:var(--text-secondary)}.user-expand-panel{padding:20px 24px 24px;background:linear-gradient(180deg,#f8faff,#f8fafc);animation:expandIn .2s ease}@keyframes expandIn{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:none}}.user-expand-stats{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:16px}.user-expand-stat{display:flex;flex-direction:column;align-items:center;background:#fff;border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px 20px;min-width:90px;flex:1;box-shadow:0 1px 3px #0f172a0a;gap:2px}.user-expand-stat-value{font-size:1.5rem;font-weight:800;color:var(--primary-dark);letter-spacing:-.03em}.user-expand-stat-label{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-secondary)}.user-expand-stat--warn .user-expand-stat-value{color:#d97706}.user-expand-stat--ok .user-expand-stat-value{color:var(--success)}.hours-chart{background:#fff;border:1px solid var(--border);border-radius:var(--radius-sm);padding:14px 16px 10px;margin-bottom:14px}.hours-chart-label{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-secondary);margin-bottom:10px}.hours-chart-bars{display:flex;gap:3px;height:88px;overflow-x:auto;padding-bottom:4px}.hours-bar-wrap{display:flex;flex-direction:column;align-items:center;flex:1;min-width:18px;max-width:32px;gap:3px;cursor:default}.hours-bar-inner{flex:1;display:flex;align-items:flex-end;width:100%}.hours-bar{width:100%;border-radius:3px 3px 0 0;background:var(--primary);opacity:.75;transition:opacity .12s}.hours-bar-wrap:hover .hours-bar{opacity:1}.hours-bar--late{background:#f59e0b}.hours-bar--none{background:var(--border);opacity:.6}.hours-bar-day{font-size:.6rem;color:var(--text-tertiary);font-weight:500;line-height:1}.hours-chart-legend{display:flex;align-items:center;gap:14px;margin-top:8px;font-size:.72rem;color:var(--text-secondary)}.hours-legend-dot{display:inline-block;width:10px;height:10px;border-radius:2px;margin-right:4px;vertical-align:middle}.hours-legend-dot--normal{background:var(--primary);opacity:.75}.hours-legend-dot--late{background:#f59e0b}.hours-legend-dot--none{background:var(--border)}.user-expand-footer{display:flex;justify-content:flex-end}.users-create-panel{background:#fff;border:1px solid rgba(37,99,235,.2);border-radius:var(--radius);box-shadow:0 4px 24px #2563eb14;padding:22px 24px 24px;margin-bottom:20px;animation:expandIn .2s ease}.users-create-panel-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}.users-create-panel-title{margin:0;font-size:1.05rem;font-weight:700;color:var(--text)}.auth-hexagons{position:fixed;inset:0;pointer-events:none;overflow:hidden}.auth-hex{position:absolute;clip-path:polygon(50% 0%,100% 25%,100% 75%,50% 100%,0% 75%,0% 25%);background:#ffffff12;will-change:transform,opacity}.auth-hex--0{width:140px;height:160px;top:8%;left:4%;animation:hexFloat0 18s ease-in-out infinite alternate}.auth-hex--1{width:90px;height:104px;top:22%;left:14%;animation:hexFloat1 22s ease-in-out infinite alternate;opacity:.6}.auth-hex--2{width:200px;height:230px;top:-6%;right:6%;animation:hexFloat2 20s ease-in-out infinite alternate;opacity:.5}.auth-hex--3{width:110px;height:126px;top:40%;right:3%;animation:hexFloat3 16s ease-in-out infinite alternate}.auth-hex--4{width:70px;height:80px;bottom:18%;left:8%;animation:hexFloat4 14s ease-in-out infinite alternate;opacity:.5}.auth-hex--5{width:160px;height:184px;bottom:-4%;left:25%;animation:hexFloat5 24s ease-in-out infinite alternate;opacity:.45}.auth-hex--6{width:100px;height:115px;bottom:12%;right:10%;animation:hexFloat6 19s ease-in-out infinite alternate}.auth-hex--7{width:60px;height:69px;top:60%;left:45%;animation:hexFloat7 15s ease-in-out infinite alternate;opacity:.4}@keyframes hexFloat0{0%{transform:translate(0) rotate(0)}to{transform:translate(24px,40px) rotate(25deg)}}@keyframes hexFloat1{0%{transform:translate(0) rotate(10deg)}to{transform:translate(-18px,30px) rotate(-15deg)}}@keyframes hexFloat2{0%{transform:translate(0) rotate(-5deg)}to{transform:translate(-30px,50px) rotate(20deg)}}@keyframes hexFloat3{0%{transform:translate(0) rotate(15deg)}to{transform:translate(20px,-35px) rotate(-20deg)}}@keyframes hexFloat4{0%{transform:translate(0) rotate(0)}to{transform:translate(30px,-20px) rotate(30deg)}}@keyframes hexFloat5{0%{transform:translate(0) rotate(-10deg)}to{transform:translate(-20px,-40px) rotate(15deg)}}@keyframes hexFloat6{0%{transform:translate(0) rotate(5deg)}to{transform:translate(-25px,20px) rotate(-25deg)}}@keyframes hexFloat7{0%{transform:translate(0) rotate(20deg)}to{transform:translate(15px,-30px) rotate(-10deg)}}.groups-form-card{margin-bottom:20px}.groups-form-title{margin:0 0 18px;font-size:1.05rem;font-weight:700;color:var(--text)}.groups-form-name-row{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-bottom:20px}.groups-form-name-row input{flex:1;min-width:200px}.groups-form-pickers{display:grid;grid-template-columns:1fr 1fr;gap:20px}@media(max-width:760px){.groups-form-pickers{grid-template-columns:1fr}}.groups-picker-header{display:flex;align-items:center;gap:8px;margin-bottom:8px}.groups-picker-label{font-size:.82rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-secondary)}.groups-picker-count{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;border-radius:10px;background:var(--primary);color:#fff;font-size:.75rem;font-weight:700}.groups-chips{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px}.groups-chip{display:inline-flex;align-items:center;gap:4px;padding:4px 10px 4px 12px;background:#2563eb1a;border:1px solid rgba(37,99,235,.2);border-radius:20px;font-size:.85rem;font-weight:600;color:var(--primary-dark)}.groups-chip-remove{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border:none;background:#2563eb26;border-radius:50%;color:var(--primary-dark);cursor:pointer;font-size:.9rem;line-height:1;padding:0;box-shadow:none;transition:background .12s}.groups-chip-remove:hover{background:#2563eb4d}.groups-picker-search{width:100%;margin-bottom:8px}.groups-picker-list{border:1px solid var(--border);border-radius:var(--radius-sm);overflow-y:auto;max-height:200px}.groups-picker-list--tall{max-height:340px}.groups-picker-item{display:flex;align-items:center;gap:10px;width:100%;padding:9px 12px;background:none;border:none;border-bottom:1px solid var(--border);text-align:left;cursor:pointer;transition:background .12s;box-shadow:none;border-radius:0;color:var(--text)}.groups-picker-item:last-child{border-bottom:none}.groups-picker-item:hover{background:var(--bg-secondary)}.groups-picker-item--selected{background:#2563eb0f}.groups-picker-item--selected:hover{background:#2563eb1a}.groups-picker-checkbox{flex-shrink:0;width:18px;height:18px;border-radius:4px;border:2px solid var(--border);display:inline-flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:700;color:#fff;transition:border-color .12s,background .12s}.groups-picker-checkbox--checked{border-color:var(--primary);background:var(--primary)}.groups-picker-item-name{flex:1;font-weight:600;font-size:.9rem;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.groups-picker-item-meta{font-size:.8rem;color:var(--text-secondary);flex-shrink:0}.groups-picker-empty{padding:16px;text-align:center;color:var(--text-secondary);font-size:.88rem;margin:0}.groups-picker-more{width:100%;border-radius:0;border-top:1px solid var(--border);font-size:.85rem;box-shadow:none}.groups-table .groups-table-name{font-weight:700}.groups-table-mgr{display:flex;flex-wrap:wrap;gap:4px}.groups-table-mgr-pill{display:inline-block;padding:2px 10px;border-radius:12px;background:#2563eb1a;color:var(--primary-dark);font-size:.8rem;font-weight:600}.groups-table-count{display:inline-block;padding:2px 10px;border-radius:12px;background:var(--bg-secondary);border:1px solid var(--border);color:var(--text-secondary);font-size:.82rem;font-weight:600}.groups-table-actions{display:flex;gap:6px;justify-content:flex-end}.groups-manager-group-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}.groups-manager-group-title{margin:0;font-size:1.05rem;font-weight:700;color:var(--text)}.notifiche-toggle-label{font-weight:600;font-size:.9rem;color:var(--text)}.notifiche-form-actions{margin-top:20px;display:flex;flex-wrap:wrap;gap:10px}.notifiche-group-picker{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:10px}.notifiche-group-btn{display:grid;grid-template-columns:1fr auto;grid-template-rows:auto auto;align-items:center;gap:4px 10px;text-align:left;width:100%;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-secondary);color:var(--text);padding:11px 12px}.notifiche-group-btn:hover:not(:disabled){border-color:#2563eb73;background:#f1f5ff}.notifiche-group-btn.selected{border-color:var(--primary);background:#2563eb1a;box-shadow:0 0 0 1px #2563eb1f}.notifiche-group-btn-name{grid-column:1;grid-row:1;font-weight:700;font-size:.94rem}.notifiche-group-btn-meta{grid-column:1;grid-row:2;color:var(--text-secondary);font-size:.82rem}.notifiche-group-btn-check{grid-column:2;grid-row:1 / span 2;width:22px;height:22px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;border:1px solid rgba(37,99,235,.4);color:var(--primary-dark);font-weight:800;font-size:.9rem;line-height:1;background:#fff}.notifiche-group-btn.selected .notifiche-group-btn-check{background:var(--primary);border-color:var(--primary);color:#fff}.btn-notifiche-send{min-width:160px;padding:13px 28px;font-size:.95rem;font-weight:700;box-shadow:0 4px 14px #2563eb4d}.btn-notifiche-send:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 20px #2563eb66}.btn-notifiche-cancel{padding:13px 20px;font-size:.95rem}.notifiche-list-head{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:16px;margin:8px 0 14px}.notifiche-list-title{margin:0;font-size:1.05rem;font-weight:700;color:var(--text)}.btn-notifiche-refresh{padding:10px 18px;font-weight:600}.table-wrap{overflow-x:auto;border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow-card)}.notifiche-table{margin:0;border-radius:0;border:none;box-shadow:none}.notifiche-col-actions{width:1%;white-space:nowrap;vertical-align:middle}.notifiche-cell-date{font-size:.88rem;color:var(--text-secondary);white-space:nowrap}.notifiche-badge{display:inline-block;padding:4px 10px;border-radius:999px;font-size:.78rem;font-weight:600;background:var(--bg-secondary);color:var(--text-secondary)}.notifiche-badge.urgente{background:#fef2f2;color:#b91c1c;border:1px solid #fecaca}.btn-monitor{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;border-radius:var(--radius-sm);border:1px solid rgba(37,99,235,.45);background:linear-gradient(180deg,#2563eb1f,#2563eb0a);color:var(--primary-dark);font-weight:600;font-size:.88rem;cursor:pointer;transition:background .15s,border-color .15s,box-shadow .15s}.btn-monitor:hover{border-color:var(--primary);background:linear-gradient(180deg,#2563eb2e,#2563eb14);box-shadow:0 4px 14px #2563eb33}.btn-monitor:active{transform:scale(.98)}.btn-monitor:disabled{opacity:.65;cursor:not-allowed;transform:none}.notifiche-report-error{margin-top:24px;padding:20px;border-radius:var(--radius-md, 12px);border:1px solid rgba(239,68,68,.4);background:linear-gradient(180deg,#fef2f2,#fff)}.notifiche-report-error-title{font-weight:800;margin:0 0 8px;color:#b91c1c}.notifiche-report-error-msg{margin:0 0 16px;line-height:1.45}.notifiche-report-error-actions{display:flex;flex-wrap:wrap;gap:10px;align-items:center}.notifiche-report-error-actions a.btn-secondary{text-decoration:none}.btn-notifiche-close-text{background:none;border:none;color:var(--text-secondary);cursor:pointer;font-weight:600;font-size:.9rem;padding:8px 4px;text-decoration:underline}.btn-notifiche-close-text:hover{color:var(--text)}.btn-monitor-icon{font-size:1.1rem;line-height:1}.notifiche-report{margin-top:24px;border:1px solid rgba(37,99,235,.2);background:linear-gradient(180deg,#fff,#f8fafc)}.notifiche-report-modern{border-radius:var(--radius-md, 12px);box-shadow:0 10px 24px #0f172a14}.notifiche-report-head{display:flex;flex-wrap:wrap;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:16px}.notifiche-report-head h3{margin:0 0 4px;font-size:1.05rem}.notifiche-report-head-actions{display:inline-flex;gap:8px;flex-wrap:wrap}.notifiche-report-sub{margin:0;font-size:.9rem}.btn-notifiche-close{padding:8px 16px;font-weight:600}.notifiche-report-stats{margin-top:4px}.notifiche-report-progress{margin-bottom:14px}.notifiche-report-table-wrap{border-radius:var(--radius-sm);border:1px solid var(--border);overflow:hidden}.notifiche-report-table tbody tr:hover{background:#2563eb0a}.notifiche-report-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:0}.notifiche-report-list li{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:10px;padding:12px 14px;border-bottom:1px solid var(--border);font-size:.95rem}.notifiche-report-list li:last-child{border-bottom:none}.notifiche-report-user{font-weight:500;color:var(--text)}.notifiche-report-status{font-size:.82rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;padding:4px 10px;border-radius:999px}.notifiche-report-status.ok{background:#ecfdf5;color:#047857}.notifiche-report-status.pending{background:#fffbeb;color:#b45309}.user-detail-toolbar{margin-bottom:8px}.user-detail-readonly{margin-bottom:20px}.user-detail-dl{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px 24px;margin:0}.user-detail-dl>div{margin:0}.user-detail-dl dt{font-size:.78rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text-secondary);margin-bottom:4px}.user-detail-dl dd{margin:0;font-size:.95rem;word-break:break-word}.user-detail-role-pill{display:inline-block;padding:4px 12px;border-radius:999px;font-size:.82rem;font-weight:700;background:#2563eb1f;color:var(--primary-dark)}.user-detail-form,.user-detail-role,.user-detail-history{margin-bottom:20px}.user-detail-form-head{margin-bottom:16px}.user-detail-form-head .card-title{margin-bottom:8px}.user-detail-form-hint{margin:0;line-height:1.45}.user-detail-form-hint--editing{color:var(--primary-dark);font-weight:500}.user-detail-form--locked{background:linear-gradient(180deg,#f8fafc,#f1f5f9);border-color:#64748b40}.user-detail-form--locked .user-detail-fields label{color:var(--text-secondary)}.user-detail-form--locked input:disabled,.user-detail-form--locked textarea:disabled{cursor:default;background:#e2e8f0!important;color:#64748b!important;border-color:#cbd5e1!important;opacity:1;-webkit-text-fill-color:#64748b}.user-detail-form--locked input[type=date]:disabled::-webkit-calendar-picker-indicator{opacity:.35}.user-detail-form--locked .user-detail-checkbox span{color:var(--text-secondary)}.user-detail-form--locked .user-detail-checkbox input:disabled{opacity:.55;cursor:not-allowed}.user-detail-form--editing .user-detail-fields label{color:var(--text)}.user-detail-fields{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px 18px}.user-detail-fields label{display:flex;flex-direction:column;gap:6px;font-weight:600;font-size:.9rem}.user-detail-span-2{grid-column:1 / -1}.user-detail-checkbox{flex-direction:row!important;align-items:flex-start;gap:10px!important;font-weight:500!important}.user-detail-checkbox input{margin-top:4px;width:1.1rem;height:1.1rem;accent-color:var(--primary)}.user-detail-actions{margin-top:20px;display:flex;flex-wrap:wrap;gap:10px}.user-detail-role-row{display:grid;grid-template-columns:minmax(140px,200px) 1fr;gap:16px;align-items:end;margin-top:12px}.user-detail-reason{display:flex;flex-direction:column;gap:6px;font-weight:600;font-size:.9rem}.user-detail-code{font-size:.82rem}.btn-user-open{padding:8px 14px;font-size:.88rem;font-weight:600;text-decoration:none;display:inline-block}.time-select-field{display:inline-flex;align-items:center;gap:2px;border:1px solid var(--border);border-radius:6px;overflow:hidden;background:var(--surface)}.time-select-field select{border:none;outline:none;background:transparent;font-size:.95rem;font-weight:600;font-variant-numeric:tabular-nums;color:var(--text-primary);padding:8px 4px 8px 10px;cursor:pointer;appearance:none;-webkit-appearance:none}.time-select-field select:focus{background:#2563eb0f}.time-select-sep{font-weight:700;font-size:1rem;color:var(--text-secondary);-webkit-user-select:none;user-select:none}.time-select-field--disabled{background:#e2e8f0;border-color:#cbd5e1}.time-select-field--disabled select{color:#64748b;cursor:default;pointer-events:none}@media(max-width:720px){.user-detail-fields,.user-detail-role-row,.monitor-letture-layout{grid-template-columns:1fr}.monitor-letture-toolbar{flex-direction:column;align-items:stretch}.monitor-letture-link-notif{text-align:center}.monitor-overview-grid{grid-template-columns:1fr}}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.monitor-letture-page .monitor-letture-toolbar,.notifiche-page .monitor-letture-toolbar{display:flex;flex-wrap:wrap;align-items:center;gap:12px 16px;padding:14px 18px;margin-bottom:20px}.monitor-letture-search{flex:1;min-width:200px;margin:0}.monitor-letture-search input{width:100%}.monitor-letture-toolbar-actions{display:flex;align-items:center;gap:10px;margin-left:auto;padding-left:16px;border-left:1px solid var(--border)}.monitor-letture-check{display:inline-flex;align-items:center;gap:10px;font-size:.88rem;font-weight:700;color:var(--text-secondary);margin:0;cursor:pointer;padding:8px 12px;border-radius:999px;border:1px solid var(--border);background:#fff;transition:border-color .15s ease,color .15s ease,background .15s ease,box-shadow .15s ease}.monitor-letture-check input{position:absolute;opacity:0;width:1px;height:1px;pointer-events:none}.monitor-letture-check-indicator{position:relative;width:38px;height:22px;border-radius:999px;border:1px solid var(--border);background:var(--bg-secondary);transition:background .15s ease,border-color .15s ease}.monitor-letture-check-indicator:after{content:"";position:absolute;top:2px;left:2px;width:16px;height:16px;border-radius:50%;background:#fff;box-shadow:0 1px 3px #0f172a40;transition:transform .15s ease}.monitor-letture-check:hover{border-color:#2563eb59;color:var(--text)}.monitor-letture-check.is-active{border-color:#2563eb73;background:#2563eb14;color:var(--primary-dark);box-shadow:0 4px 12px #2563eb29}.monitor-letture-check.is-active .monitor-letture-check-indicator{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-light) 100%);border-color:var(--primary)}.monitor-letture-check.is-active .monitor-letture-check-indicator:after{transform:translate(16px)}.monitor-letture-check:focus-within{outline:2px solid rgba(37,99,235,.35);outline-offset:2px}.monitor-letture-link-notif{text-decoration:none;margin-left:auto;display:inline-flex;align-items:center;gap:8px;padding:10px 14px;border-radius:10px;border:1px solid rgba(37,99,235,.28);background:linear-gradient(180deg,#fff,#f8fbff);color:var(--primary-dark);font-weight:700;transition:border-color .15s ease,box-shadow .15s ease,transform .1s ease,background .15s ease}.monitor-letture-link-notif:hover{border-color:#2563eb73;background:linear-gradient(180deg,#fff,#eff6ff);box-shadow:0 6px 14px #2563eb24}.monitor-letture-link-notif:active{transform:translateY(1px)}.monitor-letture-link-icon{width:20px;height:20px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;background:#2563eb1f;color:var(--primary);line-height:1}.monitor-overview-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-bottom:18px}.monitor-overview-card{border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px 14px;background:linear-gradient(180deg,#fff,#f8fafc)}.monitor-overview-card--warn{background:linear-gradient(180deg,#fff7ed,#fff);border-color:#fed7aa}.monitor-overview-card--info{background:linear-gradient(180deg,#eff6ff,#fff);border-color:#bfdbfe}.monitor-overview-label{display:block;font-size:.75rem;color:var(--text-secondary);font-weight:700;text-transform:uppercase;letter-spacing:.05em}.monitor-overview-value{display:block;margin-top:5px;font-size:1.2rem;font-weight:800;color:var(--text)}.monitor-letture-layout{display:grid;grid-template-columns:minmax(0,1fr) minmax(320px,480px);gap:20px;align-items:start}.monitor-letture-subtitle{margin:0 0 12px;font-size:1rem;font-weight:700;color:var(--text)}.monitor-letture-table-wrap{margin-bottom:8px}.monitor-letture-table-wrap .monitor-row-selected td{background:#2563eb14}.monitor-badge{display:inline-block;margin-left:8px;padding:2px 8px;border-radius:999px;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;vertical-align:middle}.monitor-badge--req{background:#fef3c7;color:#b45309}.monitor-badge--urg{color:#b91c1c;font-weight:700;background:#fef2f2;border:1px solid #fecaca}.monitor-col-actions{width:1%;white-space:nowrap}.monitor-cell-date{font-size:.88rem;color:var(--text-secondary);white-space:nowrap}.btn-monitor-open{padding:7px 14px;font-size:.82rem;font-weight:700;white-space:nowrap;letter-spacing:.01em}.btn-monitor-open:not(.is-active):hover{filter:brightness(1.07)}.btn-monitor-open.is-active{background:linear-gradient(135deg,#16a34a,#22c55e);box-shadow:0 2px 8px #16a34a4d}.monitor-letture-detail{padding:20px 22px;position:sticky;top:16px}.monitor-fullscreen{padding:28px 32px;animation:fadeIn .2s ease}.monitor-fullscreen-header{display:flex;align-items:flex-start;gap:20px;margin-bottom:24px;flex-wrap:wrap}.btn-monitor-back{background:var(--bg-secondary);color:var(--text-secondary);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 16px;font-size:.88rem;font-weight:600;cursor:pointer;white-space:nowrap;flex-shrink:0;transition:background .15s,color .15s,border-color .15s}.btn-monitor-back:hover{background:var(--bg);color:var(--text);border-color:var(--primary)}.monitor-fullscreen-meta{flex:1;min-width:0}.monitor-fullscreen-title{margin:0 0 4px;font-size:1.4rem;font-weight:800;letter-spacing:-.02em;color:var(--text);line-height:1.2}.monitor-fullscreen-stats{margin-bottom:20px}.monitor-fullscreen-progress{margin-bottom:28px}.monitor-letture-empty{padding:12px 4px}.monitor-letture-empty-title{margin:0 0 8px;font-size:1.05rem;font-weight:700}.monitor-letture-error{display:flex;flex-direction:column;align-items:flex-start;gap:12px}.monitor-detail-head{display:flex;flex-wrap:wrap;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:16px}.monitor-detail-title{margin:0 0 6px;font-size:1.1rem;font-weight:800;line-height:1.3}.monitor-stats{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-bottom:16px}.monitor-stat{padding:12px 14px;border-radius:var(--radius-sm);background:var(--bg-secondary);border:1px solid var(--border)}.monitor-stat--ok{background:#ecfdf5;border-color:#a7f3d0}.monitor-stat--warn{background:#fffbeb;border-color:#fde68a}.monitor-stat-label{display:block;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary);margin-bottom:4px}.monitor-stat-value{font-size:1.1rem;font-weight:800;color:var(--text)}.monitor-progress{margin-bottom:18px}.monitor-progress-label{display:flex;justify-content:space-between;font-size:.85rem;font-weight:600;color:var(--text-secondary);margin-bottom:6px}.monitor-progress-bar{height:10px;border-radius:999px;background:var(--bg-secondary);border:1px solid var(--border);overflow:hidden}.monitor-progress-fill{height:100%;border-radius:999px;background:linear-gradient(90deg,var(--primary),var(--primary-light));transition:width .25s ease}.monitor-notifiche-list-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px;flex-wrap:wrap}.monitor-notifiche-list-header .monitor-letture-subtitle{margin:0;display:flex;align-items:center;gap:8px}.monitor-recipients-header{display:flex;align-items:center;gap:12px;margin-bottom:10px;flex-wrap:wrap}.monitor-recipients-search{flex:1;min-width:180px;max-width:280px;padding:8px 12px;font-size:.88rem}.monitor-recipients-title{margin:0;font-size:.95rem;font-weight:700;display:flex;align-items:center;gap:8px}.monitor-recipients-count{font-size:.8rem;font-weight:500;color:var(--text-secondary)}.monitor-recipients-pagination{display:flex;align-items:center;gap:6px}.pagination-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:1.1rem;color:var(--text-secondary);cursor:pointer;transition:background .12s,color .12s,border-color .12s}.pagination-btn:hover:not(:disabled){background:var(--bg-secondary);color:var(--primary);border-color:var(--primary)}.pagination-btn:disabled{opacity:.3;cursor:not-allowed}.pagination-info{font-size:.85rem;font-weight:600;color:var(--text);min-width:48px;text-align:center;font-variant-numeric:tabular-nums}.monitor-recipients-table{font-size:.9rem}.monitor-recipients-table th,.monitor-recipients-table td{padding:10px 12px;vertical-align:middle}.monitor-recipients-table tbody tr:hover{background:#2563eb0a}
