:root{--bg:#f5f2ed;--surface:#fff;--surface-2:#ede9e3;--surface-3:#e5e0d8;--border:#ddd8d0;--input-bg:#faf8f5;--text:#5c5248;--text-h:#1c1a16;--text-muted:#9a8e82;--accent:#c49040;--accent-dim:#c490401a;--accent-hover:#d4a050;--danger:#b04040;--danger-dim:#b0404014;--danger-border:#c05050;--rs-active:var(--accent);--rs-inactive:#ddd8d0;--rs-thumb-bg:var(--surface);--shadow-sm:0 1px 4px #00000012;--shadow:0 4px 20px #00000017;--sans:"Inter", system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, "Cascadia Code", Consolas, monospace;font-family:var(--sans);letter-spacing:.01em;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:15px;line-height:1.6}*,:before,:after{box-sizing:border-box}body{margin:0}#root{flex-direction:column;width:100%;min-height:100svh;display:flex}h1,h2,h3,h4{color:var(--text-h);margin:0;font-weight:600;line-height:1.25}p{margin:0}a{color:var(--accent);text-decoration:none}a:hover{color:var(--accent-hover)}code{font-family:var(--mono);background:var(--surface-2);border:1px solid var(--border);color:var(--text-h);border-radius:4px;padding:2px 6px;font-size:.85em}.auth-container{background:var(--bg);justify-content:center;align-items:center;min-height:100vh;padding:2rem;display:flex}.auth-card{background:var(--surface);border:1px solid var(--border);width:100%;max-width:440px;box-shadow:var(--shadow);border-radius:16px;padding:2.5rem}.auth-card h1{color:var(--text-h);margin-bottom:.375rem;font-size:1.5rem}.auth-card .auth-subtitle{color:var(--text-muted);margin-bottom:2rem;font-size:.875rem}.form-group{flex-direction:column;gap:6px;margin-bottom:1.25rem;display:flex}.form-group label{letter-spacing:.04em;text-transform:uppercase;color:var(--text-muted);font-size:.8rem;font-weight:600}.form-group input,.form-group select,.form-group textarea{border:1px solid var(--border);background:var(--input-bg);color:var(--text-h);resize:vertical;border-radius:8px;outline:none;padding:.7rem .875rem;font-family:inherit;font-size:.95rem;transition:border-color .2s,box-shadow .2s}.form-group input::placeholder,.form-group textarea::placeholder{color:var(--text-muted);opacity:.7}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}.form-group select{appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%2356718a' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-position:right .875rem center;background-repeat:no-repeat;padding-right:2.25rem}.btn{cursor:pointer;white-space:nowrap;border:none;border-radius:8px;justify-content:center;align-items:center;gap:.4rem;padding:.65rem 1.25rem;font-family:inherit;font-size:.9rem;font-weight:600;transition:background .15s,opacity .15s,box-shadow .15s;display:inline-flex}.btn:disabled{opacity:.45;cursor:not-allowed}.btn-primary{background:var(--accent);color:#1a2332;width:100%;margin-top:.5rem}.btn-primary:hover:not(:disabled){background:var(--accent-hover);box-shadow:0 2px 12px #d4a05459}.btn-secondary{border:1px solid var(--border);color:var(--text);background:0 0}.btn-secondary:hover{background:var(--surface-2);border-color:var(--accent);color:var(--text-h)}.btn-sm{padding:.35rem .75rem;font-size:.8rem}.btn-danger{background:var(--danger-dim);border:1px solid var(--danger-border);color:var(--danger)}.btn-danger:hover{background:#b85c5c38}.alert{border-radius:8px;margin-bottom:1rem;padding:.75rem 1rem;font-size:.875rem;line-height:1.5}.alert-error{background:var(--danger-dim);border:1px solid var(--danger-border);color:#e08080}.auth-link{text-align:center;color:var(--text-muted);margin-top:1.5rem;font-size:.875rem}.auth-link a{color:var(--accent);font-weight:500}.auth-link a:hover{color:var(--accent-hover)}.dashboard-container{background:var(--bg);flex-direction:column;min-height:100vh;display:flex}.dashboard-header{border-bottom:1px solid var(--border);background:var(--surface);justify-content:space-between;align-items:center;padding:1rem 2.5rem;display:flex}.dashboard-header h1{letter-spacing:.06em;text-transform:uppercase;color:var(--accent);font-size:1.2rem;font-weight:700}.dashboard-user{color:var(--text-muted);align-items:center;gap:1rem;font-size:.875rem;display:flex}.dashboard-main{flex:1;padding:3rem 2rem}.result-toolbar{flex-wrap:wrap;gap:.5rem;max-width:820px;margin:1.5rem auto 0;display:flex}.result-tool-btn{border:1px solid var(--border);background:var(--surface);color:var(--text-muted);cursor:pointer;border-radius:8px;padding:.45rem 1rem;font-size:.8rem;font-weight:600;transition:background .15s,color .15s,border-color .15s}.result-tool-btn:hover,.result-tool-btn--active{background:var(--accent);color:#fff;border-color:var(--accent)}.result-toolbar-hint{color:var(--text-muted);align-self:center;padding-left:.25rem;font-size:.75rem}.cmp-chips{flex-wrap:wrap;gap:.4rem;max-width:820px;margin:.5rem auto 0;display:flex}.cmp-chip{border:1px solid var(--accent);background:color-mix(in srgb, var(--accent) 10%, transparent);color:var(--accent);border-radius:100px;align-items:center;gap:.35rem;padding:.25rem .7rem;font-size:.75rem;font-weight:600;display:inline-flex}.cmp-chip-remove{color:var(--accent);cursor:pointer;opacity:.7;background:0 0;border:none;padding:0;font-size:.7rem;line-height:1}.cmp-chip-remove:hover{opacity:1}.cmp-panel{max-width:820px;box-shadow:var(--shadow);border:1px solid var(--border);border-radius:14px;margin:1.5rem auto 0;overflow:hidden}.cmp-panel-header{background:#1a2332;justify-content:space-between;align-items:center;padding:.75rem 1.25rem;display:flex}.cmp-panel-title{color:#fff;font-size:.85rem;font-weight:700}.cmp-close-btn{color:#ffffff80;cursor:pointer;background:0 0;border:none;border-radius:4px;padding:.2rem .4rem;font-size:.9rem;transition:color .15s}.cmp-close-btn:hover{color:#fff}.cmp-table-wrap{background:var(--surface);overflow-x:auto}.cmp-table{border-collapse:collapse;width:100%;font-size:.8rem}.cmp-th{text-align:center;border-bottom:2px solid var(--border);background:var(--bg);vertical-align:bottom;padding:.75rem 1rem}.cmp-th--kpi{text-align:left;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;width:30%;font-size:.72rem;font-weight:700}.cmp-th-rank{color:var(--text-h);font-size:.75rem;font-weight:700;display:block}.cmp-th-material{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;max-width:140px;margin:0 auto;font-size:.68rem;display:block;overflow:hidden}.cmp-row{border-bottom:1px solid var(--border)}.cmp-row--overall{background:color-mix(in srgb, var(--surface) 60%, var(--bg))}.cmp-td{vertical-align:middle;padding:.6rem 1rem}.cmp-td--label{color:var(--text-muted);font-size:.78rem;font-weight:500}.cmp-td--center{text-align:center}.cmp-quality{font-size:.8rem;font-weight:700}.cmp-quality--excellent{color:#3aaa6e}.cmp-quality--strong{color:#4a90d9}.cmp-quality--good{color:#5a9fc4}.cmp-quality--fair{color:var(--accent)}.cmp-score{border:1.5px solid;border-radius:6px;justify-content:center;align-items:center;width:30px;height:30px;font-size:.82rem;font-weight:700;display:inline-flex}.cmp-score--high{color:#3aaa6e;background:#3aaa6e14;border-color:#3aaa6e66}.cmp-score--mid{color:#c49040;background:#c4904014;border-color:#c4904066}.cmp-score--low{color:#e05070;background:#e0507014;border-color:#e0507066}.cmp-score--missing{color:var(--text-muted);font-size:.9rem}.match-form-card{background:var(--surface);border:1px solid var(--border);max-width:820px;box-shadow:var(--shadow);border-radius:16px;margin:0 auto;padding:2.5rem}.match-form-title{color:var(--text-h);margin-bottom:.4rem;font-size:1.4rem}.match-form-subtitle{color:var(--text-muted);margin-bottom:2rem;font-size:.875rem;line-height:1.6}.btn-optional-toggle{border:1px solid var(--border);color:var(--accent);cursor:pointer;letter-spacing:.02em;background:0 0;border-radius:8px;align-items:center;gap:.5rem;margin-bottom:1.25rem;padding:.45rem .9rem;font-family:inherit;font-size:.825rem;font-weight:600;transition:border-color .15s,background .15s;display:inline-flex}.btn-optional-toggle:hover{border-color:var(--accent);background:var(--accent-dim)}.toggle-arrow{opacity:.8;font-size:.7rem}.optional-fields{border:1px solid var(--border);background:var(--input-bg);border-radius:12px;margin-bottom:1.5rem;padding:1.5rem 1.5rem .5rem}.range-group{margin-bottom:1.5rem}.range-header{justify-content:space-between;align-items:baseline;margin-bottom:8px;display:flex}.range-label{letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);font-size:.7rem;font-weight:700}.range-current{color:var(--accent);font-variant-numeric:tabular-nums;font-size:.82rem;font-weight:600}.range-slider-wrapper{height:28px;position:relative}.range-track-bg{pointer-events:none;border-radius:2px;height:4px;position:absolute;top:50%;left:0;right:0;transform:translateY(-50%)}.range-input{appearance:none;pointer-events:none;background:0 0;outline:none;width:100%;height:100%;margin:0;padding:0;position:absolute;left:0}.range-input::-webkit-slider-runnable-track{background:0 0;height:4px}.range-input::-webkit-slider-thumb{appearance:none;pointer-events:all;background:var(--surface);border:2px solid var(--accent);width:18px;height:18px;box-shadow:var(--shadow-sm);cursor:grab;border-radius:50%;margin-top:-7px;transition:transform .1s,box-shadow .1s}.range-input::-webkit-slider-thumb:active{cursor:grabbing;box-shadow:0 0 0 5px var(--accent-dim);transform:scale(1.2)}.range-input::-moz-range-track{background:0 0;height:4px}.range-input::-moz-range-thumb{pointer-events:all;background:var(--surface);border:2px solid var(--accent);cursor:grab;border-radius:50%;width:16px;height:16px}.range-bounds{color:var(--text-muted);font-variant-numeric:tabular-nums;justify-content:space-between;margin-top:5px;font-size:.68rem;display:flex}.optional-text-grid{grid-template-columns:1fr 1fr;gap:0 1.25rem;margin-top:.5rem;display:grid}@media (width<=560px){.optional-text-grid{grid-template-columns:1fr}}.match-submit-btn{margin-top:1.5rem}.ov-card{background:var(--surface);border:1px solid var(--border);max-width:820px;box-shadow:var(--shadow);border-radius:16px;margin:2rem auto 0;padding:2rem 2.5rem 1.5rem}.ov-header{margin-bottom:1.75rem}.ov-title-main{color:var(--text-h);margin-bottom:.4rem;font-size:1.5rem;font-weight:700;line-height:1.3}.ov-subtitle{color:var(--text-muted);font-size:.85rem;line-height:1.55}.ov-list{flex-direction:column;display:flex}.ov-row{border-bottom:1px solid var(--border);align-items:center;gap:1rem;padding:.875rem 0;display:flex}.ov-row:last-child{border-bottom:none}.ov-rank-badge{background:var(--accent);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:2rem;height:2rem;font-size:.82rem;font-weight:700;display:inline-flex}.ov-row:not(:first-child) .ov-rank-badge{background:var(--accent-dim);color:var(--accent);border:1px solid #c4904059}.ov-title{color:var(--text-h);flex:1;min-width:0;font-size:.925rem;line-height:1.4}.ov-quality{flex-shrink:0;font-size:.82rem;font-weight:700}.ov-quality--excellent,.ov-quality--strong{color:#3aaa6e}.ov-quality--good{color:var(--accent)}.ov-quality--fair{color:var(--text-muted)}.ov-disclaimer{color:var(--text-muted);border-top:1px solid var(--border);margin-top:1.25rem;padding-top:1rem;font-size:.78rem;line-height:1.5}.match-result pre{background:var(--input-bg);border:1px solid var(--border);font-size:.78rem;font-family:var(--mono);color:var(--text);white-space:pre-wrap;word-break:break-word;border-radius:10px;padding:1.25rem;line-height:1.6;overflow-x:auto}.admin-layout{background:var(--bg);min-height:100vh;display:flex}.admin-sidebar{background:var(--surface);border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;gap:0;width:230px;padding:1.75rem 1.25rem;display:flex}.admin-sidebar-header{align-items:center;gap:.6rem;margin-bottom:2.5rem;display:flex}.admin-logo{letter-spacing:.08em;text-transform:uppercase;color:var(--accent);font-size:1rem;font-weight:800}.admin-badge{background:var(--accent-dim);color:var(--accent);text-transform:uppercase;letter-spacing:.05em;border:1px solid #d4a0544d;border-radius:4px;padding:2px 7px;font-size:.6rem;font-weight:700}.admin-nav{flex-direction:column;flex:1;gap:3px;display:flex}.admin-nav-link{color:var(--text);border-radius:8px;padding:.55rem .875rem;font-size:.875rem;font-weight:500;text-decoration:none;transition:background .15s,color .15s}.admin-nav-link:hover{background:var(--surface-2);color:var(--text-h)}.admin-nav-link.active{background:var(--accent-dim);color:var(--accent);border:1px solid #d4a05433;font-weight:600}.admin-sidebar-footer{border-top:1px solid var(--border);flex-direction:column;gap:.6rem;padding-top:1.25rem;display:flex}.admin-sidebar-user{color:var(--text-muted);text-overflow:ellipsis;white-space:nowrap;font-size:.78rem;overflow:hidden}.admin-content{background:var(--bg);flex:1;overflow:auto}.pl-table-wrap{overflow-x:auto}.pl-table{border-collapse:collapse;width:100%;font-size:.82rem}.pl-table th{text-align:left;background:var(--bg);border-bottom:2px solid var(--border);text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);white-space:nowrap;padding:.6rem .75rem;font-size:.72rem;font-weight:700}.pl-row{border-bottom:1px solid var(--border);transition:background .1s}.pl-row:hover{background:var(--bg)}.pl-table td{vertical-align:middle;padding:.55rem .75rem}.pl-td-date{white-space:nowrap;color:var(--text-muted);font-size:.77rem}.pl-td-user{white-space:nowrap;font-weight:600}.pl-td-desc{color:var(--text-muted);max-width:280px}.pl-td-score,.pl-td-count{text-align:center}.pl-td-feedback{white-space:nowrap}.pl-td-actions{white-space:nowrap;gap:.4rem;display:flex}.pl-score-badge{border-radius:6px;padding:.15rem .5rem;font-size:.78rem;font-weight:700;display:inline-block}.pl-score-badge--high{color:#3aaa6e;background:#3aaa6e1f}.pl-score-badge--mid{color:#c49040;background:#c490401f}.pl-score-badge--low{color:#e05070;background:#e050701f}.pl-feedback-badge{color:var(--accent);letter-spacing:-1px}.pl-feedback-count{opacity:.7;margin-left:2px;font-size:.75rem}.pl-feedback-empty{color:var(--text-muted)}.pl-action-btn{border:1px solid var(--border);cursor:pointer;color:var(--text-muted);background:0 0;border-radius:6px;padding:.2rem .6rem;font-size:.75rem;transition:background .15s,color .15s}.pl-action-btn:hover{background:var(--accent);color:#fff;border-color:var(--accent)}.pl-action-btn--danger:hover{background:#b04040;border-color:#b04040}.pl-pagination{color:var(--text-muted);justify-content:center;align-items:center;gap:1rem;padding:1.25rem 0;font-size:.82rem;display:flex}.pl-modal-backdrop{z-index:200;background:#00000073;justify-content:center;align-items:flex-start;padding:2rem 1rem;display:flex;position:fixed;inset:0;overflow-y:auto}.pl-modal{background:var(--surface);border-radius:14px;flex-direction:column;width:100%;max-width:760px;display:flex;box-shadow:0 20px 60px #00000040}.pl-modal-header{color:#fff;background:#1a2332;border-radius:14px 14px 0 0;justify-content:space-between;align-items:center;padding:.75rem 1.25rem;font-size:.85rem;font-weight:700;display:flex}.pl-modal-close{color:#ffffff80;cursor:pointer;background:0 0;border:none;border-radius:4px;padding:.2rem .4rem;font-size:.9rem}.pl-modal-close:hover{color:#fff}.pl-modal-body{flex-direction:column;gap:1rem;max-height:70vh;padding:1.25rem 1.5rem;display:flex;overflow-y:auto}.pl-modal-footer{border-top:1px solid var(--border);justify-content:flex-end;gap:.5rem;padding:1rem 1.5rem;display:flex}.pl-detail-row{gap:.75rem;font-size:.82rem;display:flex}.pl-detail-label{color:var(--text-muted);min-width:80px;font-weight:700}.pl-detail-section{flex-direction:column;gap:.375rem;display:flex}.pl-detail-heading{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);font-size:.72rem;font-weight:700}.pl-pre{background:var(--bg);border:1px solid var(--border);white-space:pre-wrap;word-break:break-word;max-height:200px;color:var(--text-h);border-radius:8px;padding:.75rem 1rem;font-family:Courier New,monospace;font-size:.75rem;overflow-y:auto}.pl-pre--response{max-height:300px}.pl-stars{gap:2px;display:flex}.pl-star{cursor:pointer;color:var(--border);background:0 0;border:none;padding:0;font-size:1.4rem;line-height:1;transition:color .1s}.pl-star--on{color:var(--accent)}.pl-feedback-item{border:1px solid var(--border);background:var(--surface2,#ffffff08);border-radius:8px;margin-bottom:.75rem;padding:.75rem 1rem}.pl-feedback-item-header{flex-wrap:wrap;align-items:center;gap:.5rem;margin-bottom:.5rem;display:flex}.pl-feedback-rank{color:var(--text-muted);min-width:1.8rem;font-size:.8rem;font-weight:700}.pl-feedback-combo-name{color:var(--text-h);flex:1;font-size:.82rem}.pl-score-badge--sm{padding:1px 6px;font-size:.72rem}.pl-feedback-item-body{flex-direction:column;gap:.5rem;display:flex}.pl-feedback-notes{border:1px solid var(--border);background:var(--input-bg);resize:vertical;width:100%;color:var(--text-h);border-radius:8px;padding:.5rem .75rem;font-family:inherit;font-size:.82rem}.admin-page{max-width:1100px;padding:2.5rem}.admin-page-header{justify-content:space-between;align-items:center;margin-bottom:2rem;display:flex}.admin-page-header h1{font-size:1.4rem}.admin-form-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;max-width:580px;padding:2rem}.form-row{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.admin-table-wrapper{border:1px solid var(--border);border-radius:12px;overflow-x:auto}.admin-table{border-collapse:collapse;width:100%;font-size:.875rem}.admin-table th,.admin-table td{text-align:left;border-bottom:1px solid var(--border);padding:.875rem 1.125rem}.admin-table th{background:var(--surface);color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;font-size:.72rem;font-weight:700}.admin-table tbody tr:last-child td{border-bottom:none}.admin-table tbody tr:hover td{background:var(--surface-2)}.admin-table td{background:var(--surface);color:var(--text)}.admin-table-actions{gap:.5rem;display:flex}.admin-loading{color:var(--text-muted);padding:2rem 0;font-size:.9rem}.admin-empty{text-align:center;border:1px dashed var(--border);color:var(--text-muted);border-radius:12px;padding:3rem}.prompt-preview{font-family:var(--mono);color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;max-width:280px;font-size:.78rem;display:block;overflow:hidden}.prompt-form-card{background:var(--surface);border:1px solid var(--accent);box-shadow:0 0 0 4px var(--accent-dim);border-radius:14px;margin-bottom:2rem;padding:1.75rem}.prompt-versions-list{flex-direction:column;gap:.75rem;display:flex}.prompt-version-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:1.125rem 1.375rem;transition:border-color .15s}.prompt-version-card.is-active{border-color:var(--accent);background:color-mix(in srgb, var(--accent) 4%, var(--surface))}.prompt-version-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.75rem;display:flex}.prompt-version-number{font-family:var(--mono);color:var(--text-h);font-size:.95rem;font-weight:700}.prompt-version-meta{color:var(--text-muted);font-size:.78rem}.prompt-content-preview{background:var(--input-bg);border:1px solid var(--border);font-family:var(--mono);color:var(--text);white-space:pre-wrap;word-break:break-word;border-radius:8px;max-height:360px;margin-top:1rem;padding:1rem 1.125rem;font-size:.8rem;line-height:1.65;overflow-y:auto}.role-badge{letter-spacing:.04em;border-radius:4px;padding:2px 9px;font-size:.72rem;font-weight:700;display:inline-block}.role-admin{background:var(--accent-dim);color:var(--accent);border:1px solid #d4a05440}.role-user{background:var(--surface-2);color:var(--text);border:1px solid var(--border)}.detail-panel{border:1px solid var(--border);max-width:820px;box-shadow:var(--shadow);border-radius:14px;margin:1.5rem auto 0;overflow:hidden}.detail-panel-header{background:#1a2332;justify-content:space-between;align-items:flex-start;gap:1rem;padding:1rem 1.25rem;display:flex}.detail-header-left{flex:1;align-items:flex-start;gap:.875rem;min-width:0;display:flex}.detail-rank-badge{background:var(--accent);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:2rem;height:2rem;margin-top:2px;font-size:.85rem;font-weight:700;display:inline-flex}.detail-header-titles{flex-direction:column;gap:.25rem;min-width:0;display:flex}.detail-title{color:#fff;white-space:nowrap;text-overflow:ellipsis;font-size:.95rem;font-weight:600;line-height:1.35;overflow:hidden}.detail-title-sep{color:var(--accent);margin:0 .25rem}.detail-best-kpi{color:#ffffff8c;letter-spacing:.02em;font-size:.72rem}.detail-header-right{flex-shrink:0;align-items:center;gap:.5rem;display:flex}.detail-feasibility-badge{color:#5ecf90;white-space:nowrap;background:#3aaa6e33;border:1px solid #3aaa6e66;border-radius:99px;padding:.25rem .6rem;font-size:.72rem;font-weight:700}.detail-quality-badge{white-space:nowrap;border:1px solid;border-radius:99px;padding:.25rem .6rem;font-size:.72rem;font-weight:700}.detail-quality-badge--excellent{color:#5ecf90;border-color:#5ecf9080}.detail-quality-badge--good{color:#8bc4e8;border-color:#8bc4e880}.detail-quality-badge--fair{color:var(--accent);border-color:#c4904080}.detail-quality-badge--acceptable{color:var(--text-muted);border-color:var(--border)}.detail-close-btn{color:#ffffff80;cursor:pointer;background:0 0;border:none;padding:.1rem .3rem;font-size:1rem;line-height:1;transition:color .15s}.detail-close-btn:hover{color:#fff}.detail-compare-btn{color:#ffffffb3;cursor:pointer;white-space:nowrap;background:0 0;border:1px solid #ffffff4d;border-radius:6px;padding:.2rem .6rem;font-size:.72rem;font-weight:600;transition:background .15s,color .15s,border-color .15s}.detail-compare-btn:hover{color:#fff;border-color:#fff}.detail-compare-btn--active{background:var(--accent);border-color:var(--accent);color:#fff}.detail-panel-body{background:var(--surface);flex-direction:column;gap:1.25rem;padding:1.25rem 1.5rem;display:flex}.detail-score-row{grid-template-columns:repeat(3,1fr);gap:.75rem;display:grid}.detail-score-card{border:1px solid #0000;border-radius:10px;flex-direction:column;align-items:center;gap:.2rem;padding:.75rem 1rem;display:flex}.detail-score-card--excellent{background:#3aaa6e14;border-color:#3aaa6e33}.detail-score-card--good{background:#8bc4e81a;border-color:#8bc4e840}.detail-score-card--fair{background:var(--accent-dim);border-color:#c4904033}.detail-score-card--acceptable{background:var(--surface-2);border-color:var(--border)}.detail-score-card-value{font-size:1rem;font-weight:700}.detail-score-card--excellent .detail-score-card-value{color:#3aaa6e}.detail-score-card--good .detail-score-card-value{color:#5a9fc4}.detail-score-card--fair .detail-score-card-value{color:var(--accent)}.detail-score-card--acceptable .detail-score-card-value{color:var(--text-muted)}.detail-score-card-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.72rem;font-weight:600}.detail-tech-chain{flex-wrap:wrap;gap:.5rem;display:flex}.detail-tech-pill{background:var(--surface-2);border:1px solid var(--border);color:var(--text);border-radius:99px;align-items:center;gap:.35rem;padding:.3rem .75rem;font-size:.78rem;font-weight:500;display:inline-flex}.detail-tech-pill--post{background:var(--accent-dim);color:var(--accent);border-color:#c4904040}.detail-overviews{color:var(--text);flex-direction:column;gap:.4rem;font-size:.875rem;line-height:1.55;display:flex}.detail-overview-label{color:var(--accent);font-weight:700}.detail-kpi-section{flex-direction:column;gap:.5rem;display:flex}.detail-kpi-header{letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);justify-content:space-between;margin-bottom:.25rem;font-size:.7rem;font-weight:700;display:flex}.detail-kpi-row{grid-template-columns:minmax(0,1fr) 65%;align-items:center;gap:.75rem;display:grid}.detail-kpi-name{color:var(--text);font-size:.8rem;line-height:1.35}.detail-kpi-track{background:var(--surface-2);border-radius:4px;align-items:center;height:20px;display:flex;position:relative;overflow:visible}.detail-kpi-fill{border-radius:4px;min-width:2px;height:100%;transition:width .4s}.detail-kpi-score{color:#fff;mix-blend-mode:normal;text-shadow:0 1px 2px #0000004d;pointer-events:none;font-size:.72rem;font-weight:700;position:absolute;right:.5rem}.detail-compat-row{flex-wrap:wrap;gap:.5rem;display:flex}.detail-compat-badge{color:#3aaa6e;background:#3aaa6e14;border:1px solid #3aaa6e40;border-radius:99px;align-items:center;gap:.3rem;padding:.25rem .6rem;font-size:.75rem;font-weight:500;display:inline-flex}.detail-compat-badge--assumed{background:var(--accent-dim);color:var(--accent);border-color:#c4904040}.detail-bullets{flex-direction:column;gap:.4rem;margin:0;padding:0;list-style:none;display:flex}.detail-bullets li{color:var(--text);padding-left:1rem;font-size:.85rem;line-height:1.55;position:relative}.detail-bullets li:before{content:"•";color:var(--accent);font-weight:700;position:absolute;left:0}.detail-fb-section{border-top:1px solid var(--border);flex-direction:column;gap:.6rem;margin-top:1.25rem;padding-top:1.25rem;display:flex}.detail-fb-heading{text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);font-size:.75rem;font-weight:600}.detail-fb-row{align-items:center;gap:.75rem;display:flex}.detail-fb-stars{gap:2px;display:flex}.detail-fb-star{cursor:pointer;color:var(--border);background:0 0;border:none;padding:0;font-size:1.5rem;line-height:1;transition:color .1s}.detail-fb-star--on{color:var(--accent)}.detail-fb-clear{color:var(--text-muted);cursor:pointer;font-size:.72rem;text-decoration:underline}.detail-fb-clear:hover{color:var(--text)}.detail-fb-textarea{border:1px solid var(--border);background:var(--input-bg);resize:vertical;width:100%;color:var(--text-h);border-radius:8px;padding:.5rem .75rem;font-family:inherit;font-size:.82rem}.detail-fb-footer{justify-content:flex-end;display:flex}.detail-fb-btn{padding:.35rem .9rem;font-size:.8rem}@media (width<=560px){.detail-score-row,.detail-kpi-row{grid-template-columns:1fr}.detail-kpi-name{font-size:.75rem}.detail-title{white-space:normal}}.detail-chevron{color:#ffffff80;margin-left:.25rem;font-size:.85rem;transition:transform .2s}.detail-preview-row{background:var(--surface);border-top:1px solid var(--border);flex-wrap:wrap;align-items:center;gap:1.25rem;padding:.625rem 1.25rem;display:flex}.detail-preview-scores{color:var(--text-muted);flex-shrink:0;align-items:center;gap:.5rem;font-size:.8rem;display:flex}.detail-preview-sep{color:var(--border)}.detail-quality-inline--excellent{color:#3aaa6e}.detail-quality-inline--good{color:#5a9fc4}.detail-quality-inline--fair{color:var(--accent)}.detail-quality-inline--acceptable{color:var(--text-muted)}.sup-panel{max-width:820px;box-shadow:var(--shadow);border:1px solid var(--border);border-radius:14px;margin:1.5rem auto 0;overflow:hidden}.sup-panel-header{background:#1a2332;justify-content:space-between;align-items:center;padding:.75rem 1.25rem;display:flex}.sup-panel-title{color:#fff;align-items:center;gap:.5rem;font-size:.85rem;font-weight:700;display:flex}.sup-close-btn{color:#ffffff80;cursor:pointer;background:0 0;border:none;border-radius:4px;padding:.2rem .4rem;font-size:.9rem;transition:color .15s}.sup-close-btn:hover{color:#fff}.sup-body{background:var(--surface);flex-direction:column;gap:1.5rem;padding:1rem 1.25rem;display:flex}.sup-combo-block{border:1px solid var(--border);background:var(--bg);border-radius:10px;flex-direction:column;gap:.75rem;padding:1rem 1.125rem;display:flex}.sup-combo-header{align-items:center;gap:.625rem;display:flex}.sup-rank-badge{background:var(--accent);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;font-size:.7rem;font-weight:700;display:inline-flex}.sup-combo-title{color:var(--text-h);font-size:.82rem;font-weight:600}.sup-section{flex-direction:column;gap:.4rem;display:flex}.sup-section-heading{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;align-items:center;gap:.375rem;margin-bottom:.1rem;font-size:.72rem;font-weight:700;display:flex}.sup-supplier-row{border:1px solid var(--border);background:var(--surface);border-radius:8px;overflow:hidden}.sup-supplier-summary{cursor:pointer;text-align:left;background:0 0;border:none;justify-content:space-between;align-items:center;gap:.75rem;width:100%;padding:.5rem .75rem;display:flex}.sup-supplier-info{flex:1;min-width:0}.sup-supplier-desc{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;margin-bottom:.2rem;font-size:.78rem;font-style:italic;overflow:hidden}.sup-supplier-location{color:#e05070;align-items:center;gap:.25rem;font-size:.72rem;display:flex}.sup-chevron{color:var(--text-muted);flex-shrink:0;transition:transform .2s}.sup-chevron--open{transform:rotate(180deg)}.sup-supplier-detail{border-top:1px solid var(--border);flex-direction:column;gap:.2rem;padding:.375rem .75rem .625rem;display:flex}.sup-supplier-name{color:var(--text-h);font-size:.8rem;font-weight:600}.sup-supplier-link{color:#4a90d9;word-break:break-all;font-size:.73rem;text-decoration:none}.sup-supplier-link:hover{text-decoration:underline}.feas-panel{max-width:820px;box-shadow:var(--shadow);border:1px solid var(--border);border-radius:14px;margin:1.5rem auto 0;overflow:hidden}.feas-panel-header{background:#1a2332;justify-content:space-between;align-items:center;padding:.75rem 1.25rem;display:flex}.feas-panel-title{color:#fff;align-items:center;gap:.5rem;font-size:.85rem;font-weight:700;display:flex}.feas-close-btn{color:#ffffff80;cursor:pointer;background:0 0;border:none;border-radius:4px;padding:.2rem .4rem;font-size:.9rem;line-height:1;transition:color .15s}.feas-close-btn:hover{color:#fff}.feas-body{background:var(--surface);flex-direction:column;gap:1.5rem;padding:1rem 1.25rem;display:flex}.feas-row{border:1px solid var(--border);background:var(--bg);border-radius:10px;padding:1rem 1.125rem}.feas-row-header{align-items:center;gap:.625rem;margin-bottom:.5rem;display:flex}.feas-rank-badge{background:var(--accent);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;font-size:.7rem;font-weight:700;display:inline-flex}.feas-row-title{color:var(--text-h);flex:1;font-size:.82rem;font-weight:600}.feas-score{flex-shrink:0;font-size:.95rem;font-weight:700}.feas-bar-track{background:var(--border);border-radius:100px;height:6px;margin-bottom:.625rem;overflow:hidden}.feas-bar-fill{border-radius:100px;height:100%;transition:width .4s}.feas-reasoning{color:var(--text-muted);margin-bottom:.5rem;font-size:.78rem;line-height:1.5}.feas-risks{flex-direction:column;gap:.5rem;display:flex}.feas-risks-label{color:#c49040;align-items:center;gap:.35rem;font-size:.72rem;font-weight:600;display:flex}.feas-risk-item{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:.5rem .75rem}.feas-risk-top{justify-content:space-between;align-items:center;margin-bottom:.25rem;display:flex}.feas-risk-name{color:var(--text-h);font-size:.78rem;font-weight:600}.feas-risk-impact{color:#c49040;border:1px solid #c49040;border-radius:100px;padding:.1rem .5rem;font-size:.72rem;font-weight:600}.feas-risk-suggestion{color:var(--text-muted);align-items:flex-start;gap:.35rem;font-size:.73rem;line-height:1.4;display:flex}.feas-risk-suggestion svg{flex-shrink:0;margin-top:2px}.spider-card{background:var(--surface);border:1px solid var(--border);max-width:820px;box-shadow:var(--shadow);border-radius:14px;margin:2rem auto 0;overflow:hidden}.spider-panel-header{background:#1a2332;justify-content:space-between;align-items:center;padding:.75rem 1.25rem;display:flex}.spider-panel-title{color:#fff;align-items:center;gap:.5rem;font-size:.85rem;font-weight:700;display:flex}.spider-close-btn{color:#ffffff80;cursor:pointer;background:0 0;border:none;border-radius:4px;padding:.2rem .4rem;font-size:.9rem;transition:color .15s}.spider-close-btn:hover{color:#fff}.spider-card-body{padding:1.25rem 1.5rem}.spider-settings-btn{border:1px solid var(--border);width:28px;height:28px;color:var(--text-muted);cursor:pointer;background:0 0;border-radius:6px;justify-content:center;align-items:center;transition:background .15s,color .15s;display:flex}.spider-settings-btn:hover,.spider-settings-btn--active{background:var(--accent);color:#fff;border-color:var(--accent)}.spider-settings{border:1px solid var(--border);background:var(--bg);border-radius:10px;flex-direction:column;gap:.75rem;margin-bottom:1rem;padding:.875rem 1rem;display:flex;overflow:hidden}.spider-settings-section{flex-direction:column;gap:.4rem;display:flex}.spider-settings-heading{letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted);font-size:.7rem;font-weight:700}.spider-settings-chips{flex-wrap:wrap;gap:.375rem;display:flex}.spider-chip{border:1px solid var(--border);color:var(--text-muted);cursor:pointer;background:0 0;border-radius:100px;align-items:center;gap:.3rem;padding:.2rem .6rem;font-size:.72rem;transition:background .15s,color .15s,border-color .15s;display:inline-flex}.spider-chip--on{background:color-mix(in srgb, var(--chip-color,var(--accent)) 12%, transparent);border-color:var(--chip-color,var(--accent));color:var(--chip-color,var(--accent))}.spider-chip--kpi.spider-chip--on{background:color-mix(in srgb, var(--accent) 12%, transparent);border-color:var(--accent);color:var(--accent)}.spider-chart-wrap{width:100%}.spider-tooltip{background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow);border-radius:8px;padding:.5rem .75rem;font-size:.78rem;line-height:1.6}.spider-tooltip-label{color:var(--text-h);margin-bottom:.25rem;font-weight:700}
