:root{--hrs-bg: #F5F7FA;--hrs-surface: #FFFFFF;--hrs-card: #F8FAFC;--hrs-surface-light: #EFF6FF;--hrs-text: #202020;--hrs-muted: #6B7280;--hrs-primary: #0061A1;--hrs-primary-dark: #004A7D;--hrs-primary-light: #E6F2F9;--hrs-secondary: #003559;--hrs-accent: #E30614;--hrs-border: #E2E8F0;--hrs-border-strong: #CBD5E0;--hrs-shadow: 0 4px 16px rgba(0,53,89,.1);--hrs-shadow-sm: 0 1px 3px rgba(0,53,89,.08);--hrs-weekend: #D4DEE9;--hrs-today: #EFF6FF;--bt-work: #0061A1;--bt-work-soft: #E6F2F9;--bt-vacation: #DC2626;--bt-vacation-soft: #FEE2E2;--bt-sick: #D97706;--bt-sick-soft: #FEF3C7;--bt-course: #16A34A;--bt-course-soft: #DCFCE7;--bt-wfh: #3397CF;--bt-wfh-soft: #DBEAFE;--bt-holiday: #94A3B8;--bt-holiday-soft: #E5E7EB;--row-h: 44px;--day-w: 44px;--left-w: 280px}html.dark{--hrs-bg: #0D1B2A;--hrs-surface: #1A2D3F;--hrs-card: #1E3448;--hrs-surface-light: #0D2D42;--hrs-text: #E8EDF2;--hrs-muted: #8FA3B8;--hrs-primary: #3397CF;--hrs-primary-dark: #0061A1;--hrs-primary-light: #0D2D42;--hrs-secondary: #66B1DB;--hrs-border: #2A3F55;--hrs-border-strong: #3A536F;--hrs-shadow: 0 4px 16px rgba(0,0,0,.4);--hrs-shadow-sm: 0 1px 3px rgba(0,0,0,.25);--hrs-weekend: #0A1623;--hrs-today: #0D2D42;--bt-work: #3397CF;--bt-work-soft: #0D2D42;--bt-vacation-soft: #2D0D0D;--bt-sick-soft: #2D1D00;--bt-course-soft: #0D2D1A;--bt-wfh-soft: #0D2D42;--bt-holiday-soft: #1A2D3F}*{box-sizing:border-box}html,body{margin:0;padding:0;height:100%;background:var(--hrs-bg);color:var(--hrs-text);font-family:Barlow,system-ui,sans-serif;font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}#root{height:100vh;display:flex;flex-direction:column}.font-archivo{font-family:Archivo,sans-serif}.font-barlow{font-family:Barlow,sans-serif}.hrs-navbar{background:linear-gradient(92deg,#202020,#003559);height:56px;color:#fff;display:flex;align-items:center;padding:0 20px;gap:24px;flex-shrink:0;position:relative;z-index:50;box-shadow:0 1px 4px #0000002e}.hrs-navbar .logo{font-family:Archivo,sans-serif;font-weight:800;letter-spacing:.08em;font-size:18px;background:#fff;color:#003559;padding:4px 10px;border-radius:4px}.hrs-navbar .app-title{font-family:Archivo,sans-serif;font-weight:600;font-size:14px;letter-spacing:.04em}.hrs-navbar .nav-spacer{flex:1}.hrs-navbar .nav-item{font-size:13px;font-weight:500;color:#ffffffbf;padding:6px 12px;border-radius:6px;cursor:pointer;display:inline-flex;align-items:center;gap:6px;transition:background .12s,color .12s}.hrs-navbar .nav-item:hover{background:#ffffff1a;color:#fff}.hrs-navbar .nav-item.active{background:#ffffff26;color:#fff}.hrs-navbar .avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,#0061a1,#003559);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:12px;color:#fff;font-family:Archivo,sans-serif;border:2px solid rgba(255,255,255,.2)}.hrs-navbar .notif-btn{position:relative;width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;background:#ffffff14;cursor:pointer;border:none;color:#fff}.hrs-navbar .notif-btn:hover{background:#ffffff2e}.hrs-navbar .notif-badge{position:absolute;top:-2px;right:-2px;background:#e30614;color:#fff;font-size:10px;font-weight:700;min-width:16px;height:16px;padding:0 4px;border-radius:8px;display:flex;align-items:center;justify-content:center;border:2px solid #003559;font-family:Archivo,sans-serif}.hrs-page-header{background:linear-gradient(135deg,#0061a1,#003559);color:#fff;padding:10px 20px;display:flex;align-items:center;gap:14px;flex-shrink:0;flex-wrap:wrap;position:relative;z-index:40}html.dark .hrs-page-header{background:linear-gradient(135deg,#0d4a80,#001d3d)}.hrs-page-header h1{font-family:Archivo,sans-serif;font-weight:700;font-size:17px;margin:0;letter-spacing:.01em}.hrs-page-header .sep{width:1px;height:22px;background:#ffffff38}.hrs-page-header .meta{font-size:12px;color:#ffffffbf}.hrs-page-header .meta strong{color:#fff;font-family:Archivo,sans-serif;font-weight:600}.icon-btn{width:30px;height:30px;border-radius:6px;display:inline-flex;align-items:center;justify-content:center;background:#ffffff1a;border:1px solid rgba(255,255,255,.1);color:#fff;cursor:pointer;transition:background .12s}.icon-btn:hover{background:#fff3}.icon-btn.flat{background:transparent;border:1px solid transparent;color:var(--hrs-text)}.icon-btn.flat:hover{background:var(--hrs-card)}.seg-control{display:inline-flex;background:#ffffff1a;border:1px solid rgba(255,255,255,.1);padding:2px;border-radius:8px;font-family:Archivo,sans-serif}.seg-control button{background:transparent;border:none;color:#ffffffbf;font-size:12px;font-weight:600;padding:5px 12px;border-radius:6px;cursor:pointer;transition:all .12s;letter-spacing:.02em}.seg-control button.active{background:#fff;color:#003559}.seg-control button:hover:not(.active){color:#fff}.filter-bar{background:var(--hrs-surface);border-bottom:1px solid var(--hrs-border);padding:10px 20px;display:flex;align-items:center;gap:10px;flex-shrink:0;flex-wrap:wrap}.filter-chip{display:inline-flex;align-items:center;gap:6px;padding:5px 11px 5px 9px;border-radius:999px;background:var(--hrs-card);border:1px solid var(--hrs-border);font-size:12.5px;font-weight:500;color:var(--hrs-text);cursor:pointer;transition:all .12s;font-family:Barlow,sans-serif;white-space:nowrap}.filter-chip:hover{border-color:var(--hrs-primary)}.filter-chip.active{background:var(--hrs-surface-light);border-color:var(--hrs-primary);color:var(--hrs-primary)}.filter-chip .dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.filter-chip .count{background:#0000000f;color:var(--hrs-muted);font-size:10.5px;font-weight:600;padding:1px 6px;border-radius:999px;font-family:Archivo,sans-serif}.filter-chip.active .count{background:#0061a126;color:var(--hrs-primary)}.search-box{display:inline-flex;align-items:center;gap:6px;background:var(--hrs-card);border:1px solid var(--hrs-border);border-radius:6px;padding:5px 10px;flex:0 0 220px;color:var(--hrs-muted)}.search-box input{background:transparent;border:none;outline:none;font-size:13px;font-family:Barlow,sans-serif;color:var(--hrs-text);width:100%}.search-box input::placeholder{color:var(--hrs-muted)}.divider-v{width:1px;height:24px;background:var(--hrs-border)}.filter-trigger{display:inline-flex;align-items:center;gap:7px;padding:6px 12px;border-radius:7px;background:var(--hrs-card);border:1px solid var(--hrs-border);font-size:12.5px;font-weight:500;color:var(--hrs-text);cursor:pointer;transition:all .12s;font-family:Barlow,sans-serif;white-space:nowrap;height:32px}.filter-trigger:hover{border-color:var(--hrs-primary);color:var(--hrs-primary)}.filter-trigger.filtered{background:var(--hrs-surface-light);border-color:var(--hrs-primary);color:var(--hrs-primary);font-weight:600}.filter-trigger.warning{background:#fff7e0;border-color:#e0a800;color:#7a5c00}.filter-trigger-count{background:#0061a11f;color:var(--hrs-primary);font-size:10.5px;font-weight:700;padding:1px 7px;border-radius:999px;font-family:Archivo,sans-serif;letter-spacing:.02em}.filter-trigger.filtered .filter-trigger-count{background:var(--hrs-primary);color:#fff}.filter-trigger.empty .filter-trigger-count{background:#0000000f;color:var(--hrs-muted)}.filter-trigger-caret{font-size:9px;opacity:.6;margin-left:-2px}.filter-popover{position:absolute;top:calc(100% + 6px);left:0;z-index:100;background:#fff;border:1px solid var(--hrs-border);border-radius:8px;box-shadow:0 8px 24px #0015321f,0 2px 6px #0015320f;padding:12px;min-width:280px;max-width:520px}.filter-popover-header{font-size:10.5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--hrs-muted);font-family:Archivo,sans-serif;margin-bottom:8px}.filter-popover-row{display:flex;gap:6px;margin-bottom:8px;padding-bottom:8px;border-bottom:1px solid var(--hrs-border)}.filter-popover-grid{display:flex;flex-wrap:wrap;gap:6px}.filter-pill{display:inline-flex;align-items:center;gap:6px;padding:5px 10px;border-radius:6px;background:var(--hrs-card);border:1px solid var(--hrs-border);font-size:12px;font-weight:500;color:var(--hrs-text);cursor:pointer;transition:all .1s;font-family:Barlow,sans-serif;white-space:nowrap}.filter-pill:hover{border-color:var(--hrs-primary);transform:translateY(-1px)}.filter-pill.active{background:var(--hrs-surface-light);border-color:var(--hrs-primary);color:var(--hrs-primary);font-weight:600}.filter-pill .dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.filter-pill .count{background:#0000000f;color:var(--hrs-muted);font-size:10.5px;font-weight:700;padding:1px 6px;border-radius:999px;font-family:Archivo,sans-serif}.filter-pill.active .count{background:#0061a126;color:var(--hrs-primary)}.main-wrap{flex:1;min-height:0;display:flex;overflow:hidden}.timeline-host{flex:1;min-width:0;display:flex;flex-direction:column;background:var(--hrs-surface);position:relative}.sidepanel{width:340px;flex-shrink:0;border-left:1px solid var(--hrs-border);background:var(--hrs-bg);display:flex;flex-direction:column;overflow:hidden;transition:width .22s ease,opacity .22s ease}.sidepanel.collapsed{width:0;opacity:0;border-left:0}.sidepanel-inner{padding:16px;overflow-y:auto;height:100%;width:340px}.timeline{flex:1;min-height:0;display:grid;grid-template-columns:var(--left-w) 1fr;position:relative;overflow:hidden}.tl-corner{background:var(--hrs-card);border-right:1px solid var(--hrs-border);border-bottom:1px solid var(--hrs-border-strong);display:flex;align-items:stretch;position:sticky;top:0;left:0;z-index:30;font-family:Archivo,sans-serif}.tl-corner .col{flex:1;display:flex;align-items:flex-end;padding:0 12px 7px;font-size:10px;font-weight:600;color:var(--hrs-muted);letter-spacing:.05em;text-transform:uppercase}.tl-corner{overflow:hidden}.tl-corner-search{flex:1;display:flex;flex-direction:column;justify-content:center;gap:5px;padding:6px 10px;min-width:0}.tl-corner-search .search-box{width:100%;min-width:0;flex:0 0 auto;padding:3px 8px}.tl-corner-search .search-box input{font-size:12px}.tl-corner-filters{display:flex;gap:4px;flex:0 0 auto}.tl-corner-filters>div{flex:1;min-width:0}.tl-corner-filters .filter-trigger{width:100%;justify-content:flex-start;padding:3px 8px;font-size:11px}.tl-header{background:var(--hrs-card);border-bottom:1px solid var(--hrs-border-strong);position:sticky;top:0;z-index:20;overflow:hidden}.tl-header-inner{display:flex;flex-direction:column}.tl-month-row{display:flex;border-bottom:1px solid var(--hrs-border);height:22px}.tl-month-cell{flex-shrink:0;display:flex;align-items:center;justify-content:center;padding:0 10px;font-family:Archivo,sans-serif;font-size:10.5px;font-weight:700;color:var(--hrs-secondary);letter-spacing:.06em;text-transform:uppercase;border-right:2px solid var(--hrs-primary);background:var(--hrs-surface-light)}.tl-month-cell:last-child{border-right:1px solid var(--hrs-border)}html.dark .tl-month-cell{color:var(--hrs-secondary)}.tl-week-row{display:flex;border-bottom:1px solid var(--hrs-border);height:18px}.tl-week-cell{flex-shrink:0;display:flex;align-items:center;justify-content:center;font-family:Archivo,sans-serif;font-size:9.5px;font-weight:600;color:var(--hrs-muted);border-right:1px solid var(--hrs-border)}.tl-day-row{display:flex;height:36px}.tl-day-cell{width:var(--day-w);flex-shrink:0;display:flex;flex-direction:column;align-items:center;justify-content:center;border-right:1px solid var(--hrs-border);font-family:Archivo,sans-serif;background:var(--hrs-surface);position:relative}.tl-day-cell.weekend{background:var(--hrs-weekend)}.tl-day-cell .dow{font-size:9.5px;font-weight:600;color:var(--hrs-muted);text-transform:uppercase;letter-spacing:.04em;line-height:1;margin-bottom:2px}.tl-day-cell .dnum{font-size:13px;font-weight:700;color:var(--hrs-text);line-height:1}.tl-day-cell.hourmode{justify-content:flex-start;padding-top:3px}.tl-day-cell .dnum-inline{font-size:11px;font-weight:700;color:var(--hrs-text);line-height:1;white-space:nowrap}.tl-hour-strip .hour-label-abs{top:auto;bottom:1px;transform:translate(-50%)}.tl-body-scroll{position:absolute;top:0;right:0;bottom:0;left:0;overflow:auto}.tl-body-grid{display:grid;grid-template-columns:var(--left-w) 1fr;position:relative}.left-list{position:sticky;left:0;z-index:15;background:var(--hrs-surface);border-right:1px solid var(--hrs-border)}.left-group-header{display:flex;align-items:center;padding:0 12px;height:33px;background:var(--hrs-card);border-top:1px solid var(--hrs-border);border-bottom:1px solid var(--hrs-border);font-family:Archivo,sans-serif;font-size:10.5px;font-weight:700;color:var(--hrs-secondary);letter-spacing:.08em;text-transform:uppercase;gap:8px;position:sticky;left:0;cursor:pointer}.left-group-header .count{font-size:10px;font-weight:600;color:var(--hrs-muted);background:var(--hrs-surface);padding:1px 7px;border-radius:999px;margin-left:auto}.left-row{display:flex;align-items:center;padding:0 8px 0 6px;height:var(--row-h);border-bottom:1px solid var(--hrs-border);gap:8px;cursor:grab;position:relative}.left-row:hover{background:var(--hrs-card)}.left-row.dragging{opacity:.5}.left-row.drop-target-above:before{content:"";position:absolute;left:0;right:0;top:-1px;height:2px;background:var(--hrs-primary);z-index:5}.left-row.drop-target-below:after{content:"";position:absolute;left:0;right:0;bottom:-1px;height:2px;background:var(--hrs-primary);z-index:5}.left-row .grip{width:14px;color:var(--hrs-muted);flex-shrink:0;opacity:0;transition:opacity .12s;cursor:grab}.left-row:hover .grip{opacity:1}.left-row .avatar-sm{min-width:30px;height:20px;padding:0 8px;border-radius:999px;background:linear-gradient(135deg,var(--hrs-primary),var(--hrs-secondary));display:flex;align-items:center;justify-content:center;color:#fff;font-size:11px;font-weight:700;font-family:Archivo,sans-serif;flex-shrink:0;position:relative;white-space:nowrap}.left-row .avatar-sm.machine{min-width:24px;padding:0;background:linear-gradient(135deg,#475569,#1e293b);border-radius:6px}.left-row .avatar-sm.coord{box-shadow:0 0 0 1px #ffffffe6,0 0 0 2.5px var(--coord-color)}.left-row .avatar-sm[data-len="3"]{font-size:9.5px;letter-spacing:-.02em}.left-row .avatar-sm[data-len="4"]{font-size:8.5px;letter-spacing:-.04em}.left-row .avatar-sm[data-len="5"]{font-size:7.5px;letter-spacing:-.05em}.left-row.is-coord{border-left:3px solid var(--coord-color);padding-left:3px}.left-row .coord-tag{display:inline-block;background:var(--coord-color, var(--hrs-primary));color:#fff;font-family:Archivo,sans-serif;font-size:8px;font-weight:700;letter-spacing:.08em;padding:1px 5px;border-radius:3px;margin-right:5px;vertical-align:.5px}.left-row .row-edit-btn{position:absolute;right:6px;top:50%;transform:translateY(-50%);width:22px;height:22px;border-radius:5px;background:var(--hrs-surface);border:1px solid var(--hrs-border);color:var(--hrs-muted);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;opacity:0;transition:all .12s}.left-row:hover .row-edit-btn{opacity:1}.left-row .row-edit-btn:hover{color:var(--hrs-primary);border-color:var(--hrs-primary);background:var(--hrs-primary-light)}.left-add-row{display:flex;align-items:center;gap:6px;padding:8px 12px 10px;font-size:11.5px;font-weight:500;color:var(--hrs-muted);cursor:pointer;border-bottom:1px solid var(--hrs-border);font-family:Barlow,sans-serif}.left-add-row:hover{color:var(--hrs-primary);background:var(--hrs-primary-light)}.left-subdivider{display:flex;align-items:center;gap:6px;padding:4px 12px;height:24px;background:color-mix(in srgb,var(--hrs-card) 60%,var(--hrs-bg));font-family:Archivo,sans-serif;font-size:9.5px;font-weight:700;color:var(--hrs-muted);letter-spacing:.08em;text-transform:uppercase;border-top:1px solid var(--hrs-border);border-bottom:1px solid var(--hrs-border)}.left-row.is-machine .pname{font-family:Archivo,sans-serif;font-size:12px}.left-row.is-machine .prole{font-style:italic}.left-row .person{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px}.left-row .pname{font-size:11px;font-weight:600;color:var(--hrs-text);font-family:Archivo,sans-serif;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.2}.left-row .prole{font-size:9.5px;color:var(--hrs-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.2}.left-row .cap-mini{width:36px;text-align:right;font-family:Archivo,sans-serif;font-size:10px;font-weight:700;color:var(--hrs-muted);flex-shrink:0}.left-row .cap-bar{position:absolute;bottom:0;left:0;height:2px;background:var(--hrs-primary)}.body-cells{position:relative;background:repeating-linear-gradient(to right,transparent 0,transparent calc(var(--day-w) - 1px),var(--hrs-border) calc(var(--day-w) - 1px),var(--hrs-border) var(--day-w))}.body-row{position:relative;height:var(--row-h);border-bottom:1px solid var(--hrs-border)}.body-row.weekend-cells{background-image:repeating-linear-gradient(to right,transparent 0,transparent calc(var(--day-w) - 1px),var(--hrs-border) calc(var(--day-w) - 1px),var(--hrs-border) var(--day-w))}.weekend-overlay{position:absolute;top:0;bottom:0;background:var(--hrs-weekend);opacity:.85;border-left:1px solid var(--hrs-border-strong);border-right:1px solid var(--hrs-border-strong);pointer-events:none}.tl-day-cell.holiday{background:var(--hrs-weekend)}.tl-day-row-hours{background:var(--hrs-surface);height:32px;border-bottom:1px solid var(--hrs-border);overflow:hidden}.hour-label-abs{position:absolute;top:50%;transform:translate(-50%,-50%);font-family:Archivo,sans-serif;font-weight:600;letter-spacing:0;white-space:nowrap;pointer-events:none}.hour-label-abs.work{font-size:11px;color:var(--hrs-text);opacity:.92}.hour-label-abs.off{font-size:10px;color:var(--hrs-muted);opacity:.6}.hour-tick-line{position:absolute;top:60%;bottom:20%;width:1px;background:var(--hrs-border);pointer-events:none}.break-band{position:absolute;top:0;bottom:0;background:#ffc8462e;pointer-events:none;z-index:1}.hour-grid-line{position:absolute;top:0;bottom:0;width:1px;background:var(--hrs-border);pointer-events:none;z-index:0}.day-grid-line{position:absolute;top:0;bottom:0;width:2px;background:var(--hrs-primary);opacity:.5;pointer-events:none;z-index:2}.now-line{position:absolute;top:0;bottom:0;width:2px;background:#dc2626;pointer-events:none;z-index:5;box-shadow:0 0 4px #dc262666}.now-line:before{content:"";position:absolute;top:-3px;left:-4px;width:10px;height:10px;border-radius:50%;background:#dc2626;box-shadow:0 0 0 2px #fff}.half-hour-grid-line{position:absolute;top:0;bottom:0;width:1px;background:var(--hrs-border);opacity:.25;pointer-events:none;z-index:0}.off-hour-overlay{position:absolute;top:0;bottom:0;background:repeating-linear-gradient(-45deg,#94a3b81a 0,#94a3b81a 4px,#94a3b82e 4px,#94a3b82e 8px);pointer-events:none;z-index:1}.holiday-overlay{position:absolute;top:0;bottom:0;background:var(--hrs-weekend);opacity:.85;border-left:1px solid var(--hrs-border-strong);border-right:1px solid var(--hrs-border-strong);pointer-events:auto;cursor:help}.booking{position:absolute;top:4px;bottom:4px;border-radius:6px;padding:2px 3px 2px 4px;display:flex;align-items:center;gap:3px;cursor:grab;-webkit-user-select:none;user-select:none;font-family:Archivo,sans-serif;overflow:hidden;transition:box-shadow .12s,transform .12s;z-index:2;box-shadow:0 1px 2px #00000014}.booking:hover{box-shadow:0 3px 10px #0035592e,0 0 0 1.5px #fff9 inset;z-index:3}.booking.selected{outline:2px solid var(--hrs-primary);outline-offset:1px;z-index:4}.booking.dragging{opacity:.6;cursor:grabbing}.booking .bk-body{display:flex;flex-direction:column;justify-content:center;gap:1px;min-width:0;flex:1 1 0;overflow:hidden}.booking .bk-l1{display:flex;align-items:center;gap:3px;min-width:0}.booking .bk-status{flex-shrink:0;width:6px;height:6px;border-radius:50%;border:1px solid rgba(255,255,255,.92);box-shadow:0 0 0 1px #0000001f}.booking .ttl{font-size:9.5px;font-weight:700;color:inherit;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0;letter-spacing:-.01em}.booking .bk-l2{font-size:8.5px;font-weight:500;line-height:1.1;opacity:.82;font-family:Barlow,sans-serif;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0;letter-spacing:-.02em}.booking .coord-dot{position:absolute;top:3px;right:3px;width:8px;height:8px;border-radius:50%;border:1.5px solid rgba(255,255,255,.95);box-shadow:0 0 0 .5px #0003}.booking .resize-handle{position:absolute;top:0;bottom:0;width:6px;cursor:ew-resize;opacity:0;transition:opacity .12s}.booking:hover .resize-handle{opacity:1}.booking .resize-handle.left{left:0}.booking .resize-handle.right{right:0}.booking .resize-handle:after{content:"";position:absolute;top:30%;bottom:30%;left:50%;transform:translate(-50%);width:2px;border-radius:1px;background:#ffffffb3}.booking.bt-work{background:var(--bt-work);color:#fff}.booking.bt-vacation{background:var(--bt-vacation);color:#fff}.booking.bt-sick{background:var(--bt-sick);color:#fff}.booking.bt-course{background:var(--bt-course);color:#fff}.booking.bt-wfh{background:var(--bt-wfh);color:#fff}.booking.bt-holiday{background:repeating-linear-gradient(135deg,var(--bt-holiday),var(--bt-holiday) 6px,#A8B2BD 6px,#A8B2BD 12px);color:#fff}.create-preview{position:absolute;top:4px;bottom:4px;border:2px dashed var(--hrs-primary);background:#0061a11a;border-radius:6px;pointer-events:none;z-index:3;display:flex;align-items:center;justify-content:center;color:var(--hrs-primary);font-family:Archivo,sans-serif;font-size:11px;font-weight:700}.hover-cell-marker{position:absolute;background:#0061a11a;border-left:1px solid rgba(0,97,161,.45);border-right:1px solid rgba(0,97,161,.45);pointer-events:none;z-index:2;display:flex;align-items:flex-start;justify-content:center}.hover-cell-label{margin-top:1px;padding:0 5px;border-radius:0 0 5px 5px;background:var(--hrs-primary);color:#fff;font-family:Archivo,sans-serif;font-size:9.5px;font-weight:700;line-height:14px;white-space:nowrap}.hover-cell-label.stacked{display:flex;flex-direction:column;align-items:center;padding:1px 5px 2px;line-height:12px;text-transform:capitalize}.hover-cell-sub{font-size:10px}.context-menu{position:fixed;background:var(--hrs-surface);border:1px solid var(--hrs-border);border-radius:10px;box-shadow:0 12px 32px #0035592e,0 2px 6px #0000000f;padding:6px;min-width:200px;z-index:200;font-family:Barlow,sans-serif}.context-menu .item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:6px;cursor:pointer;font-size:13px;color:var(--hrs-text)}.context-menu .item:hover{background:var(--hrs-surface-light);color:var(--hrs-primary)}.context-menu .item.danger:hover{background:#fee2e2;color:var(--bt-vacation)}html.dark .context-menu .item.danger:hover{background:#2d0d0d;color:#ff4d56}.context-menu .sep{height:1px;background:var(--hrs-border);margin:4px 0}.context-menu .group-label{font-size:10px;font-weight:700;color:var(--hrs-muted);letter-spacing:.06em;text-transform:uppercase;padding:6px 10px 2px;font-family:Archivo,sans-serif}.context-menu .swatch{width:12px;height:12px;border-radius:3px;flex-shrink:0}.sp-card{background:var(--hrs-surface);border:1px solid var(--hrs-border);border-radius:12px;padding:14px;margin-bottom:12px;box-shadow:var(--hrs-shadow-sm)}.sp-card h3{font-family:Archivo,sans-serif;font-size:11px;font-weight:700;color:var(--hrs-muted);letter-spacing:.08em;text-transform:uppercase;margin:0 0 10px}.sp-stat{display:flex;align-items:baseline;justify-content:space-between;gap:8px;padding:6px 0}.sp-stat .lbl{font-size:12.5px;color:var(--hrs-text)}.sp-stat .val{font-family:Archivo,sans-serif;font-size:16px;font-weight:700;color:var(--hrs-secondary)}.sp-stat.row+.sp-stat.row{border-top:1px dashed var(--hrs-border)}.cap-row{display:flex;align-items:center;gap:8px;padding:5px 0;font-size:12px}.cap-row .name{flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:500;color:var(--hrs-text)}.cap-row .bar{width:90px;height:6px;background:var(--hrs-border);border-radius:999px;overflow:hidden}.cap-row .bar>div{height:100%;border-radius:999px}.cap-row .pct{width:36px;text-align:right;font-family:Archivo,sans-serif;font-size:11px;font-weight:700;color:var(--hrs-muted)}.legend{display:flex;flex-direction:column;gap:4px}.legend-item{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--hrs-text)}.legend-item .sw{width:14px;height:14px;border-radius:4px}.hbtn{font-family:Barlow,sans-serif;font-size:13px;font-weight:600;border-radius:8px;padding:6px 12px;border:1px solid transparent;cursor:pointer;display:inline-flex;align-items:center;gap:6px;transition:all .12s;white-space:nowrap}.hbtn-primary{background:var(--hrs-secondary);color:#fff;border-color:var(--hrs-secondary)}.hbtn-primary:hover{background:#002747}.hbtn-secondary{background:var(--hrs-primary);color:#fff;border-color:var(--hrs-primary)}.hbtn-secondary:hover{background:var(--hrs-primary-dark)}.hbtn-soft{background:var(--hrs-primary-light);color:var(--hrs-primary);border-color:#0061a133}.hbtn-soft:hover{background:var(--hrs-surface-light);border-color:var(--hrs-primary)}.hbtn-ghost{background:transparent;color:var(--hrs-primary)}.hbtn-ghost:hover{background:var(--hrs-primary-light)}.hbtn.sm{padding:4px 9px;font-size:12px}.modal-bg{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:300;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal{background:var(--hrs-surface);border-radius:14px;width:480px;max-width:90vw;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 16px 48px #00000040;overflow:hidden;font-family:Barlow,sans-serif}.modal-header{background:linear-gradient(135deg,#0061a1,#003559);color:#fff;padding:14px 20px;flex-shrink:0;display:flex;align-items:center;gap:10px}.modal-header h2{font-family:Archivo,sans-serif;font-size:15px;font-weight:700;margin:0;flex:1;letter-spacing:.01em}.modal-body{padding:18px 20px;display:flex;flex-direction:column;gap:14px;overflow-y:auto;flex:1;min-height:0}.modal-footer{padding:12px 20px;border-top:1px solid var(--hrs-border);flex-shrink:0;display:flex;gap:8px;justify-content:flex-end;background:var(--hrs-card)}.form-label{font-family:Archivo,sans-serif;font-size:11px;font-weight:700;color:var(--hrs-muted);letter-spacing:.06em;text-transform:uppercase;margin-bottom:5px;display:block}.hrs-input{width:100%;border:1px solid var(--hrs-border);border-radius:8px;padding:8px 11px;font-family:Barlow,sans-serif;font-size:13px;color:var(--hrs-text);background:var(--hrs-surface);outline:none}.hrs-input:focus{border-color:var(--hrs-primary);box-shadow:0 0 0 3px #0061a11f}.type-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}.type-grid button{border:1.5px solid var(--hrs-border);background:var(--hrs-surface);border-radius:8px;padding:7px;font-family:Barlow,sans-serif;font-size:12px;font-weight:600;color:var(--hrs-text);cursor:pointer;display:flex;align-items:center;gap:6px;justify-content:center;transition:all .12s}.type-grid button:hover{border-color:var(--hrs-primary)}.type-grid button.active{border-color:var(--type-color);background:var(--type-soft);color:var(--type-color)}.type-grid button .sw{width:12px;height:12px;border-radius:3px;background:var(--type-color)}.coord-grid{display:grid;grid-template-columns:1fr 1fr;gap:5px}.coord-grid button{display:flex;align-items:center;gap:8px;padding:7px 9px;border:1.5px solid var(--hrs-border);background:var(--hrs-surface);border-radius:8px;font-family:Barlow,sans-serif;font-size:12px;font-weight:500;color:var(--hrs-text);cursor:pointer;text-align:left;transition:all .12s;position:relative}.coord-grid button:hover{border-color:var(--c);background:color-mix(in srgb,var(--c) 8%,var(--hrs-surface))}.coord-grid button.active{background:var(--c);border-color:var(--c);color:#fff;box-shadow:0 2px 6px color-mix(in srgb,var(--c) 35%,transparent)}.coord-grid button .dot{width:10px;height:10px;border-radius:50%;background:var(--c);flex-shrink:0;box-shadow:0 0 0 1px #0000001a}.coord-grid button.active .dot{background:#fff;box-shadow:0 0 0 1.5px #ffffff80}.coord-grid button .nm{flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.coord-grid button .ini{font-family:Archivo,sans-serif;font-size:10px;font-weight:700;letter-spacing:.04em;color:var(--hrs-muted);background:var(--hrs-card);padding:1px 5px;border-radius:4px;flex-shrink:0}.coord-grid button.active .ini{background:#ffffff38;color:#fff}.tip{position:fixed;background:#1e293b;color:#fff;padding:8px 12px;border-radius:8px;font-size:12px;pointer-events:none;z-index:250;box-shadow:0 4px 16px #00000040;font-family:Barlow,sans-serif;max-width:240px;line-height:1.4}.tip strong{font-family:Archivo,sans-serif;font-weight:700}.tip .tip-meta{color:#ffffffb3;font-size:11px;margin-top:2px}.notif-panel{position:absolute;top:44px;right:16px;width:360px;background:var(--hrs-surface);border:1px solid var(--hrs-border);border-radius:12px;box-shadow:0 16px 32px #0000002e;z-index:100;overflow:hidden}.notif-panel .nph{padding:10px 14px;border-bottom:1px solid var(--hrs-border);font-family:Archivo,sans-serif;font-size:12px;font-weight:700;color:var(--hrs-secondary);letter-spacing:.06em;text-transform:uppercase;display:flex;align-items:center;justify-content:space-between}.notif-item{padding:11px 14px;display:flex;gap:10px;border-bottom:1px solid var(--hrs-border)}.notif-item:last-child{border-bottom:none}.notif-item .nidot{width:8px;height:8px;border-radius:50%;flex-shrink:0;margin-top:6px}.notif-item .ntext{font-size:12.5px;color:var(--hrs-text);line-height:1.4}.notif-item .nmeta{font-size:11px;color:var(--hrs-muted);margin-top:2px}.tl-body-scroll::-webkit-scrollbar,.sidepanel-inner::-webkit-scrollbar{width:10px;height:10px}.tl-body-scroll::-webkit-scrollbar-thumb,.sidepanel-inner::-webkit-scrollbar-thumb{background:var(--hrs-border-strong);border-radius:999px;border:2px solid var(--hrs-surface)}.tl-body-scroll::-webkit-scrollbar-thumb:hover{background:var(--hrs-muted)}.left-list .gh-spacer{height:1px}.zoom-toggle button{padding:5px 10px}.zoom-slider{display:flex;align-items:center;gap:4px;margin-left:6px}.zoom-slider input[type=range]{width:96px;accent-color:var(--hrs-primary);cursor:pointer}.zoom-slider .icon-btn:disabled{opacity:.4;cursor:default}.timeline.zoom-day{--day-w: 80px}.hour-row{display:flex;border-bottom:1px solid var(--hrs-border);height:18px}.hour-cell{flex-shrink:0;border-right:1px solid var(--hrs-border);display:flex;align-items:center;justify-content:center;font-family:Archivo,sans-serif;font-size:9.5px;font-weight:600;color:var(--hrs-muted)}.shrink-0{flex-shrink:0}.flex-1{flex:1}.no-select{-webkit-user-select:none;user-select:none}.emp-page-wrap{flex:1;min-height:0;overflow-y:auto;padding:20px;background:var(--hrs-bg)}.emp-table{background:var(--hrs-surface);border:1px solid var(--hrs-border);border-radius:12px;overflow:hidden;box-shadow:var(--hrs-shadow-sm);max-width:1280px;margin:0 auto}.emp-thead{display:grid;grid-template-columns:56px 1.8fr 90px 1.6fr 130px 150px 80px;background:var(--hrs-card);border-bottom:1px solid var(--hrs-border);align-items:center}.emp-th{font-family:Archivo,sans-serif;font-size:10.5px;font-weight:700;color:var(--hrs-muted);letter-spacing:.08em;text-transform:uppercase;padding:10px 14px}.emp-tr{display:grid;grid-template-columns:56px 1.8fr 90px 1.6fr 130px 150px 80px;align-items:center;border-bottom:1px solid var(--hrs-border);cursor:pointer;transition:background .1s}.emp-tr:hover{background:var(--hrs-card)}.emp-tr:last-child{border-bottom:none}.emp-td{padding:10px 14px;font-family:Barlow,sans-serif;font-size:13px;color:var(--hrs-text);min-width:0}.emp-td.avatar-col{padding:10px 8px 10px 14px}.emp-td.name-col .nm{font-family:Archivo,sans-serif;font-weight:600;font-size:13px;color:var(--hrs-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.emp-td.name-col .sub{font-size:10.5px;color:var(--hrs-muted);font-family:Archivo,sans-serif}.emp-td.role-col{color:var(--hrs-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ini-chip{display:inline-block;font-family:Archivo,sans-serif;font-size:10px;font-weight:700;letter-spacing:.04em;background:var(--hrs-card);border:1px solid var(--hrs-border);color:var(--hrs-text);padding:2px 7px;border-radius:5px}.dept-badge{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;border-radius:999px;font-family:Archivo,sans-serif;font-size:10.5px;font-weight:700;letter-spacing:.04em}.dept-badge.smithy{background:var(--hrs-surface-light);color:var(--hrs-primary)}.dept-badge.cnc{background:color-mix(in srgb,#475569 12%,var(--hrs-surface));color:#475569}html.dark .dept-badge.cnc{background:color-mix(in srgb,#94A3B8 18%,var(--hrs-surface));color:#cbd5e0}.coord-pill{display:inline-flex;align-items:center;gap:6px;padding:3px 9px 3px 4px;border-radius:999px;color:#fff;font-family:Archivo,sans-serif;font-size:10.5px;font-weight:700;letter-spacing:.04em}.coord-pill .dot{width:12px;height:12px;border-radius:50%;background:#fffffff5;border:2px solid rgba(0,0,0,.1)}.emp-td.actions-col{display:flex;gap:4px;justify-content:flex-end;padding:8px 14px}.emp-empty{padding:60px 20px;text-align:center;color:var(--hrs-muted)}.dept-strip{background:var(--hrs-surface);border-bottom:1px solid var(--hrs-border);padding:14px 20px 16px}.dept-strip-head{margin-bottom:10px}.dept-cards{display:flex;gap:10px;flex-wrap:wrap}.dept-card{display:flex;align-items:center;gap:12px;padding:10px 14px 10px 10px;background:var(--hrs-card);border:1.5px solid var(--hrs-border);border-radius:10px;cursor:pointer;min-width:220px;position:relative;transition:all .12s}.dept-card:hover{border-color:var(--c);box-shadow:0 2px 8px color-mix(in srgb,var(--c) 18%,transparent)}.dept-card-icon{width:40px;height:40px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.dept-card-body{flex:1;min-width:0}.dept-card-name{font-family:Archivo,sans-serif;font-weight:600;font-size:13px;color:var(--hrs-text)}.dept-card-meta{font-size:11px;color:var(--hrs-muted);margin-top:1px}.dept-card-edit{width:26px;height:26px;opacity:.6;transition:opacity .12s}.dept-card:hover .dept-card-edit{opacity:1}.dept-card-add{display:flex;align-items:center;gap:8px;padding:10px 18px;background:transparent;border:1.5px dashed var(--hrs-border-strong);border-radius:10px;cursor:pointer;font-family:Barlow,sans-serif;font-size:13px;font-weight:600;color:var(--hrs-muted);min-width:160px;transition:all .12s}.dept-card-add:hover{border-color:var(--hrs-primary);color:var(--hrs-primary);background:var(--hrs-primary-light)}.po-layout{display:grid;grid-template-columns:340px 1fr;gap:0;height:calc(100vh - 110px);background:var(--hrs-bg)}.po-sidebar{border-right:1px solid var(--hrs-border);background:var(--hrs-surface);display:flex;flex-direction:column;overflow:hidden}.po-filters{padding:12px;border-bottom:1px solid var(--hrs-border);display:flex;flex-direction:column;gap:8px;background:var(--hrs-card)}.po-search{display:flex;align-items:center;gap:6px;background:var(--hrs-surface);border:1px solid var(--hrs-border);border-radius:8px;padding:6px 9px;color:var(--hrs-muted)}.po-search input{border:none;outline:none;background:transparent;flex:1;font-family:Barlow,sans-serif;font-size:13px;color:var(--hrs-text)}.po-status-chips{display:flex;flex-wrap:wrap;gap:4px}.po-chip{font-family:Barlow,sans-serif;font-size:11px;font-weight:600;border:1px solid var(--hrs-border);background:var(--hrs-surface);color:var(--hrs-muted);border-radius:999px;padding:3px 9px;cursor:pointer;transition:all .12s}.po-chip:hover{border-color:var(--hrs-primary);color:var(--hrs-primary)}.po-chip.active{border-width:1.5px}.po-list{overflow-y:auto;flex:1;padding:6px}.po-list-item{border:1px solid var(--hrs-border);border-radius:10px;background:var(--hrs-surface);padding:9px 11px;margin-bottom:6px;cursor:pointer;transition:all .12s}.po-list-item:hover{border-color:var(--hrs-primary)}.po-list-item.active{border-color:var(--hrs-primary);background:var(--hrs-primary-light);box-shadow:inset 3px 0 0 var(--hrs-primary)}.po-list-row1{display:flex;align-items:center;justify-content:space-between;margin-bottom:3px}.po-num{font-family:Archivo,sans-serif;font-weight:700;font-size:13px;color:var(--hrs-secondary);letter-spacing:.01em}.po-list-title{font-size:13px;font-weight:500;color:var(--hrs-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:4px}.po-list-meta{font-size:11px;color:var(--hrs-muted);font-family:Barlow,sans-serif}.po-overdue{display:inline-flex;align-items:center;gap:4px;margin-left:6px;padding:1px 7px;border-radius:999px;background:#dc262618;color:#dc2626;font-weight:700}.po-empty{padding:24px 16px;color:var(--hrs-muted);text-align:center;font-size:13px}.po-detail{overflow-y:auto;padding:18px 22px;display:flex;flex-direction:column;gap:16px}.po-empty-detail{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:var(--hrs-muted);font-size:14px}.po-header{background:var(--hrs-surface);border:1px solid var(--hrs-border);border-radius:12px;padding:16px 18px}.po-header-top{display:flex;align-items:flex-start;gap:16px;margin-bottom:12px}.po-header-num{font-family:Archivo,sans-serif;font-size:22px;font-weight:700;color:var(--hrs-secondary);letter-spacing:.01em}.po-header-proj{font-size:13px;color:var(--hrs-muted);margin-top:2px}.po-header-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px 14px}.po-field{display:flex;flex-direction:column}.po-section{background:var(--hrs-surface);border:1px solid var(--hrs-border);border-radius:12px;overflow:hidden}.po-section-head{display:flex;align-items:center;gap:12px;padding:12px 16px;border-bottom:1px solid var(--hrs-border);background:var(--hrs-card)}.po-section-head h3{font-family:Archivo,sans-serif;font-size:13px;font-weight:700;margin:0;color:var(--hrs-text);letter-spacing:.02em;text-transform:uppercase}.po-section-stats{display:flex;gap:8px;font-size:12px;color:var(--hrs-muted)}.po-section-stats strong{color:var(--hrs-text)}.po-items{display:flex;flex-direction:column}.po-items-head{display:flex;gap:8px;padding:8px 14px;font-family:Archivo,sans-serif;font-size:10px;font-weight:700;color:var(--hrs-muted);letter-spacing:.06em;text-transform:uppercase;border-bottom:1px solid var(--hrs-border);background:var(--hrs-card)}.po-item-row{display:flex;gap:8px;align-items:center;padding:6px 14px;border-bottom:1px solid var(--hrs-border);font-size:13px;transition:background .12s}.po-item-row:hover{background:var(--hrs-primary-light)}.po-item-row.editing,.po-item-row.editing:hover{background:var(--hrs-card)}.po-item-row .mono{font-family:JetBrains Mono,Menlo,monospace;font-size:12px;color:var(--hrs-secondary)}.hrs-input.sm{padding:4px 7px;font-size:12px;width:100%}.sidepanel-inner.po-side{display:flex;flex-direction:column;height:100%;padding:0;gap:0}.po-side-head{padding:12px;border-bottom:1px solid var(--hrs-border);background:var(--hrs-card);display:flex;flex-direction:column;gap:8px}.po-side-head h3{font-family:Archivo,sans-serif;font-size:12px;font-weight:700;margin:0;color:var(--hrs-text);letter-spacing:.04em;text-transform:uppercase}.po-side-tabs{display:flex;gap:4px}.po-side-tabs button{flex:1;font-family:Barlow,sans-serif;font-size:11px;font-weight:600;background:var(--hrs-surface);color:var(--hrs-muted);border:1px solid var(--hrs-border);border-radius:6px;padding:4px 8px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:5px;transition:all .12s}.po-side-tabs button:hover{border-color:var(--hrs-primary);color:var(--hrs-primary)}.po-side-tabs button.active{background:var(--hrs-primary-light);color:var(--hrs-primary);border-color:var(--hrs-primary)}.po-side-badge{display:inline-block;background:var(--hrs-primary);color:#fff;font-size:10px;font-weight:700;border-radius:999px;padding:0 5px;min-width:14px;text-align:center}.po-side-search{display:flex;align-items:center;gap:6px;background:var(--hrs-surface);border:1px solid var(--hrs-border);border-radius:6px;padding:4px 8px;color:var(--hrs-muted)}.po-side-search input{flex:1;border:none;outline:none;background:transparent;font-family:Barlow,sans-serif;font-size:12px;color:var(--hrs-text)}.po-side-hint{font-size:11px;line-height:1.4;color:var(--hrs-muted);font-family:Barlow,sans-serif}.po-side-list{flex:1;overflow-y:auto;padding:6px}.po-side-empty{padding:24px 14px;color:var(--hrs-muted);text-align:center;font-size:12px}.po-side-card{background:var(--hrs-surface);border:1px solid var(--hrs-border);border-radius:8px;padding:7px 9px;margin-bottom:5px;cursor:grab;transition:all .12s}.po-side-card:hover{border-color:var(--hrs-primary);background:var(--hrs-primary-light)}.po-side-card:active{cursor:grabbing}.po-side-card-row1{display:flex;align-items:baseline;gap:6px;margin-bottom:2px}.po-side-num{font-family:JetBrains Mono,Menlo,monospace;font-size:11px;font-weight:700;color:var(--hrs-secondary)}.po-side-name{font-size:13px;font-weight:600;color:var(--hrs-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.po-side-card-row2{display:flex;gap:4px;align-items:center;font-size:11px;color:var(--hrs-muted);font-family:Barlow,sans-serif;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:4px}.po-side-card-row3{display:flex;gap:4px;align-items:center;flex-wrap:wrap}.po-side-pill{font-family:Barlow,sans-serif;font-size:10px;font-weight:600;background:var(--hrs-card);color:var(--hrs-text);border-radius:4px;padding:1px 6px;letter-spacing:.02em}.body-cells.po-drop-active{outline:2px dashed var(--hrs-primary);outline-offset:-3px;background-color:#0061a10d!important}.po-side-depts{display:flex;flex-wrap:wrap;gap:4px}.po-side-dept-chip{font-family:Barlow,sans-serif;font-size:10px;font-weight:600;background:var(--hrs-surface);color:var(--hrs-muted);border:1px solid var(--hrs-border);border-radius:999px;padding:2px 8px;cursor:pointer;transition:all .12s;letter-spacing:.02em}.po-side-dept-chip:hover{border-color:var(--hrs-primary);color:var(--hrs-primary)}.po-side-dept-chip.clear{color:var(--bt-vacation);border-color:var(--bt-vacation)}.po-grid{display:flex;flex-direction:column;font-family:Barlow,sans-serif;font-size:12px;overflow-x:auto}.po-grid-head{display:flex;gap:0;min-width:max-content;padding:6px 0;background:var(--hrs-card);border-bottom:1px solid var(--hrs-border);font-family:Archivo,sans-serif;font-size:10px;font-weight:700;color:var(--hrs-muted);letter-spacing:.05em;text-transform:uppercase}.po-grid-th{padding:2px 8px;border-right:1px solid transparent}.po-grid-th.po-grid-actions{width:130px;flex-shrink:0}.po-grid-td{display:flex;align-items:center;padding:4px 8px}.po-grid-row{display:flex;gap:0;min-width:max-content;border-bottom:1px solid var(--hrs-border);align-items:stretch;min-height:32px}.po-grid-row:hover{background:var(--hrs-primary-light)}.po-grid-row.po-grid-draft{background:#0061a10a}.po-grid-row.po-grid-draft:hover{background:#0061a112}.grid-cell-input{border:1px solid transparent;background:transparent;font-family:inherit;font-size:12px;color:var(--hrs-text);padding:5px 7px;outline:none;border-right:1px solid var(--hrs-border);-moz-appearance:none;appearance:none;-webkit-appearance:none;min-width:0}.grid-cell-input:hover{background:var(--hrs-surface)}.grid-cell-input:focus{background:var(--hrs-surface);border-color:var(--hrs-primary);box-shadow:inset 0 0 0 1px var(--hrs-primary);z-index:2;position:relative}.grid-cell-input::placeholder{color:var(--hrs-muted);opacity:.6}.grid-cell-input[type=number]::-webkit-outer-spin-button,.grid-cell-input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.grid-cell-input[type=number]{-moz-appearance:textfield}.po-grid-actions{width:130px;flex-shrink:0;display:flex;align-items:center;justify-content:flex-end;gap:4px;padding-right:8px}.hbtn-error{background:var(--bt-vacation);color:#fff;border-color:var(--bt-vacation)}.hbtn-error:hover{background:#b91c1c}.po-grid-hint{padding:12px 14px;font-size:12px;color:var(--hrs-muted);background:var(--hrs-primary-light);border-bottom:1px dashed var(--hrs-border)}.po-pdf-preview{display:flex;flex-direction:column}.po-pdf-row{display:flex;gap:6px;align-items:center;padding:5px 14px;border-bottom:1px solid var(--hrs-border)}.po-pdf-row.po-pdf-head{background:var(--hrs-card);font-family:Archivo,sans-serif;font-size:10px;font-weight:700;color:var(--hrs-muted);letter-spacing:.04em;text-transform:uppercase;padding:8px 14px}.po-spinner{display:inline-block;width:11px;height:11px;border:2px solid currentColor;border-top-color:transparent;border-radius:50%;animation:po-spin .7s linear infinite}@keyframes po-spin{to{transform:rotate(360deg)}}.po-pdf-group-head{display:flex;gap:8px;align-items:center;padding:8px 14px;background:var(--hrs-primary-light);border-top:1px solid var(--hrs-border);border-bottom:1px solid var(--hrs-border);font-family:Archivo,sans-serif}.po-pdf-group-head:first-child{border-top:none}.po-grid-pdf-cell{display:flex;align-items:center;justify-content:center;padding:2px}.po-pdf-icon-btn{background:transparent;border:1px solid var(--hrs-border);border-radius:6px;width:24px;height:24px;display:inline-flex;align-items:center;justify-content:center;color:var(--hrs-primary);cursor:pointer;transition:all .12s}.po-pdf-icon-btn:hover{background:var(--hrs-primary-light);border-color:var(--hrs-primary)}.po-pdf-thumb{background:var(--hrs-card);border:1px solid var(--hrs-border);border-radius:4px;width:70px;height:56px;padding:0;cursor:pointer;display:flex;align-items:center;justify-content:center;overflow:hidden;transition:all .12s}.po-pdf-thumb:hover{border-color:var(--hrs-primary);box-shadow:0 2px 6px #0061a126}.po-pdf-thumb iframe{width:100%;height:100%;border:0;pointer-events:none}.po-pdf-lightbox{background:var(--hrs-surface);border-radius:12px;width:90vw;height:90vh;max-width:1400px;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 20px 60px #0006}.po-pdf-lightbox-body{flex:1;background:#2d2d2d;position:relative}.po-pdf-lightbox-body iframe{width:100%;height:100%;border:0}.po-pdf-hover-preview{position:fixed;z-index:400;background:#fff;border:1px solid var(--hrs-border);border-radius:8px;box-shadow:0 12px 36px #001e3c59;overflow:hidden;display:flex;flex-direction:column;pointer-events:none;animation:po-hover-fade-in .12s ease-out}@keyframes po-hover-fade-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.po-pdf-hover-preview iframe{flex:1;width:100%;border:0;background:#f7f8fa}.po-pdf-hover-caption{background:var(--hrs-card);border-top:1px solid var(--hrs-border);padding:4px 10px;font-family:Barlow,sans-serif;font-size:11px;color:var(--hrs-muted);text-align:center}.po-jobs-panel{position:fixed;bottom:16px;right:16px;background:var(--hrs-surface);border:1px solid var(--hrs-border);border-radius:12px;box-shadow:0 10px 32px #001e3c40;width:360px;max-height:60vh;z-index:300;display:flex;flex-direction:column;overflow:hidden}.po-jobs-panel-head{padding:10px 14px;background:var(--hrs-card);border-bottom:1px solid var(--hrs-border);display:flex;gap:8px;align-items:center;font-family:Archivo,sans-serif;font-size:12px;font-weight:700;color:var(--hrs-text);letter-spacing:.03em;-webkit-user-select:none;user-select:none}.po-jobs-panel-body{overflow-y:auto;max-height:calc(60vh - 44px);padding:4px}.po-job{display:flex;gap:8px;align-items:center;padding:8px 10px;border-bottom:1px solid var(--hrs-border);font-family:Barlow,sans-serif}.po-job:last-child{border-bottom:none}.po-job-status{flex-shrink:0;width:18px;height:18px;display:inline-flex;align-items:center;justify-content:center}.po-job-body{flex:1;min-width:0}.po-job-name{font-size:12px;font-weight:600;color:var(--hrs-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.po-job-meta{font-size:11px;margin-top:1px}.po-grid-check{width:32px;flex-shrink:0;display:flex;align-items:center;justify-content:center}.po-grid-row.selected{background:#0061a114}.po-grid-bulkbar{display:flex;align-items:center;gap:8px;padding:6px 12px;background:var(--hrs-primary);color:#fff;font-family:Barlow,sans-serif;font-size:12px;border-bottom:1px solid var(--hrs-primary-dark)}.po-grid-bulkbar strong{font-weight:700}.po-grid-row.pending{background:linear-gradient(90deg,#0061a10a,#0061a11a,#0061a10a);background-size:200% 100%;animation:po-pending-shimmer 1.6s linear infinite}.po-grid-row.pending .grid-cell-input{font-style:italic}.po-grid-row.pending .grid-cell-input::placeholder{color:var(--hrs-primary);font-style:italic;font-weight:600}@keyframes po-pending-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.po-grid-row.errored{background:#dc26260f;border-left:3px solid var(--bt-vacation)}.po-grid-row.errored .grid-cell-input::placeholder{color:var(--bt-vacation);font-style:italic;font-weight:600}.po-grid-row.errored.pending{animation:none;background:#dc26260f}.po-side-card{-webkit-user-select:none;user-select:none}.po-side-card.selected{border-color:var(--hrs-primary);background:var(--hrs-primary-light);box-shadow:0 0 0 2px var(--hrs-primary-light),inset 3px 0 0 var(--hrs-primary)}.po-side-selbar{display:flex;align-items:center;gap:6px;padding:5px 8px;background:var(--hrs-primary-light);border:1px solid var(--hrs-primary);border-radius:6px;font-family:Barlow,sans-serif;font-size:11px;color:var(--hrs-primary)}.drop-preview-pill{position:absolute;border:2px dashed var(--hrs-primary);background:#0061a12e;border-radius:6px;font-family:Barlow,sans-serif;font-size:11px;font-weight:600;color:var(--hrs-primary);padding:2px 8px;display:flex;align-items:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;pointer-events:none;z-index:10;box-shadow:0 2px 8px #0061a126}.po-side-check{flex-shrink:0;width:15px;height:15px;cursor:pointer;accent-color:var(--hrs-primary);margin:0}.po-side-sort{display:flex;align-items:center;gap:6px;font-family:Barlow,sans-serif;font-size:11px;color:var(--hrs-muted)}.po-side-sort select{flex:1;border:1px solid var(--hrs-border);border-radius:6px;padding:3px 6px;font-family:Barlow,sans-serif;font-size:11px;background:var(--hrs-surface);color:var(--hrs-text);cursor:pointer}.conflict-options{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:10px;margin-top:12px}.conflict-option{display:flex;flex-direction:column;align-items:center;gap:4px;padding:12px 10px;border:1.5px solid var(--hrs-border);border-radius:10px;background:var(--hrs-surface);cursor:pointer;transition:all .12s;text-align:center}.conflict-option:hover{border-color:var(--hrs-primary);background:var(--hrs-primary-light)}.conflict-option svg{margin-bottom:2px}.conflict-option .co-title{font-family:Archivo,sans-serif;font-size:12.5px;font-weight:700;color:var(--hrs-text)}.conflict-option .co-desc{font-family:Barlow,sans-serif;font-size:11px;color:var(--hrs-muted);line-height:1.3}.push-ghost-pill{position:absolute;border:2px dashed;border-radius:6px;display:flex;align-items:center;padding:0 8px;font-size:11px;font-weight:600;pointer-events:none;z-index:9;overflow:hidden;opacity:.9}.push-ghost-pill .pgp-ttl{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
