:root{font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--color-bg:#f4f5f7;--color-surface:#fff;--color-border:#e5e7eb;--color-text:#111827;--color-text-secondary:#6b7280;--color-text-muted:#9ca3af;--color-accent:#111827;--color-on-accent:#fff;--color-accent-hover:#1f2937;--color-accent-soft:#f3f4f6;--color-live:#059669;--color-live-bg:#ecfdf5;--color-error:#dc2626;--color-error-bg:#fef2f2;--shadow-sm:0 1px 2px #0000000a;--shadow-md:0 4px 16px #0000000f;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;font-weight:400;line-height:1.5}[data-theme=dark]{--color-bg:#0f1117;--color-surface:#1a1d27;--color-border:#2d3348;--color-text:#f3f4f6;--color-text-secondary:#9ca3af;--color-text-muted:#6b7280;--color-accent:#f9fafb;--color-on-accent:#111827;--color-accent-hover:#e5e7eb;--color-accent-soft:#252836;--color-live:#34d399;--color-live-bg:#064e3b33;--color-error:#f87171;--color-error-bg:#450a0a66;--shadow-sm:0 1px 2px #0003;--shadow-md:0 4px 16px #00000059}*,:before,:after{box-sizing:border-box}body{min-width:320px;min-height:100vh;color:var(--color-text);background:var(--color-bg);margin:0}#root{width:100%;min-height:100vh}a{color:inherit;text-decoration:none}button{font-family:inherit}.app{flex-direction:column;max-width:1100px;min-height:100vh;margin:0 auto;padding:24px 20px 32px;display:flex}.app-header{justify-content:space-between;align-items:center;gap:16px;margin-bottom:28px;display:flex}.app-brand{align-items:center;gap:14px;display:flex}.app-brand__icon{border-radius:var(--radius-md);background:var(--color-accent);width:44px;height:44px;color:var(--color-on-accent);flex-shrink:0;justify-content:center;align-items:center;display:flex}.app-brand__icon svg{width:22px;height:22px}.app-brand__title{letter-spacing:-.02em;margin:0;font-size:20px;font-weight:600;line-height:1.2}.app-brand__subtitle{color:var(--color-text-secondary);margin:2px 0 0;font-size:13px;font-weight:400}.status-badge{letter-spacing:.01em;background:var(--color-accent-soft);color:var(--color-text-secondary);border:1px solid var(--color-border);white-space:nowrap;border-radius:100px;align-items:center;gap:7px;padding:6px 12px;font-size:12px;font-weight:500;display:inline-flex}.status-badge--live{background:var(--color-live-bg);color:var(--color-live);border-color:#a7f3d0}.status-badge__dot{background:var(--color-text-muted);border-radius:50%;width:7px;height:7px}.status-badge--live .status-badge__dot{background:var(--color-live);animation:2s ease-in-out infinite pulse-dot;box-shadow:0 0 0 3px #05966933}.status-badge--paused{color:#d97706;background:#fffbeb;border-color:#fde68a}.status-badge--paused .status-badge__dot{background:#d97706}.status-badge--ready{background:var(--color-accent-soft);color:var(--color-text-secondary);border-color:var(--color-border)}.status-badge--ready .status-badge__dot{background:var(--color-text-muted)}.app-header__actions{align-items:center;gap:10px;display:flex}.app-header__help{color:var(--color-text-secondary);gap:5px;font-size:12px;font-weight:500}.app-header__help:hover:not(:disabled){color:var(--color-text)}.fps-badge{font-variant-numeric:tabular-nums;color:var(--color-text-muted);background:var(--color-accent-soft);border:1px solid var(--color-border);border-radius:6px;padding:4px 8px;font-size:11px;font-weight:600}.app-main{flex:1;grid-template-columns:1fr;gap:12px;display:grid}@media (width>=768px){.app-main{grid-template-columns:minmax(0,1fr) 240px;align-items:start;gap:14px}}.app-footer{border-top:1px solid var(--color-border);flex-direction:column;align-items:center;gap:6px;margin-top:28px;padding-top:20px;display:flex}.app-footer__link{color:var(--color-text-secondary);font-size:13px;font-weight:500;transition:color .15s}.app-footer__link:hover{color:var(--color-text)}.app-footer__tip{color:var(--color-text-muted);margin:0;font-size:12px}.btn{border-radius:var(--radius-sm);cursor:pointer;white-space:nowrap;border:1px solid #0000;justify-content:center;align-items:center;gap:7px;padding:9px 16px;font-family:inherit;font-size:13px;font-weight:500;line-height:1;transition:background .15s,border-color .15s,color .15s;display:inline-flex}.btn:disabled{opacity:.45;cursor:not-allowed}.btn--primary{background:var(--color-accent);color:var(--color-on-accent);border-color:var(--color-accent);padding:12px 24px;font-size:14px}.btn--primary:hover:not(:disabled){background:var(--color-accent-hover);border-color:var(--color-accent-hover)}.btn--secondary{background:var(--color-surface);color:var(--color-text);border-color:var(--color-border)}.btn--secondary:hover:not(:disabled){background:var(--color-bg);border-color:var(--color-text-muted)}.btn--ghost{color:var(--color-text-secondary);background:0 0;border-color:#0000}.btn--ghost:hover:not(:disabled){background:var(--color-accent-soft);color:var(--color-text)}.btn--icon{padding:8px}.btn--sm{flex-shrink:0;padding:7px 12px;font-size:12px}.btn--compact{gap:5px;padding:5px 10px;font-size:11px}.btn--compact.btn--icon{padding:5px 7px}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.5}}@media (width<=480px){.app{padding:16px 14px 24px}.app-header{flex-wrap:wrap;margin-bottom:20px}.app-brand__title{font-size:18px}}.viewport-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden}.viewport-card__header{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;padding:14px 18px;display:flex}.viewport-card__label{color:var(--color-text);letter-spacing:-.01em;margin:0;font-size:13px;font-weight:600}.viewport-card__meta{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.06em;font-size:11px;font-weight:500}.video-wrap{aspect-ratio:4/3;background:#0a0a0a;position:relative}.video-wrap video,.video-wrap img{object-fit:cover;width:100%;height:100%;display:block}.video-wrap img{object-fit:contain;background:#0a0a0a}.video-wrap__source--hidden{display:none!important}.video-wrap canvas{pointer-events:none;width:100%;height:100%;position:absolute;inset:0}.video-wrap__overlay{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);color:#fff;letter-spacing:.04em;text-transform:uppercase;background:#00000073;justify-content:center;align-items:center;font-size:15px;font-weight:600;display:flex;position:absolute;inset:0}.video-wrap:fullscreen{aspect-ratio:unset;background:#000;width:100vw;height:100vh}:is(.video-wrap:fullscreen video,.video-wrap:fullscreen canvas){object-fit:contain}.results-panel{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);flex-direction:column;min-height:0;display:flex}.results-panel__header{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;gap:8px;padding:8px 10px;display:flex}.results-panel__title{letter-spacing:-.01em;align-items:center;gap:6px;margin:0;font-size:12px;font-weight:600;display:flex}.results-panel__count{background:var(--color-accent-soft);min-width:18px;height:18px;color:var(--color-text-secondary);border-radius:100px;justify-content:center;align-items:center;padding:0 5px;font-size:10px;font-weight:600;display:inline-flex}.results-panel__body{flex-direction:column;flex:1;gap:4px;max-height:min(320px,40vh);padding:6px;display:flex;overflow-y:auto}.prediction{background:var(--color-bg);border-radius:6px;flex-direction:column;gap:4px;padding:6px 8px;display:flex}.prediction__row{justify-content:space-between;align-items:center;gap:6px;display:flex}.prediction__label{color:var(--color-text);text-transform:capitalize;text-overflow:ellipsis;white-space:nowrap;font-size:12px;font-weight:600;overflow:hidden}.prediction__score{color:var(--color-text-secondary);font-variant-numeric:tabular-nums;flex-shrink:0;font-size:11px;font-weight:600}.prediction__bar{background:var(--color-border);border-radius:100px;height:3px;overflow:hidden}.prediction__bar-fill{background:var(--color-accent);border-radius:100px;height:100%;transition:width .3s}.empty-state{text-align:center;padding:16px 8px}.empty-state__text{color:var(--color-text-muted);margin:0;font-size:11px}.history{border-top:1px solid var(--color-border);margin-top:4px;padding-top:6px}.history__title{text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted);margin:0 0 4px;padding:0 2px;font-size:9px;font-weight:600}.history__list{flex-direction:column;gap:3px;margin:0;padding:0;list-style:none;display:flex}.history__item{background:var(--color-bg);border-radius:4px;justify-content:space-between;align-items:center;gap:4px;padding:4px 6px;font-size:10px;line-height:1.3;display:flex}.history__label{text-transform:capitalize;color:var(--color-text);text-overflow:ellipsis;white-space:nowrap;min-width:0;font-weight:600;overflow:hidden}.history__meta{color:var(--color-text-muted);font-variant-numeric:tabular-nums;white-space:nowrap;flex-shrink:0;font-size:9px}@media (width>=768px){.results-panel{width:100%;max-width:240px}}.controls{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);flex-direction:column;gap:8px;margin-bottom:14px;padding:10px 12px;display:flex}.controls__bar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;display:flex}.controls__toggles,.controls__actions{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.controls__row{flex-wrap:wrap;gap:6px;display:flex}.controls__slider{align-items:center;gap:10px;display:flex}.controls__slider label{color:var(--color-text-secondary);white-space:nowrap;flex-shrink:0;align-items:center;gap:6px;margin:0;font-size:11px;font-weight:500;display:flex}.controls__slider-value{color:var(--color-text);font-variant-numeric:tabular-nums;font-weight:600}.controls__slider input[type=range]{appearance:none;background:var(--color-border);cursor:pointer;border-radius:100px;outline:none;flex:1;min-width:80px;height:3px}.controls__slider input[type=range]::-webkit-slider-thumb{appearance:none;background:var(--color-accent);cursor:pointer;border:2px solid #fff;border-radius:50%;width:14px;height:14px;box-shadow:0 1px 3px #00000026}.controls__slider input[type=range]:disabled{opacity:.45;cursor:not-allowed}.segmented{background:var(--color-bg);border:1px solid var(--color-border);border-radius:6px;gap:2px;padding:2px;display:flex}.segmented--compact .segmented__btn{border-radius:4px;padding:4px 10px;font-size:11px}.segmented--3 .segmented__btn{flex:1;padding-left:6px;padding-right:6px}.segmented__btn{color:var(--color-text-secondary);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-radius:6px;flex:1;padding:6px 12px;font-family:inherit;font-size:12px;font-weight:500;transition:background .15s,color .15s}.segmented__btn:hover:not(:disabled){color:var(--color-text)}.segmented__btn--active{background:var(--color-surface);color:var(--color-text);box-shadow:var(--shadow-sm)}.segmented__btn:disabled{opacity:.45;cursor:not-allowed}.segmented--engines .segmented__btn{padding-left:8px;padding-right:8px}.segmented--disabled{opacity:.55}.btn--active{border-color:var(--color-accent);color:var(--color-accent)}@media (width<=640px){.controls__bar{flex-direction:column;align-items:stretch}.controls__toggles{width:100%}.controls__toggles .segmented{flex:1}.controls__actions{width:100%}.controls__actions .btn--compact{flex:1;justify-content:center}.controls__actions .btn--icon{flex:0}}.error-banner{border-radius:var(--radius-md);background:var(--color-error-bg);border:1px solid color-mix(in srgb, var(--color-error) 35%, transparent);color:var(--color-error);align-items:flex-start;gap:12px;margin-top:20px;padding:14px 16px;font-size:14px;line-height:1.5;display:flex}.error-banner svg{flex-shrink:0;margin-top:1px}.error-banner__content{flex:1;min-width:0}.error-banner__message{margin:0}.error-banner__hint{opacity:.85;margin:6px 0 0;font-size:12px}.error-banner--inline{margin-top:0;margin-bottom:16px}.loading-screen{z-index:9999;background:var(--color-bg);justify-content:center;align-items:center;animation:.4s loading-fade-in;display:flex;position:fixed;inset:0}.loading-screen__content{-webkit-user-select:none;user-select:none;flex-direction:column;align-items:center;display:flex}.loading-screen__logo{width:56px;height:56px;color:var(--color-text);opacity:0;margin-bottom:20px;animation:.6s .1s forwards loading-rise}.loading-screen__title{letter-spacing:-.03em;color:var(--color-text);opacity:0;margin:0;font-size:28px;font-weight:600;animation:.6s .2s forwards loading-rise}.loading-screen__subtitle{letter-spacing:.12em;text-transform:uppercase;color:var(--color-text-muted);opacity:0;margin:4px 0 32px;font-size:13px;font-weight:500;animation:.6s .3s forwards loading-rise}.loading-screen__spinner{opacity:0;width:36px;height:36px;margin-bottom:24px;animation:.6s .4s forwards loading-rise;position:relative}.loading-screen__spinner-ring{border:2px solid var(--color-border);border-top-color:var(--color-accent);border-radius:50%;animation:.8s linear infinite loading-spin;position:absolute;inset:0}.loading-screen__status{color:var(--color-text-secondary);opacity:0;margin:0;font-size:14px;font-weight:400;animation:.6s .5s forwards loading-rise}.loading-screen__dots span{animation:1.4s ease-in-out infinite loading-dot}.loading-screen__dots span:nth-child(2){animation-delay:.2s}.loading-screen__dots span:nth-child(3){animation-delay:.4s}@keyframes loading-fade-in{0%{opacity:0}to{opacity:1}}@keyframes loading-rise{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes loading-spin{to{transform:rotate(360deg)}}@keyframes loading-dot{0%,80%,to{opacity:0}40%{opacity:1}}@media (prefers-reduced-motion:reduce){.loading-screen,.loading-screen__logo,.loading-screen__title,.loading-screen__subtitle,.loading-screen__spinner,.loading-screen__status,.loading-screen__spinner-ring,.loading-screen__dots span,.status-badge--live .status-badge__dot{opacity:1!important;animation:none!important;transform:none!important}}.permission-screen{background:var(--color-bg);justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.permission-screen__topbar{z-index:1;position:absolute;top:16px;right:20px}.permission-screen__card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);width:100%;max-width:420px;box-shadow:var(--shadow-md);text-align:center;padding:40px 32px}.permission-screen__icon{border-radius:var(--radius-md);background:var(--color-accent);width:56px;height:56px;color:var(--color-on-accent);justify-content:center;align-items:center;margin-bottom:20px;display:inline-flex}.permission-screen__icon svg{width:28px;height:28px}.permission-screen__title{letter-spacing:-.02em;margin:0 0 10px;font-size:24px;font-weight:600}.permission-screen__desc{color:var(--color-text-secondary);margin:0 0 20px;font-size:14px;line-height:1.6}.permission-screen__features{text-align:left;flex-direction:column;gap:10px;margin:0 0 28px;padding:0;list-style:none;display:flex}.permission-screen__features li{color:var(--color-text-secondary);padding-left:22px;font-size:13px;position:relative}.permission-screen__features li:before{content:"";background:var(--color-live);border-radius:50%;width:8px;height:8px;position:absolute;top:7px;left:0}.permission-screen__error{border-radius:var(--radius-sm);background:var(--color-error-bg);border:1px solid var(--color-error);color:var(--color-error);text-align:left;margin:0 0 20px;padding:12px 14px;font-size:13px;line-height:1.5}.permission-screen__error p{margin:0 0 10px}.permission-screen__error-hint{opacity:.9;font-size:12px}.permission-screen__error p:last-child{margin-bottom:0}.permission-screen__error .btn{margin-top:4px}.permission-screen__note{color:var(--color-text-muted);margin:16px 0 0;font-size:11px;line-height:1.5}.permission-screen__actions{flex-direction:column;gap:10px;display:flex}.modal-backdrop{z-index:10000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0006;justify-content:center;align-items:center;padding:24px;animation:.2s loading-fade-in;display:flex;position:fixed;inset:0}.modal{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);width:100%;max-width:440px;box-shadow:var(--shadow-md);overflow:hidden}.modal--wide{flex-direction:column;max-width:520px;max-height:min(80vh,640px);display:flex}.modal--wide .modal__body{flex-direction:column;min-height:0;display:flex;overflow:hidden}.modal__hint{font-size:12px;margin:0 0 12px!important}.class-ref__toolbar{gap:8px;margin-bottom:12px;display:flex}.class-ref__search{border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg);min-width:0;color:var(--color-text);flex:1;padding:8px 10px;font-family:inherit;font-size:13px}.class-ref__actions{flex-shrink:0;gap:4px;display:flex}.class-ref__list{grid-template-columns:repeat(2,1fr);gap:2px 12px;margin:0;padding:0;font-size:12px;list-style:none;display:grid;overflow-y:auto}.class-ref__item{cursor:pointer;color:var(--color-text);align-items:center;gap:6px;padding:4px 0;display:flex}.class-ref__item input{flex-shrink:0;margin:0}@media (width<=400px){.class-ref__list{grid-template-columns:1fr}}.modal__header{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;padding:18px 20px;display:flex}.modal__header h2{margin:0;font-size:16px;font-weight:600}.modal__body{color:var(--color-text-secondary);padding:20px;font-size:14px;line-height:1.6}.modal__body p{margin:0 0 16px}.modal__highlight{border-radius:var(--radius-sm);background:var(--color-live-bg);color:var(--color-text);border:1px solid #a7f3d0;gap:12px;margin-bottom:16px;padding:14px;display:flex}.modal__highlight svg{color:var(--color-live);flex-shrink:0;margin-top:2px}.modal__highlight strong{margin-bottom:4px;font-size:13px;display:block}.modal__highlight p{color:var(--color-text-secondary);margin:0;font-size:12px}.modal__list{flex-direction:column;gap:6px;margin:0;padding-left:18px;font-size:13px;display:flex}.modal--help{max-width:560px;max-height:min(85vh,720px)}.modal__body--scroll{max-height:calc(85vh - 64px);overflow-y:auto}.help-section{margin-bottom:20px}.help-section:last-child{margin-bottom:0}.help-section__title{color:var(--color-text);letter-spacing:.01em;margin:0 0 8px;font-size:13px;font-weight:600}.help-section__body{color:var(--color-text-secondary);font-size:13px;line-height:1.55}.help-section__body p{margin:0}.help-list{flex-direction:column;gap:6px;margin:0;padding-left:18px;display:flex}.help-list--ordered{padding-left:20px}.help-list li{padding-left:2px}.help-note{color:var(--color-text-muted);font-size:12px;font-style:italic;margin:10px 0 0!important}.custom-onnx__field{margin-bottom:14px}.custom-onnx__field label{color:var(--color-text-secondary);margin-bottom:6px;font-size:12px;font-weight:500;display:block}.custom-onnx__field input[type=file]{width:100%;font-size:12px}.custom-onnx__modes{border:none;margin:0 0 14px;padding:0}.custom-onnx__modes legend{color:var(--color-text-secondary);margin-bottom:8px;font-size:12px;font-weight:500}.custom-onnx__modes label{color:var(--color-text);cursor:pointer;align-items:center;gap:8px;margin-bottom:6px;font-size:13px;display:flex}.custom-onnx__error{color:#b91c1c;border-radius:var(--radius-sm);background:#fef2f2;border:1px solid #fecaca;margin:0 0 12px;padding:10px 12px;font-size:12px}.custom-onnx__actions{justify-content:flex-end;gap:8px;margin-top:8px;display:flex}.modal__body code{background:var(--color-bg);border:1px solid var(--color-border);border-radius:4px;padding:1px 4px;font-size:11px}@media (prefers-reduced-motion:reduce){.modal-backdrop{opacity:1!important;animation:none!important;transform:none!important}}
