:root{--navy: #1a2a6b;--navy-soft: #2a3b85;--blue: #2a47c2;--blue-soft: #4a66d4;--blue-pale: #eaf0ff;--bg: #f4f6fa;--surface: #ffffff;--surface-2: #f9fafd;--border: #e3e7ee;--border-strong: #cbd2dd;--text: #14213d;--text-soft: #4b5572;--muted: #8590a6;--success: #1f9d55;--success-pale: #e6f6ec;--warning: #d97706;--warning-pale: #fff4e0;--danger: #c0392b;--danger-pale: #fdecea;--s-1: 4px;--s-2: 8px;--s-3: 12px;--s-4: 16px;--s-5: 20px;--s-6: 24px;--s-8: 32px;--r-sm: 6px;--r-md: 10px;--r-lg: 14px;--r-full: 999px;--sh-1: 0 1px 2px rgba(20, 33, 61, .04), 0 1px 1px rgba(20, 33, 61, .06);--sh-2: 0 4px 12px rgba(20, 33, 61, .08);--sh-3: 0 12px 32px rgba(20, 33, 61, .14);--fs-xs: 11px;--fs-sm: 13px;--fs-md: 14px;--fs-lg: 16px;--fs-xl: 19px;--fs-2xl: 24px;--tabbar-h: 64px;--topbar-h: 56px;--safe-bottom: env(safe-area-inset-bottom, 0px)}*{box-sizing:border-box}html,body,#root{margin:0;padding:0;height:100%;background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,sans-serif;font-size:var(--fs-md);-webkit-tap-highlight-color:transparent;text-rendering:optimizeLegibility}html{touch-action:manipulation}body{overscroll-behavior-y:contain;-webkit-text-size-adjust:100%;text-size-adjust:100%}button,.btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer;border:1px solid var(--border-strong);background:var(--surface);color:var(--text);padding:8px 14px;border-radius:var(--r-md);font-size:var(--fs-sm);font-weight:500;font-family:inherit;min-height:38px;display:inline-flex;align-items:center;justify-content:center;gap:6px;transition:background .12s,border-color .12s,transform .05s}button:hover,.btn:hover{background:var(--surface-2)}button:active,.btn:active{transform:scale(.98)}button:disabled,.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary,button.primary{background:var(--blue);color:#fff;border-color:var(--blue)}.btn-primary:hover,button.primary:hover{background:var(--blue-soft);border-color:var(--blue-soft)}.btn-danger,button.danger{background:#fff;color:var(--danger);border-color:var(--danger)}.btn-danger:hover,button.danger:hover{background:var(--danger-pale)}.btn-ghost{border-color:transparent;background:transparent}.btn-ghost:hover{background:var(--surface-2)}.btn-sm{padding:4px 10px;min-height:30px;font-size:var(--fs-xs)}.btn-block{width:100%}input,select,textarea{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid var(--border-strong);border-radius:var(--r-md);padding:10px 12px;font-size:16px;font-family:inherit;background:var(--surface);color:var(--text);width:100%}input:focus,textarea:focus,select:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px #2a47c226}input[type=date]{padding:8px 10px}textarea{resize:vertical;min-height:64px}label.field{display:block;margin-bottom:var(--s-3)}label.field>.field-label{display:block;font-size:var(--fs-xs);font-weight:600;color:var(--text-soft);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}.app{display:flex;flex-direction:column;min-height:100vh;background:var(--bg)}.topbar{background:var(--surface);border-bottom:1px solid var(--border);padding:var(--s-3) var(--s-4);display:flex;align-items:center;gap:var(--s-3);position:sticky;top:0;z-index:50;min-height:var(--topbar-h)}.topbar .brand{display:flex;align-items:center;gap:var(--s-3);flex:1;min-width:0}.topbar .brand img{height:32px;width:auto;flex-shrink:0}.topbar .brand-title{display:none;font-size:var(--fs-sm);font-weight:600;color:var(--text-soft);text-transform:uppercase;letter-spacing:.4px;border-left:1px solid var(--border);padding-left:var(--s-3)}.topbar .user-chip{display:flex;align-items:center;gap:var(--s-2);font-size:var(--fs-sm);color:var(--text);background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-full);padding:4px 10px;cursor:pointer;flex-shrink:0}.topbar .user-chip .avatar{width:28px;height:28px;border-radius:50%;background:var(--navy);color:#fff;display:flex;align-items:center;justify-content:center;font-size:var(--fs-xs);font-weight:700;flex-shrink:0}.topbar .user-chip .user-name{display:none;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.topbar-tabs{display:none}.main{flex:1;padding:var(--s-4);padding-bottom:calc(var(--tabbar-h) + var(--safe-bottom) + var(--s-4))}.tabbar{position:fixed;bottom:0;left:0;right:0;height:calc(var(--tabbar-h) + var(--safe-bottom));padding-bottom:var(--safe-bottom);background:var(--surface);border-top:1px solid var(--border);display:flex;z-index:100;box-shadow:0 -4px 12px #14213d0a}.tabbar button{flex:1;background:transparent;border:none;border-radius:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:6px 4px;min-height:var(--tabbar-h);color:var(--muted);font-size:10px;font-weight:500;position:relative}.tabbar button:hover{background:transparent}.tabbar button .icon{font-size:22px;line-height:1}.tabbar button.active{color:var(--blue)}.tabbar button .badge{position:absolute;top:6px;right:18%;background:var(--danger);color:#fff;font-size:9px;padding:1px 5px;border-radius:var(--r-full);font-weight:700;min-width:16px;text-align:center}.sheet-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#14213d73;z-index:200;display:flex;align-items:flex-end;justify-content:center}.sheet{background:var(--surface);width:100%;max-width:480px;border-radius:var(--r-lg) var(--r-lg) 0 0;padding:var(--s-4) var(--s-4) calc(var(--s-4) + var(--safe-bottom));box-shadow:var(--sh-3)}.sheet h3{margin:0 0 var(--s-3)}.sheet .sheet-item{display:flex;align-items:center;gap:var(--s-3);padding:var(--s-3);border-radius:var(--r-md);cursor:pointer;font-size:var(--fs-md);border:none;background:transparent;width:100%;justify-content:flex-start;min-height:48px}.sheet .sheet-item:hover{background:var(--surface-2)}.sheet .sheet-item.danger{color:var(--danger)}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:var(--s-4);margin-bottom:var(--s-4);box-shadow:var(--sh-1)}.card h3{margin:0 0 var(--s-3);font-size:var(--fs-lg)}.section-title{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:var(--s-3)}.section-title h2{font-size:var(--fs-lg);margin:0;color:var(--text)}.section-title .sub{font-size:var(--fs-sm);color:var(--muted)}.toolbar{display:flex;align-items:center;gap:var(--s-2);flex-wrap:wrap}.toolbar .spacer{flex:1}.muted{color:var(--muted);font-size:var(--fs-sm)}.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--s-4);background:linear-gradient(180deg,var(--bg) 0%,#e6ebf5 100%)}.login-card{background:var(--surface);border-radius:var(--r-lg);box-shadow:var(--sh-2);padding:var(--s-6);width:100%;max-width:380px}.login-card .login-logo{display:block;max-width:220px;height:auto;margin:0 auto var(--s-4)}.login-card h2{text-align:center;margin:0 0 var(--s-2);color:var(--navy);font-size:var(--fs-xl)}.login-card .sub{text-align:center;color:var(--muted);margin:0 0 var(--s-5);font-size:var(--fs-sm)}.login-card .error{color:var(--danger);background:var(--danger-pale);padding:var(--s-2) var(--s-3);border-radius:var(--r-md);margin-top:var(--s-3);font-size:var(--fs-sm)}.day-picker{display:flex;gap:6px;overflow-x:auto;padding:0 0 var(--s-1);margin:0 calc(-1 * var(--s-4)) var(--s-3);padding-left:var(--s-4);padding-right:var(--s-4);-webkit-overflow-scrolling:touch;scrollbar-width:none}.day-picker::-webkit-scrollbar{display:none}.day-picker .day-chip{flex-shrink:0;width:56px;min-height:64px;border:1px solid var(--border-strong);border-radius:var(--r-md);background:var(--surface);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:6px 4px;cursor:pointer;font-size:var(--fs-xs);color:var(--text-soft);gap:2px}.day-picker .day-chip .dow{text-transform:uppercase;font-weight:600;font-size:10px;letter-spacing:.3px}.day-picker .day-chip .dom{font-size:var(--fs-lg);font-weight:700;color:var(--text)}.day-picker .day-chip.today{border-color:var(--blue);color:var(--blue)}.day-picker .day-chip.active{background:var(--blue);border-color:var(--blue);color:#fff}.day-picker .day-chip.active .dom{color:#fff}.day-picker .day-chip .has-dot{width:6px;height:6px;border-radius:50%;background:var(--blue);margin-top:2px}.day-picker .day-chip.active .has-dot{background:#fff}.week-nav{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--s-3);gap:var(--s-2)}.week-nav .week-label{font-weight:600;color:var(--text);font-size:var(--fs-md);text-align:center;flex:1}.week-nav .week-label .sub{display:block;font-size:var(--fs-xs);color:var(--muted);font-weight:400}.week-nav .nav-btn{width:40px;height:40px;min-height:40px;border-radius:var(--r-full);padding:0}.dept-section{margin-bottom:var(--s-5)}.dept-section .dept-header{font-size:var(--fs-xs);font-weight:700;color:var(--navy);text-transform:uppercase;letter-spacing:.7px;padding:6px var(--s-3);background:var(--blue-pale);border-radius:var(--r-sm);margin-bottom:var(--s-2)}.person-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);padding:var(--s-3);margin-bottom:var(--s-2);display:flex;gap:var(--s-3);align-items:flex-start;box-shadow:var(--sh-1)}.person-card.me{border-color:var(--blue);background:linear-gradient(0deg,var(--blue-pale) 0%,var(--surface) 100%)}.person-card .avatar{width:36px;height:36px;border-radius:50%;background:var(--navy);color:#fff;display:flex;align-items:center;justify-content:center;font-size:var(--fs-sm);font-weight:700;flex-shrink:0}.person-card .body{flex:1;min-width:0}.person-card .name{font-weight:600;font-size:var(--fs-md);color:var(--text);margin-bottom:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.person-card .presence-text{font-size:var(--fs-sm);color:var(--text-soft);white-space:pre-wrap;word-break:break-word;min-height:20px}.person-card .presence-text.empty{color:var(--muted);font-style:italic}.person-card .presence-badge{display:inline-block;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.3px;padding:2px 8px;border-radius:var(--r-full);margin-bottom:4px}.presence-badge.ferie{background:var(--danger-pale);color:var(--danger)}.presence-badge.smart{background:var(--success-pale);color:var(--success)}.presence-badge.malattia{background:var(--warning-pale);color:var(--warning)}.presence-badge.present{background:var(--blue-pale);color:var(--blue)}.person-card .edit-pencil{background:transparent;border:none;color:var(--muted);padding:4px;min-height:auto;font-size:var(--fs-md)}.editor-inline{width:100%;margin-top:var(--s-2)}.editor-inline textarea{min-height:90px}.editor-inline .actions{display:flex;gap:var(--s-2);margin-top:var(--s-2);justify-content:flex-end}.saving-pill{font-size:10px;color:var(--warning)}.saved-pill{font-size:10px;color:var(--success)}.week-grid{width:100%;border-collapse:collapse}.week-grid th,.week-grid td{border:1px solid var(--border);padding:0;vertical-align:top;text-align:left}.week-grid th{background:var(--navy);color:#fff;font-weight:600;padding:10px;text-align:center;font-size:var(--fs-xs);text-transform:uppercase;letter-spacing:.4px}.week-grid th.person-col{text-align:left;min-width:180px}.week-grid th.today{background:var(--blue)}.week-grid td.person-col{background:var(--surface-2);font-weight:600;padding:10px;width:180px;font-size:var(--fs-sm)}.week-grid td.today-cell{background:#fffbe8}.week-grid .dept-row td{background:var(--navy-soft);color:#fff;font-weight:700;padding:6px 12px;font-size:var(--fs-xs);text-transform:uppercase;letter-spacing:.5px}.cell-editor{width:100%;height:100%;min-height:80px;padding:8px;border:2px solid transparent;background:transparent;font:inherit;font-size:var(--fs-sm);resize:none;white-space:pre-wrap}.cell-editor.editable:hover{background:var(--surface);cursor:text}.cell-editor.editable:focus{background:#fff;border-color:var(--blue);outline:none}.cell-editor.readonly{cursor:default}.cell-saving{background:var(--warning-pale)!important}.cell-saved{background:var(--success-pale)!important}.cal-toolbar{display:flex;align-items:center;gap:var(--s-2);margin-bottom:var(--s-3);flex-wrap:wrap}.zoom-switch{display:flex;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-md);padding:2px}.zoom-switch button{border:none;background:transparent;padding:6px 10px;font-size:var(--fs-xs);border-radius:var(--r-sm);min-height:32px;font-weight:600;color:var(--text-soft)}.zoom-switch button.active{background:var(--surface);color:var(--blue);box-shadow:var(--sh-1)}.calendar-month{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.calendar-month .dow{font-weight:600;text-align:center;padding:6px 2px;background:var(--navy);color:#fff;border-radius:var(--r-sm);font-size:10px;letter-spacing:.4px}.calendar-month .day{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-sm);min-height:80px;padding:4px;font-size:10px;overflow:hidden;cursor:pointer;display:flex;flex-direction:column;gap:2px}.calendar-month .day.other{opacity:.4;background:var(--surface-2)}.calendar-month .day.today{border-color:var(--blue);background:#fffbe8}.calendar-month .day .date-num{font-weight:700;color:var(--text)}.calendar-month .day .pill{font-size:9px;padding:1px 5px;border-radius:var(--r-full);background:var(--blue-pale);color:var(--blue);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.calendar-month .day .pill.ferie{background:var(--danger-pale);color:var(--danger)}.calendar-month .day .pill.smart{background:var(--success-pale);color:var(--success)}.calendar-month .day .pill.malattia{background:var(--warning-pale);color:var(--warning)}.calendar-year{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--s-3)}.mini-month{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);padding:var(--s-2);font-size:10px;cursor:pointer;box-shadow:var(--sh-1)}.mini-month h4{margin:0 0 6px;font-size:var(--fs-sm);text-align:center;text-transform:capitalize;color:var(--navy)}.mini-month table{width:100%;border-collapse:collapse}.mini-month td{text-align:center;padding:2px;font-size:10px}.mini-month td.has{background:var(--blue);color:#fff;border-radius:50%}.mini-month td.today{outline:2px solid var(--warning);border-radius:50%}.mini-month th{color:var(--muted);font-weight:400;font-size:9px}.audit-list{display:flex;flex-direction:column;gap:var(--s-2)}.audit-item{background:var(--surface);border:1px solid var(--border);border-left:4px solid var(--blue);border-radius:var(--r-md);padding:var(--s-3)}.audit-item.unseen{border-left-color:var(--warning);background:var(--warning-pale)}.audit-item .meta{font-size:var(--fs-xs);color:var(--muted);display:flex;flex-wrap:wrap;gap:var(--s-2);margin-bottom:6px}.audit-item .who{font-weight:600;color:var(--text)}.audit-item .day-label{display:inline-block;background:var(--warning);color:#fff;padding:1px 8px;border-radius:var(--r-full);font-size:10px;font-weight:700;margin-right:6px}.audit-item .delta{display:grid;gap:4px;font-size:var(--fs-sm)}.audit-item .delta .old{color:var(--danger);text-decoration:line-through}.audit-item .delta .new{color:var(--success)}.audit-item .actions{margin-top:var(--s-2);display:flex;justify-content:flex-end}.admin-list{display:flex;flex-direction:column;gap:var(--s-2)}.admin-item{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);padding:var(--s-3);display:flex;align-items:center;gap:var(--s-3);flex-wrap:wrap}.admin-item .info{flex:1;min-width:180px}.admin-item .name{font-weight:600}.admin-item .sub{font-size:var(--fs-xs);color:var(--muted)}.admin-item .controls{display:flex;gap:var(--s-2);flex-wrap:wrap;align-items:center}.role-pill{display:inline-block;background:var(--blue-pale);color:var(--blue);font-size:10px;font-weight:700;padding:2px 8px;border-radius:var(--r-full);text-transform:uppercase}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#14213d80;z-index:200;display:flex;align-items:center;justify-content:center;padding:var(--s-3)}.modal{background:var(--surface);border-radius:var(--r-lg);width:100%;max-width:480px;max-height:90vh;overflow:auto;padding:var(--s-5);box-shadow:var(--sh-3)}.modal h3{margin-top:0}.modal .actions{display:flex;gap:var(--s-2);justify-content:flex-end;margin-top:var(--s-4)}.fab{position:fixed;right:var(--s-4);bottom:calc(var(--tabbar-h) + var(--safe-bottom) + var(--s-4));width:56px;height:56px;border-radius:50%;background:var(--blue);color:#fff;border:none;box-shadow:var(--sh-3);font-size:24px;display:flex;align-items:center;justify-content:center;z-index:80}.fab:hover{background:var(--blue-soft)}@media (min-width: 720px){.topbar{padding:var(--s-3) var(--s-5);gap:var(--s-5)}.topbar .brand img{height:36px}.topbar .brand-title{display:block}.topbar .user-chip .user-name{display:inline}.topbar-tabs{display:flex;gap:2px;flex:1;justify-content:flex-end}.topbar-tabs button{background:transparent;border:none;border-radius:var(--r-md);color:var(--text-soft);font-weight:500;padding:8px 14px;position:relative}.topbar-tabs button:hover{background:var(--surface-2);color:var(--text)}.topbar-tabs button.active{background:var(--blue-pale);color:var(--blue)}.topbar-tabs button .badge{display:inline-block;background:var(--danger);color:#fff;font-size:10px;padding:1px 6px;border-radius:var(--r-full);margin-left:6px;font-weight:700}.tabbar,.fab{display:none}.main{padding:var(--s-5);padding-bottom:var(--s-5);max-width:1400px;margin:0 auto;width:100%}.calendar-year{grid-template-columns:repeat(4,1fr)}.calendar-month .day{min-height:110px;font-size:11px;padding:6px}.calendar-month .dow{font-size:12px;padding:8px}}@media (min-width: 1080px){.week-grid th,.week-grid td.person-col{font-size:var(--fs-sm)}.cell-editor{min-height:96px}}
