:root{--bg-primary: #1a1a1a;--bg-secondary: #2d2d2d;--bg-tertiary: #3d3d3d;--text-primary: #ffffff;--text-secondary: #a0a0a0;--accent: #00C853;--accent-lime: var(--accent);--accent-cyan: #00d4ff;--success: #4ade80;--warning: #fbbf24;--error: #ef4444;--border-radius: 8px}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;background-color:var(--bg-primary);color:var(--text-primary);height:100vh;line-height:1.6;overflow:hidden}#app{display:flex;flex-direction:column;height:100vh;overflow:hidden}.header{display:flex;justify-content:space-between;align-items:center;padding:.5rem 1.5rem;background-color:var(--bg-secondary);border-bottom:1px solid var(--bg-tertiary);flex-shrink:0}.logo{display:flex;align-items:center;gap:.5rem}.logo-icon{width:40px;height:24px}.logo-text{font-size:1.25rem;font-weight:700;letter-spacing:-.5px}.header-status{display:flex;align-items:center;gap:1rem}.status-badge{padding:.375rem .75rem;border-radius:9999px;font-size:.875rem;font-weight:500}.status-badge.disconnected{background-color:var(--bg-tertiary);color:var(--text-secondary)}.status-badge.connected{background-color:#4ade8033;color:var(--success)}.status-badge.connecting{background-color:#fbbf2433;color:#fbbf24;animation:pulse 1s infinite}.status-badge.streaming{background-color:#00c85333;color:var(--accent);animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.fps-badge{padding:.375rem .75rem;border-radius:var(--border-radius);font-size:.875rem;font-weight:600;background-color:var(--bg-tertiary);color:var(--accent-cyan);font-family:Monaco,Consolas,monospace}.renderer-toggle-container{display:flex;align-items:center;gap:.5rem;padding:.25rem .75rem;background-color:var(--bg-tertiary);border-radius:var(--border-radius)}.renderer-toggle-label{font-size:.75rem;color:var(--text-secondary);font-weight:500}.renderer-info{font-size:.625rem;color:var(--accent-cyan);background-color:#00d4ff1a;padding:.125rem .375rem;border-radius:4px;margin-left:.25rem}.toggle-switch{position:relative;display:inline-block;width:36px;height:20px}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;inset:0;background-color:var(--bg-secondary);border:1px solid var(--text-secondary);border-radius:20px;transition:.3s}.toggle-slider:before{position:absolute;content:"";height:14px;width:14px;left:2px;bottom:2px;background-color:var(--text-secondary);border-radius:50%;transition:.3s}.toggle-switch input:checked+.toggle-slider{background-color:#00c8534d;border-color:var(--accent)}.toggle-switch input:checked+.toggle-slider:before{background-color:var(--accent);transform:translate(16px)}.toggle-switch input:focus+.toggle-slider{box-shadow:0 0 1px var(--accent)}.main-content{flex:1;display:grid;grid-template-columns:1fr 300px;gap:1rem;padding:1rem;min-height:0;overflow:hidden}.video-container{position:relative;background-color:var(--bg-secondary);border-radius:var(--border-radius);overflow:hidden;display:flex;align-items:center;justify-content:center;min-height:0;height:100%}#video-canvas{max-width:100%;max-height:100%;background-color:#000}.video-controls{position:absolute;bottom:1rem;right:1rem;display:flex;gap:.5rem;opacity:0;transition:opacity .3s ease}.video-container:hover .video-controls{opacity:1}.control-btn{width:40px;height:40px;border-radius:50%;border:none;background-color:#0009;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background-color .2s ease}.control-btn:hover{background-color:#00c853cc}.control-btn svg{width:20px;height:20px}.connection-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background-color:#1a1a1af2;text-align:center}.overlay-content{display:flex;flex-direction:column;align-items:center;gap:1.5rem;padding:2rem}.goggles-icon{width:120px;height:72px}.overlay-content h2{font-size:1.75rem;font-weight:700}.overlay-content p{color:var(--text-secondary);max-width:400px}.connect-btn{display:flex;align-items:center;gap:.5rem;padding:1rem 2rem;font-size:1rem;font-weight:600;color:#fff;background:linear-gradient(135deg,var(--accent),#007e33);border:none;border-radius:var(--border-radius);cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.connect-btn:hover{transform:translateY(-2px);box-shadow:0 10px 30px #00c8534d}.connect-btn:active{transform:translateY(0)}.hint{font-size:.75rem;color:var(--text-secondary)}.info-panel{display:flex;flex-direction:column;gap:1rem;overflow-y:auto;overflow-x:hidden;min-height:0;height:100%;padding-right:4px;scrollbar-width:thin;scrollbar-color:var(--bg-tertiary) transparent}.info-panel::-webkit-scrollbar{width:6px}.info-panel::-webkit-scrollbar-track{background:transparent;border-radius:3px}.info-panel::-webkit-scrollbar-thumb{background-color:var(--bg-tertiary);border-radius:3px;transition:background-color .2s ease}.info-panel::-webkit-scrollbar-thumb:hover{background-color:var(--text-secondary)}.panel-section{background-color:var(--bg-secondary);border-radius:var(--border-radius);padding:1rem;overflow:hidden;word-wrap:break-word;overflow-wrap:break-word;flex-shrink:0}.panel-section h3{font-size:.875rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:.75rem}.device-info p{font-size:.875rem;margin-bottom:.25rem}.device-info strong{color:var(--text-secondary)}.controls{display:flex;flex-direction:column;gap:.5rem}.btn{padding:.75rem 1rem;font-size:.875rem;font-weight:600;border:none;border-radius:var(--border-radius);cursor:pointer;transition:opacity .2s ease}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,var(--accent),#007e33);color:#fff}.btn-primary:hover:not(:disabled){opacity:.9}.btn-secondary{background-color:var(--bg-tertiary);color:var(--text-primary)}.btn-secondary:hover:not(:disabled){background-color:#4d4d4d}.instructions{padding-left:1.5rem;font-size:.875rem;color:var(--text-secondary)}.instructions li{margin-bottom:.5rem}.device-list{list-style:none;font-size:.875rem}.device-list li{padding:.25rem 0;color:var(--text-secondary)}.device-list li:before{content:"•";color:var(--accent);margin-right:.5rem}.footer{background:linear-gradient(to right,var(--bg-secondary),var(--bg-tertiary));border-top:1px solid var(--bg-tertiary);padding:1.5rem;flex-shrink:0;box-shadow:0 -4px 12px #0000004d}.footer-content{display:flex;align-items:center;justify-content:space-between;gap:2rem;max-width:1400px;margin:0 auto}.footer-section{display:flex;align-items:center;gap:1.5rem}.footer-info{flex:1}.footer-branding{display:flex;flex-direction:column;gap:.25rem}.footer-title{font-size:.95rem;font-weight:700;color:var(--text-primary);letter-spacing:-.5px}.footer-subtitle{font-size:.75rem;color:var(--text-secondary);font-weight:500}.footer-links{gap:1rem}.footer-link{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background-color:#00c85314;border:1px solid rgba(0,200,83,.2);border-radius:6px;color:var(--text-primary);text-decoration:none;font-size:.85rem;font-weight:500;transition:all .2s ease}.footer-link:hover{background-color:#00c85326;border-color:var(--accent);color:var(--accent)}.footer-link svg{width:16px;height:16px;opacity:.8}.footer-link:hover svg{opacity:1}.footer-donate{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background-color:#ffffff05;border:1px solid rgba(255,255,255,.04);border-radius:6px;color:var(--accent)}.footer-donate:hover{background-color:#00c85314;border-color:var(--accent);color:var(--accent)}.footer-donate svg{width:16px;height:16px}.footer-meta{margin-left:auto}.footer-version{font-size:.75rem;color:var(--text-secondary);font-weight:500;padding:.375rem .75rem;background-color:var(--bg-secondary);border-radius:4px;border:1px solid var(--bg-tertiary)}.error-notification{position:fixed;top:1rem;right:1rem;padding:1rem 1.5rem;background-color:var(--error);color:#fff;border-radius:var(--border-radius);font-size:.875rem;font-weight:500;z-index:1000;animation:slideIn .3s ease}@keyframes slideIn{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}@media(max-width:768px){.main-content{grid-template-columns:1fr;grid-template-rows:1fr auto}.video-container{min-height:200px}.info-panel{max-height:40vh}.header{flex-direction:column;gap:.5rem;text-align:center;padding:.75rem 1rem}.header-status{flex-wrap:wrap;justify-content:center;gap:.5rem}.renderer-toggle-container{order:-1;width:100%;justify-content:center;margin-bottom:.25rem}.video-controls{opacity:1}.footer{padding:1rem .75rem}.footer-content{flex-direction:column;gap:1rem;text-align:center}.footer-section{justify-content:center;width:100%}.footer-links{flex-wrap:wrap;justify-content:center}.footer-meta{margin-left:0}}.popout-mode{background:transparent}.popout-mode #app{min-height:100vh}.popout-mode .header,.popout-mode .info-panel,.popout-mode .footer{display:none}.popout-mode .main-content{grid-template-columns:1fr;padding:0}.popout-mode .video-container{border-radius:0;height:100vh}.quality-mode-selector{display:flex;flex-direction:column;gap:.5rem}.quality-option{display:flex;align-items:flex-start;gap:.75rem;padding:.75rem;background-color:var(--bg-tertiary);border-radius:var(--border-radius);cursor:pointer;transition:background-color .2s ease,border-color .2s ease;border:2px solid transparent}.quality-option:hover{background-color:#4d4d4d}.quality-option input[type=radio]{margin-top:.25rem;accent-color:var(--accent);width:16px;height:16px;cursor:pointer}.quality-option:has(input:checked){border-color:var(--accent);background-color:#00c8531a}.quality-label{display:flex;flex-direction:column;gap:.25rem}.quality-name{font-size:.875rem;font-weight:600;color:var(--text-primary)}.quality-desc{font-size:.75rem;color:var(--text-secondary);line-height:1.3}.control-btn.pip-active{background-color:#00c853cc}.control-btn.pip-active:hover{background-color:#00c853}.control-btn.osd-active{background-color:#00c853cc}.control-btn.osd-active:hover{background-color:#00c853}.control-btn.recording{background-color:#ef4444e6;animation:recording-pulse 1s ease-in-out infinite}.control-btn.recording:hover{background-color:#ef4444}.control-btn.recording svg{fill:#fff}@keyframes recording-pulse{0%,to{box-shadow:0 0 #ef4444b3}50%{box-shadow:0 0 0 8px #ef444400}}.record-timer{background-color:#ef4444e6;color:#fff;padding:.25rem .5rem;border-radius:4px;font-size:.875rem;font-weight:600;font-family:SF Mono,Monaco,Consolas,monospace;min-width:50px;text-align:center}.record-timer.hidden{display:none}.osd-controls{display:flex;flex-direction:column;gap:.5rem}.osd-option{display:flex;align-items:center;gap:.75rem;padding:.5rem .75rem;background-color:var(--bg-tertiary);border-radius:var(--border-radius);cursor:pointer;transition:background-color .2s ease}.osd-option:hover{background-color:#4d4d4d}.osd-option input[type=checkbox]{accent-color:var(--accent);width:16px;height:16px;cursor:pointer}.osd-label{flex:1;font-size:.875rem;color:var(--text-primary)}.osd-shortcut{font-size:.625rem;font-family:Monaco,Consolas,monospace;padding:.125rem .375rem;background-color:var(--bg-secondary);border-radius:3px;color:var(--text-secondary);border:1px solid var(--bg-tertiary)}.osd-hint{font-size:.75rem;color:var(--text-secondary);margin-top:.5rem;font-style:italic}.osd-disclaimer{font-size:.75rem;color:var(--warning);background-color:#fbbf241a;border-left:3px solid var(--warning);padding:.75rem;margin-top:1rem;border-radius:4px;line-height:1.4}.shortcuts-list{list-style:none;font-size:.813rem}.shortcuts-list li{display:flex;align-items:center;gap:.5rem;padding:.25rem 0;color:var(--text-secondary)}.shortcuts-list kbd{display:inline-flex;align-items:center;justify-content:center;min-width:24px;height:24px;padding:0 .5rem;font-family:Monaco,Consolas,monospace;font-size:.75rem;font-weight:600;color:var(--text-primary);background-color:var(--bg-tertiary);border:1px solid #555;border-radius:4px;box-shadow:0 2px #333}.video-container:fullscreen{background-color:#000;border-radius:0;width:100vw;height:100vh}.video-container:fullscreen #video-canvas{width:100%;height:100%;max-width:100vw;max-height:100vh;object-fit:contain}.video-container:fullscreen .video-controls{opacity:0;transition:opacity .3s ease}.video-container:fullscreen:hover .video-controls{opacity:1}.video-container:-webkit-full-screen{background-color:#000;border-radius:0;width:100vw;height:100vh}.video-container:-webkit-full-screen #video-canvas{width:100%;height:100%;max-width:100vw;max-height:100vh;object-fit:contain}.ai-controls{display:flex;flex-direction:column;gap:.75rem}.ai-hint{font-size:.75rem;color:var(--text-secondary);margin-bottom:.5rem}.api-key-input{display:flex;gap:.5rem}.api-key-input input{flex:1;padding:.5rem;font-size:.813rem;background-color:var(--bg-tertiary);border:1px solid #555;border-radius:4px;color:var(--text-primary)}.api-key-input input::placeholder{color:var(--text-secondary)}.api-key-input input:focus{outline:none;border-color:var(--accent)}.api-key-status{font-size:.75rem;color:var(--text-secondary)}.api-key-status.saved{color:var(--success)}.api-key-status.error{color:var(--error)}.btn-small{padding:.375rem .75rem;font-size:.75rem}.ai-provider-select{display:flex;align-items:center;gap:.5rem;font-size:.813rem;margin-bottom:.5rem}.ai-provider-select label{color:var(--text-secondary)}.ai-provider-select select{flex:1;padding:.375rem .5rem;font-size:.75rem;background-color:var(--bg-tertiary);border:1px solid #555;border-radius:4px;color:var(--text-primary)}.ai-provider-select select:focus{outline:none;border-color:var(--accent)}.ai-interval-control{display:flex;align-items:center;gap:.5rem;font-size:.813rem}.ai-interval-control label{color:var(--text-secondary)}.ai-interval-control select{padding:.375rem .5rem;font-size:.75rem;background-color:var(--bg-tertiary);border:1px solid #555;border-radius:4px;color:var(--text-primary)}.ai-interval-control select:focus{outline:none;border-color:var(--accent)}.ai-status{display:flex;align-items:center;gap:.5rem;font-size:.813rem;padding:.5rem;background-color:var(--bg-tertiary);border-radius:4px}.ai-status-indicator{font-size:.75rem}.ai-status.disabled .ai-status-indicator{color:var(--text-secondary)}.ai-status.running .ai-status-indicator{color:var(--success);animation:pulse 1.5s infinite}.ai-status.analyzing .ai-status-indicator{color:var(--warning);animation:pulse .5s infinite}.ai-status.error .ai-status-indicator{color:var(--error)}.ai-status-text{color:var(--text-secondary)}.ai-warning{font-size:.688rem;color:var(--warning);margin-top:.25rem}.control-btn.share-active{background-color:var(--accent);animation:share-pulse 2s infinite}.control-btn.share-active:hover{background-color:var(--accent)}@keyframes share-pulse{0%,to{box-shadow:0 0 #00c85380}50%{box-shadow:0 0 0 8px #00c85300}}.share-modal{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background-color:#000c;z-index:100;animation:fadeIn .2s ease}.share-modal.hidden{display:none}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.share-modal-content{background-color:var(--bg-secondary);border-radius:var(--border-radius);padding:1.5rem;max-width:450px;width:90%;position:relative;animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.share-modal-close{position:absolute;top:.75rem;right:.75rem;background:none;border:none;color:var(--text-secondary);font-size:1.5rem;cursor:pointer;line-height:1;padding:.25rem;transition:color .2s ease}.share-modal-close:hover{color:var(--text-primary)}.share-modal-content h3{font-size:1.25rem;margin-bottom:.75rem;color:var(--text-primary)}.share-description{font-size:.875rem;color:var(--text-secondary);margin-bottom:1rem}.help-modal{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background-color:#0009;z-index:100;animation:fadeIn .2s ease}.help-modal.hidden{display:none}.help-modal-content{background-color:var(--bg-secondary);border-radius:var(--border-radius);padding:1.25rem;max-width:560px;width:90%;position:relative;animation:slideUp .25s ease}.help-modal-content h3{font-size:1.125rem;margin-bottom:.5rem;color:var(--text-primary)}.help-body{font-size:.875rem;color:var(--text-secondary);line-height:1.5}.help-body ol{margin-left:1.25rem;margin-bottom:.5rem}.help-body a{color:var(--accent-cyan);text-decoration:underline}.help-link{color:var(--accent-cyan);text-decoration:underline;cursor:pointer;font-size:.875rem}.help-btn{width:36px;height:36px;border-radius:6px;background-color:#ffffff05;color:var(--text-primary)}.help-btn svg{width:18px;height:18px}.share-url-container{display:flex;gap:.5rem;margin-bottom:1rem}.share-url-input{flex:1;padding:.75rem;font-size:.875rem;font-family:Monaco,Consolas,monospace;background-color:var(--bg-tertiary);border:1px solid #555;border-radius:var(--border-radius);color:var(--text-primary)}.share-url-input:focus{outline:none;border-color:var(--accent)}.share-info{display:flex;justify-content:space-between;margin-bottom:1rem;padding:.75rem;background-color:var(--bg-tertiary);border-radius:var(--border-radius)}.share-key,.share-viewers{display:flex;align-items:center;gap:.5rem}.share-key-label,.share-viewers-label{font-size:.75rem;color:var(--text-secondary)}.share-key-value{font-family:Monaco,Consolas,monospace;font-size:.875rem;font-weight:600;color:var(--accent);letter-spacing:1px}.share-viewer-count{font-size:1rem;font-weight:600;color:var(--accent-cyan)}.share-status{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background-color:var(--bg-tertiary);border-radius:var(--border-radius);margin-bottom:1rem}.share-status-indicator{font-size:.75rem;color:var(--text-secondary)}.share-status.sharing .share-status-indicator{color:var(--success);animation:pulse 1.5s infinite}.share-status.connecting .share-status-indicator{color:var(--warning);animation:pulse .5s infinite}.share-status.error .share-status-indicator{color:var(--error)}.share-status-text{font-size:.813rem;color:var(--text-secondary)}.share-actions{display:flex;gap:.75rem}.share-actions .btn{flex:1}.share-hint{font-size:.688rem;color:var(--text-secondary);margin-top:1rem;text-align:center;line-height:1.5}.viewer-banner{position:absolute;top:0;left:0;right:0;background:linear-gradient(135deg,#00c853e6,#007e33e6);padding:.5rem 1rem;z-index:50;animation:slideDown .3s ease}.viewer-banner.hidden{display:none}@keyframes slideDown{0%{opacity:0;transform:translateY(-100%)}to{opacity:1;transform:translateY(0)}}.viewer-banner-content{display:flex;align-items:center;justify-content:center;gap:.75rem}.viewer-icon{font-size:1.25rem}.viewer-text{font-weight:600;font-size:.875rem}.viewer-share-key{font-family:Monaco,Consolas,monospace;font-size:.75rem;background-color:#fff3;padding:.25rem .5rem;border-radius:4px}.viewer-banner .btn-small{padding:.25rem .75rem;font-size:.75rem}.viewer-banner .btn-primary{background-color:var(--primary-color);font-size:1rem;line-height:1}.viewer-banner .btn-primary:hover{background-color:var(--primary-hover)}body.viewer-mode .info-panel{display:none}body.viewer-mode .main-content{grid-template-columns:1fr}body.viewer-mode .video-controls{display:none}body.viewer-mode .osd-top-left,body.viewer-mode .osd-top-center,body.viewer-mode .osd-top-right{top:50px!important}#viewer-canvas{background:#000;cursor:pointer}.video-container:fullscreen{background:#000;display:flex;align-items:center;justify-content:center}.video-container:fullscreen #viewer-canvas{max-width:100%;max-height:100%;width:auto;height:auto}.video-container:fullscreen .viewer-banner{position:fixed;top:0;left:0;right:0;z-index:1000;opacity:0;transition:opacity .3s ease}.video-container:fullscreen:hover .viewer-banner{opacity:1}body.viewer-mode .renderer-toggle-container,body.viewer-mode .header-status .renderer-toggle-container{display:none}.btn-small{padding:.5rem .75rem;font-size:.75rem}.btn-copy-success{background-color:var(--success)!important;color:#fff!important}body.rc2-mode{--accent: #FF6B00;--accent-lime: #FF6B00}body.rc2-mode .status-badge.streaming{background-color:#ff6b0033;color:#ff6b00}body.rc2-mode .status-badge.connected{background-color:#ff6b0026;color:#ff9500}.rc2-notice{background:linear-gradient(90deg,#fff7f0,#fff2e6);color:#5a2b00;border-left:6px solid #FF6B00;padding:.75rem 1rem;margin:0 1rem;border-radius:6px;font-weight:600;flex-shrink:0}.rc2-notice a{color:#bf4b00;text-decoration:underline}.rc2-notice a:hover{color:#ff6b00}.rc2-notice{display:flex;justify-content:space-between;align-items:center;gap:1rem}.rc2-notice-content{flex:1}.rc2-notice-actions{display:flex;align-items:center;gap:.5rem}.rc2-notice-remember input{margin-right:.5rem}.rc2-notice button{background:transparent;border:1px solid rgba(0,0,0,.06);padding:.4rem .6rem;border-radius:4px;cursor:pointer}.rc2-notice[hidden]{display:none!important}.rc2-notice-close-x{position:absolute;top:8px;right:12px;background:transparent;border:none;color:#5a2b00;font-size:20px;line-height:1;padding:.2rem .4rem;cursor:pointer}.rc2-notice{position:relative}body.rc2-mode .connect-btn{background:linear-gradient(135deg,#ff6b00,#ff9500)}body.rc2-mode .connect-btn:hover{background:linear-gradient(135deg,#ff9500,#ffb000)}body.rc2-mode .btn-primary{background:linear-gradient(135deg,#ff6b00,#ff9500)}body.rc2-mode .btn-primary:hover{background:linear-gradient(135deg,#ff9500,#ffb000)}body.rc2-mode a{color:#ff9500}body.rc2-mode a:hover{color:#ffb000}body.rc2-mode .goggles-icon ellipse,body.rc2-mode .goggles-icon rect:first-of-type{fill:#ff6b00}
