:root{--bg-primary:#0a0e17;--bg-secondary:#111827;--bg-tertiary:#1a2332;--bg-card:#111827cc;--bg-glass:#11182799;--bg-hover:#3882f614;--bg-active:#3882f626;--text-primary:#f1f5f9;--text-secondary:#94a3b8;--text-muted:#64748b;--text-inverse:#0a0e17;--accent:#3b82f6;--accent-hover:#2563eb;--accent-light:#3b82f626;--success:#22c55e;--success-bg:#22c55e1f;--warning:#f59e0b;--warning-bg:#f59e0b1f;--danger:#ef4444;--danger-bg:#ef44441f;--info:#06b6d4;--border:#94a3b81f;--border-light:#94a3b80f;--border-accent:#3b82f64d;--shadow-sm:0 1px 3px #0000004d;--shadow-md:0 4px 12px #0006;--shadow-lg:0 8px 32px #00000080;--shadow-glow:0 0 20px #3b82f626;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--radius-full:9999px;--transition-fast:.15s ease;--transition-normal:.25s ease;--transition-slow:.4s ease;--font-sans:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;--font-mono:"JetBrains Mono","Fira Code",monospace;--sidebar-width:280px;--header-height:60px}
*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}body{font-family:var(--font-sans);background:var(--bg-primary);color:var(--text-primary);min-height:100vh;line-height:1.6}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--text-muted);border-radius:var(--radius-full)}h1,h2,h3,h4,h5,h6{color:var(--text-primary);font-weight:600;line-height:1.3}h1{font-size:1.75rem}h2{font-size:1.375rem}h3{font-size:1.125rem}a{color:var(--accent);transition:color var(--transition-fast);text-decoration:none}a:hover{color:var(--accent-hover)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}@keyframes pulse{0%,to{opacity:.5}50%{opacity:1}}.skeleton{background:linear-gradient(90deg,var(--bg-tertiary)25%,var(--bg-hover)50%,var(--bg-tertiary)75%);border-radius:var(--radius-sm);background-size:200% 100%;animation:1.5s ease-in-out infinite pulse}.flex{display:flex}.flex-col{flex-direction:column}.flex-row{align-items:center;display:flex}.flex-between{justify-content:space-between;align-items:center;display:flex}.flex-end{justify-content:flex-end;display:flex}.flex-wrap{flex-wrap:wrap}.flex-shrink-0{flex-shrink:0}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-2{gap:2px}.gap-4{gap:4px}.gap-6{gap:6px}.gap-sm,.gap-8{gap:8px}.gap-10{gap:10px}.gap-12{gap:12px}.gap-md,.gap-16{gap:16px}.gap-20{gap:20px}.gap-lg,.gap-24{gap:24px}.mb-4{margin-bottom:4px}.mb-6{margin-bottom:6px}.mb-8{margin-bottom:8px}.mb-12{margin-bottom:12px}.mb-16{margin-bottom:16px}.mb-24{margin-bottom:24px}.my-8{margin:8px 0}.mt-4{margin-top:4px}.mt-8{margin-top:8px}.mt-12{margin-top:12px}.mt-16{margin-top:16px}.mr-4{margin-right:4px}.mr-8{margin-right:8px}.m-0{margin:0}.p-8{padding:8px}.p-12{padding:12px}.p-16{padding:16px}.p-20{padding:20px}.p-24{padding:24px}.p-28{padding:28px}.p-32{padding:32px}.py-24{padding:24px 0}.py-32{padding:32px 0}.px-4{padding:0 4px}.w-full{width:100%}.text-center{text-align:center}.text-xs{font-size:.75rem}.text-s{font-size:.8125rem}.text-sm{font-size:.875rem}.text-base{font-size:.9375rem}.text-2xl{font-size:2rem}.text-muted{color:var(--text-muted)}.text-secondary{color:var(--text-secondary)}.text-muted-xs{color:var(--text-muted);font-size:.75rem}.text-muted-s{color:var(--text-muted);font-size:.8125rem}.text-muted-sm{color:var(--text-muted);font-size:.875rem}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-mono{font-family:var(--font-mono)}.whitespace-nowrap{white-space:nowrap}.hidden{display:none}.divider{border:none;border-top:2px solid var(--border);margin:4px 0}.settings-card .divider{border-top-width:2px;border-color:var(--accent);opacity:.4}.cursor-pointer{cursor:pointer}.select-none{-webkit-user-select:none;user-select:none}.self-center{align-self:center}.self-start{align-self:flex-start}.card-body{flex-direction:column;gap:20px;padding:28px;display:flex}.grid-2col{grid-template-columns:1fr 1fr;gap:16px;display:grid}.table-cell-actions{white-space:nowrap;gap:4px;display:flex}.table-cell-narrow{width:1%}.cell-truncate{text-overflow:ellipsis;white-space:nowrap;max-width:240px;overflow:hidden}.cell-truncate-sm{text-overflow:ellipsis;white-space:nowrap;max-width:160px;overflow:hidden}.input-compact{padding:4px 8px;font-size:.8125rem}.skeleton-row{height:60px;margin-bottom:8px}.skeleton-row-sm{height:40px;margin-bottom:8px}.empty-text{color:var(--text-muted);text-align:center;padding:24px 0;font-size:.875rem}.hint-text{color:var(--text-muted);margin-top:4px;font-size:.75rem;display:block}.paste-box{resize:vertical;width:100%;font-family:var(--font-mono);border:1px solid var(--border);background:var(--bg-primary);color:var(--text-primary);box-sizing:border-box;border-radius:6px;padding:8px 10px;font-size:.8125rem}.import-panel{background:var(--bg-tertiary);border:1px solid var(--border);border-radius:8px;margin-bottom:16px;padding:16px}.instrument-item{background:var(--bg-secondary);border-radius:var(--radius-sm);border:1px solid var(--border);justify-content:space-between;align-items:center;padding:8px 12px;font-size:.875rem;display:flex}.version-link{cursor:pointer;padding:2px 8px;font-size:.8125rem;text-decoration:underline}.version-label{color:var(--text-muted);padding:2px 8px;font-size:.8125rem}.snapshot-row{background:var(--bg-secondary);opacity:.82}.resize-handle{cursor:col-resize;z-index:10;width:4px;height:100%;position:absolute;top:0;left:0}.resize-handle-right{left:auto;right:0}.company-logo{object-fit:contain;max-width:100%;max-height:40px;margin-top:8px}.status-filter-group{background:var(--bg-secondary);border-radius:var(--radius-sm);border:1px solid var(--border);gap:4px;padding:4px;display:flex}.pagination-bar{border-top:1px solid var(--border);justify-content:space-between;align-items:center;margin-top:4px;padding:12px 0;display:flex}.sort-indicator{font-size:.65rem}.sort-indicator-inactive{opacity:.3}.status-filter-btn{min-width:90px}.pagination-ellipsis{padding:0 4px}.pagination-page-btn{min-width:32px}.content-narrow{max-width:480px}.content-medium{max-width:600px}.content-wide{width:100%;max-width:760px;margin:0 auto}.content-xl{max-width:900px}.text-accent{color:var(--accent)}.leading-relaxed{line-height:1.6}.overflow-x-auto{overflow-x:auto}.opacity-muted{opacity:.45}.logo-preview{object-fit:contain;border:1px solid var(--border);border-radius:4px;max-width:200px;max-height:80px}.preview-bar{background:var(--bg-tertiary);border:1px solid var(--border);border-radius:6px;align-items:center;gap:8px;padding:8px 12px;display:flex}.share-footer{text-align:center;color:var(--text-muted);padding:24px;font-size:.8125rem}.settings-card{flex-direction:column;gap:20px;max-width:720px;padding:28px;display:flex}.modal-form{flex-direction:column;gap:16px;display:flex}.nav-icon{margin-right:8px}.separator-btn{font-family:var(--font-mono);border:2px solid var(--accent);min-width:32px;font-size:.875rem;font-weight:700}.custom-sep-input{width:80px;padding:4px 8px;font-size:.8125rem}.token-field-tile{font-size:.8125rem}.template-area{background:var(--bg-secondary);border:1px solid var(--border);border-radius:8px;flex-wrap:wrap;align-items:center;gap:4px;min-height:48px;margin-bottom:10px;padding:10px 12px;display:flex}.template-token{align-items:center;gap:2px;display:flex}.token-move-btn{background:0 0;border:none;padding:0 2px;font-size:.75rem;line-height:1}.token-move-btn:not(:disabled){cursor:pointer;opacity:.6}.token-move-btn:disabled{cursor:default;opacity:.2}.token-badge{border-radius:4px;align-items:center;gap:4px;padding:3px 8px;font-size:.8125rem;display:inline-flex}.token-badge-field{background:var(--primary-bg,#eff6ff);color:var(--primary,#2563eb);border:1px solid var(--primary-light,#93c5fd);font-weight:600}.token-badge-literal{background:var(--bg-tertiary);color:var(--text-secondary);border:1px solid var(--border);font-weight:400;font-family:var(--font-mono)}.token-remove-btn{cursor:pointer;opacity:.6;background:0 0;border:none;padding:0;font-size:.875rem;line-height:1}.preview-code{color:var(--text-primary);font-size:.8125rem;font-family:var(--font-mono);word-break:break-all}.section-label{color:var(--text-muted);margin-bottom:6px;font-size:.75rem;font-weight:600}.share-meta{color:var(--text-muted);gap:24px;margin-bottom:8px;font-size:.875rem;display:flex}.step-header-bar{justify-content:space-between;margin-bottom:16px;display:flex}.upload-placeholder-icon{margin-bottom:8px;font-size:2rem}.import-table{border-collapse:collapse;table-layout:auto;width:100%;font-size:.8125rem}.import-table th{border:1px solid var(--border);background:var(--bg-secondary);min-width:110px;padding:4px 6px}.import-table td{border:1px solid var(--border);padding:3px 6px}.import-table-select{width:100%;margin:0;padding:2px 6px;font-size:.75rem}.import-header-row{opacity:.45}.import-header-row td{background:var(--bg-secondary);font-size:.75rem;font-style:italic}.import-data-td{text-overflow:ellipsis;white-space:nowrap;max-width:200px;overflow:hidden}.import-more-td{color:var(--text-muted);text-align:center;font-size:.75rem;font-style:italic}.import-checkbox-label{cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:8px;margin-bottom:12px;font-size:.8125rem;display:flex}.editor-tabs-bar{background:var(--bg-secondary);padding:12px 24px 0}.skeleton-toolbar{width:200px;height:30px}.skeleton-block{height:80px;margin-bottom:16px}
.btn{border-radius:var(--radius-md);font-family:var(--font-sans);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;-webkit-user-select:none;user-select:none;border:none;justify-content:center;align-items:center;gap:8px;padding:10px 20px;font-size:.875rem;font-weight:500;display:inline-flex}.btn:disabled{opacity:.5;pointer-events:none}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-hover);box-shadow:var(--shadow-glow)}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover{border-color:var(--border-accent);background:var(--bg-hover)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{background:#dc2626}.btn-ghost{color:var(--text-secondary);background:0 0}.btn-ghost:hover{background:var(--bg-hover);color:var(--text-primary)}.btn-sm{padding:6px 12px;font-size:.8125rem}.btn-icon{min-width:36px;min-height:36px;padding:8px}.input,.textarea,.select{background:var(--bg-tertiary);width:100%;color:var(--text-primary);border:1px solid var(--border);border-radius:var(--radius-md);font-family:var(--font-sans);transition:border-color var(--transition-fast),box-shadow var(--transition-fast);outline:none;padding:10px 14px;font-size:.875rem}.input:focus,.textarea:focus,.select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-light)}.input::placeholder,.textarea::placeholder{color:var(--text-muted)}.textarea{resize:vertical;min-height:320px}.select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;padding-right:36px}.form-group{flex-direction:column;gap:6px;display:flex}.form-label{color:var(--text-secondary);font-size:.8125rem;font-weight:500}.settings-card .form-label{color:var(--text-primary);font-size:.9375rem;font-weight:700}.form-error{color:var(--danger);font-size:.75rem}.form-hint{color:var(--text-muted);margin-top:-2px;font-size:.75rem}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.glass{background:var(--bg-glass);border:1px solid var(--border);border-radius:var(--radius-lg);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.badge{border-radius:var(--radius-full);letter-spacing:.02em;text-transform:uppercase;align-items:center;padding:3px 10px;font-size:.75rem;font-weight:600;display:inline-flex}.badge-draft{background:var(--warning-bg);color:var(--warning)}.badge-approved{background:var(--success-bg);color:var(--success)}.badge-withdrawn{background:var(--danger-bg);color:var(--danger)}.badge-editing{color:var(--info);background:#06b6d41f}.badge-pending-approval{color:var(--warning);background:#f59e0b26}.badge-rejected{background:var(--danger-bg);color:var(--danger)}.badge-quality_engineer,.badge-quality_manager{color:var(--info);background:#06b6d426}.approval-stepper{border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--bg-secondary);margin-bottom:16px;padding:16px}.approval-stepper-title{margin-bottom:12px;font-size:.875rem;font-weight:600}.approval-steps{flex-direction:column;gap:8px;display:flex}.approval-step{border-radius:var(--radius-md);border:1px solid var(--border);background:var(--bg-primary);align-items:flex-start;gap:12px;padding:8px 12px;display:flex}.approval-step-pending{border-left:3px solid var(--warning)}.approval-step-approved{border-left:3px solid var(--success)}.approval-step-rejected{border-left:3px solid var(--danger)}.approval-step-indicator{background:var(--bg-tertiary);width:28px;height:28px;color:var(--text-secondary);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.75rem;font-weight:700;display:flex}.approval-step-approved .approval-step-indicator{background:var(--success-bg);color:var(--success)}.approval-step-rejected .approval-step-indicator{background:var(--danger-bg);color:var(--danger)}.approval-step-content{flex:1;min-width:0}.approval-step-role{font-size:.875rem;font-weight:600}.approval-step-status{color:var(--text-secondary);font-size:.75rem}.approval-step-meta{color:var(--text-muted);margin-top:2px;font-size:.75rem}.approval-step-comment{color:var(--text-secondary);background:var(--bg-tertiary);border-radius:var(--radius-sm);margin-top:4px;padding:6px 8px;font-size:.8rem}.approval-action-buttons{flex-direction:column;gap:8px;margin-top:12px;display:flex}.approval-comment-input{resize:vertical;min-height:40px}.approval-action-row{justify-content:flex-end;gap:8px;display:flex}.approval-workflow-step-row{align-items:center;gap:8px;margin-bottom:8px;display:flex}.approval-workflow-step-order{text-align:center;flex-shrink:0;width:24px;font-size:.875rem;font-weight:600}.approval-workflow-step-required{white-space:nowrap;align-items:center;gap:4px;font-size:.8rem;display:flex}.recipe-calculator{border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--bg-secondary);margin-top:12px;padding:16px}.recipe-servings-input{text-align:center;width:100px}.recipe-scaled-table{margin-top:12px}.recipe-scaled-table td.recipe-scaled-value{font-weight:600}.table-wrapper{border-radius:var(--radius-lg);border:1px solid var(--border);overflow-x:auto}table{border-collapse:collapse;width:100%}th{text-align:left;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;background:var(--bg-tertiary);border-bottom:1px solid var(--border);padding:12px 16px;font-size:.75rem;font-weight:600}td{border-bottom:1px solid var(--border-light);padding:12px 16px;font-size:.875rem}tr:hover td{background:var(--bg-hover)}tr:last-child td{border-bottom:none}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;animation:fadeIn var(--transition-fast);background:#000000a6;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);width:90%;max-width:480px;box-shadow:var(--shadow-lg);animation:slideUp var(--transition-normal);padding:28px}.modal-lg{max-width:760px}.modal-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.modal-body{margin-bottom:24px}.modal-footer{justify-content:flex-end;gap:10px;display:flex}@media (max-width:480px){.modal{width:95%;max-height:90vh;padding:20px 16px;overflow-y:auto}.modal-lg{max-width:95%}.modal-header{margin-bottom:14px}.modal-header h2,.modal-header h3{font-size:1.1rem}.modal-body{margin-bottom:16px}.modal-footer{flex-wrap:wrap;gap:8px}.modal-footer .btn{flex:1;min-width:0}}.error-boundary{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:12px;min-height:60vh;padding:32px;display:flex}.error-boundary-icon{background:var(--danger-bg);width:56px;height:56px;color:var(--danger);border-radius:50%;justify-content:center;align-items:center;font-size:1.5rem;font-weight:700;display:flex}.error-boundary h2{color:var(--text-primary);margin:0;font-size:1.25rem}.error-boundary p{color:var(--text-secondary);margin:0}.toast-container{z-index:2000;flex-direction:column;gap:8px;display:flex;position:fixed;top:20px;right:20px}.toast{border-radius:var(--radius-md);box-shadow:var(--shadow-md);animation:slideInRight var(--transition-normal);max-width:400px;padding:12px 20px;font-size:.875rem}.toast-success{background:var(--success);color:#fff}.toast-error{background:var(--danger);color:#fff}.toast-info{background:var(--accent);color:#fff}.tabs{background:var(--bg-tertiary);border-radius:var(--radius-md);gap:2px;padding:4px;display:flex}.tab{color:var(--text-secondary);font-family:var(--font-sans);cursor:pointer;border-radius:var(--radius-sm);transition:all var(--transition-fast);background:0 0;border:none;flex:1;padding:10px 20px;font-size:.875rem;font-weight:500}.tab:hover{color:var(--text-primary);background:var(--bg-hover)}.tab.active{background:var(--accent);color:#fff}.custom-fields-section{flex-direction:column;gap:16px;margin-top:20px;display:flex}.custom-fields-group{border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.custom-fields-group-header{background:var(--bg-hover);border-bottom:1px solid var(--border);padding:8px 14px}.custom-fields-group-title{text-transform:uppercase;letter-spacing:.03em;color:var(--text-secondary);font-size:.8rem;font-weight:600}.custom-fields-group-body{flex-direction:column;gap:12px;padding:14px;display:flex}.multiselect-grid{flex-wrap:wrap;gap:8px;display:flex}.multiselect-option{cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:6px;font-size:.875rem;display:inline-flex}.multiselect-option input[type=checkbox]{accent-color:var(--accent)}
.editor-page{margin-left:var(--sidebar-width);flex-direction:column;min-height:100vh;display:flex}.editor-toolbar{background:var(--bg-secondary);border-bottom:1px solid var(--border);z-index:50;justify-content:space-between;align-items:center;padding:12px 24px;display:flex;position:sticky;top:0}.editor-toolbar-left{align-items:center;gap:16px;display:flex}.editor-toolbar-right{align-items:center;gap:8px;display:flex}.editor-body{flex:1;display:flex}.editor-main{flex:1;padding:24px;overflow-y:auto}.step-navigator{background:var(--bg-secondary);border-left:1px solid var(--border);width:200px;height:calc(100vh - 60px);padding:16px 8px;position:sticky;top:60px;overflow-y:auto}.step-navigator h4{color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:4px;padding:8px;font-size:.6875rem;font-weight:600}.step-nav-item{border-radius:var(--radius-sm);cursor:grab;transition:background var(--transition-fast),border-top var(--transition-fast),opacity var(--transition-fast);border-top:2px solid #0000;align-items:center;gap:8px;padding:8px 10px;font-size:.8125rem;display:flex}.step-nav-item:active{cursor:grabbing}.step-nav-item:hover{background:var(--bg-hover)}.step-nav-item.drag-over{border-top:2px solid var(--accent);background:var(--accent-light)}.step-nav-drag-handle{color:var(--text-muted);opacity:0;transition:opacity var(--transition-fast);flex-shrink:0;font-size:1rem;line-height:1}.step-nav-item:hover .step-nav-drag-handle{opacity:1}.step-nav-item.active{background:var(--accent-light);color:var(--accent)}.step-nav-number{background:var(--bg-tertiary);border-radius:var(--radius-full);flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;font-size:.75rem;font-weight:600;display:flex}.step-nav-item.active .step-nav-number{background:var(--accent);color:#fff}.step-nav-label{white-space:nowrap;text-overflow:ellipsis;color:var(--text-secondary);overflow:hidden}.step-card{border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--bg-card);transition:border-color var(--transition-fast);margin-bottom:16px;padding:24px}.step-card:hover,.step-card.active{border-color:var(--border-accent)}.step-card-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.step-number-badge{color:var(--accent);align-items:center;gap:8px;font-weight:600;display:flex}.step-actions{gap:4px;display:flex}.step-fields{grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px;display:grid}.step-fields .full-width{grid-column:1/-1}.step-two-col{grid-template-columns:1fr 3fr;align-items:start;gap:24px;display:grid}.step-col-left{flex-direction:column;gap:0;display:flex}.step-col-right{flex-direction:column;display:flex}@media (max-width:900px){.step-two-col{grid-template-columns:1fr}}.image-upload-area{border:2px dashed var(--border);border-radius:var(--radius-md);text-align:center;cursor:pointer;transition:all var(--transition-fast);background:var(--bg-tertiary);padding:40px}.image-upload-area:hover{border-color:var(--accent);background:var(--bg-hover)}.image-upload-area.has-image{border-style:solid;padding:0;position:relative}.image-upload-area img{border-radius:var(--radius-md);max-width:100%;display:block}.step-image-thumbnails{background:var(--bg-tertiary);border-radius:var(--radius-md);border:1px solid var(--border);flex-wrap:wrap;gap:8px;margin-top:8px;padding:8px;display:flex}.step-image-thumb{border-radius:var(--radius-sm);border:2px solid var(--border);cursor:pointer;background:var(--bg-secondary);width:72px;height:60px;transition:border-color var(--transition-fast);flex-shrink:0;position:relative;overflow:hidden}.step-image-thumb:hover{border-color:var(--accent)}.step-image-thumb.active{border-color:var(--accent);box-shadow:0 0 0 2px #3b82f640}.step-image-thumb img{object-fit:cover;width:100%;height:100%}.step-image-thumb-label{color:#fff;text-shadow:0 1px 2px #0009;pointer-events:none;font-size:10px;font-weight:600;position:absolute;bottom:2px;left:4px}.step-image-thumb-remove{color:#fff;cursor:pointer;opacity:0;width:18px;height:18px;transition:opacity var(--transition-fast);background:#ef4444d9;border:none;border-radius:50%;justify-content:center;align-items:center;padding:0;font-size:9px;line-height:1;display:flex;position:absolute;top:2px;right:2px}.step-image-thumb:hover .step-image-thumb-remove{opacity:1}.step-image-thumb-add{color:var(--accent);background:var(--bg-secondary);border:2px dashed var(--accent);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);justify-content:center;align-items:center;font-size:12px;font-weight:600;display:flex}.step-image-thumb-add:hover:not(:disabled){background:var(--bg-hover)}.step-image-thumb-add:disabled{opacity:.5;cursor:not-allowed}.annotation-toolbar{background:var(--bg-tertiary);border-radius:var(--radius-md);gap:4px;margin-top:8px;padding:8px;display:flex}.annotation-tool{border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);font-size:.8125rem;font-family:var(--font-sans);background:0 0;padding:8px 12px}.annotation-tool:hover{background:var(--bg-hover);color:var(--text-primary)}.annotation-tool.active{background:var(--accent);color:#fff;border-color:var(--accent)}.pdf-preview-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1000;background:#000c;flex-direction:column;display:flex;position:fixed;inset:0}.pdf-preview-toolbar{background:var(--bg-secondary);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:12px 24px;display:flex}.pdf-preview-content{flex-direction:column;flex:1;align-items:center;gap:24px;padding:32px;display:flex;overflow-y:auto}.pdf-page{color:#1a1a1a;width:210mm;min-height:297mm;box-shadow:var(--shadow-lg);background:#fff;border-radius:2px;flex-direction:column;padding:0;font-family:Inter,sans-serif;font-size:11pt;display:flex;position:relative;overflow:hidden}.pdf-page-header{background:#f8fafc;border-bottom:2px solid #3b82f6;flex-direction:column;justify-content:center;gap:4px;height:37.125mm;padding:16px 24px;display:flex}.pdf-page-header h2{color:#1e293b;margin:0;font-size:14pt}.pdf-page-header .meta{color:#64748b;gap:24px;font-size:9pt;display:flex}.pdf-page-body{flex-direction:column;flex:1;gap:16px;padding:20px 24px;display:flex}.pdf-step-image{object-fit:contain;border:1px solid #e2e8f0;border-radius:4px;max-width:100%;max-height:400px}.pdf-step-description{color:#334155;font-size:10pt;line-height:1.5}.pdf-page-footer{color:#64748b;background:#f8fafc;border-top:1px solid #e2e8f0;justify-content:space-between;align-items:center;height:37.125mm;padding:12px 24px;font-size:8pt;display:flex}.comments-section{margin-top:24px;padding:20px}.comment-item{border-bottom:1px solid var(--border-light);padding:12px 0}.comment-item:last-child{border-bottom:none}.comment-header{align-items:center;gap:8px;margin-bottom:6px;display:flex}.comment-author{color:var(--accent);font-size:.8125rem;font-weight:600}.comment-date{color:var(--text-muted);font-size:.75rem}.comment-body{color:var(--text-secondary);font-size:.875rem;line-height:1.5}.comment-input-area{gap:8px;margin-top:12px;display:flex}.reaction-plan-editor{border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--bg-secondary);margin-top:12px;padding:16px}.reaction-step-row{align-items:flex-start;gap:8px;margin-bottom:8px;display:flex}.reaction-step-number{text-align:center;flex-shrink:0;width:24px;padding-top:8px;font-size:.875rem;font-weight:600}.reaction-step-fields{flex:1;grid-template-columns:2fr 1fr 1fr 1fr;gap:6px;display:grid}.reaction-step-actions{flex-shrink:0;gap:2px;display:flex}.reaction-diagram{border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--bg-primary);padding:16px}.reaction-diagram-flow{flex-direction:column;align-items:center;gap:0;display:flex}.reaction-diagram-step{flex-direction:column;align-items:center;display:flex}.reaction-node{border-radius:var(--radius-md);border:2px solid var(--border);text-align:center;flex-direction:column;align-items:center;min-width:200px;max-width:400px;padding:10px 20px;display:flex}.reaction-node-nok{background:var(--danger-bg);border-color:var(--danger);color:var(--text-primary)}.reaction-node-ok{background:var(--success-bg);border-color:var(--success);color:var(--text-primary)}.reaction-node-action{background:var(--bg-secondary);border-color:var(--border-accent)}.reaction-node-step-num{text-transform:uppercase;color:var(--text-muted);font-size:.7rem;font-weight:700}.reaction-node-label{font-size:.875rem;font-weight:600}.reaction-node-detail{color:var(--text-secondary);font-size:.75rem}.reaction-node-escalation{color:var(--warning);margin-top:2px;font-size:.7rem;font-weight:600}.reaction-arrow{flex-direction:column;align-items:center;height:28px;display:flex}.reaction-arrow-line{background:var(--border);flex:1;width:2px}.reaction-arrow-head{color:var(--text-muted);font-size:.6rem;line-height:1}.reaction-plan-toggle-section{border-top:1px solid var(--border);padding:12px 16px 16px}.reaction-diagram-modal{width:90%;max-width:800px}.reaction-diagram-modal .modal-body{padding:0}.reaction-diagram-modal-scroll{max-height:70vh;padding:20px 24px;overflow-y:auto}@media (max-width:480px){.reaction-diagram-modal{width:95%;max-width:95%}.reaction-diagram-modal-scroll{max-height:75vh;padding:12px 14px}}
.login-page{background:var(--bg-primary);justify-content:center;align-items:center;min-height:100vh;display:flex;position:relative;overflow:hidden}.login-page:before{content:"";background:radial-gradient(circle at 30% 40%,#3b82f614 0%,#0000 50%),radial-gradient(circle at 70% 60%,#8b5cf60d 0%,#0000 50%);width:200%;height:200%;animation:20s ease-in-out infinite alternate bgShift;position:absolute;top:-50%;left:-50%}@keyframes bgShift{0%{transform:translate(0)}to{transform:translate(-3%,3%)}}.login-card{z-index:1;width:100%;max-width:420px;padding:40px;position:relative}.login-logo{text-align:center;margin-bottom:32px}.login-logo h1{background:linear-gradient(135deg,var(--accent),#8b5cf6);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:1.5rem}.login-logo p{color:var(--text-muted);margin-top:6px;font-size:.875rem}.login-form{flex-direction:column;gap:20px;display:flex}.login-error{background:var(--danger-bg);color:var(--danger);border-radius:var(--radius-md);border:1px solid #ef444433;padding:10px 14px;font-size:.8125rem}.dashboard-layout{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-width);background:var(--bg-secondary);border-right:1px solid var(--border);z-index:100;flex-direction:column;height:100vh;display:flex;position:fixed;top:0;left:0;overflow:hidden}.sidebar-header{border-bottom:1px solid var(--border);padding:20px}.sidebar-header h2{background:linear-gradient(135deg,var(--accent),#8b5cf6);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:1rem}.sidebar-header p{color:var(--text-muted);margin-top:2px;font-size:.75rem}.sidebar-content{flex:1;padding:12px;overflow-y:auto}.sidebar-section-title{justify-content:space-between;align-items:center;margin-bottom:4px;padding:8px 12px;display:flex}.sidebar-section-title span{color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;font-size:.6875rem;font-weight:600}.product-item{border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);justify-content:space-between;align-items:center;margin-bottom:2px;padding:10px 12px;display:flex}.product-item:hover{background:var(--bg-hover)}.product-item.active{background:var(--accent-light);border:1px solid var(--border-accent)}.product-item.product-item-disabled{cursor:default;opacity:.45}.product-item.product-item-disabled:hover{background:0 0}.product-item .product-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;flex:1;font-size:.875rem;overflow:hidden}.product-item .product-customer{color:var(--text-muted);font-size:.8rem}.product-item .product-count{color:var(--text-muted);flex-shrink:0;margin-left:8px;font-size:.75rem}.product-item .product-delete{opacity:0;transition:opacity var(--transition-fast);flex-shrink:0;margin-left:4px}.product-item:hover .product-delete{opacity:1}.sidebar-footer{border-top:1px solid var(--border);padding:16px}.user-info{align-items:center;gap:10px;padding:8px;display:flex}.user-avatar{border-radius:var(--radius-full);background:var(--accent);color:#fff;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:.875rem;font-weight:600;display:flex}.user-details{flex:1;min-width:0}.user-details .username{color:var(--text-primary);font-size:.875rem;font-weight:500}.user-details .role{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.6875rem}.sidebar-group{margin-bottom:2px}.sidebar-group-header{cursor:pointer;border-radius:var(--radius-md);transition:background var(--transition-fast);-webkit-user-select:none;user-select:none;justify-content:space-between;align-items:center;padding:8px 12px;display:flex}.sidebar-group-header:hover{background:var(--bg-hover)}.sidebar-group-header span{color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;font-size:.6875rem;font-weight:600}.sidebar-group-chevron{width:14px;height:14px;color:var(--text-muted);transition:transform var(--transition-fast);flex-shrink:0}.sidebar-group-chevron.expanded{transform:rotate(90deg)}.sidebar-group-items{opacity:0;max-height:0;transition:max-height .2s ease-out,opacity .15s ease-out;overflow:hidden}.sidebar-group-items.expanded{opacity:1;max-height:500px;transition:max-height .3s ease-in,opacity .2s ease-in}.sidebar-group-items .product-item{padding-left:20px}.sidebar-group+.sidebar-group{margin-top:4px}.sidebar-group-badge{background:var(--error);color:#fff;border-radius:10px;margin-left:6px;padding:0 6px;font-size:.675rem;font-weight:600;line-height:1.4}.main-content{margin-left:var(--sidebar-width);flex:1;min-height:100vh;padding:32px}.main-header{justify-content:space-between;align-items:center;margin-bottom:28px;padding-right:52px;display:flex}.main-header h1{font-size:1.5rem}.empty-state{text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:80px 20px;display:flex}.empty-state .empty-icon{opacity:.3;margin-bottom:16px;font-size:3rem}.empty-state h3{color:var(--text-secondary);margin-bottom:8px;font-size:1.125rem}.empty-state p{color:var(--text-muted);max-width:400px;font-size:.875rem}.db-not-ready-banner{text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:80px 20px;display:flex}.db-not-ready-banner .db-not-ready-icon{margin-bottom:16px;font-size:3rem}.db-not-ready-banner h3{color:var(--text-primary);margin-bottom:12px;font-size:1.25rem}.db-not-ready-banner p{color:var(--text-secondary);max-width:440px;margin-bottom:20px;font-size:.9rem}.db-not-ready-link{background:var(--accent);color:#fff;border-radius:var(--radius-md);align-items:center;gap:6px;padding:10px 20px;font-size:.875rem;font-weight:500;text-decoration:none;transition:background .15s;display:inline-flex}.db-not-ready-link:hover{background:var(--accent-hover)}.share-page{max-width:900px;margin:0 auto;padding:32px}.share-page .step-view{margin-bottom:24px;padding:24px}.share-page .step-view img{border-radius:var(--radius-md);max-width:100%}.search-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1500;animation:fadeIn var(--transition-fast);background:#000000b3;justify-content:center;align-items:flex-start;padding-top:12vh;display:flex;position:fixed;inset:0}.search-panel{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:90%;max-width:640px;max-height:72vh;animation:slideUp var(--transition-normal);flex-direction:column;display:flex;overflow:hidden}.search-input-row{border-bottom:1px solid var(--border);flex-shrink:0;align-items:center;gap:10px;padding:14px 18px;display:flex}.search-input-row svg{color:var(--text-muted);flex-shrink:0}.search-input-row input{color:var(--text-primary);background:0 0;border:none;outline:none;flex:1;font-family:inherit;font-size:1rem}.search-input-row input::placeholder{color:var(--text-muted)}.search-hint{color:var(--text-muted);border-bottom:1px solid var(--border-light);flex-shrink:0;padding:6px 18px 8px;font-size:.75rem}.search-results{flex:1;overflow-y:auto}.search-result-item{cursor:pointer;border-bottom:1px solid var(--border-light);transition:background var(--transition-fast);flex-direction:column;gap:5px;padding:12px 18px;display:flex}.search-result-item:last-child{border-bottom:none}.search-result-snapshot{background:var(--bg-secondary);opacity:.82}.search-result-snapshot:hover,.search-result-snapshot.focused{opacity:1}.search-result-item:hover,.search-result-item.focused{background:var(--bg-hover)}.search-result-item:hover .search-result-name,.search-result-item.focused .search-result-name{color:var(--accent)}.search-result-name{color:var(--text-primary);transition:color var(--transition-fast);font-size:.9375rem;font-weight:500}.search-result-meta{color:var(--text-muted);flex-wrap:wrap;align-items:center;gap:10px;font-size:.8125rem;display:flex}.search-result-product{color:var(--text-secondary);font-weight:500}.search-empty{text-align:center;color:var(--text-muted);padding:48px 24px;font-size:.875rem}.search-loading{text-align:center;color:var(--text-muted);padding:32px 24px;font-size:.875rem}@media (max-width:768px){.sidebar{transition:transform var(--transition-normal);transform:translate(-100%)}.sidebar.open{transform:translate(0)}.main-content,.editor-page{margin-left:0}.step-navigator{display:none}.step-fields{grid-template-columns:1fr}.pdf-page{width:100%;min-height:auto}}@media (max-width:480px){.search-panel{width:95%;max-height:80vh}.search-input-row{padding:10px 12px}.main-header{flex-direction:column;align-items:flex-start;gap:10px}.main-header .flex-row{flex-wrap:wrap;width:100%}}.matrix-table{overflow-x:auto}.matrix-table table{border-collapse:collapse}.matrix-header-cell{writing-mode:horizontal-tb;text-align:center;min-width:80px;font-size:.75rem}.matrix-cell{text-align:center;min-width:60px;transition:background var(--transition-fast);padding:8px;font-size:.875rem;font-weight:600}.matrix-cell-complete{background:var(--success-bg);color:var(--success)}.matrix-cell-partial{background:var(--warning-bg);color:var(--warning)}.matrix-cell-missing{background:var(--bg-tertiary);color:var(--text-muted)}.matrix-cell:hover{opacity:.8}.view-toggle{background:var(--bg-tertiary);border-radius:var(--radius-md);gap:4px;padding:2px;display:flex}.view-toggle-btn{border-radius:var(--radius-sm);cursor:pointer;color:var(--text-secondary);transition:all var(--transition-fast);background:0 0;border:none;padding:6px 12px;font-size:.8rem}.view-toggle-btn.active{background:var(--bg-primary);color:var(--text-primary);box-shadow:var(--shadow-sm)}.nav-logo-link{cursor:pointer;background:linear-gradient(135deg,var(--accent),#8b5cf6);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:1rem}.nav-filter-row{padding:4px 8px}.nav-filter-input{width:100%;font-size:.8rem!important}.nav-product-tree{max-height:45vh;overflow-y:auto}.nav-tree-expand{cursor:pointer;flex-shrink:0;align-items:center;margin-right:4px;display:inline-flex}.nav-tree-children{padding-left:20px}.nav-quick-actions{flex-wrap:wrap;gap:4px;padding:6px 8px;display:flex}.nav-item-icon{margin-right:8px;font-size:.875rem}.product-id-number{color:var(--text-muted);font-size:.8rem}.sidebar-lang-switch{gap:4px;margin-bottom:8px;display:flex}.product-card-view{max-width:1200px}.product-card-header{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);gap:24px;margin-bottom:24px;padding:24px;display:flex}.product-card-image{flex-shrink:0}.product-card-img{border-radius:var(--radius-md);object-fit:cover}.product-card-info h1{margin-bottom:8px;font-size:1.5rem}.product-card-meta{flex-wrap:wrap;gap:16px;margin-bottom:8px;display:flex}.product-card-meta-item{font-size:.875rem}.product-card-meta-item .label{color:var(--text-muted);margin-right:4px}.product-card-description{color:var(--text-secondary);margin-top:8px;font-size:.875rem}.product-card-tabs{border-bottom:1px solid var(--border);gap:2px;margin-bottom:20px;padding-bottom:0;display:flex}.product-card-tab{color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;border-bottom:2px solid #0000;padding:8px 16px;font-family:inherit;font-size:.875rem}.product-card-tab:hover{color:var(--text-primary);background:var(--bg-hover)}.product-card-tab.active{color:var(--accent);border-bottom-color:var(--accent);font-weight:500}.product-card-content{min-height:200px}.product-card-details-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.product-card-details-header h2{font-size:1.125rem}.detail-view-header{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:20px;display:flex}.detail-view-header h1{margin-bottom:4px;font-size:1.5rem}.detail-view-id{color:var(--text-muted);margin-bottom:2px;font-size:.875rem;display:block}.detail-view-parent{color:var(--text-secondary);font-size:.875rem;display:block}.detail-view-actions{flex-shrink:0}.search-panel-universal{max-width:700px;max-height:80vh}.search-group-header{color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;align-items:center;gap:6px;padding:10px 18px 4px;font-size:.6875rem;font-weight:600;display:flex}.search-group-icon{font-size:.875rem}.search-footer{border-top:1px solid var(--border);color:var(--text-muted);flex-shrink:0;gap:16px;padding:8px 18px;font-size:.75rem;display:flex}.search-footer kbd{background:var(--bg-tertiary);border:1px solid var(--border);border-radius:3px;padding:1px 4px;font-family:inherit;font-size:.6875rem}.btn-link{color:var(--accent);cursor:pointer;font-size:inherit;background:0 0;border:none;padding:0;font-family:inherit;text-decoration:none}.btn-link:hover{text-decoration:underline}.btn-danger-text{color:var(--danger)}.landing-dashboard{max-width:900px}.landing-dashboard h1{margin-bottom:24px;font-size:1.5rem}.landing-stats{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:16px;margin-bottom:32px;display:grid}.landing-stat-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);text-align:center;padding:20px}.landing-stat-value{color:var(--accent);font-size:2rem;font-weight:700}.landing-stat-label{color:var(--text-muted);margin-top:4px;font-size:.8125rem}.landing-section{margin-bottom:24px}.landing-section h2{margin-bottom:12px;font-size:1.125rem}.main-header-actions{align-items:center;gap:8px;display:flex}.pagination-info{color:var(--text-muted);font-size:.8125rem}
.module-summary-section{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);margin-top:20px;padding:16px}.module-summary-title{color:var(--text-primary);text-transform:uppercase;letter-spacing:.04em;margin-bottom:12px;font-size:.8125rem;font-weight:600}.module-summary-table{border-collapse:collapse;width:100%;font-size:.8125rem}.module-summary-table th{text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);text-align:left;border-bottom:1px solid var(--border);padding:6px 10px;font-size:.75rem}.module-summary-table td{border-bottom:1px solid var(--border-light);color:var(--text-secondary);padding:6px 10px}.module-summary-table tbody tr:last-child td{border-bottom:none}.module-validation-error{color:var(--danger);font-style:italic}.step-nav-indicators{flex-shrink:0;align-items:center;gap:4px;margin-left:auto;display:flex}.step-indicator{flex-shrink:0;line-height:1}.step-indicator-ccp{color:var(--danger);title:"CCP";font-size:.5rem}.step-indicator-cc{color:var(--warning);font-size:.6875rem}.cycle-time-indicator{background:var(--bg-secondary);border-bottom:1px solid var(--border);align-items:center;gap:16px;padding:8px 24px;display:flex}.cycle-time-header{flex-shrink:0;align-items:center;gap:8px;display:flex}.cycle-time-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;font-size:.75rem}.cycle-time-value{font-size:.875rem;font-weight:600}.cycle-time-green{color:var(--success)}.cycle-time-yellow{color:var(--warning)}.cycle-time-red{color:var(--danger)}.cycle-time-bar{background:var(--bg-tertiary);border-radius:var(--radius-full);flex:1;max-width:200px;height:6px;overflow:hidden}.cycle-time-bar-fill{border-radius:var(--radius-full);height:100%;transition:width var(--transition-normal)}.cycle-time-bar-green{background:var(--success)}.cycle-time-bar-yellow{background:var(--warning)}.cycle-time-bar-red{background:var(--danger)}.allergen-badges{flex-wrap:wrap;gap:4px;margin-top:4px;display:flex}.allergen-badges-compact{vertical-align:middle;margin-top:0;margin-left:8px;display:inline-flex}.allergen-badge{background:var(--danger-bg);color:var(--danger);border-radius:var(--radius-full);white-space:nowrap;padding:1px 6px;font-size:.6875rem}.ecn-dialog-body{flex-direction:column;gap:16px;display:flex}.ecn-dialog-description{color:var(--text-secondary);font-size:.875rem}.ecn-dialog-actions{justify-content:flex-end;gap:8px;margin-top:8px;display:flex}.ncr-status-badge{border-radius:var(--radius-sm);white-space:nowrap;border:1px solid;padding:2px 8px;font-size:.75rem;font-weight:600;display:inline-block}.text-danger{color:var(--danger,#ef4444);font-weight:600}.ncr-detail{flex-direction:column;gap:20px;padding:24px;display:flex}.ncr-detail-header{justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.ncr-detail-title{margin:0;font-size:1.25rem;font-weight:700}.ncr-detail-meta{flex-wrap:wrap;gap:16px;margin-top:4px;display:flex}.ncr-progress{align-items:center;gap:0;padding:16px 0;display:flex}.ncr-progress-step{flex-direction:column;flex:1;align-items:center;display:flex;position:relative}.ncr-progress-step:before{content:"";background:var(--border);z-index:0;height:3px;position:absolute;top:8px;left:0;right:0}.ncr-progress-step:first-child:before{left:50%}.ncr-progress-step:last-child:before{right:50%}.ncr-progress-active:before{background:var(--accent,#3b82f6)}.ncr-progress-dot{border:3px solid var(--border);background:var(--bg-primary);z-index:1;border-radius:50%;width:18px;height:18px;transition:all .2s}.ncr-progress-active .ncr-progress-dot{border-color:var(--accent,#3b82f6);background:var(--accent,#3b82f6)}.ncr-progress-current .ncr-progress-dot{box-shadow:0 0 0 4px #3b82f633}.ncr-progress-label{color:var(--text-muted);text-align:center;white-space:nowrap;margin-top:6px;font-size:.6875rem}.ncr-progress-active .ncr-progress-label{color:var(--text-primary);font-weight:600}.ncr-info-grid{max-width:800px}.ncr-8d-form{flex-direction:column;gap:12px;max-width:900px;display:flex}.ncr-8d-card{border-left:3px solid var(--accent,#3b82f6)}.ncr-8d-label{font-size:.9375rem;font-weight:600}.ncr-actions-list{flex-direction:column;gap:12px;max-width:900px;display:flex}.ncr-action-card{border-left:3px solid var(--border)}.ncr-action-header{align-items:flex-start;gap:12px;display:flex}.ncr-action-meta{flex-wrap:wrap;gap:16px;margin-top:8px;display:flex}.ncr-action-buttons{gap:8px;margin-top:12px;display:flex}.form-select{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-primary);width:100%;color:var(--text-primary);font-size:.875rem;font-family:var(--font-sans);cursor:pointer;padding:8px 12px}.form-select:focus{border-color:var(--accent);outline:none;box-shadow:0 0 0 2px #3b82f626}.eq-cal-banner{border-radius:var(--radius-md);border:1px solid var(--border);flex-wrap:wrap;align-items:center;gap:12px;padding:12px 16px;font-size:.875rem;display:flex}.eq-cal-ok{background:#22c55e0f;border-color:#22c55e4d}.eq-cal-warning{background:#f59e0b0f;border-color:#f59e0b4d}.eq-cal-overdue{background:#ef44440f;border-color:#ef44444d}.eq-cal-none{background:var(--bg-secondary)}.ppap-progress-section{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);padding:16px}.ppap-progress-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.ppap-progress-bar{background:var(--bg-tertiary);border-radius:var(--radius-full);height:8px;overflow:hidden}.ppap-progress-fill{background:var(--accent,#3b82f6);border-radius:var(--radius-full);height:100%;transition:width .3s}.kpi-dashboard{flex-direction:column;gap:24px;padding:24px;display:flex}.kpi-header{justify-content:space-between;align-items:flex-start;display:flex}.kpi-header h1{margin:0;font-size:1.5rem;font-weight:700}.kpi-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px;display:grid}.kpi-card{background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-md);flex-direction:column;gap:4px;padding:20px;display:flex}.kpi-card-label{text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);font-size:.75rem;font-weight:600}.kpi-card-value{font-variant-numeric:tabular-nums;font-size:2rem;font-weight:700;line-height:1.2}.kpi-card-detail{color:var(--text-secondary);font-size:.8125rem}.kpi-alert{color:var(--danger,#ef4444);font-weight:600}.kpi-sparkline{width:100%;height:60px}.kpi-sections{flex-direction:column;gap:20px;display:flex}.kpi-section{background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-md);padding:20px}.kpi-section-title{margin:0 0 12px;font-size:.9375rem;font-weight:600}.kpi-section-row{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;display:grid}.kpi-section-half{min-width:0}.kpi-table{border-collapse:collapse;width:100%;font-size:.8125rem}.kpi-table th{text-align:left;text-transform:uppercase;letter-spacing:.03em;color:var(--text-muted);border-bottom:1px solid var(--border);padding:6px 10px;font-size:.75rem}.kpi-table td{border-bottom:1px solid var(--border-light,var(--border));vertical-align:middle;padding:8px 10px}.kpi-rank{background:var(--bg-tertiary);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;margin-right:8px;font-size:.6875rem;font-weight:700;display:inline-flex}.kpi-bar-cell{align-items:center;gap:8px;display:flex}.kpi-bar{background:var(--accent,#3b82f6);border-radius:var(--radius-full);min-width:4px;max-width:100px;height:6px}.kpi-bar-cell span{color:var(--text-muted);white-space:nowrap;font-size:.75rem}.kpi-status-list{flex-direction:column;gap:6px;display:flex}.kpi-status-item{border-bottom:1px solid var(--border-light,var(--border));justify-content:space-between;align-items:center;padding:6px 0;font-size:.8125rem;display:flex}.kpi-status-item:last-child{border-bottom:none}@media (max-width:768px){.kpi-grid{grid-template-columns:1fr 1fr}.kpi-card-value{font-size:1.5rem}.kpi-section-row{grid-template-columns:1fr}}.sidebar-lang-switch{justify-content:center;gap:4px;padding:8px 12px 4px;display:flex}.bulk-bar{border-radius:var(--radius-md);background:#3b82f60f;border:1px solid #3b82f633;justify-content:space-between;align-items:center;margin-bottom:8px;padding:10px 16px;display:flex}.bulk-bar-count{color:var(--accent,#3b82f6);font-size:.875rem;font-weight:600}.bulk-checkbox-col{text-align:center;width:36px;padding:0 4px}.bulk-checkbox-col input[type=checkbox]{cursor:pointer;width:16px;height:16px;accent-color:var(--accent,#3b82f6)}.bulk-selected-row{background:#3b82f60a}.bulk-selected-row:hover{background:#3b82f614}.breadcrumbs{color:var(--text-muted);flex-wrap:wrap;align-items:center;gap:0;margin-bottom:8px;font-size:.8125rem;display:flex}.breadcrumb-segment{align-items:center;gap:0;display:inline-flex}.breadcrumb-link{font:inherit;color:var(--accent,#3b82f6);cursor:pointer;white-space:nowrap;background:0 0;border:none;padding:0;text-decoration:none}.breadcrumb-link:hover{text-decoration:underline}.breadcrumb-current{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;max-width:300px;font-weight:500;overflow:hidden}.breadcrumb-sep{color:var(--text-muted);opacity:.5;margin:0 6px}.editor-breadcrumb-wrap{padding:8px 24px 0}.fmea-summary-grid{flex-direction:column;gap:10px;display:flex}.fmea-summary-row{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.fmea-summary-label{color:var(--text-muted);flex-shrink:0;min-width:190px;font-size:.8125rem;font-weight:500}.fmea-summary-value{color:var(--text-primary);font-size:.8125rem;font-weight:600}.fmea-summary-missing{color:var(--text-muted);font-size:.8125rem;font-style:italic}.fmea-compliance-badge,.fmea-char-badge,.fmea-count-badge{border-radius:var(--radius-full);white-space:nowrap;align-items:center;padding:2px 8px;font-size:.75rem;font-weight:600;display:inline-flex}.fmea-badge-warn{color:var(--warning,#d97706);background:#f59e0b1a;border:1px solid #f59e0b4d}.fmea-badge-cc{color:var(--danger,#ef4444);background:#ef44441a;border:1px solid #ef44444d}.fmea-badge-sc{color:var(--warning,#d97706);background:#f59e0b1a;border:1px solid #f59e0b4d}.fmea-steps-row{align-items:center}.fmea-summary-counts{flex-wrap:wrap;gap:6px;display:flex}.module-toggle-label{cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:8px;display:flex}.module-toggle-input{display:none}.module-toggle-track{background:var(--border);border-radius:var(--radius-full);flex-shrink:0;width:40px;height:22px;transition:background .2s;display:inline-block;position:relative}.module-toggle-input:checked+.module-toggle-track{background:var(--accent,#3b82f6)}.module-toggle-thumb{background:#fff;border-radius:50%;width:16px;height:16px;transition:transform .2s;position:absolute;top:3px;left:3px;box-shadow:0 1px 3px #0003}.module-toggle-input:checked+.module-toggle-track .module-toggle-thumb{transform:translate(18px)}.module-config-row-enabled{background:#3b82f605}.module-management{flex-direction:column;gap:20px;max-width:960px;padding:24px;display:flex}.module-management-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.module-management-header h2{margin:0;font-size:1.5rem;font-weight:700}.module-management-subtitle{color:var(--text-muted);margin:4px 0 0;font-size:.875rem}.module-management-actions{align-items:center;gap:8px;display:flex}.module-management-loading{flex-direction:column;gap:12px;padding:20px 0;display:flex}.module-presets{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);padding:16px}.module-presets-info{color:var(--text-muted);margin:0 0 12px;font-size:.8125rem}.module-presets-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:10px;display:grid}.module-preset-card{background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-md);cursor:pointer;text-align:left;font:inherit;color:inherit;padding:14px 16px;transition:border-color .15s,background .15s}.module-preset-card:hover{border-color:var(--accent,#3b82f6);background:#3b82f60a}.module-preset-card-current{border-color:var(--accent,#3b82f6)}.module-preset-card-header{align-items:center;gap:8px;margin-bottom:6px;display:flex}.module-preset-card-title{font-size:.9375rem;font-weight:700}.module-preset-card-badge{color:var(--accent,#3b82f6);border-radius:var(--radius-full);background:#3b82f61a;padding:1px 6px;font-size:.6875rem;font-weight:600}.module-preset-card-desc{color:var(--text-muted);margin:0 0 8px;font-size:.78rem;line-height:1.4}.module-preset-card-count{color:var(--text-secondary);font-size:.75rem;font-weight:500}.module-warnings{flex-direction:column;gap:6px;display:flex}.module-warning{border-radius:var(--radius-md);color:var(--text-secondary);background:#f59e0b0f;border:1px solid #f59e0b40;padding:10px 14px;font-size:.8125rem}.module-warning strong{color:var(--text-primary)}.module-warning-action{color:var(--accent,#3b82f6);cursor:pointer;font:inherit;background:0 0;border:none;padding:0;font-weight:600;text-decoration:underline}.module-categories{flex-direction:column;gap:20px;display:flex}.module-category{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden}.module-category-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:14px 18px;display:flex}.module-category-title{text-transform:uppercase;letter-spacing:.04em;margin:0;font-size:.9375rem;font-weight:700}.module-category-desc{color:var(--text-muted);margin:2px 0 0;font-size:.78rem}.module-category-count{color:var(--text-muted);white-space:nowrap;font-size:.8125rem;font-weight:600}.module-category-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:0;display:grid}.module-card{cursor:pointer;border-bottom:1px solid var(--border);border-right:1px solid var(--border);align-items:flex-start;gap:12px;padding:14px 18px;transition:background .15s;display:flex}.module-card:hover{background:#3b82f608}.module-card-enabled{background:#22c55e0a}.module-card-enabled:hover{background:#22c55e12}.module-card-toggle{flex-shrink:0;padding-top:2px}.module-card-toggle input[type=checkbox]{cursor:pointer;width:18px;height:18px;accent-color:var(--success,#22c55e)}.module-card-content{min-width:0}.module-card-title{color:var(--text-primary);margin-bottom:2px;font-size:.875rem;font-weight:600}.module-card-desc{color:var(--text-muted);font-size:.75rem;line-height:1.4}.module-card-deps{color:var(--accent,#3b82f6);margin-top:4px;font-size:.6875rem;font-style:italic}.module-view{flex-direction:column;gap:16px;padding:24px;display:flex}.module-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;display:flex;overflow:hidden}.module-header>div:first-child{flex:1;min-width:0}.module-header h2{margin:0;font-size:1.5rem;font-weight:700}.control-plan-table-container{max-width:100%;position:relative;overflow-x:auto}.control-plan-table-container:after{content:"";pointer-events:none;opacity:1;background:linear-gradient(90deg,#0000,#0000000f);width:24px;transition:opacity .3s;position:absolute;top:0;bottom:0;right:0}.control-plan-items-table{min-width:1600px}.control-plan-items-table th{white-space:nowrap;padding:6px 4px;font-size:.6875rem}.control-plan-items-table td{vertical-align:middle;padding:4px}.control-plan-items-table th:first-child,.control-plan-items-table td:first-child{z-index:2;background:var(--bg-secondary);position:sticky;left:0}.control-plan-items-table td:first-child{background:var(--bg);border-right:1px solid var(--border)}.control-plan-items-table .input-sm{min-width:80px;padding:4px 6px;font-size:.8125rem}.control-plan-items-table select.input-sm{min-width:100px}@media (max-width:768px){.control-plan-items-table th{padding:4px 3px;font-size:.625rem}.control-plan-items-table td{padding:3px}.control-plan-items-table .input-sm{min-width:60px;padding:3px 4px;font-size:.75rem}.control-plan-items-table select.input-sm{min-width:80px}}@media (min-width:1600px){.control-plan-table-container:after{display:none}}.flex-row{align-items:center;display:flex}.text-sm{font-size:.8125rem}.skeleton-list{flex-direction:column;gap:12px;padding:20px 0;display:flex}.form-row{grid-template-columns:1fr 1fr;gap:12px;display:grid}.btn-success{background:var(--success,#22c55e);color:#fff;border:none}.btn-success:hover{opacity:.9}
.kiosk-layout{background:var(--bg-primary);min-height:100vh}.kiosk-page{flex-direction:column;max-width:600px;min-height:100vh;margin:0 auto;padding:16px;display:flex}.kiosk-loading{color:var(--text-secondary);flex:1;justify-content:center;align-items:center;font-size:1.25rem;display:flex}.kiosk-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px;padding-bottom:12px;display:flex}.kiosk-header-title{text-align:center;flex:1;min-width:0}.kiosk-header-title h2{white-space:nowrap;text-overflow:ellipsis;font-size:1rem;overflow:hidden}.kiosk-progress{align-items:center;gap:12px;margin-bottom:16px;display:flex}.kiosk-progress-bar{background:var(--bg-tertiary);border-radius:var(--radius-full);flex:1;height:8px;overflow:hidden}.kiosk-progress-fill{background:var(--success);border-radius:var(--radius-full);height:100%;transition:width .3s}.kiosk-progress-text{color:var(--text-secondary);white-space:nowrap;font-size:.875rem;font-weight:600}.kiosk-nav{justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px;display:flex}.kiosk-nav-btn{min-width:120px;padding:12px 16px;font-size:1rem}.kiosk-nav-indicator{color:var(--text-secondary);font-size:1rem;font-weight:600}.kiosk-step{border:2px solid var(--border);border-radius:var(--radius-lg);background:var(--bg-secondary);flex-direction:column;flex:1;gap:16px;padding:20px;display:flex}.kiosk-step-confirmed{border-color:var(--success);background:var(--success-bg)}.kiosk-step-header{align-items:baseline;gap:12px;display:flex}.kiosk-step-number{text-transform:uppercase;color:var(--text-muted);font-size:.8rem;font-weight:700}.kiosk-step-name{font-size:1.25rem;font-weight:600}.kiosk-step-image{border-radius:var(--radius-md);overflow:hidden}.kiosk-step-image img{width:100%;height:auto;display:block}.kiosk-image-nav{justify-content:space-between;align-items:center;gap:12px;margin-bottom:8px;padding:8px 0;display:flex}.kiosk-image-nav-indicator{color:var(--text-muted);font-size:.9rem;font-weight:500}.kiosk-step-description{color:var(--text-primary);white-space:pre-wrap;font-size:1.1rem;line-height:1.6}.kiosk-confirm-btn{border-radius:var(--radius-lg);cursor:pointer;width:100%;min-height:60px;transition:all var(--transition-fast);background:var(--accent);color:#fff;text-transform:uppercase;letter-spacing:.05em;border:none;justify-content:center;align-items:center;padding:16px;font-size:1.25rem;font-weight:700;display:flex}.kiosk-confirm-btn:hover{background:var(--accent-hover);box-shadow:var(--shadow-glow)}.kiosk-confirm-btn:disabled{opacity:.5;pointer-events:none}.kiosk-confirm-btn-done{background:var(--success)}.kiosk-confirm-btn-done:hover{box-shadow:none;background:#16a34a}.kiosk-complete{text-align:center;border:2px solid var(--success);border-radius:var(--radius-lg);background:var(--success-bg);flex-direction:column;align-items:center;gap:16px;margin-top:16px;padding:32px;display:flex}.kiosk-complete h3{color:var(--success);font-size:1.25rem}@media (max-width:480px){.kiosk-page{padding:8px}.kiosk-step{padding:12px}.kiosk-step-name{font-size:1.1rem}.kiosk-step-description{font-size:1rem}.kiosk-confirm-btn{min-height:56px;font-size:1.1rem}.kiosk-nav-btn{min-width:80px;padding:10px 12px;font-size:.875rem}}
.drawing-revision-badge{border-radius:var(--radius-sm);background:var(--bg-tertiary);border:1px solid var(--border);min-width:28px;height:24px;color:var(--text-primary);justify-content:center;align-items:center;padding:0 8px;font-size:.8125rem;font-weight:600;display:inline-flex}.drawing-canvas-container{flex-direction:column;gap:12px;display:flex;position:relative}.drawing-canvas{aspect-ratio:4/3;border-radius:var(--radius-md);border:1px solid var(--border);background:var(--bg-secondary);-webkit-user-select:none;user-select:none;width:100%;position:relative;overflow:hidden}.drawing-canvas-image{object-fit:contain;pointer-events:none}.drawing-canvas-placement-hint{color:var(--accent,#3b82f6);background:var(--bg-tertiary,#f0f4ff);border:1px dashed var(--accent,#3b82f6);border-radius:var(--radius-md);text-align:center;padding:6px 12px;font-size:.8rem}.drawing-marker{background:var(--bg-primary);z-index:2;border:2px solid;border-radius:50%;justify-content:center;align-items:center;transition:transform .15s,box-shadow .15s;display:flex;position:absolute;transform:translate(-50%,-50%);box-shadow:0 1px 4px #0003}.drawing-marker:hover,.drawing-marker-hovered{z-index:3;transform:translate(-50%,-50%)scale(1.15);box-shadow:0 2px 8px #0000004d}.drawing-marker-selected{z-index:4;transform:translate(-50%,-50%)scale(1.2);box-shadow:0 0 0 3px #3b82f64d,0 2px 8px #0000004d}.drawing-marker-editable{cursor:grab!important}.drawing-marker-editable:active{cursor:grabbing!important}.drawing-marker-label{pointer-events:none;font-size:.75rem;font-weight:700;line-height:1}.drawing-canvas-placeholder{height:100%;color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;gap:8px;display:flex}.drawing-canvas-placeholder-icon{font-size:2.5rem}.drawing-canvas-placeholder p{text-align:center;margin:0}.drawing-canvas-controls{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-sm);align-self:flex-start;align-items:center;gap:4px;padding:4px 8px;display:flex}.drawing-zoom-label{font-variant-numeric:tabular-nums;text-align:center;min-width:40px;color:var(--text-muted);font-size:.8rem}.drawing-zoom-hint{color:var(--text-muted);opacity:.7;margin-left:8px;font-size:.7rem}.drawing-canvas-legend{border-radius:var(--radius-sm);background:var(--bg-secondary);border:1px solid var(--border);color:var(--text-secondary);align-items:center;gap:16px;padding:8px 12px;font-size:.8125rem;display:flex}.drawing-legend-item{align-items:center;gap:6px;display:flex}.drawing-legend-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.drawing-dimension-tooltip{background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--shadow-lg);white-space:nowrap;z-index:10;pointer-events:none;flex-direction:column;gap:2px;margin-bottom:8px;padding:8px 12px;font-size:.8125rem;display:flex;position:absolute;bottom:100%;left:50%;transform:translate(-50%)}.dim-table-container{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-primary);flex-direction:column;gap:0;display:flex;overflow:hidden}.dim-table-header{border-bottom:1px solid var(--border);background:var(--bg-secondary);justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.dim-table-title{margin:0;font-size:.9375rem;font-weight:600}.dim-table-summary{gap:8px;margin-top:4px;display:flex}.dim-summary-badge{border-radius:var(--radius-sm);padding:1px 6px;font-size:.75rem;font-weight:600}.dim-summary-badge.dim-characteristic-critical{color:var(--danger,#ef4444);background:#ef44441a}.dim-summary-badge.dim-characteristic-significant{color:var(--warning,#f59e0b);background:#f59e0b1a}.dim-empty{text-align:center;color:var(--text-muted);padding:32px 16px}.dim-empty p{margin:0 0 4px}.dim-table-wrapper{overflow-x:auto}.dim-table{border-collapse:collapse;width:100%;font-size:.8125rem}.dim-table thead th{text-align:left;text-transform:uppercase;letter-spacing:.03em;color:var(--text-secondary);background:var(--bg-secondary);border-bottom:1px solid var(--border);white-space:nowrap;-webkit-user-select:none;user-select:none;padding:8px 10px;font-size:.75rem;font-weight:600}.dim-th-number{text-align:center;width:48px}.dim-th-name{min-width:120px}.dim-th-nominal{width:90px}.dim-th-tolerance{width:80px}.dim-th-unit{width:60px}.dim-th-characteristic{width:130px}.dim-th-method{width:140px}.dim-th-gdt{width:130px}.dim-th-actions{width:40px}.dim-row{cursor:pointer;transition:background .1s}.dim-row:hover{background:var(--bg-hover)}.dim-row-selected{background:#3b82f614}.dim-row-selected:hover{background:#3b82f61f}.dim-row td{border-bottom:1px solid var(--border);vertical-align:middle;padding:6px 10px}.dim-characteristic-critical{border-left:3px solid var(--danger,#ef4444)}.dim-characteristic-significant{border-left:3px solid var(--warning,#f59e0b)}.dim-cell-number{text-align:center}.dim-number-badge{background:var(--bg-tertiary);border:1px solid var(--border);min-width:24px;height:24px;color:var(--text-primary);border-radius:50%;justify-content:center;align-items:center;padding:0 4px;font-size:.75rem;font-weight:700;display:inline-flex}.dim-input{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-primary);width:100%;color:var(--text-primary);font-size:.8125rem;font-family:var(--font-sans);padding:4px 8px;transition:border-color .15s}.dim-input:focus{border-color:var(--accent);outline:none;box-shadow:0 0 0 2px #3b82f626}.dim-input-name{min-width:100px}.dim-input-number{width:80px}.dim-input-tolerance{width:70px}.dim-input-unit{width:50px}.dim-select{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-primary);width:100%;color:var(--text-primary);font-size:.8125rem;font-family:var(--font-sans);cursor:pointer;padding:4px 6px}.dim-select:focus{border-color:var(--accent);outline:none}.dim-select-gdt{min-width:110px}.dim-tolerance-value{font-family:var(--font-mono,monospace);font-size:.8125rem}.dim-characteristic-badge{border-radius:var(--radius-sm);padding:2px 8px;font-size:.75rem;font-weight:600;display:inline-block}.dim-characteristic-badge.dim-characteristic-critical{color:var(--danger,#ef4444);background:#ef44441a;border-left:none}.dim-characteristic-badge.dim-characteristic-significant{color:var(--warning,#f59e0b);background:#f59e0b1a;border-left:none}.dim-delete-btn{color:var(--text-muted);padding:4px 8px;font-size:1.125rem;line-height:1}.dim-delete-btn:hover{color:var(--danger,#ef4444)}.drawing-new-page{flex-direction:column;gap:16px;max-width:1600px;margin:0 auto;padding:16px 20px;display:flex}.drawing-new-header{justify-content:space-between;align-items:center;display:flex}.drawing-new-header h1{margin:0;font-size:1.5rem;font-weight:700}.drawing-new-actions{gap:8px;display:flex}.drawing-new-tabs{flex:none;width:fit-content;margin:0 auto}.drawing-new-tabs .tab{flex:none;min-width:110px;padding:8px 20px}.drawing-new-form-wrap{justify-content:center;padding-top:24px;display:flex}.drawing-new-form-col{flex-direction:column;gap:16px;width:100%;max-width:800px;display:flex}.drawing-new-section-title{margin:0 0 12px;font-size:1rem;font-weight:600}.drawing-new-form-grid{grid-template-columns:1fr 1fr 120px;gap:16px;margin-bottom:16px;display:grid}.drawing-new-description{resize:vertical;min-height:80px}.drawing-new-upload-area{align-items:center;gap:12px;display:flex}.drawing-new-upload-btn{cursor:pointer}.drawing-new-upload-status{color:var(--success,#22c55e);font-size:.8125rem;font-weight:500}.drawing-canvas-dim-layout{grid-template-columns:1fr 1fr;align-items:start;gap:12px;display:grid}.drawing-canvas-dim-toolbar{grid-column:1/-1;align-items:center;gap:10px;display:flex}.drawing-canvas-dim-col{flex-direction:column;display:flex}@media (max-width:1024px){.drawing-canvas-dim-layout{grid-template-columns:1fr}.drawing-new-form-grid{grid-template-columns:1fr 1fr}}@media (max-width:640px){.drawing-new-form-grid{grid-template-columns:1fr}.drawing-new-page{padding:12px}}.drawing-editor-meta{flex-wrap:wrap;align-items:center;gap:12px;margin-top:4px;display:flex}.drawing-editor-info{border-top:1px solid var(--border);flex-direction:column;gap:8px;margin-top:20px;padding-top:16px;display:flex}.drawing-editor-info-row{align-items:center;gap:8px;display:flex}.revision-history{padding:24px}.revision-history-title{margin-bottom:16px}.revision-timeline{flex-direction:column;gap:12px;display:flex}.revision-item{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-primary);padding:16px}.revision-item-header{justify-content:space-between;align-items:center;margin-bottom:4px;display:flex}.revision-item-meta{margin-bottom:4px}.revision-item-description{color:var(--text-secondary);margin-top:8px;font-size:.875rem}
.spc-dashboard{flex-direction:column;gap:24px;display:flex}.spc-controls{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;flex-wrap:wrap;align-items:flex-end;gap:16px;padding:16px;display:flex}.spc-controls .form-group{flex-direction:column;gap:4px;min-width:130px;display:flex}.spc-controls label{color:var(--text-muted);font-size:.8125rem;font-weight:500}.spc-capabilities{flex-wrap:wrap;gap:12px;display:flex}.capability-card{text-align:center;border:1px solid;border-radius:8px;flex:1;min-width:120px;padding:16px}.capability-card-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:4px;font-size:.75rem;font-weight:600}.capability-card-value{margin-bottom:4px;font-size:1.75rem;font-weight:700;line-height:1}.capability-card-status{font-size:.75rem;font-weight:500}.capability-card-info{background:var(--bg-secondary);border-color:var(--border-color)}.capability-card-info .capability-card-value{color:var(--text-primary);font-size:1.25rem}.spc-charts{flex-direction:column;gap:16px;display:flex}.spc-chart-container{border:1px solid var(--border-color);background:var(--bg-primary);border-radius:8px;padding:16px}.spc-chart-title{color:var(--text-secondary);margin-bottom:12px;font-size:.875rem;font-weight:600}.spc-chart-svg{width:100%;height:auto;display:block;overflow:visible}.spc-histogram-section{border:1px solid var(--border-color);background:var(--bg-primary);border-radius:8px;padding:16px}.spc-violations{background:var(--warning-bg);border:1px solid var(--warning);color:var(--text-primary);border-radius:8px;padding:16px}.spc-violations-title{color:var(--warning);margin-bottom:8px;font-size:.875rem;font-weight:600}.spc-violations-list{flex-direction:column;gap:4px;margin:0;padding-left:20px;display:flex}.spc-violations-list li{color:var(--text-secondary);font-size:.8125rem}.spc-no-data{text-align:center;color:var(--text-muted);background:var(--bg-secondary);border:1px dashed var(--border-color);border-radius:8px;padding:40px 24px;font-size:.875rem}.spc-loading{text-align:center;color:var(--text-muted);padding:40px;font-size:.875rem}.spc-mode-toggle{gap:8px;display:flex}.spc-mode-toggle .btn{font-size:.8125rem}.inspection-defect-count{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;margin-bottom:16px;padding:16px}.inspection-defect-count .input{max-width:200px}.inspection-equipment-section{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;flex-direction:column;gap:10px;margin-bottom:16px;padding:16px;display:flex}.inspection-equipment-section .input{max-width:400px}.inspection-equipment-info{align-items:center;gap:8px;font-size:.875rem;display:flex}.inspection-equipment-warning{border-radius:6px;align-items:center;gap:8px;padding:10px 14px;font-size:.825rem;line-height:1.4;display:flex}.inspection-equipment-overdue{color:var(--danger);background:#ef44441a;border:1px solid #ef44444d}.inspection-equipment-expiring{color:var(--warning,#f59e0b);background:#f59e0b1a;border:1px solid #f59e0b4d}@media (max-width:768px){.spc-controls{gap:12px}.spc-capabilities{gap:8px}.capability-card{min-width:90px;padding:12px 8px}.capability-card-value{font-size:1.375rem}.capability-card-info .capability-card-value{font-size:1rem}}.inspection-page{max-width:1200px;margin:0 auto;padding:24px}.inspection-page-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:24px;display:flex}.inspection-page-header h1{margin:0;font-size:1.25rem}.inspection-page-actions{flex-wrap:wrap;gap:8px;display:flex}.inspection-meta{flex-wrap:wrap;align-items:center;gap:12px;margin-top:4px;display:flex}.inspection-summary{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-primary);flex-wrap:wrap;gap:24px;margin-bottom:24px;padding:20px;display:flex}.inspection-summary-stat{flex-direction:column;align-items:center;min-width:80px;display:flex}.inspection-summary-stat-value{font-size:1.5rem;font-weight:700}.inspection-summary-stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:.75rem}.inspection-summary-stat-pass .inspection-summary-stat-value{color:var(--success,#22c55e)}.inspection-summary-stat-fail .inspection-summary-stat-value{color:var(--danger,#ef4444)}.measurement-table-wrapper{border:1px solid var(--border);border-radius:var(--radius-md);max-width:100%;overflow-x:auto}.measurement-table{border-collapse:separate;border-spacing:0;width:100%;font-size:.875rem}.measurement-table th{text-align:left;background:var(--bg-secondary);border-bottom:2px solid var(--border);white-space:nowrap;padding:10px 12px;font-size:.8rem;font-weight:600}.measurement-table td{border-bottom:1px solid var(--border);vertical-align:middle;padding:8px 12px}.measurement-table th:first-child,.measurement-table td:first-child{z-index:2;background:var(--bg-secondary);position:sticky;left:0}.measurement-table td:first-child{background:var(--bg)}.measurement-table th:nth-child(2),.measurement-table td:nth-child(2){z-index:2;background:var(--bg-secondary);border-right:2px solid var(--border);position:sticky;left:60px}.measurement-table td:nth-child(2){background:var(--bg);border-right:2px solid var(--border)}.measurement-table tbody tr:hover td:first-child,.measurement-table tbody tr:hover td:nth-child(2),.measurement-table tbody tr:hover{background:var(--bg-secondary)}.measurement-row-critical{background:#ef44440a}.measurement-row-significant{background:#f59e0b0a}.measurement-input{border:2px solid var(--border);border-radius:var(--radius-sm);text-align:center;width:90px;padding:6px 8px;font-size:.875rem;transition:border-color .15s,box-shadow .15s}.measurement-input:focus{border-color:var(--accent,#3b82f6);outline:none;box-shadow:0 0 0 3px #3b82f626}.measurement-input-pass{border-color:var(--success,#22c55e);background:#22c55e0f}.measurement-input-pass:focus{border-color:var(--success,#22c55e);box-shadow:0 0 0 3px #22c55e26}.measurement-input-fail{border-color:var(--danger,#ef4444);background:#ef44440f}.measurement-input-fail:focus{border-color:var(--danger,#ef4444);box-shadow:0 0 0 3px #ef444426}.measurement-deviation{font-size:.75rem;font-weight:500}.measurement-deviation-pass{color:var(--success,#22c55e)}.measurement-deviation-fail{color:var(--danger,#ef4444)}.measurement-characteristic-badge{border-radius:4px;padding:2px 6px;font-size:.7rem;font-weight:600;display:inline-block}.measurement-characteristic-critical{color:#dc2626;background:#ef44441f}.measurement-characteristic-significant{color:#d97706;background:#f59e0b1f}.inspection-dashboard{padding:24px}.inspection-dashboard-section{margin-bottom:32px}.inspection-dashboard-section h2{margin-bottom:16px;font-size:1.1rem}.failed-dimensions{margin-top:12px}.failed-dimension-item{align-items:center;gap:8px;padding:4px 0;font-size:.85rem;display:flex}.failed-dimension-item .dim-number-badge{background:var(--danger,#ef4444);color:#fff}@media (max-width:768px){.inspection-page{padding:12px}.inspection-summary{gap:16px;padding:16px}.measurement-input{width:70px;padding:10px 8px;font-size:1rem}.measurement-table th,.measurement-table td{padding:8px}.inspection-page-header{flex-direction:column}}
.fmea-worksheet-wrapper{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--surface);overflow-x:auto}.fmea-worksheet{border-collapse:collapse;width:100%;min-width:1400px;font-size:.8rem}.fmea-worksheet thead{background:var(--surface-elevated,var(--bg-secondary,#f5f5f5));z-index:2;position:sticky;top:0}.fmea-worksheet th{text-align:center;border-bottom:2px solid var(--border);white-space:nowrap;text-transform:uppercase;letter-spacing:.02em;padding:8px 6px;font-size:.75rem;font-weight:600}.fmea-worksheet td{border-bottom:1px solid var(--border);vertical-align:top;padding:4px}.fmea-worksheet tbody tr:hover{background:var(--surface-hover,#00000005)}.fmea-col-num{width:36px}.fmea-col-step,.fmea-col-fn{width:100px}.fmea-col-mode{width:130px}.fmea-col-effect,.fmea-col-cause{width:120px}.fmea-col-ctrl{width:110px}.fmea-col-rating{width:40px}.fmea-col-rpn{width:50px}.fmea-col-cls{width:42px}.fmea-col-actions{width:130px}.fmea-col-resp{width:90px}.fmea-col-date{width:100px}.fmea-col-act{width:80px}.fmea-input{border-radius:var(--radius-sm,4px);width:100%;min-width:60px;color:var(--text);resize:vertical;background:0 0;border:1px solid #0000;padding:4px 6px;font-family:inherit;font-size:.8rem;transition:border-color .15s}.fmea-input:hover:not(:disabled){border-color:var(--border)}.fmea-input:focus{border-color:var(--accent);background:var(--surface);outline:none}.fmea-input:disabled{opacity:.7;cursor:default}.fmea-input-required:invalid,.fmea-input-required:placeholder-shown{border-color:var(--border)}.fmea-select{border-radius:var(--radius-sm,4px);width:100%;color:var(--text);cursor:pointer;text-align:center;background:0 0;border:1px solid #0000;padding:4px 2px;font-family:inherit;font-size:.8rem}.fmea-select:hover:not(:disabled){border-color:var(--border)}.fmea-select:focus{border-color:var(--accent);outline:none}.fmea-select:disabled{opacity:.7;cursor:default}.fmea-select option{color:#000;background:#fff}.fmea-cell-num{text-align:center;color:var(--text-muted);font-weight:600}.fmea-cell-rpn{text-align:center;font-size:.85rem}.fmea-cell-cls{text-align:center}.fmea-cell-actions{justify-content:center;gap:2px;padding-top:6px;display:flex}.fmea-cls-cc{background:var(--error);color:#fff;border-radius:3px;padding:1px 5px;font-size:.7rem;font-weight:700;display:inline-block}.fmea-cls-sc{background:var(--warning,#e67e22);color:#fff;border-radius:3px;padding:1px 5px;font-size:.7rem;font-weight:700;display:inline-block}.fmea-row-high-rpn{background:#e74c3c0a}.fmea-row-high-rpn:hover{background:#e74c3c14!important}.fmea-summary-badge{background:var(--surface-elevated,var(--bg-secondary,#f5f5f5));border:1px solid var(--border);border-radius:var(--radius-md);align-items:center;padding:4px 10px;font-size:.8rem;font-weight:500;display:inline-flex}.fmea-ap-badge{text-align:center;white-space:nowrap;letter-spacing:.03em;border-radius:3px;padding:2px 6px;font-size:.7rem;font-weight:700;display:inline-block}.fmea-ap-high{color:var(--error,#ef4444);background:#ef44441f;border:1px solid #ef44444d}.fmea-ap-medium{color:var(--warning,#d97706);background:#f59e0b1f;border:1px solid #f59e0b4d}.fmea-ap-low{color:var(--success,#22c55e);background:#22c55e1a;border:1px solid #22c55e4d}.fmea-worksheet-wrapper{position:relative}.fmea-worksheet-wrapper:after{content:"";pointer-events:none;border-radius:0 var(--radius-md)var(--radius-md)0;opacity:1;background:linear-gradient(90deg,#0000,#0000000f);width:24px;transition:opacity .3s;position:absolute;top:0;bottom:0;right:0}.fmea-worksheet th:first-child,.fmea-worksheet td:first-child{z-index:3;background:var(--surface-elevated,var(--bg-secondary,#f5f5f5));position:sticky;left:0}.fmea-worksheet td:first-child{background:var(--surface,var(--bg,#fff));border-right:1px solid var(--border)}.fmea-worksheet tbody tr:hover td:first-child{background:var(--surface-hover,#00000005)}@media (max-width:768px){.fmea-worksheet{font-size:.75rem}.fmea-worksheet th{padding:6px 4px;font-size:.65rem}.fmea-worksheet td{padding:3px}.fmea-input{min-width:50px;padding:3px 4px;font-size:.75rem}.fmea-select{padding:3px 2px;font-size:.75rem}}@media (min-width:1400px){.fmea-worksheet-wrapper:after{display:none}}
.supplier-detail-header{margin-bottom:24px}.supplier-detail-header h2{margin:0;font-size:1.5rem}.supplier-info-grid{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px;margin-bottom:24px;padding:16px;font-size:.9rem;display:grid}.supplier-section{margin-bottom:24px}.supplier-section h3{margin:0 0 12px;font-size:1.1rem}.supplier-scores{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px;display:grid}.score-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);text-align:center;padding:16px}.score-label{color:var(--text-muted);margin-bottom:4px;font-size:.8rem}.score-value{font-size:1.5rem;font-weight:700}.supplier-form{max-width:800px}.form-grid{grid-template-columns:1fr 1fr;gap:12px;display:grid}@media (max-width:600px){.form-grid{grid-template-columns:1fr}.supplier-scores{grid-template-columns:repeat(2,1fr)}}.status-badge{white-space:nowrap;border-radius:10px;padding:2px 8px;font-size:.75rem;font-weight:600;display:inline-block}.status-active{background:color-mix(in srgb,var(--success)15%,transparent);color:var(--success)}.status-inactive{background:color-mix(in srgb,var(--text-muted)15%,transparent);color:var(--text-muted)}.status-blocked{background:color-mix(in srgb,var(--error)15%,transparent);color:var(--error)}.status-review{background:color-mix(in srgb,var(--warning)15%,transparent);color:var(--warning)}.clickable-row{cursor:pointer}.clickable-row:hover{background:var(--surface-hover)}.sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.sortable:hover{color:var(--accent)}
.defect-map-view{flex-direction:column;gap:20px;padding:24px;display:flex}.defect-map-view h2{margin:0;font-size:1.3rem;font-weight:600}.defect-map-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;display:flex}.defect-map-tabs{border-bottom:2px solid var(--border);gap:4px;margin-bottom:4px;display:flex}.defect-map-tab{cursor:pointer;color:var(--text-muted);background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-2px;padding:8px 16px;font-size:.85rem;transition:color .15s,border-color .15s}.defect-map-tab:hover{color:var(--text)}.defect-map-tab.active{color:var(--primary);border-bottom-color:var(--primary);font-weight:600}.defect-map-canvas-wrapper{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--surface);justify-content:center;align-items:center;min-height:300px;display:flex;position:relative;overflow:hidden}.defect-map-canvas{cursor:crosshair;max-width:100%;display:block}.defect-map-canvas.readonly{cursor:default}.defect-map-no-drawing{text-align:center;width:100%;min-height:400px;color:var(--text-muted);background:var(--bg-secondary,#f5f5f5);flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:32px;display:flex}.defect-map-no-drawing h4{color:var(--text-primary);margin:0;font-size:1rem;font-weight:600}.defect-map-no-drawing p{max-width:400px;margin:0;font-size:.85rem;line-height:1.5}.defect-map-pin{cursor:pointer;z-index:2;border:2px solid #fff;border-radius:50%;width:16px;height:16px;transition:transform .1s;position:absolute;transform:translate(-50%,-50%);box-shadow:0 1px 4px #0000004d}.defect-map-pin:hover{z-index:3;transform:translate(-50%,-50%)scale(1.3)}.defect-map-pin.selected{box-shadow:0 0 0 3px var(--primary),0 1px 4px #0000004d}.defect-map-pin-popover{z-index:10;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg,0 4px 12px #00000026);min-width:200px;max-width:300px;padding:12px;font-size:.82rem;position:absolute}.defect-map-pin-popover h4{margin:0 0 6px;font-size:.85rem}.defect-map-pin-popover .pin-actions{gap:6px;margin-top:8px;display:flex}.defect-map-toolbar{background:var(--surface-elevated,var(--bg-secondary,#f8f8f8));border:1px solid var(--border);border-radius:var(--radius-md);flex-wrap:wrap;align-items:center;gap:8px;padding:8px 12px;display:flex}.defect-map-toolbar label{color:var(--text-muted);font-size:.8rem;font-weight:500}.defect-map-toolbar select{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-tertiary);color:var(--text-primary);padding:4px 8px;font-size:.82rem}.defect-map-toolbar .pin-count{color:var(--text-muted);margin-left:auto;font-size:.8rem}.defect-map-session-list{flex-direction:column;gap:8px;display:flex}.defect-map-session-card{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--surface);cursor:pointer;align-items:center;gap:12px;padding:12px 16px;transition:border-color .15s,background .15s;display:flex}.defect-map-session-card:hover{border-color:var(--primary);background:var(--surface-hover,#00000003)}.defect-map-session-card.active{border-color:var(--primary);background:var(--primary-bg,#3b82f60f)}.defect-map-session-card .session-info{flex:1;min-width:0}.defect-map-session-card .session-info h4{margin:0 0 2px;font-size:.85rem;font-weight:600}.defect-map-session-card .session-meta{color:var(--text-muted);flex-wrap:wrap;gap:12px;font-size:.75rem;display:flex}.defect-map-session-card .session-defect-count{white-space:nowrap;font-size:.9rem;font-weight:600}.defect-map-heatmap{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--surface);position:relative;overflow:hidden}.defect-map-heatmap-legend{border-top:1px solid var(--border);flex-wrap:wrap;align-items:center;gap:12px;padding:8px 12px;font-size:.78rem;display:flex}.defect-map-heatmap-legend .legend-item{align-items:center;gap:4px;display:flex}.defect-map-heatmap-legend .legend-dot{border-radius:50%;width:10px;height:10px;display:inline-block}.defect-map-stats{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;display:grid}.defect-map-stats .stat-card{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--surface);padding:16px}.defect-map-stats .stat-card h4{color:var(--text-muted);text-transform:uppercase;letter-spacing:.03em;margin:0 0 12px;font-size:.85rem;font-weight:600}.defect-map-stats .stat-big{margin-bottom:4px;font-size:1.8rem;font-weight:700;line-height:1}.defect-map-stats .stat-label{color:var(--text-muted);font-size:.78rem}.defect-map-pareto{flex-direction:column;gap:6px;display:flex}.defect-map-pareto .pareto-row{align-items:center;gap:8px;font-size:.82rem;display:flex}.defect-map-pareto .pareto-bar-bg{background:var(--bg-secondary,#eee);border-radius:4px;flex:1;height:8px;overflow:hidden}.defect-map-pareto .pareto-bar{border-radius:4px;height:100%;transition:width .3s}.defect-map-pareto .pareto-label{white-space:nowrap;text-overflow:ellipsis;min-width:100px;overflow:hidden}.defect-map-pareto .pareto-count{text-align:right;min-width:40px;font-weight:600}.defect-map-trend{flex-direction:column;gap:4px;display:flex}.defect-map-filters{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.defect-map-filters select,.defect-map-filters input{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-tertiary);color:var(--text-primary);padding:4px 8px;font-size:.82rem}.defect-category-manager{flex-direction:column;gap:12px;display:flex}.defect-category-item{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);align-items:center;gap:10px;padding:8px 12px;display:flex}.defect-category-item.inactive{opacity:.5}.defect-category-badge{color:#fff;border-radius:12px;align-items:center;gap:6px;padding:2px 10px;font-size:.78rem;font-weight:500;display:inline-flex}.defect-severity-critical{background:#dc2626}.defect-severity-major{background:#f97316}.defect-severity-minor{color:#333;background:#eab308}.defect-severity-cosmetic{background:#6b7280}.defect-map-status{text-transform:uppercase;letter-spacing:.03em;border-radius:10px;align-items:center;padding:2px 8px;font-size:.72rem;font-weight:600;display:inline-flex}.defect-map-status.in-progress{color:#1d4ed8;background:#dbeafe}.defect-map-status.completed{color:#047857;background:#d1fae5}.defect-map-status.reviewed{color:#6d28d9;background:#ede9fe}.defect-map-form{flex-direction:column;gap:12px;display:flex}.defect-map-form .form-row{grid-template-columns:1fr 1fr;gap:12px;display:grid}.defect-map-form .form-group{flex-direction:column;gap:4px;display:flex}.defect-map-form .form-group label{color:var(--text-muted);font-size:.8rem;font-weight:500}.defect-map-form .form-group input,.defect-map-form .form-group select,.defect-map-form .form-group textarea{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-tertiary);color:var(--text-primary);padding:6px 10px;font-size:.85rem}.defect-map-summary{background:var(--surface-elevated,var(--bg-secondary,#f8f8f8));border:1px solid var(--border);border-radius:var(--radius-sm);flex-wrap:wrap;align-items:center;gap:16px;padding:8px 12px;font-size:.82rem;display:flex}.defect-map-summary .summary-item{align-items:center;gap:4px;display:flex}.defect-map-summary .summary-dot{border-radius:50%;width:8px;height:8px;display:inline-block}.defect-map-warning{border-radius:var(--radius-sm);color:#92400e;background:#fffbeb;border:1px solid #f59e0b;align-items:flex-start;gap:8px;padding:10px 14px;font-size:.82rem;line-height:1.45;display:flex}.defect-map-warning .warning-icon{flex-shrink:0;font-size:1rem;line-height:1}.defect-map-context-header{background:var(--surface-elevated,var(--bg-secondary,#f8f8f8));border:1px solid var(--border);border-radius:var(--radius-sm);flex-wrap:wrap;align-items:center;gap:12px;padding:10px 14px;font-size:.85rem;display:flex}.defect-map-context-header .context-label{color:var(--text-primary);font-weight:600}.defect-map-context-header .context-value{color:var(--text-muted)}.defect-map-context-header .context-separator{color:var(--border)}.defect-map-session-detail-header{flex-direction:column;gap:4px;display:flex}.defect-map-session-detail-header .session-detail-meta{color:var(--text-muted);flex-wrap:wrap;gap:12px;font-size:.8rem;display:flex}
.database-config-view{max-width:720px}.database-config-view h2{margin-bottom:.25rem}.database-config-view .section-description{color:var(--text-secondary);margin-bottom:1.5rem;font-size:.9rem}.database-status-cards{flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem;display:flex}.status-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:8px;flex-direction:column;gap:.25rem;min-width:140px;padding:.75rem 1rem;display:flex}.status-card .status-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.75rem}.status-card .status-badge{font-size:.9rem;font-weight:600}.status-card .status-value{font-size:.85rem}.database-config-view .error-banner{background:var(--danger-bg);color:var(--danger);border:1px solid var(--danger);border-radius:8px;margin-bottom:1.5rem;padding:.75rem 1rem;font-size:.9rem}.database-form{flex-direction:column;gap:1rem;margin-bottom:1.5rem;display:flex}.database-form .form-row{gap:1rem;display:flex}.database-form .form-group{flex-direction:column;gap:.25rem;display:flex}.database-form label{color:var(--text-secondary);font-size:.85rem;font-weight:500}.database-form input,.database-form select{border:1px solid var(--border);background:var(--bg-tertiary);color:var(--text-primary);border-radius:6px;padding:.5rem .75rem;font-size:.9rem}.database-form input:focus,.database-form select:focus{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-light);outline:none}.database-actions{flex-wrap:wrap;gap:.75rem;margin-bottom:1.5rem;display:flex}.test-result{border-radius:8px;flex-direction:column;gap:.25rem;margin-bottom:1.5rem;padding:1rem;font-size:.9rem;display:flex}.test-result.success{background:var(--success-bg);border:1px solid var(--success);color:var(--success)}.test-result.error{background:var(--danger-bg);border:1px solid var(--danger);color:var(--danger)}.ready-banner{background:var(--success-bg);color:var(--success);border:1px solid var(--success);border-radius:8px;margin-bottom:1.5rem;padding:1rem;font-weight:500}.database-help{background:var(--bg-secondary);border:1px solid var(--border);border-radius:8px;padding:1rem 1.5rem}.database-help h3{margin:0 0 .5rem;font-size:.95rem}.database-help ul{color:var(--text-secondary);margin:0;padding-left:1.25rem;font-size:.85rem}.database-help li{margin-bottom:.25rem}.guide-section{margin-top:1.25rem}.guide-section>h3{margin:0 0 .25rem;font-size:.95rem}.guide-intro{color:var(--text-secondary);margin:0 0 .75rem;font-size:.85rem}.guide-toggle{background:var(--bg-tertiary);border:1px solid var(--border);cursor:pointer;text-align:left;width:100%;color:var(--text-primary);border-radius:6px;align-items:center;gap:.5rem;margin-bottom:2px;padding:.75rem 1rem;font-size:.875rem;font-weight:500;transition:background .15s;display:flex}.guide-toggle:hover{background:var(--bg-hover)}.guide-toggle-icon{color:var(--text-muted);flex-shrink:0;font-size:.65rem;transition:transform .2s}.guide-toggle-icon.open{transform:rotate(90deg)}.guide-toggle-label{flex:1}.guide-badge{text-transform:uppercase;letter-spacing:.04em;border-radius:4px;flex-shrink:0;padding:.15rem .5rem;font-size:.7rem;font-weight:600}.guide-badge.recommended{background:var(--success-bg);color:var(--success);border:1px solid var(--success)}.guide-content{border:1px solid var(--border);background:var(--bg-primary);color:var(--text-secondary);border-top:none;border-radius:0 0 6px 6px;margin-bottom:.5rem;padding:1rem 1.25rem;font-size:.85rem;line-height:1.6}.guide-content h4{color:var(--text-primary);margin:1rem 0 .4rem;font-size:.875rem}.guide-content h4:first-child{margin-top:.25rem}.guide-content p{margin:0 0 .5rem}.guide-benefit{border-left:3px solid var(--accent);color:var(--text-secondary);background:#3b82f614;border-radius:0 4px 4px 0;padding:.5rem .75rem;margin-bottom:.75rem!important}.guide-code-block{background:var(--bg-secondary);border:1px solid var(--border);border-radius:6px;margin:.5rem 0 .75rem;overflow:hidden}.guide-code-label{background:var(--bg-tertiary);color:var(--text-muted);border-bottom:1px solid var(--border);padding:.25rem .75rem;font-size:.75rem;font-weight:600}.guide-code-block pre{margin:0;padding:.75rem;overflow-x:auto}.guide-code-block code{font-family:var(--font-mono);white-space:pre;color:var(--text-primary);font-size:.8rem;line-height:1.5}.guide-steps{margin:.5rem 0;padding-left:1.25rem}.guide-steps li{margin-bottom:.35rem}.guide-table{border-collapse:collapse;width:100%;margin:.5rem 0 .75rem;font-size:.85rem}.guide-table td{border:1px solid var(--border);color:var(--text-primary);padding:.4rem .75rem}.guide-table td:first-child{background:var(--bg-tertiary);width:120px;font-weight:600}.guide-warning{background:var(--warning-bg);border:1px solid var(--warning);color:var(--warning);border-radius:6px;margin:.75rem 0 .25rem;padding:.6rem .75rem;font-size:.82rem}@media (max-width:600px){.database-form .form-row,.database-status-cards,.database-actions{flex-direction:column}.database-actions .btn{width:100%}}
.project-view{padding:24px}.project-view-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:20px;display:flex}.project-view-header h2{margin:0;font-size:1.25rem}.project-view-actions{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.project-cards{grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:16px;display:grid}.project-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;padding:16px;transition:border-color .15s,box-shadow .15s}.project-card:hover{border-color:var(--accent);box-shadow:0 2px 8px #0000000f}.project-card-header{justify-content:space-between;align-items:flex-start;gap:8px;margin-bottom:8px;display:flex}.project-card-title h3{margin:0;font-size:1rem;font-weight:600;line-height:1.3}.project-card-number{color:var(--text-muted);font-size:.75rem;font-family:var(--font-mono)}.project-card-customer{color:var(--text-muted);margin-bottom:4px;font-size:.8rem}.project-card-description{color:var(--text-secondary);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:4px 0 8px;font-size:.8rem;display:-webkit-box;overflow:hidden}.project-card-footer{color:var(--text-muted);border-top:1px solid var(--border);gap:12px;margin-top:8px;padding-top:8px;font-size:.75rem;display:flex}.project-card-meta{white-space:nowrap}.project-status-badge{white-space:nowrap;text-transform:uppercase;letter-spacing:.03em;border-radius:999px;padding:2px 8px;font-size:.7rem;font-weight:600;display:inline-block}.project-status-active{background:var(--success-bg,#dcfce7);color:var(--success-text,#166534)}.project-status-completed{background:var(--info-bg,#dbeafe);color:var(--info-text,#1e40af)}.project-status-archived{background:var(--neutral-bg,#f3f4f6);color:var(--neutral-text,#6b7280)}.project-status-on-hold{background:var(--warning-bg,#fef9c3);color:var(--warning-text,#854d0e)}.project-detail{padding:24px}.project-detail-header{margin-bottom:24px}.project-detail-nav{margin-bottom:8px}.project-detail-title-row{justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.project-detail-title-row h2{margin:0 0 4px;font-size:1.25rem}.project-detail-meta{flex-wrap:wrap;align-items:center;gap:8px;margin-top:4px;display:flex}.project-detail-description{color:var(--text-secondary);max-width:600px;margin-top:8px;font-size:.85rem}.project-detail-actions{flex-shrink:0;gap:8px;display:flex}.project-products-section{margin-top:16px}.project-products-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.project-products-header h3{margin:0;font-size:1rem}.project-products-table{border-collapse:collapse;width:100%}.project-products-table th{text-align:left;text-transform:uppercase;color:var(--text-muted);border-bottom:2px solid var(--border);padding:8px 12px;font-size:.75rem;font-weight:600}.project-products-table td{border-bottom:1px solid var(--border);padding:10px 12px;font-size:.85rem}.project-product-row{cursor:pointer;transition:background .1s}.project-product-row:hover{background:var(--hover)}.add-product-list{border:1px solid var(--border);border-radius:var(--radius);max-height:300px;margin-top:8px;overflow-y:auto}.add-product-item{cursor:pointer;justify-content:space-between;align-items:center;padding:8px 12px;font-size:.85rem;transition:background .1s;display:flex}.add-product-item:hover{background:var(--hover)}.add-product-item+.add-product-item{border-top:1px solid var(--border)}.add-product-item-selected{background:var(--accent-bg,#eff6ff)}.product-check{color:var(--accent);flex-shrink:0;font-weight:600}.selected-products-chips{flex-wrap:wrap;gap:6px;margin-top:8px;display:flex}.product-chip{background:var(--accent-bg,#eff6ff);border:1px solid var(--accent-border,#bfdbfe);white-space:nowrap;border-radius:999px;align-items:center;gap:4px;padding:2px 8px;font-size:.75rem;font-weight:500;display:inline-flex}.product-chip-remove{cursor:pointer;color:var(--text-muted);background:0 0;border:none;padding:0 2px;font-size:.7rem;line-height:1}.product-chip-remove:hover{color:var(--danger,#dc2626)}.project-detail-name-cell{font-weight:500}.product-detail-view{padding:24px}.product-detail-view-header{margin-bottom:24px}.product-detail-view-header h2{margin:0;font-size:1.25rem;font-weight:600}.product-detail-view-id{color:var(--text-muted);font-size:1rem;font-weight:400}.product-detail-view-customer{color:var(--text-secondary);margin-top:4px;font-size:.85rem}.product-detail-view-section{margin-bottom:32px}.product-detail-view-section-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.product-detail-view-section-header h3{margin:0;font-size:1rem;font-weight:600}.product-detail-view-empty{padding:16px 0;font-size:.85rem}.product-detail-view-table{border-collapse:collapse;width:100%}.product-detail-view-table th{text-align:left;text-transform:uppercase;color:var(--text-muted);border-bottom:2px solid var(--border);padding:8px 12px;font-size:.75rem;font-weight:600}.product-detail-view-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.product-detail-view-table th.sortable:hover{color:var(--text-primary)}.product-detail-view-table td{border-bottom:1px solid var(--border);padding:10px 12px;font-size:.85rem}.product-detail-view-row.clickable{cursor:pointer;transition:background .1s}.product-detail-view-row.clickable:hover{background:var(--hover)}.product-detail-view-details-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:12px;display:grid}.detail-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;justify-content:space-between;align-items:center;padding:14px 16px;transition:border-color .15s,box-shadow .15s;display:flex}.detail-card:hover{border-color:var(--accent);box-shadow:0 2px 8px #0000000f}.detail-card-main{min-width:0}.detail-card-name{white-space:nowrap;text-overflow:ellipsis;font-size:.9rem;font-weight:600;overflow:hidden}.detail-card-id{color:var(--text-muted);font-size:.75rem;font-family:var(--font-mono);margin-top:2px}.detail-card-meta{color:var(--text-muted);white-space:nowrap;flex-shrink:0;margin-left:12px;font-size:.75rem}.product-id-number{color:var(--text-muted);font-size:.75rem;font-family:var(--font-mono)}

