@import "https://fonts.googleapis.com/css2?family=Outfit:wght@400;600;700&family=JetBrains+Mono&display=swap";:root{--bg-color:#0b0c10;--panel-bg:#14161ebf;--glass-border:#ffffff14;--accent-color:#64ffda;--accent-glow:#64ffda4d;--text-main:#e0e0e0;--text-dim:#949494;--bubble-bg:#191c26e6;--safe-top:env(safe-area-inset-top);--safe-bottom:env(safe-area-inset-bottom)}*{box-sizing:border-box;-webkit-user-select:none;user-select:none;-webkit-font-smoothing:antialiased;margin:0;padding:0}body,html{background-color:var(--bg-color);width:100%;height:100%;color:var(--text-main);-webkit-tap-highlight-color:transparent;font-family:Outfit,sans-serif;overflow:hidden}#app{flex-direction:column;width:100%;height:100%;display:flex;position:relative}#camera-container{z-index:1;background:#000;position:absolute;inset:0}#main-video{object-fit:cover;width:100%;height:100%}#tap-surface{z-index:5;position:absolute;inset:0}#ui-overlay{z-index:10;pointer-events:none;padding:calc(12px + var(--safe-top)) 12px calc(16px + var(--safe-bottom)) 12px;flex-direction:column;display:flex;position:absolute;inset:0}#main-analysis{background:var(--panel-bg);-webkit-backdrop-filter:blur(24px);border:1px solid var(--glass-border);pointer-events:auto;border-radius:20px;margin-top:0;padding:16px;box-shadow:0 12px 48px #00000080}.analysis-header{color:var(--text-dim);letter-spacing:.05em;text-transform:uppercase;justify-content:space-between;align-items:center;margin-bottom:12px;font-size:.75rem;font-weight:700;display:flex}.analysis-header-left{align-items:center;gap:10px;display:flex}.status-indicator{text-transform:uppercase;border:1px solid #0000;border-radius:12px;padding:2px 8px;font-family:JetBrains Mono,monospace;font-size:.65rem;transition:all .3s}.pulse-dot{background:var(--accent-color);width:8px;height:8px;box-shadow:0 0 12px var(--accent-color);border-radius:50%;transition:all .3s;animation:2s infinite pulse}.pulse-dot.snapping{background:#fc0;animation:.4s infinite fast-pulse;box-shadow:0 0 16px #fc0}.pulse-dot.analyzing{background:#64ffda;border-radius:2px;animation:1.4s infinite thinking;box-shadow:0 0 16px #64ffda}.pulse-dot.waiting{background:var(--text-dim);box-shadow:none;opacity:.5;animation:none}@keyframes fast-pulse{0%{opacity:.8;transform:scale(1)}50%{opacity:1;transform:scale(1.4)}to{opacity:.8;transform:scale(1)}}@keyframes pulse{0%{opacity:.5;transform:scale(1)}50%{opacity:1;box-shadow:0 0 16px var(--accent-color);transform:scale(1.2)}to{opacity:.5;transform:scale(1)}}.mini-progress-bg{background:#ffffff14;border:1px solid #ffffff0d;border-radius:4px;width:44px;height:4px;margin-left:10px;overflow:hidden}.mini-progress-fill{background:var(--accent-color);width:0%;height:100%;box-shadow:0 0 8px var(--accent-glow);transition:width .1s linear}#description-text{color:#fff;max-height:180px;font-size:1rem;line-height:1.6;overflow-y:auto}#controls-panel{pointer-events:auto;justify-content:space-between;align-items:center;gap:12px;margin-top:auto;display:flex}#controls-panel>button{flex:none}#model-selector{flex:1;min-width:0}.glass-btn{aspect-ratio:1;background:var(--panel-bg);-webkit-backdrop-filter:blur(20px);border:1px solid var(--glass-border);color:#fff;cursor:pointer;border-radius:18px;flex-shrink:0;place-items:center;width:54px;height:54px;padding:0;transition:all .2s cubic-bezier(.4,0,.2,1);display:grid}.glass-btn svg{fill:none;aspect-ratio:1;width:24px;max-width:24px;height:24px;max-height:24px;display:block}.glass-btn:active{background:#ffffff1a;transform:scale(.92)}.icon-sub-btn{color:var(--text-dim);cursor:pointer;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;margin-left:8px;padding:4px;transition:all .2s;display:flex}.icon-sub-btn:hover{color:#fff;background:#ffffff1a}.icon-sub-btn:active{transform:scale(.9)}#switch-camera-btn{border-color:#64ffda66}#toggle-analysis-btn.active-stopped{color:var(--text-dim);background:#ffffff08;border-color:#fff3}.switching-spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:20px;height:20px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}#toggle-audio-btn.active-audio{color:#ff4d4d;background:#ff4d4d0d;border-color:#ff4d4d}.glass-select{background:var(--panel-bg);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--glass-border);color:#fff;appearance:none;border-radius:18px;outline:none;height:54px;padding:0 16px;font-family:inherit;font-size:.9rem;font-weight:600}.result-bubble{background:var(--bubble-bg);-webkit-backdrop-filter:blur(24px);border:1px solid var(--glass-border);z-index:50;opacity:0;transform-origin:bottom;border-radius:20px;max-width:300px;padding:14px 20px;animation:.4s cubic-bezier(.175,.885,.32,1.275) .2s forwards bubblePop;position:absolute;box-shadow:0 16px 48px #0009}.bubble-close-btn{color:var(--text-dim);cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;padding:4px;font-size:1.4rem;line-height:1;transition:all .2s;display:flex}.bubble-close-btn:hover{color:#fff;background:#ffffff1a}.bubble-copy-btn{color:var(--text-dim);cursor:pointer;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;margin-right:auto;padding:4px;transition:all .2s;display:flex}.bubble-copy-btn:hover{color:#fff;background:#ffffff1a}@keyframes bubblePop{0%{opacity:0;transform:scale(.6)translateY(20px)}to{opacity:1;transform:scale(1)translateY(0)}}#load-progress-container{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);z-index:100;background:#000000d9;flex-direction:column;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.progress-label{margin-bottom:24px;font-size:1.1rem;font-weight:700}.progress-bar-bg{background:#ffffff1a;border-radius:10px;width:260px;height:6px;overflow:hidden}.progress-bar-fill{background:var(--accent-color);height:100%;box-shadow:0 0 20px var(--accent-color);transition:width .3s ease-out}.progress-bar-fill.optimizing{background:linear-gradient(90deg, var(--accent-color), #fff, var(--accent-color));background-size:200% 100%;animation:1.5s linear infinite shimmer}@keyframes shimmer{0%{background-position:-100% 0}to{background-position:100% 0}}.modal-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:200;pointer-events:auto;background:#0006;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-content{width:90%;max-width:400px;padding:24px!important}.modal-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.close-btn{color:var(--text-dim);cursor:pointer;background:0 0;border:none;font-size:2rem;line-height:1}.setting-item{margin-bottom:24px}.setting-item label{color:var(--text-dim);margin-bottom:12px;font-size:.85rem;display:block}.setting-item input[type=range]{width:100%;accent-color:var(--accent-color);margin-bottom:8px}.setting-val{color:var(--accent-color);font-family:JetBrains Mono,monospace;font-size:.9rem}.hidden{display:none!important}.slide-up{animation:.5s ease-out slideUp}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.touch-circle{border:2px solid var(--accent-color);pointer-events:none;z-index:150;border-radius:50%;width:40px;height:40px;animation:.8s ease-out forwards ripple;position:fixed;transform:translate(-50%,-50%)}@keyframes ripple{0%{opacity:1;transform:translate(-50%,-50%)scale(.5)}to{opacity:0;transform:translate(-50%,-50%)scale(2.5)}}.tap-indicator-container{pointer-events:none;z-index:60;justify-content:center;align-items:center;width:100px;height:100px;display:flex;position:fixed;transform:translate(-50%,-50%)}.tap-progress-ring circle{fill:none;stroke:var(--accent-color);stroke-width:4px;stroke-linecap:round;transform-origin:50%;transition:stroke-dashoffset .3s;transform:rotate(-90deg)}.tap-completion{color:var(--accent-color);animation:.4s cubic-bezier(.175,.885,.32,1.275) forwards popIn;position:absolute}.thinking-indicator{gap:4px;display:flex;position:absolute}.thinking-dot{background:var(--accent-color);border-radius:50%;width:6px;height:6px;animation:1.4s infinite thinking}.thinking-dot:nth-child(2){animation-delay:.2s}.thinking-dot:nth-child(3){animation-delay:.4s}@keyframes thinking{0%,80%,to{opacity:.3;transform:scale(0)}40%{opacity:1;transform:scale(1)}}@keyframes popIn{0%{opacity:0;transform:scale(.5)}to{opacity:1;transform:scale(1)}}@media (width<=480px){#ui-overlay{padding:calc(10px + var(--safe-top)) 15px calc(15px + var(--safe-bottom)) 15px}}
