*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}body{font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,Segoe UI,Roboto,Helvetica Neue,sans-serif;background:#000;color:#e0e0e0;min-height:100dvh;overflow-x:hidden}#root{min-height:100dvh}.results-panel{width:100%;max-width:600px;margin:0 auto;padding:0 16px 32px}.results-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.results-header h2{font-size:18px;font-weight:600;color:#f0f0f0;margin:0}.save-btn{background:#22c55e33;border:1px solid rgba(34,197,94,.4);color:#22c55e;font-size:13px;font-weight:600;padding:6px 18px;border-radius:20px;cursor:pointer;transition:all .2s;font-family:inherit}.save-btn:hover{background:#22c55e4d;color:#4ade80}.save-btn:disabled{opacity:.5;cursor:not-allowed}.results-grid{display:flex;flex-direction:column;gap:12px}.result-card{background:#ffffff0f;border:1px solid rgba(255,255,255,.1);border-radius:16px;overflow:hidden;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.result-snapshot{position:relative;width:100%;aspect-ratio:16 / 9;overflow:hidden}.result-snapshot img{width:100%;height:100%;object-fit:cover}.result-time{position:absolute;bottom:8px;right:8px;background:#0009;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#ccc;font-size:11px;padding:3px 8px;border-radius:8px;font-variant-numeric:tabular-nums}.result-details{padding:14px 16px;display:flex;flex-direction:column;gap:10px}.prediction-row{display:flex;flex-direction:column;gap:6px}.prediction-info{display:flex;justify-content:space-between;align-items:center}.prediction-class{font-size:14px;font-weight:600;color:#e0e0e0;text-transform:capitalize}.prediction-confidence{font-size:14px;font-weight:700;color:#34d399;font-variant-numeric:tabular-nums}.confidence-bar{height:6px;background:#ffffff14;border-radius:3px;overflow:hidden}.confidence-fill{height:100%;background:linear-gradient(90deg,#34d399,#60a5fa);border-radius:3px;transition:width .4s ease}.camera-page{display:flex;flex-direction:column;align-items:center;gap:32px;padding:24px 16px;min-height:100dvh}.camera-container{width:100%;max-width:480px;display:flex;flex-direction:column;align-items:center;gap:16px}.device-selector-wrapper{width:100%;min-height:36px;display:flex;justify-content:center}.device-selector{appearance:none;background:#ffffff14;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.12);border-radius:20px;color:#e0e0e0;font-size:13px;font-weight:500;padding:8px 32px 8px 16px;cursor:pointer;outline:none;transition:all .2s;background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1L5 5L9 1' stroke='%23999' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center}.device-selector:hover{background-color:#ffffff1f}.device-selector:focus{border-color:#34d39980}.device-selector option{background:#1a1a1a;color:#e0e0e0}.video-viewport{position:relative;width:100%;aspect-ratio:3 / 4;border-radius:28px;overflow:hidden;background:#0a0a0a;border:3px solid rgba(255,255,255,.08);transition:border-color .4s ease}.video-viewport.scanning{border-color:#34d39966;box-shadow:0 0 30px #34d39914,inset 0 0 30px #34d39908}.video-viewport.connecting{border-color:#fbbf2466;box-shadow:0 0 30px #fbbf2414}.video-feed{width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity .4s ease}.video-feed.mirrored{transform:scaleX(-1)}.video-feed.active{opacity:1}.device-selector.disabled{opacity:.4;cursor:not-allowed;pointer-events:none}.video-placeholder{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;color:#555}.placeholder-icon{width:80px;height:80px;border-radius:50%;background:#ffffff0a;display:flex;align-items:center;justify-content:center}.video-placeholder p{font-size:14px;margin:0}.scan-line{position:absolute;left:0;width:100%;height:2px;background:linear-gradient(90deg,transparent 0%,rgba(52,211,153,.6) 20%,rgba(52,211,153,1) 50%,rgba(52,211,153,.6) 80%,transparent 100%);box-shadow:0 0 12px #34d39980;animation:scanMove 2s ease-in-out infinite;pointer-events:none}@keyframes scanMove{0%,to{top:10%}50%{top:90%}}.detection-overlay{position:absolute;inset:0;pointer-events:none;z-index:5}.detection-marker{position:absolute;border:1px solid rgba(255,255,255,.3);box-shadow:0 0 16px #ffffff1a,0 0 4px #ffffff26;animation:markerFade 1s cubic-bezier(.22,1,.36,1) forwards}@keyframes markerFade{0%{opacity:0;transform:scale(1.08)}25%{opacity:1;transform:scale(1)}75%{opacity:1}to{opacity:0}}.detection-marker .corner{position:absolute;width:14px;height:14px;border-color:#fff;border-style:solid}.corner.tl{top:-1px;left:-1px;border-width:2.5px 0 0 2.5px;border-radius:3px 0 0}.corner.tr{top:-1px;right:-1px;border-width:2.5px 2.5px 0 0;border-radius:0 3px 0 0}.corner.bl{bottom:-1px;left:-1px;border-width:0 0 2.5px 2.5px;border-radius:0 0 0 3px}.corner.br{bottom:-1px;right:-1px;border-width:0 2.5px 2.5px 0;border-radius:0 0 3px}.corner.tl:after,.corner.tr:after,.corner.bl:after,.corner.br:after{content:"";position:absolute;background:#ffffff80}.corner.tl:after{top:5px;left:-1px;width:6px;height:1px}.corner.tr:after{top:5px;right:-1px;width:6px;height:1px}.corner.bl:after{bottom:5px;left:-1px;width:6px;height:1px}.corner.br:after{bottom:5px;right:-1px;width:6px;height:1px}.detection-label{position:absolute;top:6px;left:6px;display:flex;align-items:center;gap:6px;padding:3px 10px;background:linear-gradient(135deg,#000000bf,#0009);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.4);border-radius:4px;white-space:nowrap}.label-text{color:#fff;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.8px}.label-conf{color:#ffffff80;font-size:10px;font-weight:500}.status-bar{height:20px;display:flex;align-items:center;justify-content:center}.status-info{font-size:13px;color:#666}.status-scanning{font-size:13px;color:#34d399;animation:pulse 1.5s ease-in-out infinite}.status-detecting{font-size:13px;color:#34d399}.status-error{font-size:13px;color:#f87171}.status-complete{font-size:13px;color:#60a5fa;font-weight:500}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.controls{display:flex;justify-content:space-between;align-items:center;width:100%;height:56px}.controls-slot{height:56px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.controls-slot-left{width:80px}.controls-slot-center{flex:1}.controls-slot-right{width:80px}.control-btn{display:flex;align-items:center;justify-content:center;gap:8px;border:none;cursor:pointer;transition:all .2s;font-family:inherit}.camera-btn{width:56px;height:56px;border-radius:50%;background:#ffffff1a;color:#e0e0e0}.camera-btn:hover{background:#ffffff2e;transform:scale(1.05)}.camera-btn.active{background:#ef444433;color:#f87171}.camera-btn.active:hover{background:#ef44444d}.scan-btn{height:48px;padding:0 24px;border-radius:24px;background:#34d39926;color:#34d399;font-size:15px;font-weight:600}.scan-btn:hover{background:#34d39940;transform:scale(1.03)}.scan-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.scan-btn .spin{animation:spinAnim 1s linear infinite}@keyframes spinAnim{to{transform:rotate(360deg)}}.scan-btn.active{background:#ef444426;color:#f87171}.scan-btn.active:hover{background:#ef444440}.complete-btn{height:48px;padding:0 24px;border-radius:24px;background:#60a5fa33;color:#60a5fa;font-size:15px;font-weight:600;animation:completePulse 1.5s ease-in-out infinite}.complete-btn:hover{background:#60a5fa59;transform:scale(1.03)}@keyframes completePulse{0%,to{box-shadow:0 0 #60a5fa4d}50%{box-shadow:0 0 16px 4px #60a5fa33}}.results-btn{position:relative;width:48px;height:48px;border-radius:50%;background:#60a5fa26;color:#60a5fa}.results-btn.disabled{opacity:.3;cursor:not-allowed}.results-btn.disabled:hover{background:#60a5fa26;transform:none}.results-btn:not(.disabled):hover{background:#60a5fa40;transform:scale(1.05)}.results-badge{position:absolute;top:-2px;right:-2px;min-width:18px;height:18px;padding:0 5px;border-radius:9px;background:#60a5fa;color:#000;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;line-height:1}.results-page{width:100%;max-width:600px;margin:0 auto;animation:pageIn .3s ease}.results-page-header{display:flex;align-items:center;justify-content:space-between;padding:0 16px 20px}@keyframes pageIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.back-btn{display:flex;align-items:center;gap:6px;background:#ffffff14;border:1px solid rgba(255,255,255,.12);color:#e0e0e0;font-size:14px;font-weight:500;padding:8px 16px;border-radius:20px;cursor:pointer;transition:all .2s;font-family:inherit}.back-btn:hover{background:#ffffff24}.results-count{font-size:13px;color:#666}@media(max-width:480px){.camera-page{padding:16px 12px}.video-viewport{border-radius:24px}}@media(min-width:768px){.camera-container{max-width:440px}}.app{display:flex;flex-direction:column;align-items:center;min-height:100dvh}.app-header{text-align:center;padding:32px 16px 8px}.app-header h1{font-size:22px;font-weight:700;letter-spacing:.08em;color:#fff;margin:0}.app-header p{font-size:13px;color:#666;margin:6px 0 0;font-weight:400}.welcome-message{color:#34d399!important;font-size:14px!important;margin-top:8px!important}
