:root{--bg:#020617;--surface:#0f172a99;--surface-hover:#0f172acc;--surface-solid:#0f172a;--border:#ffffff14;--border-strong:#ffffff26;--accent:#818cf8;--accent-glow:#6366f14d;--accent-gradient:linear-gradient(135deg, #6366f1 0%, #a855f7 50%, #ec4899 100%);--green:#10b981;--green-glow:#10b98133;--yellow:#f59e0b;--red:#ef4444;--text:#f8fafc;--text-muted:#94a3b8;--text-dark:#cbd5e1;--font-sans:"Inter", system-ui, sans-serif;--font-mono:"JetBrains Mono", monospace;--radius:12px;--radius-lg:20px;--radius-xl:28px;--shadow:0 4px 24px -6px #0006;--shadow-lg:0 16px 40px -8px #0009;--shadow-glow:0 0 40px var(--accent-glow);--transition:.3s cubic-bezier(.16, 1, .3, 1);--transition-fast:.15s cubic-bezier(.4, 0, .2, 1)}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);color:var(--text);font-family:var(--font-sans);-webkit-font-smoothing:antialiased;min-height:100vh;overflow-x:hidden}body:before,body:after{content:"";filter:blur(120px);z-index:-1;opacity:.4;pointer-events:none;border-radius:50%;width:60vw;height:60vh;animation:25s ease-in-out infinite alternate drift;position:fixed}body:before{background:radial-gradient(circle,#6366f180 0%,#0000 70%);top:-20%;left:-10%}body:after{background:radial-gradient(circle,#ec48994d 0%,#0000 70%);animation-delay:-12s;bottom:-20%;right:-10%}@keyframes drift{0%{transform:translate(0)scale(1)}to{transform:translate(10%,10%)scale(1.1)}}.text-gradient{background:var(--accent-gradient);color:#0000;-webkit-background-clip:text;background-clip:text;padding-bottom:2px}#login-screen{background:var(--bg);z-index:1000;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.login-box{background:var(--surface);-webkit-backdrop-filter:blur(24px)saturate(1.5);border:1px solid var(--border);border-radius:var(--radius-xl);width:440px;box-shadow:var(--shadow-lg), var(--shadow-glow);text-align:center;padding:56px 48px;animation:.6s cubic-bezier(.34,1.56,.64,1) forwards scaleUp;position:relative;overflow:hidden}.login-box:before{content:"";background:linear-gradient(90deg, transparent, var(--accent), transparent);opacity:.8;height:1px;position:absolute;top:0;left:0;right:0}@keyframes scaleUp{0%{opacity:0;transform:translateY(40px)scale(.9)}to{opacity:1;transform:translateY(0)scale(1)}}.login-logo{font-family:var(--font-mono);letter-spacing:.2em;text-transform:uppercase;color:var(--text-muted);margin-bottom:24px;font-size:14px;font-weight:800}.login-title{letter-spacing:-.04em;margin-bottom:48px;font-size:32px;font-weight:800}.login-field{text-align:left;margin-bottom:28px}.login-field label{color:var(--text-muted);letter-spacing:.02em;margin-bottom:10px;font-size:13px;font-weight:600;display:block}.login-field input{border:1px solid var(--border);border-radius:var(--radius);width:100%;color:var(--text);font-family:var(--font-mono);transition:all var(--transition);background:#0003;outline:none;padding:16px;font-size:15px}.login-field input:focus{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-glow);background:#0006}.login-btn{background:var(--accent-gradient);border-radius:var(--radius);color:#fff;width:100%;font-family:var(--font-sans);letter-spacing:.02em;cursor:pointer;transition:all var(--transition-fast);border:none;margin-top:16px;padding:18px;font-size:16px;font-weight:700;box-shadow:0 8px 24px #6366f166}.login-btn:hover{filter:brightness(1.1);transform:translateY(-2px);box-shadow:0 12px 32px #6366f180}.login-btn:active{transform:translateY(0)}.login-error{font-family:var(--font-mono);color:var(--red);border-radius:var(--radius);background:#ef44441a;border:1px solid #ef444433;margin-top:20px;padding:12px;font-size:13px;display:none}#app{box-sizing:border-box;flex-direction:column;gap:24px;max-width:1800px;height:100vh;margin:0 auto;padding:24px;display:none}.topbar{background:var(--surface);-webkit-backdrop-filter:blur(24px);border:1px solid var(--border);border-radius:var(--radius-lg);height:72px;box-shadow:var(--shadow);flex-shrink:0;align-items:center;gap:24px;padding:0 32px;display:flex}.topbar-brand{font-family:var(--font-mono);letter-spacing:.12em;text-transform:uppercase;font-size:15px;font-weight:800}.topbar-sep{background:var(--border-strong);width:1px;height:24px}.topbar-appalto{font-family:var(--font-mono);color:var(--text-muted);font-size:14px}.topbar-appalto span{color:var(--text);font-weight:700}.topbar-status{background:var(--green-glow);font-family:var(--font-mono);color:var(--green);border:1px solid #10b9814d;border-radius:99px;align-items:center;gap:10px;margin-left:auto;padding:8px 16px;font-size:12px;font-weight:600;display:flex}.status-dot{background:var(--green);width:6px;height:6px;box-shadow:0 0 12px var(--green);border-radius:50%;animation:2s infinite pulse}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.topbar-user{color:var(--text-muted);border:1px solid var(--border);cursor:pointer;transition:all var(--transition-fast);background:#ffffff08;border-radius:99px;padding:10px 20px;font-size:14px;font-weight:600}.topbar-user:hover{color:#fff;background:#ef444426;border-color:#ef44444d}.main-layout{flex:1;gap:24px;min-height:0;display:flex;overflow:hidden}.sidebar{background:var(--surface);-webkit-backdrop-filter:blur(24px);border:1px solid var(--border);border-radius:var(--radius-lg);width:280px;box-shadow:var(--shadow);flex-direction:column;flex-shrink:0;padding:28px 20px;display:flex}.sidebar-label{letter-spacing:.15em;color:var(--text-muted);text-transform:uppercase;margin-bottom:24px;padding:0 16px;font-size:12px;font-weight:700}.sidebar-item{color:var(--text-muted);cursor:pointer;border-radius:var(--radius);transition:all var(--transition-fast);border:1px solid #0000;align-items:center;gap:14px;margin-bottom:8px;padding:16px;font-size:15px;font-weight:600;text-decoration:none;display:flex}.sidebar-item:hover{color:var(--text);background:#ffffff0f}.sidebar-item.active{color:var(--text);background:linear-gradient(135deg,#6366f126,#a855f726);border-color:#6366f14d;box-shadow:inset 0 0 24px #6366f114}.sidebar-item-left{align-items:center;gap:12px;display:flex}.dot-indicator{background:var(--text-muted);width:8px;height:8px;transition:all var(--transition-fast);border-radius:50%}.sidebar-item.active .dot-indicator{background:var(--accent);box-shadow:0 0 12px var(--accent)}.sidebar-count{font-family:var(--font-mono);color:var(--text-muted);transition:all var(--transition);background:#ffffff0d;border-radius:99px;margin-left:auto;padding:4px 12px;font-size:12px;font-weight:700}.sidebar-item.active .sidebar-count{background:var(--accent-glow);color:var(--accent)}.sidebar-footer{border-top:1px solid var(--border);margin-top:auto;padding-top:20px}.btn-outline{border:1px solid var(--border);border-radius:var(--radius);width:100%;color:var(--text-muted);font-family:var(--font-sans);cursor:pointer;transition:all var(--transition-fast);background:#ffffff05;justify-content:center;align-items:center;gap:10px;padding:14px;font-size:14px;font-weight:600;display:flex}.btn-outline:hover{color:var(--text);border-color:var(--border-strong);background:#ffffff14}.toggle-wrap{border-radius:var(--radius);border:1px solid var(--border);transition:all var(--transition-fast);background:#ffffff08;flex-wrap:wrap;justify-content:space-between;align-items:center;margin-bottom:10px;padding:14px 18px;display:flex}.toggle-wrap:hover{background:#ffffff0f}.toggle-info{flex-direction:column;gap:4px;display:flex}.toggle-name{color:var(--text);font-size:14px;font-weight:600}.toggle-device{font-family:var(--font-mono);color:var(--text-muted);font-size:11px}.toggle{flex-shrink:0;width:44px;height:24px;position:relative}.toggle input{opacity:0;width:0;height:0}.toggle-slider{cursor:pointer;background:#ffffff1a;border-radius:99px;transition:all .3s;position:absolute;inset:0}.toggle-slider:before{content:"";background:#fff;border-radius:50%;width:18px;height:18px;transition:all .3s;position:absolute;top:3px;left:3px}.toggle input:checked+.toggle-slider{background:var(--green)}.toggle input:checked+.toggle-slider:before{transform:translate(20px)}.tecnici-panel{padding:32px 40px}.tecnici-header{margin-bottom:24px}.tecnici-note{font-family:var(--font-mono);color:var(--text-muted);border-radius:var(--radius);background:#f59e0b1a;border:1px solid #f59e0b33;margin-top:8px;padding:10px 14px;font-size:12px}.tecnici-actions{align-items:center;gap:8px;margin-left:auto;display:flex}.btn-tecnico-action{border:1px solid var(--border);color:var(--text-muted);cursor:pointer;font-size:12px;font-family:var(--font-sans);transition:all var(--transition-fast);white-space:nowrap;background:0 0;border-radius:8px;align-items:center;gap:5px;padding:6px 10px;font-weight:600;display:flex}.btn-tecnico-action:hover{color:var(--text);border-color:var(--border-strong);background:#ffffff14}.btn-tecnico-action.btn-rename:hover{color:var(--accent);background:#6366f11a;border-color:#6366f166}.btn-tecnico-action.btn-delete:hover{color:var(--red);background:#ef44441a;border-color:#ef444466}.content{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);min-height:0;box-shadow:var(--shadow);flex-direction:column;flex:1;display:flex;position:relative;overflow:auto}.content-header{border-bottom:1px solid var(--border);z-index:60;background:#0003;flex-wrap:wrap;flex-shrink:0;align-items:center;gap:24px;padding:32px 40px;display:flex;position:relative;overflow:visible}.content-title{letter-spacing:-.03em;font-size:32px;font-weight:800}.content-subtitle{font-family:var(--font-mono);color:var(--text-muted);border-left:1px solid var(--border-strong);padding-left:16px;font-size:13px;font-weight:500}.content-actions{z-index:70;align-items:center;gap:14px;margin-left:auto;display:flex;position:relative;overflow:visible}.select-fancy{border:1px solid var(--border);color:var(--text);font-family:var(--font-mono);cursor:pointer;appearance:none;transition:all var(--transition-fast);background:#0000004d url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='none' stroke='%2394a3b8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M3 5l3 3 3-3'/%3E%3C/svg%3E") right 16px center no-repeat;border-radius:99px;outline:none;padding:10px 40px 10px 20px;font-size:13px;font-weight:600}.select-fancy:hover,.select-fancy:focus{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-glow)}.select-fancy option{background:var(--surface-solid);color:var(--text)}.snapshot-dropdown{z-index:80;min-width:210px;position:relative}.snapshot-trigger{border:1px solid var(--border);width:100%;color:var(--text);font-family:var(--font-mono);cursor:pointer;transition:all var(--transition-fast);background:#0000004d;border-radius:99px;justify-content:space-between;align-items:center;gap:12px;padding:10px 14px 10px 18px;font-size:13px;font-weight:600;display:flex}.snapshot-trigger:hover,.snapshot-dropdown.open .snapshot-trigger{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-glow)}.snapshot-trigger svg{transition:transform var(--transition-fast);flex-shrink:0}.snapshot-dropdown.open .snapshot-trigger svg{transform:rotate(180deg)}.snapshot-label{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.snapshot-menu{z-index:9999;border:1px solid var(--border-strong);background:var(--surface-solid);-webkit-backdrop-filter:blur(20px);box-shadow:var(--shadow-lg);border-radius:16px;max-height:280px;padding:8px;display:none;position:absolute;top:calc(100% + 10px);left:0;right:0;overflow:auto}.snapshot-dropdown.open .snapshot-menu{animation:.15s fadeIn;display:block}.snapshot-option{text-align:left;width:100%;color:var(--text);font-family:var(--font-mono);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:1px solid #0000;border-radius:10px;padding:10px 12px;font-size:13px;font-weight:600}.snapshot-option:hover{background:#6366f11f;border-color:#6366f140}.snapshot-option.active{color:var(--text);background:#6366f12e;border-color:#6366f152}button:disabled{cursor:not-allowed}.btn-icon-text{border:1px solid var(--border);color:var(--text);font-family:var(--font-sans);cursor:pointer;transition:all var(--transition-fast);background:#ffffff0d;border-radius:99px;align-items:center;gap:8px;padding:10px 20px;font-size:13px;font-weight:600;display:flex}.btn-icon-text:hover{background:var(--text);color:var(--bg);border-color:var(--text);transform:translateY(-1px)}.btn-icon-text:disabled{opacity:.4;cursor:not-allowed;filter:grayscale();transform:none}.btn-icon-text:disabled:hover{color:var(--text);border-color:var(--border);background:#ffffff0d;transform:none}.table-scroll{z-index:1;flex:1;min-height:0;margin-top:24px;padding:0 40px 24px;position:relative}table{border-collapse:separate;border-spacing:0;width:100%}thead th{border-bottom:1px solid var(--border-strong);background:#0f172ae6;padding:0}.th-inner{text-align:left;padding:14px 16px}.th-material{letter-spacing:.1em;color:var(--text-dark);text-transform:uppercase;background:inherit;min-width:190px;font-size:11px;font-weight:700}.th-tech{text-align:center;min-width:120px}.tech-name{color:var(--text);justify-content:center;align-items:center;gap:8px;margin-bottom:6px;font-size:13px;font-weight:700;display:flex}.tech-time{font-family:var(--font-mono);color:var(--text-muted);font-size:10px;display:block}.tech-location{font-family:var(--font-mono);color:var(--accent);background:var(--accent-glow);transition:all var(--transition-fast);border-radius:6px;margin-top:6px;padding:4px 10px;font-size:10px;text-decoration:none;display:inline-block}.tech-location:hover{color:#fff;background:#6366f180}.tech-nav-left{appearance:none;color:var(--accent);cursor:pointer;transition:color var(--transition-fast), transform var(--transition-fast);background:0 0;border:none;flex-shrink:0;margin:0 6px 0 0;padding:0;font-size:14px;line-height:1;display:none}.tech-nav-left:hover{color:var(--accent-glow);transform:translate(-1px)}tbody tr{transition:background-color var(--transition-fast)}tbody tr:hover{background:#ffffff08}tbody tr.extra-row{background:#f59e0b0d}tbody tr.extra-row:hover{background:#f59e0b14}tbody tr.extra-row .td-material{border-left:3px solid var(--yellow);color:var(--yellow);padding-left:11px}td{vertical-align:middle;border-bottom:1px solid #ffffff0a;padding:12px 14px}.td-material{background:var(--surface-solid);color:var(--text);white-space:nowrap;border-right:1px solid var(--border);transition:background-color var(--transition-fast);font-size:13px;font-weight:600}tbody tr:hover .td-material{background:#1e293b}.td-value{text-align:center;font-family:var(--font-mono);font-size:13px;font-weight:700}.td-value.has-value{color:#fff;text-shadow:0 0 10px #fff6;background:#ffffff0f;border-radius:8px;padding:8px 0}.td-value.empty{color:var(--text-muted);font-weight:500}.separator-row td{font-family:var(--font-sans);letter-spacing:.2em;color:var(--accent);text-transform:uppercase;border-bottom:1px solid var(--border-strong);padding:12px 14px;font-size:11px;font-weight:800;background:#00000080!important}.state-box{text-align:center;flex-direction:column;justify-content:center;align-items:center;height:100%;padding:120px 40px;display:flex}.state-box p{color:var(--text-muted);margin-top:24px;font-size:18px;font-weight:500}.loader-spinner{border:4px solid #6366f133;border-top-color:var(--accent);border-radius:50%;width:56px;height:56px;animation:1s linear infinite spin;box-shadow:0 0 24px #6366f14d}@keyframes spin{to{transform:rotate(360deg)}}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{border:2px solid var(--surface-solid);background:#ffffff26;border-radius:99px}::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.status-circle{border-radius:50%;width:10px;height:10px}.status-green{background:var(--green);box-shadow:0 0 16px #10b98180}.status-yellow{background:var(--yellow);box-shadow:0 0 16px #f59e0b80}.status-red{background:var(--red);box-shadow:0 0 16px #ef444480}.pfs-check-wrapper{cursor:pointer;align-items:center;display:inline-flex;position:relative}.pfs-check-wrapper input{opacity:0;width:0;height:0;position:absolute}.pfs-check-custom{border:2px solid var(--border-strong);background:#ffffff08;border-radius:6px;justify-content:center;align-items:center;width:20px;height:20px;transition:all .2s;display:flex}.pfs-check-wrapper:hover .pfs-check-custom{border-color:var(--accent);background:#6366f11a}.pfs-check-wrapper input:checked+.pfs-check-custom{background:var(--accent);border-color:var(--accent);box-shadow:0 0 12px var(--accent-glow)}.pfs-check-custom:after{content:"✓";color:#fff;font-size:14px;font-weight:800;display:none}.pfs-check-wrapper input:checked+.pfs-check-custom:after{display:block}.btn-delete-row{border:1px solid var(--border);color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast);background:#ffffff08;border-radius:8px;justify-content:center;align-items:center;padding:6px;display:flex}.btn-delete-row:hover{color:var(--red);background:#ef44441a;border-color:#ef44444d;transform:scale(1.1)}.delete-toolbar{-webkit-backdrop-filter:blur(16px);border:1px solid var(--border-strong);background:#1e293bcc;border-radius:20px;justify-content:space-between;align-items:center;margin-bottom:32px;padding:16px 24px;animation:.4s cubic-bezier(.16,1,.3,1) slideDown;display:none;box-shadow:0 10px 40px #0006}.btn-bulk-delete{background:var(--red);color:#fff;cursor:pointer;transition:all var(--transition-fast);border:none;border-radius:99px;padding:10px 24px;font-size:13px;font-weight:700}.btn-bulk-delete:hover{filter:brightness(1.2);transform:translateY(-1px);box-shadow:0 4px 12px #ef444466}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:.5s cubic-bezier(.2,.8,.2,1) forwards fadeIn}@keyframes fadeIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.menu-toggle{color:var(--text);cursor:pointer;border-radius:var(--radius);transition:all var(--transition-fast);background:0 0;border:none;padding:8px;display:none}.menu-toggle:hover{background:#ffffff1a}.menu-close{color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;border-radius:50%;padding:4px;display:none}.menu-close:hover{color:var(--text);background:#ffffff1a}.sidebar-header-mobile{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.sidebar-header-mobile .sidebar-label{margin-bottom:0}.sidebar-overlay{-webkit-backdrop-filter:blur(4px);z-index:90;opacity:0;pointer-events:none;width:100vw;height:100vh;transition:opacity var(--transition);background:#0009;position:fixed;top:0;left:0}.sidebar-overlay.show{opacity:1;pointer-events:auto}#offline-banner{color:var(--yellow);font-family:var(--font-mono);text-align:center;background:#f59e0b26;border-bottom:1px solid #f59e0b4d;flex-shrink:0;justify-content:center;align-items:center;gap:10px;padding:10px 24px;font-size:12px;font-weight:600;animation:.4s cubic-bezier(.16,1,.3,1) slideDown;display:none}#offline-banner.show{display:flex}#toast-container{z-index:9999;pointer-events:none;flex-direction:column;gap:10px;display:flex;position:fixed;bottom:28px;right:28px}.toast{border-radius:var(--radius);border:1px solid var(--border-strong);background:var(--surface-solid);-webkit-backdrop-filter:blur(20px);min-width:280px;max-width:400px;box-shadow:var(--shadow-lg);color:var(--text);pointer-events:auto;cursor:pointer;align-items:center;gap:12px;padding:14px 18px;font-size:14px;font-weight:500;animation:.4s cubic-bezier(.16,1,.3,1) forwards toastIn;display:flex}.toast.hide{animation:.3s forwards toastOut}.toast-icon{flex-shrink:0;font-size:18px}.toast-msg{flex:1}.toast-success{border-left:3px solid var(--green)}.toast-error{border-left:3px solid var(--red)}.toast-info{border-left:3px solid var(--accent)}.toast-warning{border-left:3px solid var(--yellow)}@keyframes toastIn{0%{opacity:0;transform:translate(40px)}to{opacity:1;transform:translate(0)}}@keyframes toastOut{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(40px)}}#confirm-overlay{z-index:8000;-webkit-backdrop-filter:blur(6px);background:#0009;justify-content:center;align-items:center;animation:.2s fadeIn;display:none;position:fixed;inset:0}#confirm-overlay.show{display:flex}.confirm-box{background:var(--surface-solid);border:1px solid var(--border-strong);border-radius:var(--radius-xl);width:420px;max-width:calc(100vw - 32px);box-shadow:var(--shadow-lg);flex-direction:column;gap:20px;padding:36px 32px;animation:.3s cubic-bezier(.34,1.56,.64,1) scaleUp;display:flex}.confirm-icon{text-align:center;font-size:36px}.confirm-title{color:var(--text);text-align:center;font-size:18px;font-weight:700}.confirm-msg{color:var(--text-muted);text-align:center;font-size:14px;line-height:1.6}.confirm-actions{justify-content:center;gap:12px;display:flex}.confirm-btn-cancel{border-radius:var(--radius);border:1px solid var(--border-strong);color:var(--text-muted);font-family:var(--font-sans);cursor:pointer;transition:all var(--transition-fast);background:0 0;flex:1;padding:12px;font-size:14px;font-weight:600}.confirm-btn-cancel:hover{color:var(--text);background:#ffffff0f}.confirm-btn-ok{border-radius:var(--radius);background:var(--red);color:#fff;font-family:var(--font-sans);cursor:pointer;transition:all var(--transition-fast);border:none;flex:1;padding:12px;font-size:14px;font-weight:700;box-shadow:0 4px 16px #ef44444d}.confirm-btn-ok:hover{filter:brightness(1.15);transform:translateY(-1px)}.confirm-btn-ok.btn-accent{background:var(--accent-gradient);box-shadow:0 4px 16px #6366f14d}.search-wrap{flex-shrink:0;margin-top:16px;margin-bottom:-8px;padding:0 40px}.search-input{border:1px solid var(--border);width:100%;max-width:360px;color:var(--text);font-family:var(--font-sans);transition:all var(--transition-fast);background:#0003 url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' fill='none' stroke='%2394a3b8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='6' cy='6' r='4'/%3E%3Cpath d='M10 10l3 3'/%3E%3C/svg%3E") 16px no-repeat;border-radius:99px;outline:none;padding:10px 20px 10px 40px;font-size:13px}.search-input:focus{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-glow);background-color:#0000004d}.search-input::placeholder{color:var(--text-muted)}#rename-overlay{z-index:8000;-webkit-backdrop-filter:blur(6px);background:#0009;justify-content:center;align-items:center;display:none;position:fixed;inset:0}#rename-overlay.show{display:flex}.rename-field{border:1px solid var(--border-strong);border-radius:var(--radius);width:100%;color:var(--text);font-family:var(--font-mono);transition:all var(--transition);background:#0003;outline:none;padding:14px 16px;font-size:15px}.rename-field:focus{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-glow);background:#00000059}.btn-spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;flex-shrink:0;width:14px;height:14px;animation:.8s linear infinite spin}.kpi-grid{flex-shrink:0;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-top:20px;padding:0 40px;display:grid}.kpi-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);-webkit-backdrop-filter:blur(24px);transition:all var(--transition-fast);flex-direction:column;gap:6px;padding:24px;display:flex}.kpi-card:hover{border-color:var(--border-strong);box-shadow:var(--shadow);transform:translateY(-2px)}.kpi-icon{font-size:24px}.kpi-value{font-family:var(--font-mono);letter-spacing:-.02em;font-size:28px;font-weight:800}.kpi-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;font-size:12px;font-weight:600}[data-theme=light]{--bg:#f8fafc;--surface:#ffffffeb;--surface-hover:#fffffffc;--surface-solid:#fff;--border:#0f172a0f;--border-strong:#0f172a1c;--text:#0f172a;--text-muted:#475569;--text-dark:#1e293b;--shadow:0 8px 24px -12px #0f172a29;--shadow-lg:0 18px 44px -16px #0f172a33}[data-theme=light] body:before{background:radial-gradient(circle,#6366f114 0%,#0000 72%)}[data-theme=light] body:after{background:radial-gradient(circle,#38bdf80f 0%,#0000 72%)}[data-theme=light] .content-header{background:#ffffffb8}[data-theme=light] thead th{background:#f8fafceb}[data-theme=light] .th-tech,[data-theme=light] .tech-name{color:#0f172a}[data-theme=light] .td-material{color:#0f172a;background:#fff}[data-theme=light] tbody tr:hover .td-material{background:#f8fafc}[data-theme=light] tbody tr:hover{background:#0f172a05}[data-theme=light] tbody tr.extra-row{background:#f59e0b14}[data-theme=light] tbody tr.extra-row:hover{background:#f59e0b1f}[data-theme=light] tbody tr.extra-row .td-material{color:#b45309;background:#fffcf0;border-left-color:#f59e0b}[data-theme=light] tbody tr.extra-row:hover .td-material{background:#fef3c7}[data-theme=light] td{border-bottom-color:#0f172a0f}[data-theme=light] .separator-row td{color:#4338ca;background:#6366f114!important}[data-theme=light] .login-box{background:#fffffff0}[data-theme=light] .login-field input{color:var(--text);background:#fffffff0}[data-theme=light] .select-fancy{color:var(--text);background-color:#fffffff2}[data-theme=light] .select-fancy option{color:#0f172a;background:#fff}[data-theme=light] .snapshot-trigger{background:#fffffff2}[data-theme=light] .snapshot-menu{background:#fffffffa}[data-theme=light] .snapshot-option:hover{background:#6366f124;border-color:#6366f140}[data-theme=light] .snapshot-option.active{background:#6366f133}[data-theme=light] .search-input{color:#0f172a;background:#fffffffa;border-color:#0f172a24}[data-theme=light] .search-input:focus{background:#fff;border-color:#4f46e5;box-shadow:0 0 0 4px #6366f124}[data-theme=light] .td-value.has-value{color:#1e293b;text-shadow:none;background:#4f46e524;border:1px solid #4f46e53d}[data-theme=light] .td-value.empty{color:#64748b}[data-theme=light] ::-webkit-scrollbar-thumb{background:#00000057}[data-theme=light] ::-webkit-scrollbar-thumb:hover{background:#00000080}.btn-theme{border:1px solid var(--border);color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast);background:0 0;border-radius:99px;justify-content:center;align-items:center;padding:8px 12px;font-size:16px;line-height:1;display:flex}.btn-theme:hover{color:var(--text);border-color:var(--border-strong);background:#ffffff14}[data-theme=light] .btn-theme:hover{background:#0000000f}[data-theme=light] .rename-field{color:#0f172a;background:#f8fafc;border-color:#e2e8f0}[data-theme=light] .rename-field:focus{background:#fff;border-color:#4f46e5;box-shadow:0 0 0 4px #6366f11a}[data-theme=light] .kpi-card{background:#ffffffe6}@media print{#app{background:#fff;height:auto;padding:0;display:block}body{color:#000;background:#fff}body:before,body:after,.topbar,.sidebar,.content-header,.status-circle{display:none!important}.content,.table-scroll{box-shadow:none!important;background:#fff!important;border:none!important;margin:0!important;padding:0!important;overflow:visible!important}table{border-collapse:collapse;width:100%;font-size:11px}th,td{padding:4px;color:#000!important;text-shadow:none!important;border:1px solid #ccc!important}.td-material,.th-inner{white-space:normal;position:static;color:#000!important;background:#f8fafc!important;border-right:none!important}.td-value{color:#000!important;background:0 0!important;border-radius:0!important}}@media (width<=900px){#app{flex-direction:column;height:100vh;padding:0;display:flex;overflow:hidden}.main-layout{flex-direction:column;flex:1;gap:0;margin:0;padding:16px;overflow:hidden}.topbar{border-radius:var(--radius-lg);gap:12px;height:64px;margin:16px 16px 0;padding:0 16px}.topbar-brand{font-size:13px}.topbar{gap:10px}.topbar-appalto,.topbar-sep,.topbar-brand-sub{display:none}.topbar-user{white-space:nowrap;padding:8px 12px;font-size:13px}.menu-toggle,.menu-close{display:flex}.sidebar{z-index:100;width:280px;height:100%;transition:transform var(--transition);border-right:1px solid var(--border);background:#0f172afa;border-top:none;border-bottom:none;border-left:none;border-radius:0;padding:24px;position:fixed;top:0;bottom:0;left:0;transform:translate(-100%)}.sidebar.open{transform:translate(0);box-shadow:20px 0 40px #00000080}.content{border-radius:var(--radius-lg)}.content-header{flex-direction:column;align-items:flex-start;gap:16px;padding:24px 20px}.content-actions{flex-wrap:wrap;width:100%;margin-left:0}.table-scroll{-webkit-overflow-scrolling:touch;flex:none;height:auto;padding:0 20px 24px;overflow-x:auto}.td-material,.th-material{z-index:10;position:sticky;left:0}.th-material{z-index:11;border-right:1px solid var(--border-strong);background:#0f172afa}.td-material{border-right:1px solid var(--border)}.login-box{width:calc(100% - 32px);padding:48px 24px}.search-wrap{padding:0 20px}.search-input{max-width:100%}#toast-container{bottom:16px;left:16px;right:16px}.toast{min-width:unset}.kpi-grid{padding:0 20px}.tech-name{justify-content:flex-start}.tech-nav-left{align-items:center;margin-right:8px;display:inline-flex}[data-theme=light] .th-material{-webkit-backdrop-filter:none!important;background:#f8fafcfa!important;border-right:1px solid #0f172a1f!important}[data-theme=light] .td-material{background:#fff!important;border-right:1px solid #0f172a14!important}}
