*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}.home-container{width:100vw;height:100vh;display:flex;align-items:flex-start;justify-content:center;background-color:#f5f5f5;cursor:pointer;overflow:hidden}.home-image{width:100%;height:auto;-o-object-fit:cover;object-fit:cover}.dev-mode-indicator{position:fixed;top:0;left:0;right:0;background:linear-gradient(90deg,#ff6b35,#f7931e);color:#fff;text-align:center;padding:8px;font-size:14px;font-weight:700;z-index:1000;box-shadow:0 2px 8px rgba(0,0,0,.3)}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;overflow:hidden;position:fixed}.app-container,body{background:#000;width:100vw;height:100vh}.app-container{position:relative;color:#fff}.header-simple{position:fixed;top:16px;left:0;right:0;z-index:30;background:linear-gradient(180deg,rgba(0,0,0,.85),transparent);padding:env(safe-area-inset-top,32px) 20px 32px;text-align:center}.progress-steps{justify-content:space-between;margin:0 auto 28px auto;padding:0 20px;max-width:640px}.progress-steps,.step-item{display:flex;align-items:center}.step-item{flex-direction:column;flex:1;position:relative}.step-item:not(:last-child):after{content:"";position:absolute;left:50%;top:6px;width:calc(100% - 12px);height:2px;background:hsla(0,0%,100%,.2);transform:translateX(6px);z-index:0}.step-dot{width:12px;height:12px;border-radius:50%;background:hsla(0,0%,100%,.4);margin-bottom:8px;position:relative;z-index:1}.step-dot,.step-label{transition:all .3s ease}.step-label{font-size:12px;color:hsla(0,0%,100%,.7);text-align:center;white-space:nowrap}.step-item.active .step-dot{background:#0abaff;box-shadow:0 0 0 4px rgba(10,186,255,.25)}.step-item.active .step-label{color:#0abaff;font-weight:600}.step-item.completed .step-dot{background:#34c759}.step-item.completed .step-label{color:#34c759;font-weight:500}.step-item.completed:not(:last-child):after{background:#34c759}.main-instruction{font-size:30px;font-weight:700;color:#fff;text-shadow:0 2px 8px rgba(0,0,0,.8);letter-spacing:2px;margin-bottom:12px}.sub-instruction{font-size:16px;color:hsla(0,0%,100%,.75)}.camera-container{position:absolute;top:0;left:0;width:100%;height:100%}#videoElement{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.overlay{position:absolute;top:0;left:0;right:0;bottom:0;pointer-events:none}.car-frame-large{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:85.3vw;height:55.7vw;background-position:50%;background-repeat:no-repeat;background-size:contain;opacity:.9;filter:drop-shadow(0 0 18px rgba(255,222,102,.75));transition:all .3s ease}.car-frame-large.rear{height:46.4vw}.expected-box{border:2px dashed hsla(0,0%,100%,.25);box-shadow:inset 0 0 18px rgba(0,0,0,.25)}.expected-box,.status-toast{position:absolute;border-radius:20px}.status-toast{bottom:120px;left:50%;transform:translateX(-50%);padding:8px 16px;background:rgba(0,0,0,.75);border:1px solid hsla(0,0%,100%,.15);color:#fff;font-size:13px;letter-spacing:.3px;backdrop-filter:blur(8px);transition:all .3s ease;max-width:280px;text-align:center}.status-toast.matched{background:rgba(0,255,106,.15);border-color:rgba(0,255,106,.4);color:#00ff6a}.status-toast.good{background:rgba(0,196,255,.15);border-color:rgba(0,196,255,.4);color:#50d8ff}.loading-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.9);display:flex;flex-direction:column;align-items:center;justify-content:center;color:#fff;z-index:100}.spinner{width:42px;height:42px;border:3px solid hsla(0,0%,100%,.3);border-top:3px solid #fff;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:20px}@keyframes spin{to{transform:rotate(1turn)}}@keyframes successFlash{0%{background:hsla(0,0%,100%,0)}50%{background:hsla(0,0%,100%,.15)}to{background:hsla(0,0%,100%,0)}}.voice-hint{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:rgba(0,0,0,.68);color:#fff;padding:6px 12px;border-radius:16px;text-align:center;z-index:60;max-width:80vw;opacity:0;transition:opacity .3s ease;font-size:13px}.voice-hint.show{opacity:1}.speech-enable-hint{position:fixed;top:20px;right:20px;z-index:70;opacity:0;transition:opacity .3s ease;cursor:pointer}.speech-enable-hint.show{opacity:1}.speech-hint-content{background:rgba(0,0,0,.8);color:#fff;padding:12px 16px;border-radius:20px;display:flex;align-items:center;gap:8px;border:2px solid hsla(0,0%,100%,.3);backdrop-filter:blur(8px)}.speech-icon{font-size:18px;animation:pulse 2s infinite}.speech-text{font-size:14px;font-weight:500}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.debug-panel{position:fixed;top:100px;left:10px;width:280px;background:rgba(0,0,0,.9);color:#fff;border-radius:8px;font-size:12px;z-index:80;max-height:60vh;overflow-y:auto}.debug-header{padding:8px 12px;background:hsla(0,0%,100%,.1);cursor:pointer;font-weight:700;border-radius:8px 8px 0 0;-webkit-user-select:none;-moz-user-select:none;user-select:none}.debug-toggle{float:right}.debug-content{padding:0}.debug-section{padding:8px 12px;border-bottom:1px solid hsla(0,0%,100%,.1)}.debug-section:last-child{border-bottom:none}.debug-section h4{margin:0 0 4px 0;color:#0abaff;font-size:11px;font-weight:700}.debug-section div{margin:2px 0;font-family:monospace}.debug-log-item{font-size:10px;color:#0f0;border-bottom:1px solid hsla(0,0%,100%,.1);padding:2px 0}@media (max-width:640px){.debug-panel{width:260px;left:5px;top:80px;font-size:11px}}.results-modal{position:fixed;top:0;left:0;right:0;bottom:0;background:#fff;z-index:200;display:flex;flex-direction:column;transform:translateY(100%);transition:transform .3s ease;color:#111}.results-modal.show{transform:translateY(0)}.results-header{padding:24px 20px 12px 20px;text-align:center;border-bottom:1px solid #e0e0e0}.results-content{flex:1;padding:20px;overflow-y:auto}.photo-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:18px;margin-bottom:30px}.photo-item{text-align:center}.photo-preview{width:100%;height:140px;border-radius:12px;border:2px solid #e0e0e0;-o-object-fit:cover;object-fit:cover;background:#f5f5f5;display:flex;align-items:center;justify-content:center;color:#999;font-size:12px}.photo-label,.photo-preview.placeholder{font-weight:500}.photo-label{margin-top:10px;font-size:15px}.results-actions{padding:20px;display:flex;gap:12px}.btn{flex:1;padding:15px;border:none;border-radius:10px;font-size:16px;font-weight:600;cursor:pointer;touch-action:manipulation;-webkit-user-select:none;-moz-user-select:none;user-select:none}.btn-primary{background:#007aff;color:#fff}.btn-secondary{background:#f0f0f0;color:#333}.btn:disabled{opacity:.6;cursor:not-allowed}@media (max-width:520px){.main-instruction{font-size:24px}.sub-instruction{font-size:14px}.status-toast{bottom:110px;font-size:12px;padding:6px 14px;max-width:240px}}