@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";:root{--card-bg:var(--fnx-card-bg);--fnx-window-bg:#fff;--fnx-card-bg:#f9fafb;--fnx-surface-bg:#f3f4f6;--fnx-header-bg:#f9fafb;--fnx-text-primary:#111827;--fnx-text-secondary:#6b7280;--fnx-text-on-primary:#fff;--fnx-table-bg:#fff;--fnx-table-fg:#111827;--fnx-table-header-bg:#f3f4f6;--fnx-table-header-fg:#374151;--fnx-table-row-alt:#f9fafb;--fnx-table-row-hover:#f3f4f6;--fnx-table-row-selected:#00d9d9;--fnx-table-border:#d1d5db;--fnx-border:#e5e7eb;--fnx-border-color:#e5e7eb;--fnx-border-focus:#00d9d9;--fnx-btn-primary-bg:#00d9d9;--fnx-btn-primary-bg-hover:#00f0f0;--fnx-btn-primary-bg-pressed:#00c0c0;--fnx-btn-primary-fg:#111827;--fnx-input-bg:#fff;--fnx-input-fg:#111827;--fnx-placeholder:#9ca3af;--fnx-combobox-bg:#fff;--fnx-combobox-fg:#111827;--fnx-combobox-item-bg:#fff;--fnx-combobox-item-fg:#111827;--fnx-combobox-item-hover-bg:#f3f4f6;--fnx-combobox-item-selected-bg:#00d9d9;--fnx-combobox-item-selected-fg:#111827;--fnx-toggle-bg:#e5e7eb;--fnx-toggle-bg-checked:#00d9d9;--fnx-toggle-thumb:#fff;--fnx-error-text:#dc2626;--fnx-error-bg:#fef2f2;--fnx-notification-badge:#ff6b6b;--fnx-accent:#00d9d9;--fnx-accent-hover:#00f0f0;--fnx-badge-primary-bg:#00d9d9;--fnx-badge-secondary-bg:#00b8b8}[data-theme=dark]{--fnx-window-bg:#2a2f38;--fnx-card-bg:#3d4451;--fnx-surface-bg:#1f2328;--fnx-header-bg:#3d4451;--fnx-text-primary:#fff;--fnx-text-secondary:#9ca3af;--fnx-text-on-primary:#fff;--fnx-table-bg:#3d4451;--fnx-table-fg:#f3f4f6;--fnx-table-header-bg:#4b5563;--fnx-table-header-fg:#fff;--fnx-table-row-alt:#4b5563;--fnx-table-row-hover:#6b7280;--fnx-table-row-selected:#00d9d9;--fnx-table-border:#6b7280;--fnx-border:#4b5563;--fnx-border-color:#4b5563;--fnx-border-focus:#00d9d9;--fnx-btn-primary-bg:#00d9d9;--fnx-btn-primary-bg-hover:#00f0f0;--fnx-btn-primary-bg-pressed:#00c0c0;--fnx-btn-primary-fg:#1f2328;--fnx-input-bg:#3d4451;--fnx-input-fg:#fff;--fnx-placeholder:#6b7280;--fnx-combobox-bg:#3d4451;--fnx-combobox-fg:#fff;--fnx-combobox-item-bg:#2a2f38;--fnx-combobox-item-fg:#fff;--fnx-combobox-item-hover-bg:#4b5563;--fnx-combobox-item-selected-bg:#00d9d9;--fnx-combobox-item-selected-fg:#1f2328;--fnx-toggle-bg:#4b5563;--fnx-toggle-bg-checked:#00d9d9;--fnx-toggle-thumb:#fff;--fnx-error-text:#f87171;--fnx-error-bg:#7f1d1d;--fnx-notification-badge:#ff6b6b;--fnx-accent:#00d9d9;--fnx-accent-hover:#00f0f0;--fnx-badge-primary-bg:#00d9d9;--fnx-badge-secondary-bg:#00b8b8}@media (prefers-color-scheme:dark){:root:not([data-theme=light]){--fnx-window-bg:#2a2f38;--fnx-card-bg:#3d4451;--fnx-surface-bg:#1f2328;--fnx-header-bg:#3d4451;--fnx-text-primary:#fff;--fnx-text-secondary:#9ca3af;--fnx-table-bg:#3d4451;--fnx-table-fg:#f3f4f6;--fnx-table-header-bg:#4b5563;--fnx-table-header-fg:#fff;--fnx-table-row-alt:#4b5563;--fnx-table-row-hover:#6b7280;--fnx-table-border:#6b7280;--fnx-border:#4b5563;--fnx-border-color:#4b5563;--fnx-btn-primary-fg:#1f2328;--fnx-input-bg:#3d4451;--fnx-input-fg:#fff;--fnx-placeholder:#6b7280;--fnx-combobox-bg:#3d4451;--fnx-combobox-fg:#fff;--fnx-combobox-item-bg:#2a2f38;--fnx-combobox-item-fg:#fff;--fnx-combobox-item-hover-bg:#4b5563;--fnx-combobox-item-selected-fg:#1f2328;--fnx-toggle-bg:#4b5563;--fnx-error-text:#f87171;--fnx-error-bg:#7f1d1d}}:root{--shell-sidebar-bg:var(--fnx-window-bg);--shell-bg:var(--fnx-surface-bg);--shell-text:var(--fnx-text-primary);--shell-text-muted:var(--fnx-text-secondary);--shell-border:var(--fnx-border);--shell-sidebar-text:var(--fnx-text-primary);--shell-sidebar-text-muted:var(--fnx-text-secondary);--bg:var(--olive-1);--bg-secondary:var(--olive-2);--text:var(--olive-12);--text-muted:var(--olive-11);--border:var(--olive-6);--border-focus:var(--olive-8);--accent:var(--olive-12);--accent-hover:var(--olive-11);--error:var(--fnx-error-text);--error-bg:var(--fnx-error-bg);--font-sans:"Inter", system-ui, -apple-system, sans-serif;--font-weight-light:300;--font-weight-normal:400;--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--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;--space-1:.25rem;--space-2:.5rem;--space-3:.75rem;--space-4:1rem;--space-6:1.5rem;--space-8:2rem;--space-12:3rem;--radius-sm:.375rem;--radius-md:.5rem;--radius-lg:.75rem;--radius-xl:1rem;font-family:var(--font-sans);font-size:16px;line-height:1.5;font-weight:var(--font-weight-normal);color:var(--text);background-color:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}[data-theme=dark]{--shell-sidebar-bg:var(--fnx-window-bg);--shell-bg:var(--fnx-surface-bg);--shell-text:var(--fnx-text-primary);--shell-text-muted:var(--fnx-text-secondary);--shell-border:var(--fnx-border);--shell-sidebar-text:var(--fnx-text-primary);--shell-sidebar-text-muted:var(--fnx-text-secondary);--bg:var(--fnx-surface-bg);--bg-secondary:var(--fnx-card-bg);--text:var(--fnx-text-primary);--text-muted:var(--fnx-text-secondary);--border:var(--fnx-border);--border-focus:var(--fnx-border-focus);--accent:var(--fnx-accent);--accent-hover:var(--fnx-accent-hover);--error:var(--fnx-error-text);--error-bg:var(--fnx-error-bg);--text-primary:var(--fnx-text-primary,#fff);--text-secondary:var(--fnx-text-secondary,#9ca3af);--chip-bg:#1a3a4a;--chip-border:#2d5a7b;--pool-chip-bg:#1a3a2a;--pool-chip-border:#2d7b4f;--chip-text:#fff}*,:before,:after{box-sizing:border-box}body{min-height:100vh;margin:0}#root{width:100%}.login-container{min-height:100vh;padding:var(--space-6);background:linear-gradient(135deg, var(--olive-2) 0%, var(--olive-3) 100%);justify-content:center;align-items:center;animation:.6s ease-out fadeIn;display:flex}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.login-card{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-xl);width:100%;max-width:28rem;padding:var(--space-8);box-shadow:var(--shadow-lg);animation:.5s ease-out .1s both slideUp}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.login-header{text-align:center;margin-bottom:var(--space-8);animation:.5s ease-out .2s both slideUp}.login-logo{width:48px;height:48px;margin:0 auto var(--space-4);background:var(--olive-12);border-radius:var(--radius-lg);justify-content:center;align-items:center;display:flex}.login-logo svg{width:28px;height:28px;color:var(--olive-1)}.login-title{font-size:1.5rem;font-weight:var(--font-weight-semibold);color:var(--text);margin:0 0 var(--space-2);letter-spacing:-.025em}.login-subtitle{color:var(--text-muted);margin:0;font-size:.875rem}.login-form{gap:var(--space-4);flex-direction:column;display:flex}.form-group{gap:var(--space-2);flex-direction:column;animation:.5s ease-out .3s both slideUp;display:flex}.form-group:nth-child(2){animation-delay:.35s}.form-group:nth-child(3){animation-delay:.4s}.form-group:nth-child(4){animation-delay:.45s}.form-label{font-size:.875rem;font-weight:var(--font-weight-medium);color:var(--text)}.form-input{width:100%;padding:var(--space-3) var(--space-4);font-size:1rem;font-family:var(--font-sans);color:var(--text);background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-md);transition:border-color .15s,box-shadow .15s}.form-input:focus{border-color:var(--olive-9);outline:none;box-shadow:0 0 0 3px #898e8726}.form-input::placeholder{color:var(--olive-8)}.form-input.error{border-color:var(--error)}.form-input.error:focus{box-shadow:0 0 0 3px #b91c1c1a}.password-wrapper{position:relative}.password-toggle{right:var(--space-3);padding:var(--space-1);cursor:pointer;color:var(--text-muted);background:0 0;border:none;transition:color .15s;position:absolute;top:50%;transform:translateY(-50%)}.password-toggle:hover{color:var(--text)}.submit-button{width:100%;padding:var(--space-3) var(--space-4);font-size:1rem;font-weight:var(--font-weight-medium);font-family:var(--font-sans);color:var(--olive-1);background:var(--olive-12);border-radius:var(--radius-md);cursor:pointer;margin-top:var(--space-2);border:none;transition:background-color .15s,transform .1s;animation:.5s ease-out .5s both slideUp}.submit-button:hover:not(:disabled){background:var(--olive-11)}.submit-button:active:not(:disabled){transform:scale(.98)}.submit-button:disabled{opacity:.6;cursor:not-allowed}.error-message{align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);background:var(--error-bg);border-radius:var(--radius-md);color:var(--error);border:1px solid #fecaca;font-size:.875rem;animation:.4s ease-out shake;display:flex}@keyframes shake{0%,to{transform:translate(0)}20%{transform:translate(-4px)}40%{transform:translate(4px)}60%{transform:translate(-4px)}80%{transform:translate(4px)}}.error-message svg{flex-shrink:0;width:18px;height:18px}.loading-spinner{border:2px solid #0000;border-top-color:currentColor;border-radius:50%;width:18px;height:18px;animation:.7s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.bootstrap-notice{text-align:center;padding:var(--space-4);background:var(--olive-3);border-radius:var(--radius-md);margin-bottom:var(--space-4);animation:.5s ease-out .25s both slideUp}.bootstrap-notice p{color:var(--text-muted);margin:0;font-size:.875rem}.page-header{justify-content:space-between;align-items:center;margin-bottom:2rem;display:flex}.table-container{background:var(--card-bg);border:1px solid var(--border);border-radius:8px}.reports-table{border-collapse:collapse;width:100%;font-family:Inter,system-ui,sans-serif}.reports-table th{background:var(--fnx-table-header-bg);text-align:left;color:var(--text-secondary);border-bottom:1px solid var(--border);z-index:1;padding:.75rem 1rem;font-size:.875rem;font-weight:600;position:sticky;top:0}.reports-table td{color:var(--fnx-text-primary);border-bottom:1px solid var(--fnx-table-border);padding:1rem;font-size:.875rem}.reports-table tbody tr:last-child td{border-bottom:none}.cell-content{max-width:400px}.content-preview{color:var(--text-muted)}.content-empty{color:var(--fnx-placeholder)}.btn-secondary{background:var(--bg-secondary,#f3f4f6);color:var(--text,#374151)}.btn-danger{color:#fff;background:#ef4444}.btn-approve{color:#fff;background:#10b981}.btn-approve:hover{background:#059669}.btn:disabled{opacity:.5;cursor:not-allowed}.dialog{background:var(--fnx-window-bg,#fff);border-radius:12px;flex-direction:column;width:90%;max-width:800px;max-height:90vh;display:flex;overflow:hidden;box-shadow:0 25px 50px -12px #00000040}.dialog-header{background:var(--fnx-window-bg,#fff);border-bottom:1px solid var(--fnx-border,#e5e7eb);padding:1.25rem 1.5rem}.dialog-footer{background:var(--fnx-surface-bg,#f3f4f6);border-top:1px solid var(--fnx-border,#e5e7eb);padding:1rem 1.5rem}.dialog-header h2{color:var(--text);margin:0;font-size:1.25rem;font-weight:700}.dialog-close{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;width:2rem;height:2rem;padding:0;font-size:1.75rem;line-height:1;display:flex}.dialog-close:hover{background:var(--bg-hover);color:var(--text)}.dialog-loading{justify-content:center;padding:4rem;display:flex}.dialog-body{scrollbar-gutter:stable;flex:1;min-height:400px;max-height:70vh;padding:1.5rem;overflow-y:scroll}.dialog-body::-webkit-scrollbar{width:8px}.dialog-body::-webkit-scrollbar-track{background:var(--fnx-surface-bg,#f3f4f6)}.dialog-body::-webkit-scrollbar-thumb{background:var(--text-muted,#9ca3af);border-radius:4px}.dialog-footer{justify-content:flex-end;gap:.75rem;display:flex}.dialog-section{border:1px solid var(--fnx-border,#e5e7eb);background:var(--fnx-card-bg,#f9fafb);border-radius:8px;margin-bottom:1rem;padding:1rem}.dialog-section legend{color:var(--text);padding:0 .5rem;font-weight:600}.form-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1rem;display:grid}.form-group{flex-direction:column;gap:.375rem;display:flex}.form-group label{color:var(--text-secondary);font-size:.875rem;font-weight:500}.form-group input,.form-group select,.form-group textarea{border:2px solid var(--border,#e5e7eb);background:var(--bg-primary);color:var(--text);border-radius:6px;padding:.625rem .875rem;font-family:inherit;font-size:.9375rem;transition:border-color .2s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--fnx-btn-primary-bg,#3b82f6);outline:none}.form-group input.readonly,.form-group input:read-only{background:var(--bg-secondary);color:var(--text-muted)}.form-group textarea{resize:vertical;min-height:60px}.error-message{color:#dc2626;background:#fef2f2;border:1px solid #fecaca;border-radius:6px;margin-bottom:1rem;padding:.75rem 1rem;font-size:.875rem}.filter-bar{background:var(--bg-secondary);border-radius:8px;flex-wrap:wrap;align-items:flex-end;gap:1rem;margin-bottom:1rem;padding:1rem;display:flex}.filter-group{flex-direction:column;gap:.375rem;display:flex}.filter-group label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;font-size:.75rem;font-weight:600}.filter-group input,.filter-group select{border:2px solid var(--border,#e5e7eb);background:var(--bg-primary);color:var(--text);border-radius:6px;min-width:140px;padding:.5rem .75rem;font-size:.875rem}.action-toolbar{flex-wrap:wrap;align-items:center;gap:.5rem;margin-bottom:1rem;display:flex}.toolbar-divider{background:var(--border);width:1px;height:2rem;margin:0 .5rem}.reports-table{border-collapse:collapse;width:100%}.reports-table th{text-align:left;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);background:var(--fnx-table-header-bg);border-bottom:2px solid var(--border);padding:.75rem 1rem;font-size:.75rem;font-weight:600}.reports-table td{border-bottom:1px solid var(--border);color:var(--text);padding:.75rem 1rem;font-size:.875rem}.reports-table tbody tr{cursor:pointer;transition:background-color .15s}.reports-table tbody tr:hover{background:var(--bg-hover)}.reports-table tbody tr.selected{background:var(--fnx-btn-primary-bg-hover,#dbeafe)}.status-badge{color:#fff;text-transform:uppercase;letter-spacing:.025em;border-radius:9999px;padding:.25rem .75rem;font-size:.75rem;font-weight:600;display:inline-block}.clone-badge{margin-left:.5rem;font-size:.875rem}.cell-date{align-items:center;display:flex}@media print{.filter-bar,.action-toolbar,.dialog-overlay>:not(.dialog){display:none!important}.dialog{width:100%;max-width:none;max-height:none;box-shadow:none;position:static}}.photo-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:.75rem;margin-bottom:.75rem;display:grid}.photo-thumbnail{cursor:pointer;border:2px solid var(--border,#e5e7eb);background:var(--bg-secondary);border-radius:6px;justify-content:center;align-items:center;width:150px;height:112px;transition:border-color .2s,transform .2s;display:flex;overflow:hidden}.photo-thumbnail:hover{border-color:var(--fnx-btn-primary-bg,#3b82f6);transform:scale(1.02)}.photo-thumbnail img{object-fit:cover;width:100%;height:100%}.photo-hint{color:var(--text-muted);margin:0;font-size:.75rem;font-style:italic}.attachments-loading,.attachments-empty{color:var(--text-muted);text-align:center;padding:1rem;font-size:.875rem}.lightbox-overlay{z-index:2000;background:#000000e6;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.lightbox-content{flex-direction:column;align-items:center;max-width:90vw;max-height:90vh;display:flex;position:relative}.lightbox-content img{object-fit:contain;border-radius:4px;max-width:100%;max-height:85vh}.lightbox-close{color:#fff;cursor:pointer;background:0 0;border:none;padding:.25rem .5rem;font-size:2rem;line-height:1;position:absolute;top:-2rem;right:0}.lightbox-close:hover{color:#ccc}.lightbox-filename{color:#fff;text-align:center;margin-top:.5rem;font-size:.875rem}.markdown-attachments{flex-direction:column;gap:1rem;display:flex}.markdown-attachment{border:2px solid var(--border,#e5e7eb);border-radius:8px;overflow:hidden}.markdown-filename{background:var(--bg-secondary);color:var(--text);border-bottom:1px solid var(--border);padding:.5rem .75rem;font-size:.875rem;font-weight:600}.markdown-content{padding:.75rem;font-size:.9375rem;line-height:1.6}.markdown-content h1{margin:0 0 .5rem;font-size:1.5rem}.markdown-content h2{margin:.5rem 0;font-size:1.25rem}.markdown-content h3{margin:.5rem 0;font-size:1.1rem}.markdown-content p{margin:.5rem 0}.markdown-content ul,.markdown-content ol{margin:.5rem 0;padding-left:1.5rem}.markdown-content li{margin:.25rem 0}.markdown-content code{background:var(--bg-secondary);border-radius:4px;padding:.125rem .375rem;font-size:.875em}.markdown-content pre{background:var(--bg-secondary);border-radius:6px;padding:.75rem;overflow-x:auto}.markdown-content pre code{background:0 0;padding:0}.markdown-raw{white-space:pre-wrap;word-break:break-word;color:var(--text);margin:0;padding:.75rem;font-size:.875rem}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:2rem;display:flex}.page-title{color:var(--text);margin:0;font-family:Inter,system-ui,sans-serif;font-size:1.75rem;font-weight:700}.btn{cursor:pointer;border:none;border-radius:8px;align-items:center;gap:.5rem;padding:.75rem 1.25rem;font-family:Inter,system-ui,sans-serif;font-size:.9375rem;font-weight:600;transition:all .2s;display:inline-flex}.btn svg{width:18px;height:18px}.btn-primary{background:var(--fnx-btn-primary-bg);color:var(--fnx-btn-primary-fg)}.view-toggle{gap:.5rem;margin-bottom:1.5rem;display:flex}.toggle-btn{border:1px solid var(--fnx-border);background:var(--fnx-input-bg);color:var(--text-muted);cursor:pointer;border-radius:6px;padding:.5rem 1rem;font-family:Inter,system-ui,sans-serif;font-size:.875rem;font-weight:500;transition:all .2s}.toggle-btn.active{background:var(--fnx-btn-primary-bg);color:var(--fnx-btn-primary-fg);border-color:var(--fnx-btn-primary-bg)}.toggle-btn:hover:not(.active){background:var(--fnx-table-row-hover)}.location-group{margin-bottom:2rem;transition:transform .2s}.location-group:hover{cursor:grab}.location-group[aria-roledragging=true]{opacity:.5}.location-title{color:var(--text);margin:0 0 1rem;font-family:Inter,system-ui,sans-serif;font-size:1.125rem;font-weight:600}.loading-state{justify-content:center;padding:4rem;display:flex}.empty-state{color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;padding:4rem;display:flex}.empty-state svg{opacity:.4;width:64px;height:64px;margin-bottom:1rem}.empty-state p{margin:0;font-family:Inter,system-ui,sans-serif;font-size:1rem}.table-container{background:var(--card-bg);border-radius:8px;overflow:auto}.employees-table{border-collapse:collapse;table-layout:fixed;width:100%;min-width:0;font-family:Inter,system-ui,sans-serif}.employees-table th{background:var(--fnx-table-header-bg);color:var(--text-secondary);z-index:1;border-bottom:1px solid var(--border);padding:.75rem 1rem;font-size:.875rem;font-weight:600;position:sticky;top:0}.employees-table th:first-child{width:20%}.employees-table th:nth-child(2){width:25%}.employees-table th:nth-child(3){width:15%}.employees-table th:nth-child(4),.employees-table th:nth-child(5){width:10%}.employees-table th:last-child{text-align:center;width:20%;min-width:180px}.employees-table td:last-child{text-align:center;white-space:nowrap;overflow:visible}.employees-table th:first-child,.employees-table th:nth-child(2){text-align:left}.employees-table td{color:var(--fnx-text-primary);border-bottom:1px solid var(--fnx-table-border);text-align:center;padding:.875rem .75rem;font-size:.875rem}.employees-table td:nth-child(2){text-align:left}.employees-table td.cell-actions{text-align:center}.employees-table tbody tr:hover{background:var(--fnx-table-row-hover)}.employees-table tbody tr:last-child td{border-bottom:none}.cell-name{justify-content:flex-start;align-items:center;gap:.75rem;font-weight:500;display:flex}.employee-avatar{background:var(--fnx-btn-primary-bg);width:36px;height:36px;color:var(--fnx-btn-primary-fg);text-transform:uppercase;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.75rem;font-weight:700;display:flex}.cell-date{white-space:nowrap}.status-badge{border-radius:9999px;padding:.25rem .625rem;font-size:.75rem;font-weight:700;display:inline-block}.btn-edit{background:var(--fnx-table-row-hover);border:1px solid var(--fnx-border);color:var(--text);cursor:pointer;white-space:nowrap;border-radius:6px;justify-content:center;align-items:center;gap:.375rem;min-width:90px;padding:.5rem .75rem;font-family:Inter,system-ui,sans-serif;font-size:.8125rem;font-weight:500;transition:all .2s;display:inline-flex}.btn-edit svg{width:14px;height:14px}.btn-delete{background:var(--fnx-error-bg);border:1px solid var(--fnx-border);color:var(--fnx-error-text);cursor:pointer;white-space:nowrap;border-radius:6px;justify-content:center;align-items:center;gap:.375rem;min-width:90px;margin-left:.5rem;padding:.5rem .75rem;font-family:Inter,system-ui,sans-serif;font-size:.8125rem;font-weight:500;transition:all .2s;display:inline-flex}.btn-delete:hover{color:#b91c1c;background:#fecaca}.btn-edit:hover{background:var(--fnx-border);color:var(--text)}.modal-overlay{z-index:1000;background:#00000080;justify-content:center;align-items:flex-start;padding:1rem;display:flex;position:fixed;inset:0;overflow-y:auto}.modal{background:var(--fnx-window-bg);border-radius:12px;width:100%;max-width:800px;margin:2rem auto;padding:1.5rem;box-shadow:0 20px 40px #0003}.modal h2{color:var(--text);margin:0 0 1.5rem;font-family:Inter,system-ui,sans-serif;font-size:1.25rem;font-weight:700}.modal form{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.modal .form-group{margin-bottom:0}.modal .form-group:nth-child(11),.modal .form-group:nth-child(12),.modal .modal-actions{grid-column:1/-1}@media (width<=600px){.modal form{grid-template-columns:1fr}}.form-group input{border:1px solid var(--fnx-border);width:100%;color:var(--fnx-text-primary);box-sizing:border-box;background:var(--fnx-input-bg);border-radius:8px;padding:.625rem .875rem;font-family:Inter,system-ui,sans-serif;font-size:.9375rem}.form-group input:focus{border-color:var(--fnx-border-focus);outline:none;box-shadow:0 0 0 3px #00d9d91a}.form-group select{border:1px solid var(--fnx-border);width:100%;color:var(--fnx-text-primary);box-sizing:border-box;background:var(--fnx-input-bg);border-radius:8px;padding:.625rem .875rem;font-family:Inter,system-ui,sans-serif;font-size:.9375rem}.modal-actions{justify-content:flex-end;gap:.75rem;margin-top:1.5rem;display:flex}.btn-cancel{background:var(--fnx-table-row-hover);border:1px solid var(--fnx-border);color:var(--text);cursor:pointer;border-radius:8px;padding:.625rem 1rem;font-family:Inter,system-ui,sans-serif;font-size:.9375rem;font-weight:500}.btn-save{background:var(--fnx-btn-primary-bg);color:var(--fnx-btn-primary-fg);cursor:pointer;border:none;border-radius:8px;padding:.625rem 1rem;font-family:Inter,system-ui,sans-serif;font-size:.9375rem;font-weight:600}.btn-save:hover{background:var(--fnx-btn-primary-bg-hover)}.btn-save:disabled{opacity:.6;cursor:not-allowed}@media (width<=1024px){.main-content{margin-left:0;padding:1.5rem}.page-header{flex-direction:column;align-items:flex-start;gap:1rem}.page-title{font-size:1.5rem}}@media (width<=768px){.main-content{padding:4rem 1rem 1rem}.page-container{padding:0}.page-header{flex-direction:column;align-items:stretch;gap:1rem;margin-bottom:1.5rem}.page-title{font-size:1.25rem}.btn-primary{justify-content:center;width:100%}.btn-edit,.btn-delete{max-width:90px;padding:.375rem .5rem;font-size:.75rem;visibility:visible!important;min-width:70px!important;display:inline-flex!important}.btn-edit span{display:inline}.employees-table{table-layout:auto;font-size:.75rem}.employees-table th,.employees-table td{padding:.5rem .375rem;visibility:visible!important}.employees-table th:nth-child(3),.employees-table td:nth-child(3),.employees-table th:nth-child(5),.employees-table td:nth-child(5){display:none!important}.employee-avatar{width:28px;height:28px;font-size:.625rem}.cell-name{flex-direction:row;align-items:center;gap:.5rem}}@media (width<=480px){.modal{border-radius:8px;padding:1rem}.modal h2{font-size:1.125rem}.modal-actions{flex-direction:column}.btn-cancel,.btn-save{text-align:center;justify-content:center;width:100%}}.btn-edit,.btn-delete{cursor:pointer;border:none;border-radius:6px;justify-content:center;align-items:center;padding:.375rem;transition:all .2s;display:flex}.btn-edit{background:var(--fnx-btn-primary-bg,#3b82f6);color:#fff}.btn-edit:hover{background:var(--fnx-btn-primary-bg-hover,#2563eb)}.btn-delete{color:#fff;background:#ef4444}.btn-delete:hover{background:#dc2626}.btn-edit svg,.btn-delete svg{width:16px;height:16px}.projekte-table th{background:var(--fnx-table-header-bg);color:var(--text-secondary);z-index:1;border-bottom:1px solid var(--border);padding:.75rem 1rem;font-size:.875rem;font-weight:600;position:sticky;top:0}.employee-transfer{margin-top:1rem}.transfer-list{align-items:center;gap:1rem;display:flex}.transfer-column{flex:1}.transfer-column select{width:100%;height:120px}.transfer-buttons{flex-direction:column;gap:.5rem;display:flex}.transfer-buttons button{background:var(--accent-color,#3b82f6);color:#fff;cursor:pointer;border:none;border-radius:4px;padding:.5rem 1rem}.transfer-buttons button:disabled{opacity:.5;cursor:not-allowed}.project-locations{background:var(--surface-bg,#f8fafc);border-radius:8px;padding:1rem}.location-add{gap:.5rem;margin-bottom:.75rem;display:flex}.location-add input{border:1px solid var(--border,#e2e8f0);border-radius:6px;flex:1;padding:.5rem;font-size:.875rem}.location-add button{background:var(--accent-color,#3b82f6);color:#fff;cursor:pointer;border:none;border-radius:6px;padding:.5rem 1rem;font-size:.875rem}.location-add button:hover{background:var(--accent-color-hover,#2563eb)}.locations-list{flex-direction:column;gap:.5rem;display:flex}.location-item{background:var(--card-bg,white);border:1px solid var(--border,#e2e8f0);border-radius:6px;overflow:hidden}.location-header{align-items:center;gap:.5rem;padding:.5rem .75rem;display:flex}.location-desc{flex:1;font-size:.875rem}.btn-expand,.btn-remove{cursor:pointer;color:var(--text-secondary,#64748b);background:0 0;border:none;padding:.25rem .5rem;font-size:.75rem}.btn-remove:hover{color:#ef4444}.location-remarks{border-top:1px solid var(--border,#e2e8f0);background:var(--surface-bg,#f8fafc);padding:.5rem .75rem}.location-remarks textarea{border:1px solid var(--border,#e2e8f0);resize:vertical;border-radius:4px;width:100%;padding:.5rem;font-size:.813rem}.no-locations{color:var(--text-secondary,#64748b);margin:0;font-size:.813rem;font-style:italic}.customers-table th{background:var(--fnx-table-header-bg);color:var(--text-secondary);border-bottom:1px solid var(--border);text-align:left;padding:.75rem 1rem;font-size:.875rem;font-weight:600}.customers-table td{border-bottom:1px solid var(--border);padding:.75rem 1rem;font-size:.875rem}.customers-table tr:hover{background:var(--fnx-table-hover-bg)}.cell-name{font-weight:500}.cell-actions{gap:.5rem;display:flex}.rollen-layout{gap:1.5rem;height:calc(100vh - 140px);display:flex}.rollen-sidebar{background:var(--card-bg);border-radius:8px;flex-direction:column;flex-shrink:0;width:200px;padding:1rem;display:flex}.sidebar-header-row{justify-content:space-between;align-items:center;margin-bottom:.75rem;display:flex}.sidebar-header-row h3{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin:0;font-size:.875rem}.btn-add{background:var(--fnx-btn-primary-bg,#3b82f6);width:32px;height:32px;color:var(--fnx-btn-primary-fg,#fff);cursor:pointer;border:none;border-radius:8px;justify-content:center;align-items:center;padding:0;transition:all .15s;display:flex}.btn-add:hover{background:var(--fnx-btn-primary-bg-hover,#2563eb)}.btn-add svg{width:18px;height:18px}.role-list{flex-direction:column;gap:.25rem;display:flex}.role-item{text-align:left;width:100%;color:var(--text-primary);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:.75rem 1rem;font-size:.9375rem;transition:background .15s}.role-item:hover{background:var(--hover-bg)}.role-item.active{background:color-mix(in srgb, var(--primary) 20%, transparent);color:var(--primary);font-weight:600}.rollen-matrix{flex-direction:column;flex:1;min-width:0;display:flex}.matrix-header{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.matrix-header h2{font-size:1.25rem;font-weight:600}.matrix-table-container{background:var(--card-bg);border-radius:8px;flex:1;overflow:auto}.matrix-table{border-collapse:collapse;width:100%;min-width:500px}.matrix-table th,.matrix-table td{text-align:left;border-bottom:1px solid var(--border);padding:.75rem 1rem}.matrix-table th{background:var(--fnx-table-header-bg);color:var(--text-secondary);z-index:1;font-size:.875rem;font-weight:600;position:sticky;top:0}.col-feature{width:40%}.col-access{width:20%;text-align:center!important}.col-access input[type=radio]{cursor:pointer;width:18px;height:18px;accent-color:var(--primary)}.category-row{background:var(--surface-bg)}.category-cell{color:var(--text-primary);font-size:.9375rem;font-weight:600}.col-header input[type=radio]{cursor:pointer;width:20px;height:20px;accent-color:var(--primary)}.perm-name{color:var(--text-secondary);font-size:.875rem}.message{border-radius:6px;margin-bottom:1rem;padding:.75rem 1rem}.message.success{color:#065f46;background:#d1fae5}.message.error{color:#991b1b;background:#fee2e2}.table-container{background:var(--card-bg);border-radius:8px}.benutzer-table{border-collapse:collapse;width:100%}.benutzer-table th,.benutzer-table td{text-align:left;border-bottom:1px solid var(--border);padding:.75rem 1rem}.benutzer-table th{color:var(--text-secondary);background:var(--fnx-table-header-bg);z-index:1;font-size:.875rem;font-weight:600;position:sticky;top:0}.benutzer-table tbody tr:hover{background:var(--hover-bg)}.role-select{border:1px solid var(--border);background:var(--input-bg);color:var(--text-primary);cursor:pointer;border-radius:6px;min-width:150px;padding:.5rem .75rem;font-size:.875rem}.role-select:disabled{opacity:.6;cursor:not-allowed}.status-badge.status-active{color:#fff;background:#10b981;border-radius:4px;padding:.25rem .5rem;font-size:.75rem}.status-badge.status-inactive{color:#fff;background:#6b7280;border-radius:4px;padding:.25rem .5rem;font-size:.75rem}.cell-actions{align-items:center;gap:.5rem;display:flex}.btn-delete{cursor:pointer;color:#fff;background:#ef4444;border:none;border-radius:4px;align-items:center;gap:.25rem;padding:.375rem .625rem;font-size:.8125rem;transition:all .15s;display:flex}.btn-delete:hover{opacity:.85}.btn-delete:disabled{opacity:.5;cursor:not-allowed}.btn-delete svg{width:14px;height:14px}.dialog{background:var(--card-bg);border-radius:12px;width:100%;max-width:440px;overflow:hidden;box-shadow:0 20px 40px #0000004d}.dialog-close{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;padding:0;font-size:1.5rem;line-height:1}.dialog-close:hover{color:var(--text-primary)}.dialog-body{padding:1.25rem}.dialog-footer{border-top:1px solid var(--border);justify-content:flex-end;gap:.75rem;padding:1rem 1.25rem;display:flex}.dialog-error{color:#991b1b;background:#fee2e2;border-radius:6px;margin-bottom:1rem;padding:.75rem 1rem;font-size:.875rem}.sidebar{background:var(--shell-sidebar-bg);z-index:100;flex-direction:column;width:260px;height:100vh;transition:transform .3s;display:flex;position:fixed;top:0;left:0;box-shadow:4px 0 24px #00000014}.sidebar-header{border-bottom:1px solid #ffffff14;padding:1.75rem 1.5rem 1.25rem}.sidebar-logo{color:var(--fnx-accent);letter-spacing:-.02em;margin:0;font-family:Inter,system-ui,sans-serif;font-size:1.5rem;font-weight:700}.sidebar-nav{flex-direction:column;flex:1;gap:.25rem;padding:1rem .75rem;display:flex;overflow-y:auto}.sidebar-nav-item{color:var(--shell-sidebar-text-muted);cursor:pointer;text-align:left;background:0 0;border:none;border-radius:10px;align-items:center;gap:.875rem;width:100%;padding:.875rem 1rem;font-family:Inter,system-ui,sans-serif;font-size:.9375rem;font-weight:500;transition:all .2s cubic-bezier(.4,0,.2,1);display:flex}.sidebar-nav-item svg{opacity:.85;flex-shrink:0;width:20px;height:20px;transition:opacity .2s}.sidebar-nav-item:hover{color:var(--shell-sidebar-text);background:#ffffff14}.sidebar-nav-item:hover svg{opacity:1}.sidebar-nav-item.active{background:var(--shell-bg);color:var(--shell-sidebar-text);box-shadow:0 2px 8px #00000026}.sidebar-nav-item.active svg{opacity:1}.nav-tree-node{flex-direction:column;display:flex}.nav-tree-node .sidebar-nav-item.has-children{justify-content:flex-start}.nav-chevron{flex-shrink:0;width:16px;height:16px;margin-right:.25rem;transition:transform .2s}.nav-chevron.expanded{transform:rotate(90deg)}.nav-tree-children{flex-direction:column;gap:.125rem;margin-top:.125rem;padding-left:1.5rem;display:flex}.nav-tree-children .sidebar-nav-item{padding:.625rem .875rem;font-size:.875rem}.sidebar-footer{border-top:1px solid #ffffff14;flex-direction:column;gap:.75rem;padding:1rem .75rem;display:flex}.sidebar-user{background:#ffffff0d;border-radius:10px;flex-direction:column;gap:.125rem;padding:.75rem 1rem;display:flex}.sidebar-user-name{color:var(--shell-sidebar-text);font-family:Inter,system-ui,sans-serif;font-size:.875rem;font-weight:600}.sidebar-user-role{color:var(--shell-sidebar-text-muted);text-transform:capitalize;font-family:Inter,system-ui,sans-serif;font-size:.75rem}.sidebar-logout{color:var(--shell-sidebar-text-muted);cursor:pointer;text-align:left;background:#ffffff0d;border:none;border-radius:10px;align-items:center;gap:.875rem;width:100%;padding:.875rem 1rem;font-family:Inter,system-ui,sans-serif;font-size:.9375rem;font-weight:500;transition:all .2s cubic-bezier(.4,0,.2,1);display:flex}.sidebar-logout svg{flex-shrink:0;width:20px;height:20px}.sidebar-logout:hover{color:var(--fnx-error-text);background:#dc262633}.theme-toggle{color:var(--shell-sidebar-text-muted);cursor:pointer;text-align:left;background:#ffffff0d;border:none;border-radius:10px;align-items:center;gap:.625rem;width:100%;padding:.75rem 1rem;font-family:Inter,system-ui,sans-serif;font-size:.875rem;font-weight:500;transition:all .2s cubic-bezier(.4,0,.2,1);display:flex}.theme-toggle svg{flex-shrink:0;width:18px;height:18px}.theme-toggle:hover{color:var(--shell-sidebar-text);background:#ffffff1a}.mobile-menu-btn{z-index:200;background:var(--fnx-accent);color:#fff;cursor:pointer;border:none;border-radius:8px;width:44px;height:44px;padding:.5rem;display:none;position:fixed;top:1rem;left:1rem;box-shadow:0 2px 8px #00000040}.mobile-menu-btn:hover{background:var(--olive-9)}.mobile-menu-btn svg{width:24px;height:24px}.sidebar-overlay{z-index:99;background:#00000080;display:none;position:fixed;inset:0}@media (width<=1024px){.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.mobile-menu-btn{justify-content:center;align-items:center;display:flex}.sidebar-overlay.open{display:block}.main-content{margin-left:0;padding:5rem 1rem 1rem}}@media (width<=480px){.main-content{padding:5rem 1rem 1rem}}.planung-page{box-sizing:border-box;flex-direction:column;width:100%;min-width:0;max-width:100%;height:calc(100vh - 64px);display:flex;overflow:hidden}.planung-matrix{background:var(--card-bg);min-width:max-content;transform:scale(var(--matrix-scale,1));transform-origin:0 0;border-radius:8px;flex-direction:column;font-size:13px;display:flex}.matrix-header{z-index:20;background:var(--fnx-table-header-bg,#f5f7fa);flex-shrink:0;display:flex;position:sticky}.matrix-header-row1{border-bottom:1px solid var(--border-color,#ddd);top:0}.matrix-header-row2{border-bottom:2px solid var(--border-color,#ddd);top:48px}.matrix-body{flex-direction:column;display:flex}.matrix-row{border-bottom:1px solid var(--border-color,#eee);flex-shrink:0;min-height:80px;display:flex}.matrix-row:hover{background:var(--hover-bg,#f8f9fa)}.header-cell{height:48px;color:var(--text-secondary,#555);border-right:1px solid var(--border-color,#eee);text-align:center;box-sizing:border-box;flex-shrink:0;justify-content:center;align-items:center;padding:0 .75rem;font-size:.875rem;font-weight:600;display:flex}.date-header,.row-header{flex-shrink:0;width:100px;min-width:100px;max-width:100px}.available-header,.available-lane{flex-shrink:0;width:160px;min-width:160px;max-width:160px}.column-name-cell,.project-header-cell,.day-cell:not(.special-cell){flex-shrink:0;width:180px;min-width:180px;max-width:180px}.sick-header-cell,.vacation-header-cell,.special-cell{flex-shrink:0;width:130px;min-width:130px;max-width:130px}.date-header,.row-header.date-cell{z-index:15;background:var(--card-bg,#fff);position:sticky;left:0}.matrix-header-row1 .date-header,.matrix-header-row2 .date-header{z-index:25;background:var(--fnx-table-header-bg,#f5f7fa)}.column-name-cell .column-header{width:100%;height:100%;color:var(--text-primary,#222);justify-content:center;align-items:center;font-weight:600;display:flex}.project-header-cell{background:var(--bg-secondary,#fafafa);cursor:pointer;font-size:.75rem}.project-chip{color:#fff;white-space:nowrap;text-overflow:ellipsis;border-radius:4px;max-width:100%;padding:2px 8px;font-size:11px;font-weight:500;display:inline-block;overflow:hidden}.project-empty{color:var(--text-secondary,#999);font-size:11px}.sick-header-cell{color:#c62828;background:#fff5f5}.vacation-header-cell{color:#2e7d32;background:#f5fff5}.row-header{border-right:1px solid var(--border-color,#ddd);justify-content:center;align-items:center;padding:.5rem;font-size:.875rem;font-weight:500;display:flex}.date-cell{background:var(--bg-primary,#fff)}.day-cell{border-right:1px solid var(--border-color,#eee);box-sizing:border-box;flex-direction:column;gap:2px;padding:.25rem;display:flex;overflow:hidden}.day-cell:hover{background:var(--hover-bg,#00000005)}.available-lane{background:var(--bg-secondary,#f8f8f8);border-right:1px solid var(--border-color,#ccc);box-sizing:border-box;flex-direction:column;padding:.25rem;display:flex;overflow:hidden}.lane-content{flex-wrap:wrap;flex:1;align-content:flex-start;gap:2px;display:flex;overflow:hidden}.special-cell{border-right:1px solid var(--border-color,#eee);box-sizing:border-box;flex-direction:column;gap:2px;padding:.25rem;display:flex}.special-cell.sick-cell{background:#fff5f5}.special-cell.vacation-cell{background:#f5fff5;border-right:none}.cell-employees{flex-wrap:wrap;align-content:flex-start;gap:2px;display:flex}.cell-project{min-height:0}.employee-chip{background:var(--chip-bg,#e3f2fd);border:1px solid var(--chip-border,#90caf9);cursor:default;-webkit-user-select:none;user-select:none;touch-action:none;border-radius:10px;align-items:center;gap:4px;padding:2px 6px;font-size:11px;transition:box-shadow .15s,transform .1s;display:inline-flex}.employee-chip.draggable{cursor:grab}.employee-chip.draggable:active{cursor:grabbing}.employee-chip.draggable:hover{box-shadow:0 2px 4px #00000026}.employee-chip.pool-chip{background:var(--pool-chip-bg,#e8f5e9);border-color:var(--pool-chip-border,#a5d6a7)}.chip-name{color:var(--chip-text,var(--text-primary,#333));white-space:nowrap;text-overflow:ellipsis;max-width:120px;font-weight:500;overflow:hidden}.chip-note{color:var(--text-secondary,#666);font-size:10px;font-style:italic}.chip-remove{cursor:pointer;color:var(--text-secondary,#999);background:0 0;border:none;border-radius:50%;margin-left:2px;padding:0 2px;font-size:14px;line-height:1;transition:background .15s,color .15s}.chip-remove:hover{background:var(--danger-color,#ff5252);color:#fff}.item-badge{color:var(--text-secondary,#888);margin-left:4px;font-size:10px}.context-menu{z-index:1000;background:var(--bg-primary,#fff);border:1px solid var(--border-color,#ddd);border-radius:8px;min-width:220px;max-width:320px;padding:4px 0;position:fixed;overflow:hidden;box-shadow:0 4px 16px #00000026}.context-menu-search{border-bottom:1px solid var(--border-color,#eee);padding:8px}.context-menu-search input{border:1px solid var(--border-color,#ddd);box-sizing:border-box;border-radius:4px;outline:none;width:100%;padding:6px 10px;font-size:13px}.context-menu-search input:focus{border-color:var(--primary-color,#2196f3)}.context-menu-list{max-height:240px;padding:4px 0;overflow-y:auto}.context-menu-loading,.context-menu-empty{color:var(--text-secondary,#888);text-align:center;padding:12px 16px;font-size:13px}.context-menu-item{cursor:pointer;align-items:center;gap:8px;padding:8px 16px;transition:background .1s;display:flex}.context-menu-item:hover{background:var(--hover-bg,#f5f5f5)}.context-menu-item.disabled{opacity:.5;cursor:not-allowed}.context-menu-item.danger{color:var(--danger-color,#d32f2f);border-top:1px solid var(--border-color,#eee);margin-top:4px;padding-top:10px}.context-menu-item.danger:hover{background:#ffebee}.item-color{border-radius:3px;flex-shrink:0;width:12px;height:12px}.item-name{flex:1;font-size:13px}.item-number{color:var(--text-secondary,#888);font-size:11px}.loading-state{justify-content:center;align-items:center;padding:48px;display:flex}.loading-spinner{border:3px solid var(--border-color,#eee);border-top-color:var(--primary-color,#2196f3);border-radius:50%;width:32px;height:32px;animation:.8s linear infinite spin}.error-state{color:var(--danger-color,#d32f2f);text-align:center;padding:24px}.matrix-empty{text-align:center;color:var(--text-secondary,#888);padding:48px}.drop-target{outline:2px dashed var(--primary-color,#2196f3);outline-offset:-2px;background:var(--drop-target-bg,#e3f2fd)!important}.employee-chip.dragging{opacity:.5}.dialog-overlay{z-index:1000;background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.dialog{background:var(--bg-primary,#fff);border-radius:12px;flex-direction:column;min-width:400px;max-width:90vw;max-height:90vh;display:flex;overflow:hidden;box-shadow:0 8px 32px #0003}.dialog-header{border-bottom:1px solid var(--border-color,#eee);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.dialog-header h2{margin:0;font-size:18px;font-weight:600}.dialog-close{cursor:pointer;color:var(--text-secondary,#666);background:0 0;border:none;border-radius:4px;padding:4px 8px;font-size:20px}.dialog-close:hover{background:var(--hover-bg,#f0f0f0)}.dialog-content{flex:1;padding:20px;overflow-y:auto}.btn-primary{background:var(--primary-color,#2196f3);color:#fff;cursor:pointer;border:none;border-radius:6px;padding:8px 16px;font-size:14px;transition:background .15s}.btn-primary:hover{background:var(--primary-hover,#1976d2)}.btn-primary:disabled{background:var(--disabled-color,#ccc);cursor:not-allowed}.btn-secondary{background:var(--bg-secondary,#f0f0f0);color:var(--text-primary,#333);border:1px solid var(--border-color,#ddd);cursor:pointer;border-radius:6px;padding:8px 16px;font-size:14px}.btn-secondary:hover{background:var(--hover-bg,#e8e8e8)}.btn-icon{cursor:pointer;color:var(--text-secondary,#666);background:0 0;border:none;border-radius:4px;padding:4px 8px;font-size:14px}.btn-icon:hover{background:var(--hover-bg,#f0f0f0)}.btn-danger-icon:hover{color:var(--danger-color,#d32f2f);background:#ffebee}.btn-sm{padding:4px 10px;font-size:12px}.btn-danger{background:var(--danger-color,#d32f2f);color:#fff;cursor:pointer;border:none;border-radius:4px}.btn-danger:hover{background:#b71c1c}.columns-manager-dialog{width:450px}.new-column-form{gap:8px;margin-bottom:12px;display:flex}.new-column-form input{border:1px solid var(--border-color,#ddd);border-radius:6px;outline:none;flex:1;padding:8px 12px;font-size:14px}.new-column-form input:focus{border-color:var(--primary-color,#2196f3)}.columns-hint{color:var(--text-secondary,#888);margin:0 0 16px;font-size:12px}.columns-list{flex-direction:column;gap:4px;display:flex}.sortable-column{background:var(--bg-secondary,#f8f8f8);border:1px solid var(--border-color,#eee);border-radius:6px;align-items:center;gap:8px;padding:10px 12px;transition:box-shadow .15s,opacity .15s;display:flex}.sortable-column:hover{box-shadow:0 2px 8px #0000001a}.sortable-column.dragging{z-index:10;box-shadow:0 4px 12px #00000026}.column-drag-handle{cursor:grab;color:var(--text-secondary,#999);-webkit-user-select:none;user-select:none;padding:4px;font-size:12px}.column-drag-handle:active{cursor:grabbing}.column-name{cursor:text;flex:1;font-size:14px}.column-name-input{border:1px solid var(--primary-color,#2196f3);border-radius:4px;outline:none;flex:1;padding:4px 8px;font-size:14px}.column-actions{align-items:center;gap:4px;display:flex}.delete-confirm{color:var(--danger-color,#d32f2f);align-items:center;gap:6px;font-size:12px;display:flex}.empty-state{text-align:center;color:var(--text-secondary,#888);padding:32px;font-size:14px}.toast-container{z-index:2000;flex-direction:column;gap:8px;display:flex;position:fixed;bottom:24px;right:24px}.toast{border-radius:8px;align-items:center;gap:12px;min-width:280px;max-width:400px;padding:12px 16px;font-size:14px;animation:.2s ease-out slideIn;display:flex;box-shadow:0 4px 12px #00000026}@keyframes slideIn{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}.toast-error{border-left:4px solid var(--danger-color,#d32f2f);color:#b71c1c;background:#ffebee}.toast-success{color:#1b5e20;background:#e8f5e9;border-left:4px solid #4caf50}.toast-info{border-left:4px solid var(--primary-color,#2196f3);color:#0d47a1;background:#e3f2fd}.toast-message{flex:1}.toast-close{cursor:pointer;color:inherit;opacity:.7;background:0 0;border:none;padding:0 4px;font-size:16px}.toast-close:hover{opacity:1}.employee-chip:focus-visible,.day-cell:focus-visible,.column-header:focus-visible{outline:2px solid var(--primary-color,#2196f3);outline-offset:2px}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.planung-toolbar{background:var(--bg-primary,#fff);border-bottom:1px solid var(--border-color,#eee);flex-shrink:0;justify-content:space-between;align-items:center;gap:16px;padding:12px 16px;display:flex}.toolbar-left,.toolbar-center,.toolbar-right{align-items:center;gap:8px;display:flex}.range-toggle{background:var(--bg-secondary,#f0f0f0);border-radius:6px;display:flex;overflow:hidden}.range-toggle button{cursor:pointer;background:0 0;border:none;padding:6px 12px;font-size:13px;transition:background .15s}.range-toggle button:hover{background:var(--hover-bg,#e8e8e8)}.range-toggle button.active{background:var(--primary-color,#2196f3);color:#fff}.nav-btn{border:1px solid var(--border-color,#ddd);background:var(--bg-primary,#fff);cursor:pointer;border-radius:6px;padding:6px 12px;font-size:14px}.nav-btn:hover{background:var(--hover-bg,#f5f5f5)}.today-btn{border:1px solid var(--primary-color,#2196f3);background:var(--bg-primary,#fff);color:var(--primary-color,#2196f3);cursor:pointer;border-radius:6px;padding:6px 16px;font-size:13px;font-weight:500}.today-btn:hover{background:var(--primary-color,#2196f3);color:#fff}.manage-btn{border:1px solid var(--border-color,#ddd);background:var(--bg-primary,#fff);cursor:pointer;border-radius:6px;padding:6px 16px;font-size:13px}.manage-btn:hover{background:var(--hover-bg,#f5f5f5);border-color:var(--primary-color,#2196f3)}.zoom-controls{align-items:center;gap:4px;margin-right:12px;display:flex}.zoom-btn{border:1px solid var(--border-color,#ddd);background:var(--bg-primary,#fff);cursor:pointer;width:28px;height:28px;color:var(--text-primary,#333);border-radius:4px;justify-content:center;align-items:center;font-size:16px;transition:background .15s;display:flex}[data-theme=dark] .zoom-btn{background:var(--bg-secondary,#3d4451);border-color:var(--border-color,#4b5563);color:var(--text-primary,#fff)}.zoom-btn:hover{background:var(--hover-bg,#e8e8e8)}[data-theme=dark] .zoom-btn:hover{background:var(--hover-bg,#4b5563)}.zoom-label{color:var(--text-primary,#333);text-align:center;min-width:45px;font-size:13px;font-weight:500}[data-theme=dark] .zoom-label{color:var(--text-primary,#fff)}.planung-matrix-wrapper{flex:1;min-width:0;min-height:0;overflow:auto}.planung2-page{box-sizing:border-box;flex-direction:column;width:100%;min-width:0;max-width:100%;height:calc(100vh - 64px);display:flex;overflow:hidden}.planung2-table-wrapper{flex:1;min-width:0;min-height:0;overflow:auto}.planung2-table{border-collapse:collapse;background:var(--card-bg);border-radius:8px;width:100%;font-size:13px}.planung2-table th,.planung2-table td{text-align:left;border-bottom:1px solid var(--border-color,#eee);border-right:1px solid var(--border-color,#eee);vertical-align:top;padding:.5rem .75rem}.planung2-table th{color:var(--text-secondary,#555);background:var(--fnx-table-header-bg,#f5f7fa);z-index:10;font-size:.875rem;font-weight:600;position:sticky;top:0}.planung2-table thead tr:first-child th{z-index:20;top:0}.planung2-table thead tr:nth-child(2) th{z-index:10;top:40px}.planung2-table th.sticky-left{z-index:25;background:var(--fnx-table-header-bg,#f5f7fa);position:sticky;left:0}.planung2-table td.sticky-left{z-index:5;background:var(--card-bg,#fff);position:sticky;left:0}.planung2-table tbody tr:hover td,.planung2-table tbody tr:hover td.sticky-left{background:var(--hover-bg,#f8f9fa)}.employee-name-cell{min-width:150px;font-weight:500;background:var(--bg-secondary,#f8f8f8)!important}.date-header-cell{text-align:center;min-width:80px;color:var(--text-secondary);font-size:.75rem}.date-header-day{color:var(--text-primary);font-weight:600}.project-header-cell{cursor:pointer;min-width:140px;font-size:.75rem;background:var(--bg-secondary,#fafafa)!important}.project-header-cell:hover{background:var(--hover-bg,#eee)!important}.project-chip{color:#fff;white-space:nowrap;border-radius:4px;padding:2px 6px;font-size:11px;font-weight:500;display:inline-block}.project-empty-text{color:var(--text-secondary,#999);font-size:11px}.assignment-cell{min-width:140px;padding:.25rem;transition:background .15s}.assignment-cell.drop-target{outline:2px dashed var(--primary-color,#2196f3);outline-offset:-2px;background:var(--drop-target-bg,#e3f2fd)!important}.cell-assignments{flex-wrap:wrap;align-content:flex-start;gap:2px;min-height:24px;display:flex}.planung2-page .employee-chip{background:var(--chip-bg,#e3f2fd);border:1px solid var(--chip-border,#90caf9);cursor:default;-webkit-user-select:none;user-select:none;border-radius:10px;align-items:center;gap:4px;padding:2px 6px;font-size:11px;display:inline-flex}.planung2-page .chip-name{color:var(--chip-text,var(--text-primary,#333));white-space:nowrap;text-overflow:ellipsis;max-width:100px;font-weight:500;overflow:hidden}.planung2-page .chip-remove{cursor:pointer;color:var(--text-secondary,#999);background:0 0;border:none;border-radius:50%;margin-left:2px;padding:0 2px;font-size:14px;line-height:1;transition:background .15s,color .15s}.planung2-page .chip-remove:hover{background:var(--danger-color,#ff5252);color:#fff}.planung2-toolbar{background:var(--bg-primary,#fff);border-bottom:1px solid var(--border-color,#eee);flex-shrink:0;justify-content:space-between;align-items:center;gap:16px;padding:12px 16px;display:flex}.planung2-toolbar .toolbar-left,.planung2-toolbar .toolbar-center,.planung2-toolbar .toolbar-right{align-items:center;gap:8px;display:flex}.planung2-toolbar .range-toggle{background:var(--bg-secondary,#f0f0f0);border-radius:6px;display:flex;overflow:hidden}.planung2-toolbar .range-toggle button{cursor:pointer;background:0 0;border:none;padding:6px 12px;font-size:13px;transition:background .15s}.planung2-toolbar .range-toggle button:hover{background:var(--hover-bg,#e8e8e8)}.planung2-toolbar .range-toggle button.active{background:var(--primary-color,#2196f3);color:#fff}.planung2-toolbar .nav-btn{border:1px solid var(--border-color,#ddd);background:var(--bg-primary,#fff);cursor:pointer;border-radius:6px;padding:6px 12px;font-size:14px}.planung2-toolbar .nav-btn:hover{background:var(--hover-bg,#f5f5f5)}.planung2-toolbar .today-btn{border:1px solid var(--primary-color,#2196f3);background:var(--bg-primary,#fff);color:var(--primary-color,#2196f3);cursor:pointer;border-radius:6px;padding:6px 16px;font-size:13px;font-weight:500}.planung2-toolbar .today-btn:hover{background:var(--primary-color,#2196f3);color:#fff}.planung2-toolbar .manage-btn{border:1px solid var(--border-color,#ddd);background:var(--bg-primary,#fff);cursor:pointer;border-radius:6px;padding:6px 16px;font-size:13px}.planung2-toolbar .manage-btn:hover{background:var(--hover-bg,#f5f5f5);border-color:var(--primary-color,#2196f3)}.planung2-page .context-menu{z-index:1000;background:var(--bg-primary,#fff);border:1px solid var(--border-color,#ddd);border-radius:8px;min-width:220px;max-width:320px;padding:4px 0;position:fixed;overflow:hidden;box-shadow:0 4px 16px #00000026}.planung2-page .context-menu-search{border-bottom:1px solid var(--border-color,#eee);padding:8px}.planung2-page .context-menu-search input{border:1px solid var(--border-color,#ddd);box-sizing:border-box;border-radius:4px;outline:none;width:100%;padding:6px 10px;font-size:13px}.planung2-page .context-menu-list{max-height:240px;padding:4px 0;overflow-y:auto}.planung2-page .context-menu-item{cursor:pointer;align-items:center;gap:8px;padding:8px 16px;transition:background .1s;display:flex}.planung2-page .context-menu-item:hover{background:var(--hover-bg,#f5f5f5)}.planung2-page .item-color{border-radius:3px;flex-shrink:0;width:12px;height:12px}.planung2-page .item-name{flex:1;font-size:13px}.planung2-page .item-number{color:var(--text-secondary,#888);font-size:11px}.planung2-page .empty-state{text-align:center;color:var(--text-secondary,#888);padding:48px;font-size:14px}.planung2-page .loading-state{justify-content:center;align-items:center;padding:48px;display:flex}.planung2-page .loading-spinner{border:3px solid var(--border-color,#eee);border-top-color:var(--primary-color,#2196f3);border-radius:50%;width:32px;height:32px;animation:.8s linear infinite spin}.planung2-page .error-state{color:var(--danger-color,#d32f2f);text-align:center;padding:24px}.app-layout{min-height:100vh;display:flex}.main-content{background:var(--bg-secondary);min-width:0;min-height:100vh;color:var(--text);box-sizing:border-box;flex:1;margin-left:260px;padding:2.5rem}.page-container{box-sizing:border-box;width:100%;max-width:1400px;margin:0 auto;animation:.3s ease-out fadeIn}.page-container h1{color:var(--text);margin:0 0 1rem;font-family:Inter,system-ui,sans-serif;font-size:1.75rem;font-weight:700}.page-container p{color:var(--text-muted);font-family:Inter,system-ui,sans-serif;font-size:1rem}@media (width<=1024px){.main-content{margin-left:0;padding:1.5rem}.page-header{flex-direction:column;align-items:flex-start;gap:1rem}.page-title{font-size:1.5rem}}@media (width<=768px){.main-content{padding:1rem}.page-container{padding:0}.page-header{flex-direction:column;align-items:stretch;gap:1rem;margin-bottom:1.5rem}.page-title{font-size:1.25rem}.btn-primary{justify-content:center;width:100%}}
