better-table 1.1.0 → 1.3.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +187 -18
- package/dist/better-table.cjs.js +1 -1
- package/dist/better-table.cjs.js.map +1 -1
- package/dist/better-table.css +1 -1
- package/dist/better-table.es.js +2225 -980
- package/dist/better-table.es.js.map +1 -1
- package/dist/components/BetterTable/__tests__/helpers/test-data.d.ts +125 -0
- package/dist/components/BetterTable/components/TableActionOverflow.d.ts +16 -0
- package/dist/components/BetterTable/components/TableColumnVisibility.d.ts +4 -0
- package/dist/components/BetterTable/components/TableExpandedRow.d.ts +8 -0
- package/dist/components/BetterTable/components/TableFilterPanel.d.ts +7 -0
- package/dist/components/BetterTable/components/TableFloatingFilter.d.ts +8 -0
- package/dist/components/BetterTable/components/TableRow.d.ts +2 -1
- package/dist/components/BetterTable/components/TableVirtualBody.d.ts +10 -0
- package/dist/components/BetterTable/components/index.d.ts +6 -0
- package/dist/components/BetterTable/constants.d.ts +20 -0
- package/dist/components/BetterTable/context/TableContext.d.ts +15 -65
- package/dist/components/BetterTable/context/TableDataContext.d.ts +18 -0
- package/dist/components/BetterTable/context/TableFilterContext.d.ts +17 -0
- package/dist/components/BetterTable/context/TablePaginationContext.d.ts +19 -0
- package/dist/components/BetterTable/context/TableSelectionContext.d.ts +15 -0
- package/dist/components/BetterTable/context/TableSortContext.d.ts +10 -0
- package/dist/components/BetterTable/context/TableUIContext.d.ts +33 -0
- package/dist/components/BetterTable/context/index.d.ts +14 -2
- package/dist/components/BetterTable/hooks/index.d.ts +6 -0
- package/dist/components/BetterTable/hooks/useColumnResize.d.ts +23 -0
- package/dist/components/BetterTable/hooks/useColumnVisibility.d.ts +24 -0
- package/dist/components/BetterTable/hooks/useExpandableRows.d.ts +19 -0
- package/dist/components/BetterTable/hooks/useFocusTrap.d.ts +6 -0
- package/dist/components/BetterTable/hooks/useMediaQuery.d.ts +8 -0
- package/dist/components/BetterTable/hooks/useTableFilter.d.ts +5 -3
- package/dist/components/BetterTable/hooks/useTablePagination.d.ts +3 -1
- package/dist/components/BetterTable/hooks/useTableSearch.d.ts +3 -1
- package/dist/components/BetterTable/hooks/useTableSort.d.ts +14 -2
- package/dist/components/BetterTable/hooks/useVirtualization.d.ts +25 -0
- package/dist/components/BetterTable/index.d.ts +5 -4
- package/dist/components/BetterTable/types.d.ts +178 -5
- package/dist/components/BetterTable/utils/sortData.d.ts +8 -1
- package/dist/index.d.ts +6 -5
- package/package.json +24 -15
package/dist/better-table.css
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
:root{--bt-color-primary: #3b82f6;--bt-color-primary-hover: #2563eb;--bt-color-primary-light: #eff6ff;--bt-color-success: #22c55e;--bt-color-danger: #ef4444;--bt-color-danger-hover: #dc2626;--bt-color-warning: #f59e0b;--bt-color-info: #06b6d4;--bt-color-text: #1f2937;--bt-color-text-secondary: #6b7280;--bt-color-text-disabled: #9ca3af;--bt-color-border: #e5e7eb;--bt-color-border-hover: #d1d5db;--bt-color-background: #ffffff;--bt-color-background-hover: #f9fafb;--bt-color-background-striped: #f3f4f6;--bt-color-background-selected: #eff6ff;--bt-color-background-header: #f9fafb;--bt-spacing-xs: .25rem;--bt-spacing-sm: .5rem;--bt-spacing-md: .75rem;--bt-spacing-lg: 1rem;--bt-spacing-xl: 1.5rem;--bt-font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--bt-font-size-sm: .875rem;--bt-font-size-md: 1rem;--bt-font-size-lg: 1.125rem;--bt-font-weight-normal: 400;--bt-font-weight-medium: 500;--bt-font-weight-semibold: 600;--bt-border-radius-sm: .25rem;--bt-border-radius-md: .375rem;--bt-border-radius-lg: .5rem;--bt-border-width: 1px;--bt-shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--bt-shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--bt-shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--bt-transition-fast: .15s ease;--bt-transition-normal: .2s ease;--bt-cell-padding-sm: .5rem .75rem;--bt-cell-padding-md: .75rem 1rem;--bt-cell-padding-lg: 1rem 1.25rem;--bt-z-header: 10;--bt-z-modal-backdrop: 100;--bt-z-modal: 101}[data-theme=dark],.bt-dark{--bt-color-text: #f9fafb;--bt-color-text-secondary: #9ca3af;--bt-color-text-disabled: #6b7280;--bt-color-border: #374151;--bt-color-border-hover: #4b5563;--bt-color-background: #1f2937;--bt-color-background-hover: #374151;--bt-color-background-striped: #111827;--bt-color-background-selected: #1e3a5f;--bt-color-background-header: #111827}@media(max-width:768px){:root{--bt-cell-padding-sm: .375rem .5rem;--bt-cell-padding-md: .5rem .75rem;--bt-cell-padding-lg: .75rem 1rem}}.bt-container{font-family:var(--bt-font-family);font-size:var(--bt-font-size-md);color:var(--bt-color-text);width:100%}.bt-table-wrapper{overflow:auto;border-radius:var(--bt-border-radius-md);border:var(--bt-border-width) solid var(--bt-color-border)}.bt-table-wrapper.bt-bordered{border:var(--bt-border-width) solid var(--bt-color-border)}.bt-table{width:100%;border-collapse:collapse;border-spacing:0;background-color:var(--bt-color-background)}.bt-thead{background-color:var(--bt-color-background-header)}.bt-thead.bt-sticky{position:sticky;top:0;z-index:var(--bt-z-header)}.bt-th{padding:var(--bt-cell-padding-md);text-align:left;font-weight:var(--bt-font-weight-semibold);color:var(--bt-color-text);border-bottom:var(--bt-border-width) solid var(--bt-color-border);white-space:nowrap;vertical-align:top}.bt-th.bt-align-center{text-align:center}.bt-th.bt-align-right{text-align:right}.bt-th-content{display:flex;flex-direction:column;gap:var(--bt-spacing-sm)}.bt-th-header{display:flex;align-items:center;justify-content:space-between;gap:var(--bt-spacing-sm)}.bt-th-title{flex:1}.bt-sort-btn{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;padding:0;border:none;background:transparent;cursor:pointer;color:var(--bt-color-text-secondary);border-radius:var(--bt-border-radius-sm);transition:all var(--bt-transition-fast)}.bt-sort-btn:hover{background-color:var(--bt-color-background-hover);color:var(--bt-color-text)}.bt-sort-btn.bt-active{color:var(--bt-color-primary)}.bt-filter-input,.bt-filter-select{width:100%;padding:var(--bt-spacing-xs) var(--bt-spacing-sm);font-size:var(--bt-font-size-sm);border:var(--bt-border-width) solid var(--bt-color-border);border-radius:var(--bt-border-radius-sm);background-color:var(--bt-color-background);color:var(--bt-color-text);transition:border-color var(--bt-transition-fast)}.bt-filter-input:focus,.bt-filter-select:focus{outline:none;border-color:var(--bt-color-primary)}.bt-filter-input::placeholder{color:var(--bt-color-text-disabled)}.bt-tbody{background-color:var(--bt-color-background)}.bt-tr{transition:background-color var(--bt-transition-fast)}.bt-tr.bt-hoverable:hover{background-color:var(--bt-color-background-hover)}.bt-tr.bt-selected{background-color:var(--bt-color-background-selected)}.bt-tr.bt-striped:nth-child(2n){background-color:var(--bt-color-background-striped)}.bt-tr.bt-clickable{cursor:pointer}.bt-td{padding:var(--bt-cell-padding-md);border-bottom:var(--bt-border-width) solid var(--bt-color-border);color:var(--bt-color-text);vertical-align:middle}.bt-td.bt-align-center{text-align:center}.bt-td.bt-align-right{text-align:right}.bt-size-small .bt-th,.bt-size-small .bt-td{padding:var(--bt-cell-padding-sm);font-size:var(--bt-font-size-sm)}.bt-size-large .bt-th,.bt-size-large .bt-td{padding:var(--bt-cell-padding-lg)}.bt-checkbox-cell{width:40px;text-align:center}.bt-checkbox{width:18px;height:18px;cursor:pointer;accent-color:var(--bt-color-primary)}.bt-actions-cell{white-space:nowrap}.bt-actions-wrapper{display:flex;align-items:center;gap:var(--bt-spacing-xs)}.bt-action-btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--bt-spacing-xs);padding:var(--bt-spacing-xs) var(--bt-spacing-sm);font-size:var(--bt-font-size-sm);font-weight:var(--bt-font-weight-medium);border:var(--bt-border-width) solid var(--bt-color-border);border-radius:var(--bt-border-radius-sm);background-color:var(--bt-color-background);color:var(--bt-color-text);cursor:pointer;transition:all var(--bt-transition-fast);text-decoration:none}.bt-action-btn:hover:not(:disabled){background-color:var(--bt-color-background-hover);border-color:var(--bt-color-border-hover)}.bt-action-btn:disabled{opacity:.5;cursor:not-allowed}.bt-action-btn.bt-variant-primary{background-color:var(--bt-color-primary);border-color:var(--bt-color-primary);color:#fff}.bt-action-btn.bt-variant-primary:hover:not(:disabled){background-color:var(--bt-color-primary-hover)}.bt-action-btn.bt-variant-danger{background-color:var(--bt-color-danger);border-color:var(--bt-color-danger);color:#fff}.bt-action-btn.bt-variant-danger:hover:not(:disabled){background-color:var(--bt-color-danger-hover)}.bt-action-btn.bt-variant-ghost{border-color:transparent;background-color:transparent}.bt-action-btn.bt-variant-ghost:hover:not(:disabled){background-color:var(--bt-color-background-hover)}.bt-empty{padding:var(--bt-spacing-xl);text-align:center;color:var(--bt-color-text-secondary)}.bt-empty-icon{font-size:3rem;margin-bottom:var(--bt-spacing-md);opacity:.5}.bt-empty-text{font-size:var(--bt-font-size-md)}.bt-loading{display:flex;align-items:center;justify-content:center;padding:var(--bt-spacing-xl)}.bt-loading-spinner{width:32px;height:32px;border:3px solid var(--bt-color-border);border-top-color:var(--bt-color-primary);border-radius:50%;animation:bt-spin .8s linear infinite}@keyframes bt-spin{to{transform:rotate(360deg)}}.bt-loading-text{margin-left:var(--bt-spacing-md);color:var(--bt-color-text-secondary)}.bt-loading-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background-color:#ffffffb3;z-index:5}.bt-container-loading{position:relative}@media(max-width:1024px){.bt-table-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch}.bt-th,.bt-td{padding:var(--bt-cell-padding-sm);font-size:var(--bt-font-size-sm)}.bt-checkbox-cell{width:36px}}.bt-cards{display:none}@media(max-width:640px){.bt-table{display:none}.bt-cards{display:flex;flex-direction:column;gap:var(--bt-spacing-md);padding:var(--bt-spacing-md)}.bt-table-wrapper{overflow:visible;border:none;border-radius:0}.bt-card{padding:var(--bt-spacing-md);border:var(--bt-border-width) solid var(--bt-color-border);border-radius:var(--bt-border-radius-md);background:var(--bt-color-background);transition:all var(--bt-transition-fast)}.bt-card.bt-selected{background-color:var(--bt-color-background-selected);border-color:var(--bt-color-primary)}.bt-card.bt-hoverable:active{background-color:var(--bt-color-background-hover)}.bt-card-header{display:flex;align-items:center;gap:var(--bt-spacing-sm);padding-bottom:var(--bt-spacing-sm);margin-bottom:var(--bt-spacing-xs);border-bottom:2px solid var(--bt-color-border)}.bt-card-title{font-weight:var(--bt-font-weight-semibold);font-size:var(--bt-font-size-md);flex:1;word-break:break-word}.bt-card-row{display:flex;justify-content:space-between;align-items:flex-start;padding:var(--bt-spacing-xs) 0;border-bottom:var(--bt-border-width) solid var(--bt-color-border);gap:var(--bt-spacing-md)}.bt-card-row:last-child{border-bottom:none}.bt-card-label{font-weight:var(--bt-font-weight-medium);color:var(--bt-color-text-secondary);font-size:var(--bt-font-size-sm);flex-shrink:0;min-width:80px}.bt-card-value{text-align:right;word-break:break-word;flex:1}.bt-card-value-empty{color:var(--bt-color-text-disabled)}.bt-card-actions{display:flex;gap:var(--bt-spacing-sm);margin-top:var(--bt-spacing-md);padding-top:var(--bt-spacing-sm);border-top:var(--bt-border-width) solid var(--bt-color-border)}.bt-card-actions .bt-action-btn{flex:1;justify-content:center;min-height:44px}}.bt-toolbar{display:flex;align-items:center;justify-content:space-between;gap:var(--bt-spacing-md);padding:var(--bt-spacing-md);background-color:var(--bt-color-background);border-bottom:var(--bt-border-width) solid var(--bt-color-border);flex-wrap:wrap}.bt-toolbar-left{display:flex;align-items:center;gap:var(--bt-spacing-md);flex-shrink:1;min-width:0;overflow:visible}.bt-toolbar-right{display:flex;align-items:center;gap:var(--bt-spacing-sm);flex-shrink:0}.bt-search{position:relative;width:250px;flex-shrink:1;min-width:120px}.bt-search-input{width:100%;padding:var(--bt-spacing-sm) var(--bt-spacing-md);padding-left:36px;font-size:var(--bt-font-size-md);border:var(--bt-border-width) solid var(--bt-color-border);border-radius:var(--bt-border-radius-md);background-color:var(--bt-color-background);color:var(--bt-color-text);transition:all var(--bt-transition-fast);box-sizing:border-box}.bt-search-input:focus{outline:none;border-color:var(--bt-color-primary);box-shadow:0 0 0 3px var(--bt-color-primary-light)}.bt-search-input::placeholder{color:var(--bt-color-text-disabled)}.bt-search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--bt-color-text-secondary);pointer-events:none}.bt-search-clear{position:absolute;right:8px;top:50%;transform:translateY(-50%);padding:4px;border:none;background:transparent;color:var(--bt-color-text-secondary);cursor:pointer;border-radius:var(--bt-border-radius-sm);display:flex;align-items:center;justify-content:center}.bt-search-clear:hover{color:var(--bt-color-text);background-color:var(--bt-color-background-hover)}.bt-selection-info{display:flex;align-items:center;gap:var(--bt-spacing-sm);padding:var(--bt-spacing-xs) var(--bt-spacing-sm);background-color:var(--bt-color-primary-light);border-radius:var(--bt-border-radius-sm);font-size:var(--bt-font-size-sm);color:var(--bt-color-primary);white-space:nowrap;flex-shrink:0;z-index:1}.bt-selection-clear{padding:2px 6px;border:none;background:transparent;color:var(--bt-color-primary);cursor:pointer;font-size:var(--bt-font-size-sm);text-decoration:underline;white-space:nowrap}.bt-selection-clear:hover{color:var(--bt-color-primary-hover)}.bt-global-actions{display:flex;align-items:center;gap:var(--bt-spacing-sm)}.bt-global-btn{display:inline-flex;align-items:center;gap:var(--bt-spacing-xs);padding:var(--bt-spacing-sm) var(--bt-spacing-md);font-size:var(--bt-font-size-sm);font-weight:var(--bt-font-weight-medium);border:var(--bt-border-width) solid var(--bt-color-border);border-radius:var(--bt-border-radius-md);background-color:var(--bt-color-background);color:var(--bt-color-text);cursor:pointer;transition:all var(--bt-transition-fast)}.bt-global-btn:hover:not(:disabled){background-color:var(--bt-color-background-hover);border-color:var(--bt-color-border-hover)}.bt-global-btn:disabled{opacity:.5;cursor:not-allowed}.bt-global-btn.bt-variant-primary{background-color:var(--bt-color-primary);border-color:var(--bt-color-primary);color:#fff}.bt-global-btn.bt-variant-primary:hover:not(:disabled){background-color:var(--bt-color-primary-hover)}.bt-global-btn.bt-variant-danger{background-color:var(--bt-color-danger);border-color:var(--bt-color-danger);color:#fff}.bt-global-btn.bt-variant-danger:hover:not(:disabled){background-color:var(--bt-color-danger-hover)}@media(max-width:1024px){.bt-search{width:200px;min-width:150px}}@media(max-width:640px){.bt-toolbar{flex-direction:column;align-items:stretch;gap:var(--bt-spacing-sm)}.bt-toolbar-left,.bt-toolbar-right{width:100%}.bt-toolbar-left{flex-direction:column;gap:var(--bt-spacing-sm)}.bt-search{width:100%;max-width:none}.bt-search-input{font-size:16px}.bt-selection-info{width:100%;justify-content:space-between}.bt-global-actions{flex-wrap:wrap;width:100%}.bt-global-btn{flex:1;min-width:calc(50% - var(--bt-spacing-xs));justify-content:center;min-height:44px}}.bt-pagination{display:flex;align-items:center;justify-content:space-between;gap:var(--bt-spacing-md);padding:var(--bt-spacing-md);background-color:var(--bt-color-background);border-top:var(--bt-border-width) solid var(--bt-color-border);flex-wrap:wrap}.bt-pagination-info{font-size:var(--bt-font-size-sm);color:var(--bt-color-text-secondary)}.bt-pagination-controls{display:flex;align-items:center;gap:var(--bt-spacing-sm)}.bt-pagination-btn{display:inline-flex;align-items:center;justify-content:center;min-width:32px;height:32px;padding:0 var(--bt-spacing-sm);font-size:var(--bt-font-size-sm);font-weight:var(--bt-font-weight-medium);border:var(--bt-border-width) solid var(--bt-color-border);border-radius:var(--bt-border-radius-sm);background-color:var(--bt-color-background);color:var(--bt-color-text);cursor:pointer;transition:all var(--bt-transition-fast)}.bt-pagination-btn:hover:not(:disabled){background-color:var(--bt-color-background-hover);border-color:var(--bt-color-border-hover)}.bt-pagination-btn:disabled{opacity:.5;cursor:not-allowed}.bt-pagination-btn.bt-active{background-color:var(--bt-color-primary);border-color:var(--bt-color-primary);color:#fff}.bt-pagination-pages{display:flex;align-items:center;gap:var(--bt-spacing-xs)}.bt-pagination-ellipsis{padding:0 var(--bt-spacing-xs);color:var(--bt-color-text-secondary)}.bt-page-size{display:flex;align-items:center;gap:var(--bt-spacing-sm)}.bt-page-size-label{font-size:var(--bt-font-size-sm);color:var(--bt-color-text-secondary)}.bt-page-size-select{padding:var(--bt-spacing-xs) var(--bt-spacing-sm);font-size:var(--bt-font-size-sm);border:var(--bt-border-width) solid var(--bt-color-border);border-radius:var(--bt-border-radius-sm);background-color:var(--bt-color-background);color:var(--bt-color-text);cursor:pointer}.bt-page-size-select:focus{outline:none;border-color:var(--bt-color-primary)}.bt-quick-jumper{display:flex;align-items:center;gap:var(--bt-spacing-sm)}.bt-quick-jumper-label{font-size:var(--bt-font-size-sm);color:var(--bt-color-text-secondary)}.bt-quick-jumper-input{width:50px;padding:var(--bt-spacing-xs) var(--bt-spacing-sm);font-size:var(--bt-font-size-sm);border:var(--bt-border-width) solid var(--bt-color-border);border-radius:var(--bt-border-radius-sm);background-color:var(--bt-color-background);color:var(--bt-color-text);text-align:center}.bt-quick-jumper-input:focus{outline:none;border-color:var(--bt-color-primary)}@media(max-width:1024px){.bt-quick-jumper{display:none}}@media(max-width:640px){.bt-pagination{flex-direction:column;gap:var(--bt-spacing-sm)}.bt-pagination-info{order:1;text-align:center}.bt-pagination-controls{order:2;justify-content:center}.bt-page-size{order:3;justify-content:center}.bt-pagination-pages{display:none}.bt-pagination-btn{min-width:44px;height:44px}border-color: var(--bt-color-primary)}.bt-modal-backdrop{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:var(--bt-z-modal-backdrop);animation:bt-fade-in .2s ease}.bt-modal{position:relative;background-color:var(--bt-color-background);border-radius:var(--bt-border-radius-lg);box-shadow:var(--bt-shadow-lg);max-width:90vw;max-height:90vh;overflow:auto;z-index:var(--bt-z-modal);animation:bt-scale-in .2s ease}.bt-modal-sm{width:400px}.bt-modal-md{width:600px}.bt-modal-lg{width:800px}.bt-modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--bt-spacing-lg);border-bottom:var(--bt-border-width) solid var(--bt-color-border)}.bt-modal-title{font-size:var(--bt-font-size-lg);font-weight:var(--bt-font-weight-semibold);color:var(--bt-color-text);margin:0}.bt-modal-close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;border:none;background:transparent;color:var(--bt-color-text-secondary);cursor:pointer;border-radius:var(--bt-border-radius-sm);transition:all var(--bt-transition-fast);font-size:1.25rem}.bt-modal-close:hover{background-color:var(--bt-color-background-hover);color:var(--bt-color-text)}.bt-modal-body{padding:var(--bt-spacing-lg)}.bt-modal-footer{display:flex;align-items:center;justify-content:flex-end;gap:var(--bt-spacing-sm);padding:var(--bt-spacing-lg);border-top:var(--bt-border-width) solid var(--bt-color-border)}@keyframes bt-fade-in{0%{opacity:0}to{opacity:1}}@keyframes bt-scale-in{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@media(max-width:640px){.bt-modal{width:95vw!important;max-height:90vh}.bt-modal-header,.bt-modal-body,.bt-modal-footer{padding:var(--bt-spacing-md)}.bt-modal-footer{flex-direction:column}.bt-modal-footer button{width:100%}.bt-modal-close{min-width:44px;min-height:44px}}
|
|
1
|
+
:root{--bt-color-primary: #3b82f6;--bt-color-primary-hover: #2563eb;--bt-color-primary-light: #eff6ff;--bt-color-success: #22c55e;--bt-color-danger: #ef4444;--bt-color-danger-hover: #dc2626;--bt-color-danger-light: #fecaca;--bt-color-warning: #f59e0b;--bt-color-info: #06b6d4;--bt-color-text: #1f2937;--bt-color-text-secondary: #6b7280;--bt-color-text-disabled: #9ca3af;--bt-color-border: #e5e7eb;--bt-color-border-hover: #d1d5db;--bt-color-background: #ffffff;--bt-color-background-hover: #f9fafb;--bt-color-row-hover: #dbeafe;--bt-color-background-striped: #f9fafb;--bt-color-background-selected: #eff6ff;--bt-color-background-header: #f9fafb;--bt-spacing-xs: .25rem;--bt-spacing-sm: .5rem;--bt-spacing-md: .75rem;--bt-spacing-lg: 1rem;--bt-spacing-xl: 1.5rem;--bt-font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--bt-font-size-sm: .875rem;--bt-font-size-md: 1rem;--bt-font-size-lg: 1.125rem;--bt-font-weight-normal: 400;--bt-font-weight-medium: 500;--bt-font-weight-semibold: 600;--bt-border-radius-sm: .25rem;--bt-border-radius-md: .375rem;--bt-border-radius-lg: .5rem;--bt-border-width: 1px;--bt-shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--bt-shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--bt-shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--bt-shadow-primary: 0 2px 4px rgb(59 130 246 / .3);--bt-shadow-dropdown: 0 4px 12px rgb(0 0 0 / .12);--bt-color-scroll-shadow: rgba(0, 0, 0, .08);--bt-transition-fast: .15s ease;--bt-transition-normal: .2s ease;--bt-cell-padding-sm: .5rem .75rem;--bt-cell-padding-md: .75rem 1rem;--bt-cell-padding-lg: 1rem 1.25rem;--bt-color-overlay: rgba(255, 255, 255, .7);--bt-color-backdrop: rgba(0, 0, 0, .5);--bt-z-header: 10;--bt-z-dropdown: 60;--bt-z-modal-backdrop: 100;--bt-z-modal: 101}[data-theme=dark],.bt-dark{--bt-color-text: #f9fafb;--bt-color-text-secondary: #9ca3af;--bt-color-text-disabled: #6b7280;--bt-color-border: #374151;--bt-color-border-hover: #4b5563;--bt-color-background: #1f2937;--bt-color-background-hover: #374151;--bt-color-row-hover: #2d3f56;--bt-color-background-striped: #111827;--bt-color-background-selected: #1e3a5f;--bt-color-background-header: #111827;--bt-color-overlay: rgba(0, 0, 0, .5);--bt-color-backdrop: rgba(0, 0, 0, .7);--bt-shadow-dropdown: 0 4px 12px rgb(0 0 0 / .32);--bt-color-scroll-shadow: rgba(255, 255, 255, .06)}@media(max-width:768px){:root{--bt-cell-padding-sm: .375rem .5rem;--bt-cell-padding-md: .5rem .75rem;--bt-cell-padding-lg: .75rem 1rem}}.bt-container,.bt-container *,.bt-container *:before,.bt-container *:after{box-sizing:border-box}.bt-container{font-family:var(--bt-font-family);font-size:var(--bt-font-size-md);color:var(--bt-color-text);line-height:1.5;width:100%;-webkit-text-size-adjust:100%}.bt-container :where(table){border-collapse:collapse;border-spacing:0;border:none;margin:0;padding:0;font-size:inherit;font-family:inherit;color:inherit;width:100%}.bt-container :where(thead,tbody,tfoot,tr){border:none;margin:0;padding:0;font-size:inherit;vertical-align:middle}.bt-container :where(th,td){border:none;margin:0;padding:0;font-size:inherit;font-family:inherit;color:inherit;text-align:left;vertical-align:middle}.bt-container :where(button){font-family:inherit;font-size:inherit;line-height:inherit;color:inherit;margin:0;border:none;background:none;cursor:pointer}.bt-container :where(input,select){font-family:inherit;font-size:inherit;color:inherit;margin:0}.bt-container :where(h2){margin:0;padding:0;font-size:inherit;font-weight:inherit;line-height:inherit}.bt-container :where(a){color:inherit;text-decoration:none}.bt-table-wrapper{overflow:auto;border-radius:var(--bt-border-radius-md);border:var(--bt-border-width) solid var(--bt-color-border);box-shadow:var(--bt-shadow-sm);scrollbar-width:thin;scrollbar-color:var(--bt-color-border-hover) transparent}.bt-table-wrapper::-webkit-scrollbar{width:8px;height:8px}.bt-table-wrapper::-webkit-scrollbar-track{background:transparent}.bt-table-wrapper::-webkit-scrollbar-thumb{background-color:var(--bt-color-border-hover);border-radius:4px;border:2px solid transparent;background-clip:content-box}.bt-table-wrapper::-webkit-scrollbar-thumb:hover{background-color:var(--bt-color-text-disabled)}.bt-table-wrapper::-webkit-scrollbar-corner{background:transparent}@supports (overflow: overlay){.bt-table-wrapper{overflow:overlay}}.bt-table-wrapper{background:linear-gradient(to right,var(--bt-color-background) 30%,transparent) left center,linear-gradient(to left,var(--bt-color-background) 30%,transparent) right center,linear-gradient(to right,var(--bt-color-background),transparent) left center,linear-gradient(to left,var(--bt-color-background),transparent) right center,linear-gradient(to right,var(--bt-color-scroll-shadow),transparent) left center,linear-gradient(to left,var(--bt-color-scroll-shadow),transparent) right center;background-size:40px 100%,40px 100%,14px 100%,14px 100%,14px 100%,14px 100%;background-repeat:no-repeat;background-attachment:local,local,scroll,scroll,scroll,scroll}.bt-table-wrapper.bt-bordered{border:var(--bt-border-width) solid var(--bt-color-border)}.bt-table{width:100%;border-collapse:collapse;border-spacing:0;background-color:var(--bt-color-background)}.bt-thead{background-color:var(--bt-color-background-header)}.bt-thead.bt-sticky{position:sticky;top:0;z-index:var(--bt-z-header)}.bt-th{padding:var(--bt-cell-padding-md);text-align:left;font-weight:var(--bt-font-weight-semibold);color:var(--bt-color-text-secondary);font-size:var(--bt-font-size-sm);text-transform:uppercase;letter-spacing:.05em;border-bottom:2px solid var(--bt-color-border);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;vertical-align:top;transition:color var(--bt-transition-fast)}.bt-th.bt-sorted{color:var(--bt-color-primary)}.bt-th.bt-align-center{text-align:center}.bt-th.bt-align-right{text-align:right}.bt-th-content{display:flex;flex-direction:column;gap:var(--bt-spacing-sm);min-width:0}.bt-th-header{display:flex;align-items:center;justify-content:space-between;gap:var(--bt-spacing-sm);min-width:0}.bt-th-title{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.bt-sort-btn{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;padding:0;border:none;background:transparent;cursor:pointer;color:var(--bt-color-text-secondary);border-radius:var(--bt-border-radius-sm);transition:all var(--bt-transition-fast)}.bt-sort-btn:hover{background-color:var(--bt-color-background-hover);color:var(--bt-color-text)}.bt-sort-btn.bt-active{color:var(--bt-color-primary);background-color:var(--bt-color-primary-light)}.bt-sort-btn.bt-active:hover{background-color:color-mix(in srgb,var(--bt-color-primary) 15%,transparent)}.bt-sort-icon{display:block}.bt-filter-panel{padding:var(--bt-spacing-lg) var(--bt-spacing-xl);background-color:var(--bt-color-background-header);border-bottom:var(--bt-border-width) solid var(--bt-color-border);animation:bt-panel-slide .18s ease-out}@keyframes bt-panel-slide{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.bt-filter-panel-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:var(--bt-spacing-lg) var(--bt-spacing-xl)}.bt-filter-field{display:flex;flex-direction:column;gap:var(--bt-spacing-sm)}.bt-filter-field-active .bt-filter-field-label{color:var(--bt-color-primary);font-weight:var(--bt-font-weight-semibold)}.bt-filter-field-label{font-size:var(--bt-font-size-sm);color:var(--bt-color-text-secondary);font-weight:var(--bt-font-weight-medium);letter-spacing:.01em}.bt-filter-field-dates{display:flex;align-items:center;gap:var(--bt-spacing-sm)}.bt-filter-field-separator{color:var(--bt-color-text-disabled);flex-shrink:0;font-size:var(--bt-font-size-sm)}.bt-filter-panel-footer{display:flex;align-items:center;justify-content:flex-end;margin-top:var(--bt-spacing-lg);padding-top:var(--bt-spacing-md);border-top:var(--bt-border-width) solid var(--bt-color-border)}.bt-filter-panel-clear{padding:var(--bt-spacing-sm) var(--bt-spacing-md);border:var(--bt-border-width) solid transparent;background:transparent;color:var(--bt-color-danger);font-size:var(--bt-font-size-sm);font-weight:var(--bt-font-weight-medium);cursor:pointer;border-radius:var(--bt-border-radius-md);transition:all var(--bt-transition-fast)}.bt-filter-panel-clear:hover{background-color:color-mix(in srgb,var(--bt-color-danger) 8%,transparent);border-color:color-mix(in srgb,var(--bt-color-danger) 20%,transparent)}.bt-filter-input,.bt-filter-select{width:100%;padding:var(--bt-spacing-sm) var(--bt-spacing-md);font-size:var(--bt-font-size-sm);border:var(--bt-border-width) solid var(--bt-color-border);border-radius:var(--bt-border-radius-md);background-color:var(--bt-color-background);color:var(--bt-color-text);transition:all var(--bt-transition-fast);box-sizing:border-box}.bt-filter-input:focus,.bt-filter-select:focus{outline:none;border-color:var(--bt-color-primary);box-shadow:0 0 0 3px var(--bt-color-primary-light)}.bt-filter-input::placeholder{color:var(--bt-color-text-disabled)}.bt-filter-select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%236b7280' d='M3 5l3 3 3-3'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:28px;cursor:pointer}.bt-fp-wrapper{display:flex;align-items:center;border:var(--bt-border-width) solid var(--bt-color-border);border-radius:var(--bt-border-radius-md);background-color:var(--bt-color-background);transition:all var(--bt-transition-fast);overflow:hidden}.bt-fp-wrapper:focus-within{border-color:var(--bt-color-primary);box-shadow:0 0 0 2px var(--bt-color-primary-light)}.bt-fp-wrapper.bt-fp-active{border-color:var(--bt-color-primary);background-color:var(--bt-color-primary-light)}.bt-fp-icon{flex-shrink:0;margin-left:8px;color:var(--bt-color-text-disabled);pointer-events:none;display:block}.bt-fp-wrapper:focus-within .bt-fp-icon,.bt-fp-wrapper.bt-fp-active .bt-fp-icon{color:var(--bt-color-primary)}.bt-fp-wrapper .bt-filter-input,.bt-fp-wrapper .bt-filter-select{border:none;box-shadow:none;background:transparent}.bt-fp-wrapper .bt-filter-input:focus,.bt-fp-wrapper .bt-filter-select:focus{box-shadow:none}.bt-fp-wrapper.bt-filter-field-dates{gap:0}.bt-fp-wrapper.bt-filter-field-dates .bt-filter-input{min-width:0;flex:1;border:none;border-radius:0;background:transparent;padding:var(--bt-spacing-sm) var(--bt-spacing-xs)}.bt-fp-wrapper.bt-filter-field-dates .bt-filter-input:focus{box-shadow:none}.bt-fp-wrapper .bt-filter-input[type=number]::-webkit-inner-spin-button,.bt-fp-wrapper .bt-filter-input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.bt-fp-wrapper .bt-filter-input[type=number]{-moz-appearance:textfield}.bt-floating-filter-row{background-color:var(--bt-color-background-header);border-bottom:var(--bt-border-width) solid var(--bt-color-border)}.bt-floating-filter-cell{padding:4px var(--bt-spacing-md)!important;vertical-align:middle}.bt-ff-wrapper{position:relative;display:flex;align-items:center;border:var(--bt-border-width) solid var(--bt-color-border);border-radius:var(--bt-border-radius-sm);background-color:var(--bt-color-background);transition:all var(--bt-transition-fast);overflow:hidden}.bt-ff-wrapper:focus-within{border-color:var(--bt-color-primary);box-shadow:0 0 0 2px var(--bt-color-primary-light)}.bt-ff-wrapper.bt-ff-active{border-color:var(--bt-color-primary);background-color:var(--bt-color-primary-light)}.bt-ff-icon{flex-shrink:0;margin-left:6px;color:var(--bt-color-text-disabled);pointer-events:none}.bt-ff-wrapper:focus-within .bt-ff-icon,.bt-ff-wrapper.bt-ff-active .bt-ff-icon{color:var(--bt-color-primary)}.bt-ff-wrapper .bt-floating-filter-input,.bt-ff-wrapper .bt-floating-filter-select{border:none;box-shadow:none;background:transparent}.bt-ff-wrapper .bt-floating-filter-input:focus,.bt-ff-wrapper .bt-floating-filter-select:focus{box-shadow:none}.bt-floating-filter-input,.bt-floating-filter-select{width:100%;padding:4px var(--bt-spacing-sm);font-size:var(--bt-font-size-sm);border:var(--bt-border-width) solid var(--bt-color-border);border-radius:var(--bt-border-radius-sm);background-color:var(--bt-color-background);color:var(--bt-color-text);transition:all var(--bt-transition-fast);box-sizing:border-box}.bt-floating-filter-input:focus,.bt-floating-filter-select:focus{outline:none;border-color:var(--bt-color-primary);box-shadow:0 0 0 2px var(--bt-color-primary-light)}.bt-floating-filter-input::placeholder{color:var(--bt-color-text-disabled);font-style:italic;letter-spacing:1px}.bt-floating-filter-input[type=number]::-webkit-inner-spin-button,.bt-floating-filter-input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.bt-floating-filter-input[type=number]{-moz-appearance:textfield}.bt-floating-filter-select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%236b7280' d='M3 5l3 3 3-3'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 6px center;padding-right:22px;cursor:pointer}.bt-floating-filter-dates{display:flex;align-items:center;gap:0;border:var(--bt-border-width) solid var(--bt-color-border);border-radius:var(--bt-border-radius-sm);background-color:var(--bt-color-background);overflow:hidden;transition:all var(--bt-transition-fast)}.bt-floating-filter-dates:focus-within{border-color:var(--bt-color-primary);box-shadow:0 0 0 2px var(--bt-color-primary-light)}.bt-floating-filter-dates.bt-ff-active{border-color:var(--bt-color-primary);background-color:var(--bt-color-primary-light)}.bt-floating-filter-dates .bt-floating-filter-input{min-width:0;flex:1;border:none;border-radius:0;background:transparent;font-size:var(--bt-font-size-sm);padding:4px;box-shadow:none}.bt-floating-filter-dates .bt-floating-filter-input:focus{box-shadow:none}.bt-ff-date-sep{flex-shrink:0;color:var(--bt-color-text-disabled);font-size:11px;line-height:1;-webkit-user-select:none;user-select:none}.bt-sticky .bt-floating-filter-row{position:sticky;top:0;z-index:9}.bt-sticky-filter{position:sticky;z-index:9}.bt-size-small .bt-floating-filter-cell{padding:2px var(--bt-spacing-sm)!important}.bt-size-small .bt-floating-filter-input,.bt-size-small .bt-floating-filter-select{padding:2px var(--bt-spacing-xs);font-size:12px}.bt-size-small .bt-ff-icon{width:10px;height:10px;margin-left:4px}.bt-size-large .bt-floating-filter-cell{padding:var(--bt-spacing-sm) var(--bt-spacing-lg)!important}.bt-size-large .bt-floating-filter-input,.bt-size-large .bt-floating-filter-select{padding:var(--bt-spacing-sm) var(--bt-spacing-md);font-size:var(--bt-font-size-md)}.bt-size-large .bt-ff-icon{width:14px;height:14px;margin-left:8px}.bt-tbody{background-color:var(--bt-color-background)}.bt-tr{transition:all var(--bt-transition-fast);border-left:3px solid transparent}.bt-tr.bt-striped:nth-child(2n){background-color:var(--bt-color-background-striped)}.bt-tr.bt-hoverable:hover{background-color:var(--bt-color-row-hover);border-left-color:var(--bt-color-primary);box-shadow:inset 0 0 0 1px var(--bt-color-border-hover)}.bt-tr.bt-selected{background-color:var(--bt-color-background-selected);border-left-color:var(--bt-color-primary)}.bt-tr.bt-selected.bt-hoverable:hover{background-color:color-mix(in srgb,var(--bt-color-primary) 15%,var(--bt-color-background-selected))}.bt-tr.bt-clickable{cursor:pointer}.bt-td{padding:var(--bt-cell-padding-md);border-bottom:var(--bt-border-width) solid var(--bt-color-border);color:var(--bt-color-text);vertical-align:middle;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.bt-td.bt-align-center{text-align:center}.bt-td.bt-align-right{text-align:right}.bt-size-small .bt-th,.bt-size-small .bt-td{padding:var(--bt-cell-padding-sm);font-size:var(--bt-font-size-sm)}.bt-size-large .bt-th,.bt-size-large .bt-td{padding:var(--bt-cell-padding-lg)}.bt-checkbox-cell{width:40px;text-align:center;overflow:visible;text-overflow:clip}.bt-checkbox{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:18px;height:18px;border:2px solid var(--bt-color-border-hover);border-radius:var(--bt-border-radius-sm);background-color:var(--bt-color-background);cursor:pointer;transition:all var(--bt-transition-fast);position:relative;flex-shrink:0}.bt-checkbox:hover{border-color:var(--bt-color-primary)}.bt-checkbox:checked{background-color:var(--bt-color-primary);border-color:var(--bt-color-primary)}.bt-checkbox:checked:after{content:"";position:absolute;left:4px;top:1px;width:6px;height:10px;border:solid white;border-width:0 2px 2px 0;transform:rotate(45deg)}.bt-actions-cell{white-space:nowrap;overflow:visible;text-overflow:clip}.bt-actions-wrapper{display:flex;align-items:center;gap:var(--bt-spacing-xs);opacity:.6;transition:opacity var(--bt-transition-fast)}.bt-tr:hover .bt-actions-wrapper,.bt-tr:focus-within .bt-actions-wrapper,.bt-tr.bt-selected .bt-actions-wrapper{opacity:1}.bt-action-btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--bt-spacing-xs);padding:var(--bt-spacing-xs) var(--bt-spacing-sm);font-size:var(--bt-font-size-sm);font-weight:var(--bt-font-weight-medium);border:var(--bt-border-width) solid var(--bt-color-border);border-radius:var(--bt-border-radius-sm);background-color:var(--bt-color-background);color:var(--bt-color-text);cursor:pointer;transition:all var(--bt-transition-fast);text-decoration:none}.bt-action-btn:hover:not(:disabled){background-color:var(--bt-color-background-hover);border-color:var(--bt-color-border-hover)}.bt-action-btn:disabled{opacity:.5;cursor:not-allowed}.bt-action-btn.bt-variant-primary{background-color:var(--bt-color-primary);border-color:var(--bt-color-primary);color:#fff}.bt-action-btn.bt-variant-primary:hover:not(:disabled){background-color:var(--bt-color-primary-hover)}.bt-action-btn.bt-variant-danger{background-color:var(--bt-color-danger);border-color:var(--bt-color-danger);color:#fff}.bt-action-btn.bt-variant-danger:hover:not(:disabled){background-color:var(--bt-color-danger-hover)}.bt-action-btn.bt-variant-ghost{border-color:transparent;background-color:transparent}.bt-action-btn.bt-variant-ghost:hover:not(:disabled){background-color:var(--bt-color-background-hover)}.bt-action-icon-only{padding:var(--bt-spacing-xs);min-width:32px;min-height:32px}.bt-overflow-container{position:relative;display:inline-flex}.bt-overflow-trigger{padding:var(--bt-spacing-xs);min-width:32px;min-height:32px;border-color:transparent;background:transparent}.bt-overflow-trigger:hover:not(:disabled){background-color:var(--bt-color-background-hover);border-color:var(--bt-color-border)}.bt-overflow-icon{display:flex;align-items:center;justify-content:center;line-height:1}.bt-overflow-menu{z-index:var(--bt-z-dropdown);min-width:180px;background:var(--bt-color-background);border:var(--bt-border-width) solid var(--bt-color-border);border-radius:var(--bt-border-radius-md);box-shadow:var(--bt-shadow-dropdown);padding:var(--bt-spacing-xs) 0;animation:bt-fade-in .12s ease-out;font-family:var(--bt-font-family);font-size:var(--bt-font-size-md);color:var(--bt-color-text);line-height:1.5}.bt-overflow-menu,.bt-overflow-menu *{box-sizing:border-box}.bt-overflow-menu :where(button,a){font-family:inherit;font-size:inherit;line-height:inherit;color:inherit;margin:0;border:none;background:none;cursor:pointer;text-decoration:none}.bt-overflow-separator{height:1px;background:var(--bt-color-border);margin:var(--bt-spacing-xs) 0}.bt-overflow-item{display:flex;align-items:center;gap:var(--bt-spacing-sm);width:100%;padding:var(--bt-spacing-sm) var(--bt-spacing-md);font-size:var(--bt-font-size-sm);font-weight:var(--bt-font-weight-medium);background:none;border:none;border-left:3px solid transparent;color:var(--bt-color-text);cursor:pointer;text-decoration:none;text-align:left;transition:background-color var(--bt-transition-fast)}.bt-overflow-item:hover:not(:disabled){background-color:var(--bt-color-background-hover)}.bt-overflow-item:disabled{opacity:.5;cursor:not-allowed}.bt-overflow-item-danger{border-left:3px solid var(--bt-color-danger-light)}.bt-overflow-item-danger:hover:not(:disabled){background-color:color-mix(in srgb,var(--bt-color-danger) 8%,transparent)}.bt-overflow-item-icon{flex-shrink:0;font-size:var(--bt-font-size-md);line-height:1}.bt-overflow-item-label{flex:1}.bt-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--bt-spacing-xl) var(--bt-spacing-lg);margin:var(--bt-spacing-lg) auto;max-width:320px;text-align:center;color:var(--bt-color-text-secondary);border:2px dashed var(--bt-color-border);border-radius:var(--bt-border-radius-lg);background-color:var(--bt-color-background-header)}.bt-empty-icon{margin-bottom:var(--bt-spacing-md);color:var(--bt-color-text-disabled)}.bt-empty-svg{display:block}.bt-empty-text{font-size:var(--bt-font-size-md);font-weight:var(--bt-font-weight-medium)}.bt-loading{display:flex;align-items:center;justify-content:center;padding:var(--bt-spacing-xl)}.bt-loading-spinner{width:32px;height:32px;border:3px solid var(--bt-color-border);border-top-color:var(--bt-color-primary);border-radius:50%;animation:bt-spin .8s linear infinite}@keyframes bt-spin{to{transform:rotate(360deg)}}.bt-loading-text{margin-left:var(--bt-spacing-md);color:var(--bt-color-text-secondary)}.bt-loading-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background-color:var(--bt-color-overlay);z-index:5}.bt-container-loading{position:relative}.bt-sort-btn:focus-visible,.bt-action-btn:focus-visible,.bt-overflow-trigger:focus-visible,.bt-checkbox:focus-visible{outline:none;box-shadow:0 0 0 2px var(--bt-color-background),0 0 0 4px var(--bt-color-primary)}.bt-tr:focus-visible{outline:none;box-shadow:inset 0 0 0 2px var(--bt-color-primary)}@media(max-width:1024px){.bt-table-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch}.bt-th,.bt-td{padding:var(--bt-cell-padding-sm);font-size:var(--bt-font-size-sm)}.bt-checkbox-cell{width:36px}}.bt-table,.bt-cards{animation:bt-fade-in .15s ease-out}.bt-cards{display:flex;flex-direction:column;gap:var(--bt-spacing-md);padding:var(--bt-spacing-md)}@media(max-width:640px){.bt-table-wrapper{overflow:visible;border:none;border-radius:0}.bt-card{padding:var(--bt-spacing-md);border:var(--bt-border-width) solid var(--bt-color-border);border-radius:var(--bt-border-radius-md);background:var(--bt-color-background);box-shadow:var(--bt-shadow-sm);transition:all var(--bt-transition-fast)}.bt-card.bt-hoverable:active{background-color:var(--bt-color-background-hover);box-shadow:var(--bt-shadow-md)}.bt-card.bt-selected{background-color:var(--bt-color-background-selected);border-color:var(--bt-color-primary);box-shadow:var(--bt-shadow-md)}.bt-card-header{display:flex;align-items:center;gap:var(--bt-spacing-sm);padding-bottom:var(--bt-spacing-sm);margin-bottom:var(--bt-spacing-xs);border-bottom:2px solid var(--bt-color-border)}.bt-card-title{font-weight:var(--bt-font-weight-semibold);font-size:var(--bt-font-size-md);flex:1;word-break:break-word}.bt-card-row{display:flex;justify-content:space-between;align-items:flex-start;padding:var(--bt-spacing-xs) 0;border-bottom:var(--bt-border-width) solid var(--bt-color-border);gap:var(--bt-spacing-md)}.bt-card-row:last-child{border-bottom:none}.bt-card-label{font-weight:var(--bt-font-weight-medium);color:var(--bt-color-text-secondary);font-size:var(--bt-font-size-sm);flex-shrink:0;min-width:80px}.bt-card-value{text-align:right;word-break:break-word;flex:1}.bt-card-value-empty{color:var(--bt-color-text-disabled)}.bt-card-actions{display:flex;align-items:center;gap:var(--bt-spacing-sm);margin-top:var(--bt-spacing-md);padding-top:var(--bt-spacing-sm);border-top:var(--bt-border-width) solid var(--bt-color-border)}.bt-card-actions .bt-action-btn{justify-content:center;min-height:44px;min-width:44px}.bt-card-actions .bt-overflow-trigger{min-height:44px;min-width:44px}}.bt-table-resizable{table-layout:fixed}.bt-th-resizable{position:relative}.bt-resize-handle{position:absolute;top:0;right:-2px;width:5px;height:100%;cursor:col-resize;z-index:1;-webkit-user-select:none;user-select:none;touch-action:none}.bt-resize-handle:after{content:"";position:absolute;top:25%;right:2px;width:1px;height:50%;background-color:var(--bt-color-border-hover);transition:background-color var(--bt-transition-fast),width var(--bt-transition-fast)}.bt-resize-handle:hover:after,.bt-resize-handle:active:after{width:3px;right:1px;background-color:var(--bt-color-primary);border-radius:1px}.bt-sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.bt-expand-cell{width:40px;min-width:40px;max-width:40px;text-align:center;padding:0!important;overflow:visible;text-overflow:clip}.bt-expand-button{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;margin:0;border:none;border-radius:var(--bt-radius);background:transparent;color:var(--bt-color-text-secondary);cursor:pointer;transition:transform .2s ease,background-color .15s ease,color .15s ease}.bt-expand-button:hover{background-color:var(--bt-color-hover);color:var(--bt-color-text)}.bt-expand-button:focus-visible{outline:2px solid var(--bt-color-primary);outline-offset:1px}.bt-expand-button-expanded .bt-expand-icon{transform:rotate(90deg)}.bt-expand-icon{transition:transform .2s ease}.bt-expanded-row .bt-expanded-content{padding:var(--bt-spacing-md) var(--bt-spacing-lg);background-color:var(--bt-color-bg-subtle, var(--bt-color-bg-secondary));border-bottom:1px solid var(--bt-color-border);overflow:visible;white-space:normal;text-overflow:clip}.bt-tr.bt-expanded{border-bottom-color:transparent}.bt-toolbar{display:flex;align-items:center;justify-content:space-between;gap:var(--bt-spacing-md);padding:var(--bt-spacing-md);background-color:var(--bt-color-background);border-bottom:var(--bt-border-width) solid var(--bt-color-border);flex-wrap:wrap}.bt-toolbar-left{display:flex;align-items:center;gap:var(--bt-spacing-md);flex-shrink:1;min-width:0;overflow:visible}.bt-toolbar-right{display:flex;align-items:center;gap:var(--bt-spacing-sm);flex-shrink:0}.bt-search{position:relative;width:250px;flex-shrink:1;min-width:120px}.bt-search-input{width:100%;padding:var(--bt-spacing-sm) var(--bt-spacing-md);padding-left:36px;font-size:var(--bt-font-size-md);border:var(--bt-border-width) solid var(--bt-color-border);border-radius:var(--bt-border-radius-md);background-color:var(--bt-color-background);color:var(--bt-color-text);transition:all var(--bt-transition-fast);box-sizing:border-box}.bt-search-input:focus{outline:none;border-color:var(--bt-color-primary);box-shadow:0 0 0 3px var(--bt-color-primary-light)}.bt-search-input::placeholder{color:var(--bt-color-text-disabled)}.bt-search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--bt-color-text-secondary);pointer-events:none;display:flex;align-items:center}.bt-search-svg{display:block}.bt-search-clear{position:absolute;right:8px;top:50%;transform:translateY(-50%);padding:4px;border:none;background:transparent;color:var(--bt-color-text-secondary);cursor:pointer;border-radius:var(--bt-border-radius-sm);display:flex;align-items:center;justify-content:center}.bt-search-clear:hover{color:var(--bt-color-text);background-color:var(--bt-color-background-hover)}.bt-global-btn:focus-visible,.bt-filter-toggle:focus-visible,.bt-search-toggle:focus-visible,.bt-search-clear:focus-visible,.bt-selection-clear:focus-visible{outline:none;box-shadow:0 0 0 2px var(--bt-color-background),0 0 0 4px var(--bt-color-primary)}.bt-clear-svg,.bt-check-svg{display:block}.bt-selection-info{display:flex;align-items:center;gap:var(--bt-spacing-sm);padding:var(--bt-spacing-xs) var(--bt-spacing-sm);background-color:var(--bt-color-primary-light);border-radius:var(--bt-border-radius-sm);font-size:var(--bt-font-size-sm);color:var(--bt-color-primary);white-space:nowrap;flex-shrink:0;z-index:1}.bt-selection-clear{padding:2px 6px;border:none;background:transparent;color:var(--bt-color-primary);cursor:pointer;font-size:var(--bt-font-size-sm);text-decoration:underline;white-space:nowrap}.bt-selection-clear:hover{color:var(--bt-color-primary-hover)}.bt-global-actions{display:flex;align-items:center;gap:var(--bt-spacing-sm)}.bt-global-btn{display:inline-flex;align-items:center;gap:var(--bt-spacing-xs);padding:var(--bt-spacing-sm) var(--bt-spacing-md);font-size:var(--bt-font-size-sm);font-weight:var(--bt-font-weight-medium);border:var(--bt-border-width) solid var(--bt-color-border);border-radius:var(--bt-border-radius-md);background-color:var(--bt-color-background);color:var(--bt-color-text);cursor:pointer;transition:all var(--bt-transition-fast)}.bt-global-btn:hover:not(:disabled){background-color:var(--bt-color-background-hover);border-color:var(--bt-color-border-hover)}.bt-global-btn:disabled{opacity:.5;cursor:not-allowed}.bt-global-btn.bt-variant-primary{background-color:var(--bt-color-primary);border-color:var(--bt-color-primary);color:#fff}.bt-global-btn.bt-variant-primary:hover:not(:disabled){background-color:var(--bt-color-primary-hover)}.bt-global-btn.bt-variant-danger{background-color:var(--bt-color-danger);border-color:var(--bt-color-danger);color:#fff}.bt-global-btn.bt-variant-danger:hover:not(:disabled){background-color:var(--bt-color-danger-hover)}.bt-filter-toggle{display:inline-flex;align-items:center;gap:var(--bt-spacing-xs);padding:var(--bt-spacing-sm) var(--bt-spacing-md);font-size:var(--bt-font-size-sm);font-weight:var(--bt-font-weight-medium);border:var(--bt-border-width) solid var(--bt-color-border);border-radius:var(--bt-border-radius-md);background-color:var(--bt-color-background);color:var(--bt-color-text);cursor:pointer;transition:all var(--bt-transition-fast);flex-shrink:0;white-space:nowrap}.bt-filter-toggle:hover{background-color:var(--bt-color-background-hover);border-color:var(--bt-color-border-hover)}.bt-filter-toggle-active{border-color:var(--bt-color-primary);color:var(--bt-color-primary);background-color:var(--bt-color-primary-light)}.bt-filter-toggle-active:hover{background-color:var(--bt-color-primary-light)}.bt-filter-toggle-icon{display:flex;align-items:center;line-height:1}.bt-filter-toggle-svg{display:block}.bt-filter-toggle-badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 4px;font-size:11px;font-weight:var(--bt-font-weight-semibold);background-color:var(--bt-color-primary);color:#fff;border-radius:9px;line-height:1}@media(max-width:1024px){.bt-search{width:200px;min-width:150px}}.bt-search-toggle{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;padding:0;border:var(--bt-border-width) solid var(--bt-color-border);border-radius:var(--bt-border-radius-md);background-color:var(--bt-color-background);color:var(--bt-color-text-secondary);cursor:pointer;transition:all var(--bt-transition-fast);flex-shrink:0;font-size:16px}.bt-search-toggle:hover{background-color:var(--bt-color-background-hover);border-color:var(--bt-color-border-hover);color:var(--bt-color-text)}.bt-global-btn-mobile{padding:var(--bt-spacing-sm);min-width:40px;min-height:40px;justify-content:center}.bt-global-btn-mobile .bt-global-icon{margin:0}@media(max-width:640px){.bt-toolbar{flex-direction:row;align-items:center;gap:var(--bt-spacing-sm);padding:var(--bt-spacing-sm) var(--bt-spacing-md)}.bt-toolbar-left{flex:1;min-width:0;gap:var(--bt-spacing-sm)}.bt-toolbar-right{flex-shrink:0}.bt-search-mobile{width:100%;min-width:0;flex:1}.bt-search-input{font-size:16px}.bt-selection-info{flex-shrink:1;min-width:0}.bt-selection-count{white-space:nowrap}.bt-selection-clear{padding:4px;text-decoration:none;font-size:14px;line-height:1}.bt-global-actions{gap:var(--bt-spacing-xs)}.bt-global-btn{min-height:40px}.bt-filter-toggle{padding:var(--bt-spacing-sm);min-width:40px;min-height:40px;justify-content:center}.bt-filter-panel{padding:var(--bt-spacing-md)}.bt-filter-panel-grid{grid-template-columns:1fr;gap:var(--bt-spacing-md)}.bt-filter-field-dates{flex-direction:column}.bt-filter-field-separator{display:none}}.bt-column-visibility{position:relative}.bt-column-visibility-btn{display:inline-flex;align-items:center;gap:var(--bt-spacing-xs);padding:var(--bt-spacing-sm) var(--bt-spacing-md);font-size:var(--bt-font-size-sm);font-weight:var(--bt-font-weight-medium);border:var(--bt-border-width) solid var(--bt-color-border);border-radius:var(--bt-border-radius-md);background-color:var(--bt-color-background);color:var(--bt-color-text);cursor:pointer;transition:all var(--bt-transition-fast);white-space:nowrap}.bt-column-visibility-btn:hover{background-color:var(--bt-color-background-hover);border-color:var(--bt-color-border-hover)}.bt-column-visibility-btn-active{border-color:var(--bt-color-primary);color:var(--bt-color-primary)}.bt-column-visibility-badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;font-size:.7rem;font-weight:var(--bt-font-weight-semibold);line-height:1;background-color:var(--bt-color-primary);color:#fff;border-radius:999px}.bt-column-visibility-dropdown{position:absolute;top:calc(100% + 4px);left:0;z-index:var(--bt-z-dropdown);min-width:200px;max-height:320px;background-color:var(--bt-color-background);border:var(--bt-border-width) solid var(--bt-color-border);border-radius:var(--bt-border-radius-lg);box-shadow:var(--bt-shadow-dropdown);overflow:hidden;display:flex;flex-direction:column}.bt-column-visibility-header{display:flex;align-items:center;justify-content:space-between;padding:var(--bt-spacing-sm) var(--bt-spacing-md);border-bottom:var(--bt-border-width) solid var(--bt-color-border)}.bt-column-visibility-title{font-size:var(--bt-font-size-sm);font-weight:var(--bt-font-weight-semibold);color:var(--bt-color-text-secondary);text-transform:uppercase;letter-spacing:.04em}.bt-column-visibility-show-all{font-size:var(--bt-font-size-sm);color:var(--bt-color-primary);cursor:pointer;background:none;border:none;padding:2px 6px;border-radius:var(--bt-border-radius-sm);transition:background var(--bt-transition-fast)}.bt-column-visibility-show-all:hover{background-color:var(--bt-color-primary-light)}.bt-column-visibility-list{overflow-y:auto;padding:var(--bt-spacing-xs) 0}.bt-column-visibility-item{display:flex;align-items:center;gap:var(--bt-spacing-sm);width:100%;padding:var(--bt-spacing-sm) var(--bt-spacing-md);font-size:var(--bt-font-size-sm);color:var(--bt-color-text);background:none;border:none;cursor:pointer;transition:background var(--bt-transition-fast);text-align:left}.bt-column-visibility-item:hover{background-color:var(--bt-color-background-hover)}.bt-column-visibility-item-hidden{color:var(--bt-color-text-disabled)}.bt-column-visibility-check{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border:var(--bt-border-width) solid var(--bt-color-border);border-radius:var(--bt-border-radius-sm);flex-shrink:0;transition:all var(--bt-transition-fast)}.bt-column-visibility-check-active{background-color:var(--bt-color-primary);border-color:var(--bt-color-primary);color:#fff}.bt-column-visibility-item-label{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.bt-sort-priority{position:absolute;top:-6px;right:-6px;display:inline-flex;align-items:center;justify-content:center;min-width:14px;height:14px;padding:0 3px;font-size:.6rem;font-weight:var(--bt-font-weight-semibold);line-height:1;background-color:var(--bt-color-primary);color:#fff;border-radius:999px}.bt-sort-btn{position:relative}@media(max-width:640px){.bt-column-visibility-label{display:none}.bt-column-visibility-btn{padding:var(--bt-spacing-sm);min-width:40px;min-height:40px;justify-content:center}.bt-column-visibility-dropdown{left:auto;right:0}}.bt-pagination{display:flex;align-items:center;justify-content:space-between;gap:var(--bt-spacing-md);padding:var(--bt-spacing-md);background-color:var(--bt-color-background);border-top:var(--bt-border-width) solid var(--bt-color-border);flex-wrap:wrap}.bt-pagination-info{font-size:var(--bt-font-size-sm);color:var(--bt-color-text-secondary)}.bt-pagination-controls{display:flex;align-items:center;gap:var(--bt-spacing-sm)}.bt-pagination-btn{display:inline-flex;align-items:center;justify-content:center;min-width:32px;height:32px;padding:0 var(--bt-spacing-sm);font-size:var(--bt-font-size-sm);font-weight:var(--bt-font-weight-medium);border:var(--bt-border-width) solid var(--bt-color-border);border-radius:var(--bt-border-radius-sm);background-color:var(--bt-color-background);color:var(--bt-color-text);cursor:pointer;transition:all var(--bt-transition-fast)}.bt-pagination-svg{display:block}.bt-pagination-btn:hover:not(:disabled){background-color:var(--bt-color-background-hover);border-color:var(--bt-color-border-hover)}.bt-pagination-btn:disabled{opacity:.5;cursor:not-allowed}.bt-pagination-btn.bt-active{background-color:var(--bt-color-primary);border-color:var(--bt-color-primary);color:#fff;box-shadow:var(--bt-shadow-primary)}.bt-pagination-btn:focus-visible{outline:none;box-shadow:0 0 0 2px var(--bt-color-background),0 0 0 4px var(--bt-color-primary)}.bt-pagination-btn.bt-active:focus-visible{box-shadow:var(--bt-shadow-primary),0 0 0 2px var(--bt-color-background),0 0 0 4px var(--bt-color-primary)}.bt-pagination-pages{display:flex;align-items:center;gap:var(--bt-spacing-xs)}.bt-pagination-ellipsis{padding:0 var(--bt-spacing-xs);color:var(--bt-color-text-secondary)}.bt-page-size{display:flex;align-items:center;gap:var(--bt-spacing-sm)}.bt-page-size-label{font-size:var(--bt-font-size-sm);color:var(--bt-color-text-secondary)}.bt-page-size-select{padding:var(--bt-spacing-xs) var(--bt-spacing-sm);font-size:var(--bt-font-size-sm);border:var(--bt-border-width) solid var(--bt-color-border);border-radius:var(--bt-border-radius-sm);background-color:var(--bt-color-background);color:var(--bt-color-text);cursor:pointer}.bt-page-size-select:focus{outline:none;border-color:var(--bt-color-primary)}.bt-quick-jumper{display:flex;align-items:center;gap:var(--bt-spacing-sm)}.bt-quick-jumper-label{font-size:var(--bt-font-size-sm);color:var(--bt-color-text-secondary)}.bt-qj-wrapper{display:flex;align-items:center;border:var(--bt-border-width) solid var(--bt-color-border);border-radius:var(--bt-border-radius-sm);background-color:var(--bt-color-background);overflow:hidden;transition:all var(--bt-transition-fast)}.bt-qj-wrapper:focus-within{border-color:var(--bt-color-primary);box-shadow:0 0 0 2px var(--bt-color-primary-light)}.bt-quick-jumper-input{width:44px;padding:var(--bt-spacing-xs) var(--bt-spacing-sm);font-size:var(--bt-font-size-sm);border:none;background:transparent;color:var(--bt-color-text);text-align:center}.bt-quick-jumper-input:focus{outline:none}.bt-quick-jumper-input::-webkit-inner-spin-button,.bt-quick-jumper-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.bt-quick-jumper-input{-moz-appearance:textfield}.bt-qj-hint{flex-shrink:0;padding:0 6px 0 2px;font-size:12px;color:var(--bt-color-text-disabled);line-height:1;-webkit-user-select:none;user-select:none}@media(max-width:1024px){.bt-quick-jumper{display:none}}@media(max-width:640px){.bt-pagination{flex-direction:column;gap:var(--bt-spacing-sm)}.bt-pagination-info{order:1;text-align:center}.bt-pagination-controls{order:2;justify-content:center}.bt-page-size{order:3;justify-content:center}.bt-pagination-pages{display:none}.bt-pagination-btn{min-width:44px;height:44px}}.bt-modal-backdrop{position:fixed;inset:0;background-color:var(--bt-color-backdrop);display:flex;align-items:center;justify-content:center;z-index:var(--bt-z-modal-backdrop);animation:bt-fade-in .2s ease}.bt-modal{position:relative;background-color:var(--bt-color-background);border-radius:var(--bt-border-radius-lg);box-shadow:var(--bt-shadow-lg);max-width:90vw;max-height:90vh;overflow:auto;z-index:var(--bt-z-modal);animation:bt-scale-in .2s ease}.bt-modal-sm{width:400px}.bt-modal-md{width:600px}.bt-modal-lg{width:800px}.bt-modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--bt-spacing-lg);border-bottom:var(--bt-border-width) solid var(--bt-color-border)}.bt-modal-title{font-size:var(--bt-font-size-lg);font-weight:var(--bt-font-weight-semibold);color:var(--bt-color-text);margin:0}.bt-modal-close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;border:none;background:transparent;color:var(--bt-color-text-secondary);cursor:pointer;border-radius:var(--bt-border-radius-sm);transition:all var(--bt-transition-fast)}.bt-modal-close-svg{display:block}.bt-modal-close:hover{background-color:var(--bt-color-background-hover);color:var(--bt-color-text)}.bt-modal-body{padding:var(--bt-spacing-lg)}.bt-modal-footer{display:flex;align-items:center;justify-content:flex-end;gap:var(--bt-spacing-sm);padding:var(--bt-spacing-lg);border-top:var(--bt-border-width) solid var(--bt-color-border)}@keyframes bt-fade-in{0%{opacity:0}to{opacity:1}}@keyframes bt-scale-in{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@media(max-width:640px){.bt-modal{width:95vw!important;max-height:90vh}.bt-modal-header,.bt-modal-body,.bt-modal-footer{padding:var(--bt-spacing-md)}.bt-modal-footer{flex-direction:column}.bt-modal-footer button{width:100%}.bt-modal-close{min-width:44px;min-height:44px}}
|