:root{--bg-primary: #0a0e1a;--bg-secondary: #111827;--bg-tertiary: #1a2035;--bg-card: rgba(255, 255, 255, .05);--bg-card-hover: rgba(255, 255, 255, .08);--border: rgba(255, 255, 255, .1);--border-strong: rgba(255, 255, 255, .18);--accent: #00b0bd;--accent-dark: #008fa0;--accent-light: #33c4cf;--accent-glow: rgba(0, 176, 189, .3);--accent-glow-strong: rgba(0, 176, 189, .5);--secondary: #00529c;--text-primary: #f1f5f9;--text-secondary: #94a3b8;--text-muted: #64748b;--success: #72bf44;--success-bg: rgba(114, 191, 68, .15);--warning: #f15a22;--warning-bg: rgba(241, 90, 34, .15);--danger: #ef4444;--danger-bg: rgba(239, 68, 68, .15);--info-bg: rgba(0, 176, 189, .1);--radius-sm: 6px;--radius: 12px;--radius-lg: 16px;--radius-xl: 24px;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .4);--shadow: 0 4px 20px rgba(0, 0, 0, .5);--shadow-lg: 0 8px 40px rgba(0, 0, 0, .6);--shadow-glow: 0 0 30px var(--accent-glow);--shadow-glow-strong: 0 0 50px var(--accent-glow-strong);--transition: all .2s cubic-bezier(.4, 0, .2, 1);--transition-slow: all .35s cubic-bezier(.4, 0, .2, 1);--font-mono: "JetBrains Mono", "Fira Code", monospace}[data-theme=light]{--bg-primary: #f0f4f8;--bg-secondary: #ffffff;--bg-tertiary: #e2eaf4;--bg-card: rgba(0, 82, 156, .04);--bg-card-hover: rgba(0, 82, 156, .08);--border: rgba(0, 82, 156, .15);--border-strong: rgba(0, 82, 156, .28);--accent: #00529c;--accent-dark: #003d75;--accent-light: #0a6ec7;--accent-glow: rgba(0, 82, 156, .2);--accent-glow-strong: rgba(0, 82, 156, .35);--secondary: #00b0bd;--text-primary: #1a2035;--text-secondary: #4a5568;--text-muted: #718096;--success: #72bf44;--success-bg: rgba(114, 191, 68, .15);--warning: #f15a22;--warning-bg: rgba(241, 90, 34, .15);--danger: #ef4444;--danger-bg: rgba(239, 68, 68, .15);--info-bg: rgba(0, 176, 189, .1);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .1);--shadow: 0 4px 20px rgba(0, 0, 0, .12);--shadow-lg: 0 8px 40px rgba(0, 0, 0, .18)}[data-theme=light] body{background-color:var(--bg-primary);color:var(--text-primary)}[data-theme=light] .app-header{background:#f0f4f8e6}[data-theme=light] .glass-card{background:#00529c08;border-color:var(--border)}[data-theme=light] .glass-card:hover{background:#00529c0f}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}body{font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background-color:var(--bg-primary);color:var(--text-primary);line-height:1.6;min-height:100vh;overflow-x:hidden}img{max-width:350px;display:block}button{cursor:pointer;font-family:inherit}input,select,textarea{font-family:inherit}a{color:var(--accent-light);text-decoration:none}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.glass-card{background:#ffffff08;border:1px solid rgba(255,255,255,.1);border-radius:var(--radius);transition:var(--transition)}.glass-card:hover{background:#ffffff0d;border-color:#ffffff26}.btn-primary{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 28px;background:var(--accent);color:#fff;font-size:.9rem;font-weight:600;letter-spacing:.02em;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition);position:relative;overflow:hidden}.btn-primary:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,rgba(255,255,255,.1),transparent);opacity:0;transition:opacity .2s}.btn-primary:hover{background:var(--accent-dark);box-shadow:0 0 20px var(--accent-glow),0 4px 15px #0000004d;transform:translateY(-1px)}.btn-primary:hover:before{opacity:1}.btn-primary:active{transform:translateY(0);box-shadow:0 0 10px var(--accent-glow)}.btn-primary:disabled{opacity:.4;cursor:not-allowed;transform:none;box-shadow:none}.btn-secondary{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 28px;background:transparent;color:var(--text-secondary);font-size:.9rem;font-weight:500;letter-spacing:.02em;border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition)}.btn-secondary:hover{background:var(--bg-card);color:var(--text-primary);border-color:var(--border-strong);box-shadow:var(--shadow-sm)}.btn-secondary:disabled{opacity:.4;cursor:not-allowed}.btn-ghost{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 16px;background:transparent;color:var(--text-muted);font-size:.85rem;font-weight:500;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition)}.btn-ghost:hover{background:var(--bg-card);color:var(--text-primary)}.btn-icon{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;background:var(--bg-card);color:var(--text-secondary);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition);flex-shrink:0}.btn-icon:hover{background:var(--bg-card-hover);color:var(--text-primary);border-color:var(--border-strong)}.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;font-size:.75rem;font-weight:600;letter-spacing:.03em;border-radius:100px;border:1px solid transparent}.badge-blue{background:var(--info-bg);color:var(--accent-light);border-color:#00b0bd40}.badge-green{background:var(--success-bg);color:var(--success);border-color:#72bf4440}.badge-orange{background:var(--warning-bg);color:var(--warning);border-color:#f59e0b40}.badge-red{background:var(--danger-bg);color:var(--danger);border-color:#ef444440}.badge-gray{background:#64748b26;color:var(--text-muted);border-color:#64748b33}.toggle-label{display:flex;align-items:center;gap:10px;cursor:pointer;-webkit-user-select:none;user-select:none}.toggle-label input[type=checkbox]{position:absolute;opacity:0;width:0;height:0}.toggle-track{position:relative;width:42px;height:24px;background:#64748b4d;border:1px solid var(--border);border-radius:100px;transition:var(--transition);flex-shrink:0}.toggle-track:after{content:"";position:absolute;top:3px;left:3px;width:16px;height:16px;background:var(--text-muted);border-radius:50%;transition:var(--transition);box-shadow:0 1px 3px #0006}.toggle-label input:checked+.toggle-track{background:var(--accent);border-color:var(--accent);box-shadow:0 0 12px var(--accent-glow)}.toggle-label input:checked+.toggle-track:after{transform:translate(18px);background:#fff}.progress-bar-container{width:100%;height:4px;background:var(--border);border-radius:100px;overflow:hidden}.progress-bar-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent-light));border-radius:100px;transition:width .4s cubic-bezier(.4,0,.2,1);position:relative}.progress-bar-fill:after{content:"";position:absolute;top:0;right:0;width:40px;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.4));animation:shimmer 1.5s ease-in-out infinite}@keyframes shimmer{0%{opacity:0}50%{opacity:1}to{opacity:0}}.form-group{display:flex;flex-direction:column;gap:6px}.form-label{font-size:.8rem;font-weight:500;color:var(--text-secondary);letter-spacing:.04em;text-transform:uppercase}.form-input{width:100%;padding:10px 14px;background:#ffffff0a;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:.9rem;transition:var(--transition);outline:none}.form-input:focus{border-color:var(--accent);background:#00b0bd0d;box-shadow:0 0 0 3px var(--accent-glow)}.form-input::placeholder{color:var(--text-muted)}.form-select{width:100%;padding:10px 36px 10px 14px;background:#ffffff0a;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:.9rem;transition:var(--transition);outline:none;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%2394a3b8' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center}.form-select:focus{border-color:var(--accent);background-color:#00b0bd0d;box-shadow:0 0 0 3px var(--accent-glow)}.form-select option{background:var(--bg-secondary);color:var(--text-primary)}.segmented-control{display:inline-flex;background:#0000004d;border:1px solid var(--border);border-radius:var(--radius-sm);padding:3px;gap:2px}.segmented-btn{padding:7px 18px;background:transparent;border:none;border-radius:4px;color:var(--text-muted);font-size:.85rem;font-weight:500;cursor:pointer;transition:var(--transition);white-space:nowrap}.segmented-btn.active{background:var(--accent);color:#fff;box-shadow:0 0 12px var(--accent-glow)}.segmented-btn:not(.active):hover{color:var(--text-primary);background:var(--bg-card)}.segmented-btn:disabled{opacity:.4;cursor:not-allowed}.divider{height:1px;background:var(--border);margin:0}.tooltip-wrapper{position:relative;display:inline-flex}.tooltip-wrapper:hover .tooltip-content{opacity:1;transform:translateY(0);pointer-events:auto}.tooltip-content{position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%) translateY(4px);background:var(--bg-tertiary);border:1px solid var(--border-strong);color:var(--text-secondary);font-size:.75rem;padding:6px 10px;border-radius:var(--radius-sm);white-space:nowrap;opacity:0;transition:var(--transition);pointer-events:none;z-index:100;box-shadow:var(--shadow)}.tooltip-content:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:5px solid transparent;border-top-color:var(--border-strong)}.info-icon{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;border-radius:50%;background:var(--border);color:var(--text-muted);font-size:.65rem;font-weight:700;cursor:help;flex-shrink:0}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInScale{0%{opacity:0;transform:scale(.97)}to{opacity:1;transform:scale(1)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes gradientShift{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}.animate-fade-in{animation:fadeIn .4s ease both}.animate-fade-in-scale{animation:fadeInScale .3s ease both}#root{min-height:100vh;display:flex;flex-direction:column}.app-wrapper{min-height:100vh;background:var(--bg-primary);background-image:radial-gradient(ellipse 80% 50% at 50% -20%,rgba(0,176,189,.08),transparent),radial-gradient(ellipse 60% 40% at 80% 100%,rgba(114,191,68,.04),transparent);display:flex;flex-direction:column}.app-header{position:sticky;top:0;z-index:50;background:#0a0e1ad9;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border);padding:0 32px;height:68px;display:flex;align-items:center;justify-content:space-between}.app-header:after{content:"";position:absolute;bottom:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--accent-glow),rgba(114,191,68,.2),transparent)}.header-brand{display:flex;align-items:center;gap:12px;height:100%}.header-logo-img{height:28px;width:auto;display:block}.header-logo-sep{font-size:.85rem;font-weight:400;color:var(--text-muted);line-height:1}.header-subtitle{font-size:.72rem;color:var(--text-muted);letter-spacing:.08em;text-transform:uppercase;font-weight:500;padding-left:4px;border-left:1px solid var(--border)}.theme-toggle{color:var(--text-secondary);transition:var(--transition)}.theme-toggle:hover{color:var(--accent);border-color:var(--accent)}.header-actions{display:flex;align-items:center;gap:10px}.feedback-link{width:auto;padding:0 12px;gap:8px;font-size:.78rem;font-weight:500;letter-spacing:.02em;color:var(--text-secondary);text-decoration:none;white-space:nowrap;transition:var(--transition)}.feedback-link:hover{color:var(--accent);border-color:var(--accent)}.header-status{display:flex;align-items:center;gap:6px;font-size:.8rem;color:var(--text-muted)}.status-dot{width:7px;height:7px;border-radius:50%;background:var(--success);box-shadow:0 0 8px var(--success);animation:pulse 2s ease-in-out infinite}.step-bar{padding:12px 4px 0;display:flex;align-items:center;gap:0;max-width:350px;margin:0 auto;width:100%}.step-item{display:flex;flex-direction:column;align-items:center;gap:4px;flex:1;position:relative}.step-item:not(:last-child):after{content:"";position:absolute;top:9px;left:calc(50% + 9px);right:calc(-50% + 9px);height:1px;background:var(--border);transition:var(--transition-slow)}.step-item.completed:not(:last-child):after{background:var(--accent);box-shadow:0 0 6px var(--accent-glow)}.step-circle{width:18px;height:18px;border-radius:50%;border:1.5px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:.55rem;font-weight:700;color:var(--text-muted);background:var(--bg-secondary);transition:var(--transition);z-index:1}.step-item.active .step-circle{border-color:var(--accent);background:var(--accent);color:#fff;box-shadow:0 0 15px var(--accent-glow)}.step-item.completed .step-circle{border-color:var(--success);background:var(--success-bg);color:var(--success)}.step-label{font-size:.55rem;font-weight:500;color:var(--text-muted);letter-spacing:.04em;text-transform:uppercase}.step-item.active .step-label{color:var(--accent-light)}.step-item.completed .step-label{color:var(--success)}.app-main{flex:1;padding:32px;max-width:1400px;width:100%;margin:0 auto}.app-wrapper--review{height:100dvh;overflow:hidden}.app-main--review{max-width:none;margin:0;padding:16px 24px;display:flex;flex-direction:column;overflow:hidden;min-height:0}.app-main--review .results-layout{flex:1;min-height:0;align-items:stretch;grid-template-rows:minmax(0,1fr)}.app-main--review .diagram-viewer{align-self:auto}.app-main--review .diagram-canvas{flex:1;min-height:0;overflow:hidden}.upload-layout{display:flex;flex-direction:column;gap:24px;max-width:860px;margin:0 auto;animation:fadeIn .4s ease both}.upload-zone{border:2px dashed var(--border);border-radius:var(--radius-lg);padding:60px 40px;text-align:center;cursor:pointer;transition:var(--transition);background:#ffffff05;position:relative;overflow:hidden}.upload-zone:before{content:"";position:absolute;top:-2px;right:-2px;bottom:-2px;left:-2px;border-radius:var(--radius-lg);background:linear-gradient(135deg,var(--accent-glow),transparent,rgba(114,191,68,.1),transparent);opacity:0;transition:opacity .3s;z-index:-1}.upload-zone:hover,.upload-zone.dragging{border-color:var(--accent);background:#00b0bd0d;box-shadow:0 0 40px var(--accent-glow),inset 0 0 30px #00b0bd0a}.upload-zone:hover:before,.upload-zone.dragging:before{opacity:1}.upload-zone.dragging{border-color:var(--accent-light);box-shadow:0 0 60px var(--accent-glow-strong),inset 0 0 40px #00b0bd0f;transform:scale(1.005)}.upload-zone.has-file{border-color:var(--success);background:#72bf4408;box-shadow:0 0 20px #72bf4426}.upload-icon{width:64px;height:64px;margin:0 auto 20px;color:var(--text-muted);transition:var(--transition)}.upload-zone:hover .upload-icon,.upload-zone.dragging .upload-icon{color:var(--accent);transform:translateY(-4px);filter:drop-shadow(0 0 10px var(--accent-glow))}.upload-zone.has-file .upload-icon{color:var(--success)}.upload-title{font-size:1.2rem;font-weight:600;color:var(--text-primary);margin-bottom:8px}.upload-subtitle{font-size:.875rem;color:var(--text-muted);margin-bottom:20px}.upload-formats{display:flex;align-items:center;justify-content:center;gap:8px;flex-wrap:wrap}.format-tag{padding:4px 12px;background:var(--bg-card);border:1px solid var(--border);border-radius:100px;font-size:.75rem;font-weight:500;color:var(--text-muted);font-family:var(--font-mono)}.selected-file-info{display:flex;align-items:center;justify-content:center;gap:12px;margin-top:20px;padding:12px 20px;background:var(--success-bg);border:1px solid rgba(114,191,68,.25);border-radius:var(--radius-sm);display:inline-flex}.selected-file-name{font-size:.875rem;font-weight:500;color:var(--success);font-family:var(--font-mono)}.selected-file-size{font-size:.8rem;color:var(--text-muted)}.upload-actions{display:flex;align-items:center;justify-content:flex-end;gap:12px}.config-panel{padding:24px;animation:fadeIn .4s ease .1s both}.config-panel-header{display:flex;align-items:center;gap:8px;margin-bottom:20px}.config-panel-title{font-size:.85rem;font-weight:600;color:var(--text-secondary);letter-spacing:.06em;text-transform:uppercase}.config-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;align-items:start}.config-toggles{display:flex;gap:24px;grid-column:1 / -1;padding-top:4px;border-top:1px solid var(--border);margin-top:4px}.config-toggle-item{display:flex;flex-direction:column;gap:10px}.toggle-label-text{font-size:.85rem;font-weight:500;color:var(--text-primary)}.processing-layout{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:32px;animation:fadeIn .4s ease both}.spinner-container{position:relative;width:100px;height:100px}.spinner-ring{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:50%;border:3px solid transparent}.spinner-ring-outer{border-top-color:var(--accent);animation:spin 1.2s linear infinite;box-shadow:0 0 20px var(--accent-glow)}.spinner-ring-middle{top:12px;right:12px;bottom:12px;left:12px;border-top-color:#00b0bd80;border-right-color:#00b0bd4d;animation:spin .8s linear infinite reverse}.spinner-ring-inner{top:24px;right:24px;bottom:24px;left:24px;border-top-color:var(--accent-light);animation:spin 1.6s linear infinite}.spinner-center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:20px;height:20px;border-radius:50%;background:radial-gradient(circle,var(--accent),var(--accent-dark));box-shadow:0 0 15px var(--accent-glow-strong);animation:pulse 2s ease-in-out infinite}.processing-text{text-align:center}.processing-title{font-size:1.35rem;font-weight:600;color:var(--text-primary);margin-bottom:8px;animation:pulse 3s ease-in-out infinite}.processing-subtitle{font-size:.875rem;color:var(--text-muted)}.processing-steps{display:flex;flex-direction:column;gap:10px;width:320px}.processing-step{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);transition:var(--transition)}.processing-step.active{border-color:#00b0bd4d;background:var(--info-bg)}.processing-step.done{border-color:#72bf4433;background:var(--success-bg)}.processing-step-icon{width:20px;height:20px;color:var(--text-muted);flex-shrink:0}.processing-step.active .processing-step-icon{color:var(--accent)}.processing-step.done .processing-step-icon{color:var(--success)}.processing-step-label{font-size:.85rem;color:var(--text-secondary)}.processing-step.active .processing-step-label{color:var(--accent-light)}.processing-step.done .processing-step-label{color:var(--success)}.results-layout{display:grid;grid-template-columns:1fr 320px 300px;gap:24px;animation:fadeIn .4s ease both}.symbol-list-column{display:flex;flex-direction:column;gap:16px;align-self:start;min-width:0}.app-main--review .symbol-list-column{align-self:auto;overflow:hidden}.app-main--review .symbol-list-column .symbol-list-card{flex:1;display:flex;flex-direction:column;overflow:hidden}.app-main--review .symbol-list-column .symbol-list{flex:1;max-height:none;overflow-y:auto}.app-main--review .results-panel{overflow-y:auto;min-height:0}.app-main--bom{max-width:none}.results-panel{display:flex;flex-direction:column;gap:16px;order:3}.symbol-list-column{order:2}.results-header{display:flex;flex-direction:column;gap:8px;padding:16px 20px}.results-header-row{display:flex;align-items:center;justify-content:space-between;gap:8px}.results-title{font-size:1rem;font-weight:700;color:var(--text-primary);letter-spacing:-.01em}.results-meta{font-size:.8rem;color:var(--text-muted);font-family:var(--font-mono)}.detection-count-card{padding:16px;display:flex;flex-direction:column;gap:16px}.count-row{display:flex;align-items:center;justify-content:space-between;gap:8px}.count-label{font-size:.8rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;font-weight:500}.count-value{font-size:2.2rem;font-weight:800;color:var(--text-primary);letter-spacing:-.03em;font-family:var(--font-mono);line-height:1}.count-value.blue{color:var(--accent-light)}.count-value.green{color:var(--success)}.count-value.orange{color:var(--warning)}.count-breakdown{display:flex;gap:8px}.count-chip{flex:1;padding:8px 12px;background:#ffffff05;border-radius:4px;border:1px solid rgba(255,255,255,.1);text-align:center}.count-chip-value{font-size:1.4rem;font-weight:700;font-family:var(--font-mono);line-height:1;margin-bottom:4px}.count-chip-label{font-size:.7rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.symbol-list-card{flex:1;overflow:hidden;padding:0}.symbol-list-header{padding:16px 20px 12px;font-size:.8rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--border)}.symbol-list{overflow-y:auto;max-height:600px;padding:8px}.symbol-row{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition);border:1px solid transparent}.symbol-row:hover{background:var(--bg-card);border-color:var(--border)}.symbol-row.highlighted{background:var(--info-bg);border-color:#00b0bd40}.symbol-tag{font-family:var(--font-mono);font-size:.75rem;font-weight:500;color:var(--accent-light);min-width:80px}.symbol-class{font-size:.85rem;color:var(--text-primary);flex:1}.symbol-confidence{font-family:var(--font-mono);font-size:.72rem;color:var(--text-muted)}.unknowns-section{padding:20px 24px;display:flex;flex-direction:column;gap:14px;border-top:1px solid var(--border)}.unknowns-title{display:flex;align-items:center;gap:8px;font-size:.875rem;font-weight:600;color:var(--warning)}.unknowns-desc{font-size:.8rem;color:var(--text-muted);line-height:1.5}.results-actions{padding:16px 24px;display:flex;gap:12px;border-top:1px solid var(--border)}.diagram-viewer{border-radius:var(--radius-lg);position:relative;background:var(--bg-secondary);border:1px solid var(--border);display:flex;flex-direction:column;align-self:start}.diagram-toolbar{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:#0000004d;border-bottom:1px solid var(--border);flex-shrink:0}.diagram-toolbar-left,.diagram-toolbar-right{display:flex;align-items:center;gap:8px}.diagram-title{font-size:.8rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em}.zoom-controls{display:flex;align-items:center;gap:4px}.zoom-level{font-size:.75rem;font-family:var(--font-mono);color:var(--text-muted);min-width:42px;text-align:center}.diagram-canvas{flex:none;overflow:auto;position:relative;display:flex;align-items:flex-start;justify-content:center;padding:20px;background:linear-gradient(rgba(255,255,255,.015) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.015) 1px,transparent 1px);background-size:24px 24px}.diagram-image-wrap{position:relative;display:inline-block;transform-origin:top left;transition:transform .15s ease}.diagram-image{display:block;max-width:100%;border-radius:4px;box-shadow:var(--shadow-lg)}.diagram-highlight-overlay{position:absolute;border:5px solid var(--accent);border-radius:4px;box-shadow:0 0 0 3px var(--accent-glow),0 0 15px var(--accent-glow);pointer-events:none;animation:fadeInScale .2s ease both}.diagram-placeholder{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:var(--text-muted);padding:60px}.diagram-placeholder svg{opacity:.3}.symbol-crop-inset{position:absolute;bottom:16px;right:16px;width:200px;overflow:hidden;border-radius:var(--radius-sm);border:2px solid var(--accent);box-shadow:0 0 20px var(--accent-glow),var(--shadow-lg);background:var(--bg-secondary);animation:fadeInScale .2s ease both}.symbol-crop-header{padding:6px 10px;background:#00000080;font-size:.7rem;font-weight:600;color:var(--accent-light);text-transform:uppercase;letter-spacing:.06em}.symbol-crop-canvas{position:relative;overflow:hidden}.labeler-card{padding:24px;animation:fadeInScale .3s ease both}.labeler-nav{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.labeler-nav-info{font-size:.85rem;color:var(--text-muted)}.labeler-nav-buttons{display:flex;gap:6px}.labeler-progress{margin-bottom:20px}.labeler-progress-label{display:flex;justify-content:space-between;font-size:.75rem;color:var(--text-muted);margin-bottom:8px}.labeler-symbol-preview{margin-bottom:20px;border-radius:var(--radius-sm);overflow:hidden;border:1px solid var(--border);background:var(--bg-secondary)}.preview-header{padding:8px 12px;background:#0000004d;font-size:.75rem;color:var(--text-muted);font-family:var(--font-mono);border-bottom:1px solid var(--border)}.labeler-crop-container{position:relative;overflow:hidden;height:160px;display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary)}.labeler-form{display:grid;grid-template-columns:1fr 1fr;gap:14px}.labeler-form .form-group:first-child{grid-column:1 / -1}.labeler-actions{margin-top:16px;display:flex;gap:10px}.labeler-actions .btn-primary{flex:1}.bom-layout{animation:fadeIn .4s ease both;display:flex;flex-direction:column;gap:24px}.bom-header-card{padding:28px 32px;display:flex;align-items:flex-start;justify-content:space-between;gap:24px}.bom-header-info{flex:1}.bom-title{font-size:1.5rem;font-weight:800;color:var(--text-primary);letter-spacing:-.02em;margin-bottom:6px}.bom-subtitle{font-size:.875rem;color:var(--text-muted);font-family:var(--font-mono)}.bom-total-card{text-align:right;padding:16px 24px;background:var(--info-bg);border:1px solid rgba(0,176,189,.25);border-radius:var(--radius);min-width:200px}.bom-total-label{font-size:.7rem;font-weight:600;color:var(--accent-light);text-transform:uppercase;letter-spacing:.1em;margin-bottom:6px}.bom-total-value{font-size:2rem;font-weight:800;color:var(--text-primary);letter-spacing:-.03em;font-family:var(--font-mono);line-height:1}.bom-header-actions{display:flex;gap:10px;align-items:center}.bom-table-card{overflow:hidden;padding:0}.bom-table-wrap{overflow-x:auto}.bom-table{width:100%;border-collapse:collapse;font-size:.875rem}.bom-table th{padding:14px 16px;text-align:left;font-size:.72rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.07em;background:#00000040;border-bottom:1px solid var(--border);white-space:nowrap}.bom-table th:last-child,.bom-table td:last-child{text-align:right;padding-right:24px}.bom-table td{padding:13px 16px;color:var(--text-primary);border-bottom:1px solid rgba(255,255,255,.04);transition:var(--transition);vertical-align:middle}.bom-table tr:nth-child(2n) td{background:#ffffff05}.bom-table tr:hover td{background:#00b0bd0d}.bom-table tr:last-child td{border-bottom:none}.bom-tag-cell{font-family:var(--font-mono);font-size:.78rem;color:var(--accent-light)}.bom-item-num{font-family:var(--font-mono);font-size:.78rem;color:var(--text-muted);width:40px}.bom-price-cell{font-family:var(--font-mono);font-weight:600;color:var(--text-primary)}.bom-total-cell{font-family:var(--font-mono);font-weight:700;color:var(--accent-light)}.bom-footer{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;background:#0003;border-top:1px solid var(--border)}.bom-footer-info{font-size:.8rem;color:var(--text-muted)}.bom-totals-row{background:#00b0bd0f!important;font-weight:700;border-top:2px solid rgba(0,176,189,.2)}.bom-totals-row td{border-bottom:none!important;color:var(--text-primary);font-weight:700}.error-banner{padding:14px 20px;background:var(--danger-bg);border:1px solid rgba(239,68,68,.25);border-radius:var(--radius-sm);color:var(--danger);font-size:.875rem;display:flex;align-items:center;gap:10px}.error-banner svg{flex-shrink:0}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:40px;color:var(--text-muted);text-align:center}.empty-state svg{opacity:.3}.empty-state-title{font-size:.95rem;font-weight:500;color:var(--text-secondary)}.empty-state-desc{font-size:.82rem;color:var(--text-muted);max-width:260px}@media (max-width: 1100px){.results-layout{grid-template-columns:1fr}.results-panel{order:-1}.symbol-list-column{order:-2}}@media (max-width: 768px){.app-header{padding:0 20px}.app-main{padding:20px}.step-bar{padding:10px 8px 0}.config-grid{grid-template-columns:1fr}.config-toggles{flex-direction:column;gap:16px}.bom-header-card{flex-direction:column;padding:20px}.bom-total-card{width:100%;text-align:left}.labeler-form{grid-template-columns:1fr}.labeler-form .form-group:first-child{grid-column:1}}.annotation-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:var(--bg-primary);display:flex;flex-direction:column}.annotation-toolbar{display:flex;align-items:center;gap:16px;padding:10px 20px;background:var(--bg-card);border-bottom:1px solid var(--border);flex-shrink:0}.annotation-toolbar-title{font-weight:700;font-size:.95rem;color:var(--text-primary);white-space:nowrap}.annotation-toolbar-hint{font-size:.8rem;color:var(--text-muted);flex:1}.annotation-toolbar-controls{display:flex;gap:6px;align-items:center}.ann-btn{background:var(--bg-secondary);border:1px solid var(--border);color:var(--text-primary);border-radius:6px;padding:4px 10px;font-size:1rem;cursor:pointer;transition:background .15s}.ann-btn:hover{background:#ffffff14}.ann-btn-close{color:var(--danger);border-color:#ef44444d;margin-left:8px}.ann-view-steps{display:flex;align-items:center;gap:8px;padding:0 10px;border-left:1px solid var(--border);border-right:1px solid var(--border)}.ann-toggle-btn{display:flex;align-items:center;gap:8px;background:var(--bg-secondary);border:1px solid var(--border);color:var(--text-secondary);border-radius:20px;padding:4px 12px 4px 8px;font-size:.8rem;cursor:pointer;transition:background .2s,border-color .2s,color .2s,box-shadow .2s;white-space:nowrap;-webkit-user-select:none;user-select:none}.ann-toggle-btn:hover:not(:disabled){background:#00b0bd14;border-color:#00b0bd59;color:var(--text-primary)}.ann-toggle-btn.ann-toggle-on{background:#00b0bd1f;border-color:var(--accent);color:var(--accent);box-shadow:0 0 0 1px #00b0bd33}.ann-toggle-btn.ann-toggle-locked{opacity:.4;cursor:not-allowed}.ann-toggle-btn:disabled{cursor:not-allowed;opacity:.55}.ann-toggle-track{position:relative;display:inline-block;width:28px;height:16px;border-radius:8px;background:#ffffff1f;border:1px solid rgba(255,255,255,.18);flex-shrink:0;transition:background .2s,border-color .2s}.ann-toggle-on .ann-toggle-track{background:var(--accent);border-color:var(--accent)}.ann-toggle-thumb{position:absolute;top:1px;left:2px;width:12px;height:12px;border-radius:50%;background:#ffffff80;transition:transform .2s cubic-bezier(.4,0,.2,1),background .2s}.ann-toggle-on .ann-toggle-thumb{transform:translate(12px);background:#fff}.ann-toggle-label{font-weight:500}.ann-step-spinner{display:inline-block;width:14px;height:14px;border:2px solid rgba(0,176,189,.25);border-top-color:var(--accent);border-radius:50%;animation:ann-spin .7s linear infinite;flex-shrink:0}@keyframes ann-spin{to{transform:rotate(360deg)}}.ann-step-error{font-size:.75rem;color:var(--danger);max-width:200px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.annotation-stage-area{display:flex;flex:1;overflow:hidden}.annotation-canvas-container{flex:1;overflow:hidden;position:relative;background:repeating-conic-gradient(rgba(255,255,255,.03) 0% 25%,transparent 0% 50%) 0 0 / 20px 20px}.annotation-loading{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:.9rem}.annotation-sidebar{width:220px;flex-shrink:0;border-left:1px solid var(--border);background:var(--bg-card);padding:16px 12px;overflow-y:auto;display:flex;flex-direction:column;gap:8px}.annotation-sidebar-title{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:4px}.annotation-sidebar-empty{font-size:.8rem;color:var(--text-muted);font-style:italic}.annotation-sidebar-item{display:flex;flex-direction:column;gap:2px;padding:6px 8px;background:var(--bg-secondary);border-radius:6px;border:1px solid var(--border)}.annotation-sidebar-id{font-family:var(--font-mono);font-size:.72rem;color:var(--accent)}.annotation-sidebar-class{font-size:.78rem;color:var(--text-secondary)}.annotation-form-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:10;display:flex;align-items:center;justify-content:center;background:#0000008c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.annotation-form{background:#0f1623;border:1px solid var(--border-strong);border-radius:12px;padding:24px;width:360px;max-width:90vw;display:flex;flex-direction:column;gap:14px;box-shadow:0 20px 60px #000c}.annotation-form-header{font-size:1rem;font-weight:700;color:var(--text-primary)}.annotation-crop-preview{border:1px solid var(--border);border-radius:6px;overflow:hidden;min-height:160px;max-height:200px;display:flex;align-items:center;justify-content:center;background:var(--bg-secondary)}.annotation-crop-preview img{max-width:100%;max-height:200px;object-fit:contain;image-rendering:auto}.ann-field{display:flex;flex-direction:column;gap:4px}.ann-field label{font-size:.75rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.ann-field input{background:var(--bg-secondary);border:1px solid var(--border);border-radius:6px;padding:7px 10px;color:var(--text-primary);font-size:.875rem;outline:none;transition:border-color .15s;width:100%;box-sizing:border-box}.ann-field input:focus{border-color:var(--accent)}.ann-field-row{display:flex;gap:10px}.ann-field-row .ann-field{flex:1}.ann-error{font-size:.8rem;color:var(--danger);background:#ef444414;border:1px solid rgba(239,68,68,.2);border-radius:6px;padding:6px 10px}.ann-form-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:4px}.ann-trigger-btn{display:flex;align-items:center;gap:6px;font-size:.8rem;padding:5px 12px;white-space:nowrap}.badge-manual{display:inline-flex;align-items:center;padding:2px 7px;border-radius:4px;font-size:.7rem;font-weight:600;letter-spacing:.03em;background:#8b5cf626;color:#a78bfa;border:1px solid rgba(139,92,246,.25)}
