:root{--color-brand-dark: #003664;--color-brand-medium: #0f5a88;--color-brand-light: #2596be;--color-brand-lighter: #36b4e5;--color-brand-pale: #e6f6fc;--color-primary: var(--color-brand-light);--color-primary-hover: var(--color-brand-medium);--color-secondary: #64748b;--color-success: #10b981;--color-success-bg: #ecfdf5;--color-warning: #f59e0b;--color-warning-bg: #fffbeb;--color-error: #ef4444;--color-error-bg: #fef2f2;--color-info: #3b82f6;--color-info-bg: #eff6ff;--color-bg-body: #f1f5f9;--color-bg-card: #ffffff;--color-bg-sidebar: #ffffff;--color-text-primary: #0f172a;--color-text-secondary: #64748b;--color-text-muted: #94a3b8;--color-border: #e2e8f0;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: 1rem;--radius-xl: 1.5rem;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--transition-base: .2s ease-in-out}body{font-family:Segoe UI,Inter,-apple-system,BlinkMacSystemFont,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--color-bg-body);color:var(--color-text-primary)}.btn-primary{background:var(--color-brand-light);color:#fff;box-shadow:0 4px 12px #2596be4d}.btn-primary:hover{background:var(--color-brand-medium);transform:translateY(-1px)}.btn-secondary{background:var(--color-bg-tertiary);color:var(--color-text-primary)}.btn-secondary:hover{background:var(--color-border)}.btn-success{background:var(--gradient-success);color:#fff}.btn-warning{background:var(--gradient-warning);color:#fff}.btn-error{background:var(--gradient-error);color:#fff}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.card{background:var(--color-bg-card);border-radius:var(--radius-lg);padding:var(--spacing-lg);box-shadow:var(--shadow-md);border:1px solid var(--color-border);transition:all var(--transition-base)}.card:hover{box-shadow:var(--shadow-lg);border-color:var(--color-primary)}.card-header{font-size:var(--font-size-lg);font-weight:700;margin-bottom:var(--spacing-md);color:var(--color-text-primary)}input[type=text],input[type=file],select,textarea{width:100%;padding:.75rem 1rem;background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);font-size:var(--font-size-base);transition:all var(--transition-base);font-family:inherit}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #667eea1a}table{width:100%;border-collapse:collapse}th{background:var(--color-bg-tertiary);padding:.75rem 1rem;text-align:left;font-weight:600;font-size:var(--font-size-sm);color:var(--color-text-secondary);border-bottom:2px solid var(--color-border)}td{padding:.875rem 1rem;border-bottom:1px solid var(--color-border);color:var(--color-text-primary)}tr:hover{background:#667eea0d}.badge{display:inline-flex;align-items:center;padding:.25rem .75rem;border-radius:var(--radius-xl);font-size:var(--font-size-xs);font-weight:600;text-transform:uppercase;letter-spacing:.05em}.badge-success{background:var(--color-success-light);color:var(--color-success)}.badge-error{background:var(--color-error-light);color:var(--color-error)}.badge-warning{background:var(--color-warning-light);color:var(--color-warning)}.badge-info{background:var(--color-info-light);color:var(--color-info)}.alert{padding:var(--spacing-md);border-radius:var(--radius-md);margin-bottom:var(--spacing-md);display:flex;align-items:flex-start;gap:var(--spacing-sm)}.alert-success{background:var(--color-success-light);color:var(--color-success);border-left:4px solid var(--color-success)}.alert-error{background:var(--color-error-light);color:var(--color-error);border-left:4px solid var(--color-error)}.alert-warning{background:var(--color-warning-light);color:var(--color-warning);border-left:4px solid var(--color-warning)}.alert-info{background:var(--color-info-light);color:var(--color-info);border-left:4px solid var(--color-info)}@keyframes spin{to{transform:rotate(360deg)}}.spinner{width:20px;height:20px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}.glass{background:#1e293bb3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1)}.text-center{text-align:center}.text-right{text-align:right}.mt-1{margin-top:var(--spacing-sm)}.mt-2{margin-top:var(--spacing-md)}.mt-3{margin-top:var(--spacing-lg)}.mb-1{margin-bottom:var(--spacing-sm)}.mb-2{margin-bottom:var(--spacing-md)}.mb-3{margin-bottom:var(--spacing-lg)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-1{gap:var(--spacing-sm)}.gap-2{gap:var(--spacing-md)}.gap-3{gap:var(--spacing-lg)}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{transform:translate(-100%)}to{transform:translate(0)}}.fade-in{animation:fadeIn var(--transition-base) ease-out}.slide-in{animation:slideIn var(--transition-base) ease-out}.metric-tabs-container{display:grid;grid-template-columns:repeat(9,1fr);gap:.75rem;margin-bottom:var(--spacing-lg);overflow-x:auto;padding-bottom:4px}.metric-tab{background:#fff9;border:1px solid #e2e8f0;border-radius:var(--radius-lg);padding:.75rem;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);border-bottom:3px solid transparent;min-width:110px}.metric-tab:hover{background:#fff;transform:translateY(-2px);box-shadow:var(--shadow-md)}.metric-tab.active{background:#fff;border-color:var(--color-border);box-shadow:var(--shadow-lg);transform:translateY(-2px)}.tab-count{font-size:1.5rem;font-weight:800;line-height:1}.tab-label{font-size:.7rem;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.02em;display:block;line-height:1.2}@media(max-width:1400px){.metric-tabs-container{grid-template-columns:repeat(5,1fr)}}@media(max-width:768px){.metric-tabs-container{grid-template-columns:repeat(3,1fr)}}.filter-section{cursor:default;border-left:4px solid var(--color-brand-light);padding:.8rem}.filter-header{cursor:pointer;-webkit-user-select:none;user-select:none}.radio-label{display:inline-flex;align-items:center;gap:.5rem;padding:.25rem .75rem;border-radius:var(--radius-xl);border:1px solid var(--color-border);cursor:pointer;font-size:var(--font-size-sm);color:var(--color-text-secondary);background:#fff;transition:all var(--transition-base)}.radio-label:hover{background:var(--color-brand-pale);color:var(--color-brand-medium)}.radio-label.active{background:var(--color-brand-light);color:#fff;border-color:var(--color-brand-light)}.radio-label input{display:none}.input-date,.input-select{padding:.5rem;border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-sm);max-width:160px}.input-select:focus,.input-date:focus{border-color:var(--color-brand-light);outline:none}.toast-container{position:fixed;top:20px;left:50%;transform:translate(-50%);z-index:9999;display:flex;flex-direction:column;align-items:center;gap:10px;pointer-events:none}.toast{display:flex;align-items:center;gap:12px;padding:16px;border-radius:12px;background:#fff;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;min-width:320px;max-width:450px;animation:slideIn .3s ease-out forwards;pointer-events:auto;border-left:6px solid transparent}.toast.closing{animation:slideOut .3s ease-in forwards}@keyframes slideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideOut{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-20px)}}.toast-icon{display:flex;align-items:center;justify-content:center;flex-shrink:0}.toast-content{flex:1}.toast-title{font-weight:600;margin-bottom:2px}.toast-message{font-size:.9em;color:#4b5563}.toast-close{background:none;border:none;cursor:pointer;color:#9ca3af;padding:4px;margin-left:8px;border-radius:4px;transition:background .2s}.toast-close:hover{background:#0000000d;color:#4b5563}.toast-success{background:#ecfdf5;border-left-color:#10b981}.toast-success .toast-title{color:#065f46}.toast-success .toast-icon{color:#059669}.toast-error{background:#fef2f2;border-left-color:#ef4444}.toast-error .toast-title{color:#991b1b}.toast-error .toast-icon{color:#dc2626}.toast-warning{background:#fffbeb;border-left-color:#f59e0b}.toast-warning .toast-title{color:#92400e}.toast-warning .toast-icon{color:#d97706}.toast-info{background:#eff6ff;border-left-color:#3b82f6}.toast-info .toast-title{color:#1e40af}.toast-info .toast-icon{color:#2563eb}.bom-card{background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a}.bom-card .space-y-4>*+*{margin-top:1rem}.bom-manager-container{display:grid;grid-template-columns:35% 62.7%;gap:1.5rem}.bom-card{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--color-border);padding:.2rem 1.2rem 1.8rem 1.5rem}.upload-area{border:2px dashed var(--color-brand-lighter);transition:all .2s;background:#f8fafc;padding:3% 6%}.upload-area:hover,.upload-area.drag-active{border-color:var(--color-brand-light);background:#f0f9ff}.icon-circle{width:48px;height:48px;border-radius:50%;background:#fff;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-sm);cursor:pointer}.bom-details-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}.detail-item label{font-size:.75rem;text-transform:uppercase;color:var(--color-text-secondary);font-weight:600;margin-bottom:.25rem;display:block}.detail-item div{font-size:1rem;color:var(--color-text-primary)}.confirm-upload-btn{padding:3%;border-radius:8px;border:none}@media(max-width:1024px){.bom-manager-container{grid-template-columns:1fr}}.file-tracking-container{min-height:400px;display:flex;flex-direction:column}.btn-icon{background:transparent;border:none;cursor:pointer;padding:6px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center}.modal-overlay{position:fixed;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#fff;padding:1.5rem;border-radius:8px;width:400px;box-shadow:0 4px 12px #00000026;text-align:center}.modal-actions{display:flex;gap:12px;justify-content:center;margin-top:20px}.modal-btn{padding:8px 20px;border-radius:6px;font-weight:500;cursor:pointer;border:none}.modal-btn-confirm{background:#ef4444;color:#fff}.modal-btn-cancel{background:#e2e8f0;color:#475569}.search-input{width:280px;padding:8px 12px;border:1.5px solid #e2e8f0;border-radius:8px;font-size:.9rem;transition:all .2s ease;outline:none}.search-input:focus{border-color:#2596be;box-shadow:0 0 0 3px #2596be1a}.search-input::placeholder{color:#94a3b8}.dashboard-page{background:linear-gradient(135deg,#f8fafc,#eff6ff);min-height:100vh;padding:20px 10px 0}.text-brand-dark{color:var(--color-brand-dark)}.text-brand-medium{color:var(--color-brand-medium)}.text-brand-light{color:var(--color-brand-light)}.font-bold{font-weight:700}.font-semibold{font-weight:600}.text-sm{font-size:.875rem}.text-xs{font-size:.75rem}.table-responsive{overflow-x:auto;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);background:#fff;padding-top:10px;margin-bottom:10px}table{border-collapse:collapse}td,th{vertical-align:middle;padding:12px;border-bottom:none}tr{border-bottom:1px solid #e0e0e0}:root{--bg-page: #f5f9fc;--bg-card: #ffffff;--border: #e6edf3;--primary: #1f7ae0;--primary-light: #e8f1fd;--text: #1f2937;--muted: #6b7280}.settings-page{background:var(--bg-page);padding:24px}.settings-breadcrumb{display:flex;align-items:center;gap:8px;margin-bottom:20px;font-size:14px}.breadcrumb-item{color:var(--primary);text-decoration:none}.breadcrumb-item:hover{text-decoration:underline;opacity:.8}.breadcrumb-item.current{color:var(--muted);cursor:default}.breadcrumb-item.current:hover{text-decoration:none;opacity:1}.breadcrumb-separator{color:var(--muted)}.settings-container{display:flex;gap:24px;height:calc(100vh - 140px)}.settings-sidebar{width:260px;background:var(--bg-card);border:1px solid var(--border);border-radius:14px;padding:12px}.settings-sidebar-header{display:flex;gap:8px;padding:14px;font-weight:600;border-bottom:1px solid var(--border)}.settings-tab{width:100%;text-align:left;padding:12px 14px;border-radius:10px;border:none;background:none;cursor:pointer;color:var(--muted);display:flex;gap:10px}.settings-tab.active{background:var(--primary-light);color:var(--primary);font-weight:600}.settings-content{flex:1;background:var(--bg-card);border:1px solid var(--border);border-radius:14px;padding:28px;overflow-y:auto}.section-title h2{margin:0;font-size:18px}.section-title p{color:var(--muted);margin-top:4px}.form-group{margin-top:18px}.form-input,.form-select,.form-textarea{width:100%;padding:10px;border-radius:10px;border:1px solid var(--border)}.input-row{display:flex;gap:10px;align-items:center;padding-top:5px}.input-row .form-input{flex:1;width:auto}.run-at-width{width:98%}.browse-btn{padding:10px 14px;border-radius:10px;background:#f1f5f9;border:1px solid var(--border);white-space:nowrap;cursor:pointer;font-weight:500}.toggle-row{margin-top:20px;display:flex;justify-content:space-between}.toggle{width:44px;height:24px;background:#d1d5db;border-radius:20px;cursor:pointer;position:relative}.toggle span{position:absolute;top:4px;left:4px;width:16px;height:16px;background:#fff;border-radius:50%;transition:.3s}.toggle.active{background:var(--primary)}.toggle.active span{left:24px}.settings-footer{margin-top:32px;border-top:1px solid var(--border);padding-top:20px;display:flex;justify-content:flex-end;gap:12px}.btn-primary{background:var(--primary);color:#fff;padding:10px 18px;border-radius:10px;border:none}.btn-secondary{background:#f1f5f9;padding:10px 16px;border-radius:10px;border:none}.notification-grid{margin-top:10px;display:grid;gap:8px}.notification-grid .toggle-row{margin-top:12px;padding-bottom:12px;border-bottom:1px solid #f1f5f9}.notification-grid .toggle-row:last-child{border-bottom:none}.form-textarea{min-height:80px;resize:vertical}.form-row{display:flex;gap:20px}.form-row .form-group{flex:1;margin-top:18px}input[type=time].form-input{cursor:pointer}.modal-overlay{position:fixed;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal-content{background:#fff;border-radius:16px;width:500px;max-width:90%;box-shadow:0 10px 25px #0000001a;animation:slideUp .3s ease-out;border-left:6px solid #f59e0b;position:relative}.modal-content.small{width:400px}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{padding:24px;display:flex;justify-content:center;align-items:center;position:relative;text-align:center}.modal-header p{margin:0;color:var(--text);line-height:1.5;padding-right:30px}.close-btn{background:none;border:none;font-size:24px;cursor:pointer;color:var(--muted);position:absolute;right:12px;top:8px;line-height:1;z-index:10}.modal-footer{padding:16px 24px;border-top:1px solid var(--border);display:flex;justify-content:center;gap:16px}.form-select,.form-textarea{margin-top:5px}.form-textarea.error{border-color:var(--color-error, #ef4444)}.error-message-inline{color:var(--color-error, #ef4444);font-size:13px;margin-top:6px;font-weight:500}.label-margin{margin-top:5px}.App{min-height:100vh}
