*{margin:0;padding:0;box-sizing:border-box}:root{--bg-primary: #0f0f0f;--bg-secondary: #1a1a1a;--bg-tertiary: #252525;--text-primary: #f5f5f5;--text-secondary: #a0a0a0;--text-muted: #6a6a6a;--accent: #d4a373;--success: #b8bb26;--success-glow: rgba(184, 187, 38, .4);--border: #383838;--scanner-idle: rgba(160, 160, 160, .5);--scanner-active: rgba(184, 187, 38, .95)}html,body,#app{height:100%;overflow:hidden;touch-action:manipulation}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif;background:var(--bg-primary);color:var(--text-primary)}#app{display:flex;flex-direction:column}header{padding:10px 12px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border);background:var(--bg-secondary);flex-shrink:0;gap:10px}.logo{font-family:ui-monospace,SF Mono,Cascadia Code,monospace;font-size:13px;font-weight:600;letter-spacing:-.02em;color:var(--text-primary);display:flex;align-items:center;gap:8px}.logo-icon{width:16px;height:16px;border:2px solid var(--text-secondary);border-radius:2px;position:relative}.logo-icon:before,.logo-icon:after{content:"";position:absolute;background:var(--text-secondary)}.logo-icon:before{width:5px;height:5px;top:1px;left:1px}.logo-icon:after{width:3px;height:3px;bottom:1px;right:1px}.header-right{display:flex;align-items:center;gap:6px}.status{font-size:10px;color:var(--text-muted);font-family:ui-monospace,SF Mono,monospace;text-transform:uppercase;letter-spacing:.05em}.status.ready{color:var(--success)}.icon-btn{width:26px;height:26px;background:transparent;border:1px solid var(--border);border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);transition:all .15s ease}.icon-btn:hover{background:var(--bg-tertiary);color:var(--text-primary);border-color:var(--text-muted)}.icon-btn.active{background:var(--bg-tertiary);border-color:var(--accent);color:var(--accent)}.icon-btn svg{width:13px;height:13px}.settings-panel{background:var(--bg-tertiary);border-bottom:1px solid var(--border);padding:10px 12px}.settings-grid{display:flex;flex-wrap:wrap;gap:8px 16px;align-items:center}.setting-item{display:flex;align-items:center;gap:8px}.setting-label{font-size:11px;color:var(--text-secondary);white-space:nowrap}.stepper{display:flex;align-items:center;background:var(--bg-secondary);border:1px solid var(--border);border-radius:4px;overflow:hidden;-webkit-user-select:none;user-select:none}.stepper-btn{width:22px;height:22px;background:transparent;border:none;color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:500;transition:all .1s ease}.stepper-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.stepper-btn:active{background:var(--border)}.stepper-value{min-width:32px;height:22px;display:flex;align-items:center;justify-content:center;font-family:ui-monospace,SF Mono,monospace;font-size:11px;color:var(--text-primary);cursor:ew-resize;border-left:1px solid var(--border);border-right:1px solid var(--border)}.setting-select{background:var(--bg-secondary);border:1px solid var(--border);border-radius:4px;color:var(--text-primary);font-family:ui-monospace,SF Mono,monospace;font-size:11px;padding:4px 8px;cursor:pointer;outline:none}.setting-select:hover{border-color:var(--text-muted)}.setting-select:focus{border-color:var(--accent)}.toggle{position:relative;width:32px;height:18px;background:var(--border);border-radius:9px;cursor:pointer;transition:background .2s ease;flex-shrink:0}.toggle.active{background:var(--success)}.toggle:after{content:"";position:absolute;top:2px;left:2px;width:14px;height:14px;background:var(--text-primary);border-radius:50%;transition:transform .2s ease}.toggle.active:after{transform:translate(14px)}.viewfinder-container{flex:1;position:relative;overflow:hidden;background:#000;min-height:0;display:flex;align-items:center;justify-content:center}.viewfinder{aspect-ratio:1;max-width:100%;max-height:100%;position:relative}.viewfinder video{width:100%;height:100%;object-fit:cover}.viewfinder video.mirror{transform:scaleX(-1)}.viewfinder video.hidden{opacity:0;position:absolute;pointer-events:none}.scan-overlay{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.scan-overlay-mask{position:absolute;top:0;right:0;bottom:0;left:0;background:#0009}.scan-region{position:absolute}.scan-corners{width:100%;height:100%;fill:none;stroke:var(--success);stroke-width:3;stroke-linecap:round;stroke-linejoin:round;animation:scan-pulse 1.5s ease-in-out infinite}@keyframes scan-pulse{0%,to{opacity:.8;transform:scale(.98)}50%{opacity:1;transform:scale(1.01)}}.scanning-indicator{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;color:var(--text-secondary);font-size:14px;text-transform:uppercase;letter-spacing:.1em}.scanning-spinner{width:48px;height:48px;border:3px solid var(--border);border-top-color:var(--success);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.vignette{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;opacity:0;transition:opacity .3s ease}.vignette.active{opacity:1}.vignette:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at center,transparent 0%,transparent 12%,rgba(0,0,0,.75) 20%,rgba(0,0,0,.88) 100%)}.scanner-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;pointer-events:none}.target-box{width:min(40vw,180px);height:min(40vw,180px);position:relative}.corner{position:absolute;width:20px;height:20px;border-color:var(--scanner-idle);border-style:solid;transition:border-color .2s ease,filter .2s ease}.corner.tl{top:0;left:0;border-width:3px 0 0 3px;border-radius:3px 0 0}.corner.tr{top:0;right:0;border-width:3px 3px 0 0;border-radius:0 3px 0 0}.corner.bl{bottom:0;left:0;border-width:0 0 3px 3px;border-radius:0 0 0 3px}.corner.br{bottom:0;right:0;border-width:0 3px 3px 0;border-radius:0 0 3px}.target-box.detected .corner{border-color:var(--scanner-active);filter:drop-shadow(0 0 8px var(--success-glow))}.qr-highlight{position:absolute;border:2px solid var(--success);background:#b8bb2626;border-radius:4px;pointer-events:none;opacity:0;transition:opacity .3s ease}.qr-highlight.visible{opacity:1}.scan-line{position:absolute;left:4px;right:4px;height:2px;background:linear-gradient(90deg,transparent,var(--scanner-idle),transparent);opacity:.6;animation:scan 2s ease-in-out infinite}.target-box.detected .scan-line{background:linear-gradient(90deg,transparent,var(--scanner-active),transparent)}@keyframes scan{0%,to{top:4px}50%{top:calc(100% - 6px)}}.press-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#0f0f0feb;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;z-index:10;cursor:pointer;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none}.press-overlay:active .scan-button{background:var(--success);border-color:var(--success);color:var(--bg-primary);transform:scale(.95)}.scan-button{width:100px;height:100px;border-radius:50%;background:var(--bg-tertiary);border:3px solid var(--border);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);transition:all .15s ease;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none}.scan-button:hover{border-color:var(--text-muted);color:var(--text-primary)}.scan-button:active,.scan-button.active{background:var(--success);border-color:var(--success);color:var(--bg-primary);transform:scale(.95)}.scan-button svg{width:40px;height:40px}.press-hint{font-size:12px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em}.error-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--bg-primary);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px;text-align:center;z-index:20}.error-icon{width:44px;height:44px;border:2px solid var(--text-muted);border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:14px}.error-icon:before{content:"!";font-size:22px;color:var(--text-muted);font-weight:600}.error-title{font-size:15px;font-weight:600;margin-bottom:6px;color:var(--text-primary)}.error-message{font-size:12px;color:var(--text-secondary);line-height:1.5;max-width:260px}.results-panel{background:var(--bg-secondary);border-top:1px solid var(--border);flex-shrink:0}.last-result{padding:12px 14px;border-bottom:1px solid var(--border);cursor:pointer;transition:background .15s ease}.last-result:hover{background:var(--bg-tertiary)}.last-result:active{background:var(--bg-primary)}.result-label{font-size:9px;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);margin-bottom:4px;font-weight:600}.result-value{font-family:ui-monospace,SF Mono,Cascadia Code,monospace;font-size:14px;line-height:1.4;color:var(--text-primary);word-break:break-all;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.result-value.empty{color:var(--text-muted);font-style:italic}.copy-hint{font-size:9px;color:var(--text-muted);margin-top:6px;opacity:0;transition:opacity .15s ease;text-transform:uppercase;letter-spacing:.05em}.last-result:hover .copy-hint{opacity:1}.history{max-height:120px;overflow-y:auto}.history-header{padding:10px 14px 6px;font-size:9px;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);font-weight:600;position:sticky;top:0;background:var(--bg-secondary);display:flex;justify-content:space-between;align-items:center}.clear-btn{background:transparent;border:1px solid var(--border);color:var(--text-muted);font-size:9px;padding:2px 8px;border-radius:3px;cursor:pointer;text-transform:uppercase;letter-spacing:.05em}.clear-btn:hover{border-color:var(--text-muted);color:var(--text-secondary)}.history-list{list-style:none}.history-item{padding:8px 14px;display:flex;gap:10px;align-items:flex-start;border-bottom:1px solid var(--border);cursor:pointer;transition:background .15s ease}.history-item:hover{background:var(--bg-tertiary)}.history-time{font-family:ui-monospace,SF Mono,monospace;font-size:10px;color:var(--text-muted);flex-shrink:0;width:42px}.history-value{font-size:12px;color:var(--text-secondary);flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.empty-history{padding:20px 14px;text-align:center;color:var(--text-muted);font-size:12px}.history::-webkit-scrollbar{width:5px}.history::-webkit-scrollbar-track{background:transparent}.history::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.history::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.toast{position:fixed;bottom:16px;left:50%;transform:translate(-50%) translateY(80px);background:var(--bg-tertiary);color:var(--text-primary);padding:8px 16px;border-radius:5px;font-size:12px;border:1px solid var(--border);opacity:0;transition:transform .2s ease,opacity .2s ease;z-index:100}.toast.visible{transform:translate(-50%) translateY(0);opacity:1}.viewfinder .scan-region-highlight{border:2px solid var(--scanner-idle)!important;border-radius:8px;background:transparent!important;box-shadow:0 0 0 9999px #000000b3}.viewfinder .scan-region-highlight-svg{stroke:var(--success)!important;stroke-width:3!important}.viewfinder .code-outline-highlight{stroke:var(--success)!important;stroke-width:3!important;fill:#b8bb2633!important}.hook-toggle{width:26px;height:26px;background:transparent;border:1px solid var(--border);border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s ease}.hook-toggle svg{width:14px;height:14px}.hook-toggle.on{background:#b8bb2626;border-color:var(--success);color:var(--success)}.hook-toggle.off{background:#fb49341a;border-color:#fb4934;color:#fb4934;opacity:.7}.hook-toggle:hover{opacity:1}.setting-input{background:var(--bg-secondary);border:1px solid var(--border);border-radius:4px;color:var(--text-primary);font-family:ui-monospace,SF Mono,monospace;font-size:11px;padding:6px 8px;width:180px;outline:none}.setting-input:focus{border-color:var(--accent)}.setting-input::placeholder{color:var(--text-muted)}.server-input-wrap{display:flex;align-items:center;gap:8px}.server-status{width:18px;height:18px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.server-status svg{width:12px;height:12px}.server-status.checking{border:2px solid var(--border);border-top-color:var(--text-secondary);animation:spin .6s linear infinite}.server-status.online{background:#b8bb2633;color:var(--success)}.server-status.offline{background:#fb493433;color:#fb4934}.send-btn{background:var(--success);border:none;border-radius:4px;color:var(--bg-primary);font-size:10px;font-weight:600;padding:6px 12px;cursor:pointer;text-transform:uppercase;letter-spacing:.05em;margin-top:8px;transition:all .15s ease}.send-btn:hover{filter:brightness(1.1)}.send-btn:active{transform:scale(.95)}.send-btn-small{background:var(--bg-tertiary);border:1px solid var(--border);border-radius:3px;color:var(--text-secondary);font-size:9px;font-weight:600;padding:3px 8px;cursor:pointer;text-transform:uppercase;letter-spacing:.05em;transition:all .15s ease}.send-btn-small:hover{border-color:var(--success);color:var(--success)}.hook-spinner,.hook-spinner-small{border:2px solid var(--border);border-top-color:var(--success);border-radius:50%;animation:spin .6s linear infinite}.hook-spinner{width:20px;height:20px;margin-top:8px}.hook-spinner-small{width:14px;height:14px}.hook-response,.hook-response-small{font-family:ui-monospace,SF Mono,monospace}.hook-response{display:block;font-size:11px;margin-top:4px;padding:4px 8px;border-radius:3px;background:var(--bg-tertiary)}.hook-response.success{color:var(--success)}.hook-response.error{color:#fb4934}.hook-response-small{font-size:10px;color:var(--text-muted);margin-left:8px}.hook-response-small.success{color:var(--success)}.hook-response-small.error{color:#fb4934}.last-result-meta{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-top:6px}.history-item{flex-wrap:wrap}.history-item-main{display:flex;gap:10px;align-items:flex-start;flex:1;min-width:0}.history-item-actions{display:flex;align-items:center;gap:8px}.toast.success{border-color:var(--success);background:#b8bb2626}.toast.error{border-color:#fb4934;background:#fb493426}
