:root{--bg-primary:#f8fafc;--bg-secondary:#fff;--bg-tertiary:#f1f5f9;--text-primary:#0f172a;--text-secondary:#475569;--text-tertiary:#94a3b8;--accent:#6366f1;--accent-hover:#4f46e5;--accent-light:#e0e7ff;--border-color:#e2e8f0;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -2px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -4px #0000001a;--font-family:"Outfit", "Inter", system-ui, -apple-system, sans-serif;--radius-sm:6px;--radius-md:12px;--radius-lg:18px;font-family:var(--font-family);background:var(--bg-primary);color:var(--text-primary);box-sizing:border-box;letter-spacing:-.01em;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0;padding:0;font-size:16px;line-height:1.5}@media (prefers-color-scheme:dark){:root{--bg-primary:#0b0f19;--bg-secondary:#151f32;--bg-tertiary:#1e293b;--text-primary:#f8fafc;--text-secondary:#94a3b8;--text-tertiary:#64748b;--accent:#818cf8;--accent-hover:#6366f1;--accent-light:#6366f126;--border-color:#24334c;--shadow-sm:0 1px 2px 0 #00000080;--shadow-md:0 4px 6px -1px #00000080;--shadow-lg:0 10px 15px -3px #00000080}}*{box-sizing:border-box}body{background-color:var(--bg-primary);color:var(--text-primary);min-height:100vh;margin:0;padding:0}#root{flex-direction:column;width:100%;max-width:100%;min-height:100vh;margin:0;padding:0;display:flex}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}.leader-page-nav{gap:6px;margin-bottom:6px;display:flex}.leader-page-nav-btn{border:1px solid var(--border-color);border-radius:var(--radius-sm);background:var(--bg-primary);color:var(--text-secondary);cursor:pointer;flex:1;padding:8px 10px;font-size:12px;font-weight:700;transition:background .15s,border-color .15s,color .15s}.leader-page-nav-btn:hover{border-color:var(--accent);color:var(--accent)}.leader-page-nav-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}.dashboard-container{background:var(--bg-primary);height:100vh;display:flex;overflow:hidden}.sidebar{background:var(--bg-secondary);border-right:1px solid var(--border-color);width:320px;min-width:280px;height:100vh;box-shadow:var(--shadow-sm);flex-direction:column;display:flex;overflow:hidden}.sidebar-header{border-bottom:1px solid var(--border-color);padding:14px 16px}.sidebar-title{color:var(--text-primary);margin:0 0 2px;font-family:Outfit,sans-serif;font-size:16px;font-weight:700}.sidebar-subtitle{color:var(--text-tertiary);margin:0;font-size:11px}.user-panel{border-radius:var(--radius-sm);background:var(--bg-tertiary);border:1px solid var(--border-color);margin:8px 12px;padding:8px 10px}.user-panel-top{justify-content:space-between;align-items:center;gap:8px;margin-bottom:3px;display:flex}.user-panel-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;min-width:0;font-size:13px;font-weight:700;overflow:hidden}.user-panel-meta{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;font-size:11px;line-height:1.35;overflow:hidden}.user-panel-badge{background:var(--accent-light);color:var(--accent);border-radius:8px;flex-shrink:0;padding:2px 6px;font-size:10px;font-weight:700}.sidebar-actions{gap:8px;padding:0 16px 12px;display:flex}.sidebar-btn{border:1px solid var(--border-color);border-radius:var(--radius-sm);background:var(--bg-secondary);color:var(--text-secondary);cursor:pointer;flex:1;padding:8px 12px;font-size:13px;font-weight:600;transition:background .15s,border-color .15s,color .15s}.sidebar-btn:hover:not(:disabled){background:var(--bg-tertiary);color:var(--text-primary)}.sidebar-btn.primary{background:var(--accent);border-color:var(--accent);color:#fff}.sidebar-btn.primary:hover:not(:disabled){background:var(--accent-hover);border-color:var(--accent-hover)}.sidebar-btn:disabled{opacity:.55;cursor:not-allowed}.search-box{padding:0 16px 12px}.search-input{border:1px solid var(--border-color);border-radius:var(--radius-sm);background:var(--bg-primary);width:100%;color:var(--text-primary);padding:10px 12px;font-size:13px}.search-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-light);outline:none}.filter-tabs{flex-wrap:wrap;gap:6px;padding:0 16px 12px;display:flex}.filter-tab{border:1px solid var(--border-color);background:var(--bg-primary);color:var(--text-secondary);cursor:pointer;white-space:nowrap;border-radius:999px;padding:5px 10px;font-size:11px;font-weight:600;transition:all .15s}.filter-tab:hover{border-color:var(--accent);color:var(--accent)}.filter-tab.active{background:var(--accent);border-color:var(--accent);color:#fff}.employee-list{flex:1;padding:0 8px 16px;overflow-y:auto}.dept-group{margin-bottom:12px}.dept-group-title{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.04em;padding:6px 8px;font-size:11px;font-weight:700}.employee-item{border-radius:var(--radius-sm);text-align:left;cursor:pointer;background:0 0;border:1px solid #0000;border-left-width:3px;justify-content:space-between;align-items:center;gap:8px;width:100%;margin-bottom:4px;padding:10px 12px;transition:background .15s,border-color .15s;display:flex}.employee-item.status-empty{border-left-color:#f97316}.employee-item.status-draft{border-left-color:#eab308}.employee-item.status-saved{border-left-color:#10b981}.employee-item.status-excluded{border-left-color:#8b5cf6}.employee-item:hover{background:var(--bg-tertiary)}.employee-item.selected{background:var(--accent-light);border-color:var(--accent)}.employee-item-left{flex:1;min-width:0}.employee-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:600;overflow:hidden}.employee-meta{color:var(--text-tertiary);margin-top:2px;font-size:11px}.employee-item-right{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:4px;display:flex}.interview-status{white-space:nowrap;border:1px solid #0000;border-radius:10px;padding:4px 9px;font-size:10px;font-weight:700}.interview-status.empty{color:#c2410c;background-color:#fff7ed;border-color:#fdba74}.interview-status.draft{color:#a16207;background-color:#fef9c3;border-color:#fde047}.interview-status.saved{color:#047857;background-color:#d1fae5;border-color:#6ee7b7}.interview-status.excluded{color:#6d28d9;background-color:#ede9fe;border-color:#c4b5fd}@media (prefers-color-scheme:dark){.interview-status.empty{color:#fb923c;background-color:#f9731633;border-color:#fb923c73}.interview-status.draft{color:#facc15;background-color:#eab30833;border-color:#facc1573}.interview-status.saved{color:#34d399;background-color:#10b98133;border-color:#34d39973}.interview-status.excluded{color:#a78bfa;background-color:#8b5cf633;border-color:#a78bfa73}}.main-content{flex-direction:column;flex:1;gap:16px;min-width:0;height:100vh;padding:24px;display:flex;overflow:hidden}.interview-summary-bar{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);flex-shrink:0;padding:20px 24px}.form-panel{flex:1;min-height:0;padding-right:4px;overflow-y:auto}.summary-header{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:16px;display:flex}.summary-title{color:var(--text-primary);margin:0;font-family:Outfit,sans-serif;font-size:20px;font-weight:700}.summary-total{color:var(--text-secondary);white-space:nowrap;font-size:13px;font-weight:600}.summary-badges{flex-wrap:wrap;gap:8px;margin-top:8px;display:flex}.db-badge{border-radius:999px;align-items:center;padding:4px 10px;font-size:11px;font-weight:600;display:inline-flex}.db-badge.error{color:#b91c1c;background:#fef2f2}.db-badge.loading{background:var(--accent-light);color:var(--accent)}.summary-stats{grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:12px;display:grid}.summary-stat{border-radius:var(--radius-md);background:var(--bg-tertiary);border:1px solid var(--border-color);padding:12px 14px}.summary-stat.stat-empty{background:#fff7ed;border-color:#fdba74}.summary-stat.stat-draft{background:#fefce8;border-color:#fde047}.summary-stat.stat-saved{background:#ecfdf5;border-color:#6ee7b7}.summary-stat.stat-excluded{background:#f5f3ff;border-color:#c4b5fd}.summary-stat-label{color:var(--text-tertiary);margin-bottom:4px;font-size:11px;font-weight:600}.summary-stat-value{color:var(--text-primary);font-size:22px;font-weight:700}.summary-stat.stat-empty .summary-stat-value{color:#c2410c}.summary-stat.stat-draft .summary-stat-value{color:#a16207}.summary-stat.stat-saved .summary-stat-value{color:#047857}.summary-stat.stat-excluded .summary-stat-value{color:#6d28d9}.summary-stat-value.accent{color:var(--accent)}.form-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:24px}.form-card-header{border-bottom:1px solid var(--border-color);margin-bottom:20px;padding-bottom:16px}.form-card-title-row{flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:4px;display:flex}.form-card-title{margin:0;font-family:Outfit,sans-serif;font-size:18px;font-weight:700}.form-card-subtitle{color:var(--text-secondary);margin:0;font-size:13px}.form-grid{grid-template-columns:repeat(2,1fr);gap:16px;margin-bottom:16px;display:grid}.form-field{flex-direction:column;gap:6px;display:flex}.form-field.full{grid-column:1/-1}.form-label-row{justify-content:space-between;align-items:center;gap:8px;display:flex}.form-label{color:var(--text-secondary);font-size:13px;font-weight:600}.form-copy-btn{border:1px solid var(--border-color);border-radius:var(--radius-sm);background:var(--bg-primary);color:var(--text-secondary);cursor:pointer;flex-shrink:0;padding:2px 8px;font-size:11px;font-weight:600;transition:background .15s,color .15s,border-color .15s}.form-copy-btn:hover:not(:disabled){background:var(--accent-light);border-color:var(--accent);color:var(--accent)}.form-copy-btn:disabled{opacity:.4;cursor:not-allowed}.form-copy-btn.copied{background:var(--accent-light);border-color:var(--accent);color:var(--accent)}.form-input,.form-textarea,.form-select{border:1px solid var(--border-color);border-radius:var(--radius-sm);background:var(--bg-primary);width:100%;color:var(--text-primary);padding:10px 12px;font-family:inherit;font-size:14px}.form-textarea{resize:vertical;min-height:100px;line-height:1.6}.form-input:focus,.form-textarea:focus,.form-select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-light);outline:none}.form-actions{flex-wrap:wrap;gap:10px;margin-top:8px;display:flex}.form-btn{border:1px solid var(--border-color);border-radius:var(--radius-sm);background:var(--bg-secondary);color:var(--text-secondary);cursor:pointer;padding:10px 18px;font-size:14px;font-weight:600;transition:background .15s,border-color .15s,color .15s}.form-btn:hover:not(:disabled){background:var(--bg-tertiary);color:var(--text-primary)}.form-btn.draft{color:#b45309;background:#fef3c7;border-color:#fde68a}.form-btn.reset{color:#475569;background:#fff;border-color:#cbd5e1}.form-btn.reset:hover:not(:disabled){color:#334155;background:#f8fafc;border-color:#94a3b8}.form-btn.exclude{color:#6b7280;background:#f9fafb;border-color:#e5e7eb}.form-btn.save{background:var(--accent);border-color:var(--accent);color:#fff}.form-btn.save:hover:not(:disabled){background:var(--accent-hover);border-color:var(--accent-hover)}.form-btn:disabled{opacity:.55;cursor:not-allowed}.empty-state{text-align:center;background:var(--bg-secondary);border:1px dashed var(--border-color);border-radius:var(--radius-lg);color:var(--text-secondary);flex-direction:column;flex:1;justify-content:center;align-items:center;padding:48px 24px;display:flex}.empty-state-icon{margin-bottom:12px;font-size:40px}.empty-state-title{color:var(--text-primary);margin:0 0 8px;font-size:16px;font-weight:700}.empty-state-text{margin:0;font-size:14px;line-height:1.6}.loading-overlay{text-align:center;color:var(--text-secondary);padding:24px;font-size:14px}.sidebar-empty{text-align:center;color:var(--text-tertiary);padding:24px 16px;font-size:13px}@media (width<=900px){.dashboard-container{flex-direction:column;height:auto;min-height:100vh;overflow:visible}.sidebar{width:100%;height:auto;max-height:45vh}.main-content{height:auto;min-height:60vh;overflow:visible}.form-panel{overflow:visible}.form-grid{grid-template-columns:1fr}}.shift-assignment-card{overflow:auto}.shift-save-btn{border-radius:var(--radius-sm);color:#4338ca;cursor:pointer;background:#eef2ff;border:1px solid #6366f1;padding:10px 16px;font-size:13px;font-weight:700;transition:background .15s,border-color .15s}.shift-save-btn:hover:not(:disabled){background:#e0e7ff;border-color:#4f46e5}.shift-save-btn:disabled{opacity:.55;cursor:not-allowed}.shift-status-message{border-radius:var(--radius-sm);margin-bottom:12px;padding:10px 12px;font-size:13px;font-weight:600}.shift-status-message.success{color:#047857;background:#ecfdf5;border:1px solid #6ee7b7}.shift-status-message.error{color:#b91c1c;background:#fef2f2;border:1px solid #fecaca}.shift-status-message.picker{margin-top:0}.shift-picker-panel-header{justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px;display:flex}.shift-picker-panel-header .shift-picker-section-title{margin:0}.shift-assignment-layout.vertical{flex-direction:column;gap:16px;display:flex}.shift-standard-section,.shift-standing-section,.shift-member-picker-panel.bottom{border-radius:var(--radius-md);border:1px solid var(--border-color);background:var(--bg-secondary);padding:16px}.shift-section-header{justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:12px;display:flex}.shift-section-header .shift-section-title{margin:0 0 4px}.shift-section-header .shift-section-desc{margin:0}.shift-member-label{flex-flow:wrap;align-items:baseline;gap:6px;min-width:0;line-height:1.25;display:inline-flex}.shift-member-name{color:var(--text-primary);letter-spacing:-.01em;font-size:13px;font-weight:800}.shift-member-grade{color:var(--text-secondary);font-size:12px;font-weight:600}.shift-member-empty{color:var(--text-tertiary);font-size:12px;font-weight:500}.shift-matrix-cell .shift-member-label{flex:1;min-width:0}.shift-matrix-cell .shift-member-name,.shift-standing-summary-item .shift-member-name,.shift-member-pick-btn .shift-member-name{color:var(--text-primary);font-size:13px;font-weight:800}.shift-matrix-cell .shift-member-grade,.shift-standing-summary-item .shift-member-grade,.shift-member-pick-btn .shift-member-grade{color:var(--text-secondary);font-size:12px;font-weight:600}.shift-matrix-cell-td.empty .shift-member-empty{color:var(--text-tertiary)}.shift-member-pick-btn .shift-member-label{align-items:flex-start}.shift-member-pick-btn.selected .shift-member-name,.shift-member-pick-btn.selected .shift-member-grade{color:#fff}.shift-member-pick-btn.selected .shift-member-grade{opacity:.9}.shift-section-title{color:var(--text-primary);margin:0 0 8px;font-size:15px;font-weight:700}.shift-section-desc{color:var(--text-tertiary);margin:0 0 12px;font-size:12px}.shift-matrix-wrap{border-radius:var(--radius-sm);background:#fff;border:1px solid #c7d2fe;overflow-x:auto}.shift-matrix{border-collapse:collapse;table-layout:fixed;width:100%;min-width:720px}.shift-matrix th,.shift-matrix td{vertical-align:middle;border:1px solid #dbeafe;padding:10px 8px;font-size:12px}.shift-matrix thead th{color:#4338ca;text-align:center;background:#eef2ff;font-weight:800}.shift-matrix-role-col{width:96px}.shift-matrix-shift-col{min-width:120px}.shift-matrix-role-label{color:#4338ca;text-align:left;white-space:nowrap;background:#f8fafc;font-weight:800}.shift-matrix-cell-td{background:#fff;padding:0}.shift-matrix-cell-td.empty{background:var(--bg-tertiary)}.shift-matrix-cell{justify-content:space-between;align-items:center;gap:6px;min-height:40px;padding:10px 8px;display:flex}.shift-matrix-cell-td.empty .shift-matrix-member{color:var(--text-tertiary);font-weight:500}.shift-matrix-member{min-width:0;color:var(--text-primary);word-break:keep-all;flex:1;font-weight:600;line-height:1.35}.shift-group-row,.shift-standing-role-row{flex-direction:row;gap:12px;padding-bottom:4px;display:flex;overflow-x:auto}.shift-standing-role-block{border-radius:var(--radius-sm);cursor:pointer;background:#fff;border:1px solid #c7d2fe;flex:1 0 220px;min-width:220px;padding:12px;transition:border-color .15s,background .15s,box-shadow .15s}.shift-standing-role-block:hover:not(.skeleton){background:#f8faff;border-color:#818cf8}.shift-standing-role-block.selected{background:#eef2ff;border-color:#4338ca;box-shadow:inset 0 0 0 1px #4338ca}.shift-standing-role-block:focus-visible{outline-offset:2px;outline:2px solid #6366f1}.shift-standing-summary-item{border-radius:var(--radius-sm);background:#eef2ff;border:1px solid #c7d2fe;justify-content:space-between;align-items:center;gap:8px;padding:7px 10px;display:flex}.shift-standing-summary-item .shift-member-label{flex:1;min-width:0}.shift-standing-role-header{justify-content:space-between;align-items:center;gap:8px;margin-bottom:10px;display:flex}.shift-standing-role-header .shift-standing-role-title{margin:0}.shift-standing-selected-count{color:#4338ca;background:#eef2ff;border:1px solid #c7d2fe;border-radius:999px;flex-shrink:0;padding:2px 8px;font-size:11px;font-weight:700}.shift-standing-checkbox-list{flex-direction:column;gap:6px;max-height:240px;padding-right:2px;display:flex;overflow-y:auto}.shift-standing-checkbox-empty{border-radius:var(--radius-sm);background:var(--bg-tertiary);color:var(--text-tertiary);margin:0;padding:8px 10px;font-size:12px}.shift-standing-checkbox-item{border-radius:var(--radius-sm);cursor:pointer;background:#f8fafc;border:1px solid #dbeafe;align-items:center;gap:8px;padding:7px 10px;transition:background .15s,border-color .15s;display:flex}.shift-standing-checkbox-item:hover{background:#eef2ff;border-color:#c7d2fe}.shift-standing-checkbox-item.checked{background:#eef2ff;border-color:#818cf8}.shift-standing-checkbox-input{accent-color:#4338ca;cursor:pointer;flex-shrink:0;width:15px;height:15px}.shift-standing-checkbox-item .shift-member-label{flex:1;min-width:0}.shift-standing-role-block.skeleton{background:var(--bg-tertiary);min-height:120px}.shift-group-title,.shift-standing-role-title{color:#4338ca;margin:0 0 10px;font-size:14px;font-weight:800}.shift-member-summary-list{flex-direction:column;gap:6px;margin:0;padding:0;list-style:none;display:flex}.shift-member-summary-item{border-radius:var(--radius-sm);color:var(--text-primary);background:#eef2ff;border:1px solid #c7d2fe;align-items:center;gap:8px;padding:7px 10px;font-size:12px;font-weight:600;display:flex}.shift-member-summary-item.empty{background:var(--bg-tertiary);border-color:var(--border-color);color:var(--text-tertiary);font-weight:500}.shift-roster-role{color:#4338ca;flex-shrink:0;min-width:64px;font-size:11px;font-weight:800}.shift-roster-member{flex:1;min-width:0;font-size:11px;line-height:1.35}.shift-member-remove-btn.inline{margin-left:auto}.shift-standing-member-item{border-radius:var(--radius-sm);color:var(--text-primary);background:#eef2ff;border:1px solid #c7d2fe;justify-content:space-between;align-items:center;gap:8px;padding:7px 10px;font-size:11px;font-weight:600;display:flex}.shift-member-remove-btn{color:#4338ca;cursor:pointer;background:#fff;border:1px solid #c7d2fe;border-radius:999px;flex-shrink:0;width:22px;height:22px;font-size:14px;line-height:1}.shift-member-remove-btn:hover:not(:disabled){color:#b91c1c;background:#fef2f2;border-color:#fecaca}.shift-member-remove-btn:disabled{opacity:.5;cursor:not-allowed}.shift-picker-section-title{color:var(--text-primary);margin:0 0 12px;font-size:15px;font-weight:700}.shift-picker-blocks{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-bottom:12px;display:grid}.shift-picker-block{border-radius:var(--radius-sm);background:#fff;border:1px solid #c7d2fe;padding:12px}.shift-picker-title{color:#4338ca;margin:0 0 10px;font-size:13px;font-weight:800}.shift-tab-list{flex-wrap:wrap;gap:8px;margin-bottom:10px;display:flex}.shift-tab-list.compact{margin-bottom:10px}.shift-tab{border-radius:var(--radius-sm);color:#4338ca;cursor:pointer;background:#fff;border:1px solid #c7d2fe;min-width:48px;padding:7px 10px;font-size:12px;font-weight:700}.shift-tab.selected{color:#fff;background:#4338ca;border-color:#4338ca}.shift-picker-controls{flex-wrap:wrap;align-items:flex-end;gap:8px;display:flex}.shift-role-field.inline{flex:1;min-width:140px}.shift-role-field{flex-direction:column;gap:6px;display:flex}.shift-role-label{color:var(--text-secondary);font-size:12px;font-weight:700}.shift-role-select{border:1px solid var(--border-color);border-radius:var(--radius-sm);width:100%;color:var(--text-primary);background:#fff;padding:9px 10px;font-size:13px}.shift-member-picker-list.horizontal{flex-wrap:wrap;gap:8px;max-height:220px;padding:2px;display:flex;overflow-y:auto}.shift-member-pick-btn{border:1px solid var(--border-color);border-radius:var(--radius-sm);background:var(--bg-secondary);color:var(--text-primary);text-align:left;cursor:pointer;padding:8px 10px;font-size:12px;font-weight:600}.shift-member-pick-btn:hover:not(:disabled){background:#eef2ff;border-color:#c7d2fe}.shift-member-pick-btn.selected{color:#fff;background:#4338ca;border-color:#4338ca}.shift-member-pick-btn.taken:not(.selected){opacity:.55}.shift-add-member-btn{border-radius:var(--radius-sm);color:#4338ca;cursor:pointer;background:#eef2ff;border:1px solid #6366f1;flex-shrink:0;padding:9px 12px;font-size:12px;font-weight:700}.shift-add-member-btn:hover:not(:disabled){background:#e0e7ff}.shift-add-member-btn.remove{color:#b91c1c;background:#fef2f2;border-color:#fecaca}.shift-add-member-btn.remove:hover:not(:disabled){background:#fee2e2;border-color:#fca5a5}.shift-add-member-btn:disabled,.shift-role-select:disabled,.shift-tab:disabled,.shift-member-pick-btn:disabled{opacity:.65;cursor:not-allowed}.shift-loading{text-align:center;color:var(--text-tertiary);padding:16px;font-size:13px}.shift-menu-item.selected{background:#eef2ff;border-color:#6366f1}@media (width<=960px){.shift-picker-blocks{grid-template-columns:1fr}.shift-group-block,.shift-standing-role-block{flex-basis:200px;min-width:200px}}.dept-tree-list{flex:1;padding:0 8px 16px;overflow-y:auto}.dept-tree-item{border-radius:var(--radius-sm);text-align:left;cursor:pointer;background:0 0;border:1px solid #0000;justify-content:space-between;align-items:center;gap:8px;width:100%;margin-bottom:4px;padding:9px 12px;transition:background .15s,border-color .15s;display:flex}.dept-tree-item:hover{background:var(--bg-tertiary)}.dept-tree-item.selected{background:var(--accent-light);border-color:var(--accent)}.dept-tree-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;min-width:0;font-size:13px;font-weight:600;overflow:hidden}.dept-tree-count{color:var(--text-tertiary);flex-shrink:0;font-size:11px;font-weight:700}.dept-tree-item.selected .dept-tree-count{color:var(--accent)}.dept-summary-bar{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);flex-shrink:0;padding:16px 20px}.dept-summary-row{align-items:stretch;gap:12px;display:flex;overflow-x:auto}.dept-summary-title-inline{color:var(--text-primary);white-space:nowrap;flex-shrink:0;align-items:center;margin:0;padding-right:6px;font-family:Outfit,sans-serif;font-size:18px;font-weight:800;display:flex}.dept-summary-stat{border-radius:var(--radius-md);background:var(--bg-secondary);border:1px solid var(--border-color);min-width:116px;box-shadow:var(--shadow-sm);flex:1;padding:14px 16px}.dept-age-stat-count{color:var(--text-secondary);margin-top:4px;font-size:12px;font-weight:700}.dept-summary-stat-label{color:var(--text-secondary);white-space:nowrap;letter-spacing:-.01em;margin-bottom:6px;font-size:13px;font-weight:700}.dept-summary-stat-value{color:var(--text-primary);white-space:nowrap;font-size:18px;font-weight:600;line-height:1.4}.dept-member-breakdown-stat{flex:1.4;min-width:168px}.dept-member-breakdown-list{flex-direction:column;gap:5px;display:flex}.dept-member-breakdown-item{justify-content:space-between;align-items:center;gap:8px;font-size:14px;line-height:1.35;display:flex}.dept-member-breakdown-name{min-width:0;color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;font-weight:700;overflow:hidden}.dept-member-breakdown-name.root-team{color:var(--text-primary)}.dept-member-breakdown-count{color:var(--text-primary);flex-shrink:0;font-size:15px;font-weight:600}.dept-detail-panel{flex:1;min-height:0;padding-right:4px;overflow-y:auto}.dept-detail-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:24px}.dept-detail-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:20px;padding-bottom:16px;display:flex}.dept-detail-title{margin:0 0 4px;font-family:Outfit,sans-serif;font-size:18px;font-weight:700}.dept-detail-subtitle{color:var(--text-secondary);margin:0;font-size:13px}.dept-detail-badge{background:var(--accent-light);color:var(--accent);border-radius:999px;flex-shrink:0;padding:4px 10px;font-size:11px;font-weight:700}.dept-child-list{flex-wrap:wrap;gap:8px;margin-bottom:20px;display:flex}.dept-child-chip{border:1px solid var(--border-color);background:var(--bg-tertiary);color:var(--text-secondary);border-radius:999px;padding:6px 10px;font-size:12px;font-weight:600}.dept-member-table{border-collapse:collapse;width:100%}.dept-member-table th,.dept-member-table td{text-align:left;border-bottom:1px solid var(--border-color);padding:10px 12px;font-size:13px}.dept-member-table th{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.04em;font-size:11px;font-weight:700}.dept-member-table tbody tr:hover{background:var(--bg-tertiary)}.dept-member-table .dept-member-duty{min-width:160px;max-width:320px;color:var(--text-secondary);word-break:keep-all;line-height:1.45}.tenure-menu-item{border:1px solid var(--border-color);background:var(--bg-primary);gap:6px;margin-bottom:0}.tenure-menu-chevron{width:20px;height:20px;color:var(--accent);background:var(--accent-light);border:1px solid var(--accent);text-align:center;border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;font-size:13px;font-weight:800;line-height:1;display:inline-flex}.tenure-menu-item.expanded .tenure-menu-chevron{color:#fff;background:var(--accent)}.tenure-sidebar-section{border-top:1px solid var(--border-color);margin-top:12px;padding-top:12px}.tenure-employee-list{border-left:2px solid var(--border-color);margin-top:4px;margin-left:10px;padding-left:10px}.tenure-menu-item.expanded,.tenure-menu-item.selected{background:var(--accent-light);border-color:var(--accent)}.tenure-employee-item{border-left:3px solid #0000;align-items:flex-start}.tenure-employee-item.category-contract{border-left-color:#2563eb}.tenure-employee-item.category-dispatch{border-left-color:#7c3aed}.tenure-employee-item.category-unknown{border-left-color:#9ca3af}.tenure-employee-left{flex:1;min-width:0}.tenure-employee-top{align-items:center;gap:6px;min-width:0;display:flex}.tenure-category-badge{letter-spacing:-.01em;white-space:nowrap;border:1px solid #0000;border-radius:999px;flex-shrink:0;padding:2px 7px;font-size:10px;font-weight:800}.tenure-category-badge.contract{color:#1d4ed8;background:#dbeafe;border-color:#93c5fd}.tenure-category-badge.dispatch{color:#6d28d9;background:#ede9fe;border-color:#c4b5fd}.tenure-category-badge.unknown{color:#6b7280;background:#f3f4f6;border-color:#e5e7eb}.tenure-employee-top .dept-tree-name{min-width:0}.tenure-employee-meta{color:var(--text-tertiary);margin-top:4px;padding-left:2px;font-size:11px;font-weight:600}.tenure-status-badge{white-space:nowrap;border:1px solid #0000;border-radius:999px;flex-shrink:0;padding:4px 8px;font-size:10px;font-weight:700}.tenure-status-badge.compact{padding:3px 7px;font-size:9px}.tenure-status-badge.active{color:#047857;background:#ecfdf5;border-color:#6ee7b7}.tenure-status-badge.department{text-overflow:ellipsis;background:var(--bg-tertiary);max-width:92px;color:var(--text-secondary);border-color:var(--border-color);overflow:hidden}.tenure-status-badge.reminder{color:#c2410c;background:#fff7ed;border-color:#fdba74}.tenure-status-badge.expired{color:#b91c1c;background:#fef2f2;border-color:#fecaca}.tenure-status-badge.unknown{color:#6b7280;background:#f3f4f6;border-color:#e5e7eb}.tenure-summary-alert{border-radius:var(--radius-md);color:#9a3412;background:#fff7ed;border:1px solid #fdba74;margin-bottom:12px;padding:12px 14px;font-size:13px;font-weight:600}.tenure-detail-card .tenure-alert{border-radius:var(--radius-md);color:#9a3412;background:#fff7ed;border:1px solid #fdba74;margin-bottom:16px;padding:12px 14px;font-size:13px;line-height:1.5}.tenure-info-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-bottom:24px;display:grid}.tenure-info-item{border-radius:var(--radius-md);background:var(--bg-secondary);border:1px solid var(--border-color);box-shadow:var(--shadow-sm);padding:16px 18px}.tenure-info-label{color:var(--text-secondary);letter-spacing:-.01em;margin-bottom:8px;font-size:13px;font-weight:700;display:block}.tenure-info-label-note{color:var(--accent);margin-left:4px;font-size:12px;font-weight:600}.tenure-info-value{color:var(--text-primary);word-break:keep-all;font-size:18px;font-weight:600;line-height:1.4}.tenure-info-value.days-reminder{color:#c2410c}.tenure-info-value.days-expired{color:#b91c1c}.tenure-info-value.days-active{color:#047857}.tenure-info-value.days-unknown{color:var(--text-secondary)}.tenure-action-group{border-top:1px solid var(--border-color);padding-top:16px}.tenure-action-title{color:var(--text-primary);margin:0 0 10px;font-size:14px;font-weight:700}.tenure-action-buttons{flex-wrap:wrap;gap:8px;display:flex}.tenure-action-btn{border:1px solid var(--border-color);border-radius:var(--radius-sm);background:var(--bg-secondary);color:var(--text-secondary);cursor:pointer;padding:10px 14px;font-size:13px;font-weight:600;transition:background .15s,border-color .15s,color .15s}.tenure-action-btn:hover:not(:disabled){background:var(--bg-tertiary);color:var(--text-primary)}.tenure-action-btn.calendar{color:#1d4ed8;background:#eff6ff;border-color:#93c5fd}.tenure-action-btn.email{color:#047857;background:#ecfdf5;border-color:#6ee7b7}.tenure-action-btn:disabled{opacity:.5;cursor:not-allowed}.tenure-action-note{color:var(--text-tertiary);margin:10px 0 0;font-size:12px;line-height:1.5}.retirement-menu-item{margin-top:4px}.tenure-overview-card{overflow:auto}.tenure-overview-badge{color:#1d4ed8;background:#eff6ff;border:1px solid #93c5fd}.tenure-detail-card-nested{border-top:1px solid var(--border-color);box-shadow:none;margin-top:16px;padding-top:20px}.tenure-month-selection{background:#eff6ff;border-color:#93c5fd}.tenure-month-selection .green-plan-chart-selection-title{color:#1d4ed8}.tenure-month-selection .green-plan-chart-selection-clear{color:#1d4ed8;border-color:#93c5fd}.tenure-expiry-chart-rows{flex-direction:column;gap:8px;display:flex}.tenure-expiry-year-row{border-bottom:1px solid var(--border-color);align-items:flex-end;gap:10px;padding-bottom:8px;display:flex}.tenure-expiry-year-row:last-child{border-bottom:none;padding-bottom:0}.tenure-expiry-year-label-col{flex-direction:column;flex-shrink:0;justify-content:flex-end;align-items:center;gap:4px;width:52px;min-height:70px;padding-bottom:2px;display:flex}.tenure-expiry-year-label-col .green-plan-chart-year-value{color:var(--text-primary);font-size:14px;font-weight:800}.tenure-expiry-year-label-col .green-plan-chart-year-total{color:#1d4ed8;font-size:11px;font-weight:700}.tenure-expiry-months{flex:1;grid-template-columns:repeat(12,minmax(0,1fr));align-items:end;gap:3px;width:100%;min-width:0;height:70px;display:grid;position:relative;overflow:hidden}.tenure-expiry-chart .tenure-expiry-bar{gap:2px;width:100%;min-width:0}.tenure-expiry-chart .tenure-expiry-bar .green-plan-chart-bar-track{width:100%;height:36px}.tenure-expiry-bar:not(.empty) .tenure-expiry-bar-fill{height:100%}.tenure-expiry-bar.empty .tenure-expiry-bar-fill{height:0}.tenure-expiry-bar .green-plan-chart-bar-quarter{white-space:nowrap;font-size:9px}.tenure-expiry-year-row:has(.has-now-line) .tenure-expiry-year-label-col{min-height:86px}.tenure-expiry-months.has-now-line{box-sizing:border-box;height:86px;padding-top:16px;overflow:hidden}.tenure-expiry-chart .green-plan-chart-now-line.tenure-expiry-now-line{height:36px;top:19px;transform:translate(-50%)}.tenure-selection-entry{border-radius:var(--radius-sm);background:#fff;border:1px solid #bfdbfe;flex-wrap:wrap;align-items:center;gap:10px 14px;width:100%;padding:10px 12px;display:flex}.tenure-selection-entry-head{flex-direction:column;gap:4px;min-width:140px;display:flex}.tenure-month-selection .green-plan-chart-selection-list{flex-direction:column;align-items:stretch}.tenure-selection-inline-fields{flex-wrap:wrap;align-items:center;gap:10px 16px;display:flex}.tenure-selection-inline-field{align-items:baseline;gap:6px;font-size:14px;display:inline-flex}.tenure-selection-inline-label{color:var(--text-secondary);white-space:nowrap;font-size:13px;font-weight:700}.tenure-selection-inline-value{color:var(--text-primary);font-size:14px;font-weight:700}.tenure-selection-inline-actions{flex-wrap:wrap;align-items:center;gap:6px;margin-left:auto;display:flex}.tenure-action-btn.compact{padding:6px 10px;font-size:11px}.tenure-month-selection .green-plan-date-group{border-top-color:#bfdbfe}.tenure-month-selection .green-plan-date-group-label{color:#1d4ed8}.tenure-expiry-bar .green-plan-chart-bar-count{font-size:10px}.tenure-expiry-bar-fill{background:#60a5fa}.tenure-expiry-bar:not(.empty):hover .tenure-expiry-bar-fill{background:#2563eb}.tenure-expiry-bar.selected .tenure-expiry-bar-fill{background:#1d4ed8;box-shadow:0 0 0 2px #93c5fd}.tenure-selection-chip{cursor:pointer;text-align:left;background:#fff;border:1px solid #bfdbfe}.tenure-selection-chip.selected{border-color:#1d4ed8;box-shadow:0 0 0 2px #93c5fd}.tenure-selection-chip .tenure-category-badge{border-radius:999px;padding:1px 6px;font-size:10px;font-weight:700}.retirement-badge{color:#047857;background:#ecfdf5;border:1px solid #6ee7b7}.retirement-overview-card{overflow:auto}.retirement-rule-guide{flex-wrap:wrap;gap:8px;margin-top:10px;display:flex}.retirement-rule-item{border-radius:var(--radius-md);background:var(--bg-secondary);border:1px solid var(--border-color);box-shadow:var(--shadow-sm);align-items:center;gap:6px;padding:8px 12px;display:inline-flex}.retirement-rule-label{color:var(--text-primary);font-size:12px;font-weight:800}.retirement-rule-eq{color:var(--text-tertiary);font-size:12px;font-weight:700}.retirement-rule-value{color:var(--accent);font-size:12px;font-weight:700}.green-plan-chart{border-radius:var(--radius-md);background:var(--bg-secondary);border:1px solid var(--border-color);margin-bottom:20px;padding:16px 18px}.green-plan-chart-header{margin-bottom:14px}.green-plan-chart-title{color:var(--text-primary);margin:0;font-size:15px;font-weight:700}.green-plan-chart-desc{color:var(--text-tertiary);margin:4px 0 0;font-size:12px}.green-plan-chart-empty{text-align:center;color:var(--text-tertiary);padding:20px;font-size:13px}.green-plan-chart-scroll{overflow-x:auto}.green-plan-chart-body{gap:0;min-width:min-content;padding-bottom:4px;display:flex}.green-plan-chart-year-block{flex-shrink:0;display:flex}.green-plan-chart-year-divider{background:var(--border-color);flex-shrink:0;align-self:stretch;width:1px;margin:0 12px}.green-plan-chart-year-group{flex-shrink:0;min-width:120px;padding:0 4px}.green-plan-chart-year-label{justify-content:center;align-items:baseline;gap:6px;margin-bottom:8px;display:flex}.green-plan-chart-year-value{color:var(--text-primary);font-size:13px;font-weight:700}.green-plan-chart-year-total{color:var(--accent);font-size:11px;font-weight:700}.green-plan-chart-quarters{grid-template-columns:repeat(4,1fr);align-items:end;gap:8px;height:160px;display:grid;position:relative}.green-plan-chart-quarters.tenure-expiry-months{grid-template-columns:repeat(12,minmax(0,1fr));gap:3px;height:70px}.green-plan-chart-quarters.tenure-expiry-months.has-now-line{box-sizing:border-box;height:86px;padding-top:16px;overflow:hidden}.green-plan-chart-now-line{height:110px;top:16px;left:calc((var(--now-quarter) - .5) * 25%);z-index:4;pointer-events:none;background:#ef4444;border-radius:2px;width:3px;position:absolute;transform:translate(-50%);box-shadow:0 0 0 1px #fecaca,0 0 8px #dc262680}.green-plan-chart-now-line:before{content:"현재";color:#dc2626;white-space:nowrap;background:#fef2f2;border:1px solid #fecaca;border-radius:999px;padding:1px 6px;font-size:10px;font-weight:800;line-height:1.4;position:absolute;top:0;left:50%;transform:translate(-50%,calc(-100% - 4px))}.tenure-expiry-chart .green-plan-chart-now-line.tenure-expiry-now-line:before{top:0}.green-plan-chart-bar{cursor:pointer;background:0 0;border:none;flex-direction:column;align-items:center;gap:4px;min-width:44px;padding:0;display:flex}.green-plan-chart-bar.empty{cursor:default;opacity:.45}.green-plan-chart-bar:not(.empty):hover .green-plan-chart-bar-fill{background:#059669}.green-plan-chart-bar.selected .green-plan-chart-bar-fill{background:#047857;box-shadow:0 0 0 2px #6ee7b7}.green-plan-chart-bar.empty.selected .green-plan-chart-bar-track{box-shadow:inset 0 0 0 2px #6ee7b7}.green-plan-chart-bar-track{border-radius:var(--radius-sm);background:var(--bg-tertiary);align-items:flex-end;width:100%;height:110px;display:flex;overflow:hidden}.green-plan-chart-bar-fill{border-radius:var(--radius-sm) var(--radius-sm) 0 0;background:#10b981;width:100%;transition:height .2s,background .15s}.green-plan-chart-bar-quarter{color:var(--text-secondary);font-size:11px;font-weight:700}.green-plan-chart-bar-count{color:var(--text-primary);font-size:11px;font-weight:700}.green-plan-chart-selection{border-radius:var(--radius-md);background:#ecfdf5;border:1px solid #6ee7b7;margin-bottom:20px;padding:14px 16px}.green-plan-chart-selection-header{justify-content:space-between;align-items:center;gap:12px;margin-bottom:10px;display:flex}.green-plan-chart-selection-title{color:#047857;margin:0;font-size:14px;font-weight:700}.green-plan-chart-selection-clear{border-radius:var(--radius-sm);color:#047857;cursor:pointer;background:#fff;border:1px solid #6ee7b7;padding:4px 10px;font-size:11px;font-weight:600}.green-plan-chart-selection-list{flex-wrap:wrap;gap:8px;display:flex}.green-plan-chart-selection-groups{flex-direction:column;gap:14px;display:flex}.green-plan-date-group{border-top:1px solid #a7f3d0;padding-top:12px}.green-plan-date-group:first-child{border-top:none;padding-top:0}.green-plan-date-group-header{justify-content:space-between;align-items:center;gap:8px;margin-bottom:8px;display:flex}.green-plan-date-group-label{color:#047857;font-size:13px;font-weight:700}.green-plan-date-group-count{color:var(--text-secondary);font-size:11px;font-weight:700}.green-plan-chart-selection-chip{border-radius:var(--radius-sm);color:var(--text-primary);background:#fff;border:1px solid #a7f3d0;flex-direction:column;gap:4px;padding:8px 10px;font-size:13px;font-weight:700;display:inline-flex}.green-plan-chart-selection-chip-top{flex-wrap:wrap;align-items:center;gap:6px;display:inline-flex}.green-plan-category-badge{border:1px solid #0000;border-radius:999px;padding:1px 6px;font-size:10px;font-weight:700;line-height:1.4}.green-plan-category-badge.category-general{color:#1d4ed8;background:#eff6ff;border-color:#93c5fd}.green-plan-category-badge.category-pro{color:#6d28d9;background:#f5f3ff;border-color:#c4b5fd}.green-plan-category-badge.category-other{background:var(--bg-tertiary);color:var(--text-secondary);border-color:var(--border-color)}.green-plan-chart-selection-chip-meta{color:var(--text-tertiary);font-size:11px;font-weight:600}.retirement-summary-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-bottom:20px;display:grid}.retirement-summary-stat{border-radius:var(--radius-md);background:var(--bg-secondary);border:1px solid var(--border-color);padding:14px 16px}.retirement-summary-stat.highlight{background:#ecfdf5;border-color:#6ee7b7}.retirement-summary-stat-label{color:var(--text-secondary);font-size:12px;font-weight:700}.retirement-summary-stat-value{color:var(--text-primary);margin-top:6px;font-size:22px;font-weight:700}.retirement-summary-stat.highlight .retirement-summary-stat-value{color:#047857}.retirement-cohort-section{border-top:1px solid var(--border-color);margin-bottom:24px;padding-top:20px}.retirement-cohort-section:first-of-type{border-top:none;padding-top:0}.retirement-cohort-header{justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:12px;display:flex}.retirement-cohort-title{color:var(--text-primary);margin:0;font-size:16px;font-weight:700}.retirement-cohort-desc{color:var(--text-tertiary);margin:4px 0 0;font-size:12px;line-height:1.5}.retirement-cohort-count{background:var(--bg-tertiary);color:var(--text-secondary);border-radius:999px;flex-shrink:0;padding:4px 10px;font-size:12px;font-weight:700}.retirement-table-wrap{overflow-x:auto}.retirement-member-table th,.retirement-member-table td{white-space:nowrap}.retirement-timeline{font-weight:700}.retirement-timeline.days-green{color:#047857}.retirement-timeline.days-sabbatical{color:#b45309}.retirement-timeline.days-upcoming{color:#1d4ed8}@media (width<=900px){.tenure-info-grid{grid-template-columns:1fr}.retirement-summary-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}.auth-loading-page{min-height:100vh;color:var(--text-secondary);justify-content:center;align-items:center;font-size:15px;display:flex}
