.roles-page.svelte-1gunji{padding:0 1.5rem 2rem;max-width:1400px;margin:0 auto}.view-tabs.svelte-1gunji{display:flex;gap:.25rem;border-bottom:1px solid var(--border, #2a2a4a);margin-bottom:1.5rem;align-items:center}.view-tab.svelte-1gunji{padding:.75rem 1.25rem;background:none;border:none;border-bottom:2px solid transparent;color:var(--text-muted, #94a3b8);font-size:.875rem;font-weight:500;cursor:pointer;white-space:nowrap}.view-tab.svelte-1gunji:hover{color:var(--text, #e2e8f0)}.view-tab.active.svelte-1gunji{color:#3b82f6;border-bottom-color:#3b82f6}.tab-actions.svelte-1gunji{margin-left:auto;padding-bottom:.5rem}.loading-state.svelte-1gunji,.empty-state.svelte-1gunji{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;color:var(--text-muted, #94a3b8)}.empty-state.svelte-1gunji span:where(.svelte-1gunji){font-size:3rem;margin-bottom:1rem}.spinner.svelte-1gunji{width:36px;height:36px;border:3px solid var(--border, #2a2a4a);border-top-color:#3b82f6;border-radius:50%;animation:svelte-1gunji-spin .75s linear infinite;margin-bottom:1rem}@keyframes svelte-1gunji-spin{to{transform:rotate(360deg)}}.error-banner.svelte-1gunji{display:flex;justify-content:space-between;padding:.75rem 1rem;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:8px;color:#f87171;margin-bottom:1rem;font-size:.875rem}.error-banner.svelte-1gunji button:where(.svelte-1gunji){background:none;border:none;color:#f87171;cursor:pointer}.org-chart.svelte-1gunji{display:flex;flex-direction:column;gap:1.5rem;align-items:center;padding:2rem 0}.org-node.svelte-1gunji{display:flex;flex-direction:column;align-items:center}.org-card.svelte-1gunji{display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:1rem 1.5rem;background:var(--card-bg, #1a1a2e);border:1px solid var(--border, #2a2a4a);border-radius:12px;min-width:180px;text-align:center}.org-node.root.svelte-1gunji>.org-card:where(.svelte-1gunji){border-color:#3b82f6;background:#3b82f60d}.org-name.svelte-1gunji{font-weight:700;color:var(--text, #e2e8f0);font-size:.9rem}.org-code.svelte-1gunji{font-size:.7rem;color:var(--text-muted, #94a3b8)}.org-manager.svelte-1gunji{font-size:.8rem;color:var(--text-muted, #94a3b8)}.org-count.svelte-1gunji{font-size:.75rem;color:#3b82f6}.org-children.svelte-1gunji{display:flex;gap:1rem;margin-top:1rem;flex-wrap:wrap;justify-content:center}.dept-grid.svelte-1gunji{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}.dept-card.svelte-1gunji{background:var(--card-bg, #1a1a2e);border:1px solid var(--border, #2a2a4a);border-radius:12px;padding:1.25rem;transition:border-color .15s}.dept-card.svelte-1gunji:hover{border-color:#3b82f64d}.dept-header.svelte-1gunji{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.dept-name.svelte-1gunji{font-weight:700;color:var(--text, #e2e8f0);font-size:1rem}.dept-code.svelte-1gunji{font-size:.7rem;padding:.15rem .5rem;background:#8b5cf61a;color:#a78bfa;border-radius:4px}.dept-desc.svelte-1gunji{font-size:.8rem;color:var(--text-muted, #94a3b8);margin:.5rem 0}.dept-meta.svelte-1gunji{display:flex;flex-direction:column;gap:.25rem;margin-top:.75rem}.dept-meta-item.svelte-1gunji{font-size:.8rem;color:var(--text-muted, #94a3b8)}.table-container.svelte-1gunji{border:1px solid var(--border, #2a2a4a);border-radius:12px;background:var(--card-bg, #1a1a2e);overflow-x:auto}.data-table.svelte-1gunji{width:100%;border-collapse:collapse;font-size:.875rem}.data-table.svelte-1gunji th:where(.svelte-1gunji){text-align:left;padding:.875rem 1rem;font-weight:600;color:var(--text-muted, #94a3b8);font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border, #2a2a4a)}.data-table.svelte-1gunji td:where(.svelte-1gunji){padding:.75rem 1rem;color:var(--text, #e2e8f0);border-bottom:1px solid var(--border, #2a2a4a)}.data-table.svelte-1gunji tbody:where(.svelte-1gunji) tr:where(.svelte-1gunji):last-child td:where(.svelte-1gunji){border-bottom:none}.data-table.svelte-1gunji tbody:where(.svelte-1gunji) tr:where(.svelte-1gunji):hover{background:#3b82f60a}.role-title.svelte-1gunji{font-weight:600}.code-badge.svelte-1gunji{font-size:.75rem;padding:.15rem .5rem;background:#3b82f61a;color:#60a5fa;border-radius:4px}.status-dot.svelte-1gunji{display:inline-block;width:8px;height:8px;border-radius:50%;background:#64748b;margin-right:.375rem}.status-dot.active.svelte-1gunji{background:#10b981}.btn.svelte-1gunji{display:inline-flex;align-items:center;gap:.375rem;padding:.625rem 1rem;border-radius:8px;font-size:.85rem;font-weight:600;cursor:pointer;border:none;transition:background .15s}.btn.svelte-1gunji:disabled{opacity:.5;cursor:not-allowed}.btn-primary.svelte-1gunji{background:#3b82f6;color:#fff}.btn-primary.svelte-1gunji:hover:not(:disabled){background:#2563eb}.btn-outline.svelte-1gunji{background:transparent;color:var(--text, #e2e8f0);border:1px solid var(--border, #2a2a4a)}.modal-overlay.svelte-1gunji{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:100;padding:1rem}.modal.svelte-1gunji{background:var(--card-bg, #1a1a2e);border:1px solid var(--border, #2a2a4a);border-radius:16px;width:100%;max-width:480px;box-shadow:0 20px 60px #0006}.modal-header.svelte-1gunji{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border, #2a2a4a)}.modal-header.svelte-1gunji h2:where(.svelte-1gunji){font-size:1.125rem;font-weight:700;color:var(--text, #e2e8f0);margin:0}.modal-close.svelte-1gunji{background:none;border:none;color:var(--text-muted, #94a3b8);cursor:pointer;font-size:1.125rem}.modal-body.svelte-1gunji{padding:1.5rem}.modal-footer.svelte-1gunji{display:flex;justify-content:flex-end;gap:.75rem;padding:1rem 1.5rem;border-top:1px solid var(--border, #2a2a4a)}.form-stack.svelte-1gunji{display:flex;flex-direction:column;gap:1rem}.form-group.svelte-1gunji{display:flex;flex-direction:column;gap:.375rem}.form-group.svelte-1gunji label:where(.svelte-1gunji){font-size:.8rem;font-weight:600;color:var(--text-muted, #94a3b8);text-transform:uppercase}.form-group.svelte-1gunji input:where(.svelte-1gunji),.form-group.svelte-1gunji select:where(.svelte-1gunji){background:#0003;border:1px solid var(--border, #2a2a4a);border-radius:8px;padding:.625rem .75rem;color:var(--text, #e2e8f0);font-size:.875rem;outline:none}.form-group.svelte-1gunji input:where(.svelte-1gunji):focus,.form-group.svelte-1gunji select:where(.svelte-1gunji):focus{border-color:#3b82f6}
