: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}.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:.5rem 1rem;background-color:#c0392b;font-size:.875rem}.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:1rem}.viewer-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid #333}.viewer-header h3{margin:0;font-size:1rem;color:#888}.connection-status{display:flex;align-items:center;gap:1rem}.status-indicator{padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:500;text-transform:capitalize}.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{display:grid;grid-template-columns:1fr 1fr;gap:1rem}@media(max-width:900px){.viewer-content{grid-template-columns:1fr}}.video-section{position:relative;background-color:#000;border-radius:8px;overflow:hidden;aspect-ratio:4/3}.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:#888;font-size:1rem}.controls-section{display:flex;flex-direction:column;gap:1rem}.data-channel-section{background-color:#2a2a2a;border-radius:8px;padding:1rem}.data-channel-section h4{margin:0 0 .75rem;font-size:.9rem;color:#aaa}.message-input-row{display:flex;gap:.5rem;margin-bottom:.75rem}.message-input-row input{flex:1;padding:.5rem;border-radius:4px;border:1px solid #444;background-color:#1a1a1a;color:inherit;font-size:.875rem}.message-input-row input:disabled{opacity:.5;cursor:not-allowed}.message-input-row button{padding:.5rem 1rem;font-size:.875rem}.received-messages{font-size:.8rem}.received-messages strong{display:block;margin-bottom:.5rem;color:#888}.messages-list{max-height:100px;overflow-y:auto;background-color:#1a1a1a;border-radius:4px;padding:.5rem}.no-messages{color:#666;font-style:italic}.log-section{background-color:#2a2a2a;border-radius:8px;padding:1rem;flex:1;min-height:150px}.log-section h4{margin:0 0 .75rem;font-size:.9rem;color:#aaa}.log-entries{max-height:200px;overflow-y:auto;font-family:monospace;font-size:.75rem;background-color:#1a1a1a;border-radius:4px;padding:.5rem}.log-entry{margin-bottom:.25rem}.log-timestamp{color:#666}.log-info{color:#aaa}.log-success{color:#7ae27a}.log-warning{color:#f0ad4e}.log-error{color:#e27a7a}
