:root{--color-primary: #334155;--color-primary-light: #475569;--color-primary-dark: #1e293b;--color-primary-darker: #0f172a;--color-accent: #22c55e;--color-accent-light: #4ade80;--color-accent-dark: #16a34a;--color-secondary: #059669;--color-secondary-light: #10b981;--color-background: #1e293b;--color-surface: #334155;--color-surface-light: #475569;--color-text: rgba(255, 255, 255, .87);--color-text-muted: rgba(255, 255, 255, .6);--color-text-dim: rgba(255, 255, 255, .4);--color-border: rgba(255, 255, 255, .1);--color-border-light: rgba(255, 255, 255, .2);--color-error: #ef4444;--color-warning: #f59e0b;--color-success: #22c55e;--gradient-primary: linear-gradient(135deg, #334155 0%, #1e293b 100%);--gradient-accent: linear-gradient(135deg, #22c55e 0%, #059669 100%);font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:var(--color-text);background-color:var(--color-background);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:var(--color-accent);text-decoration:inherit}a:hover{color:var(--color-accent-light)}body{margin:0;min-width:320px;min-height:100vh}#root{min-height:100vh}.loading-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background:var(--gradient-primary)}.loading-spinner{width:40px;height:40px;border:4px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:var(--color-surface);color:var(--color-text);cursor:pointer;transition:border-color .25s,background-color .25s}button:hover{border-color:var(--color-accent)}button:focus,button:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}@media(prefers-color-scheme:light){:root{--color-background: #f8fafc;--color-surface: #ffffff;--color-surface-light: #f1f5f9;--color-text: #334155;--color-text-muted: #64748b;--color-text-dim: #94a3b8;--color-border: rgba(51, 65, 85, .1);--color-border-light: rgba(51, 65, 85, .2)}a:hover{color:var(--color-accent-dark)}}.data-table-container{width:100%}.data-table-search{position:relative;margin-bottom:1rem;max-width:300px}.search-icon{position:absolute;left:.75rem;top:50%;transform:translateY(-50%);width:20px;height:20px;color:#999;pointer-events:none}.data-table-search-input{width:100%;padding:.75rem 1rem .75rem 2.75rem;border:2px solid #21a5a2;border-radius:8px;font-size:.9rem;transition:border-color .2s,box-shadow .2s}.data-table-search-input:focus{outline:none;border-color:#1a8a87;box-shadow:0 0 0 3px #21a5a233}.data-table-search-input:focus+.search-icon,.data-table-search:focus-within .search-icon{color:#21a5a2}.data-table-wrapper{overflow-x:auto;border-radius:8px;border:2px solid #21a5a2}.data-table{width:100%;border-collapse:collapse;background:var(--color-surface)}.data-table.editable{table-layout:auto;min-width:max-content}.data-table th,.data-table td{padding:.875rem 1rem;text-align:left;border-right:1px solid rgba(255,255,255,.3)}.data-table th:last-child,.data-table td:last-child{border-right:none}.data-table th{background:#21a5a2;color:#fff;font-weight:600;font-size:.9rem;white-space:pre-line;text-align:center;-webkit-user-select:none;user-select:none;border-bottom:2px solid #1a8a87}.data-table th.sortable{cursor:pointer;transition:background-color .2s}.data-table th.sortable:hover{background:#1a8a87}.th-content{display:flex;align-items:center;gap:.5rem}.sort-icon{width:18px;height:18px;color:#fff9;flex-shrink:0}.sort-icon.active{color:#fff}.data-table tbody tr:nth-child(odd){background:var(--color-surface)}.data-table tbody tr:nth-child(2n){background:var(--color-surface-light)}.data-table tbody tr{transition:background-color .2s;border-bottom:1px solid var(--color-border)}.data-table tbody tr:hover{background:var(--color-primary-light)}.data-table tbody tr.clickable{cursor:pointer}.data-table tbody tr.clickable:hover{background:var(--color-primary-light)}.data-table td{color:var(--color-text)}.data-table td.row-number{background:var(--color-primary-dark);color:var(--color-text-muted);font-weight:500;text-align:center;width:50px}.cell-badge{display:inline-block;padding:.35rem .75rem;background:#21a5a2;color:#fff;border-radius:4px;font-size:.85rem;font-weight:500;min-width:40px;text-align:center}.cell-badge.primary{background:#21a5a2}.cell-badge.secondary{background:#5bc0be}.cell-badge.success{background:#22c55e}.cell-badge.warning{background:#f59e0b}.cell-badge.danger{background:#ef4444}.cell-badge.price:before{content:"$ "}.toggle-switch{position:relative;width:44px;height:24px;background:#ccc;border-radius:24px;cursor:pointer;transition:background .3s;margin:0 auto}.toggle-switch.active{background:#21a5a2}.toggle-switch:after{content:"";position:absolute;top:2px;left:2px;width:20px;height:20px;background:#fff;border-radius:50%;transition:transform .3s;box-shadow:0 1px 3px #0003}.toggle-switch.active:after{transform:translate(20px)}.data-table-empty{text-align:center;padding:2rem;color:var(--color-text-muted);background:var(--color-surface)}.data-table-loading{text-align:center;padding:2rem;color:#21a5a2;background:var(--color-surface)}.data-table-pagination{display:flex;align-items:center;justify-content:flex-end;gap:1.5rem;padding:1rem;background:#21a5a2;color:#fff;font-size:.875rem;border-radius:0 0 6px 6px}.pagination-info{display:flex;align-items:center;gap:.5rem}.select-wrapper{position:relative;display:inline-flex;align-items:center}.page-size-select{appearance:none;-webkit-appearance:none;-moz-appearance:none;background:var(--color-surface);border:none;border-radius:4px;padding:.375rem 2rem .375rem .75rem;font-size:.875rem;color:var(--color-text);cursor:pointer;min-width:60px}.page-size-select:focus{outline:none;box-shadow:0 0 0 2px #ffffff80}.select-icon{position:absolute;right:.5rem;width:16px;height:16px;color:var(--color-text-muted);pointer-events:none}.pagination-range{color:#fff}.pagination-controls{display:flex;align-items:center;gap:.25rem}.pagination-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;border:none;border-radius:4px;background:#fff3;color:#fff;cursor:pointer;transition:background-color .2s}.pagination-btn:hover:not(:disabled){background:#ffffff4d}.pagination-btn:disabled{color:#fff6;cursor:not-allowed}.pagination-btn svg{width:18px;height:18px}@media(max-width:768px){.data-table th,.data-table td{padding:.6rem .5rem;font-size:.85rem}.data-table-search{max-width:100%}.data-table-pagination{flex-wrap:wrap;justify-content:center;gap:1rem}.pagination-info{order:1}.pagination-range{order:3;width:100%;text-align:center}.pagination-controls{order:2}.cell-badge{padding:.25rem .5rem;font-size:.8rem}}.data-table-toolbar{display:flex;justify-content:flex-start;align-items:center;gap:1rem;margin-bottom:1rem}.add-row-btn{padding:.6rem 1.25rem;background:#21a5a2;color:#fff;border:none;border-radius:6px;font-size:.9rem;font-weight:600;cursor:pointer;transition:background .2s,transform .1s}.add-row-btn:hover{background:#1a8a87;transform:translateY(-1px)}.add-row-btn:active{transform:translateY(0)}.data-table.editable td{padding:.25rem .5rem;height:16px;vertical-align:middle;overflow:hidden}.data-table.editable tbody tr{background:var(--color-surface)}.data-table.editable tbody tr:nth-child(2n){background:var(--color-surface-light)}.row-number-header,.row-number{width:50px;min-width:50px;text-align:center;background:var(--color-primary-dark)!important;color:var(--color-text-muted);font-weight:500;font-size:.85rem}.actions-header,.actions-cell{width:120px;min-width:120px;text-align:center;padding-left:.5rem;padding-right:.5rem}.actions-cell{vertical-align:middle;text-align:center}.actions-cell-inner{display:flex;align-items:center;justify-content:center;gap:.35rem}.cell-content{display:flex;align-items:center;min-height:32px}.cell-input{width:100%;max-width:100%;box-sizing:border-box;padding:.4rem .6rem;border:1px solid var(--color-border-light);border-radius:4px;font-size:.85rem;background:var(--color-surface)!important;color:var(--color-text);outline:none;transition:border-color .2s,box-shadow .2s}.cell-input-error{border-color:#ef4444!important}.cell-input-error:focus{box-shadow:0 0 0 2px #ef444433!important}.cell-validation-error{display:block;color:#ef4444;font-size:.7rem;margin-top:2px;line-height:1.2}.cell-input:hover{border-color:#21a5a2}.cell-input:focus{border-color:#21a5a2;box-shadow:0 0 0 2px #21a5a233}.cell-input::placeholder{color:#94a3b8;font-size:.8rem}.cell-select{cursor:pointer;background:var(--color-surface)!important;min-width:0}.multiselect-container{position:relative;width:100%}.multiselect-trigger{display:flex;align-items:center;justify-content:space-between;cursor:pointer;min-height:32px}.multiselect-text{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.multiselect-arrow{font-size:.7rem;margin-left:.5rem;color:#666}.multiselect-dropdown{position:fixed;background:#fff;border:1px solid #21a5a2;border-radius:4px;box-shadow:0 4px 12px #00000026;z-index:9999;max-height:200px;overflow-y:auto;min-width:150px}.multiselect-option{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;cursor:pointer;transition:background .15s}.multiselect-option:hover{background:#f0f9f9}.multiselect-option input[type=checkbox]{width:16px;height:16px;accent-color:#21a5a2;cursor:pointer}.multiselect-option span{font-size:.85rem;color:var(--color-text)}.multiselect-option.selected{background:#e0f7f6}.multiselect-option.selected:hover{background:#d0efee}.multiselect-count{background:#21a5a2;color:#fff;font-size:.7rem;font-weight:600;padding:2px 6px;border-radius:10px;margin-left:4px;flex-shrink:0}.edit-row-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;background:#e0f2fe;border:1px solid #7dd3fc;border-radius:4px;color:#0284c7;cursor:pointer;transition:all .2s}.edit-row-btn:hover{background:#7dd3fc;color:#0369a1}.edit-row-btn svg{width:16px;height:16px}.save-row-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;background:#dcfce7;border:1px solid #86efac;border-radius:4px;color:#16a34a;cursor:pointer;transition:all .2s}.save-row-btn:hover{background:#86efac;color:#166534}.save-row-btn svg{width:16px;height:16px}.delete-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;background:#fee2e2;border:1px solid #fca5a5;border-radius:4px;color:#dc2626;cursor:pointer;transition:all .2s}.delete-btn:hover{background:#fca5a5;color:#991b1b}.delete-btn svg{width:16px;height:16px}.delete-btn.delete-btn-text{width:auto;padding:.35rem .75rem;font-size:.75rem;font-weight:600;background:#fa1302;border:none;color:#fff;border-radius:6px;display:inline-flex;align-items:center;justify-content:center}.delete-btn.delete-btn-text:hover{background:#dc0f00}.cell-badge.readonly{background:#e5e7eb;color:#6b7280}.data-table tbody tr.new-row{background:#fed7aa!important}.data-table tbody tr.dirty-row{background:#fef9c3!important}.data-table tbody tr.status-not-started{background:#fed7aa!important}.data-table tbody tr.status-in-progress{background:#bbf7d0!important}.data-table tbody tr.status-complete{background:#1f2937!important;color:#f9fafb}.data-table tbody tr.status-complete .cell-input{background:#374151!important;color:#f9fafb;border-color:#4b5563}.data-table tbody tr.status-complete .cell-select{background:#374151!important;color:#f9fafb}.save-btn{padding:.6rem 1.25rem;background:#22c55e;color:#fff;border:none;border-radius:6px;font-size:.9rem;font-weight:600;cursor:pointer;transition:background .2s}.save-btn:hover{background:#16a34a}@media(max-width:768px){.data-table-toolbar{flex-direction:column;align-items:stretch}.add-row-btn{width:100%;text-align:center}.cell-input{font-size:16px}.row-number-header,.row-number{width:40px;min-width:40px;font-size:.75rem}.actions-header,.actions-cell{width:60px;min-width:60px}}.navigation{position:fixed;top:0;left:0;right:0;height:60px;background:var(--color-primary-dark);border-bottom:2px solid var(--color-accent);z-index:100;box-shadow:0 2px 10px #0000004d}.nav-container{display:flex;align-items:center;height:100%;padding:0 2rem}.nav-logo{display:flex;align-items:center;text-decoration:none}.nav-logo:hover{opacity:.9}.nav-logo-img{height:50px;width:auto;border-radius:6px;object-fit:contain}.nav-hamburger{display:none;flex-direction:column;justify-content:space-between;width:28px;height:20px;background:transparent;border:none;cursor:pointer;padding:8px;box-sizing:content-box}.hamburger-line{display:block;width:100%;height:3px;background:#fff;border-radius:2px;transition:transform .3s,opacity .3s}.hamburger-line.open:nth-child(1){transform:translateY(8.5px) rotate(45deg)}.hamburger-line.open:nth-child(2){opacity:0}.hamburger-line.open:nth-child(3){transform:translateY(-8.5px) rotate(-45deg)}.nav-links{display:flex;align-items:center;gap:.5rem;margin-left:2rem}.nav-user-section{display:flex;align-items:center;gap:1rem;margin-left:auto;flex-shrink:0}.nav-link{color:#ffffffe6;text-decoration:none;padding:.5rem 1rem;border-radius:8px;font-size:.9rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase;transition:all .2s}.nav-link:hover{color:var(--color-accent-light);background:#22c55e1a}.nav-link.active{color:var(--color-accent);background:#22c55e26;border-bottom:2px solid var(--color-accent)}.nav-user{display:flex;flex-direction:column;align-items:flex-end;margin-right:.5rem}.nav-user-name{color:#fff;font-size:.9rem;font-weight:500}.nav-user-role{color:#fff9;font-size:.75rem;text-transform:capitalize}.nav-logout{padding:.5rem 1.25rem;background:var(--color-accent);color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:.9rem;font-weight:600;transition:all .2s}.nav-logout:hover{background:var(--color-accent-dark)}@media(max-width:768px){.nav-container{padding:0 1rem}.nav-logo{flex-shrink:0}.nav-logo-img{height:40px}.nav-hamburger{display:flex;flex-shrink:0;z-index:101;position:relative;margin-left:auto}.nav-links{display:none;position:fixed;top:60px;left:0;right:0;background:var(--color-primary-dark);flex-direction:column;align-items:stretch;padding:1rem 1rem 6rem;gap:.5rem;z-index:100;margin-left:0}.nav-links.open{display:flex}.nav-user-section{display:none}.nav-links.open~.nav-user-section{display:flex;flex-direction:column;position:fixed;bottom:0;left:0;right:0;background:var(--color-primary-darker);padding:1rem;gap:.75rem;z-index:102;border-top:1px solid var(--color-border)}.nav-link{padding:.75rem 1rem;text-align:left}.nav-link:hover,.nav-link.active{background:#ffffff1a}.nav-user{align-items:center;flex-direction:row;gap:.5rem;margin-right:0;padding:0}.nav-user-name{font-size:.95rem}.nav-user-role{font-size:.75rem}.nav-logout{width:100%;text-align:center;padding:.75rem}}.layout{min-height:100vh;background:var(--gradient-primary)}.layout-content{padding-top:60px}
