@import url(https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap);body{-moz-osx-font-smoothing:grayscale;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}:root{--primary:#6366f1;--primary-hover:#4f46e5;--primary-glow:#6366f140;--secondary:#94a3b8;--success:#10b981;--success-bg:#10b98114;--success-border:#10b98133;--danger:#ef4444;--danger-bg:#ef444414;--danger-border:#ef444433;--warning:#f59e0b;--warning-bg:#f59e0b14;--bg-primary:#0f172a;--bg-secondary:#1e293b;--bg-card:#1e293bb3;--bg-elevated:#33415580;--text-primary:#f1f5f9;--text-secondary:#94a3b8;--text-muted:#64748b;--border-color:#94a3b81f;--border-active:#6366f166;--glass-bg:#1e293b8c;--glass-border:#94a3b81a;--glass-blur:16px;--shadow-sm:0 1px 3px #0000004d;--shadow-md:0 4px 12px #00000040;--shadow-lg:0 8px 32px #0000004d;--shadow-glow:0 0 40px var(--primary-glow);--radius-sm:8px;--radius-md:14px;--radius-lg:20px;--radius-full:9999px}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;background:#0f172a;background:var(--bg-primary);color:#f1f5f9;color:var(--text-primary);font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;min-height:100vh;overflow-x:hidden}body:before{background:radial-gradient(ellipse at 20% 20%,#6366f114 0,#0000 50%),radial-gradient(ellipse at 80% 80%,#10b9810f 0,#0000 50%),radial-gradient(ellipse at 50% 50%,#ef44440a 0,#0000 70%);content:"";inset:0;pointer-events:none;position:fixed;z-index:0}.app-container{display:flex;flex-direction:column;min-height:100vh;position:relative;z-index:1}.navbar{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(var(--glass-blur));backdrop-filter:blur(var(--glass-blur));background:#1e293b8c;background:var(--glass-bg);border-bottom:1px solid #94a3b81a;border-bottom:1px solid var(--glass-border);justify-content:space-between;padding:.75rem 2rem;position:-webkit-sticky;position:sticky;top:0;z-index:100}.logo,.navbar{align-items:center;display:flex}.logo{gap:.75rem}.logo-icon{align-items:center;background:linear-gradient(135deg,#6366f1,#818cf8);background:linear-gradient(135deg,var(--primary),#818cf8);border-radius:8px;border-radius:var(--radius-sm);display:flex;font-size:1.5rem;height:38px;justify-content:center;width:38px}.logo h1{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#e0e7ff,#c7d2fe,#a5b4fc);-webkit-background-clip:text;font-size:1.25rem;font-weight:700;letter-spacing:-.025em;margin:0}.mode-toggle{background:#0f172a99;border:1px solid #94a3b81f;border:1px solid var(--border-color);border-radius:9999px;border-radius:var(--radius-full);gap:2px;padding:4px}.mode-btn,.mode-toggle{display:flex;position:relative}.mode-btn{align-items:center;background:#0000;border:none;border-radius:9999px;border-radius:var(--radius-full);color:#64748b;color:var(--text-muted);cursor:pointer;font-family:inherit;font-size:.82rem;font-weight:600;gap:.4rem;padding:.45rem 1.1rem;transition:color .3s;z-index:2}.mode-btn.active{color:#f1f5f9;color:var(--text-primary)}.mode-icon{font-size:.9rem}.mode-slider{background:#33415580;background:var(--bg-elevated);border:1px solid #6366f133;border-radius:9999px;border-radius:var(--radius-full);box-shadow:0 0 12px #6366f11a;height:calc(100% - 8px);position:absolute;top:4px;transition:left .35s cubic-bezier(.16,1,.3,1);width:calc(50% - 5px);z-index:1}.mode-slider.left{left:4px}.mode-slider.right{left:calc(50% + 1px)}.main-content{align-items:center;display:flex;flex:1 1;flex-direction:column;gap:2rem;margin:0 auto;max-width:620px;padding:2.5rem 1.5rem;width:100%}.card{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(var(--glass-blur));backdrop-filter:blur(var(--glass-blur));background:#1e293bb3;background:var(--bg-card);border:1px solid #94a3b81f;border:1px solid var(--border-color);border-radius:20px;border-radius:var(--radius-lg);box-shadow:0 4px 12px #00000040;box-shadow:var(--shadow-md);padding:2rem;text-align:center;transition:box-shadow .3s ease,border-color .3s ease;width:100%}.card:hover{border-color:#94a3b82e;box-shadow:0 8px 32px #0000004d;box-shadow:var(--shadow-lg)}.card h2{font-size:1.5rem;font-weight:700;letter-spacing:-.025em;margin:0 0 .25rem}.subtitle{color:#94a3b8;color:var(--text-secondary);font-size:.9rem;margin-bottom:1.75rem}.drop-zone{align-items:center;background:#0f172a66;border:2px dashed #94a3b81f;border:2px dashed var(--border-color);border-radius:14px;border-radius:var(--radius-md);cursor:pointer;display:flex;justify-content:center;min-height:220px;padding:2.5rem 2rem;position:relative;transition:all .25s ease}.drop-zone.active,.drop-zone:hover{background:#6366f10f;border-color:#6366f1;border-color:var(--primary);box-shadow:inset 0 0 30px #6366f10d}.drop-zone.has-preview{background:#000;border-color:#94a3b81f;border-color:var(--border-color);border-style:solid;overflow:hidden;padding:0}.hidden-input{display:none}.drop-zone-content{align-items:center;display:flex;flex-direction:column;gap:.5rem}.upload-icon{filter:grayscale(.2);font-size:3rem;margin-bottom:.5rem}.drop-zone-content p{color:#94a3b8;color:var(--text-secondary);font-size:.9rem}.drop-zone-content p strong{color:#6366f1;color:var(--primary);font-weight:600}.file-hint{color:#64748b!important;color:var(--text-muted)!important;font-size:.8rem!important;margin-top:.25rem}.drag-overlay{align-items:center;background:#6366f11f;border-radius:12px;border-radius:calc(var(--radius-md) - 2px);color:#6366f1;color:var(--primary);display:flex;font-size:1.1rem;font-weight:600;inset:0;justify-content:center;pointer-events:none;position:absolute}.preview-container{height:100%;position:relative;width:100%}.preview-image{display:block;height:100%;max-height:280px;object-fit:contain;width:100%}.remove-btn{align-items:center;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0009;border:1px solid #ffffff26;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:1.2rem;height:32px;justify-content:center;position:absolute;right:10px;top:10px;transition:all .2s;width:32px}.remove-btn:hover{background:#ef4444cc;transform:scale(1.1)}.analyze-btn{align-items:center;background:linear-gradient(135deg,#6366f1,#818cf8);background:linear-gradient(135deg,var(--primary),#818cf8);border:none;border-radius:14px;border-radius:var(--radius-md);color:#fff;cursor:pointer;display:flex;font-family:inherit;font-size:1rem;font-weight:600;gap:.5rem;justify-content:center;letter-spacing:.01em;margin-top:1.5rem;overflow:hidden;padding:.9rem;position:relative;transition:all .25s ease;width:100%}.analyze-btn:before{background:linear-gradient(135deg,#0000,#ffffff1a);content:"";inset:0;opacity:0;position:absolute;transition:opacity .25s}.analyze-btn:hover:not(:disabled):before{opacity:1}.analyze-btn:disabled{background:#33415580;background:var(--bg-elevated);color:#64748b;color:var(--text-muted);cursor:not-allowed}.analyze-btn:hover:not(:disabled){box-shadow:0 0 40px #6366f140;box-shadow:var(--shadow-glow);transform:translateY(-1px)}.analyze-btn:active:not(:disabled){transform:translateY(0)}.analyze-btn.live-start{background:linear-gradient(135deg,#10b981,#34d399);background:linear-gradient(135deg,var(--success),#34d399)}.analyze-btn.live-start:hover:not(:disabled){box-shadow:0 0 40px #10b9814d}.analyze-btn.live-stop{background:linear-gradient(135deg,#ef4444,#f87171);background:linear-gradient(135deg,var(--danger),#f87171)}.analyze-btn.live-stop:hover:not(:disabled){box-shadow:0 0 40px #ef44444d}.analyze-btn.secondary-btn{background:#33415580;background:var(--bg-elevated);border:1px solid #94a3b81f;border:1px solid var(--border-color);color:#94a3b8;color:var(--text-secondary);flex:0 0 auto;padding:.9rem 1.5rem;width:auto}.analyze-btn.secondary-btn:hover{border-color:#64748b;border-color:var(--text-muted);box-shadow:none;color:#f1f5f9;color:var(--text-primary)}.btn-icon{font-size:1rem}.controls-row{display:flex;gap:.75rem;margin-top:1.5rem}.controls-row .analyze-btn{flex:1 1;margin-top:0}.spinner{animation:spin .7s linear infinite;border:3px solid #fff3;border-radius:50%;border-top-color:#fff;height:20px;width:20px}@keyframes spin{to{transform:rotate(1turn)}}.error-message{background:#ef444414;background:var(--danger-bg);border:1px solid #ef444433;border:1px solid var(--danger-border);border-radius:8px;border-radius:var(--radius-sm);color:#ef4444;color:var(--danger);font-size:.85rem;margin-top:1rem;padding:.75rem 1rem;text-align:left}.camera-viewport{align-items:center;background:#0f172a99;border:2px solid #94a3b81f;border:2px solid var(--border-color);border-radius:14px;border-radius:var(--radius-md);display:flex;justify-content:center;min-height:300px;overflow:hidden;position:relative;transition:border-color .3s}.camera-viewport.active{border-color:#6366f14d}.camera-feed{display:block;height:auto;max-height:400px;object-fit:cover;width:100%}.hidden-canvas{display:none}.camera-placeholder{align-items:center;cursor:pointer;display:flex;flex-direction:column;gap:.5rem;inset:0;justify-content:center;padding:2rem;position:absolute;transition:background .2s}.camera-placeholder:hover{background:#6366f10f}.camera-placeholder-icon{animation:pulse 2s ease-in-out infinite;font-size:3.5rem;margin-bottom:.5rem}.camera-placeholder p{color:#94a3b8;color:var(--text-secondary);font-size:.9rem}.camera-placeholder p strong{color:#6366f1;color:var(--primary)}@keyframes pulse{0%,to{opacity:.9;transform:scale(1)}50%{opacity:1;transform:scale(1.08)}}.scan-overlay{inset:0;pointer-events:none;position:absolute;z-index:5}.scan-line{animation:scanMove 2.5s ease-in-out infinite;background:linear-gradient(90deg,#0000,#6366f1,#6366f1cc,#6366f1,#0000);background:linear-gradient(90deg,#0000,var(--primary),#6366f1cc,var(--primary),#0000);box-shadow:0 0 15px #6366f140,0 0 30px #6366f126;box-shadow:0 0 15px var(--primary-glow),0 0 30px #6366f126;height:2px;left:5%;position:absolute;right:5%}@keyframes scanMove{0%,to{top:10%}50%{top:85%}}.scan-corner{border-color:#6366f1;border-color:var(--primary);border-style:solid;border-width:0;height:20px;position:absolute;width:20px}.scan-corner.tl{border-left-width:3px;border-radius:4px 0 0 0;border-top-width:3px;left:8px;top:8px}.scan-corner.tr{border-radius:0 4px 0 0;border-right-width:3px;border-top-width:3px;right:8px;top:8px}.scan-corner.bl{border-bottom-width:3px;border-left-width:3px;border-radius:0 0 0 4px;bottom:8px;left:8px}.scan-corner.br{border-bottom-width:3px;border-radius:0 0 4px 0;border-right-width:3px;bottom:8px;right:8px}.live-badge{align-items:center;animation:fadeIn .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#000000b3;border:1px solid #ffffff1a;border-radius:9999px;border-radius:var(--radius-full);bottom:12px;display:flex;font-size:.8rem;font-weight:600;gap:.5rem;left:12px;padding:.45rem .9rem;position:absolute;z-index:10}.live-badge.normal{border-color:#10b98166;color:#10b981;color:var(--success)}.live-badge.defect{border-color:#ef444466;color:#ef4444;color:var(--danger)}.live-badge-dot{animation:blink 1.2s ease-in-out infinite;border-radius:50%;height:8px;width:8px}.live-badge.normal .live-badge-dot{background:#10b981;background:var(--success);box-shadow:0 0 6px #10b981;box-shadow:0 0 6px var(--success)}.live-badge.defect .live-badge-dot{background:#ef4444;background:var(--danger);box-shadow:0 0 6px #ef4444;box-shadow:0 0 6px var(--danger)}@keyframes blink{0%,to{opacity:1}50%{opacity:.3}}.fps-counter{font-feature-settings:"tnum";-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#0009;border:1px solid #ffffff14;border-radius:8px;border-radius:var(--radius-sm);color:#64748b;color:var(--text-muted);font-size:.7rem;font-variant-numeric:tabular-nums;font-weight:600;padding:.25rem .6rem;position:absolute;right:10px;top:10px;z-index:10}.speed-control{background:#33415580;background:var(--bg-elevated);border:1px solid #94a3b81f;border:1px solid var(--border-color);border-radius:14px;border-radius:var(--radius-md);margin-top:1.25rem;padding:1rem 1.25rem}.speed-label{color:#94a3b8;color:var(--text-secondary);display:flex;font-size:.8rem;font-weight:600;justify-content:space-between;margin-bottom:.6rem}.speed-value{font-feature-settings:"tnum";color:#6366f1;color:var(--primary);font-variant-numeric:tabular-nums}.speed-slider{-webkit-appearance:none;background:#94a3b826;border-radius:3px;direction:rtl;height:6px;outline:none;width:100%}.speed-slider::-webkit-slider-thumb{-webkit-appearance:none;background:#6366f1;background:var(--primary);border-radius:50%;box-shadow:0 0 8px #6366f140;box-shadow:0 0 8px var(--primary-glow);cursor:pointer;height:18px;-webkit-transition:transform .15s;transition:transform .15s;width:18px}.speed-slider::-webkit-slider-thumb:hover{transform:scale(1.2)}.speed-labels{color:#64748b;color:var(--text-muted);display:flex;font-size:.7rem;justify-content:space-between;margin-top:.4rem}.result-card{animation:slideUp .4s cubic-bezier(.16,1,.3,1);text-align:left}.result-card.compact{padding:1.5rem}.result-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1.5rem}.result-header h3{font-size:1.15rem;font-weight:700}.status-badge{border-radius:9999px;border-radius:var(--radius-full);font-size:.8rem;font-weight:700;letter-spacing:.06em;padding:.3rem .85rem;text-transform:uppercase}.status-badge.normal{background:#10b98114;background:var(--success-bg);border:1px solid #10b98133;border:1px solid var(--success-border);color:#10b981;color:var(--success)}.status-badge.defect{background:#ef444414;background:var(--danger-bg);border:1px solid #ef444433;border:1px solid var(--danger-border);color:#ef4444;color:var(--danger)}.defect-type-section{background:#33415580;background:var(--bg-elevated);border:1px solid #94a3b81f;border:1px solid var(--border-color);border-radius:14px;border-radius:var(--radius-md);margin-bottom:1.25rem;padding:1rem 1.25rem}.defect-type-label{color:#64748b;color:var(--text-muted);font-size:.75rem;font-weight:600;letter-spacing:.08em;margin-bottom:.5rem;text-transform:uppercase}.defect-type-value{font-size:1.35rem;font-weight:700;margin-bottom:.4rem;text-transform:capitalize}.defect-type-value.defective{color:#ef4444;color:var(--danger)}.defect-type-value.normal{color:#10b981;color:var(--success)}.metric{margin-bottom:1.25rem}.metric-label{color:#94a3b8;color:var(--text-secondary);display:block;font-size:.8rem;font-weight:500;margin-bottom:.5rem}.progress-bar-bg{background:#94a3b81f;border-radius:4px;height:8px;margin-bottom:.4rem;overflow:hidden}.progress-bar-fill{border-radius:4px;height:100%;transition:width .8s cubic-bezier(.16,1,.3,1)}.result-card.defect .progress-bar-fill{background:linear-gradient(90deg,#ef4444,#f87171);background:linear-gradient(90deg,var(--danger),#f87171)}.result-card.normal .progress-bar-fill{background:linear-gradient(90deg,#10b981,#34d399);background:linear-gradient(90deg,var(--success),#34d399)}.metric-value{color:#f1f5f9;color:var(--text-primary);font-size:.85rem;font-weight:600}.classification-section{border-top:1px solid #94a3b81f;border-top:1px solid var(--border-color);margin-top:1.25rem;padding-top:1.25rem}.classification-section h4{color:#94a3b8;color:var(--text-secondary);font-size:.85rem;font-weight:600;letter-spacing:.06em;margin-bottom:1rem;text-transform:uppercase}.class-prob-row{align-items:center;animation:fadeInRow .4s ease forwards;display:flex;gap:.75rem;margin-bottom:.6rem;opacity:0}.class-prob-row:first-child{animation-delay:.05s}.class-prob-row:nth-child(2){animation-delay:.1s}.class-prob-row:nth-child(3){animation-delay:.15s}.class-prob-row:nth-child(4){animation-delay:.2s}.class-prob-row:nth-child(5){animation-delay:.25s}.class-prob-row:nth-child(6){animation-delay:.3s}@keyframes fadeInRow{0%{opacity:0;transform:translateX(-8px)}to{opacity:1;transform:translateX(0)}}.class-name{color:#94a3b8;color:var(--text-secondary);flex-shrink:0;font-size:.8rem;font-weight:500;text-align:right;text-transform:capitalize;width:100px}.class-name.top-class{color:#f1f5f9;color:var(--text-primary);font-weight:700}.class-bar-bg{background:#94a3b81a;border-radius:3px;flex:1 1;height:6px;overflow:hidden}.class-bar-fill{background:#6366f1;background:var(--primary);border-radius:3px;height:100%;opacity:.5;transition:width .8s cubic-bezier(.16,1,.3,1)}.class-bar-fill.top-bar{background:linear-gradient(90deg,#6366f1,#818cf8);background:linear-gradient(90deg,var(--primary),#818cf8);opacity:1}.class-bar-fill.defect-free-bar{background:linear-gradient(90deg,#10b981,#34d399);background:linear-gradient(90deg,var(--success),#34d399)}.class-bar-fill.defect-free-bar.top-bar{opacity:1}.class-prob-value{font-feature-settings:"tnum";color:#64748b;color:var(--text-muted);flex-shrink:0;font-size:.78rem;font-variant-numeric:tabular-nums;font-weight:600;text-align:right;width:52px}.class-prob-value.top-value{color:#6366f1;color:var(--primary)}.footer{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(var(--glass-blur));backdrop-filter:blur(var(--glass-blur));background:#1e293b8c;background:var(--glass-bg);border-top:1px solid #94a3b81f;border-top:1px solid var(--border-color);color:#64748b;color:var(--text-muted);font-size:.8rem;padding:1.5rem;text-align:center}@keyframes slideUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@media (max-width:640px){.navbar{flex-wrap:wrap;gap:.75rem;justify-content:center;padding:.75rem 1rem}.main-content{padding:1.25rem 1rem}.card{padding:1.5rem}.class-name{font-size:.72rem;width:80px}.mode-btn{font-size:.75rem;padding:.4rem .8rem}.controls-row{flex-direction:column}.analyze-btn.secondary-btn{width:100%}}
/*# sourceMappingURL=main.b3daa892.css.map*/