:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;font-synthesis:none;--ink:#102a43;--muted:#63778b;--paper:#fff;--canvas:#edf3f6;--line:#d6e1e7;--brand:#007f82;--brand-dark:#075f63;--brand-soft:#e3f5f3;--amber:#a55b0a;--red:#b42318;--shadow:0 20px 60px #16324617;font-family:Inter,Microsoft YaHei,PingFang SC,Segoe UI,sans-serif}*{box-sizing:border-box}body{min-width:320px;min-height:100vh;color:var(--ink);background:radial-gradient(circle at 7% 0%, #007f821f, transparent 31rem), linear-gradient(180deg, #f8fbfc 0%, var(--canvas) 100%);margin:0}button,input{font:inherit}button{border:0}.app-shell{width:min(1240px,100vw - 40px);margin:0 auto;padding:42px 0 26px}.hero{justify-content:space-between;align-items:flex-start;gap:32px;margin-bottom:24px;display:flex}.eyebrow,.section-kicker{color:var(--brand);letter-spacing:.18em;margin:0 0 8px;font-size:11px;font-weight:800}h1,h2,p{margin-top:0}h1{letter-spacing:-.035em;margin-bottom:10px;font-size:clamp(30px,4vw,46px);line-height:1.08}h2{letter-spacing:-.015em;margin-bottom:0;font-size:19px}.hero-copy{max-width:680px;color:var(--muted);margin-bottom:0;font-size:15px;line-height:1.7}.status-stack{flex-wrap:wrap;justify-content:flex-end;gap:8px;display:flex}.badge,.count-pill,.model-version,.result-tag{border:1px solid var(--line);min-height:30px;color:var(--muted);white-space:nowrap;background:#ffffffbf;border-radius:999px;justify-content:center;align-items:center;padding:5px 10px;font-size:12px;font-weight:700;display:inline-flex}.badge.success{color:var(--brand-dark);background:#edf9f7;border-color:#9bd6d1}.badge.busy{color:var(--amber);background:#fff8e9;border-color:#efc98f}.badge.error{color:var(--red);background:#fff4f2;border-color:#efb9b3}.badge.warning{color:var(--amber);background:#fff8e9;border-color:#efc98f}.panel{box-shadow:var(--shadow);background:#ffffffed;border:1px solid #becfd8cc;border-radius:18px}.model-panel{margin-bottom:18px;padding:20px 22px}.panel-heading{justify-content:space-between;align-items:center;gap:20px;display:flex}.panel-heading.compact{margin-bottom:18px}.model-version{min-height:27px;font-family:ui-monospace,SFMono-Regular,Consolas,monospace}.progress-track{background:#e9f0f3;border-radius:999px;height:7px;margin:18px 0 9px;overflow:hidden}.progress-fill{border-radius:inherit;background:linear-gradient(90deg, var(--brand), #36b9ad);width:0;height:100%;transition:width .18s;display:block}.model-meta{color:var(--muted);justify-content:space-between;gap:18px;font-size:12px;display:flex}.workspace{grid-template-columns:minmax(300px,.82fr) minmax(480px,1.4fr);align-items:start;gap:18px;display:grid}.upload-panel,.results-panel{padding:22px}.results-panel{min-height:510px}.dropzone{min-height:190px;color:var(--muted);cursor:pointer;text-align:center;background:linear-gradient(145deg,#f8fcfc,#eef7f7);border:1.5px dashed #9bb8c4;border-radius:14px;place-items:center;padding:28px;transition:all .16s;display:grid}.dropzone:hover,.dropzone.dragging{border-color:var(--brand);background:var(--brand-soft);transform:translateY(-1px)}.dropzone input{opacity:0;width:1px;height:1px;position:absolute}.dropzone strong{color:var(--ink);margin:10px 0 4px;font-size:16px}.dropzone span:last-child{font-size:12px}.drop-icon{color:#fff;background:var(--brand);border-radius:50%;place-items:center;width:42px;height:42px;font-size:24px;font-weight:300;display:grid}.actions{grid-template-columns:1fr auto;gap:10px;margin-top:14px;display:grid}.button{cursor:pointer;border-radius:10px;min-height:43px;padding:10px 17px;font-weight:750;transition:all .15s}.button.primary{color:#fff;background:var(--brand)}.button.primary:hover:not(:disabled){background:var(--brand-dark)}.button.secondary{color:var(--ink);background:#eef3f5}.button:disabled{cursor:not-allowed;opacity:.48}.message{min-height:21px;color:var(--muted);margin:12px 2px;font-size:12px;line-height:1.55}.message.error{color:var(--red)}.message.warning{color:var(--amber)}.message.success{color:var(--brand-dark)}.file-list,.result-list{gap:10px;display:grid}.file-item{border:1px solid var(--line);background:#fbfdfd;border-radius:11px;grid-template-columns:54px minmax(0,1fr) auto;align-items:center;gap:11px;padding:9px;display:grid}.file-item img{object-fit:cover;background:#dfe8ec;border-radius:7px;width:54px;height:42px}.file-info{min-width:0}.file-info strong{text-overflow:ellipsis;white-space:nowrap;font-size:12px;display:block;overflow:hidden}.file-info span,.file-index{color:var(--muted);font-size:11px}.file-index{font-family:ui-monospace,SFMono-Regular,Consolas,monospace}.empty-state{border:1px dashed var(--line);min-height:390px;color:var(--muted);text-align:center;border-radius:14px;align-content:center;place-items:center;display:grid}.empty-state span{color:var(--ink);font-weight:750}.empty-state p{margin:8px 0 0;font-size:13px}.result-card{border:1px solid var(--line);background:#fcfefe;border-radius:14px;grid-template-columns:150px minmax(0,1fr);gap:16px;padding:14px;display:grid}.result-card>img{object-fit:cover;background:#dfe8ec;border-radius:10px;width:150px;height:120px}.result-content{min-width:0}.result-heading{justify-content:space-between;align-items:center;gap:12px;display:flex}.result-heading strong{text-overflow:ellipsis;white-space:nowrap;font-size:13px;overflow:hidden}.result-tag{min-height:27px;color:var(--brand-dark);background:var(--brand-soft);border-color:#9bd6d1}.result-tag.error{color:var(--red);background:#fff4f2;border-color:#efb9b3}.confidence{color:var(--muted);margin:9px 0 11px;font-size:12px}.confidence strong{color:var(--ink);font-size:15px}.probabilities{gap:5px;display:grid}.probability-row{color:var(--muted);grid-template-columns:60px minmax(60px,1fr) 48px;align-items:center;gap:8px;font-size:10px;display:grid}.probability-row>span:last-child{text-align:right;font-variant-numeric:tabular-nums}.probability-track{background:#e7eef1;border-radius:999px;height:5px;overflow:hidden}.probability-track span{border-radius:inherit;background:linear-gradient(90deg, var(--brand), #52c4b7);height:100%;display:block}.result-error{color:var(--red);margin:12px 0 0;font-size:12px}footer{color:#738595;justify-content:space-between;gap:20px;margin-top:18px;padding:0 4px;font-size:10px;display:flex}@media (max-width:850px){.app-shell{width:min(100% - 24px,680px);padding-top:24px}.hero,footer{flex-direction:column}.status-stack{justify-content:flex-start}.workspace{grid-template-columns:1fr}.results-panel{min-height:360px}}@media (max-width:540px){.app-shell{width:min(100% - 16px,520px)}.model-panel,.upload-panel,.results-panel{border-radius:14px;padding:16px}.model-meta{flex-direction:column;align-items:flex-start;gap:3px}.result-card{grid-template-columns:1fr}.result-card>img{width:100%;height:auto;max-height:210px}.probability-row{grid-template-columns:55px minmax(50px,1fr) 45px}}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition:none!important}}
