body{background:#f0f2f5;font-family:"Segoe UI",Arial,sans-serif;margin:0}
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1e3a5f 0%,#3b82f6 100%)}
.login-card{width:400px;border:0;border-radius:12px}

.top-nav{display:flex;align-items:center;background:#1e293b;color:#fff;padding:0 16px;height:48px;gap:10px;position:sticky;top:0;z-index:100}
.top-nav-brand{font-weight:700;font-size:13px;white-space:nowrap;min-width:300px}
.top-nav-tabs{display:flex;gap:2px;flex:1;overflow-x:auto}
.tn-tab{border:0;background:transparent;color:#94a3b8;padding:10px 14px;font-size:13px;white-space:nowrap;border-bottom:2px solid transparent;cursor:pointer}
.tn-tab:hover{color:#e2e8f0}
.tn-tab.active{color:#fff;border-bottom-color:#3b82f6;font-weight:600}
.top-nav-right{display:flex;align-items:center;gap:8px;white-space:nowrap}

.app-body{padding:16px 20px;max-width:1600px;margin:0 auto}
.page{display:none}.page.active{display:block}

.section-title{font-size:14px;font-weight:700;margin-bottom:0}
.cfg-table td:first-child{font-weight:500;width:40%;color:#475569}

.rate-badge{padding:14px;border-radius:10px;text-align:center;font-size:16px;font-weight:700;color:#fff}
.rate-badge.usd{background:linear-gradient(135deg,#059669,#10b981)}.rate-badge.eur{background:linear-gradient(135deg,#2563eb,#3b82f6)}.rate-badge.mxn{background:linear-gradient(135deg,#d97706,#f59e0b)}

.hero-banner{background:linear-gradient(135deg,#0f172a 0%,#1e3a5f 40%,#3b82f6 100%);border-radius:14px;padding:28px 30px;display:flex;justify-content:space-between;align-items:center;color:#fff}
.hero-left h3{margin:0;font-weight:700;font-size:22px;letter-spacing:.5px}.hero-sub{font-size:13px;opacity:.7;margin-top:4px}
.hero-right{display:flex;align-items:center;gap:8px}

.country-row{display:flex;gap:12px}
.country-row .country-card{flex:1;min-width:0}
.country-card{border-radius:14px;padding:16px;display:flex;align-items:center;gap:12px;color:#fff;position:relative;overflow:hidden;box-shadow:0 4px 20px rgba(0,0,0,.15);transition:transform .2s}
.country-card:hover{transform:translateY(-3px)}
.mx-bg{background:linear-gradient(135deg,#065f46,#10b981)}.br-bg{background:linear-gradient(135deg,#1d4ed8,#60a5fa)}.cl-bg{background:linear-gradient(135deg,#7c2d12,#dc2626)}.co-bg{background:linear-gradient(135deg,#ca8a04,#facc15)}.ar-bg{background:linear-gradient(135deg,#0284c7,#38bdf8)}
.co-bg .cc-name,.co-bg .cc-rate,.co-bg .cc-cny{color:#422006}
.cc-flag img{width:56px;height:40px;border-radius:6px;object-fit:cover;box-shadow:0 2px 8px rgba(0,0,0,.2)}
.cc-body{flex:1}.cc-name{font-size:14px;font-weight:700;margin-bottom:2px}
.cc-clock{font-size:22px;font-weight:700;font-variant-numeric:tabular-nums;letter-spacing:1px;margin-bottom:6px}
.cc-pair{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:1px}
.cc-label{font-size:11px;opacity:.7;letter-spacing:.5px;font-weight:600}
.cc-val{font-size:15px;font-weight:700;font-variant-numeric:tabular-nums}
.cc-val.cc-sm{font-size:13px;opacity:.85}

.rate-detail-table thead th{background:#1e293b;color:#fff;font-size:11px;text-align:center;padding:8px 10px;border:none}
.rate-detail-table td{text-align:center;vertical-align:middle;font-size:13px;padding:8px 10px}
.rate-detail-table td:first-child{font-size:22px}
.rate-detail-table tr:hover{background:#f0f9ff}

.product-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:12px}
.product-card{background:#fff;border:1px solid #e2e8f0;border-radius:10px;overflow:hidden;transition:box-shadow .2s}
.product-card:hover{box-shadow:0 4px 16px rgba(0,0,0,.08)}
.pc-top{display:flex;gap:12px;padding:12px}
.pc-img{width:80px;height:80px;border-radius:8px;object-fit:cover;border:1px solid #e2e8f0;background:#f8fafc;flex-shrink:0}
.pc-info{flex:1;min-width:0}
.pc-title{font-size:13px;font-weight:600;color:#1e293b;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;margin-bottom:4px}
.pc-meta{font-size:11px;color:#64748b;line-height:1.6}
.pc-meta span{margin-right:10px}
.pc-bottom{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;background:#f8fafc;border-top:1px solid #f1f5f9;font-size:11px}
.pc-price{font-weight:700;color:#059669;font-size:14px}
.pc-actions a{color:#3b82f6;text-decoration:none;margin-left:8px;font-size:11px}
.pc-actions a:hover{text-decoration:underline}

.ms-product-table-wrap{background:#fff;border:1px solid #e2e8f0;border-radius:10px;overflow:hidden;max-height:calc(100vh - 200px);overflow-y:auto}
.ms-product-table{margin:0;font-size:13px}
.ms-product-table thead th{background:#f8fafc;font-size:12px;font-weight:600;color:#475569;padding:10px 12px;border-bottom:2px solid #e2e8f0;white-space:nowrap;position:sticky;top:0;z-index:2}
.ms-product-table tbody td{vertical-align:top;padding:12px 10px;border-bottom:1px solid #f1f5f9}
.ms-product-table tbody tr:hover{background:#f0f9ff}
.ms-pinfo{display:flex;gap:10px;align-items:flex-start}
.ms-thumb-wrap{display:flex;gap:4px;flex-shrink:0}
.ms-thumb-main{width:68px;height:68px;border-radius:6px;object-fit:cover;border:1px solid #e2e8f0;background:#f8fafc;cursor:pointer;transition:transform .15s}
.ms-thumb-main:hover{transform:scale(1.08)}
.ms-thumb-extra{width:30px;height:30px;border-radius:4px;object-fit:cover;border:1px solid #e2e8f0;background:#f8fafc;cursor:pointer;opacity:.8}
.ms-thumb-extra:hover{opacity:1}
.ms-details{flex:1;min-width:0}
.ms-details .ms-title{font-size:13px;font-weight:600;color:#1e293b;max-width:180px;word-break:break-word;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-bottom:2px}
.ms-details .ms-title-zh{font-size:11px;color:#64748b;max-width:180px;word-break:break-word;overflow:hidden;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;margin-bottom:2px}
.ms-details .ms-meta{font-size:11px;color:#64748b;line-height:1.7}
.ms-details .ms-meta a{color:#10b981;text-decoration:none}
.ms-details .ms-meta a:hover{text-decoration:underline}
.ms-site-row{display:flex;align-items:center;gap:6px;margin-bottom:3px;font-size:12px;line-height:1.5}
.ms-site-badge{display:inline-block;min-width:40px;text-align:center;padding:1px 6px;border-radius:4px;font-size:11px;font-weight:600;color:#fff;flex-shrink:0}
.ms-site-badge.mx{background:#10b981}.ms-site-badge.br{background:#3b82f6}.ms-site-badge.cl{background:#ef4444}.ms-site-badge.co{background:#f59e0b;color:#422006}.ms-site-badge.ar{background:#38bdf8}.ms-site-badge.uy{background:#8b5cf6}.ms-site-badge.default{background:#94a3b8}
.ms-site-price{font-weight:600;color:#059669}.ms-site-usd{color:#64748b;font-size:11px}
.ms-tag{display:inline-block;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:600;margin:1px 2px}
.ms-tag-site{background:#e0f2fe;color:#0369a1}
.ms-cat{font-size:11px;color:#475569;line-height:1.6;max-width:140px}
.ms-actions{display:flex;flex-wrap:wrap;gap:4px}
.ms-actions a,.ms-actions button{font-size:11px;padding:2px 8px;border-radius:4px;text-decoration:none;cursor:pointer;border:1px solid #e2e8f0;background:#fff;color:#3b82f6}
.ms-actions a:hover,.ms-actions button:hover{background:#f0f9ff}
.ms-actions .ms-del{color:#dc2626;border-color:#fecaca}
.ms-actions .ms-del:hover{background:#fef2f2}

.ms-inline-edit{font-size:10px;padding:0 4px;border:1px solid #d1d5db;border-radius:3px;background:#f9fafb;color:#6b7280;cursor:pointer;margin-left:3px;line-height:18px}
.ms-inline-edit:hover{background:#dbeafe;color:#2563eb;border-color:#93c5fd}

.ms-filter-bar{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.ms-filter-bar select{width:160px}

.ms-lightbox{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.85);z-index:9999;display:flex;align-items:center;justify-content:center;cursor:pointer}
.ms-lightbox img{max-width:90vw;max-height:90vh;border-radius:8px;box-shadow:0 8px 40px rgba(0,0,0,.5);object-fit:contain}
.ms-lightbox-close{position:absolute;top:20px;right:30px;color:#fff;font-size:36px;font-weight:700;cursor:pointer;line-height:1}

.ms-modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.5);z-index:9998;display:flex;align-items:center;justify-content:center}
.ms-modal{background:#fff;border-radius:12px;width:900px;max-width:95vw;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 12px 48px rgba(0,0,0,.2)}
.ms-modal-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid #e2e8f0}
.ms-modal-close{border:none;background:none;font-size:24px;color:#64748b;cursor:pointer;line-height:1}
.ms-modal-close:hover{color:#1e293b}
.ms-modal-body{padding:20px;overflow-y:auto;flex:1}
.ms-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px 20px}
.ms-detail-grid .ms-dg-label{font-size:11px;color:#64748b;font-weight:600;margin-bottom:1px}
.ms-detail-grid .ms-dg-value{font-size:13px;color:#1e293b;margin-bottom:8px;word-break:break-all}
.ms-detail-grid .ms-dg-full{grid-column:1/-1}
.ms-detail-grid .ms-dg-desc{max-height:120px;overflow-y:auto;font-size:12px;background:#f8fafc;border-radius:6px;padding:8px;line-height:1.6}
.ms-detail-images{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:12px}
.ms-detail-images img{width:100px;height:100px;border-radius:6px;object-fit:cover;border:1px solid #e2e8f0;cursor:pointer}
.ms-spid-label{font-size:10px;color:#64748b;display:block;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ms-gid-label{font-size:10px;color:#94a3b8;font-family:monospace;margin-top:1px}
.ms-src-link{display:block;font-size:10px;color:#3b82f6;text-decoration:none;word-break:break-all;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ms-src-link:hover{text-decoration:underline}

.batch-bar{display:flex;align-items:center;gap:8px;padding:8px 14px;background:#eff6ff;border:1px solid #bfdbfe;border-radius:8px}
.ms-product-table .ms-check{width:16px;height:16px;cursor:pointer}

.ship-country-card{background:#fff;border:1px solid #e2e8f0;border-radius:10px;overflow:hidden;height:100%;display:flex;flex-direction:column}
.ship-header{padding:10px 14px;color:#fff;font-weight:700;font-size:13px;display:flex;align-items:center;gap:8px;flex-shrink:0}
.ship-header img{width:24px;height:16px;border-radius:3px}
.ship-mx{background:linear-gradient(135deg,#065f46,#10b981)}.ship-br{background:linear-gradient(135deg,#1d4ed8,#60a5fa)}.ship-cl{background:linear-gradient(135deg,#7c2d12,#dc2626)}.ship-co{background:linear-gradient(135deg,#ca8a04,#f59e0b)}.ship-ar{background:linear-gradient(135deg,#0284c7,#38bdf8)}
.ship-body{padding:0;flex:1;overflow-y:auto}
.ship-body table{margin:0;font-size:12px}
.ship-body th{background:#f8fafc;font-size:11px;font-weight:600;color:#64748b;padding:6px 8px}
.ship-body td{padding:5px 8px;text-align:center}

.stat-card{background:#fff;border:1px solid #e2e8f0;border-radius:10px;padding:14px;text-align:center}
.stat-card.glass{background:linear-gradient(135deg,rgba(255,255,255,.9),rgba(241,245,249,.95));backdrop-filter:blur(6px);border:1px solid rgba(226,232,240,.6)}
.stat-card .k{font-size:24px;font-weight:700}.stat-card .l{font-size:11px;color:#64748b}

.req::after{content:" *";color:#dc2626}

.pricing-matrix th,.pricing-matrix td{font-size:13px;text-align:center;vertical-align:middle;padding:8px 10px}
.pricing-matrix td:first-child{text-align:left;min-width:200px;padding:10px 12px}
.pricing-matrix tbody tr{border-bottom:1px solid #f1f5f9}
.pricing-matrix tbody tr:last-child{border-bottom:2px solid #e2e8f0}
.pricing-matrix .price-cell{font-weight:700;color:#059669;font-size:13px}
.pricing-matrix .profit-cell{font-weight:700}
.profit-good{color:#059669}.profit-warn{color:#d97706}.profit-bad{color:#dc2626}

.calc-panel{display:block}.calc-panel.d-none{display:none!important}
.calc-tab.active{background:#3b82f6!important;color:#fff!important}

.agent-steps{max-height:440px;overflow-y:auto}
.step-card{background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:10px 14px;margin-bottom:6px}
.step-card .step-phase{font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.5px}
.step-card .step-phase.SEARCH{color:#3b82f6}.step-card .step-phase.RANK{color:#8b5cf6}.step-card .step-phase.DETAIL{color:#f59e0b}.step-card .step-phase.VERIFY_EXTRACT{color:#10b981}.step-card .step-phase.CONCLUSION{color:#ef4444}
.step-card .step-decision{font-size:11px;margin-top:3px;color:#64748b}
.step-card .step-reasoning{font-size:11px;margin-top:4px;padding:5px 8px;background:#f8fafc;border-radius:4px;white-space:pre-wrap;word-break:break-word}
.agent-status-bar{padding:10px 14px;border-radius:8px;font-weight:600}
.agent-status-bar.running{background:#dbeafe;color:#1d4ed8}.agent-status-bar.success{background:#d1fae5;color:#065f46}.agent-status-bar.error{background:#fee2e2;color:#991b1b}

.reverse-card{background:#fff;border:1px solid #e2e8f0;border-radius:10px;padding:14px}
.reverse-card .rv-label,.rv-label{font-size:11px;color:#64748b;margin-bottom:2px}
.reverse-card .rv-value{font-size:18px;font-weight:700}
.reverse-card .rv-value.highlight{color:#dc2626}.reverse-card .rv-value.safe{color:#059669}
.reverse-guidance{background:#fef3c7;border:1px solid #fbbf24;border-radius:8px;padding:10px 14px;font-weight:600;color:#92400e}

.wo-table-wrap{max-height:440px;overflow-y:auto;border:1px solid #e2e8f0;border-radius:8px}
.wo-row-ok{background:#f0fdf4}.wo-row-infringement{background:#fef2f2}.wo-row-out_of_stock{background:#fffbeb}.wo-row-no_source,.wo-row-skip{background:#f8fafc;color:#94a3b8}.wo-row-error{background:#fef2f2;color:#991b1b}
.wo-row-ok td:nth-child(10){color:#16a34a;font-weight:600}.wo-row-infringement td:nth-child(10){color:#dc2626;font-weight:600}.wo-row-out_of_stock td:nth-child(10){color:#d97706;font-weight:600}
.wo-status-icon{margin-right:3px}

.erp-product-cell{display:flex;gap:10px;align-items:flex-start}.erp-thumb{width:60px;height:60px;border-radius:6px;object-fit:cover;border:1px solid #e2e8f0;background:#f8fafc}
.erp-price-stack{font-size:12px;line-height:1.6}

.result-box{min-height:40px;background:#f8fafc;border:1px solid #dbe4ee;border-radius:8px;padding:10px;white-space:pre-wrap;word-break:break-word}
.btn-purple{background:#7c3aed;color:#fff;border:0}.btn-purple:hover{background:#6d28d9;color:#fff}

.comm-header{background:linear-gradient(135deg,#4f46e5,#7c3aed);padding:14px 20px;border-radius:10px 10px 0 0}
.comm-table-wrap{max-height:600px;overflow-y:auto;border:1px solid #e2e8f0;border-radius:0 0 8px 8px}
.comm-thead th{font-size:11px;text-align:center;vertical-align:middle;white-space:nowrap;position:sticky;top:0;z-index:2}
.comm-th-cat{background:#1e293b!important;color:#fff!important}
.comm-th-classic{background:#2563eb!important;color:#fff!important}
.comm-th-premium{background:#7c3aed!important;color:#fff!important}
#commissionTable td{font-size:12px;text-align:center;vertical-align:middle;white-space:nowrap}
#commissionTable td:first-child,#commissionTable td:nth-child(2){text-align:left;max-width:200px;overflow:hidden;text-overflow:ellipsis}
#commissionTable td:nth-child(13){text-align:left}

.src-badge{display:inline-block;font-size:10px;padding:1px 6px;border-radius:3px;font-weight:600;margin-left:4px}
.src-badge.approved{background:#d1fae5;color:#065f46}
.src-badge.pending_review{background:#fef3c7;color:#92400e}
.src-badge.no_match{background:#fee2e2;color:#991b1b}
.src-badge.rejected{background:#e2e8f0;color:#475569}
.src-badge.processing{background:#dbeafe;color:#1d4ed8}
.src-badge.error{background:#fee2e2;color:#991b1b}

.ms-actions .ms-source-btn{color:#7c3aed;border-color:#c4b5fd}
.ms-actions .ms-source-btn:hover{background:#f5f3ff}
.ms-actions .ms-calc-btn{color:#0f766e;border-color:#5eead4}
.ms-actions .ms-calc-btn:hover{background:#ecfeff}
.ms-actions .ms-source-btn.sourcing{color:#1d4ed8;border-color:#93c5fd;animation:pulse-source 1.5s infinite}
@keyframes pulse-source{0%,100%{opacity:1}50%{opacity:.5}}

.ms-inline-wrap{display:inline-flex;gap:4px;align-items:center;margin-left:8px}
.ms-price-input{width:74px;height:24px;border:1px solid #cbd5e1;border-radius:5px;padding:0 6px;font-size:11px}
.ms-save-site-price{height:24px;border:1px solid #93c5fd;background:#eff6ff;color:#1d4ed8;border-radius:5px;padding:0 8px;font-size:11px}

.batch-log-wrap{max-height:240px;overflow-y:auto;border:1px solid #e2e8f0;border-radius:8px;background:#f8fafc;padding:8px;font-size:12px}
.batch-log-wrap .bl-item{padding:3px 6px;border-bottom:1px solid #f1f5f9;display:flex;gap:8px;align-items:center}
.batch-log-wrap .bl-item:last-child{border:none}
.batch-log-wrap .bl-ok{color:#059669}.batch-log-wrap .bl-err{color:#dc2626}.batch-log-wrap .bl-nomatch{color:#d97706}

.sr-candidates-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:8px;max-height:300px;overflow-y:auto}
.sr-cand-card{border:1px solid #e2e8f0;border-radius:8px;padding:6px;text-align:center;font-size:11px;transition:all .15s;cursor:default}
.sr-cand-card.selected{border-color:#7c3aed;background:#f5f3ff;box-shadow:0 0 0 2px rgba(124,58,237,.3)}
.sr-cand-card img{width:100%;height:100px;object-fit:contain;border-radius:4px;margin-bottom:4px;background:#fff}
.sr-cand-card .c-title{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:1.3;margin-bottom:2px}
.sr-cand-card .c-price{font-weight:700;color:#059669}
.sr-cand-card .c-sales{color:#64748b}

.sr-best-match{display:flex;gap:16px;padding:16px;border:2px solid #10b981;border-radius:12px;background:#f0fdf4;margin-bottom:12px}
.sr-best-match img{width:140px;height:140px;object-fit:contain;border-radius:8px;background:#fff;border:1px solid #e2e8f0;cursor:pointer;flex-shrink:0}
.sr-best-info{flex:1}
.sr-best-info .bm-title{font-weight:700;font-size:14px;margin-bottom:6px}
.sr-best-info .bm-meta{font-size:12px;color:#475569;line-height:1.8}
.sr-best-info .bm-link{color:#3b82f6;text-decoration:none;font-size:12px}
.sr-best-info .bm-link:hover{text-decoration:underline}

.sr-actions{display:flex;gap:8px;margin-top:12px;padding-top:12px;border-top:1px solid #e2e8f0}
.sr-actions .btn{padding:8px 20px;font-weight:600}

/* Sourcing toast bar - fixed at bottom */
.sourcing-toast-bar{position:fixed;bottom:0;left:0;right:0;z-index:9999;background:linear-gradient(135deg,#4f46e5,#7c3aed);color:#fff;padding:10px 20px;box-shadow:0 -4px 20px rgba(0,0,0,.2);transition:transform .3s ease}
.sourcing-toast-bar.d-none{display:none!important}
.stb-inner{display:flex;align-items:center;gap:12px;justify-content:center;font-size:14px;font-weight:500}
.stb-spinner{width:18px;height:18px;border:2.5px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:stb-spin .8s linear infinite;flex-shrink:0}
@keyframes stb-spin{to{transform:rotate(360deg)}}
.stb-count{background:rgba(255,255,255,.2);padding:2px 10px;border-radius:12px;font-size:12px;font-weight:600}

/* Sourcing status indicator on product row */
.ms-source-btn.active-sourcing{color:#fff!important;background:#7c3aed!important;border-color:#7c3aed!important;pointer-events:none;animation:pulse-source 1.5s infinite}
.ms-source-btn.active-sourcing::before{content:"";display:inline-block;width:12px;height:12px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:stb-spin .8s linear infinite;margin-right:4px;vertical-align:middle}

/* TikTok Selection Module */
.tt-panel{min-height:200px}
.tt-route-badge{padding:3px 10px;border-radius:12px;font-size:11px;font-weight:600;text-transform:uppercase}
.tt-route-badge.video_first{background:#dbeafe;color:#1d4ed8}
.tt-route-badge.card_first{background:#dcfce7;color:#166534}
.tt-route-badge.hybrid{background:#fef3c7;color:#92400e}
.tt-route-badge.none{background:#f3f4f6;color:#6b7280}
.tt-status-badge{padding:3px 10px;border-radius:12px;font-size:11px;font-weight:600}
.tt-status-badge.approved{background:#dcfce7;color:#166534}
.tt-status-badge.rejected{background:#fee2e2;color:#991b1b}
.tt-status-badge.pending{background:#fef3c7;color:#92400e}
.tt-score-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.tt-score-card{background:#f8fafc;border-radius:10px;padding:16px}
.tt-score-card h6{font-size:13px;font-weight:700;margin-bottom:12px}
.tt-dim-bar{display:flex;align-items:center;gap:8px;margin-bottom:6px;font-size:12px}
.tt-dim-bar .label{width:100px;color:#64748b;flex-shrink:0}
.tt-dim-bar .bar{flex:1;height:8px;background:#e2e8f0;border-radius:4px;overflow:hidden}
.tt-dim-bar .bar .fill{height:100%;border-radius:4px;transition:width .3s}
.tt-dim-bar .val{width:32px;text-align:right;font-weight:600;font-size:11px}
.tt-fulfill-table{font-size:12px}
.tt-fulfill-table th{background:#f1f5f9;font-weight:600}
.tt-fulfill-table .recommended{background:#ecfdf5;font-weight:600}
.tt-big-score{font-size:48px;font-weight:800;line-height:1}
.tt-big-score.pass{color:#16a34a}
.tt-big-score.fail{color:#dc2626}
