body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.App{text-align:center}.App-logo{height:40vmin;pointer-events:none}@media (prefers-reduced-motion:no-preference){.App-logo{animation:App-logo-spin 20s linear infinite}}.App-header{align-items:center;background-color:#282c34;color:#fff;display:flex;flex-direction:column;font-size:calc(10px + 2vmin);justify-content:center;min-height:100vh}.App-link{color:#61dafb}@keyframes App-logo-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}:root{--accent-gradient:linear-gradient(135deg,#2563eb,#0ea5e9);--accent-gradient-hover:linear-gradient(135deg,#1d4ed8,#0284c7);--spacing-md:0.625rem;--spacing-lg:0.875rem;--spacing-xl:1.25rem;--transition-fast:0.15s ease;--z-table-header:10;--z-action-column-header:20;--z-dropdown:1000;--z-module-header:100;--z-main-layout-dropdown:1030;--z-fixed:1040;--layout-header-height:3rem;--layout-footer-height:2rem;--layout-tabbar-height:2.5rem;--layout-sidebar-width:16rem;--layout-sidebar-collapsed-width:4rem}html[data-theme=dark]{--bg-primary:#0f172a;--bg-secondary:#1e293b;--bg-tertiary:#334155;--bg-gradient:linear-gradient(135deg,#0f172a,#1e293b);--table-header-bg:#1e3a5f;--table-header-text:#e8eef7;--table-header-border:#475569;--modal-header-bg:#1e3a5f;--modal-footer-bg:#1e293b;--text-primary:#f1f5f9;--text-secondary:#cbd5e1;--text-muted:#64748b;--border-color:#47556980;--input-border-color:#64748b;--glass-bg:#0f172af2}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}body{background:linear-gradient(135deg,#f8fafc,#e2e8f0);background:var(--bg-gradient);overflow-x:hidden}.module-master-container{height:calc(100vh - var(--layout-header-height) - var(--layout-footer-height))}.module-master-container.with-tabs{height:calc(100vh - var(--layout-header-height) - var(--layout-footer-height) - var(--layout-tabbar-height))}.module-header{gap:.875rem;margin:.625rem 1.25rem;margin:var(--spacing-md) 1.25rem;min-height:2.75rem;padding:.875rem 1.5rem;z-index:100;z-index:var(--z-module-header)}.module-header-content{display:flex;flex-direction:column;gap:.125rem}.module-title{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#2563eb,#0ea5e9);background:var(--accent-gradient);-webkit-background-clip:text;background-clip:text;line-height:1.2}.view-mode-group{background:#fff;background:var(--bg-primary);border:1px solid #e2e8f0cc;border:1px solid var(--border-color);border-radius:.375rem;border-radius:var(--radius-sm);gap:.125rem;padding:.125rem}.view-mode-btn,.view-mode-group{align-items:center;display:inline-flex}.view-mode-btn{background:#0000;border:none;border-radius:.375rem;border-radius:var(--radius-sm);color:#64748b;color:var(--text-secondary);cursor:pointer;height:2rem;justify-content:center;padding:0;position:relative;transition:all .2s ease;transition:all var(--transition);width:2rem}.view-mode-btn:hover{background:#f8fafc;background:var(--bg-secondary);color:#1e293b;color:var(--text-primary)}.view-mode-btn.active{background:#2563eb;background:var(--primary);box-shadow:0 1px 3px #2563eb4d;color:#fff}.view-mode-btn svg{height:16px;width:16px}.view-mode-btn:after{background:#1e293b;background:var(--text-primary);border-radius:.375rem;border-radius:var(--radius-sm);bottom:calc(100% + .5rem);color:#fff;content:attr(data-tooltip);font-size:.7rem;font-weight:500;left:50%;opacity:0;padding:.375rem .625rem;pointer-events:none;position:absolute;transform:translateX(-50%);transition:opacity .2s ease;transition:opacity var(--transition);white-space:nowrap;z-index:1000}.view-mode-btn:hover:after{opacity:1}.module-content{transition:all .3s ease;transition:all var(--transition-slow)}.search-input-wrapper{min-width:250px}.search-input-wrapper svg{color:#94a3b8;color:var(--text-muted);left:.625rem;pointer-events:none;position:absolute;z-index:1}.search-input{background:#fff;background:var(--bg-primary);border:1px solid #e2e8f0cc;border:1px solid var(--border-color);border-radius:.375rem;border-radius:var(--radius-sm);font-family:inherit;font-size:.8rem;padding:.5rem .75rem .5rem 2.25rem;transition:all .2s ease;transition:all var(--transition)}.search-input:focus{border-color:#2563eb;border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1a;outline:none}.data-grid-container{margin-top:0;min-width:0;padding:0;transition:all .3s ease;transition:all var(--transition-slow)}.data-table-wrapper{border:1px solid #e2e8f080;border:1px solid var(--border-light);border-radius:.75rem;border-radius:var(--radius-md);box-shadow:0 2px 8px #00000014;box-shadow:var(--shadow);margin:0;position:relative}.data-table{font-size:.8rem;position:relative}.data-table thead{z-index:10;z-index:var(--z-table-header)}.data-table thead th{background:#e0ebf7;background:var(--table-header-bg);border-bottom:2px solid #cbd5e1;border-bottom:2px solid var(--table-header-border);color:#1e3a8a;color:var(--table-header-text);font-size:.75rem;font-weight:700;letter-spacing:.05em;padding:.625rem .75rem;position:relative;text-align:left;text-transform:uppercase;vertical-align:middle;white-space:nowrap}.data-table tbody td{border-bottom:1px solid #e2e8f080;border-bottom:1px solid var(--border-light);color:#1e293b;color:var(--text-primary);line-height:1.4;padding:.5rem .625rem;position:relative;vertical-align:middle}.data-table tbody tr{position:relative;transition:background .15s ease;transition:background var(--transition-fast);z-index:1}.data-table tbody tr.has-active-menu{position:relative;z-index:10005!important;z-index:var(--z-active-row)!important}.data-table td:first-child,.data-table th:first-child{padding:.5rem .375rem;text-align:center;width:40px}.row-select,.row-select-all{accent-color:#2563eb;accent-color:var(--primary);cursor:pointer;height:16px;width:16px}.data-table tbody td.action-column{background:#fff;background:var(--bg-primary);padding:.5rem;z-index:2;z-index:var(--z-action-column-body)}.data-table tbody td.action-column,.data-table thead th.action-column{border-left:2px solid #e2e8f0cc;border-left:2px solid var(--border-color);box-shadow:-2px 0 4px #0000000d;min-width:70px;position:-webkit-sticky;position:sticky;right:0;text-align:center;width:70px}.data-table thead th.action-column{background:#e0ebf7;background:var(--table-header-bg);top:0;z-index:20;z-index:var(--z-action-column-header)}.data-table tbody tr:hover td.action-column{background:#f8fafc;background:var(--bg-secondary)}.data-table tbody tr.has-active-menu td.action-column{background:#fff;background:var(--bg-primary);z-index:10006!important;z-index:calc(var(--z-active-row) + 1)!important}.action-menu-container{display:inline-block;position:relative;z-index:1}.action-menu-trigger{background:#fff;background:var(--bg-primary);border:1px solid #e2e8f0cc;border:1px solid var(--border-color);display:inline-flex;height:1.875rem;padding:0;position:relative;transition:all .2s ease;transition:all var(--transition);width:1.875rem;z-index:1}.action-menu-trigger.active,.action-menu-trigger:hover{border-color:#2563eb;border-color:var(--primary)}.action-menu-trigger.active{background:#2563eb;background:var(--primary);color:#fff;z-index:10102;z-index:calc(var(--z-action-menu) + 2)}.action-menu-trigger svg{height:16px;width:16px}.action-menu-dropdown{animation:slideDown .2s ease;animation:slideDown var(--transition);background:#fff;background:var(--bg-primary);border:2px solid #2563eb;border:2px solid var(--primary);border-radius:.75rem;border-radius:var(--radius-md);box-shadow:0 12px 32px #2563eb33;max-height:280px;min-width:180px;overflow-y:auto;padding:.5rem;position:absolute;right:0;top:calc(100% + .5rem);z-index:10100;z-index:var(--z-action-menu)}.action-menu-item{border-radius:.5rem;border-radius:var(--radius);font-family:inherit;font-size:.85rem;font-weight:500;gap:.75rem;padding:.625rem .875rem;transition:all .2s cubic-bezier(.4,0,.2,1)}.action-menu-item:hover{color:#2563eb;color:var(--primary);padding-left:1rem;transform:translateX(4px)}.action-menu-item svg{flex-shrink:0;height:18px;transition:transform .2s ease;transition:transform var(--transition);width:18px}.action-menu-item:hover svg{transform:scale(1.15)}.action-menu-item-danger,.action-menu-item-danger:hover{color:#dc2626;color:var(--danger)}.action-menu-item-danger:hover{background:#dc26261a}.action-menu-divider{background:#e2e8f0cc;background:var(--border-color);height:1px;margin:.5rem 0}@media (max-width:768px){.action-menu-dropdown{animation:slideUp .2s ease;border-radius:1rem;border-radius:var(--radius-lg);bottom:1rem;box-shadow:0 -4px 32px #0003;left:1rem;max-height:60vh;min-width:auto;position:fixed;right:1rem;top:auto}.action-menu-item{font-size:.95rem;padding:.875rem 1rem}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.btn{align-items:center;border:none;border-radius:.375rem;border-radius:var(--radius-sm);cursor:pointer;display:inline-flex;font-family:inherit;font-size:.8rem;font-weight:600;gap:.5rem;gap:var(--spacing-sm);justify-content:center;padding:.5rem .875rem;padding:var(--spacing-sm) var(--spacing-lg);text-decoration:none;transition:all .2s ease;transition:all var(--transition);-webkit-user-select:none;user-select:none;white-space:nowrap}.btn:disabled{cursor:not-allowed;opacity:.5}.btn-primary{box-shadow:0 2px 8px #00000014;box-shadow:var(--shadow)}.btn-primary:hover:not(:disabled){background:#1d4ed8;box-shadow:0 4px 12px #0000001f;box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn-secondary{border:1.5px solid #e2e8f0cc;border:1.5px solid var(--border-color)}.btn-secondary:hover:not(:disabled){background:#f8fafc;background:var(--bg-secondary);border-color:#2563eb;border-color:var(--primary);color:#2563eb;color:var(--primary)}.btn-danger{background:#dc2626;background:var(--danger);box-shadow:0 2px 8px #00000014;box-shadow:var(--shadow);color:#fff}.btn-danger:hover:not(:disabled){background:#b91c1c;box-shadow:0 4px 12px #0000001f;box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn-success{background:#16a34a;background:var(--success);box-shadow:0 2px 8px #00000014;box-shadow:var(--shadow);color:#fff}.btn-success:hover:not(:disabled){background:#15803d;box-shadow:0 4px 12px #0000001f;box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn-icon{align-items:center;border-radius:.375rem;border-radius:var(--radius-sm);color:#64748b;color:var(--text-secondary);cursor:pointer;display:inline-flex;height:2rem;justify-content:center;padding:0;transition:all .2s ease;transition:all var(--transition);width:2rem}.btn-icon:hover{transform:translateY(-1px)}.btn-icon svg{stroke-width:2;height:18px;width:18px}.search-panel{box-shadow:-4px 0 12px #00000014;height:100%;overflow:hidden;transition:all .3s ease;transition:all var(--transition-slow)}.search-panel.collapsed{border-left:none;box-shadow:none;width:0}.search-panel-header{background:#e0ebf7;background:var(--table-header-bg);flex-shrink:0;padding:.875rem 1.25rem;padding:var(--spacing-lg) 1.25rem}.search-panel-title{color:#1e3a8a;color:var(--table-header-text)}.search-panel-close{align-items:center;background:#0000;border:none;border-radius:.375rem;border-radius:var(--radius-sm);color:#64748b;color:var(--text-secondary);cursor:pointer;display:inline-flex;height:1.5rem;justify-content:center;transition:all .15s ease;transition:all var(--transition-fast);width:1.5rem}.search-panel-close:hover{background:#00000014;color:#1e293b;color:var(--text-primary)}.search-panel-content{min-height:0;padding:1.25rem}.filter-section:last-child{margin-bottom:0}.filter-section-title{color:#64748b;color:var(--text-secondary);font-size:.75rem;letter-spacing:.05em;margin-bottom:.625rem}.filter-actions{background:#f8fafc;background:var(--bg-secondary);flex-shrink:0;gap:.625rem;padding:.875rem 1.25rem;padding:var(--spacing-lg) 1.25rem}.filter-actions .btn{flex:1 1}.pagination-footer{background:#fff;background:var(--bg-primary);border-radius:0 0 .75rem .75rem;border-radius:0 0 var(--radius-md) var(--radius-md);border-top:1px solid #e2e8f0cc;border-top:1px solid var(--border-color);gap:.625rem;gap:var(--spacing-md);margin:0;padding:.625rem .875rem;padding:.625rem var(--spacing-lg)}.pagination-controls{align-items:center}.page-btn{display:inline-flex;font-family:inherit;height:2rem;padding:0 .5rem;transition:all .15s ease;transition:all var(--transition-fast)}.page-size-selector select{font-family:inherit;font-size:.75rem;padding:.375rem .625rem}.form-row{display:flex;gap:1rem;margin-bottom:.875rem}.form-row:last-child{margin-bottom:0}.form-group{display:flex;flex:1 1;flex-direction:column;gap:.375rem;margin-bottom:.875rem;margin-bottom:var(--spacing-lg)}.form-label{display:block;font-size:.75rem;font-weight:600;margin-bottom:.375rem}.form-input,.form-select,.form-textarea{border:1px solid #334155!important;border:1px solid var(--input-border-color,#334155)!important;font-family:inherit;font-size:.8rem;padding:.5rem .75rem;transition:all .2s ease;transition:all var(--transition);width:100%}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:#2563eb!important;border-color:var(--primary)!important}.form-input:disabled,.form-select:disabled,.form-textarea:disabled{-webkit-text-fill-color:#1e293b;-webkit-text-fill-color:var(--text-primary);color:#1e293b;color:var(--text-primary);opacity:1}.form-textarea{min-height:80px;resize:vertical}.form-input.input-error,.form-select.input-error,.form-textarea.input-error{border-color:#dc2626!important;border-color:var(--danger)!important;box-shadow:0 0 0 3px #dc26261a}.error-message,.form-error{color:#dc2626;color:var(--danger);display:block;font-size:.75rem;margin-top:.25rem}.checkbox-label{align-items:center;color:#1e293b;color:var(--text-primary);cursor:pointer;display:flex;font-size:.8rem;gap:.5rem;margin-bottom:.5rem}.checkbox-label input[type=checkbox],.checkbox-label input[type=radio]{accent-color:#2563eb;accent-color:var(--primary);cursor:pointer;height:16px;width:16px}.badge{align-items:center;border-radius:.375rem;border-radius:var(--radius-sm);display:inline-flex;font-size:.7rem;font-weight:600;gap:.25rem;letter-spacing:.025em;padding:.1875rem .4375rem;text-transform:uppercase;white-space:nowrap}.badge-active{color:#16a34a;color:var(--success)}.badge-inactive{color:#64748b;color:var(--secondary)}.badge-pending{color:#d97706;color:var(--warning)}.badge-error{color:#dc2626;color:var(--danger)}.modal-backdrop{animation:fadeIn .2s ease;animation:fadeIn var(--transition);background:#0009;inset:0}.modal-container{animation:modalSlideUp .3s ease;animation:modalSlideUp var(--transition-slow);background:#fff;background:var(--bg-primary);border-radius:1rem;border-radius:var(--radius-lg);box-shadow:0 25px 50px -12px #0006;box-shadow:var(--shadow-xl);display:flex;flex-direction:column;left:50%;max-height:85vh;overflow:hidden;position:fixed;top:50%;transform:translate(-50%,-50%);width:90%;z-index:10050;z-index:var(--z-modal)}.modal-sm{max-width:400px;min-height:280px}.modal-md{max-width:600px;min-height:400px}.modal-lg{max-width:900px;min-height:500px}.modal-xl{max-width:1100px;min-height:600px}.modal-header{border-bottom:2px solid #e0ebf7;min-height:4rem}.modal-title{font-weight:700}.modal-close{height:2rem;padding:0;transition:all .2s ease;transition:all var(--transition);width:2rem}.modal-close:hover{background:#f8fafc;background:var(--bg-secondary);color:#dc2626;color:var(--danger)}.modal-tabs{background:#fff;background:var(--bg-primary);border-bottom:1px solid #e2e8f0cc;border-bottom:1px solid var(--border-color);display:flex;gap:.25rem;padding:.75rem 1.5rem 0}.modal-tab{background:#0000;border:none;border-bottom:2px solid #0000;color:#64748b;color:var(--text-secondary);cursor:pointer;font-size:.8rem;font-weight:500;padding:.5rem 1rem;transition:all .2s ease;transition:all var(--transition)}.modal-tab.active,.modal-tab:hover{color:#2563eb;color:var(--primary)}.modal-tab.active{border-bottom-color:#2563eb;border-bottom-color:var(--primary)}.modal-content{background:#fff;background:var(--bg-primary);flex:1 1;min-height:0;overflow-y:auto;padding:1.5rem}.modal-footer{border-top:2px solid #e2e8f0cc;border-top:2px solid var(--border-color);gap:.875rem;min-height:4.5rem;padding:1.25rem 1.5rem}.modal-footer .btn{font-weight:600;height:2.5rem;min-width:110px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@keyframes modalSlideUp{0%{opacity:0;transform:translate(-50%,-45%)}to{opacity:1;transform:translate(-50%,-50%)}}@media (max-width:768px){.module-header{align-items:stretch;flex-direction:column;gap:.625rem;gap:var(--spacing-md);padding:.625rem .875rem;padding:var(--spacing-md) var(--spacing-lg)}.module-toolbar{flex-wrap:wrap;width:100%}.search-input-wrapper{flex:1 1;min-width:auto}.data-grid-container{padding:0}.search-panel{bottom:0;box-shadow:-8px 0 24px #0003;max-width:320px;position:absolute;right:0;top:0;width:100%;z-index:1040;z-index:var(--z-fixed)}.search-panel.collapsed{transform:translateX(100%);width:320px}.data-table{font-size:.75rem}.data-table tbody td,.data-table thead th{padding:.5rem .375rem}.action-column{width:60px}.pagination-footer{flex-direction:column;gap:.625rem;gap:var(--spacing-md)}.modal-container{max-height:95vh;width:95%}.view-mode-group{justify-content:center;order:-1;width:100%}}::-webkit-scrollbar{height:8px;width:8px}::-webkit-scrollbar-track{background:#f8fafc;background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:#e2e8f0cc;background:var(--border-color);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#94a3b8;background:var(--text-muted)}.text-center{text-align:center}.text-right{text-align:right}.font-bold{font-weight:700}.text-sm{font-size:.875rem}.text-xs{font-size:.75rem}.mt-1{margin-top:.25rem;margin-top:var(--spacing-xs)}.mt-2{margin-top:.5rem;margin-top:var(--spacing-sm)}.mt-3{margin-top:.625rem;margin-top:var(--spacing-md)}.mt-4{margin-top:.875rem;margin-top:var(--spacing-lg)}.mb-1{margin-bottom:.25rem;margin-bottom:var(--spacing-xs)}.mb-2{margin-bottom:.5rem;margin-bottom:var(--spacing-sm)}.mb-3{margin-bottom:.625rem;margin-bottom:var(--spacing-md)}.mb-4{margin-bottom:.875rem;margin-bottom:var(--spacing-lg)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:.5rem;gap:var(--spacing-sm)}.gap-3{gap:.625rem;gap:var(--spacing-md)}.gap-4{gap:.875rem;gap:var(--spacing-lg)}.toast-container{display:flex;flex-direction:column;gap:10px;max-width:400px;position:fixed;right:20px;top:80px;z-index:10000}.toast{align-items:flex-start;animation:toast-slide-in .3s ease-out;background:#fff;background:var(--card-bg,#fff);border-radius:8px;box-shadow:0 4px 12px #00000026,0 0 0 1px #0000000d;display:flex;gap:12px;min-width:300px;padding:14px 16px}@keyframes toast-slide-in{0%{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}.toast-icon{align-items:center;border-radius:50%;display:flex;flex-shrink:0;font-size:14px;font-weight:700;height:24px;justify-content:center;width:24px}.toast-success .toast-icon{background:#10b981;color:#fff}.toast-error .toast-icon{background:#ef4444;color:#fff}.toast-warning .toast-icon{background:#f59e0b;color:#fff}.toast-info .toast-icon{background:#3b82f6;color:#fff}.toast-content{flex:1 1;min-width:0}.toast-title{color:#1e293b;color:var(--text-primary,#1f2937);font-size:.9rem;font-weight:600;margin-bottom:2px}.toast-message{color:#64748b;color:var(--text-secondary,#6b7280);font-size:.85rem;line-height:1.4}.toast-close{background:none;border:none;color:#64748b;color:var(--text-secondary,#9ca3af);cursor:pointer;flex-shrink:0;font-size:18px;line-height:1;padding:0;transition:color .2s}.toast-close:hover{color:#1e293b;color:var(--text-primary,#374151)}.toast-success{border-left:4px solid #10b981}.toast-error{border-left:4px solid #ef4444}.toast-warning{border-left:4px solid #f59e0b}.toast-info{border-left:4px solid #3b82f6}:root{--primary:#2563eb;--secondary:#64748b;--success:#16a34a;--warning:#d97706;--danger:#dc2626;--info:#0ea5e9;--bg-primary:#fff;--bg-secondary:#f8fafc;--bg-tertiary:#f1f5f9;--bg-gradient:linear-gradient(135deg,#f8fafc,#e2e8f0);--table-header-bg:#e0ebf7;--table-header-text:#1e3a8a;--table-header-border:#cbd5e1;--modal-header-bg:#f0f7ff;--modal-footer-bg:#f8fafc;--text-primary:#1e293b;--text-secondary:#64748b;--text-muted:#94a3b8;--text-disabled:#cbd5e1;--border-color:#e2e8f0cc;--border-light:#e2e8f080;--input-border-color:#334155;--glass-bg:#fffffff2;--shadow-sm:0 1px 2px 0 #0000000d;--shadow:0 2px 8px #00000014;--shadow-md:0 4px 12px #0000001f;--shadow-lg:0 8px 24px #00000029;--shadow-xl:0 25px 50px -12px #0006;--z-table-content:1;--z-action-column-body:2;--z-action-column-header:3;--z-active-row:10005;--z-modal-backdrop:10040;--z-modal:10050;--z-action-menu:10100;--spacing-xs:0.25rem;--spacing-sm:0.5rem;--spacing-md:0.75rem;--spacing-lg:1rem;--spacing-xl:1.5rem;--radius-sm:0.375rem;--radius:0.5rem;--radius-md:0.75rem;--radius-lg:1rem;--transition:0.2s ease;--transition-slow:0.3s ease}*{box-sizing:border-box;margin:0;padding:0}body{color:#1e293b;color:var(--text-primary);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:.8rem;line-height:1.5}.module-master-container{background:linear-gradient(135deg,#f8fafc,#e2e8f0);background:var(--bg-gradient);display:flex;flex-direction:column;height:calc(100vh - 5rem);min-height:0;overflow:hidden}.module-master-container.with-tabs{height:calc(100vh - 7.5rem)}.module-header{align-items:center;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#fffffff2;background:var(--glass-bg);border:1px solid #e2e8f080;border:1px solid var(--border-light);border-radius:.75rem;border-radius:var(--radius-md);box-shadow:0 2px 8px #00000014;box-shadow:var(--shadow);display:flex;flex-shrink:0;flex-wrap:wrap;gap:1rem;gap:var(--spacing-lg);justify-content:space-between;margin:.75rem;margin:var(--spacing-md);min-height:3rem;padding:1rem 1.5rem;position:-webkit-sticky;position:sticky;top:0}.module-header.context-header-connected{border-radius:0 0 .75rem .75rem;border-radius:0 0 var(--radius-md) var(--radius-md);margin-top:0}.module-title-wrapper{align-items:center;display:flex;gap:.75rem}.module-icon,.module-title{color:#2563eb;color:var(--primary)}.module-title{font-size:1.1rem;font-weight:700;margin:0}.module-description{color:#64748b;color:var(--text-secondary);font-size:.75rem;margin:0}.module-toolbar{align-items:center;display:flex;flex-wrap:wrap;gap:.5rem;gap:var(--spacing-sm)}.toolbar-separator{background:#e2e8f0cc;background:var(--border-color);height:1.5rem;margin:0 .25rem;width:1px}.search-input-wrapper{align-items:center;background:#fff;background:var(--bg-primary);border:1px solid #e2e8f0cc;border:1px solid var(--border-color);border-radius:.375rem;border-radius:var(--radius-sm);display:flex;gap:.5rem;min-width:200px;padding:.5rem .75rem;position:relative}.search-input{background:#0000;border:none;color:#1e293b;color:var(--text-primary);font-size:.75rem;outline:none;width:100%}.search-input::placeholder{color:#94a3b8;color:var(--text-muted)}.view-toggle{background:#fff;background:var(--bg-primary);border:1px solid #e2e8f0cc;border:1px solid var(--border-color);border-radius:.375rem;border-radius:var(--radius-sm);display:flex;gap:0;padding:.25rem}.view-btn{align-items:center;background:#0000;border:none;border-radius:.375rem;border-radius:var(--radius-sm);color:#64748b;color:var(--text-secondary);cursor:pointer;display:flex;justify-content:center;padding:.4rem .6rem;transition:.2s ease;transition:var(--transition)}.view-btn:hover{background:#f8fafc;background:var(--bg-secondary);color:#2563eb;color:var(--primary)}.view-btn.active{background:#2563eb;background:var(--primary);color:#fff}.btn-icon,.btn-primary,.btn-secondary{align-items:center;border:none;border-radius:.375rem;border-radius:var(--radius-sm);cursor:pointer;display:inline-flex;font-size:.75rem;font-weight:500;gap:.5rem;padding:.5rem 1rem;transition:.2s ease;transition:var(--transition);white-space:nowrap}.btn-primary{background:#2563eb;background:var(--primary);color:#fff}.btn-primary:hover{background:#1d4ed8;box-shadow:0 4px 12px #0000001f;box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn-secondary{background:#fff;background:var(--bg-primary);border:1px solid #e2e8f0cc;border:1px solid var(--border-color);color:#1e293b;color:var(--text-primary)}.btn-secondary:hover{background:#f8fafc;background:var(--bg-secondary);border-color:#2563eb;border-color:var(--primary);color:#2563eb;color:var(--primary)}.btn-icon{background:#fff;background:var(--bg-primary);border:1px solid #e2e8f0cc;border:1px solid var(--border-color);padding:.5rem;position:relative}.btn-icon:hover{background:#f8fafc;background:var(--bg-secondary);color:#2563eb;color:var(--primary)}.btn-icon.active,.btn-icon:hover{border-color:#2563eb;border-color:var(--primary)}.btn-icon.active{background:#2563eb;background:var(--primary);color:#fff}.filter-badge{background:#dc2626;background:var(--danger);border-radius:10px;color:#fff;font-size:.6rem;font-weight:600;padding:.125rem .375rem;position:absolute;right:-4px;top:-4px}.btn-sm{font-size:.7rem;padding:.375rem .75rem}.btn-xs{font-size:.65rem;padding:.25rem .5rem}.btn-block{justify-content:center;width:100%}.btn-danger-outline{background:#0000;border:1px solid #dc2626;border:1px solid var(--danger);color:#dc2626;color:var(--danger)}.btn-danger-outline:hover{background:#dc2626;background:var(--danger);color:#fff}.module-content{gap:0;position:relative}.data-grid-container,.module-content{display:flex;flex:1 1;min-height:0;overflow:hidden;transition:.3s ease;transition:var(--transition-slow)}.data-grid-container{flex-direction:column}.bulk-actions-bar{align-items:center;background:#fff;background:var(--bg-primary);border:1px solid #e2e8f0cc;border:1px solid var(--border-color);border-radius:.5rem;border-radius:var(--radius);box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);display:flex;justify-content:space-between;margin-bottom:.75rem;margin-bottom:var(--spacing-md);padding:.75rem 1rem}.bulk-actions-info{align-items:center;color:#2563eb;color:var(--primary);font-size:.75rem;font-weight:500}.bulk-actions-buttons,.bulk-actions-info{display:flex;gap:.5rem}.data-table-wrapper{background:#fff;background:var(--bg-primary);border:1px solid #e2e8f0cc;border:1px solid var(--border-color);border-radius:.5rem;border-radius:var(--radius);box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);flex:1 1;min-height:0;overflow:auto}.data-table{border-collapse:collapse;font-size:.75rem;width:100%}.data-table thead{position:-webkit-sticky;position:sticky;top:0;z-index:3;z-index:var(--z-action-column-header)}.data-table th,.data-table thead{background:#e0ebf7;background:var(--table-header-bg)}.data-table th{border-bottom:2px solid #cbd5e1;border-bottom:2px solid var(--table-header-border);color:#1e3a8a;color:var(--table-header-text);font-weight:600;padding:.75rem;text-align:left;white-space:nowrap}.data-table td.text-right,.data-table th.text-right{text-align:right}.data-table td.text-center,.data-table th.text-center{text-align:center}.action-column-header{background:#e0ebf7;background:var(--table-header-bg);position:-webkit-sticky;position:sticky;right:0;text-align:center;z-index:3;z-index:var(--z-action-column-header)}.data-table tbody tr{border-bottom:1px solid #e2e8f0cc;border-bottom:1px solid var(--border-color);transition:.2s ease;transition:var(--transition)}.data-table tbody tr:hover{background:#f8fafc;background:var(--bg-secondary)}.data-table tbody tr:nth-child(2n){background:#f8fafc4d}.data-table tbody tr:nth-child(2n):hover{background:#f8fafc;background:var(--bg-secondary)}.data-table td{color:#1e293b;color:var(--text-primary);padding:.75rem}.action-column-body{background:#fff;background:var(--bg-primary);box-shadow:-2px 0 4px #0000000d;position:-webkit-sticky;position:sticky;right:0;text-align:center;z-index:2;z-index:var(--z-action-column-body)}.data-table tbody tr:hover .action-column-body{background:#f8fafc;background:var(--bg-secondary)}.link-button{background:none;border:none;color:#2563eb;color:var(--primary);cursor:pointer;font-size:inherit;font-weight:500;padding:0;text-decoration:none}.link-button:hover{text-decoration:underline}.font-semibold{font-weight:600}.action-menu-trigger{align-items:center;background:#0000;border:none;border-radius:.375rem;border-radius:var(--radius-sm);color:#64748b;color:var(--text-secondary);cursor:pointer;display:flex;justify-content:center;padding:.375rem;transition:.2s ease;transition:var(--transition)}.action-menu-trigger:hover{background:#f8fafc;background:var(--bg-secondary);color:#2563eb;color:var(--primary)}.action-menu-backdrop{background:#0000;bottom:0;left:0;position:fixed;right:0;top:0;z-index:10099}.action-menu{background:#fff;border:1px solid #e2e8f0cc;border:1px solid var(--border-color);border-radius:.5rem;border-radius:var(--radius);box-shadow:0 8px 24px #00000029;box-shadow:var(--shadow-lg);min-width:160px;padding:.25rem 0;position:absolute;z-index:10100;z-index:var(--z-action-menu)}.action-menu-item{align-items:center;background:#0000;border:none;color:#1e293b;color:var(--text-primary);cursor:pointer;display:flex;font-size:.75rem;gap:.5rem;padding:.5rem .75rem;text-align:left;transition:.2s ease;transition:var(--transition);width:100%}.action-menu-item:hover{background:#f8fafc;background:var(--bg-secondary)}.action-menu-item.primary:hover{background:#2563eb1a;color:#2563eb;color:var(--primary)}.action-menu-item.success:hover{background:#16a34a1a;color:#16a34a;color:var(--success)}.action-menu-item.warning:hover{background:#d977061a;color:#d97706;color:var(--warning)}.action-menu-item.danger:hover{background:#dc26261a;color:#dc2626;color:var(--danger)}.action-menu-item.disabled{cursor:not-allowed;opacity:.5}.action-menu-separator{background:#e2e8f0cc;background:var(--border-color);height:1px;margin:.25rem 0}.status-badge{align-items:center;border-radius:12px;display:inline-flex;font-size:.7rem;font-weight:500;gap:.25rem;padding:.25rem .625rem;white-space:nowrap}.badge-active{background:#16a34a1a;border:1px solid #16a34a33;color:#15803d}.badge-inactive{background:#64748b1a;border:1px solid #64748b33;color:#475569}.badge-success{background:#16a34a1a;border:1px solid #16a34a33;color:#15803d}.badge-pending{background:#d977061a;border:1px solid #d9770633;color:#c2410c}.badge-error{background:#dc26261a;border:1px solid #dc262633;color:#b91c1c}.pagination-footer{align-items:center;display:flex;flex-shrink:0;flex-wrap:wrap;gap:1rem;justify-content:space-between;margin-top:auto;padding:1rem 0}.pagination-info{color:#64748b;color:var(--text-secondary);font-size:.75rem}.pagination-controls{display:flex;gap:.25rem}.page-btn{align-items:center;background:#fff;background:var(--bg-primary);border:1px solid #e2e8f0cc;border:1px solid var(--border-color);border-radius:.375rem;border-radius:var(--radius-sm);color:#1e293b;color:var(--text-primary);cursor:pointer;display:flex;font-size:.75rem;justify-content:center;min-width:2rem;padding:.375rem .75rem;transition:.2s ease;transition:var(--transition)}.page-btn:hover:not(:disabled){background:#f8fafc;background:var(--bg-secondary);color:#2563eb;color:var(--primary)}.page-btn.active,.page-btn:hover:not(:disabled){border-color:#2563eb;border-color:var(--primary)}.page-btn.active{background:#2563eb;background:var(--primary);color:#fff}.page-btn:disabled{cursor:not-allowed;opacity:.5}.page-size-selector{align-items:center;color:#64748b;color:var(--text-secondary);display:flex;font-size:.75rem;gap:.5rem}.page-size-selector select{border:1px solid #e2e8f0cc;border:1px solid var(--border-color);border-radius:.375rem;border-radius:var(--radius-sm);color:#1e293b;color:var(--text-primary);cursor:pointer;padding:.375rem}.page-size-selector select,.search-panel{background:#fff;background:var(--bg-primary)}.search-panel{border-left:1px solid #e2e8f0cc;border-left:1px solid var(--border-color);box-shadow:-4px 0 8px #0000000d;display:flex;flex-direction:column;flex-shrink:0;transition:transform .3s ease;transition:transform var(--transition-slow);width:320px;z-index:1010}.search-panel.collapsed{transform:translateX(100%)}.search-panel-header{align-items:center;background:#f8fafc;background:var(--bg-secondary);border-bottom:1px solid #e2e8f0cc;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;padding:1rem}.search-panel-title{align-items:center;color:#1e293b;color:var(--text-primary);display:flex;font-size:.9rem;font-weight:600;gap:.5rem;margin:0}.search-panel-content{flex:1 1;overflow-y:auto;padding:1rem}.filter-section{margin-bottom:1.25rem}.filter-section-title{color:#1e293b;color:var(--text-primary);display:block;font-size:.7rem;font-weight:600;letter-spacing:.5px;margin-bottom:.5rem;text-transform:uppercase}.filter-input,.filter-select{background:#fff;background:var(--bg-primary);border:1px solid #e2e8f0cc;border:1px solid var(--border-color);border-radius:.375rem;border-radius:var(--radius-sm);color:#1e293b;color:var(--text-primary);font-size:.75rem;padding:.5rem;width:100%}.filter-input::placeholder{color:#94a3b8;color:var(--text-muted)}.filter-range{align-items:center;display:flex;gap:.5rem}.filter-range input{flex:1 1}.filter-range span{color:#94a3b8;color:var(--text-muted);font-size:.7rem}.filter-date-range{display:flex;flex-direction:column;gap:.5rem}.filter-date-range span{color:#94a3b8;color:var(--text-muted);font-size:.7rem;text-align:center}.filter-actions{border-top:1px solid #e2e8f0cc;border-top:1px solid var(--border-color);display:flex;flex-direction:column;gap:.5rem;padding:1rem}.modal-backdrop{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0f172a99;bottom:0;justify-content:center;left:0;right:0;top:0;z-index:10040;z-index:var(--z-modal-backdrop)}.modal,.modal-backdrop{display:flex;position:fixed}.modal{background:#fff;background:var(--bg-primary);border-radius:1rem;border-radius:var(--radius-lg);box-shadow:0 25px 50px -12px #0006;box-shadow:var(--shadow-xl);flex-direction:column;left:50%;max-height:90vh;overflow:hidden;top:50%;transform:translate(-50%,-50%);z-index:10050;z-index:var(--z-modal)}.modal-small{max-width:400px;min-height:280px;width:90%}.modal-medium{max-width:600px;min-height:400px;width:90%}.modal-large{max-width:900px;min-height:500px;width:90%}.modal-xlarge{max-width:1200px;min-height:600px;width:90%}.modal-header{align-items:center;background:#f0f7ff;background:var(--modal-header-bg);border-bottom:1px solid #e2e8f0cc;border-bottom:1px solid var(--border-color);display:flex;flex-shrink:0;justify-content:space-between;padding:1.25rem 1.5rem}.modal-header-left{align-items:center;display:flex;flex:1 1;gap:1rem}.modal-title{color:#1e293b;color:var(--text-primary);font-size:1.125rem;font-weight:600;margin:0}.modal-close{align-items:center;background:#0000;border:none;border-radius:.375rem;border-radius:var(--radius-sm);color:#64748b;color:var(--text-secondary);cursor:pointer;display:flex;justify-content:center;padding:.5rem;transition:.2s ease;transition:var(--transition)}.modal-close:hover{background:#0000000d;color:#1e293b;color:var(--text-primary)}.modal-body{flex:1 1;min-height:0;overflow-y:auto;padding:1.5rem}.modal-footer{align-items:center;background:#f8fafc;background:var(--modal-footer-bg);border-top:1px solid #e2e8f0cc;border-top:1px solid var(--border-color);display:flex;flex-shrink:0;gap:.75rem;justify-content:flex-end;padding:1rem 1.5rem}.context-badge-elegant{align-items:center;background:linear-gradient(135deg,#fef3c7,#fde68a);border:1px solid #f59e0b33;border-radius:.5rem;border-radius:var(--radius);box-shadow:0 2px 8px #f59e0b26;display:inline-flex;gap:.75rem;padding:.5rem .875rem}.context-badge-elegant .badge-icon{align-items:center;background:#fff;border-radius:.375rem;border-radius:var(--radius-sm);box-shadow:0 2px 4px #0000001a;color:#d97706;display:flex;flex-shrink:0;height:2rem;justify-content:center;width:2rem}.context-badge-elegant .badge-content{display:flex;flex-direction:column;gap:.125rem;line-height:1.2}.context-badge-elegant .badge-bu{color:#78350f;font-size:.8rem;font-weight:600}.context-badge-elegant .badge-entity{color:#92400e;font-size:.7rem;font-weight:400}.context-badge-elegant .badge-divider{background:linear-gradient(180deg,#0000,#f59e0b4d 20%,#f59e0b4d 80%,#0000);height:2rem;width:1px}.context-badge-elegant .badge-fy{align-items:center;color:#78350f;display:flex;font-size:.7rem;font-weight:600;gap:.375rem;white-space:nowrap}.form-section{margin-bottom:1.5rem}.form-section:last-child{margin-bottom:0}.form-section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem}.form-section-title{border-bottom:1px solid #e2e8f0cc;border-bottom:1px solid var(--border-color);color:#1e293b;color:var(--text-primary);font-size:.85rem;font-weight:600;margin:0 0 1rem;padding-bottom:.5rem}.form-grid{grid-gap:1rem;display:grid;gap:1rem}.form-grid-2{grid-template-columns:repeat(2,1fr)}.form-grid-3{grid-template-columns:repeat(3,1fr)}.form-field{display:flex;flex-direction:column;gap:.375rem}.form-field-full{grid-column:1/-1}.form-label{color:#1e293b;color:var(--text-primary);font-size:.7rem;font-weight:500}.required{color:#dc2626;color:var(--danger)}.form-input,.form-select,.form-textarea{background:#fff;background:var(--bg-primary);border:1px solid #e2e8f0cc;border:1px solid var(--border-color);border-radius:.375rem;border-radius:var(--radius-sm);color:#1e293b;color:var(--text-primary);font-size:.75rem;padding:.5rem;transition:.2s ease;transition:var(--transition)}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:#2563eb;border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1a;outline:none}.form-input:disabled,.form-select:disabled,.form-textarea:disabled{background:#f8fafc;background:var(--bg-secondary);color:#cbd5e1;color:var(--text-disabled);cursor:not-allowed}.form-input-sm,.form-select-sm,.form-textarea-sm{font-size:.7rem;padding:.375rem}.form-help{color:#94a3b8;color:var(--text-muted);font-size:.65rem;margin-top:.25rem}.form-checkbox-wrapper{align-items:center;display:flex;gap:.5rem}.form-checkbox{cursor:pointer;height:1rem;width:1rem}.form-label-sm{color:#64748b;color:var(--text-secondary);font-size:.7rem}.line-items-table-wrapper{border:1px solid #e2e8f0cc;border:1px solid var(--border-color);border-radius:.5rem;border-radius:var(--radius);margin-top:.75rem;overflow-x:auto}.line-items-table{border-collapse:collapse;font-size:.7rem;min-width:1400px;width:100%}.line-items-table th{background:#e0ebf7;background:var(--table-header-bg);border-bottom:2px solid #cbd5e1;border-bottom:2px solid var(--table-header-border);color:#1e3a8a;color:var(--table-header-text);font-weight:600;padding:.625rem .5rem;position:-webkit-sticky;position:sticky;text-align:left;top:0;white-space:nowrap}.line-items-table td{border-bottom:1px solid #e2e8f0cc;border-bottom:1px solid var(--border-color);padding:.5rem}.line-items-table tbody tr:hover{background:#f8fafc;background:var(--bg-secondary)}.amount-text{color:#1e293b;color:var(--text-primary);font-weight:500}.invoice-totals{background:#f8fafc;background:var(--bg-secondary);border-radius:.5rem;border-radius:var(--radius);margin-left:auto;margin-top:1.5rem;max-width:400px;padding:1rem}.totals-row{align-items:center;border-bottom:1px solid #e2e8f0cc;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;padding:.5rem 0}.totals-row:last-child{border-bottom:none}.totals-row-total{border-top:2px solid #e2e8f0cc;border-top:2px solid var(--border-color);font-size:.85rem;font-weight:600;padding-top:.75rem}.totals-label{color:#64748b;color:var(--text-secondary);font-size:.75rem}.totals-value{color:#1e293b;color:var(--text-primary);font-size:.8rem;font-weight:600}.totals-row-total .totals-label,.totals-row-total .totals-value{color:#2563eb;color:var(--primary);font-size:.9rem}.skeleton-container{padding:1rem}.skeleton-row{border-bottom:1px solid #e2e8f0cc;border-bottom:1px solid var(--border-color);display:flex;gap:1rem;padding:.75rem}.skeleton-cell{animation:skeleton-loading 1.5s infinite;background:linear-gradient(90deg,#f1f5f9 25%,#e2e8f0 50%,#f1f5f9 75%);background-size:200% 100%;border-radius:.375rem;border-radius:var(--radius-sm);height:1rem}@keyframes skeleton-loading{0%{background-position:200% 0}to{background-position:-200% 0}}.empty-state{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:400px;padding:3rem 1.5rem;text-align:center}.empty-state-icon{color:#94a3b8;color:var(--text-muted);margin-bottom:1rem;opacity:.5}.empty-state-title{color:#1e293b;color:var(--text-primary);font-size:1rem;font-weight:600;margin:0 0 .5rem}.empty-state-message{color:#64748b;color:var(--text-secondary);font-size:.8rem;margin:0 0 1.5rem}@media (max-width:1024px){.form-grid-2,.form-grid-3{grid-template-columns:1fr}.modal-xlarge{max-width:95vw;width:95%}.search-panel{bottom:0;position:fixed;right:0;top:0;z-index:2000}}@media (max-width:768px){.module-header{align-items:stretch;flex-direction:column}.module-toolbar{justify-content:space-between}.pagination-footer{align-items:stretch;flex-direction:column}}.collapsible-legend{cursor:pointer;-webkit-user-select:none;user-select:none}.collapsible-legend:hover{opacity:.8}.scs-container{position:relative;width:100%}.scs-input{background:var(--bg-primary);border:1px solid #334155;border:1px solid var(--input-border-color,#334155);border-radius:var(--radius-sm);color:var(--text-primary);font-size:.875rem;outline:none;padding:.5rem .75rem;transition:border-color var(--transition-fast);width:100%}.scs-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1a}.scs-dropdown{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-sm);box-shadow:0 4px 12px #0000001f;box-shadow:var(--shadow-md,0 4px 12px #0000001f);left:0;margin-top:.25rem;max-height:300px;overflow-y:auto;position:absolute;right:0;top:100%;z-index:1000;z-index:var(--z-dropdown,1000)}.scs-suggestion{align-items:center;border-bottom:1px solid #e2e8f080;border-bottom:1px solid var(--border-light,#e2e8f080);cursor:pointer;display:flex;justify-content:space-between;padding:.5rem .75rem;transition:background var(--transition-fast)}.scs-suggestion:last-child{border-bottom:none}.scs-suggestion:hover:not(.scs-suggestion--disabled){background:var(--bg-secondary)}.scs-suggestion--disabled{cursor:not-allowed;opacity:.5}.scs-suggestion-content{flex:1 1;min-width:0}.scs-suggestion-name{color:var(--text-primary);font-size:.8125rem;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.scs-suggestion-subtitle{color:var(--text-muted);font-size:.6875rem;margin-top:.125rem}.scs-badge{border-radius:9999px;flex-shrink:0;font-size:.6875rem;font-weight:600;margin-left:.5rem;padding:.125rem .5rem;white-space:nowrap}.scs-empty,.scs-loading{color:var(--text-muted);font-size:.8125rem;padding:.75rem;text-align:center}.tree-container{display:flex;flex-direction:column;height:100%;overflow:hidden}.tree-toolbar{align-items:center;background:var(--bg-secondary);border-bottom:1px solid var(--border-color);display:flex;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md)}.tree-search{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-primary);flex:1 1;font-size:.8125rem;outline:none;padding:.375rem .625rem;transition:border-color var(--transition-fast)}.tree-search:focus{border-color:var(--primary);box-shadow:0 0 0 2px #2563eb1a}.tree-toolbar-buttons{display:flex;gap:.25rem}.tree-btn{align-items:center;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;display:inline-flex;font-size:.875rem;height:1.75rem;justify-content:center;transition:all var(--transition-fast);width:1.75rem}.tree-btn:hover{background:var(--bg-tertiary);border-color:var(--primary);color:var(--primary)}.tree-content{flex:1 1;overflow-y:auto;padding:var(--spacing-xs) 0}.tree-node{align-items:center;color:var(--text-primary);cursor:pointer;display:flex;font-size:.8125rem;gap:var(--spacing-xs);min-height:2rem;padding:.375rem .75rem;transition:background var(--transition-fast);-webkit-user-select:none;user-select:none}.tree-node:hover{background:var(--bg-secondary)}.tree-node--selected{background:#2563eb14;border-right:2px solid var(--primary)}.tree-node--inactive{opacity:.5}.tree-chevron{color:var(--text-secondary);flex-shrink:0;font-size:.75rem;text-align:center;transition:transform var(--transition-fast);width:1rem}.tree-node-content{flex:1 1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tree-node-actions{display:none;flex-shrink:0;gap:var(--spacing-xs)}.tree-node:hover .tree-node-actions{display:flex}.tree-empty{color:var(--text-muted);font-size:.875rem;padding:2rem;text-align:center}.tree-loading{padding:var(--spacing-md)}.tree-skeleton{padding:.375rem .75rem}.tree-skeleton-bar{animation:tree-pulse 1.5s ease-in-out infinite;background:var(--bg-tertiary);border-radius:var(--radius-sm);height:1rem;width:60%}.tree-skeleton:nth-child(2) .tree-skeleton-bar{width:75%}.tree-skeleton:nth-child(3) .tree-skeleton-bar{width:50%}.tree-skeleton:nth-child(4) .tree-skeleton-bar{width:65%}.tree-skeleton:nth-child(5) .tree-skeleton-bar{width:45%}@keyframes tree-pulse{0%,to{opacity:.4}50%{opacity:.8}}
/*# sourceMappingURL=main.d38ae6ae.css.map*/