:root{--primary: #00417A;--navy: #1B3A6B;--accent: #1E8BC3;--mid: #1C6BB0;--text: #262626;--text-secondary: #6B7A93;--grey-light: #D0D8E4;--grey-dark: #8096B0;--bg: #F4F7FA;--bg-alt: #EBF4FD;--white: #FFFFFF;--green: #1A9E5C;--orange: #E8820C;--cyan: #2AC0CE;--red: #C0392B;--purple: #7B1FA2;--font: "DM Sans", -apple-system, sans-serif;--mono: "JetBrains Mono", monospace;--radius: 8px;--shadow: 0 1px 3px rgba(0,65,122,.08), 0 4px 12px rgba(0,65,122,.04);--shadow-lg: 0 4px 24px rgba(0,65,122,.12)}*{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100%}body{font-family:var(--font);color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased}.app{display:flex;flex-direction:column;min-height:100vh}.header{background:var(--primary);color:var(--white);padding:0 24px;height:56px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100}.header-left{display:flex;align-items:center;gap:16px}.header-logo{font-size:18px;font-weight:700;letter-spacing:-.3px}.header-logo span{color:var(--accent)}.header-nav{display:flex;gap:4px}.header-nav button{background:transparent;border:none;color:#ffffffb3;padding:8px 14px;border-radius:6px;cursor:pointer;font:500 13px var(--font);transition:all .15s}.header-nav button:hover,.header-nav button.active{background:#ffffff1f;color:var(--white)}.header-right{display:flex;align-items:center;gap:12px}.header-user{font-size:13px;opacity:.8}.btn{padding:7px 16px;border-radius:6px;border:none;cursor:pointer;font:500 13px var(--font);transition:all .15s;display:inline-flex;align-items:center;gap:6px}.btn-primary{background:var(--accent);color:var(--white)}.btn-primary:hover{background:var(--mid)}.btn-ghost{background:#ffffff1a;color:var(--white)}.btn-ghost:hover{background:#fff3}.btn-outline{background:transparent;border:1px solid var(--grey-light);color:var(--text)}.btn-outline:hover{border-color:var(--accent);color:var(--accent)}.btn-danger{background:var(--red);color:var(--white)}.btn-sm{padding:4px 10px;font-size:12px}.btn-sync{background:var(--green);color:var(--white)}.btn-sync:hover{background:#158f50}.btn-sync:disabled{opacity:.5;cursor:not-allowed}.main{flex:1;padding:20px 24px 40px;max-width:100%;overflow-x:auto}.kpi-bar{display:flex;gap:12px;margin-bottom:20px;flex-wrap:wrap}.kpi{background:var(--white);border-radius:var(--radius);padding:14px 20px;box-shadow:var(--shadow);min-width:130px}.kpi-label{font-size:11px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}.kpi-value{font-size:24px;font-weight:700;color:var(--primary);font-family:var(--mono)}.filters{display:flex;gap:10px;margin-bottom:16px;flex-wrap:wrap;align-items:center}.filters select,.filters input{padding:7px 12px;border:1px solid var(--grey-light);border-radius:6px;font:400 13px var(--font);background:var(--white);color:var(--text)}.filters select:focus,.filters input:focus{outline:none;border-color:var(--accent)}.table-wrap{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:13px}thead th{background:var(--primary);color:var(--white);padding:10px 12px;text-align:left;font-weight:600;white-space:nowrap;position:sticky;top:0}tbody td{padding:8px 12px;border-bottom:1px solid var(--bg);vertical-align:middle}tbody tr:nth-child(2n){background:var(--bg-alt)}tbody tr:hover{background:#dce8f5;cursor:pointer}tbody tr.archived{opacity:.5}tbody tr.hidden-row{opacity:.4;background:repeating-linear-gradient(45deg,transparent,transparent 10px,rgba(0,0,0,.02) 10px,rgba(0,0,0,.02) 20px)}thead th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .15s}thead th.sortable:hover{background:var(--navy)}td.date{font-family:var(--mono);font-size:12px;white-space:nowrap}td.num{text-align:center;font-family:var(--mono);font-size:12px}.status{display:inline-block;padding:3px 10px;border-radius:12px;font-size:11px;font-weight:600;white-space:nowrap}.status-assignment{background:#e8eef7;color:#1b3a6b}.status-pianificazione{background:#fff3e0;color:#e8820c}.status-esecuzione{background:#e0f2fe;color:#1e8bc3}.status-uat{background:#e0f7fa;color:#00838f}.status-golive{background:#e8f5e9;color:#1a9e5c}.status-rework{background:#fbe9e7;color:#bf360c}.status-standby{background:#f3e5f5;color:#7b1fa2}.status-hs-won{background:#e8f5e9;color:#1a9e5c}.status-hs-lost{background:#fbe9e7;color:#c0392b}.status-hs-contract{background:#fff3e0;color:#e8820c}.status-hs-open{background:#e0f2fe;color:#1e8bc3}.flag{display:inline-block;padding:2px 6px;border-radius:4px;font-size:10px;font-weight:700;margin-right:3px;letter-spacing:.3px}.flag-sap{background:#fff3e0;color:#e8820c;border:1px solid #E8820C}.flag-ddm{background:#e0f2fe;color:#1e8bc3;border:1px solid #1E8BC3}.panel-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000004d;z-index:200;animation:fadeIn .15s}.panel{position:fixed;top:0;right:0;bottom:0;width:480px;max-width:90vw;background:var(--white);z-index:201;box-shadow:var(--shadow-lg);display:flex;flex-direction:column;animation:slideIn .2s}.panel-header{padding:20px 24px;border-bottom:1px solid var(--bg);display:flex;justify-content:space-between;align-items:center}.panel-header h2{font-size:16px;color:var(--primary)}.panel-close{background:none;border:none;font-size:20px;cursor:pointer;color:var(--text-secondary)}.panel-body{flex:1;overflow-y:auto;padding:24px}.field-group{margin-bottom:20px}.field-group label{display:block;font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.3px;margin-bottom:6px}.field-group input,.field-group select,.field-group textarea{width:100%;padding:8px 12px;border:1px solid var(--grey-light);border-radius:6px;font:400 14px var(--font)}.field-group input:focus,.field-group select:focus{outline:none;border-color:var(--accent)}.field-group .readonly{background:var(--bg);color:var(--text-secondary);border-color:transparent}.field-section{font-size:13px;font-weight:700;color:var(--primary);margin:24px 0 12px;padding-bottom:6px;border-bottom:2px solid var(--accent)}.panel-footer{padding:16px 24px;border-top:1px solid var(--bg);display:flex;gap:8px;justify-content:flex-end}.gantt-container{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);overflow-x:auto;padding:16px}.gantt-row{display:flex;align-items:center;height:32px;border-bottom:1px solid var(--bg)}.gantt-row:nth-child(2n){background:var(--bg-alt)}.gantt-label{width:280px;min-width:280px;padding:0 12px;font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.gantt-bars{flex:1;position:relative;height:100%}.gantt-bar{position:absolute;height:18px;top:7px;border-radius:3px;min-width:4px;opacity:.85}.gantt-bar-exec{background:var(--accent)}.gantt-bar-uat{background:var(--orange)}.gantt-bar-rework{background:var(--red)}.gantt-bar-plan{background:var(--green)}.gantt-header{display:flex;height:28px;border-bottom:2px solid var(--grey-light);margin-bottom:4px}.gantt-header-label{width:280px;min-width:280px;font-size:11px;font-weight:600;color:var(--text-secondary);padding:0 12px}.gantt-header-months{flex:1;display:flex;position:relative}.gantt-month{font-size:10px;color:var(--text-secondary);text-align:center;border-left:1px solid var(--bg);padding:4px 0}.gantt-today{position:absolute;top:0;bottom:0;width:2px;background:var(--red);z-index:5;opacity:.6}.gantt-legend{display:flex;gap:16px;margin-bottom:12px;font-size:12px}.gantt-legend-item{display:flex;align-items:center;gap:5px}.gantt-legend-color{width:14px;height:10px;border-radius:2px}.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#00417a,#1b3a6b,#1e8bc3)}.login-box{background:var(--white);border-radius:12px;padding:40px;width:380px;box-shadow:var(--shadow-lg)}.login-box h1{font-size:22px;color:var(--primary);margin-bottom:6px}.login-box p{font-size:13px;color:var(--text-secondary);margin-bottom:28px}.login-box .field-group{margin-bottom:16px}.login-box .btn{width:100%;justify-content:center;padding:10px;font-size:14px}.login-error{color:var(--red);font-size:13px;margin-bottom:12px}.admin-card{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px;margin-bottom:20px}.admin-card h3{font-size:15px;color:var(--primary);margin-bottom:16px}.user-row{display:flex;align-items:center;justify-content:space-between;padding:10px 0;border-bottom:1px solid var(--bg)}.user-row:last-child{border:none}.user-info{display:flex;flex-direction:column}.user-name{font-weight:600;font-size:14px}.user-meta{font-size:12px;color:var(--text-secondary)}.user-actions{display:flex;gap:6px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideIn{0%{transform:translate(100%)}to{transform:translate(0)}}@media (max-width:768px){.main{padding:12px}.kpi-bar{gap:8px}.kpi{min-width:100px;padding:10px 14px}.panel{width:100vw}.gantt-label{width:180px;min-width:180px}}
