
:root{--bg:#06111c;--panel:#0b1826;--panel2:#0f2133;--line:rgba(0,174,239,.22);--line2:rgba(255,255,255,.08);--text:#eef9ff;--muted:#9db4c8;--cyan:#00aeef;--cyan2:#38d8ff;--blue:#0b6dd9;--green:#22c55e;--amber:#f59e0b;--red:#ef4444;--violet:#a855f7;--shadow:0 24px 70px rgba(0,0,0,.38);--radius:24px}
*{box-sizing:border-box}html,body{margin:0;height:100%;font-family:Inter,Segoe UI,Arial,sans-serif;background:radial-gradient(circle at 15% 10%,rgba(0,174,239,.20),transparent 28%),linear-gradient(135deg,#02080e,#071827 55%,#03070d);color:var(--text);font-size:16.5px}button,input,select,textarea{font:inherit}button{cursor:pointer}.hidden{display:none!important}.muted{color:var(--muted)}.small{font-size:13px}.mono{font-family:Consolas,monospace}.login-screen{min-height:100vh;display:grid;place-items:center;position:relative;overflow:hidden;padding:24px}.login-screen:before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(0,174,239,.08) 1px,transparent 1px),linear-gradient(90deg,rgba(0,174,239,.06) 1px,transparent 1px);background-size:60px 60px;mask-image:radial-gradient(circle at center,#000,transparent 80%)}.login-bg-line{position:absolute;height:1px;width:140%;left:-20%;background:linear-gradient(90deg,transparent,var(--cyan),transparent);opacity:.32;animation:slideLine 7s linear infinite}.l1{top:28%;animation-delay:-1s}.l2{top:51%;animation-delay:-3s}.l3{top:75%;animation-delay:-5s}@keyframes slideLine{from{transform:translateX(-12%)}to{transform:translateX(12%)}}.login-card{position:relative;z-index:2;width:min(440px,100%);background:rgba(6,18,30,.82);border:1px solid var(--line);box-shadow:var(--shadow),0 0 90px rgba(0,174,239,.18);border-radius:34px;padding:42px 36px;text-align:center;backdrop-filter:blur(22px);animation:loginEnter .7s ease both}.login-logo-frame{width:132px;height:132px;margin:0 auto 18px;border-radius:32px;display:grid;place-items:center;border:1px solid var(--line);background:#02080e;box-shadow:0 0 0 10px rgba(0,174,239,.04),0 0 48px rgba(0,174,239,.32);animation:logoFloat 3.8s ease-in-out infinite}.login-logo{width:108px;height:108px;image-rendering:crisp-edges;filter:drop-shadow(0 0 18px rgba(0,174,239,.75));animation:logoPulse 2.6s ease-in-out infinite}.login-card h1{font-size:44px;line-height:1;margin:0 0 6px;letter-spacing:-1.8px}.login-card p{margin:0 0 26px;color:var(--muted);font-size:17px}.login-card label{display:block;text-align:left;margin:16px 0 7px;color:#bfd6e8;font-weight:800;text-transform:uppercase;letter-spacing:1.6px;font-size:12px}.login-card input{width:100%;padding:16px 17px;background:rgba(255,255,255,.06);border:1px solid var(--line2);border-radius:17px;color:#fff;outline:none;font-size:18px}.login-card input:focus{border-color:var(--cyan);box-shadow:0 0 0 4px rgba(0,174,239,.13)}.login-error{display:none;margin-top:14px;color:#ffcaca;background:rgba(239,68,68,.12);border:1px solid rgba(239,68,68,.28);border-radius:14px;padding:10px;text-align:left}.demo-hint{margin-top:16px;border:0;background:transparent;color:#7fa8bd;font-size:12px}.demo-hint:hover{color:var(--cyan)}@keyframes loginEnter{from{opacity:0;transform:translateY(20px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes logoFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-9px)}}@keyframes logoPulse{0%,100%{filter:drop-shadow(0 0 14px rgba(0,174,239,.65))}50%{filter:drop-shadow(0 0 30px rgba(0,174,239,1))}}
.app{height:100vh;display:grid;grid-template-columns:304px 1fr}.sidebar{background:rgba(4,14,24,.92);border-right:1px solid var(--line);backdrop-filter:blur(20px);display:flex;flex-direction:column;min-width:0}.brand-block{display:flex;gap:14px;align-items:center;padding:22px;border-bottom:1px solid var(--line2)}.side-logo{width:64px;height:64px;border-radius:18px;box-shadow:0 0 28px rgba(0,174,239,.38);image-rendering:crisp-edges}.brand-block strong{font-size:24px;letter-spacing:-.8px}.brand-block span{display:block;color:var(--muted);font-size:13px;margin-top:3px}#nav{padding:14px;overflow:auto}.nav-item{display:flex;align-items:center;gap:12px;padding:13px 14px;border-radius:16px;color:#c6d7e5;margin-bottom:7px;border:1px solid transparent;font-weight:800}.nav-item:hover,.nav-item.active{background:rgba(0,174,239,.12);border-color:var(--line);color:#fff}.nav-item .ico{font-size:20px;width:26px;text-align:center}.side-footer{margin-top:auto;padding:16px;border-top:1px solid var(--line2);display:flex;align-items:center;justify-content:space-between;gap:10px}.side-footer button,.icon-btn{background:rgba(255,255,255,.06);border:1px solid var(--line2);border-radius:13px;color:#fff;padding:10px 12px}.main{min-width:0;overflow:auto}.topbar{position:sticky;top:0;z-index:8;height:78px;display:flex;align-items:center;gap:16px;padding:0 24px;border-bottom:1px solid var(--line2);background:rgba(3,10,18,.82);backdrop-filter:blur(18px)}.topbar h2{margin:0;font-size:28px;letter-spacing:-.9px}.topbar span{color:var(--muted);font-size:14px}.top-actions{margin-left:auto;display:flex;gap:10px}.content{padding:24px}.btn{border:1px solid var(--line2);border-radius:15px;background:rgba(255,255,255,.07);color:#fff;padding:11px 14px;font-weight:850;display:inline-flex;gap:8px;align-items:center;justify-content:center}.btn:hover{transform:translateY(-1px);background:rgba(255,255,255,.10)}.btn.primary{background:linear-gradient(135deg,var(--cyan),var(--blue));border-color:rgba(0,174,239,.55);box-shadow:0 16px 38px rgba(0,174,239,.18)}.btn.big{width:100%;padding:17px;margin-top:22px;font-size:19px}.btn.success{background:linear-gradient(135deg,#22c55e,#15803d)}.btn.danger{background:linear-gradient(135deg,#ef4444,#991b1b)}.btn.install{border-color:rgba(0,174,239,.28)}.hero{position:relative;overflow:hidden;background:linear-gradient(135deg,rgba(15,33,51,.95),rgba(4,15,27,.92));border:1px solid var(--line);border-radius:var(--radius);padding:28px;box-shadow:var(--shadow);margin-bottom:18px}.hero:after{content:"";position:absolute;right:-130px;top:-130px;width:360px;height:360px;border-radius:50%;background:radial-gradient(circle,rgba(0,174,239,.22),transparent 68%)}.hero h1{margin:0 0 8px;font-size:42px;letter-spacing:-1.8px}.hero p{margin:0;color:#a7bdd1;max-width:980px;line-height:1.6;font-size:17px}.grid4{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.grid2{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.card{background:rgba(11,24,38,.86);border:1px solid var(--line2);border-radius:22px;padding:18px;box-shadow:0 12px 32px rgba(0,0,0,.18);min-width:0}.card h3{margin:0 0 6px;font-size:21px}.kpi{padding:20px}.kpi .n{font-size:38px;font-weight:900;letter-spacing:-1.4px}.kpi .l{color:var(--muted);font-weight:800;font-size:13px;text-transform:uppercase;letter-spacing:1px}.toolbar{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin:16px 0}.input,select,textarea{width:100%;background:rgba(255,255,255,.06);border:1px solid var(--line2);border-radius:14px;color:#fff;padding:12px;outline:none}.toolbar .input,.toolbar select{max-width:280px}.input:focus,select:focus,textarea:focus{border-color:var(--cyan);box-shadow:0 0 0 4px rgba(0,174,239,.10)}select option{background:#081522;color:white}.table-wrap{overflow:auto;border:1px solid var(--line2);border-radius:18px}.table{width:100%;border-collapse:collapse;min-width:980px}.table th,.table td{padding:12px 14px;border-bottom:1px solid rgba(255,255,255,.07);text-align:left;vertical-align:top}.table th{position:sticky;top:0;background:#0d1d2e;color:#a9c0d6;text-transform:uppercase;font-size:12px;letter-spacing:1.2px;z-index:1}.tag{display:inline-flex;align-items:center;justify-content:center;padding:5px 9px;border-radius:999px;font-size:12px;font-weight:900;border:1px solid var(--line2)}.Ferie{background:rgba(250,204,21,.15);color:#fde68a;border-color:rgba(250,204,21,.38)}.Permesso{background:rgba(34,211,238,.15);color:#a5f3fc;border-color:rgba(34,211,238,.38)}.ROL{background:rgba(168,85,247,.16);color:#e9d5ff;border-color:rgba(168,85,247,.38)}.Malattia{background:rgba(239,68,68,.16);color:#fecaca;border-color:rgba(239,68,68,.38)}.Chiusura,.Chiusura-aziendale{background:rgba(34,197,94,.15);color:#bbf7d0;border-color:rgba(34,197,94,.38)}.Festività{background:rgba(148,163,184,.17);color:#e2e8f0;border-color:rgba(148,163,184,.38)}.Congedo{background:rgba(251,146,60,.16);color:#fed7aa;border-color:rgba(251,146,60,.38)}
.calendar-card{padding:0;overflow:hidden}.calendar-top{padding:18px;border-bottom:1px solid var(--line2);display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.calendar-wrap{overflow:auto;max-height:64vh}.calendar-grid{display:grid;min-width:1320px}.cal-head,.cal-row{display:grid;grid-template-columns:260px repeat(var(--days),38px) 210px}.cal-head{position:sticky;top:0;z-index:4;background:#0d1d2e}.cal-head>div,.cal-row>div{border-right:1px solid rgba(255,255,255,.06);border-bottom:1px solid rgba(255,255,255,.07)}.cal-head .name-cell,.cal-row .person-cell{position:sticky;left:0;z-index:3;background:#0d1d2e}.cal-row .person-cell{background:rgba(10,23,37,.98)}.name-cell,.day-head,.person-cell,.day-cell,.sum-cell{padding:9px 8px}.day-head{text-align:center;font-size:12px;color:#bcd1e3}.day-head .dow{display:block;color:#7191aa;font-size:10px;margin-top:2px}.person-cell b{display:block;font-size:14px}.person-cell span{display:block;color:#8fa6ba;font-size:12px;margin-top:2px}.day-cell{height:50px;display:grid;place-items:center;position:relative}.day-cell.weekend{background:rgba(255,255,255,.025)}.day-cell.today{outline:2px solid rgba(0,174,239,.5);outline-offset:-2px}.event-pill{width:26px;height:26px;border-radius:9px;display:grid;place-items:center;font-size:12px;font-weight:900;box-shadow:0 8px 20px rgba(0,0,0,.22)}.day-cell.clickable{cursor:pointer}.sum-cell{font-size:12px;color:#cbd5e1}.event-tooltip{position:fixed;z-index:20;background:#06111c;border:1px solid var(--line);box-shadow:var(--shadow);border-radius:16px;padding:12px;max-width:340px;display:none}.event-tooltip h4{margin:0 0 6px}.legend{display:flex;gap:8px;flex-wrap:wrap}.legend .tag{font-size:12px}.modal-back{position:fixed;inset:0;background:rgba(0,0,0,.66);backdrop-filter:blur(8px);display:grid;place-items:center;z-index:50;padding:20px}.modal{width:min(780px,100%);max-height:90vh;overflow:auto;background:#081522;border:1px solid var(--line);border-radius:24px;box-shadow:var(--shadow);padding:20px}.modal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.modal-head h3{margin:0}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.form-row label{display:block;color:#a9c0d6;text-transform:uppercase;font-size:12px;letter-spacing:1px;font-weight:900;margin:0 0 6px}.toast{position:fixed;right:24px;bottom:24px;background:#071827;border:1px solid var(--line);border-radius:16px;padding:14px 16px;box-shadow:var(--shadow);z-index:80}.activity-card{display:grid;grid-template-columns:1.2fr .8fr;gap:16px}.progress{height:10px;border-radius:999px;background:rgba(255,255,255,.08);overflow:hidden}.progress span{display:block;height:100%;background:linear-gradient(90deg,var(--cyan),var(--blue));border-radius:999px}.warning{border-color:rgba(245,158,11,.4);background:rgba(245,158,11,.08)}.print-only{display:none}
@media(max-width:1050px){.app{grid-template-columns:1fr}.sidebar{position:fixed;z-index:40;width:min(330px,92vw);height:100vh;transform:translateX(-105%);transition:.2s}.sidebar.open{transform:translateX(0)}.grid4,.grid3,.grid2,.activity-card{grid-template-columns:1fr}.hero h1{font-size:33px}.top-actions{display:none}.content{padding:16px}.topbar{padding:0 16px}.topbar h2{font-size:24px}.login-card h1{font-size:38px}}
@media print{body{background:white;color:#111}.sidebar,.topbar,.modal-back,.toast,.no-print{display:none!important}.app{display:block;height:auto}.main{overflow:visible}.content{padding:0}.hero,.toolbar,.calendar-top button,.calendar-top select,.calendar-top input{display:none!important}.card{box-shadow:none;border:0;background:white;color:#111}.calendar-wrap{max-height:none;overflow:visible}.calendar-grid{min-width:0}.cal-head,.cal-row{grid-template-columns:170px repeat(var(--days),24px) 120px!important}.day-cell{height:30px}.event-pill{width:18px;height:18px;border-radius:5px;font-size:9px}.cal-head .name-cell,.cal-row .person-cell{position:static;background:white;color:#111}.cal-head{position:static;background:white;color:#111}.cal-head>div,.cal-row>div{border-color:#ddd}.table th{position:static;background:#eee;color:#111}.table{min-width:0;font-size:10px}.print-break{break-before:page}}
