/**
 * Organization Tree CSS v2
 * 
 * Modernes, kompaktes Layout für Organisationsstruktur
 * Mit Drag & Drop Styling
 */

/* ============================================
   ORGANIZATION TABS
   ============================================ */

.org-tabs-container {
    background: var(--card-bg, #fff);
    border-radius: 8px;
    padding: 8px;
    box-shadow: var(--shadow-sm);
    margin-bottom: 8px;
}

.org-tabs {
    display: flex;
    gap: 4px;
    flex-wrap: wrap;
    align-items: center;
}

.org-tab {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 10px 16px;
    background: var(--bg-secondary, #F3F4F6);
    border: 2px solid transparent;
    border-radius: 8px;
    cursor: pointer;
    transition: all 0.2s ease;
    font-size: 14px;
    color: var(--text-secondary, #6B7280);
}

.org-tab:hover {
    background: var(--bg-tertiary, #E5E7EB);
    color: var(--text-primary, #111827);
}

.org-tab.active {
    background: var(--primary, #3B82F6);
    color: white;
    border-color: var(--primary-dark, #2563EB);
}

.org-tab-icon {
    font-size: 16px;
}

.org-tab-name {
    font-weight: 500;
}

.org-tab-add {
    border: 2px dashed var(--border-color, #D1D5DB);
    background: transparent;
}

.org-tab-add:hover {
    border-color: var(--primary, #3B82F6);
    background: var(--primary-light, #EFF6FF);
    color: var(--primary, #3B82F6);
}

/* ============================================
   CONTAINER & LAYOUT
   ============================================ */

.org-container {
    display: flex;
    flex-direction: column;
    gap: 16px;
    min-height: 100%;
}

.org-stats-bar {
    background: var(--card-bg, #fff);
    border-radius: 8px;
    padding: 12px 16px;
    box-shadow: var(--shadow-sm);
}

.org-stats {
    display: flex;
    flex-wrap: wrap;
    gap: 16px;
    align-items: center;
}

.org-stat-item {
    padding: 4px 12px;
    font-size: 13px;
    color: var(--text-secondary);
}

.org-stat-item strong {
    color: var(--text-primary);
    font-size: 15px;
}

.org-toolbar {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}

.org-main-layout {
    display: flex;
    gap: 16px;
    flex: 1;
    min-height: 400px;
}

.org-tree-container {
    flex: 1;
    background: var(--card-bg, #fff);
    border-radius: 8px;
    padding: 16px;
    box-shadow: var(--shadow-sm);
    overflow-x: auto;
}

/* ============================================
   EMPTY STATE
   ============================================ */

.org-empty-state {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 60px 20px;
    text-align: center;
    color: var(--text-muted);
}

.org-empty-icon {
    font-size: 64px;
    margin-bottom: 16px;
    opacity: 0.5;
}

.org-empty-state h3 {
    margin-bottom: 8px;
    color: var(--text-primary);
}

.org-empty-state p {
    margin-bottom: 24px;
}

/* ============================================
   ORG NODE
   ============================================ */

.org-node {
    margin-bottom: 8px;
    border-left: 3px solid var(--node-color, #6B7280);
    border-radius: 4px;
    background: var(--bg-secondary, #F9FAFB);
    transition: all 0.2s ease;
}

.org-node.dragging {
    opacity: 0.5;
    transform: scale(0.98);
}

.org-node-header {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 10px 12px;
    cursor: grab;
    user-select: none;
    border-radius: 4px 4px 0 0;
    transition: background 0.15s ease;
}

.org-node-header:hover {
    background: var(--bg-tertiary, #F3F4F6);
}

.org-node-header:active {
    cursor: grabbing;
}

.org-node-toggle {
    width: 20px;
    height: 20px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: none;
    border: none;
    cursor: pointer;
    color: var(--text-muted);
    font-size: 10px;
    padding: 0;
}

.org-node-toggle:hover {
    color: var(--text-primary);
}

.org-node-toggle-placeholder {
    width: 20px;
}

.org-node-icon {
    width: 28px;
    height: 28px;
    border-radius: 6px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 14px;
    color: white;
    flex-shrink: 0;
}

.org-node-name {
    font-weight: 600;
    font-size: 14px;
    color: var(--text-primary);
}

.org-node-level {
    font-size: 11px;
    color: var(--text-muted);
    padding: 2px 6px;
    background: var(--bg-tertiary, #E5E7EB);
    border-radius: 4px;
}

.org-leader-badge {
    font-size: 12px;
    color: var(--text-secondary);
    margin-left: auto;
}

.org-member-count {
    font-size: 12px;
    color: var(--text-muted);
    padding: 2px 8px;
    background: var(--bg-tertiary, #E5E7EB);
    border-radius: 12px;
}

.org-node-actions {
    display: flex;
    gap: 2px;
    opacity: 0;
    transition: opacity 0.15s ease;
}

.org-node-header:hover .org-node-actions {
    opacity: 1;
}

.org-node-actions .btn-icon {
    width: 28px;
    height: 28px;
    border-radius: 4px;
    border: none;
    background: transparent;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
}

.org-node-actions .btn-icon:hover {
    background: var(--bg-tertiary, #E5E7EB);
}

/* ============================================
   NODE CONTENT
   ============================================ */

.org-node-content {
    padding: 0 12px 12px 40px;
}

/* ============================================
   LEADER SLOTS
   ============================================ */

.org-leader-slots {
    display: flex;
    gap: 12px;
    margin-bottom: 12px;
    flex-wrap: wrap;
}

.org-leader-slot {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 12px;
    background: var(--card-bg, #fff);
    border: 2px dashed var(--border-color, #E5E7EB);
    border-radius: 8px;
    min-width: 200px;
    transition: all 0.2s ease;
}

.org-leader-slot.filled {
    border-style: solid;
    border-color: var(--node-color, #6B7280);
}

.org-leader-slot.drop-target-hover {
    border-color: var(--primary, #3B82F6);
    background: var(--primary-light, #EFF6FF);
}

.org-leader-slot .slot-label {
    font-size: 11px;
    color: var(--text-muted);
    white-space: nowrap;
}

.org-leader-slot .slot-person {
    display: flex;
    align-items: center;
    gap: 8px;
    flex: 1;
}

.org-leader-slot .slot-person-info {
    display: flex;
    flex-direction: column;
    flex: 1;
    min-width: 0;
}

.org-leader-slot .slot-person-name {
    font-size: 13px;
    font-weight: 500;
    color: var(--text-primary);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.org-leader-slot .slot-person-position {
    font-size: 11px;
    color: var(--text-muted);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.org-leader-slot .slot-empty {
    font-size: 12px;
    color: var(--text-muted);
    font-style: italic;
}

.btn-icon-small {
    width: 20px;
    height: 20px;
    border: none;
    background: transparent;
    cursor: pointer;
    border-radius: 4px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 12px;
    opacity: 0.5;
}

.btn-icon-small:hover {
    opacity: 1;
    background: var(--bg-tertiary, #E5E7EB);
}

/* ============================================
   MEMBERS GRID
   ============================================ */

.org-members-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    padding: 8px;
    background: var(--card-bg, #fff);
    border-radius: 8px;
    min-height: 40px;
    border: 2px dashed transparent;
    transition: all 0.2s ease;
}

.org-members-grid.drop-target-hover {
    border-color: var(--primary, #3B82F6);
    background: var(--primary-light, #EFF6FF);
}

.org-drop-zone {
    padding: 16px;
    background: var(--card-bg, #fff);
    border: 2px dashed var(--border-color, #E5E7EB);
    border-radius: 8px;
    text-align: center;
    color: var(--text-muted);
    font-size: 13px;
    transition: all 0.2s ease;
}

.org-drop-zone.drop-target-hover {
    border-color: var(--primary, #3B82F6);
    background: var(--primary-light, #EFF6FF);
    color: var(--primary, #3B82F6);
}

/* ============================================
   MEMBER CARD
   ============================================ */

.org-member-card {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 6px 10px;
    background: var(--bg-secondary, #F9FAFB);
    border: 1px solid var(--border-color, #E5E7EB);
    border-radius: 6px;
    cursor: grab;
    transition: all 0.15s ease;
    max-width: 200px;
}

.org-member-card:hover {
    background: var(--bg-tertiary, #F3F4F6);
    box-shadow: var(--shadow-sm);
}

.org-member-card:active {
    cursor: grabbing;
}

.org-member-card.dragging {
    opacity: 0.5;
}

.org-member-card.primary {
    border-color: var(--warning, #F59E0B);
    background: #FFFBEB;
}

.org-member-card .member-info {
    display: flex;
    flex-direction: column;
    min-width: 0;
    flex: 1;
}

.org-member-card .member-name {
    font-size: 13px;
    font-weight: 500;
    color: var(--text-primary);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.org-member-card .member-pnr {
    font-size: 11px;
    color: var(--text-muted);
}

.org-member-card .primary-badge {
    color: var(--warning, #F59E0B);
    font-size: 14px;
}

.org-member-card .member-actions {
    opacity: 0;
    transition: opacity 0.15s ease;
}

.org-member-card:hover .member-actions {
    opacity: 1;
}

/* ============================================
   PERSON AVATAR
   ============================================ */

.person-avatar {
    width: 28px;
    height: 28px;
    border-radius: 50%;
    object-fit: cover;
    flex-shrink: 0;
}

.person-avatar-placeholder {
    background: linear-gradient(135deg, var(--primary, #3B82F6) 0%, var(--primary-dark, #1D4ED8) 100%);
    color: white;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 11px;
    font-weight: 600;
}

/* ============================================
   UNASSIGNED POOL
   ============================================ */

.org-pool {
    width: 280px;
    background: var(--card-bg, #fff);
    border-radius: 8px;
    box-shadow: var(--shadow-sm);
    display: flex;
    flex-direction: column;
    max-height: calc(100vh - 300px);
}

.org-pool-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 12px 16px;
    border-bottom: 1px solid var(--border-color, #E5E7EB);
}

.org-pool-header h4 {
    margin: 0;
    font-size: 14px;
    color: var(--text-primary);
}

.org-pool-content {
    flex: 1;
    overflow-y: auto;
    padding: 12px;
}

.org-pool-empty {
    padding: 20px;
    text-align: center;
    color: var(--success, #10B981);
    font-size: 13px;
}

.org-pool-person {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 8px 10px;
    margin-bottom: 6px;
    background: var(--bg-secondary, #F9FAFB);
    border: 1px solid var(--border-color, #E5E7EB);
    border-radius: 6px;
    cursor: grab;
    transition: all 0.15s ease;
}

.org-pool-person:hover {
    background: var(--bg-tertiary, #F3F4F6);
    box-shadow: var(--shadow-sm);
}

.org-pool-person:active {
    cursor: grabbing;
}

.org-pool-person .person-info,
.org-pool-person .pool-person-info {
    display: flex;
    flex-direction: column;
    min-width: 0;
}

.org-pool-person .person-name,
.org-pool-person .pool-person-name {
    font-size: 13px;
    font-weight: 500;
    color: var(--text-primary);
}

.org-pool-person .person-pnr,
.org-pool-person .pool-person-position {
    font-size: 11px;
    color: var(--text-muted);
}

/* ============================================
   DRAG & DROP STATES
   ============================================ */

.drop-target-available {
    /* Subtiler Hinweis dass Drop möglich ist */
}

.drop-target-hover {
    border-color: var(--primary, #3B82F6) !important;
    background-color: var(--primary-light, #EFF6FF) !important;
}

/* ============================================
   CONTEXT MENU
   ============================================ */

.org-context-menu {
    position: fixed;
    z-index: 10000;
    background: var(--card-bg, #fff);
    border-radius: 8px;
    box-shadow: var(--shadow-lg, 0 10px 25px rgba(0,0,0,0.15));
    padding: 6px 0;
    min-width: 180px;
    animation: fadeIn 0.1s ease;
}

.org-context-menu button {
    display: block;
    width: 100%;
    padding: 8px 16px;
    text-align: left;
    border: none;
    background: none;
    cursor: pointer;
    font-size: 13px;
    color: var(--text-primary);
    transition: background 0.1s ease;
}

.org-context-menu button:hover {
    background: var(--bg-secondary, #F9FAFB);
}

.org-context-menu button.danger {
    color: var(--danger, #EF4444);
}

.org-context-menu button.danger:hover {
    background: #FEE2E2;
}

.org-context-menu hr {
    margin: 6px 0;
    border: none;
    border-top: 1px solid var(--border-color, #E5E7EB);
}

/* ============================================
   MODAL OVERRIDES
   ============================================ */

.modal-small {
    max-width: 400px;
}

/* ============================================
   CHILDREN CONTAINER
   ============================================ */

.org-children {
    margin-top: 8px;
}

/* ============================================
   RESPONSIVE
   ============================================ */

@media (max-width: 768px) {
    .org-main-layout {
        flex-direction: column;
    }
    
    .org-pool {
        width: 100%;
        max-height: 300px;
    }
    
    .org-leader-slots {
        flex-direction: column;
    }
    
    .org-leader-slot {
        min-width: 100%;
    }
}

/* ============================================
   SPINNER
   ============================================ */

.spinner {
    width: 32px;
    height: 32px;
    border: 3px solid var(--border-color, #E5E7EB);
    border-top-color: var(--primary, #3B82F6);
    border-radius: 50%;
    animation: spin 0.8s linear infinite;
    margin: 0 auto 16px;
}

@keyframes spin {
    to { transform: rotate(360deg); }
}

@keyframes fadeIn {
    from { opacity: 0; transform: translateY(-4px); }
    to { opacity: 1; transform: translateY(0); }
}

/* ============================================
   DARK MODE SUPPORT
   ============================================ */

[data-theme="dark"] .org-tabs-container {
    background: var(--card-bg, #1e293b);
    border: 1px solid var(--border-color, #334155);
}

[data-theme="dark"] .org-tab {
    background: var(--bg-secondary, #334155);
    color: var(--text-secondary, #94a3b8);
}

[data-theme="dark"] .org-tab:hover {
    background: var(--bg-tertiary, #475569);
    color: var(--text-primary, #f1f5f9);
}

[data-theme="dark"] .org-tab.active {
    background: var(--primary, #3B82F6);
    color: white;
}

[data-theme="dark"] .org-tab-add {
    background: transparent;
    border-color: var(--border-color, #475569);
}

[data-theme="dark"] .org-tab-add:hover {
    border-color: var(--primary, #3B82F6);
    background: rgba(59, 130, 246, 0.1);
    color: var(--primary, #3B82F6);
}

[data-theme="dark"] .org-stats-bar,
[data-theme="dark"] .org-tree-container,
[data-theme="dark"] .org-pool {
    background: var(--card-bg, #1e293b);
    border: 1px solid var(--border-color, #334155);
}

[data-theme="dark"] .org-node {
    background: var(--bg-secondary, #1e293b);
    border-left-width: 3px;
}

[data-theme="dark"] .org-node-header:hover {
    background: var(--bg-tertiary, #334155);
}

[data-theme="dark"] .org-node-name {
    color: var(--text-primary, #f1f5f9);
}

[data-theme="dark"] .org-node-level {
    background: var(--bg-tertiary, #334155);
    color: var(--text-secondary, #94a3b8);
}

[data-theme="dark"] .org-member-count {
    background: var(--bg-tertiary, #334155);
    color: var(--text-secondary, #94a3b8);
}

[data-theme="dark"] .org-leader-slot {
    background: var(--bg-secondary, #1e293b);
    border-color: var(--border-color, #475569);
}

[data-theme="dark"] .org-leader-slot.filled {
    background: var(--bg-tertiary, #334155);
}

[data-theme="dark"] .org-leader-slot .slot-label {
    color: var(--text-secondary, #94a3b8);
}

[data-theme="dark"] .org-leader-slot .slot-empty {
    color: var(--text-muted, #64748b);
}

[data-theme="dark"] .org-members-grid {
    background: var(--bg-tertiary, #0f172a);
    border-color: var(--border-color, #334155);
}

[data-theme="dark"] .org-member-card {
    background: var(--card-bg, #1e293b);
    border-color: var(--border-color, #334155);
}

[data-theme="dark"] .org-member-card:hover {
    background: var(--bg-tertiary, #334155);
    border-color: var(--primary, #3b82f6);
}

[data-theme="dark"] .member-name {
    color: var(--text-primary, #f1f5f9);
}

[data-theme="dark"] .member-info {
    color: var(--text-secondary, #94a3b8);
}

[data-theme="dark"] .org-pool-header {
    border-bottom-color: var(--border-color, #334155);
}

[data-theme="dark"] .org-pool-title {
    color: var(--text-primary, #f1f5f9);
}

[data-theme="dark"] .org-pool-item {
    background: var(--bg-secondary, #1e293b);
    border-color: var(--border-color, #334155);
}

[data-theme="dark"] .org-pool-item:hover {
    background: var(--bg-tertiary, #334155);
    border-color: var(--primary, #3b82f6);
}

[data-theme="dark"] .org-pool-person {
    background: var(--bg-secondary, #1e293b);
    border-color: var(--border-color, #334155);
}

[data-theme="dark"] .org-pool-person:hover {
    background: var(--bg-tertiary, #334155);
    border-color: var(--primary, #3b82f6);
}

[data-theme="dark"] .org-pool-person .pool-person-name,
[data-theme="dark"] .org-pool-person .person-name {
    color: var(--text-primary, #f1f5f9);
}

[data-theme="dark"] .org-pool-person .pool-person-position,
[data-theme="dark"] .org-pool-person .person-pnr {
    color: var(--text-secondary, #94a3b8);
}

[data-theme="dark"] .pool-person-name {
    color: var(--text-primary, #f1f5f9);
}

[data-theme="dark"] .pool-person-info {
    color: var(--text-secondary, #94a3b8);
}

[data-theme="dark"] .org-context-menu {
    background: var(--card-bg, #1e293b);
    border-color: var(--border-color, #334155);
}

[data-theme="dark"] .org-context-menu button {
    color: var(--text-primary, #f1f5f9);
}

[data-theme="dark"] .org-context-menu button:hover {
    background: var(--bg-tertiary, #334155);
}

[data-theme="dark"] .org-empty-state h3 {
    color: var(--text-primary, #f1f5f9);
}

[data-theme="dark"] .org-empty-state p {
    color: var(--text-secondary, #94a3b8);
}

[data-theme="dark"] .org-stat-item {
    color: var(--text-secondary, #94a3b8);
}

[data-theme="dark"] .org-stat-item strong {
    color: var(--text-primary, #f1f5f9);
}

[data-theme="dark"] .org-node-toggle {
    color: var(--text-muted, #64748b);
}

[data-theme="dark"] .org-node-toggle:hover {
    color: var(--text-primary, #f1f5f9);
}

[data-theme="dark"] .org-leader-badge {
    color: var(--text-secondary, #94a3b8);
}

[data-theme="dark"] .btn-icon-small:hover {
    background: var(--bg-tertiary, #334155);
}

[data-theme="dark"] .org-node-actions .btn-icon:hover {
    background: var(--bg-tertiary, #334155);
}

/* ============================================
   ORGANIZATION v3 SPECIFIC STYLES
   ============================================ */

/* Organization Header */
.org-header {
    background: var(--card-bg, #fff);
    border-radius: 8px;
    padding: 16px;
    display: flex;
    align-items: center;
    gap: 16px;
    flex-wrap: wrap;
    box-shadow: var(--shadow-sm);
}

.org-header-info {
    display: flex;
    align-items: center;
    gap: 12px;
    flex: 1;
}

.org-header-info h2 {
    margin: 0;
    font-size: 18px;
    color: var(--text-primary);
}

.org-type-badge {
    padding: 4px 10px;
    background: var(--primary-light, #EFF6FF);
    color: var(--primary, #3B82F6);
    border-radius: 12px;
    font-size: 12px;
    font-weight: 500;
}

.org-code {
    padding: 4px 8px;
    background: var(--bg-secondary);
    border-radius: 4px;
    font-family: monospace;
    font-size: 12px;
    color: var(--text-secondary);
}

.org-header-stats {
    display: flex;
    gap: 16px;
}

.org-header-stats .stat-item {
    font-size: 13px;
    color: var(--text-secondary);
}

.org-header-stats .stat-item.warning {
    color: var(--warning, #F59E0B);
}

.org-header-actions {
    display: flex;
    gap: 8px;
}

/* Tab Count Badge */
.org-tab-count {
    padding: 2px 8px;
    background: rgba(255,255,255,0.2);
    border-radius: 10px;
    font-size: 11px;
    font-weight: 600;
}

.org-tab:not(.active) .org-tab-count {
    background: var(--bg-tertiary, #E5E7EB);
    color: var(--text-secondary);
}

/* Empty Units State */
.org-empty-units {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 40px;
    text-align: center;
    color: var(--text-muted);
}

.org-empty-units h4 {
    margin: 16px 0 8px;
    color: var(--text-secondary);
}

/* Unit Styles */
.org-unit {
    margin-bottom: 4px;
}

.org-unit-header {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 10px 12px;
    background: var(--bg-secondary, #F9FAFB);
    border-radius: 6px;
    border-left: 4px solid var(--node-color, #6B7280);
    transition: all 0.2s ease;
}

.org-unit-header:hover {
    background: var(--bg-tertiary, #F3F4F6);
}

.org-unit-toggle {
    background: none;
    border: none;
    cursor: pointer;
    font-size: 10px;
    color: var(--text-muted);
    padding: 4px;
    width: 20px;
}

.org-unit-toggle-placeholder {
    width: 20px;
}

.org-unit-icon {
    width: 24px;
    height: 24px;
    border-radius: 4px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 12px;
    color: white;
}

.org-unit-name {
    font-weight: 500;
    color: var(--text-primary);
}

.org-unit-level {
    padding: 2px 8px;
    background: var(--bg-tertiary, #E5E7EB);
    border-radius: 4px;
    font-size: 11px;
    color: var(--text-secondary);
}

.org-unit-actions {
    margin-left: auto;
    display: flex;
    gap: 4px;
    opacity: 0;
    transition: opacity 0.2s;
}

.org-unit-header:hover .org-unit-actions {
    opacity: 1;
}

.org-unit-content {
    padding-left: 16px;
    padding-top: 8px;
}

.org-unit-children {
    margin-top: 4px;
}

/* Members Zone */
.org-members-zone {
    padding: 12px;
    background: var(--bg-secondary, #F9FAFB);
    border: 2px dashed var(--border-color, #E5E7EB);
    border-radius: 6px;
    margin-top: 8px;
    text-align: center;
    transition: all 0.2s ease;
}

.org-members-zone:hover {
    border-color: var(--primary, #3B82F6);
    background: var(--primary-light, #EFF6FF);
}

.org-members-zone .members-hint {
    color: var(--text-muted);
    font-size: 13px;
}

/* Pool Sections */
.pool-section {
    margin-bottom: 16px;
}

.pool-section-title {
    font-size: 12px;
    font-weight: 600;
    color: var(--text-secondary);
    margin: 0 0 8px;
    padding-bottom: 4px;
    border-bottom: 1px solid var(--border-color);
}

.pool-persons {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.pool-person {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 8px 10px;
    background: var(--bg-secondary, #F9FAFB);
    border-radius: 6px;
    border: 1px solid var(--border-color, #E5E7EB);
    cursor: grab;
    transition: all 0.2s ease;
}

.pool-person:hover {
    background: var(--bg-tertiary, #F3F4F6);
    border-color: var(--primary, #3B82F6);
}

.pool-person:active {
    cursor: grabbing;
}

.pool-person-info {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.pool-person-name {
    font-weight: 500;
    font-size: 13px;
    color: var(--text-primary);
}

.pool-person-position {
    font-size: 11px;
    color: var(--text-muted);
}

.pool-empty {
    text-align: center;
    padding: 20px;
    color: var(--success, #10B981);
    font-size: 13px;
}

/* Dark Mode for v3 */
[data-theme="dark"] .org-header {
    background: var(--card-bg, #1e293b);
}

[data-theme="dark"] .org-header-info h2 {
    color: var(--text-primary, #f1f5f9);
}

[data-theme="dark"] .org-type-badge {
    background: rgba(59, 130, 246, 0.2);
    color: var(--primary, #60a5fa);
}

[data-theme="dark"] .org-code {
    background: var(--bg-tertiary, #334155);
    color: var(--text-secondary, #94a3b8);
}

[data-theme="dark"] .org-unit-header {
    background: var(--bg-secondary, #1e293b);
}

[data-theme="dark"] .org-unit-header:hover {
    background: var(--bg-tertiary, #334155);
}

[data-theme="dark"] .org-unit-name {
    color: var(--text-primary, #f1f5f9);
}

[data-theme="dark"] .org-unit-level {
    background: var(--bg-tertiary, #334155);
    color: var(--text-secondary, #94a3b8);
}

[data-theme="dark"] .org-members-zone {
    background: var(--bg-secondary, #1e293b);
    border-color: var(--border-color, #334155);
}

[data-theme="dark"] .org-members-zone:hover {
    background: rgba(59, 130, 246, 0.1);
    border-color: var(--primary, #3b82f6);
}

[data-theme="dark"] .pool-section-title {
    color: var(--text-secondary, #94a3b8);
    border-bottom-color: var(--border-color, #334155);
}

[data-theme="dark"] .pool-person {
    background: var(--bg-secondary, #1e293b);
    border-color: var(--border-color, #334155);
}

[data-theme="dark"] .pool-person:hover {
    background: var(--bg-tertiary, #334155);
    border-color: var(--primary, #3b82f6);
}

[data-theme="dark"] .pool-person-name {
    color: var(--text-primary, #f1f5f9);
}

[data-theme="dark"] .org-empty-units h4 {
    color: var(--text-secondary, #94a3b8);
}

/* ============================================
   MEMBERS GRID & POOL SCROLLING
   ============================================ */

.org-members-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    padding: 8px 0;
}

.org-member-card {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 12px;
    background: var(--card-bg, #fff);
    border: 1px solid var(--border-color, #E5E7EB);
    border-radius: 8px;
    cursor: grab;
    transition: all 0.2s ease;
    min-width: 180px;
    max-width: 220px;
}

.org-member-card:hover {
    border-color: var(--primary, #3B82F6);
    box-shadow: 0 2px 8px rgba(0,0,0,0.1);
}

.org-member-card:active {
    cursor: grabbing;
}

.org-member-card .person-avatar {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background: var(--primary, #3B82F6);
    color: white;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 12px;
    font-weight: 600;
    flex-shrink: 0;
}

.org-member-card .member-info {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.org-member-card .member-name {
    font-weight: 500;
    font-size: 13px;
    color: var(--text-primary);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.org-member-card .member-position {
    font-size: 11px;
    color: var(--text-muted);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.org-member-card .btn-icon-small {
    opacity: 0;
    transition: opacity 0.2s;
}

.org-member-card:hover .btn-icon-small {
    opacity: 1;
}

/* Pool Scrolling */
.org-pool {
    width: 320px;
    max-height: calc(100vh - 300px);
    display: flex;
    flex-direction: column;
    background: var(--card-bg, #fff);
    border-radius: 8px;
    box-shadow: var(--shadow-sm);
    overflow: hidden;
}

.org-pool-header {
    padding: 12px 16px;
    border-bottom: 1px solid var(--border-color);
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-shrink: 0;
}

.org-pool-header h4 {
    margin: 0;
    font-size: 14px;
}

.org-pool-content {
    flex: 1;
    overflow-y: auto;
    padding: 12px;
}

/* Dark Mode for Members */
[data-theme="dark"] .org-member-card {
    background: var(--bg-secondary, #1e293b);
    border-color: var(--border-color, #334155);
}

[data-theme="dark"] .org-member-card:hover {
    border-color: var(--primary, #3b82f6);
}

[data-theme="dark"] .org-member-card .member-name {
    color: var(--text-primary, #f1f5f9);
}

[data-theme="dark"] .org-member-card .member-position {
    color: var(--text-secondary, #94a3b8);
}

[data-theme="dark"] .org-pool {
    background: var(--card-bg, #1e293b);
}

[data-theme="dark"] .org-pool-header {
    border-bottom-color: var(--border-color, #334155);
}

[data-theme="dark"] .org-pool-header h4 {
    color: var(--text-primary, #f1f5f9);
}

/* ============================================
   TOOLBAR STYLES
   ============================================ */

.toolbar-separator {
    width: 1px;
    height: 24px;
    background: var(--border-color, #E5E7EB);
    margin: 0 8px;
}

.btn-outline {
    background: transparent;
    border: 1px solid var(--border-color, #D1D5DB);
    color: var(--text-secondary, #6B7280);
}

.btn-outline:hover {
    background: var(--bg-tertiary, #F3F4F6);
    border-color: var(--primary, #3B82F6);
    color: var(--primary, #3B82F6);
}

/* ============================================
   DEPTH LEVEL COLORS
   ============================================ */

/* Ebene 0 - Dunkelblau */
.org-unit-depth-0 > .org-unit-header {
    background: rgba(30, 64, 175, 0.1) !important;
    border-left-color: #1E40AF !important;
}
.org-unit-depth-0 > .org-unit-header .org-unit-name {
    color: #1E40AF !important;
    font-weight: 600;
}

/* Ebene 1 - Grün */
.org-unit-depth-1 > .org-unit-header {
    background: rgba(4, 120, 87, 0.1) !important;
    border-left-color: #047857 !important;
}
.org-unit-depth-1 > .org-unit-header .org-unit-name {
    color: #047857 !important;
    font-weight: 500;
}

/* Ebene 2 - Orange */
.org-unit-depth-2 > .org-unit-header {
    background: rgba(180, 83, 9, 0.1) !important;
    border-left-color: #B45309 !important;
}
.org-unit-depth-2 > .org-unit-header .org-unit-name {
    color: #B45309 !important;
}

/* Ebene 3 - Violett */
.org-unit-depth-3 > .org-unit-header {
    background: rgba(124, 58, 237, 0.1) !important;
    border-left-color: #7C3AED !important;
}
.org-unit-depth-3 > .org-unit-header .org-unit-name {
    color: #7C3AED !important;
}

/* Ebene 4 - Rot */
.org-unit-depth-4 > .org-unit-header {
    background: rgba(220, 38, 38, 0.1) !important;
    border-left-color: #DC2626 !important;
}
.org-unit-depth-4 > .org-unit-header .org-unit-name {
    color: #DC2626 !important;
}

/* Ebene 5+ - Türkis */
.org-unit-depth-5 > .org-unit-header {
    background: rgba(8, 145, 178, 0.1) !important;
    border-left-color: #0891B2 !important;
}
.org-unit-depth-5 > .org-unit-header .org-unit-name {
    color: #0891B2 !important;
}

/* Level badges auch einfärben */
.org-unit-depth-0 .org-unit-level { background: rgba(30, 64, 175, 0.15); color: #1E40AF; }
.org-unit-depth-1 .org-unit-level { background: rgba(4, 120, 87, 0.15); color: #047857; }
.org-unit-depth-2 .org-unit-level { background: rgba(180, 83, 9, 0.15); color: #B45309; }
.org-unit-depth-3 .org-unit-level { background: rgba(124, 58, 237, 0.15); color: #7C3AED; }
.org-unit-depth-4 .org-unit-level { background: rgba(220, 38, 38, 0.15); color: #DC2626; }
.org-unit-depth-5 .org-unit-level { background: rgba(8, 145, 178, 0.15); color: #0891B2; }

/* Dark Mode für Ebenenfarben */
[data-theme="dark"] .org-unit-depth-0 > .org-unit-header { background: rgba(59, 130, 246, 0.15) !important; }
[data-theme="dark"] .org-unit-depth-1 > .org-unit-header { background: rgba(16, 185, 129, 0.15) !important; }
[data-theme="dark"] .org-unit-depth-2 > .org-unit-header { background: rgba(245, 158, 11, 0.15) !important; }
[data-theme="dark"] .org-unit-depth-3 > .org-unit-header { background: rgba(139, 92, 246, 0.15) !important; }
[data-theme="dark"] .org-unit-depth-4 > .org-unit-header { background: rgba(239, 68, 68, 0.15) !important; }
[data-theme="dark"] .org-unit-depth-5 > .org-unit-header { background: rgba(6, 182, 212, 0.15) !important; }

[data-theme="dark"] .org-unit-depth-0 > .org-unit-header .org-unit-name { color: #60A5FA !important; }
[data-theme="dark"] .org-unit-depth-1 > .org-unit-header .org-unit-name { color: #34D399 !important; }
[data-theme="dark"] .org-unit-depth-2 > .org-unit-header .org-unit-name { color: #FBBF24 !important; }
[data-theme="dark"] .org-unit-depth-3 > .org-unit-header .org-unit-name { color: #A78BFA !important; }
[data-theme="dark"] .org-unit-depth-4 > .org-unit-header .org-unit-name { color: #F87171 !important; }
[data-theme="dark"] .org-unit-depth-5 > .org-unit-header .org-unit-name { color: #22D3EE !important; }

