: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;display:flex;place-items:center;min-width:320px;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}}.admin-panel{width:100%;max-width:1600px;margin:0 auto;padding:20px;min-height:100vh;background:#1a1a1a;color:#fff}.admin-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:30px;padding-bottom:20px;border-bottom:2px solid #3b82f6}.admin-header h1{margin:0;font-size:32px;color:#fff}.back-btn,.refresh-btn{padding:10px 20px;background:#3b82f6;color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;transition:background .2s;margin-left:10px}.back-btn:hover,.refresh-btn:hover{background:#2563eb}.admin-content{display:grid;grid-template-columns:1fr 1.5fr;gap:30px;height:calc(100vh - 200px)}.sessions-list{background:#2a2a2a;border-radius:12px;padding:20px;overflow-y:auto}.sessions-list h2{margin:0 0 20px;font-size:20px;color:#fff}.sessions-grid{display:flex;flex-direction:column;gap:12px}.session-card{background:#1a1a1a;border:2px solid #3b82f6;border-radius:8px;padding:16px;cursor:pointer;transition:all .2s}.session-card:hover{border-color:#60a5fa;transform:translate(4px)}.session-card.selected{border-color:#4ade80;background:#1a2a1a}.session-card-header{margin-bottom:12px}.session-id{font-family:Courier New,monospace;font-size:16px;font-weight:600;color:#4ade80;word-break:break-all}.session-card-body{display:flex;flex-direction:column;gap:8px}.session-info{display:flex;justify-content:space-between;font-size:13px}.session-info .label{color:#a0a0a0;font-weight:500}.session-info .value{color:#fff;text-align:right;max-width:60%;word-break:break-word}.transcripts-panel{background:#2a2a2a;border-radius:12px;padding:20px;overflow-y:auto;display:flex;flex-direction:column}.transcripts-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:15px;border-bottom:1px solid #3b82f6}.transcripts-header h2{margin:0;font-size:20px;color:#fff;word-break:break-all}.close-btn{background:#ef4444;color:#fff;border:none;border-radius:50%;width:32px;height:32px;cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;transition:background .2s;flex-shrink:0}.close-btn:hover{background:#dc2626}.transcripts-list{display:flex;flex-direction:column;gap:16px}.transcript-item{background:#1a1a1a;border-radius:8px;padding:16px;border-left:4px solid #3b82f6}.transcript-header{display:flex;align-items:center;gap:12px;margin-bottom:12px;flex-wrap:wrap}.speaker-badge{background:#3b82f6;color:#fff;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600;text-transform:uppercase}.transcript-item.local .speaker-badge{background:#4ade80}.transcript-item.remote .speaker-badge{background:#f59e0b}.timestamp{color:#a0a0a0;font-size:12px}.languages{color:#60a5fa;font-size:12px;font-weight:500}.transcript-content{display:flex;flex-direction:column;gap:10px}.original-text,.translated-text{font-size:14px;line-height:1.6}.original-text{color:#a0a0a0;font-style:italic}.original-text strong{color:#fff;font-style:normal}.translated-text{color:#fff;font-weight:500}.translated-text strong{color:#60a5fa}.empty-state{text-align:center;padding:60px 20px;color:#888;font-style:italic}.sessions-list::-webkit-scrollbar,.transcripts-panel::-webkit-scrollbar{width:8px}.sessions-list::-webkit-scrollbar-track,.transcripts-panel::-webkit-scrollbar-track{background:#1a1a1a;border-radius:4px}.sessions-list::-webkit-scrollbar-thumb,.transcripts-panel::-webkit-scrollbar-thumb{background:#3b82f6;border-radius:4px}.sessions-list::-webkit-scrollbar-thumb:hover,.transcripts-panel::-webkit-scrollbar-thumb:hover{background:#60a5fa}@media(max-width:1200px){.admin-content{grid-template-columns:1fr;height:auto}.sessions-list,.transcripts-panel{max-height:500px}}@media(max-width:768px){.admin-header{flex-direction:column;align-items:flex-start;gap:10px}.admin-header h1{font-size:24px}.back-btn,.refresh-btn{width:100%;margin-left:0;margin-top:5px}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#1a1a1a;color:#fff}.App{min-height:100vh;display:flex;flex-direction:column;align-items:center;padding:20px;position:relative}.admin-toggle{position:fixed;top:20px;right:20px;z-index:1000}.admin-btn{padding:10px 20px;background:#2a2a2a;color:#fff;border:2px solid #3b82f6;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s;text-decoration:none;display:inline-block}.admin-btn:hover{background:#3b82f6;border-color:#60a5fa;transform:scale(1.05)}.video-call-container{width:100%;max-width:1400px;display:flex;flex-direction:column;align-items:center;gap:20px}.video-call-container h1{margin-bottom:20px;color:#fff}.header-with-menu{display:flex;align-items:flex-start;justify-content:space-between;width:100%;gap:20px}.header-info{display:flex;flex-direction:column;gap:8px;flex:1}.header-info h1{margin:0;font-size:28px}.session-info{display:flex;align-items:center;gap:8px;background:#1a1a1a;padding:8px 12px;border-radius:8px;font-size:14px}.session-id-label{color:#a0a0a0;font-weight:500}.session-id{font-family:Courier New,monospace;color:#4ade80;font-size:14px;font-weight:600}.user-name{color:#a0a0a0;font-size:14px;font-style:italic}.end-session-btn{padding:10px 20px;background:#ef4444;color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;transition:background .2s;margin-top:10px}.end-session-btn:hover{background:#dc2626}.language-menu-container{position:relative}.language-menu-icon{width:48px;height:48px;border-radius:50%;border:2px solid #3b82f6;background:#2a2a2a;color:#fff;font-size:24px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.language-menu-icon:hover{background:#3b82f6;transform:scale(1.1)}.language-menu-dropdown{position:absolute;top:calc(100% + 10px);right:0;background:#2a2a2a;border:2px solid #3b82f6;border-radius:12px;padding:20px;min-width:280px;z-index:1000;box-shadow:0 4px 20px #00000080;animation:slideDown .2s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.language-menu-item{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}.language-menu-item:last-child{margin-bottom:0}.language-menu-item label{font-size:14px;color:#a0a0a0;font-weight:500}.language-selection{display:flex;gap:20px;align-items:center;justify-content:center;padding:16px 24px;background:#2a2a2a;border-radius:12px;margin-bottom:20px;flex-wrap:wrap}.language-selector{display:flex;flex-direction:column;gap:8px;min-width:200px}.language-selector label{font-size:14px;color:#a0a0a0;font-weight:500}.language-dropdown{padding:10px 12px;background:#1a1a1a;border:2px solid #3b82f6;border-radius:8px;color:#fff;font-size:14px;cursor:pointer;transition:border-color .2s;font-family:inherit}.language-dropdown:focus{outline:none;border-color:#60a5fa}.language-dropdown:hover{border-color:#60a5fa}.language-dropdown option{background:#1a1a1a;color:#fff}.error-message{background:#f44;color:#fff;padding:12px 20px;border-radius:8px;margin-bottom:20px;max-width:100%}.info-message{background:#3b82f6;color:#fff;padding:12px 20px;border-radius:8px;margin-bottom:20px;text-align:center}.error-boundary{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px;text-align:center}.error-boundary h2{color:#f44;margin-bottom:16px}.error-boundary button{margin-top:20px;padding:12px 24px;background:#3b82f6;color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:16px}.error-boundary button:hover{background:#2563eb}.loading-indicator{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:20px}.spinner{width:50px;height:50px;border:4px solid #3b82f6;border-top:4px solid transparent;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.status-indicator{margin-left:8px;font-size:12px;display:inline-flex;align-items:center}.status-indicator.listening{animation:pulse 2s ease-in-out infinite}.status-indicator.connected{color:#4ade80}.status-indicator.transcribing{margin-left:6px}.transcribing-light{width:8px;height:8px;background-color:#22c55e;border-radius:50%;display:inline-block;box-shadow:0 0 8px #22c55e,0 0 12px #22c55e;animation:transcribingPulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes transcribingPulse{0%,to{opacity:1;box-shadow:0 0 8px #22c55e,0 0 12px #22c55e}50%{opacity:.7;box-shadow:0 0 12px #22c55e,0 0 16px #22c55e,0 0 20px #22c55e}}.video-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:20px;width:100%;margin-bottom:20px}.video-wrapper{position:relative;background:#000;border-radius:12px;overflow:hidden;aspect-ratio:16 / 9;box-shadow:0 4px 6px #0000004d}.video-stream{width:100%;height:100%;position:relative}.video-element{width:100%;height:100%;object-fit:cover}.video-placeholder{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#888;font-size:18px}.video-label{position:absolute;top:10px;left:10px;background:#000000b3;padding:6px 12px;border-radius:6px;font-size:14px;font-weight:500;z-index:5}.session-setup{width:100%;max-width:600px;background:#2a2a2a;padding:40px;border-radius:12px;display:flex;flex-direction:column;gap:24px;margin:40px auto}.session-setup-header{text-align:center;margin-bottom:20px}.session-setup-header h1{font-size:32px;color:#fff;margin-bottom:8px}.session-setup-header p{font-size:16px;color:#a0a0a0}.session-setup-content{display:flex;flex-direction:column;gap:24px}.session-options{display:flex;flex-direction:column;gap:16px;align-items:stretch}.divider{display:flex;align-items:center;text-align:center;color:#888;font-size:14px;margin:8px 0}.divider:before,.divider:after{content:"";flex:1;border-bottom:1px solid #444}.divider span{padding:0 16px}.session-form{display:flex;flex-direction:column;gap:24px}.setup-section label{font-size:14px;color:#a0a0a0;font-weight:500;margin-bottom:8px}.name-input,.session-id-input{width:100%;padding:12px;background:#1a1a1a;border:2px solid #3b82f6;border-radius:8px;color:#fff;font-size:14px;font-family:inherit}.name-input:focus,.session-id-input:focus{outline:none;border-color:#60a5fa}.name-input:disabled,.session-id-input:disabled{opacity:.5;cursor:not-allowed}.session-id-input{font-family:Courier New,monospace;text-transform:lowercase}.session-id-display{display:flex;align-items:center;gap:12px;background:#1a1a1a;padding:12px;border-radius:8px}.session-id-display code{flex:1;font-family:Courier New,monospace;font-size:14px;color:#4ade80;word-break:break-all}.info-text{font-size:14px;color:#a0a0a0;line-height:1.5;text-align:center;padding:12px;background:#1a1a1a;border-radius:8px}.form-actions{display:flex;gap:12px;justify-content:flex-end}.secondary-btn{padding:12px 24px;background:#1a1a1a;color:#fff;border:2px solid #3b82f6;border-radius:8px;cursor:pointer;font-size:16px;font-weight:500;transition:all .2s}.secondary-btn:hover:not(:disabled){background:#2a2a2a;border-color:#60a5fa}.secondary-btn:disabled{opacity:.5;cursor:not-allowed}.connection-setup{width:100%;max-width:600px;background:#2a2a2a;padding:30px;border-radius:12px;display:flex;flex-direction:column;gap:24px}.setup-section{display:flex;flex-direction:column;gap:12px}.setup-section h2{font-size:18px;color:#fff;margin-bottom:8px}.peer-id-display{display:flex;align-items:center;gap:12px;background:#1a1a1a;padding:12px;border-radius:8px}.peer-id-display code{flex:1;font-family:Courier New,monospace;font-size:14px;color:#4ade80;word-break:break-all}.copy-btn{padding:6px 12px;background:#3b82f6;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:12px;transition:background .2s}.copy-btn:hover{background:#2563eb}.peer-id-input{width:100%;padding:12px;background:#1a1a1a;border:2px solid #3b82f6;border-radius:8px;color:#fff;font-size:14px;font-family:Courier New,monospace}.peer-id-input:focus{outline:none;border-color:#60a5fa}.peer-id-input:disabled{opacity:.5;cursor:not-allowed}.primary-btn{padding:12px 24px;background:#3b82f6;color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:16px;font-weight:500;transition:background .2s}.primary-btn:hover:not(:disabled){background:#2563eb}.primary-btn:disabled{opacity:.5;cursor:not-allowed}.controls{display:flex;gap:16px;justify-content:center;padding:20px;background:#2a2a2a;border-radius:12px}.control-btn{width:60px;height:60px;border-radius:50%;border:none;background:#3b82f6;color:#fff;font-size:24px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.control-btn:hover{background:#2563eb;transform:scale(1.1)}.control-btn.disabled{background:#6b7280}.control-btn.disconnect{background:#ef4444}.control-btn.disconnect:hover{background:#dc2626}.translating-indicator{position:absolute;top:10px;right:10px;z-index:20;pointer-events:none}.translating-icon{background:#3b82f6e6;border-radius:50%;width:40px;height:40px;display:flex;align-items:center;justify-content:center;font-size:20px;animation:translatingSpin 1.5s linear infinite;box-shadow:0 2px 8px #0000004d}@keyframes translatingSpin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.subtitle-container{position:absolute;bottom:0;left:0;right:0;padding:20px;pointer-events:none;z-index:15}.subtitle-overlay{background:linear-gradient(to top,rgba(0,0,0,.9) 0%,rgba(0,0,0,.7) 50%,transparent 100%);padding:16px 20px;border-radius:8px;text-align:center;animation:fadeIn .3s ease-in;transition:opacity .5s ease-out,transform .5s ease-out}.subtitle-overlay.fading-out{opacity:0;transform:translateY(10px)}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.subtitle-original{font-size:14px;color:#a0a0a0;margin-bottom:6px;font-style:italic;line-height:1.4}.subtitle-translation{font-size:20px;font-weight:600;color:#fff;text-shadow:2px 2px 4px rgba(0,0,0,.8);line-height:1.5;word-wrap:break-word}.transcript-display{position:absolute;bottom:50px;left:10px;right:10px;background:#000c;padding:12px;border-radius:8px;max-height:120px;overflow-y:auto}.transcript-display.interim{background:#3b82f6cc}.transcript-label{font-size:11px;color:#aaa;margin-bottom:4px;text-transform:uppercase;letter-spacing:.5px}.transcript-text{font-size:14px;color:#fff;line-height:1.4}.transcript-display.interim .transcript-text{color:#e0e7ff;font-style:italic}.transcript-toggle-button{padding:10px 20px;background:#2a2a2a;color:#fff;border:2px solid #3b82f6;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s;margin-top:10px}.transcript-toggle-button:hover{background:#3b82f6;border-color:#60a5fa}.transcript-panel{position:fixed;bottom:20px;right:20px;width:400px;max-width:calc(100vw - 40px);max-height:500px;background:#2a2a2a;border:2px solid #3b82f6;border-radius:12px;display:flex;flex-direction:column;box-shadow:0 4px 20px #00000080;z-index:1000}.transcript-panel-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid #3b82f6;background:#1a1a1a;border-radius:10px 10px 0 0}.transcript-panel-header h3{margin:0;color:#fff;font-size:18px}.transcript-toggle-btn{background:transparent;border:none;color:#fff;font-size:20px;cursor:pointer;padding:4px 8px;border-radius:4px;transition:background .2s}.transcript-toggle-btn:hover{background:#3b82f6}.transcript-panel-content{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:12px}.transcript-panel-content::-webkit-scrollbar{width:8px}.transcript-panel-content::-webkit-scrollbar-track{background:#1a1a1a;border-radius:4px}.transcript-panel-content::-webkit-scrollbar-thumb{background:#3b82f6;border-radius:4px}.transcript-panel-content::-webkit-scrollbar-thumb:hover{background:#60a5fa}.transcript-empty{text-align:center;color:#888;padding:40px 20px;font-style:italic}.transcript-item{background:#1a1a1a;border-radius:8px;padding:12px;border-left:3px solid #3b82f6}.transcript-item.local{border-left-color:#4ade80}.transcript-item.remote{border-left-color:#f59e0b}.transcript-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.transcript-speaker{font-weight:600;color:#fff;font-size:14px}.transcript-time{font-size:12px;color:#888}.transcript-original{font-size:13px;color:#a0a0a0;margin-bottom:6px;font-style:italic;line-height:1.4}.transcript-translated{font-size:15px;color:#fff;line-height:1.5;font-weight:500}@media(max-width:768px){.video-grid{grid-template-columns:1fr}.connection-setup{padding:20px}.controls{flex-wrap:wrap}.transcript-display{font-size:12px;padding:8px;max-height:80px}.header-with-menu{flex-direction:column;align-items:flex-start}.language-menu-dropdown{right:auto;left:0}.transcript-panel{width:calc(100vw - 40px);max-height:400px;bottom:10px;right:10px}}
