*{box-sizing:border-box;margin:0;padding:0}body{color:#e0e0e0;background:#0f1117;margin:0}#root{min-height:100vh}.gateway-landing-root{--bg-color:#0f172a;--card-bg:#1e293bd9;--card-bg-hover:#1e293bf2;--text-color:#e2e8f0;--text-muted:#94a3b8;--text-dim:#64748b;--border-color:#94a3b826;--service-color:#f97316;--glow-r:249;--glow-g:115;--glow-b:22;background:var(--bg-color);color:var(--text-color);min-height:100vh;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Apple SD Gothic Neo,Noto Sans KR,sans-serif;position:relative;overflow-x:hidden}.gateway-landing-root:before{content:"";pointer-events:none;background-image:linear-gradient(#94a3b808 1px,#0000 1px),linear-gradient(90deg,#94a3b808 1px,#0000 1px);background-size:40px 40px;position:fixed;inset:0}.gateway-landing-root:after{content:"";pointer-events:none;background:radial-gradient(at 30% 10%,#f973161a 0%,#0000 50%),radial-gradient(at 70% 90%,#a855f70d 0%,#0000 50%);width:200%;height:200%;position:fixed;inset:-50%}.gateway-landing-root .sl-container{z-index:1;max-width:960px;margin:0 auto;padding:2rem 2rem 3rem;position:relative}.gateway-landing-root .sl-hero{text-align:center;border:1px solid var(--border-color);background:var(--card-bg);border-radius:16px;margin-bottom:2rem;padding:2.5rem 1.5rem;animation:.7s ease-out .1s backwards glFadeInUp;position:relative;overflow:hidden}.gateway-landing-root .sl-hero:before{content:"";background:linear-gradient(90deg, transparent, var(--service-color), transparent);height:2px;position:absolute;top:0;left:0;right:0}.gateway-landing-root .sl-hero h1{letter-spacing:-.03em;color:#f1f5f9;margin:0 0 .3rem;font-size:2.2rem;font-weight:800}.gateway-landing-root .sl-hero .tagline{color:var(--text-muted);margin:0 0 .4rem;font-size:.95rem;font-weight:300}.gateway-landing-root .sl-hero .desc{color:var(--text-dim);max-width:620px;margin:0 auto;font-size:.85rem;line-height:1.65}.gateway-landing-root .sl-section{margin-bottom:1.75rem}.gateway-landing-root .sl-section-title{text-transform:uppercase;letter-spacing:.12em;color:var(--service-color);border-left:2px solid var(--service-color);margin-bottom:.85rem;padding-left:.6rem;font-size:.7rem;font-weight:700}.gateway-landing-root .sl-features{grid-template-columns:repeat(3,1fr);gap:.85rem;animation:.7s ease-out .2s backwards glFadeInUp;display:grid}.gateway-landing-root .sl-feature{background:var(--card-bg);border:1px solid var(--border-color);cursor:pointer;color:inherit;border-radius:12px;padding:1rem;text-decoration:none;transition:all .25s;display:block;position:relative}.gateway-landing-root .sl-feature:hover{background:var(--card-bg-hover);border-color:#94a3b840;transform:translateY(-2px);box-shadow:0 6px 20px -6px #0000004d}.gateway-landing-root .sl-feature-icon{margin-bottom:.5rem;font-size:1.4rem;display:block}.gateway-landing-root .sl-feature-name{color:#f1f5f9;margin-bottom:.3rem;font-size:.9rem;font-weight:700}.gateway-landing-root .sl-feature-desc{color:var(--text-dim);font-size:.72rem;line-height:1.45}.gateway-landing-root .sl-feature-tag{text-transform:none;letter-spacing:.02em;color:var(--text-muted);background:#94a3b81a;border-radius:4px;align-items:center;gap:.2rem;margin-top:.6rem;padding:.2rem .5rem;font-size:.62rem;font-weight:600;display:inline-flex}.gateway-landing-root .sl-feature-tag--public{color:#10b981;background:#10b9811f}.gateway-landing-root .sl-arch{animation:.7s ease-out .3s backwards glFadeInUp}.gateway-landing-root .sl-arch-diagram{background:var(--card-bg);border:1px solid var(--border-color);border-radius:12px;flex-wrap:wrap;justify-content:center;align-items:center;gap:0;padding:1.5rem;display:flex}.gateway-landing-root .sl-arch-node{text-align:center;border:1px solid var(--border-color);background:#0f172a99;border-radius:10px;min-width:110px;padding:.75rem 1rem}.gateway-landing-root .sl-arch-node-label{color:#f1f5f9;margin-bottom:.2rem;font-size:.7rem;font-weight:700}.gateway-landing-root .sl-arch-node-tech{color:var(--text-dim);font-size:.6rem}.gateway-landing-root .sl-arch-node-tech-sub{opacity:.7;font-size:.85em}.gateway-landing-root .sl-arch-node.highlight{border-color:var(--service-color);box-shadow:0 0 12px #f973162e}.gateway-landing-root .sl-arch-arrow{color:var(--text-dim);padding:0 .6rem;font-size:1rem}.gateway-landing-root .sl-flow{animation:.7s ease-out .35s backwards glFadeInUp}.gateway-landing-root .sl-flow-steps{background:var(--card-bg);border:1px solid var(--border-color);border-radius:12px;align-items:center;gap:0;padding:1.25rem 1.5rem;display:flex;overflow-x:auto}.gateway-landing-root .sl-flow-step{text-align:center;flex-shrink:0;padding:.6rem .8rem}.gateway-landing-root .sl-flow-step-num{width:24px;height:24px;color:var(--service-color);background:#f973162e;border-radius:50%;justify-content:center;align-items:center;margin-bottom:.35rem;font-size:.65rem;font-weight:700;display:inline-flex}.gateway-landing-root .sl-flow-step-label{color:#f1f5f9;white-space:nowrap;margin-bottom:.15rem;font-size:.7rem;font-weight:600}.gateway-landing-root .sl-flow-step-desc{color:var(--text-dim);white-space:nowrap;font-size:.6rem}.gateway-landing-root .sl-flow-arrow{color:var(--text-dim);opacity:.5;flex-shrink:0;padding:0 .3rem;font-size:.85rem}.gateway-landing-root .sl-tech{animation:.7s ease-out .4s backwards glFadeInUp}.gateway-landing-root .sl-tech-list{flex-wrap:wrap;gap:.6rem;display:flex}.gateway-landing-root .sl-tech-badge{background:var(--card-bg);border:1px solid var(--border-color);color:var(--text-muted);border-radius:8px;align-items:center;gap:.3rem;padding:.4rem .75rem;font-size:.72rem;font-weight:600;transition:border-color .2s;display:inline-flex}.gateway-landing-root .sl-tech-badge:hover{border-color:#94a3b84d}.gateway-landing-root .sl-tech-dot{border-radius:50%;width:6px;height:6px}.gateway-landing-root .sl-connected{animation:.7s ease-out .45s backwards glFadeInUp}.gateway-landing-root .sl-connected-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:.7rem;display:grid}.gateway-landing-root .sl-connected-card{background:var(--card-bg);border:1px solid var(--border-color);color:inherit;border-radius:10px;align-items:center;gap:.75rem;padding:.75rem 1rem;text-decoration:none;transition:all .2s;display:flex}.gateway-landing-root .sl-connected-card:hover{background:var(--card-bg-hover);border-color:#94a3b840;transform:translateY(-1px)}.gateway-landing-root .sl-connected-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.gateway-landing-root .sl-connected-info{flex:1}.gateway-landing-root .sl-connected-name{color:#f1f5f9;font-size:.78rem;font-weight:700}.gateway-landing-root .sl-connected-role{color:var(--text-dim);font-size:.62rem}.gateway-landing-root .sl-connected-arrow{color:var(--text-dim);font-size:.8rem;transition:color .2s}.gateway-landing-root .sl-connected-card:hover .sl-connected-arrow{color:var(--service-color)}@keyframes glFadeInUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@media (width<=768px){.gateway-landing-root .sl-container{padding:1.5rem 1rem 2rem}.gateway-landing-root .sl-hero h1{font-size:1.6rem}.gateway-landing-root .sl-hero{padding:1.75rem 1rem}.gateway-landing-root .sl-features{grid-template-columns:repeat(2,1fr)}.gateway-landing-root .sl-arch-diagram{flex-direction:column;gap:0}.gateway-landing-root .sl-arch-arrow{padding:.3rem 0;transform:rotate(90deg)}}@media (width<=480px){.gateway-landing-root .sl-features,.gateway-landing-root .sl-connected-grid{grid-template-columns:1fr}.gateway-landing-root .sl-flow-steps{padding:1rem}}.cropper-container{-ms-touch-action:none;touch-action:none;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none;direction:ltr;font-size:0;line-height:0;position:relative}.cropper-container img{backface-visibility:hidden;image-orientation:0deg;width:100%;height:100%;display:block;min-width:0!important;max-width:none!important;min-height:0!important;max-height:none!important}.cropper-wrap-box,.cropper-canvas,.cropper-drag-box,.cropper-crop-box,.cropper-modal{position:absolute;inset:0}.cropper-wrap-box,.cropper-canvas{overflow:hidden}.cropper-drag-box{opacity:0;background-color:#fff}.cropper-modal{opacity:.5;background-color:#000}.cropper-view-box{outline:1px solid #3399ffbf;width:100%;height:100%;display:block;overflow:hidden}.cropper-dashed{opacity:.5;border:0 dashed #eee;display:block;position:absolute}.cropper-dashed.dashed-h{border-top-width:1px;border-bottom-width:1px;width:100%;height:33.3333%;top:33.3333%;left:0}.cropper-dashed.dashed-v{border-left-width:1px;border-right-width:1px;width:33.3333%;height:100%;top:0;left:33.3333%}.cropper-center{opacity:.75;width:0;height:0;display:block;position:absolute;top:50%;left:50%}.cropper-center:before,.cropper-center:after{content:" ";background-color:#eee;display:block;position:absolute}.cropper-center:before{width:7px;height:1px;top:0;left:-3px}.cropper-center:after{width:1px;height:7px;top:-3px;left:0}.cropper-face,.cropper-line,.cropper-point{opacity:.1;width:100%;height:100%;display:block;position:absolute}.cropper-face{background-color:#fff;top:0;left:0}.cropper-line{background-color:#39f}.cropper-line.line-e{cursor:ew-resize;width:5px;top:0;right:-3px}.cropper-line.line-n{cursor:ns-resize;height:5px;top:-3px;left:0}.cropper-line.line-w{cursor:ew-resize;width:5px;top:0;left:-3px}.cropper-line.line-s{cursor:ns-resize;height:5px;bottom:-3px;left:0}.cropper-point{opacity:.75;background-color:#39f;width:5px;height:5px}.cropper-point.point-e{cursor:ew-resize;margin-top:-3px;top:50%;right:-3px}.cropper-point.point-n{cursor:ns-resize;margin-left:-3px;top:-3px;left:50%}.cropper-point.point-w{cursor:ew-resize;margin-top:-3px;top:50%;left:-3px}.cropper-point.point-s{cursor:s-resize;margin-left:-3px;bottom:-3px;left:50%}.cropper-point.point-ne{cursor:nesw-resize;top:-3px;right:-3px}.cropper-point.point-nw{cursor:nwse-resize;top:-3px;left:-3px}.cropper-point.point-sw{cursor:nesw-resize;bottom:-3px;left:-3px}.cropper-point.point-se{cursor:nwse-resize;opacity:1;width:20px;height:20px;bottom:-3px;right:-3px}@media (width>=768px){.cropper-point.point-se{width:15px;height:15px}}@media (width>=992px){.cropper-point.point-se{width:10px;height:10px}}@media (width>=1200px){.cropper-point.point-se{opacity:.75;width:5px;height:5px}}.cropper-point.point-se:before{content:" ";opacity:0;background-color:#39f;width:200%;height:200%;display:block;position:absolute;bottom:-50%;right:-50%}.cropper-invisible{opacity:0}.cropper-bg{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABAAAAAQAQMAAAAlPW0iAAAAA3NCSVQICAjb4U/gAAAABlBMVEXMzMz////TjRV2AAAACXBIWXMAAArrAAAK6wGCiw1aAAAAHHRFWHRTb2Z0d2FyZQBBZG9iZSBGaXJld29ya3MgQ1M26LyyjAAAABFJREFUCJlj+M/AgBVhF/0PAH6/D/HkDxOGAAAAAElFTkSuQmCC)}.cropper-hide{width:0;height:0;display:block;position:absolute}.cropper-hidden{display:none!important}.cropper-move{cursor:move}.cropper-crop{cursor:crosshair}.cropper-disabled .cropper-drag-box,.cropper-disabled .cropper-face,.cropper-disabled .cropper-line,.cropper-disabled .cropper-point{cursor:not-allowed}.app{color:#e0e0e0;background:#0f1117;min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.app-header{text-align:center;border-bottom:1px solid #1e2330;padding:32px 20px 16px;position:relative}.app-back-link{color:#94a3b8;border-radius:6px;padding:4px 10px;font-size:13px;text-decoration:none;transition:color .15s,background .15s;position:absolute;top:36px;left:24px}.app-back-link:hover{color:#f97316;background:#f9731614}.app-header h1{color:#fff;margin:0;font-size:24px}.app-header p{color:#888;margin:6px 0 0;font-size:14px}.app-main{max-width:960px;margin:0 auto;padding:32px 20px}.uploader{text-align:center;cursor:pointer;border:2px dashed #2a3040;border-radius:12px;padding:64px 24px;transition:all .2s;position:relative}.uploader:hover,.uploader.dragging{background:#4a8cff0d;border-color:#4a8cff}.uploader-content{color:#888;flex-direction:column;align-items:center;gap:12px;display:flex}.uploader-content svg{color:#4a8cff}.uploader-content p{margin:0}.uploader-content .hint{color:#555;font-size:12px}.uploader input[type=file]{opacity:0;cursor:pointer;position:absolute;inset:0}.loading{color:#4a8cff;margin-top:16px;font-size:14px}.error-msg{color:#f55;margin-top:12px;font-size:14px}.btn{cursor:pointer;border:none;border-radius:8px;padding:8px 20px;font-size:14px;font-weight:500;transition:opacity .2s}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{color:#fff;background:#4a8cff}.btn-secondary{color:#ccc;background:#2a3040}.btn-accent{color:#000;background:#f59e0b}.btn-success{color:#fff;background:#10b981}.crop-editor{flex-direction:column;gap:16px;display:flex}.crop-header{align-items:center;gap:16px;display:flex}.crop-header h2{flex:1;margin:0;font-size:18px}.dim{color:#666;font-size:13px}.crop-workspace{background:#1a1d28;border-radius:8px;overflow:hidden}.crop-controls{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;display:flex}.model-select{align-items:center;gap:8px;display:flex}.model-select label{color:#888;font-size:14px}.model-select select{color:#e0e0e0;background:#1a1d28;border:1px solid #2a3040;border-radius:6px;padding:6px 12px;font-size:13px}.crop-buttons{gap:8px;display:flex}.status-bar{background:#1a1d28;border-radius:8px;align-items:center;gap:10px;padding:12px 16px;font-size:14px;display:flex}.status-bar.processing{color:#4a8cff}.spinner{border:2px solid #333;border-top-color:#4a8cff;border-radius:50%;width:16px;height:16px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.modal-overlay{z-index:100;background:#000c;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal-content{background:#1a1d28;border-radius:16px;width:100%;max-width:900px;max-height:90vh;padding:24px;overflow-y:auto}.modal-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.modal-header h2{margin:0;font-size:20px}.modal-close{color:#888;cursor:pointer;background:0 0;border:none;font-size:28px;line-height:1}.modal-close:hover{color:#fff}.result-info{gap:16px;margin-bottom:16px;font-size:14px;display:flex}.result-tabs{gap:4px;margin-bottom:16px;display:flex}.tab{color:#888;cursor:pointer;background:#0f1117;border:1px solid #2a3040;border-radius:6px;padding:8px 16px;font-size:13px;transition:all .2s}.tab.active{color:#fff;background:#4a8cff;border-color:#4a8cff}.result-preview{background:#0f1117;border-radius:8px;justify-content:center;min-height:300px;padding:16px;display:flex}.result-preview img{object-fit:contain;max-width:100%;max-height:500px}.result-preview img.checkerboard{background-image:repeating-conic-gradient(#333 0% 25%,#222 0% 50%);background-size:16px 16px}.bbox-info{color:#666;text-align:center;margin-top:12px;font-size:13px}.modal-actions{flex-wrap:wrap;justify-content:center;gap:8px;margin-top:20px;display:flex}.analyze-panel{background:#1a1d24;border:1px solid #2a3040;border-radius:12px;padding:20px}.analyze-header{flex-wrap:wrap;align-items:center;gap:16px;margin-bottom:20px;display:flex}.analyze-header h2{color:#ddd;word-break:break-all;flex:1;margin:0;font-size:18px;font-weight:500}.analyze-body{grid-template-columns:minmax(0,1.4fr) minmax(280px,1fr);gap:20px;display:grid}@media (width<=900px){.analyze-body{grid-template-columns:1fr}}.analyze-canvas{background:#0f1117;border-radius:8px;justify-content:center;align-items:center;min-height:320px;padding:12px;display:flex}.analyze-image-wrap{max-width:100%;display:inline-block;position:relative}.analyze-image{object-fit:contain;max-width:100%;max-height:70vh;display:block}.bbox-overlay{pointer-events:none;width:100%;height:100%;position:absolute;inset:0}.analyze-controls{flex-direction:column;gap:16px;display:flex}.analyze-controls .form-group{flex-direction:column;gap:6px;display:flex}.analyze-controls label{color:#aaa;font-size:13px}.analyze-controls textarea{color:#eee;resize:vertical;background:#0f1117;border:1px solid #2a3040;border-radius:6px;padding:10px;font-family:inherit;font-size:14px}.analyze-controls input[type=range]{width:100%}.analyze-controls .hint{color:#666;font-size:12px}.query-chips{flex-wrap:wrap;gap:6px;margin-top:4px;display:flex}.chip{color:#ccc;background:#0f1117;border:1px solid #2a3040;border-radius:12px;padding:3px 10px;font-size:12px}.analyze-results{flex-direction:column;gap:12px;max-height:60vh;padding-right:6px;display:flex;overflow-y:auto}.query-group h4{margin:6px 0 8px;font-size:14px}.detection-card{background:#0f1117;border:1px solid #2a3040;border-radius:8px;margin-bottom:8px;padding:10px 12px;transition:border-color .15s,transform .15s}.detection-card.highlighted{border-color:#4a8cff;transform:translateY(-1px)}.detection-head{justify-content:space-between;align-items:center;margin-bottom:8px;font-size:13px;display:flex}.color-strip{border:1px solid #2a3040;border-radius:4px;height:18px;margin-bottom:8px;display:flex;overflow:hidden}.color-swatch{height:100%}.stat-grid{grid-template-columns:1fr 1fr;gap:6px 12px;display:grid}.stat{color:#bbb;grid-template-columns:50px 1fr 36px;align-items:center;gap:6px;font-size:12px;display:grid}.stat-label{color:#888}.stat-bar{background:#2a3040;border-radius:3px;height:6px;overflow:hidden}.stat-bar-fill{background:linear-gradient(90deg,#4a8cff,#84cc16);height:100%}.stat-val{text-align:right;font-variant-numeric:tabular-nums}.mode-badge{color:#aaa;background:#1a1d24;border:1px solid #2a3040;border-radius:14px;margin-top:8px;padding:4px 12px;font-size:12px;display:inline-block}.mode-badge strong{color:#4a8cff;margin-left:4px}.btn.btn-recommended{position:relative;box-shadow:0 0 0 2px #4a8cff,0 0 16px #4a8cff73}.btn.btn-recommended:after{content:"추천";color:#fff;letter-spacing:.5px;background:#4a8cff;border-radius:8px;padding:2px 6px;font-size:10px;font-weight:600;position:absolute;top:-8px;right:-8px}.multi-uploader{flex-direction:column;gap:16px;display:flex}.multi-uploader-queue{background:#1a1d24;border:1px solid #2a3040;border-radius:12px;padding:16px}.queue-header{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:12px;display:flex}.queue-header strong{color:#ddd}.queue-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px;display:grid}.queue-item{background:#0f1117;border:1px solid #2a3040;border-radius:8px;transition:border-color .2s;position:relative;overflow:hidden}.queue-item img{object-fit:cover;width:100%;height:100px;display:block}.queue-item-overlay{pointer-events:none;height:100px;position:absolute;inset:0 0 auto}.queue-item-pending img{filter:grayscale(.4)brightness(.8)}.queue-item-uploading{border-color:#4a8cff}.queue-shimmer{background:linear-gradient(90deg,#0000 0%,#4a8cff59 50%,#0000 100%) 0 0/200% 100%;animation:1.2s linear infinite shimmer;position:absolute;inset:0}@keyframes shimmer{0%{background-position:-100% 0}to{background-position:100% 0}}.queue-item-done{border-color:#10b981}.queue-item-error{border-color:#ef4444}.queue-check{color:#fff;background:#10b981;border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;font-size:13px;font-weight:700;display:flex;position:absolute;top:6px;right:6px}.queue-error{color:#fff;background:#ef4444;border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;font-weight:700;display:flex;position:absolute;top:6px;right:6px}.queue-item-name{color:#aaa;white-space:nowrap;text-overflow:ellipsis;padding:6px 8px;font-size:11px;overflow:hidden}.queue-item-err{color:#f87171;padding:0 8px 6px;font-size:11px}.queue-item-remove{color:#fff;cursor:pointer;background:#0009;border:none;border-radius:50%;width:20px;height:20px;font-size:14px;line-height:1;position:absolute;top:4px;left:4px}.batch-analyze{flex-direction:column;gap:16px;display:flex}.batch-header{align-items:center;gap:16px;display:flex}.batch-header h2{color:#ddd;margin:0;font-size:18px}.batch-controls{background:#1a1d24;border:1px solid #2a3040;border-radius:12px;grid-template-columns:minmax(0,2fr) minmax(180px,1fr) auto;align-items:end;gap:16px;padding:16px;display:grid}@media (width<=800px){.batch-controls{grid-template-columns:1fr}}.batch-controls textarea{color:#eee;resize:vertical;background:#0f1117;border:1px solid #2a3040;border-radius:6px;width:100%;padding:8px 10px;font-family:inherit;font-size:14px}.batch-controls input[type=range]{width:100%}.batch-controls .form-group{flex-direction:column;gap:6px;display:flex}.batch-controls label{color:#aaa;font-size:12px}.batch-run-btn{white-space:nowrap}.batch-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px;display:grid}.batch-card{background:#1a1d24;border:1px solid #2a3040;border-radius:12px;flex-direction:column;transition:border-color .2s;display:flex;overflow:hidden}.batch-card-analyzing{border-color:#4a8cff}.batch-card-done{border-color:#10b981}.batch-card-error{border-color:#ef4444}.batch-card-imgwrap{background:#0f1117;position:relative}.batch-card-imgwrap img{object-fit:contain;width:100%;max-height:280px;display:block}.batch-card-veil{color:#aaa;letter-spacing:1px;background:#0f1117a6;justify-content:center;align-items:center;font-size:13px;display:flex;position:absolute;inset:0}.batch-card-veil.err{color:#f87171}.scanline{pointer-events:none;width:100%;height:100%;position:absolute;inset:0}.scanline-band{animation:2.4s ease-in-out infinite scanY}@keyframes scanY{0%{y:-14;opacity:0}10%{opacity:1}90%{opacity:1}to{y:100;opacity:0}}.batch-card-meta{border-top:1px solid #2a3040;padding:10px 12px}.batch-card-name{color:#ddd;white-space:nowrap;text-overflow:ellipsis;margin-bottom:6px;font-size:13px;overflow:hidden}.batch-card-status .err-text{color:#f87171;font-size:12px}.stage-indicator{align-items:center;gap:10px;font-size:12px;display:flex}.stage-track{gap:4px;display:flex}.stage-dot{background:#2a3040;border-radius:50%;width:8px;height:8px;transition:background .3s}.stage-dot-on{background:#4a8cff;box-shadow:0 0 8px #4a8cff}.stage-label{color:#4a8cff;font-weight:500}.stage-dots{margin-left:2px;display:inline-flex}.stage-dots span{opacity:0;animation:1.2s infinite stageDot}.stage-dots span:nth-child(2){animation-delay:.2s}.stage-dots span:nth-child(3){animation-delay:.4s}@keyframes stageDot{0%,80%,to{opacity:0}40%{opacity:1}}.batch-card-detections{border-top:1px solid #2a3040;flex-direction:column;gap:6px;padding:8px 12px 12px;display:flex}.batch-query-row{flex-direction:column;gap:4px;display:flex}.batch-query-label{font-size:12px;font-weight:600}.batch-query-cards{flex-wrap:wrap;gap:6px;display:flex}.mini-detection{color:#ccc;cursor:default;background:#0f1117;border:1px solid #2a3040;border-radius:6px;flex-direction:column;gap:4px;min-width:80px;padding:4px 8px;font-size:11px;display:flex}.mini-detection.highlighted{border-color:#4a8cff}.mini-detection-score{color:#ddd;font-weight:600}.mini-color-strip{border:1px solid #2a3040;border-radius:2px;height:8px;display:flex;overflow:hidden}.mini-color-strip>div{height:100%}.mini-stats{color:#888;gap:6px;font-size:10px;display:flex}.match-panel{background:#1a1d24;border:1px solid #2a3040;border-radius:12px;flex-direction:column;gap:16px;padding:20px;display:flex}.match-header{align-items:center;gap:16px;display:flex}.match-header h2{color:#ddd;margin:0;font-size:18px}.match-controls{grid-template-columns:minmax(0,1.5fr) minmax(180px,1fr) auto;align-items:end;gap:16px;display:grid}@media (width<=800px){.match-controls{grid-template-columns:1fr}}.match-controls .form-group{flex-direction:column;gap:6px;display:flex}.match-controls label{color:#aaa;font-size:12px}.match-controls select{color:#eee;background:#0f1117;border:1px solid #2a3040;border-radius:6px;padding:8px 10px;font-size:14px}.match-controls input[type=range]{width:100%}.match-controls .hint{color:#666;font-size:11px}.match-canvas{background:#0f1117;border-radius:8px;justify-content:center;padding:12px;display:flex}.match-image-wrap{max-width:100%;display:inline-block;position:relative}.match-image{object-fit:contain;max-width:100%;max-height:70vh;display:block}.match-stage{justify-content:center;display:flex}.stage-large .stage-dot{width:12px;height:12px}.stage-large .stage-label{font-size:14px}.match-results{flex-direction:column;gap:8px;display:flex}.match-result-summary{align-items:baseline;gap:12px;display:flex}.match-result-summary strong{color:#10b981;font-size:16px}.match-detection-list{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:8px;display:grid}.admin-root{color:#ddd;max-width:1200px;margin:0 auto;padding:24px}.admin-login{background:#1a1d24;border:1px solid #2a3040;border-radius:12px;flex-direction:column;gap:12px;max-width:360px;margin:80px auto;padding:24px;display:flex}.admin-login h1{margin:0;font-size:20px}.admin-login input{color:#eee;background:#0f1117;border:1px solid #2a3040;border-radius:6px;padding:10px;font-size:14px}.admin-header{align-items:center;gap:16px;margin-bottom:16px;display:flex}.admin-header h1{flex:1;margin:0;font-size:22px}.admin-tabs{border-bottom:1px solid #2a3040;gap:8px;margin-bottom:16px;padding-bottom:6px;display:flex}.admin-keywords,.admin-submissions{flex-direction:column;gap:16px;display:flex}.admin-create{background:#1a1d24;border:1px solid #2a3040;border-radius:8px;flex-wrap:wrap;gap:8px;padding:12px;display:flex}.admin-create input{color:#eee;background:#0f1117;border:1px solid #2a3040;border-radius:6px;flex:1;min-width:160px;padding:8px 10px;font-size:14px}.admin-keyword-list{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px;display:grid}.admin-keyword-row{cursor:pointer;background:#1a1d24;border:1px solid #2a3040;border-radius:8px;padding:12px;transition:border-color .2s;position:relative}.admin-keyword-row.selected,.admin-keyword-row:hover{border-color:#4a8cff}.admin-keyword-name{margin-bottom:4px;font-size:15px;font-weight:600}.admin-keyword-desc{color:#aaa;margin-bottom:6px;font-size:12px}.admin-keyword-stats{color:#888;gap:12px;font-size:12px;display:flex}.admin-keyword-del{padding:2px 8px;font-size:11px;position:absolute;top:8px;right:8px}.admin-ref-panel{background:#1a1d24;border:1px solid #2a3040;border-radius:8px;flex-direction:column;gap:12px;padding:16px;display:flex}.admin-ref-panel h3{margin:0;font-size:16px}.admin-add-ref-btn{cursor:pointer;align-self:flex-start}.admin-cropper{background:#0f1117;border:1px solid #2a3040;border-radius:8px;flex-direction:column;gap:10px;padding:12px;display:flex}.admin-cropper-controls{flex-wrap:wrap;gap:8px;display:flex}.admin-cropper-controls input{color:#eee;background:#0f1117;border:1px solid #2a3040;border-radius:6px;flex:1;min-width:200px;padding:8px 10px}.admin-ref-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px;display:grid}.admin-ref-thumb{background:#0f1117;border:1px solid #2a3040;border-radius:8px;flex-direction:column;display:flex;overflow:hidden}.admin-ref-thumb img{object-fit:cover;width:100%;height:140px;display:block}.admin-ref-loading{color:#666;justify-content:center;align-items:center;width:100%;height:140px;font-size:12px;display:flex}.admin-ref-meta{color:#aaa;align-items:center;gap:6px;padding:6px 8px;font-size:11px;display:flex}.admin-ref-source{border-radius:8px;padding:1px 6px;font-weight:600}.admin-ref-source-admin{color:#4a8cff;background:#4a8cff22}.admin-ref-source-user-derived{color:#10b981;background:#10b98122}.admin-ref-del{color:#888;cursor:pointer;background:0 0;border:none;margin-left:auto;font-size:16px;line-height:1}.admin-ref-del:hover{color:#f87171}.admin-sub-filter{background:#1a1d24;border:1px solid #2a3040;border-radius:8px;flex-wrap:wrap;align-items:center;gap:12px;padding:10px 12px;display:flex}.admin-sub-filter select{color:#eee;background:#0f1117;border:1px solid #2a3040;border-radius:6px;margin-left:8px;padding:6px 8px}.admin-sub-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px;display:grid}.admin-sub-card{cursor:pointer;background:#1a1d24;border:1px solid #2a3040;border-radius:8px;transition:border-color .2s;overflow:hidden}.admin-sub-card:hover{border-color:#4a8cff}.admin-sub-card img{object-fit:cover;width:100%;height:140px;display:block}.admin-sub-meta{flex-direction:column;gap:2px;padding:8px 10px;font-size:12px;display:flex}.admin-sub-promoted{color:#10b981;background:#10b98122;border-radius:4px;width:fit-content;margin-top:4px;padding:1px 6px;font-size:10px;font-weight:600;display:inline-block}.admin-sub-modal{max-width:1000px}.admin-sub-image-wrap{max-width:100%;margin:12px 0;display:inline-block;position:relative}.admin-sub-image{object-fit:contain;max-width:100%;max-height:60vh;display:block}.admin-sub-detlist{flex-direction:column;gap:6px;max-height:240px;display:flex;overflow-y:auto}.admin-sub-detrow{background:#0f1117;border:1px solid #2a3040;border-radius:6px;grid-template-columns:auto auto 1fr auto;align-items:center;gap:12px;padding:6px 10px;font-size:13px;display:grid}.admin-sub-detrow.highlighted{border-color:#4a8cff}.admin-mode-toggle{gap:6px;margin:12px 0 8px;display:flex}.admin-draw-hint{color:#cdd9ee;background:#4a8cff14;border:1px solid #4a8cff4d;border-radius:6px;margin-bottom:8px;padding:8px 12px;font-size:12px;line-height:1.5}.admin-draw-hint strong{color:#4a8cff}.admin-sub-footer{border-top:1px solid #2a3040;flex-wrap:wrap;align-items:center;gap:12px;margin-top:14px;padding-top:12px;display:flex}.admin-sub-footer .dim{flex:1;min-width:200px;font-size:11px}.btn.btn-danger{color:#fff;background:#dc2626;border:1px solid #b91c1c}.btn.btn-danger:hover:not(:disabled){background:#b91c1c}.admin-add-ref-row{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.admin-add-ref-row .dim{flex:1;min-width:200px;font-size:11px}.admin-pending-banner{border-radius:6px;margin-bottom:8px;padding:8px 12px;font-size:13px}.admin-pending-positive{color:#6ee7b7;background:#10b9811f;border:1px solid #10b98166}.admin-pending-negative{color:#fca5a5;background:#ef44441f;border:1px solid #ef444466}.admin-ref-section{margin-top:14px}.admin-ref-section h4{color:#ddd;margin:0 0 6px;font-size:14px}.admin-neg-title{color:#f87171!important}.admin-neg-hint{margin-bottom:8px;font-size:11px;line-height:1.5}.admin-ref-thumb.admin-ref-negative{border-color:#ef444480}.admin-ref-polarity-badge{color:#fff;letter-spacing:.5px;background:#ef4444;border-radius:3px;padding:1px 5px;font-size:9px;font-weight:700}.admin-polarity-row{flex-wrap:wrap;align-items:center;gap:8px;margin:8px 0;display:flex}.admin-polarity-row .tab.active.negative{background:#ef4444;border-color:#b91c1c}
