*{box-sizing:border-box;margin:0;padding:0}:root{--bg:#f4f6f9;--surface:#fff;--border:#e2e8f0;--text:#1e293b;--text-muted:#64748b;--primary:#2563eb;--primary-hover:#1d4ed8;--danger:#dc2626;--danger-hover:#b91c1c;--success:#16a34a;--warning:#d97706;--radius:10px;--shadow:0 1px 3px #0f172a14, 0 4px 12px #0f172a0a}*{box-sizing:border-box}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;margin:0;font-family:Segoe UI,PingFang SC,Microsoft YaHei,sans-serif;line-height:1.5}#root{min-height:100vh}code{background:#f1f5f9;border-radius:4px;padding:.1em .4em;font-family:Consolas,Courier New,monospace;font-size:.9em}.app-layout{min-height:100vh;display:flex}.sidebar{color:#e2e8f0;z-index:100;background:#1e293b;flex-direction:column;flex-shrink:0;width:240px;display:flex;position:fixed;top:0;bottom:0;left:0}.sidebar-brand{border-bottom:1px solid #ffffff14;align-items:center;gap:.75rem;padding:1.25rem 1rem;display:flex}.brand-logo{background:var(--primary);color:#fff;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:.85rem;font-weight:700;display:flex}.sidebar-brand h1{color:#f8fafc;margin:0;font-size:.95rem;font-weight:700;line-height:1.3}.sidebar-brand p{color:#94a3b8;margin:.15rem 0 0;font-size:.75rem}.sidebar-nav{flex-direction:column;flex:1;gap:.25rem;padding:.75rem .65rem;display:flex}.nav-item{color:#94a3b8;cursor:pointer;text-align:left;background:0 0;border:none;border-radius:8px;align-items:center;gap:.75rem;width:100%;padding:.75rem .85rem;transition:background .15s,color .15s;display:flex}.nav-item:hover{color:#e2e8f0;background:#ffffff0f}.nav-item.active{background:var(--primary);color:#fff}.nav-item.active .nav-desc{color:#ffffffbf}.nav-icon{text-align:center;flex-shrink:0;width:1.5rem;font-size:1.25rem}.nav-text{flex-direction:column;gap:.1rem;min-width:0;display:flex}.nav-label{font-size:.9rem;font-weight:600}.nav-desc{color:#64748b;white-space:nowrap;text-overflow:ellipsis;font-size:.72rem;overflow:hidden}.sidebar-footer{border-top:1px solid #ffffff14;flex-direction:column;gap:.5rem;padding:1rem;display:flex}.status-item{color:#94a3b8;align-items:center;gap:.5rem;font-size:.78rem;display:flex}.status-dot{border-radius:50%;flex-shrink:0;width:7px;height:7px}.status-ok{background:#22c55e;box-shadow:0 0 6px #22c55e80}.status-warn{background:#f59e0b;box-shadow:0 0 6px #f59e0b80}.status-neutral{background:#64748b}.main-wrapper{flex-direction:column;flex:1;min-height:100vh;margin-left:240px;display:flex}.main-header{background:var(--surface);border-bottom:1px solid var(--border);z-index:10;padding:1.25rem 1.75rem;position:sticky;top:0}.main-header h2{margin:0;font-size:1.25rem;font-weight:700}.main-header p{color:var(--text-muted);margin:.25rem 0 0;font-size:.875rem}.main-content{flex:1;width:100%;max-width:1200px;padding:1.5rem 1.75rem}.panel-header{margin-bottom:1.25rem}.panel-header h2{margin:0;font-size:1.25rem}.panel-header p{color:var(--text-muted);margin:.35rem 0 0;font-size:.9rem}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);margin-bottom:1rem;padding:1.25rem}.card h3{margin:0 0 1rem;font-size:1.05rem}.form-card label{margin-bottom:1rem;font-size:.875rem;font-weight:500;display:block}.form-card input,.form-card textarea{border:1px solid var(--border);border-radius:8px;width:100%;margin-top:.35rem;padding:.6rem .75rem;font-family:inherit;font-size:.95rem;transition:border-color .15s,box-shadow .15s;display:block}.form-card input:focus,.form-card textarea:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #2563eb1f}.form-card textarea{resize:vertical;min-height:120px}.row-2{grid-template-columns:1fr 180px;gap:1rem;display:grid}.section-title{justify-content:space-between;align-items:center;margin-bottom:.75rem;font-size:.875rem;font-weight:600;display:flex}.specs-section{margin-top:.5rem}.spec-block{border:1px solid var(--border);background:#f8fafc;border-radius:8px;margin-bottom:.75rem;padding:1rem}.spec-header{justify-content:space-between;align-items:center;margin-bottom:.75rem;display:flex}.attrs-section{margin-top:.75rem}.attr-row{grid-template-columns:1fr 1fr auto;gap:.5rem;margin-bottom:.5rem;display:grid}.attr-row input{margin-top:0}.form-actions{flex-wrap:wrap;gap:.75rem;margin-top:.5rem;display:flex}.btn-primary,.btn-secondary,.btn-danger{cursor:pointer;border:none;border-radius:8px;padding:.6rem 1.1rem;font-size:.9rem;font-weight:500;transition:background .15s,opacity .15s}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--primary-hover)}.btn-secondary{color:var(--text);border:1px solid var(--border);background:#f1f5f9}.btn-secondary:hover:not(:disabled){background:#e2e8f0}.btn-danger{color:var(--danger);background:#fef2f2;border:1px solid #fecaca}.btn-danger:hover:not(:disabled){background:#fee2e2}.btn-sm{padding:.35rem .75rem;font-size:.8rem}.btn-icon{border:1px solid var(--border);cursor:pointer;width:32px;height:36px;color:var(--text-muted);background:0 0;border-radius:6px;align-self:end;font-size:1.1rem}.btn-icon:hover{color:var(--danger);background:#fee2e2;border-color:#fecaca}button:disabled{opacity:.6;cursor:not-allowed}.alert{border-radius:8px;margin-bottom:1rem;padding:.85rem 1rem;font-size:.9rem}.alert-error{color:#991b1b;background:#fef2f2;border:1px solid #fecaca}.alert-warn{color:#92400e;background:#fffbeb;border:1px solid #fde68a}.muted{color:var(--text-muted)}.parts-list{flex-direction:column;gap:1rem;display:flex}.part-item{border:1px solid var(--border);border-radius:8px;overflow:hidden}.part-item-header{border-bottom:1px solid var(--border);background:#f8fafc;justify-content:space-between;align-items:flex-start;gap:1rem;padding:.85rem 1rem;display:flex}.aliases{color:var(--text-muted);margin-top:.2rem;font-size:.8rem;display:block}.part-actions{flex-shrink:0;gap:.5rem;display:flex}.specs-table-wrap,.result-table-wrap{overflow-x:auto}table{border-collapse:collapse;width:100%;font-size:.875rem}th,td{text-align:left;border-bottom:1px solid var(--border);padding:.65rem 1rem}th{color:var(--text-muted);white-space:nowrap;background:#f8fafc;font-size:.8rem;font-weight:600}td.price{color:var(--primary);white-space:nowrap;font-weight:600}.result-summary{border-bottom:1px solid var(--border);flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:1rem;margin-bottom:1rem;padding-bottom:1rem;display:flex}.result-label{color:var(--text-muted);margin-bottom:.25rem;font-size:.8rem;display:block}.total-price{color:var(--primary);font-size:2rem;font-weight:700}.result-meta{color:var(--text-muted);flex-direction:column;align-items:flex-end;gap:.25rem;font-size:.85rem;display:flex}.result-meta .warn{color:var(--warning)}.ai-summary{color:#0c4a6e;background:#f0f9ff;border:1px solid #bae6fd;border-radius:8px;margin:0 0 1rem;padding:.75rem 1rem;font-size:.9rem}.specs-cell{max-width:200px;color:var(--text-muted);font-size:.8rem}.row-unmatched{background:#fffbeb}.item-note{color:var(--text-muted);margin-top:.2rem;font-size:.75rem}.badge{border-radius:999px;padding:.2rem .55rem;font-size:.75rem;font-weight:500;display:inline-block}.badge-ok{color:#166534;background:#dcfce7}.badge-warn{color:#92400e;background:#fef3c7}.badge-neutral{color:var(--text-muted);background:#f1f5f9}.badge-high{color:#166534;background:#dcfce7}.badge-medium{color:#1e40af;background:#dbeafe}.badge-low{color:#92400e;background:#fef3c7}.badge-none{color:#991b1b;background:#fee2e2}@media (width<=768px){.sidebar{width:64px}.sidebar-brand div:last-child,.nav-text,.sidebar-footer{display:none}.sidebar-brand{justify-content:center;padding:1rem .5rem}.nav-item{justify-content:center;padding:.75rem}.main-wrapper{margin-left:64px}.main-content{padding:1rem}.row-2{grid-template-columns:1fr}.part-item-header{flex-direction:column}.result-summary{flex-direction:column;align-items:flex-start}.result-meta{align-items:flex-start}}
