*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;font-size:14px;color:#1f2933;background:#f4f6f8}:root{--primary: #2563eb;--primary-dark: #1d4ed8;--border: #e2e8f0;--muted: #64748b;--bg-card: #ffffff;--danger: #dc2626;--success: #16a34a}a{color:var(--primary);text-decoration:none}a:hover{text-decoration:underline}.app-shell{display:flex;min-height:100vh}.sidebar{width:220px;background:#0f172a;color:#e2e8f0;display:flex;flex-direction:column;flex-shrink:0;transition:width .18s ease;overflow-x:hidden}.sidebar.collapsed{width:62px}.sidebar-top{display:flex;align-items:center;justify-content:space-between;padding:14px 12px;border-bottom:1px solid #1e293b}.sidebar-brand{display:flex;align-items:center;gap:10px;font-size:18px;font-weight:800;letter-spacing:.02em;color:#fff;min-width:0;background:none;border:none;padding:2px;cursor:pointer}.brand-flame{color:#ef4444;display:flex;flex-shrink:0}.sidebar-toggle{background:none;border:none;color:#94a3b8;cursor:pointer;padding:5px;border-radius:6px;display:flex;flex-shrink:0}.sidebar-toggle:hover{background:#1e293b;color:#e2e8f0}.sidebar.collapsed .sidebar-top{justify-content:center}.sidebar.collapsed .sidebar-brand{gap:0}.sidebar-nav{display:flex;flex-direction:column;padding:8px 0}.sidebar-group+.sidebar-group{margin-top:2px;border-top:1px solid #15203a;padding-top:2px}.sidebar-group-title{font-size:11px;text-transform:uppercase;letter-spacing:.07em;color:#64748b;padding:10px 16px 4px;display:flex;align-items:center;gap:6px}.nav-badge{font-size:9px;font-weight:700;text-transform:uppercase;background:#7c3aed;color:#fff;padding:1px 5px;border-radius:8px;letter-spacing:.04em}.nav-link{color:#cbd5e1;padding:9px 16px;font-weight:500;display:flex;align-items:center;gap:11px}.nav-link svg{flex-shrink:0;color:#94a3b8}.nav-link:hover{background:#1e293b;text-decoration:none}.nav-link.active{background:var(--primary);color:#fff}.nav-link.active svg{color:#fff}.nav-link .nav-badge{margin-left:auto}.nav-link.disabled{opacity:.55;cursor:default}.nav-link.disabled:hover{background:none}.sidebar.collapsed .nav-label,.sidebar.collapsed .sidebar-group-title,.sidebar.collapsed .nav-badge{display:none}.sidebar.collapsed .nav-link,.sidebar.collapsed .board-link{justify-content:center;padding:10px 0}.sidebar.collapsed .sidebar-boards{padding:10px 0}.sidebar.collapsed .sidebar-group+.sidebar-group{padding-top:4px}.main{flex:1;display:flex;flex-direction:column;min-width:0}.topbar{height:56px;background:#fff;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 20px}.topbar-user{display:flex;align-items:center;gap:10px}.user-name{font-weight:600}.user-role{font-size:12px;color:var(--muted);background:#f1f5f9;padding:2px 8px;border-radius:12px}.content{padding:24px;flex:1}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:16px 20px;margin-bottom:16px}.card-title{font-size:15px;font-weight:700;margin:0 0 12px}.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.page-title{font-size:20px;font-weight:700;margin:0}table{width:100%;border-collapse:collapse;background:#fff}th,td{text-align:left;padding:10px 12px;border-bottom:1px solid var(--border);vertical-align:middle}th{font-size:12px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);background:#f8fafc}tr:hover td{background:#f8fafc}.badge{display:inline-block;padding:2px 10px;border-radius:12px;font-size:12px;font-weight:600;background:#e2e8f0;color:#334155;white-space:nowrap}.badge-bozza{background:#e2e8f0;color:#475569}.badge-in_produzione{background:#dbeafe;color:#1d4ed8}.badge-completato{background:#dcfce7;color:#15803d}.badge-spedito{background:#ede9fe;color:#6d28d9}.badge-da_fare{background:#f1f5f9;color:#475569}.badge-in_corso{background:#fef9c3;color:#a16207}.badge-eseguito,.badge-ricevuto,.badge-picking_fatto,.badge-anteprima_approvata{background:#dcfce7;color:#15803d}.badge-parziale{background:#fed7aa;color:#c2410c}.badge-da_verificare{background:#fee2e2;color:#b91c1c}.badge-inviare_anteprima{background:#fef9c3;color:#a16207}.badge-attesa_approvazione{background:#dbeafe;color:#1d4ed8}.badge-incisione_telaio{background:#ede9fe;color:#6d28d9}.progress{position:relative;width:100%;min-width:80px;height:16px;background:#e2e8f0;border-radius:8px;overflow:hidden}.progress-fill{height:100%;background:var(--primary);transition:width .2s ease}.progress-label{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;color:#1f2933}.kanban{display:flex;gap:12px;overflow-x:auto;padding-bottom:8px}.kanban-col{background:#f1f5f9;border:1px solid var(--border);border-radius:10px;min-width:240px;width:240px;flex-shrink:0;padding:10px}.kanban-col-title{font-size:13px;font-weight:700;margin-bottom:8px;display:flex;justify-content:space-between;align-items:center}.kanban-col-count{background:#fff;border-radius:10px;padding:0 8px;font-size:12px;color:var(--muted)}.kanban-card{background:#fff;border:1px solid var(--border);border-radius:8px;padding:10px;margin-bottom:8px;font-size:13px}.kanban-card-title{font-weight:600;margin-bottom:4px}.kanban-card-meta{color:var(--muted);font-size:12px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 14px;border-radius:8px;border:1px solid transparent;background:var(--primary);color:#fff;font-size:14px;font-weight:600;cursor:pointer;text-decoration:none}.btn:hover{background:var(--primary-dark);text-decoration:none}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{background:#fff;color:#334155;border-color:var(--border)}.btn-secondary:hover{background:#f1f5f9}.btn-danger{background:var(--danger)}.btn-danger:hover{background:#b91c1c}.btn-sm{padding:4px 10px;font-size:12px}.icon-btn{padding:4px 7px;font-size:15px;line-height:1}.form{display:flex;flex-direction:column;gap:12px}.form-row{display:flex;gap:12px;flex-wrap:wrap}.form-group{display:flex;flex-direction:column;gap:4px;flex:1;min-width:160px}.form-group label{font-size:12px;font-weight:600;color:var(--muted)}input,select,textarea{padding:8px 10px;border:1px solid var(--border);border-radius:8px;font-size:14px;font-family:inherit;background:#fff}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--primary)}textarea{resize:vertical;min-height:60px}select[multiple]{min-height:90px}.form-actions{display:flex;gap:8px;justify-content:flex-end}.toolbar{display:flex;gap:10px;align-items:center;margin-bottom:16px;flex-wrap:wrap}.muted{color:var(--muted)}.error{background:#fee2e2;color:#b91c1c;padding:10px 12px;border-radius:8px;margin-bottom:12px}.loading{color:var(--muted);padding:20px}.stat-number{font-size:28px;font-weight:700}.list-clean{list-style:none;padding:0;margin:0}.list-clean li{padding:8px 0;border-bottom:1px solid var(--border)}.tabs{display:flex;gap:8px;margin-bottom:16px}.tab{padding:8px 14px;border:1px solid var(--border);border-radius:8px;background:#fff;cursor:pointer;font-weight:600}.tab.active{background:var(--primary);color:#fff;border-color:var(--primary)}.login-wrap{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:20px}.login-card{background:#fff;border:1px solid var(--border);border-radius:12px;padding:28px;width:100%;max-width:360px}.login-card h1{font-size:20px;margin:0 0 20px}.demo-creds{margin-top:18px;font-size:12px;color:var(--muted);background:#f8fafc;border-radius:8px;padding:10px 12px}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.calendar-cell{background:#fff;border:1px solid var(--border);border-radius:6px;min-height:90px;padding:4px 6px;font-size:12px}.calendar-cell.outside{background:#f8fafc;color:#cbd5e1}.calendar-daynum{font-weight:700;margin-bottom:4px}.calendar-weekday{text-align:center;font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;padding:4px 0}.cal-task{display:flex;align-items:center;gap:4px;margin-bottom:2px}.cal-tag{font-size:10px;font-weight:700;border-radius:4px;padding:0 4px;color:#fff}.cal-tag.p{background:var(--primary)}.cal-tag.s{background:var(--danger)}.cal-tag.i{background:#00897b}.cal-tag.r{background:#7b3ff2}.cfg-pill{display:inline-block;padding:3px 10px;border-radius:6px;font-size:12px;font-weight:600;white-space:nowrap;line-height:1.4}.cfg-cell{position:relative;display:inline-block}.cfg-cell-btn{background:none;border:none;padding:0;cursor:pointer}.cfg-menu{position:absolute;z-index:30;top:100%;left:0;margin-top:4px;background:#fff;border:1px solid var(--border);border-radius:8px;box-shadow:0 8px 24px #0f172a26;padding:6px;min-width:160px;max-height:280px;overflow:auto}.cfg-menu-item{display:block;width:100%;text-align:left;background:none;border:none;padding:4px;cursor:pointer;border-radius:6px}.cfg-menu-item:hover{background:#f1f5f9}.grid-wrap{background:#fff;border:1px solid var(--border);border-radius:10px;overflow:hidden}.grid-toolbar{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;border-bottom:1px solid var(--border);background:#f8fafc}.grid-scroll{overflow:auto;max-height:calc(100vh - 220px)}.grid-table{border-collapse:separate;border-spacing:0;width:100%;font-size:13px}.grid-table thead th{position:sticky;top:0;background:#f8fafc;z-index:5}.grid-table th,.grid-table td{padding:6px 10px;border-bottom:1px solid var(--border);white-space:nowrap}.grid-filter-row th{top:33px;padding:4px 8px;background:#fff}.grid-filter-input{width:100%;min-width:80px;padding:4px 6px;font-size:12px}.grid-filter-date{display:flex;gap:2px}.grid-filter-date input{padding:2px 4px;font-size:11px;width:110px}.grid-filter-select{position:relative}.grid-filter-btn{width:100%;padding:4px 6px;font-size:12px;background:#fff;border:1px solid var(--border);border-radius:6px;cursor:pointer;text-align:left}.grid-filter-menu{position:absolute;z-index:40;top:100%;left:0;margin-top:2px;background:#fff;border:1px solid var(--border);border-radius:8px;box-shadow:0 8px 24px #0f172a26;padding:6px;min-width:160px;max-height:240px;overflow:auto}.grid-filter-opt{display:flex;align-items:center;gap:6px;padding:3px 4px;font-size:13px;font-weight:400;text-transform:none;letter-spacing:0;color:#1f2933;cursor:pointer}.grid-filter-clear{display:block;width:100%;margin-top:4px;padding:4px;font-size:12px;background:#f1f5f9;border:none;border-radius:6px;cursor:pointer}.grid-row.clickable{cursor:pointer}.grid-row:hover td{background:#f8fafc}.grid-group-header{cursor:pointer;background:#f1f5f9}.grid-group-header td{font-weight:700;position:relative;padding-left:16px}.grid-group-bar{position:absolute;left:0;top:0;bottom:0;width:5px}.grid-group-caret{margin-right:6px}.grid-group-count{margin-left:8px;background:#fff;border-radius:10px;padding:0 8px;font-size:12px;color:var(--muted)}.timer-cell{display:flex;align-items:center;gap:6px;white-space:nowrap}.timer-btn{border:1px solid var(--border);background:#fff;border-radius:6px;width:24px;height:24px;cursor:pointer;font-size:11px;line-height:1}.timer-btn.running{background:var(--danger);color:#fff;border-color:var(--danger)}.timer-val{font-variant-numeric:tabular-nums}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a80;display:flex;align-items:center;justify-content:center;z-index:100;padding:20px}.modal-panel{background:#fff;border-radius:12px;width:100%;max-width:520px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden}.modal-panel.wide{max-width:900px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--border)}.modal-title{margin:0;font-size:16px}.modal-close{background:none;border:none;font-size:24px;line-height:1;cursor:pointer;color:var(--muted)}.modal-body{padding:18px;overflow:auto}.attach-thumb{border:1px solid var(--border);border-radius:6px;overflow:hidden;cursor:pointer;padding:0;background:#f8fafc;display:inline-flex;align-items:center;justify-content:center}.attach-thumb img{width:100%;height:100%;object-fit:cover}.attach-pdf-badge{font-size:10px;font-weight:700;color:var(--danger)}.attach-viewer{width:100%;height:70vh;border:none}.attach-full{max-width:100%;max-height:70vh;display:block;margin:0 auto}.attach-input{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.user-avatar{width:28px;height:28px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:13px;font-weight:700}.person-chip{display:inline-flex;align-items:center;gap:5px}.person-dot{width:18px;height:18px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:#fff}.sidebar-boards{padding:10px 8px;border-top:1px solid #1e293b;margin-top:6px}.sidebar-section-title{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:#64748b;padding:4px 8px}.board-link{display:flex;align-items:center;gap:8px;padding:6px 8px;color:#cbd5e1;border-radius:6px;font-size:13px}.board-link:hover{background:#1e293b;text-decoration:none}.board-dot{width:8px;height:8px;border-radius:50%;background:#43a047}.board-dot.ext{background:#fb8c00}.side-panel-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:89;background:#0f172a1f;cursor:pointer}.side-panel{position:fixed;top:0;right:0;bottom:0;width:420px;max-width:92vw;background:#fff;border-left:1px solid var(--border);box-shadow:-8px 0 24px #0f172a1f;z-index:90;display:flex;flex-direction:column}.side-panel-header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--border)}.side-panel-body{padding:18px;overflow:auto}.field-row{display:flex;justify-content:space-between;gap:12px;padding:8px 0;border-bottom:1px solid var(--border);align-items:center}.field-label{font-size:12px;color:var(--muted);font-weight:600}.stat-card{background:#fff;border:1px solid var(--border);border-radius:10px;padding:14px 16px}.stat-card .stat-label{font-size:12px;color:var(--muted);font-weight:600}.bar-row{display:flex;align-items:center;gap:8px;margin:6px 0}.bar-track{flex:1;height:10px;background:#eef1f5;border-radius:5px;overflow:hidden}.bar-fill{height:100%;background:var(--primary)}.urgent-flag{color:var(--danger);font-weight:700}.product-subrow>td,.grid-subrow>td{background:#f7f9fc;border-top:none;padding:4px 10px 6px}.task-products{display:flex;flex-direction:column;gap:2px}.task-product-line{display:flex;align-items:center;flex-wrap:wrap;gap:8px;font-size:12px;color:var(--muted);border-left:3px solid #c7d7ea;padding-left:8px}.prod-swatch{display:inline-block;width:10px;height:10px;border-radius:2px;flex:0 0 auto;box-shadow:0 0 0 1px #0000001f inset}.prod-toggle{display:inline-flex;align-items:center;gap:3px;border:none;background:transparent;padding:2px 3px;cursor:pointer;border-radius:4px;line-height:1}.prod-toggle:hover{background:#eef2f7}.prod-caret{color:#94a3b8;font-size:10px}.tp-prod{font-weight:600;color:#334155}.tp-color{color:#475569}.tp-color:before{content:"·";margin-right:8px;color:#94a3b8}.tp-qty{color:#1f76c2;font-weight:600}.tp-sizes{display:inline-flex;flex-wrap:wrap;gap:4px}.tp-size{display:inline-flex;align-items:baseline;gap:2px;background:#eef2f7;border:1px solid #e2e8f0;border-radius:4px;padding:0 5px;font-size:11px}.tp-size-code{font-weight:700;color:#334155}.tp-size-qty{color:#64748b}.tp-size-qty:before{content:":";margin-right:1px;color:#94a3b8}.subrow-toggle-cell{width:34px;text-align:center;padding-left:6px;padding-right:0}.prod-tasks{display:flex;flex-direction:column;gap:4px}.prod-task-line{display:flex;align-items:center;flex-wrap:wrap;gap:8px;font-size:12px;border-left:3px solid #c7d7ea;padding-left:8px}.prodotti-table{table-layout:fixed;width:100%}.prodotti-table td{overflow:hidden;text-overflow:ellipsis}.prod-tasks-wrap{overflow-x:auto;max-width:100%}.prod-tasks-wrap table{table-layout:auto}.group-badge{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:4px;border:none;background:#1f76c2;color:#fff;font-size:11px;font-weight:800;cursor:pointer;flex:0 0 auto;line-height:1}.group-badge:hover{background:#155a96}.group-flash>td{animation:groupFlash 1.2s ease}@keyframes groupFlash{0%,to{background:#eef4fb}30%{background:#ffe9a8}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.brand-text{display:flex;flex-direction:column;align-items:flex-start;line-height:1.1}.brand-name{font-size:18px;font-weight:800}.brand-sub{display:flex;align-items:center;gap:6px;margin-top:1px}.env-tag{font-size:9px;font-weight:800;text-transform:uppercase;letter-spacing:.08em;padding:0 4px;border-radius:4px}.env-dev{color:#0c4a6e;background:#38bdf8}.env-prod{color:#fff;background:#dc2626}.ver-tag{font-size:9px;font-weight:600;color:#94a3b8;letter-spacing:.04em}.nav-link.locked{opacity:.45;cursor:not-allowed}.nav-link.locked:hover{background:none}.nav-link.locked .nav-label{font-weight:500}.nav-link.locked svg:last-child{margin-left:auto;opacity:.8}.tab.locked{opacity:.45;cursor:not-allowed}.login-brand{display:flex;align-items:center;gap:10px;justify-content:center;margin-bottom:18px}.login-brand .brand-flame{color:#ef4444;display:flex}.login-brand-name{font-size:30px;font-weight:800;letter-spacing:.02em;color:#1f2933}.login-dark{background:#000!important}.login-dark .login-card{background:#fff;box-shadow:0 10px 40px #00000080}
