.toast-container{position:fixed;top:24px;left:50%;transform:translate(-50%);display:flex;flex-direction:column;gap:8px;z-index:2000;pointer-events:none}.toast{pointer-events:auto;min-width:240px;max-width:480px;padding:12px 18px;border-radius:10px;font-size:13px;font-weight:500;font-family:var(--font);color:#fff;cursor:pointer;box-shadow:0 6px 18px #00000026;animation:toast-in .18s ease-out}.toast--error{background:var(--status-error)}.toast--warning{background:var(--status-warning);color:#1a1631}.toast--success{background:var(--status-success)}.toast--info{background:var(--status-info)}@keyframes toast-in{0%{transform:translateY(-12px);opacity:0}to{transform:translateY(0);opacity:1}}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;background:linear-gradient(135deg,#f8f7fc,#f0eef8);font-family:var(--font)}.login-card{width:100%;max-width:420px;background:#fff;border:1px solid rgba(92,53,168,.1);border-radius:16px;padding:44px 40px 36px;box-shadow:0 4px 24px #5c35a814,0 0 0 1px #5c35a80d}.login-brand{display:flex;flex-direction:row;align-items:center;justify-content:center;gap:10px;margin-bottom:18px}.login-brand-icon{width:36px;height:36px;border-radius:50%;background:#fff;box-shadow:0 2px 10px #5c35a82e;flex-shrink:0;overflow:hidden;display:flex;align-items:center;justify-content:center}.login-brand-icon img{width:160%;height:160%;object-fit:contain}.login-brand-name{font-size:20px;font-weight:900;letter-spacing:.5px;color:#3d3858}.login-title{font-size:26px;font-weight:800;letter-spacing:-.5px;color:#3d3858;margin:0 0 8px;text-align:center}.login-subtitle{font-size:14px;color:#7a7492;margin:0 0 28px;text-align:center;line-height:1.5}.login-field{margin-bottom:18px;text-align:left}.login-field label{display:block;font-size:13px;font-weight:600;color:#3d3858;margin-bottom:8px}.login-input-wrap{position:relative}.login-input{width:100%;background:#f8f7fc;border:1px solid #E2DEEF;border-radius:10px;padding:13px 14px;font-size:14px;font-family:var(--font);color:#3d3858;outline:none;transition:border-color .2s,background .2s,box-shadow .2s}.login-input::placeholder{color:#9d98b5}.login-input:focus{border-color:#7b52c8;background:#fff;box-shadow:0 0 0 3px #7b52c81a}.login-input:disabled{opacity:.6;cursor:not-allowed}.login-input-eye{position:absolute;right:14px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;opacity:.4;color:#3d3858;padding:0;display:flex;align-items:center;transition:opacity .2s}.login-input-eye:hover{opacity:.8}.login-submit-btn{width:100%;padding:14px;background:linear-gradient(135deg,#7B52C8,var(--accent-primary));border:none;border-radius:10px;color:#fff;font-size:15px;font-weight:700;font-family:var(--font);cursor:pointer;transition:all .2s;box-shadow:0 3px 12px #5c35a84d;margin-top:4px}.login-submit-btn:hover:not(:disabled){background:linear-gradient(135deg,#8a63d8,#6b42c0);transform:translateY(-1px);box-shadow:0 6px 20px #5c35a859}.login-submit-btn:active{transform:translateY(0)}.login-submit-btn:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}.login-footer{text-align:center;margin-top:28px;font-size:12px;color:#7a7492;line-height:1.6}.login-footer code{font-family:SFMono-Regular,Consolas,monospace;font-size:11px;color:#3d3858;background:#f0eef8;padding:1px 6px;border-radius:4px}.login-version{text-align:center;margin-top:10px;font-size:11px;color:#b0aac8;font-family:SFMono-Regular,Consolas,monospace}.sidebar{background:var(--sidebar-bg);border-right:1px solid var(--accent-border);display:flex;flex-direction:column;overflow:hidden;height:100vh;position:sticky;top:0}.sidebar-header{padding:16px;border-bottom:1px solid var(--accent-border)}.brand{display:flex;align-items:center;gap:10px}.brand-logo{width:36px;height:36px;border-radius:50%;background:#fff;box-shadow:0 2px 10px #5c35a82e;flex-shrink:0;overflow:hidden;display:flex;align-items:center;justify-content:center}.brand-logo img{width:160%;height:160%;object-fit:contain}.brand-name{font-size:13px;font-weight:800;color:#3d3858;letter-spacing:-.3px}.sidebar-nav{display:flex;flex-direction:column;padding:12px 8px;gap:2px}.sidebar-item{display:flex;align-items:center;gap:10px;width:100%;padding:10px 12px;border:none;background:transparent;border-radius:8px;font-family:var(--font);font-size:13px;font-weight:600;color:var(--text-primary);cursor:pointer;text-align:left;transition:background .15s}.sidebar-item:hover{background:var(--hover-light)}.sidebar-item--active{background:#5c35a81a;color:var(--accent-primary)}.sidebar-item-icon{font-size:14px;width:18px;display:inline-flex;justify-content:center}.sidebar-spacer{flex:1}.sidebar-footer{position:relative;border-top:1px solid var(--accent-border);padding:8px;display:flex;flex-direction:column}.sidebar-user{display:flex;align-items:center;gap:10px;width:100%;padding:8px 10px;border:none;background:transparent;border-radius:8px;font-family:var(--font);font-size:13px;font-weight:600;color:var(--text-primary);cursor:pointer;text-align:left;transition:background .15s}.sidebar-user:hover,.sidebar-user--open{background:var(--hover-light)}.sidebar-user-name{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-user-chevron{font-size:10px;color:var(--text-tertiary);flex-shrink:0}.sidebar-user-menu{position:absolute;bottom:calc(100% - 8px);left:8px;right:8px;background:var(--bg-primary);border:1px solid var(--accent-border);border-radius:8px;box-shadow:0 8px 28px #00000024;padding:4px;display:flex;flex-direction:column;z-index:100;animation:sidebar-menu-in .14s ease-out}@keyframes sidebar-menu-in{0%{transform:translateY(4px);opacity:0}to{transform:translateY(0);opacity:1}}.sidebar-user-menu button{display:flex;align-items:center;gap:10px;width:100%;padding:8px 12px;border:none;background:transparent;border-radius:6px;font-family:var(--font);font-size:13px;font-weight:600;color:var(--text-primary);cursor:pointer;text-align:left;transition:background .12s}.sidebar-user-menu button:hover{background:var(--accent-light);color:var(--accent-primary)}.sidebar-user-menu hr{border:none;border-top:1px solid var(--border-color);margin:4px 0}.bom-tree{display:flex;flex-direction:column;height:100vh;overflow:hidden}.bom-where-used-banner{display:flex;align-items:center;gap:14px;padding:10px 20px;background:var(--accent-light);border-bottom:1px solid var(--accent-border);font-size:13px;color:var(--accent-hover)}.bom-where-used-back{display:inline-flex;align-items:center;gap:4px;padding:5px 12px;background:var(--bg-primary);border:1px solid var(--accent-border);border-radius:6px;font-family:var(--font);font-size:13px;font-weight:600;color:var(--accent-primary);cursor:pointer;transition:background .15s,border-color .15s}.bom-where-used-back:hover{background:#fff;border-color:var(--accent-primary)}.bom-where-used-label{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.bom-where-used-label strong{color:var(--text-primary);font-weight:700}.bom-toolbar{display:flex;align-items:center;gap:12px;padding:14px 20px;border-bottom:1px solid var(--border-color);background:var(--bg-primary)}.bom-search{position:relative;flex:1;max-width:480px}.bom-search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);font-size:13px;opacity:.5;pointer-events:none}.bom-search-input{width:100%;padding:9px 36px 9px 34px;border:1px solid var(--border-color);border-radius:8px;font-family:var(--font);font-size:13px;color:var(--text-primary);background:var(--bg-secondary);outline:none;transition:border-color .15s,background .15s,box-shadow .15s}.bom-search-input:focus{border-color:#7b52c8;background:#fff;box-shadow:0 0 0 3px #7b52c81a}.bom-additional-toggle{display:inline-flex;align-items:center;margin-left:auto;gap:7px;padding:9px 14px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;font-family:var(--font);font-size:13px;font-weight:500;color:var(--text-secondary);cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap;transition:background .15s,border-color .15s,color .15s}.bom-additional-toggle:hover{background:var(--accent-light);border-color:var(--accent-border);color:var(--text-primary)}.bom-additional-toggle input[type=checkbox]{accent-color:var(--accent-primary);width:14px;height:14px;cursor:pointer;flex-shrink:0}.bom-additional-toggle:has(input:checked){border-color:var(--accent-primary);color:var(--accent-primary);background:var(--accent-light)}.bom-search-history{position:absolute;top:calc(100% + 4px);left:0;right:0;z-index:300;background:var(--bg-surface, #fff);border:1px solid var(--border-color, #e0d9f0);border-radius:8px;box-shadow:0 4px 16px #0000001f;max-height:240px;overflow-y:auto;padding:4px 0}.bom-search-history-item{display:flex;align-items:center;gap:8px;width:100%;padding:7px 12px;background:none;border:none;text-align:left;font-family:var(--font);font-size:13px;color:var(--text-primary);cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.bom-search-history-item:hover{background:var(--accent-light, #eae5f5);color:var(--accent-primary)}.bom-search-history-icon{flex-shrink:0;font-size:12px;color:var(--text-secondary)}.bom-search-clear{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;font-size:12px;color:var(--text-secondary);padding:4px 6px;border-radius:4px}.bom-search-clear:hover{background:var(--accent-light);color:var(--text-primary)}.bom-refresh-btn{display:inline-flex;align-items:center;gap:6px;padding:9px 14px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;font-family:var(--font);font-size:13px;font-weight:600;color:var(--text-primary);cursor:pointer;transition:background .15s,border-color .15s}.bom-refresh-btn:hover:not(:disabled){background:var(--accent-light);border-color:var(--accent-border)}.bom-refresh-btn:disabled{opacity:.5;cursor:not-allowed}.bom-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:32px;color:var(--text-secondary);font-size:14px}.bom-empty-error{color:var(--status-error);font-weight:600;margin:0}.bom-empty-detail{font-size:13px;color:var(--text-secondary);max-width:480px;text-align:center;margin:0}.bom-grid-wrap{flex:1;min-height:0;overflow:auto}.bom-grid{width:100%;border-collapse:collapse;font-size:13px;font-family:var(--font)}.bom-grid thead{position:sticky;top:0;background:var(--bg-primary);z-index:1}.bom-grid thead th{padding:10px 12px;text-align:left;font-weight:700;font-size:12px;letter-spacing:.3px;color:var(--text-secondary);border-bottom:2px solid var(--accent-border);background:var(--bg-primary);white-space:nowrap}.bom-grid tbody tr{border-bottom:1px solid var(--border-color);transition:background .1s}.bom-grid tbody tr:nth-child(2n){background:#fafafe}.bom-grid tbody tr:hover{background:#5c35a80a}.bom-row--errored{background:#ef44440f!important}.bom-row--root{font-weight:600}.bom-grid td{padding:8px 12px;vertical-align:middle;color:var(--text-primary)}.bom-col-tree{width:1%;white-space:nowrap}.bom-cell-tree{display:inline-flex;align-items:center;gap:6px}.bom-level-num{font-size:11px;color:var(--text-tertiary, #aaa);min-width:28px;text-align:right;flex-shrink:0;font-variant-numeric:tabular-nums}.bom-chevron{width:18px;height:18px;display:inline-flex;align-items:center;justify-content:center;background:none;border:none;border-radius:4px;cursor:pointer;color:var(--text-secondary);padding:0;flex-shrink:0}.bom-chevron:hover:not(:disabled){background:var(--accent-light);color:var(--accent-primary)}.bom-chevron:disabled{cursor:default}.bom-icon{display:inline-flex;flex-shrink:0}.bom-row-action-btn{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;background:none;border:1px solid transparent;border-radius:4px;cursor:pointer;color:var(--text-tertiary);padding:0;margin-left:2px;flex-shrink:0;transition:color .15s,background .15s,border-color .15s}.bom-row-action-btn:hover:not(:disabled){color:var(--accent-primary);background:var(--accent-light);border-color:var(--accent-border)}.bom-row-action-btn:disabled{opacity:.5;cursor:not-allowed}.bom-row-action-btn--locate{color:var(--accent-orange)}.bom-row-action-btn--locate:hover:not(:disabled){color:var(--accent-orange);background:#f5a6231f;border-color:#f5a62366}@keyframes bom-row-located-flash{0%{background-color:#f5a6238c}to{background-color:#f5a62340}}.bom-row--located{background-color:#f5a62340!important;animation:bom-row-located-flash 1s ease-out}.bom-expand-all-btn{display:inline-flex;align-items:center;gap:4px;background:none;border:1px solid transparent;border-radius:4px;cursor:pointer;font-size:12px;color:var(--text-tertiary);padding:2px 6px;margin-left:4px;transition:color .15s,background .15s,border-color .15s}.bom-expand-all-btn:hover{color:var(--accent-primary);background:var(--accent-light);border-color:var(--accent-border)}.bom-expand-all-progress{font-size:11px;font-weight:600;font-variant-numeric:tabular-nums}.bom-row-menu-wrap{position:relative;display:inline-flex}.bom-row-menu-btn{letter-spacing:1px;font-size:14px;line-height:1}.bom-row-menu{position:absolute;top:calc(100% + 4px);left:0;z-index:200;background:var(--bg-surface, #fff);border:1px solid var(--border-color, #e0d9f0);border-radius:6px;box-shadow:0 4px 14px #0000001f;min-width:120px;padding:4px 0}.bom-row-menu-item{display:block;width:100%;padding:7px 14px;background:none;border:none;text-align:left;font-size:13px;color:var(--text-primary);cursor:pointer;white-space:nowrap}.bom-row-menu-item:hover{background:var(--accent-light, #eae5f5);color:var(--accent-primary)}.export-modal-bom-name{font-size:13px;font-weight:600;color:var(--accent-primary);margin-bottom:16px;word-break:break-word}.export-progress-label{flex:1;font-size:12px;color:var(--text-secondary);font-variant-numeric:tabular-nums;align-self:center}.export-option-desc{color:var(--text-secondary);font-size:11px;font-weight:400}.export-format-group{border:none;padding:0;margin:0 0 16px}.export-section-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary);margin-bottom:8px}.export-format-option{display:flex;align-items:center;gap:8px;padding:5px 0;font-size:13px;cursor:pointer}.bom-col-text{max-width:360px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.bom-col-key{white-space:nowrap}.bom-col-key a{color:var(--accent-primary);text-decoration:none;font-weight:600}.bom-col-key a:hover{color:var(--accent-hover);text-decoration:underline}.bom-status-bar{flex-shrink:0;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:8px 20px;border-top:1px solid var(--border-color);font-size:12px;color:var(--text-secondary);background:var(--bg-secondary)}.bom-status-info{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.bom-pagination{display:flex;align-items:center;gap:4px;flex-shrink:0}.bom-pagination button{padding:4px 10px;font-size:12px;font-family:var(--font);font-weight:600;color:var(--text-primary);background:var(--bg-primary);border:1px solid var(--border-color);border-radius:4px;cursor:pointer;transition:background .15s,border-color .15s}.bom-pagination button:hover:not(:disabled){background:var(--accent-light);border-color:var(--accent-border);color:var(--accent-primary)}.bom-pagination button:disabled{opacity:.4;cursor:not-allowed}.bom-pagination-info{padding:0 8px;font-variant-numeric:tabular-nums;font-weight:600;color:var(--text-primary)}.eco-modal{max-width:min(900px,92vw);width:92vw}.eco-modal-body{padding:0;overflow:hidden;display:flex;flex-direction:column}.eco-modal-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:40px 24px;color:var(--text-secondary);font-size:14px}.eco-modal-error{color:#c0392b}.eco-modal-table-wrap{overflow:auto;flex:1}.eco-modal-table{min-width:100%}.spinner-ring{display:inline-block;border:2px solid;border-radius:50%;animation:spinner-spin .8s linear infinite}@keyframes spinner-spin{to{transform:rotate(360deg)}}.settings-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:flex;justify-content:center;align-items:center;padding:20px;z-index:1500}.settings-modal{background:var(--bg-primary);border-radius:12px;box-shadow:0 12px 40px #0000002e;width:100%;max-width:560px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden;animation:settings-in .2s ease-out}@keyframes settings-in{0%{transform:translateY(-12px);opacity:0}to{transform:translateY(0);opacity:1}}.settings-header{display:flex;justify-content:space-between;align-items:center;padding:18px 22px;border-bottom:1px solid var(--border-color)}.settings-header h2{margin:0;font-size:18px;font-weight:700;color:var(--text-primary)}.settings-close{width:30px;height:30px;border:none;background:none;border-radius:6px;cursor:pointer;font-size:16px;color:var(--text-secondary);display:inline-flex;align-items:center;justify-content:center}.settings-close:hover{background:var(--accent-light);color:var(--text-primary)}.settings-note{padding:12px 22px;background:#f5a62314;border-bottom:1px solid rgba(245,166,35,.2);font-size:12px;color:var(--text-secondary);line-height:1.5}.settings-note code{font-family:SFMono-Regular,Consolas,monospace;font-size:11px;background:var(--bg-secondary);padding:1px 6px;border-radius:4px;color:var(--text-primary)}.settings-body{padding:18px 22px;overflow-y:auto}.settings-field{display:grid;grid-template-columns:160px 1fr;align-items:baseline;padding:10px 0;gap:16px}.settings-field-label{font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.4px}.settings-field-value{font-size:13px;color:var(--text-primary);word-break:break-all}.settings-field-value.mono{font-family:SFMono-Regular,Consolas,monospace;font-size:12px;background:var(--bg-secondary);border:1px solid var(--border-color);padding:6px 10px;border-radius:6px}.settings-field-empty{color:var(--text-tertiary)}.settings-divider{height:1px;background:var(--border-color);margin:14px 0}.settings-footer{display:flex;justify-content:flex-end;gap:8px;padding:14px 22px;border-top:1px solid var(--border-color);background:var(--bg-secondary)}.release-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:flex;justify-content:center;align-items:center;padding:20px;z-index:1500}.release-modal{background:var(--bg-primary);border-radius:12px;box-shadow:0 12px 40px #0000002e;width:100%;max-width:640px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden;animation:release-in .2s ease-out}@keyframes release-in{0%{transform:translateY(-12px);opacity:0}to{transform:translateY(0);opacity:1}}.release-header{display:flex;align-items:center;gap:10px;padding:18px 22px;border-bottom:1px solid var(--border-color)}.release-header h2{margin:0;font-size:18px;font-weight:700;color:var(--text-primary)}.release-current-version{font-size:11px;font-weight:700;letter-spacing:.4px;background:var(--accent-light);color:var(--accent-primary);padding:3px 8px;border-radius:999px}.release-close{margin-left:auto;width:30px;height:30px;border:none;background:none;border-radius:6px;cursor:pointer;font-size:16px;color:var(--text-secondary);display:inline-flex;align-items:center;justify-content:center}.release-close:hover{background:var(--accent-light);color:var(--text-primary)}.release-body{padding:18px 22px;overflow-y:auto}.release-empty{color:var(--text-tertiary);text-align:center;margin:12px 0}.release-entry{padding:14px 0;border-bottom:1px solid var(--border-color)}.release-entry:last-child{border-bottom:none}.release-entry-head{display:flex;align-items:baseline;gap:12px;margin-bottom:6px}.release-entry-version{font-weight:700;color:var(--accent-primary);font-size:14px}.release-entry-date{font-size:12px;color:var(--text-tertiary);font-variant-numeric:tabular-nums}.release-entry-changes{margin:4px 0 0;padding-left:20px;color:var(--text-primary);font-size:13px;line-height:1.55}.release-entry-changes li{margin:2px 0}.release-footer{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:12px 22px;border-top:1px solid var(--border-color);background:var(--bg-secondary)}.release-legend{display:flex;flex-wrap:wrap;gap:10px 16px}.release-legend-item{font-size:11px;color:var(--text-secondary);white-space:nowrap}:root{--accent-primary: #5C35A8;--accent-hover: #3D2070;--accent-light: #EAE5F5;--accent-border: #D4D0E0;--accent-orange: #F5A623;--text-primary: #1A1631;--text-secondary: #6B6580;--text-tertiary: #A8A1BE;--bg-primary: #FFFFFF;--bg-secondary: #F5F5F5;--sidebar-bg: #EAE5F5;--border-color: #E8E4F0;--border-hover: #DDD8E8;--hover-light: #D4D0E0;--status-success: #10B981;--status-warning: #F59E0B;--status-error: #EF4444;--status-info: #3B82F6;--font: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif}*{box-sizing:border-box}html,body{margin:0;padding:0;font-family:var(--font);background:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}button{font-family:var(--font);cursor:pointer}input,textarea,select{font-family:var(--font)}h1{font-size:28px;font-weight:700;line-height:1.2;letter-spacing:-.5px}h2{font-size:24px;font-weight:700;line-height:1.2;letter-spacing:-.4px}h3{font-size:18px;font-weight:700;line-height:1.3;letter-spacing:-.3px}h4{font-size:16px;font-weight:700;line-height:1.4}h5{font-size:14px;font-weight:700;line-height:1.4}h6{font-size:12px;font-weight:700;line-height:1.5;text-transform:uppercase;letter-spacing:.5px}.text-body-large{font-size:15px;font-weight:400;line-height:1.6}.text-body{font-size:13px;font-weight:400;line-height:1.5}.text-body-small{font-size:12px;font-weight:400;line-height:1.5}.text-body-tiny{font-size:11px;font-weight:400;line-height:1.4}.text-primary{color:var(--text-primary)}.text-secondary{color:var(--text-secondary)}.text-tertiary{color:var(--text-tertiary)}.text-muted{color:var(--text-tertiary);opacity:.7}.btn-primary{padding:10px 16px;background:var(--accent-primary);color:#fff;border:none;border-radius:6px;font-size:13px;font-weight:700;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 4px #5c35a833;letter-spacing:.3px}.btn-primary:hover{background:#3d2070;transform:translateY(-2px);box-shadow:0 4px 12px #5c35a84d}.btn-primary:active{transform:translateY(0);box-shadow:0 1px 3px #5c35a833}.btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}.btn-secondary{padding:10px 16px;background:var(--white);color:var(--text-primary);border:1px solid var(--border-color);border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;transition:all .15s cubic-bezier(.4,0,.2,1)}.btn-secondary:hover{background:var(--bg-secondary);border-color:#d4d0e0;color:var(--text-primary);box-shadow:0 1px 3px #0000000d}.btn-secondary:active{background:var(--border-color)}.btn-secondary:disabled{opacity:.5;cursor:not-allowed}.btn-outline{padding:10px 16px;background:var(--white);color:var(--accent-primary);border:1.5px solid var(--accent-primary);border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;transition:all .15s cubic-bezier(.4,0,.2,1)}.btn-outline:hover{background:var(--accent-light);border-color:#3d2070}.btn-outline:active{background:#5c35a81a}.btn-danger{padding:10px 16px;background:var(--status-error);color:#fff;border:none;border-radius:6px;font-size:13px;font-weight:700;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 4px #ef444433}.btn-danger:hover{background:#dc2626;transform:translateY(-2px);box-shadow:0 4px 12px #ef44444d}.btn-danger:active{transform:translateY(0)}.btn-icon{width:32px;height:32px;border-radius:6px;border:none;background:transparent;color:var(--text-secondary);cursor:pointer;transition:all .15s ease;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}.btn-icon:hover{background:var(--hover-light);color:var(--accent-primary)}.form-group{margin-bottom:16px}.form-label{display:block;font-size:12px;font-weight:700;color:var(--text-primary);margin-bottom:6px;text-transform:uppercase;letter-spacing:.3px}.form-label.required:after{content:" *";color:var(--status-error)}.form-input{width:100%;padding:10px 12px;background:var(--white);border:1px solid var(--border-color);border-radius:6px;font-size:13px;color:var(--text-primary);outline:none;transition:all .15s cubic-bezier(.4,0,.2,1);font-family:var(--font)}.form-input::placeholder{color:var(--text-tertiary)}.form-input:focus{border-color:var(--accent-primary);background:var(--white);box-shadow:0 0 0 3px #5c35a814,0 1px 3px #0000000a}.form-input:disabled{background:var(--bg-secondary);color:var(--text-tertiary);cursor:not-allowed;border-color:var(--border-color)}.form-textarea{width:100%;padding:10px 12px;background:var(--white);border:1px solid var(--border-color);border-radius:6px;font-size:13px;color:var(--text-primary);outline:none;transition:all .15s cubic-bezier(.4,0,.2,1);font-family:var(--font);resize:vertical;min-height:80px}.form-textarea:focus{border-color:var(--accent-primary);background:var(--white);box-shadow:0 0 0 3px #5c35a814,0 1px 3px #0000000a}.form-select{width:100%;padding:10px 12px;background:var(--white);border:1px solid var(--border-color);border-radius:6px;font-size:13px;color:var(--text-primary);outline:none;transition:all .15s cubic-bezier(.4,0,.2,1);font-family:var(--font);cursor:pointer}.form-select:focus{border-color:var(--accent-primary);box-shadow:0 0 0 3px #5c35a814,0 1px 3px #0000000a}.form-checkbox,.form-radio{width:18px;height:18px;cursor:pointer;accent-color:var(--accent-primary)}.card{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;padding:16px;box-shadow:0 1px 3px #0000000a;transition:all .2s cubic-bezier(.4,0,.2,1)}.card:hover{box-shadow:0 4px 12px #00000014;border-color:#d4d0e0}.card-header{font-size:14px;font-weight:700;color:var(--text-primary);margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid var(--border-color)}.card-body{font-size:13px;color:var(--text-secondary)}.card-footer{margin-top:12px;padding-top:12px;border-top:1px solid var(--border-color);display:flex;gap:8px;justify-content:flex-end}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal{background:var(--bg-primary);border-radius:8px;box-shadow:0 20px 60px #00000026;max-height:90vh;max-width:600px;width:90%;display:flex;flex-direction:column;animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{padding:20px;border-bottom:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-between}.modal-title{font-size:16px;font-weight:700;color:var(--text-primary)}.modal-close{width:32px;height:32px;border:none;background:transparent;color:var(--text-tertiary);cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;transition:all .15s}.modal-close:hover{color:var(--text-primary);background:var(--hover-light);border-radius:4px}.modal-body{flex:1;overflow-y:auto;padding:20px}.modal-footer{padding:16px 20px;border-top:1px solid var(--border-color);background:var(--bg-secondary);border-radius:0 0 8px 8px;display:flex;gap:8px;justify-content:flex-end}.table-wrapper{overflow-x:auto;border-radius:8px;border:1px solid var(--border-color)}.table{width:100%;border-collapse:collapse;font-size:13px}.table thead tr{background:var(--bg-secondary);border-bottom:1px solid var(--border-color)}.table th{padding:12px 16px;text-align:left;font-weight:700;color:var(--text-primary);white-space:nowrap}.table tbody tr{border-bottom:1px solid var(--border-color);transition:background .15s ease}.table tbody tr:hover{background:var(--hover-light)}.table td{padding:12px 16px;color:var(--text-secondary)}.table td.align-center{text-align:center}.table td.align-right{text-align:right}.badge{display:inline-block;padding:4px 10px;border-radius:4px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.3px;background-color:var(--text-tertiary);color:#fff}.badge-primary{background:#5c35a833;color:#d86b00;font-weight:600}.badge-success{background:#10b98126;color:#047857;font-weight:600}.badge-warning{background:#f59e0b26;color:#92400e;font-weight:600}.badge-error{background:#ef444426;color:#991b1b;font-weight:600}.badge-info{background:#3b82f626;color:#1e40af;font-weight:600}.pill{display:inline-flex;align-items:center;gap:8px;padding:6px 12px;border-radius:20px;font-size:12px;font-weight:600;border:1px solid var(--border-color);background:var(--bg-secondary);color:var(--text-secondary)}.pill.primary{border-color:var(--accent-border);background:var(--accent-light);color:var(--accent-primary)}.alert{padding:12px 16px;border-radius:6px;border-left:4px solid;font-size:13px;margin-bottom:16px;display:flex;gap:12px;align-items:flex-start}.alert-icon{font-size:16px;flex-shrink:0;margin-top:2px}.alert-content{flex:1}.alert-title{font-weight:700;margin-bottom:4px;font-size:13px}.alert-success{background:#10b9811f;border-color:#10b981;color:#047857}.alert-warning{background:#f59e0b1f;border-color:#f59e0b;color:#92400e}.alert-error{background:#ef44441f;border-color:#ef4444;color:#991b1b}.alert-info{background:#3b82f61f;border-color:#3b82f6;color:#1e40af}.spinner{width:16px;height:16px;border:2px solid var(--border-color);border-top-color:var(--accent-primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.skeleton{background:linear-gradient(90deg,var(--bg-secondary),var(--border-color),var(--bg-secondary));background-size:200% 100%;animation:shimmer 2s infinite}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.flex{display:flex}.flex-col{display:flex;flex-direction:column}.flex-center{display:flex;align-items:center;justify-content:center}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.p-2{padding:8px}.p-3{padding:12px}.p-4{padding:16px}.m-2{margin:8px}.m-3{margin:12px}.m-4{margin:16px}.mt-2{margin-top:8px}.mt-3{margin-top:12px}.mt-4{margin-top:16px}.mb-2{margin-bottom:8px}.mb-3{margin-bottom:12px}.mb-4{margin-bottom:16px}.rounded{border-radius:6px}.rounded-lg{border-radius:8px}.rounded-full{border-radius:9999px}.shadow-sm{box-shadow:0 1px 3px #00000014}.shadow{box-shadow:0 2px 8px #0000001f}.shadow-lg{box-shadow:0 10px 20px #00000026}.sidebar{border-right:1px solid var(--border-color)}.sidebar-footer{border-top:1px solid var(--border-color)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#00000014;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#00000026}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;font-family:var(--font);background:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.app-shell{display:grid;grid-template-columns:200px 1fr;min-height:100vh}.app-main{display:flex;flex-direction:column;min-width:0;background:var(--bg-primary)}
