:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;min-width:320px;min-height:100vh}#root{width:100%;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.loading-screen{display:flex;justify-content:center;align-items:center;height:100vh;font-size:1.25rem;color:#888}.loading{text-align:center;padding:2rem;color:#888}.error{color:#e57373;margin-top:.75rem;font-size:.875rem}.empty-state{text-align:center;color:#888;padding:2rem}.login-page{display:flex;justify-content:center;align-items:center;min-height:100vh}.login-card{background-color:#2a2a2a;padding:3rem;border-radius:12px;text-align:center;min-width:320px}.login-card h1{margin:0 0 .5rem}.login-card .subtitle{color:#888;margin:0 0 2rem}.google-btn{width:100%;padding:.875rem 1.5rem;background-color:#4285f4;color:#fff;border:none;border-radius:6px;font-size:1rem;cursor:pointer;transition:background-color .2s}.google-btn:hover:not(:disabled){background-color:#357abd}.google-btn:disabled{opacity:.6;cursor:not-allowed}.dashboard{max-width:1000px;margin:0 auto;padding:1rem 2rem}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid #333}.dashboard-header h1{margin:0;font-size:1.5rem}.user-info{display:flex;align-items:center;gap:1rem}.user-info span{color:#888}.user-info button{padding:.5rem 1rem;font-size:.875rem}.dashboard-nav{display:flex;gap:.5rem;margin-bottom:1.5rem}.tab-btn{padding:.75rem 1.5rem;background-color:transparent;border:1px solid #444;border-radius:6px;color:#888;cursor:pointer;transition:all .2s}.tab-btn:hover{border-color:#666;color:#fff}.tab-btn.active{background-color:#646cff;border-color:#646cff;color:#fff}.create-form{display:flex;gap:.75rem;margin-bottom:1.5rem}.create-form input,.create-form select{padding:.75rem;border-radius:6px;border:1px solid #444;background-color:#1a1a1a;color:inherit;font-size:1rem}.create-form input{flex:1}.create-form input:focus,.create-form select:focus{outline:none;border-color:#646cff}.create-form button{padding:.75rem 1.5rem;white-space:nowrap}.items-list{list-style:none;padding:0;margin:0}.item-row{display:flex;justify-content:space-between;align-items:center;padding:1rem;background-color:#2a2a2a;border-radius:8px;margin-bottom:.5rem}.item-row.clickable{cursor:pointer;transition:background-color .2s}.item-row.clickable:hover{background-color:#353535}.item-row.revoked{opacity:.5}.item-info{display:flex;flex-direction:column;gap:.25rem}.item-name{font-weight:500}.item-name.room-link{color:#7c8aff}.item-row.clickable:hover .item-name.room-link{text-decoration:underline}.item-meta{font-size:.8rem;color:#888}.item-actions{display:flex;align-items:center;gap:1rem}.item-id{font-size:.8rem;background-color:#1a1a1a;padding:.25rem .5rem;border-radius:4px}.item-scope{font-size:.8rem;background-color:#3a3a5a;padding:.25rem .5rem;border-radius:4px}.delete-btn{padding:.5rem 1rem;background-color:#c0392b;font-size:.875rem}.delete-btn:hover{background-color:#a93226}.back-btn{padding:.5rem 1rem;background-color:transparent;border:1px solid #444;border-radius:6px;color:#888;cursor:pointer;transition:all .2s;font-size:.875rem;white-space:nowrap;flex-shrink:0}.back-btn:hover{border-color:#666;color:#fff}.connect-btn{padding:.5rem 1rem;background-color:#27ae60;font-size:.875rem}.connect-btn:hover{background-color:#219a52}.disconnect-btn{padding:.4rem .75rem;background-color:#c0392b;font-size:.8rem;white-space:nowrap;flex-shrink:0}.disconnect-btn:hover{background-color:#a93226}.refresh-btn{padding:.5rem;background-color:transparent;border:1px solid #444;border-radius:6px;cursor:pointer;font-size:1rem}.refresh-btn:hover:not(:disabled){border-color:#666}.refresh-btn:disabled{opacity:.5;cursor:not-allowed}.token-display{background-color:#2d4a2d;border:1px solid #4a7a4a;border-radius:8px;padding:1rem;margin-bottom:1.5rem}.token-display p{margin:0 0 .75rem}.token-display .token{display:block;background-color:#1a1a1a;padding:.75rem;border-radius:4px;margin-bottom:.75rem;word-break:break-all;font-size:.8rem}.token-display button{margin-right:.5rem;padding:.5rem 1rem;font-size:.875rem}.sessions-header{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem}.sessions-header h2{margin:0;flex:1}.session-status{font-size:.75rem;padding:.25rem .75rem;border-radius:12px;font-weight:500}.status-created{background-color:#3a3a5a;color:#a0a0ff}.status-offer_set{background-color:#3a4a3a;color:#a0ffa0}.status-answer_set{background-color:#4a4a3a;color:#ffffa0}.status-completed{background-color:#2d4a2d;color:#4a7a4a}.status-expired{background-color:#4a2d2d;color:#7a4a4a}.webrtc-viewer{background-color:#1a1a1a;border-radius:8px;padding:.75rem}.viewer-header{display:flex;justify-content:space-between;align-items:center;gap:.5rem;margin-bottom:.75rem;padding-bottom:.5rem;border-bottom:1px solid #333;min-height:36px}.viewer-header-left{display:flex;align-items:center;gap:.5rem;min-width:0;flex:1}.viewer-header-right{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.viewer-info{font-size:.85rem;color:#ccc;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.viewer-info-sep{color:#555}.viewer-info-session{color:#888;font-size:.75rem;font-family:monospace}.status-indicator{padding:.2rem .6rem;border-radius:12px;font-size:.7rem;font-weight:500;text-transform:capitalize;white-space:nowrap}.status-new,.status-connecting{background-color:#3a3a5a;color:#a0a0ff}.status-connected{background-color:#2d4a2d;color:#7ae27a}.status-disconnected,.status-closed{background-color:#4a3a3a;color:#e27a7a}.status-failed{background-color:#4a2d2d;color:#ff6b6b}.viewer-content{position:relative;background-color:#000;border-radius:8px;overflow:hidden;aspect-ratio:16/9;width:100%}.video-section{position:absolute;inset:0}.remote-video{width:100%;height:100%;object-fit:contain}.video-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background-color:#000000b3;color:#ccc;z-index:5}.video-overlay-content{display:flex;flex-direction:column;align-items:center;gap:1.25rem}.video-overlay-text{font-size:1.25rem;letter-spacing:.04em;text-align:center}@keyframes spin{to{transform:rotate(360deg)}}.video-spinner{width:64px;height:64px;border:4px solid rgba(255,255,255,.15);border-top-color:#646cff;border-radius:50%;animation:spin .8s linear infinite}.ptz-controls{display:flex;flex-direction:column;gap:1rem;padding:.75rem;background-color:#2a2a2a;border-radius:12px;align-items:center}.ptz-controls.ptz-disabled{opacity:.4;pointer-events:none}.ptz-controls.ptz-overlay{position:absolute;z-index:10;bottom:.75rem;left:.75rem;right:.75rem;flex-direction:row;justify-content:space-between;align-items:flex-end;background-color:transparent;padding:0;border-radius:0;pointer-events:none;opacity:.55;transition:opacity .3s ease}.ptz-controls.ptz-overlay:hover,.ptz-controls.ptz-overlay:active{opacity:1}.ptz-controls.ptz-overlay .ptz-dpad,.ptz-controls.ptz-overlay .ptz-zoom{pointer-events:auto;background-color:#1e1e1ebf;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);border-radius:12px;padding:.5rem}.ptz-controls.ptz-overlay.ptz-disabled{opacity:.25}.ptz-dpad{display:flex;flex-direction:column;align-items:center;gap:.25rem}.ptz-dpad-middle{display:flex;gap:.25rem;align-items:center}.ptz-btn{width:44px;height:44px;border:none;border-radius:8px;background-color:#646cffcc;color:#fff;font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background-color .15s,transform .1s;user-select:none;-webkit-user-select:none;touch-action:manipulation;padding:0}.ptz-btn:hover:not(:disabled){background-color:#646cff}.ptz-btn:active:not(:disabled){background-color:#5058dc;transform:scale(.95)}.ptz-btn:disabled{opacity:.4;cursor:not-allowed}.ptz-home{background-color:#27ae60cc}.ptz-home:hover:not(:disabled){background-color:#27ae60}.ptz-home:active:not(:disabled){background-color:#219a52}.ptz-zoom{display:flex;flex-direction:column;align-items:center;gap:.25rem}.ptz-zoom-label{font-size:.7rem;color:#aaa;text-transform:uppercase;letter-spacing:.05em}.ptz-zoom-in,.ptz-zoom-out{width:44px;height:44px;font-size:1.25rem;font-weight:700}.ptz-zoom-in{background-color:#3498dbcc}.ptz-zoom-in:hover:not(:disabled){background-color:#3498db}.ptz-zoom-out{background-color:#e74c3ccc}.ptz-zoom-out:hover:not(:disabled){background-color:#e74c3c}.fullscreen-btn{position:absolute;z-index:11;top:.5rem;right:.5rem;width:36px;height:36px;border:none;border-radius:6px;background-color:#1e1e1eb3;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);color:#ccc;font-size:1.25rem;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:.55;transition:opacity .3s ease,background-color .2s;padding:0}.fullscreen-btn:hover{opacity:1;background-color:#323232e6;color:#fff}.viewer-content.viewer-fullscreen{border-radius:0}.viewer-content:fullscreen{width:100vw;height:100vh;aspect-ratio:auto;border-radius:0;background-color:#000}.viewer-content:-webkit-full-screen{width:100vw;height:100vh;aspect-ratio:auto;border-radius:0;background-color:#000}.viewer-content:fullscreen .ptz-controls.ptz-overlay{opacity:.65}.viewer-content:fullscreen .ptz-controls.ptz-overlay:hover,.viewer-content:fullscreen .ptz-controls.ptz-overlay:active{opacity:1}.viewer-content:fullscreen .fullscreen-btn{opacity:.65}.viewer-content:fullscreen .fullscreen-btn:hover{opacity:1}@media(max-width:768px){.dashboard{padding:.75rem 1rem}.dashboard-header{flex-direction:column;align-items:flex-start;gap:.5rem;margin-bottom:1rem;padding-bottom:.75rem}.dashboard-header h1{font-size:1.25rem}.user-info{width:100%;justify-content:space-between}.dashboard-nav{gap:.25rem}.tab-btn{flex:1;text-align:center;padding:.625rem .75rem;font-size:.875rem}.create-form{flex-wrap:wrap}.create-form input{min-width:0}.item-row{flex-wrap:wrap;gap:.5rem;padding:.75rem}.item-actions{width:100%;justify-content:flex-end}.sessions-header{flex-wrap:wrap;gap:.5rem}.sessions-header h2{font-size:1.1rem}}@media(max-width:768px){.webrtc-viewer{padding:.5rem;border-radius:0;margin:-.5rem -1rem;width:calc(100% + 2rem)}.viewer-header{gap:.375rem;margin-bottom:.5rem;padding-bottom:.375rem;flex-wrap:wrap}.viewer-header .back-btn{padding:.375rem .625rem;font-size:.8rem}.viewer-info{font-size:.75rem}.viewer-info-session{font-size:.7rem}.status-indicator{font-size:.65rem;padding:.15rem .5rem}.disconnect-btn{padding:.3rem .6rem;font-size:.75rem}.viewer-content{border-radius:4px}.ptz-btn{width:40px;height:40px;font-size:.9rem}.ptz-zoom-in,.ptz-zoom-out{width:40px;height:40px;font-size:1.1rem}.ptz-controls.ptz-overlay{bottom:.5rem;left:.5rem;right:.5rem}.ptz-controls.ptz-overlay .ptz-dpad,.ptz-controls.ptz-overlay .ptz-zoom{padding:.375rem}.fullscreen-btn{width:32px;height:32px;font-size:1.1rem;top:.375rem;right:.375rem}}@media(max-width:380px){.viewer-header-left{flex-wrap:wrap;gap:.25rem}.viewer-info-sep,.viewer-info-session{display:none}.ptz-btn{width:36px;height:36px;font-size:.85rem;border-radius:6px}.ptz-zoom-in,.ptz-zoom-out{width:36px;height:36px;font-size:1rem}.ptz-controls.ptz-overlay .ptz-dpad,.ptz-controls.ptz-overlay .ptz-zoom{padding:.25rem}}@media(hover:none)and (pointer:coarse){.ptz-controls.ptz-overlay,.fullscreen-btn{opacity:.65}}
