body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#1a1a1a;color:#fff;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}*{box-sizing:border-box}.channel-selection{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;flex-direction:column;min-height:100vh;padding:2rem}.channel-header{color:#fff;margin-bottom:3rem;text-align:center}.channel-header h1{font-size:2.5rem;margin-bottom:.5rem;text-shadow:2px 2px 4px #0003}.channel-header p{font-size:.9rem;margin-bottom:.5rem;opacity:.9}.channels-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin:0 auto;max-width:1200px;width:100%}.channel-card{align-items:center;background:#fff;border-radius:16px;box-shadow:0 4px 6px #0000001a;cursor:pointer;display:flex;gap:1rem;transition:transform .2s,box-shadow .2s}.channel-card:hover{box-shadow:0 8px 20px #00000026;transform:translateY(-5px)}.channel-icon{align-items:center;border-radius:50%;color:#fff;display:flex;font-size:2rem;justify-content:center}.channel-info{flex:1 1}.channel-info h3{color:#333;font-size:1rem;margin:0 0 .3rem}.channel-status{align-items:center;color:#4caf50;display:flex;font-size:.65rem;gap:.5rem;margin:0}.live-dot{animation:pulse 1.5s infinite;background-color:#4caf50;border-radius:50%;display:inline-block;height:8px;width:8px}@media (max-width:768px){.channel-selection{padding:1rem}.channel-header h1{font-size:1rem;margin:0}.channels-grid{gap:.5rem;grid-template-columns:repeat(auto-fit,minmax(80px,2fr));max-width:250px}.channel-card{padding:.5rem}.channel-icon{font-size:1.5rem;height:40px;width:40px}}.message-list{display:flex;flex-direction:column}.no-messages{color:#888;font-size:.85rem;padding:30px 20px;text-align:center}.message-bubble{animation:fadeInUp .2s ease;border-left:3px solid #4f9eff;max-width:90%;padding:2px 8px;width:fit-content}.message-bubble.own{border-left-color:#ffd966}@keyframes fadeInUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.message-header{align-items:baseline;display:flex;flex-wrap:wrap;font-size:.7rem;gap:10px;margin-bottom:4px}.message-username{color:#acf;font-size:.55rem;font-weight:700}.message-bubble.own .message-username{color:#ffe5a3}.message-timestamp{color:#aaa;font-size:.65rem}.message-content{color:#f0f0f0;font-size:.55rem;word-break:break-word}.message-input-form{background:#0000}.message-input-form.compact .input-container{gap:8px}.input-container{align-items:flex-end;display:flex;gap:10px}.message-textarea{background:#0009;border:1px solid #ffffff40;border-radius:28px;color:#fff;flex:1 1;font-family:inherit;font-size:.75rem;max-height:80px;outline:none;padding:6px 16px;resize:none;transition:.2s}.message-textarea:focus{background:#000c;border-color:#4f9eff;outline:none}.message-textarea:disabled{cursor:not-allowed;opacity:.6}.send-button{background:#4f9eff;border:none;border-radius:40px;color:#fff;cursor:pointer;font-size:.9rem;font-weight:600;height:fit-content;padding:7px 20px;transition:.2s}.send-button:hover:not(:disabled){background:#2f7edf;transform:scale(.97)}.send-button:disabled{background:#555;cursor:not-allowed;opacity:.5}.video-publisher-background,.video-subscriber-background{align-items:center;background:#000;display:flex;height:100%;justify-content:center;overflow:hidden;position:relative;width:100%}.camera-preview-background,.video-stream-background{display:block;height:100%;object-fit:contain;width:100%}.live-badge-background{animation:pulse 2s infinite;background:#ff4757;border-radius:16px;color:#fff;font-size:.65rem;font-weight:700;left:10px;padding:3px 8px;position:absolute;top:10px;z-index:10}.live-badge-background.watching{animation:none;background:#4f9eff}.camera-placeholder-background,.video-placeholder-background{align-items:center;background:linear-gradient(135deg,#0a0a0a,#1a1a2e);bottom:0;display:flex;justify-content:center;left:0;position:absolute;right:0;top:0}.placeholder-content-background{color:#666;text-align:center}.placeholder-content-background .placeholder-icon{font-size:36px;margin-bottom:8px;opacity:.6}.placeholder-content-background p{font-size:.75rem;margin:4px 0}.placeholder-content-background .sub-wait-text{color:#555;font-size:.65rem;margin-top:6px}.error-overlay-background{background:#000c;bottom:0;color:#ff6b6b;font-size:.65rem;left:0;padding:6px;position:absolute;right:0;text-align:center}.audio-level-indicator-background{background:#00000080;border-radius:2px;bottom:15px;height:3px;left:15px;overflow:hidden;position:absolute;right:60px;z-index:10}.audio-level-bar{height:100%;transition:width .05s linear}.volume-controls-background{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#00000080;border-radius:30px;bottom:10px;display:flex;gap:6px;padding:5px 10px;position:absolute;right:10px;z-index:10}.volume-btn{background:#fff3;border:none;border-radius:50%;color:#fff;cursor:pointer;font-size:12px;height:28px;transition:.2s;width:28px}.volume-btn:hover{background:#fff6;transform:scale(1.05)}.volume-indicator{background:#00000080;border-radius:15px;color:#fff;font-size:10px;font-weight:600;min-width:35px;padding:3px 6px;text-align:center}.audio-toggle-background{align-items:center;background:#0009;border:none;border-radius:50%;bottom:15px;color:#fff;cursor:pointer;display:flex;font-size:18px;height:40px;justify-content:center;position:absolute;right:15px;transition:.2s;width:40px;z-index:10}.audio-toggle-background:hover{background:#000c;transform:scale(1.05)}.connecting-overlay{align-items:center;background:#000000b3;bottom:0;color:#fff;display:flex;flex-direction:column;gap:10px;justify-content:center;left:0;position:absolute;right:0;top:0}.connecting-spinner{animation:spin 1s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#4f9eff;height:28px;width:28px}@keyframes spin{to{transform:rotate(1turn)}}.video-publisher,.video-subscriber{background:#000;height:100%;overflow:hidden;position:relative;width:100%}.camera-preview,.video-stream{display:block;height:100%;object-fit:cover;width:100%}.live-badge{animation:pulse 2s infinite;background:#ff4757;border-radius:30px;color:#fff;font-size:.7rem;font-weight:700;left:12px;padding:4px 10px;position:absolute;top:12px;z-index:10}.live-badge.watching{animation:none;background:#4f9eff}.video-controls-panel{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#000000b3;border-radius:60px;bottom:20px;display:flex;gap:12px;left:50%;padding:8px 16px;position:absolute;transform:translateX(-50%);z-index:20}.cam-toggle-btn,.start-stream-btn,.stop-stream-btn{border:none;border-radius:40px;cursor:pointer;font-size:.8rem;font-weight:600;padding:8px 16px;transition:.2s}.cam-toggle-btn{background:#4f9eff;color:#fff}.start-stream-btn{background:#2ed573}.stop-stream-btn{background:#ff4757}.cam-toggle-btn:disabled,.start-stream-btn:disabled{cursor:not-allowed;opacity:.5}.camera-error-overlay{align-items:center;background:#000000e6;bottom:0;display:flex;justify-content:center;left:0;position:absolute;right:0;top:0;z-index:20}.error-content{color:#fff;padding:20px;text-align:center}.error-content p{font-size:.9rem;margin-bottom:16px}.error-content button{background:#4f9eff;border:none;border-radius:40px;color:#fff;cursor:pointer;font-weight:600;padding:10px 24px}.video-subscriber-placeholder{align-items:center;background:#0a0a0a;display:flex;height:100%;justify-content:center;width:100%}.placeholder-content{color:#888;text-align:center}.placeholder-icon{font-size:48px;margin-bottom:16px;opacity:.5}.placeholder-content h3{color:#ccc;font-size:1.2rem;margin-bottom:8px}.placeholder-content p{font-size:.85rem}.modal-overlay{align-items:center;animation:fadeIn .2s ease;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0009;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:2000}.username-modal{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#14141ed9;border-radius:32px;box-shadow:0 20px 40px #00000080,0 0 0 1px #ffffff1a;max-width:400px;padding:40px 32px;text-align:center;width:90%}.modal-icon{font-size:48px;margin-bottom:16px}.username-modal h2{color:#fff;font-size:1.8rem;font-weight:600;margin-bottom:12px}.username-modal p{color:#aaa;font-size:.95rem;margin-bottom:28px}.username-modal input{background:#1e1e2a;border:1px solid #3a3a44;border-radius:60px;color:#fff;font-size:1rem;margin-bottom:24px;outline:none;padding:14px 18px;transition:all .2s;width:100%}.username-modal input:focus{border-color:#4f9eff;box-shadow:0 0 0 2px #4f9eff4d}.username-modal button{background:#4f9eff;border:none;border-radius:60px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:14px 28px;transition:.2s;width:100%}.username-modal button:hover{background:#2f7edf;transform:scale(.98)}@keyframes fadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.chat-room{align-items:center;background:#0a0a0a;display:flex;height:100%;justify-content:center;overflow:hidden;position:relative;width:100%}.chat-overlay{margin:0 auto;max-width:100%;pointer-events:none;z-index:20}.chat-card,.chat-overlay{display:flex;flex-direction:column;position:relative;width:100%}.chat-card{border-radius:0;box-shadow:none;height:100vh;max-height:100%;overflow:hidden;pointer-events:auto}.video-background-container{align-items:center;background:#000;bottom:0;display:flex;justify-content:center;left:0;position:absolute;right:0;top:0;z-index:1}.video-background-container>*{display:block;height:100%;object-fit:contain;width:100%}.chat-content-overlay{background:linear-gradient(180deg,#0000004d 0,#0009);display:flex;flex-direction:column;height:100%;position:relative;z-index:2}.chat-header-bar{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#00000080;border-bottom:1px solid #ffffff1a;justify-content:space-between;padding:12px 16px}.chat-header-bar,.user-info{align-items:center;display:flex;flex-wrap:wrap;gap:8px}.action-buttons{display:flex;gap:8px}.username-badge{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#4f9eff33;border:1px solid #fff3;border-radius:40px;color:#fff;font-size:.75rem;font-weight:500;padding:4px 12px}.channel-name-badge{background:#0009;border-radius:20px;color:#4ecdc4;font-size:.65rem;padding:4px 10px;text-transform:uppercase}.channel-name-badge,.leave-channel-btn{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);font-weight:600}.leave-channel-btn{background:#ff4757cc;border:none;border-radius:40px;color:#fff;cursor:pointer;font-size:.75rem;padding:6px 14px;transition:.2s}.leave-channel-btn:hover{background:#ff4757;transform:scale(.96)}.message-list-container{flex:1 1;overflow-y:auto;padding:12px;scroll-behavior:smooth}.message-list-container::-webkit-scrollbar{width:4px}.message-list-container::-webkit-scrollbar-track{background:#0000}.message-list-container::-webkit-scrollbar-thumb{background:#ffffff4d;border-radius:4px}.input-area{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#00000080;border-top:1px solid #ffffff1a;padding:8px 12px}.floating-error{animation:slideIn .3s ease;background:#ff4757;border-radius:40px;bottom:20px;box-shadow:0 4px 12px #0000004d;color:#fff;font-size:.75rem;padding:10px 16px;position:fixed;right:20px;z-index:100}@keyframes slideIn{0%{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}@media (orientation:landscape){.chat-header-bar{padding:8px 12px}.username-badge{font-size:.7rem;padding:3px 10px}.channel-name-badge{font-size:.6rem;padding:3px 8px}.leave-channel-btn{font-size:.7rem;padding:5px 12px}.message-list-container{padding:8px}.input-area{padding:6px 12px}}@media (max-height:500px){.chat-header-bar{padding:4px 8px}.username-badge{font-size:.65rem;padding:2px 8px}.channel-name-badge{font-size:.55rem;padding:2px 6px}.leave-channel-btn{font-size:.65rem;padding:3px 10px}.message-list-container{padding:4px}.input-area{padding:4px 8px}}.channel-selector-wrap,.publisher-notice-mini,.role-badge,.stream-action-btn{display:none}

/*!* Chat Room Styles *!*/

/*!* Channel Selector Styles *!*/

/*!* Message List Styles *!*/

/*!* Message Input Styles *!*/

/*!* Error Message *!*/

/*!* Scrollbar Styling *!*/.publisher-modal{max-width:400px;width:90%}.modal-header{margin-bottom:2rem;text-align:center}.modal-icon{font-size:3rem;margin-bottom:1rem}.modal-header h2{color:#333;margin:0 0 .5rem}.modal-header p{color:#666;font-size:.85rem;margin:0}.form-group{margin-bottom:1.5rem}.form-group label{color:#555;display:block;font-size:.85rem;font-weight:500;margin-bottom:.5rem}.form-group input{border:1px solid #ddd;border-radius:8px;font-size:1rem;padding:.75rem;transition:border-color .2s;width:100%}.form-group input:focus{border-color:#4a90e2;box-shadow:0 0 0 2px #4a90e21a;outline:none}.modal-close{background:none;border:none;color:#999;cursor:pointer;font-size:1.2rem;position:absolute;right:1rem;top:1rem;transition:color .2s}.modal-close:hover{color:#333}.error-message{background:#fee;border-radius:8px;color:#c33;font-size:.85rem;margin-bottom:1rem;padding:.75rem}button[type=submit]:hover:not(:disabled){transform:translateY(-2px)}button[type=submit]:disabled{cursor:not-allowed;opacity:.7}.publisher-page{background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh;padding:2rem}.publisher-container{margin:0 auto;max-width:1200px}.publisher-header{align-items:center;background:#fffffff2;border-radius:16px;box-shadow:0 4px 6px #0000001a;display:flex;justify-content:space-between;margin-bottom:.5rem;padding:.2rem 1rem}.header-left,.header-right{align-items:center;display:flex;gap:1rem}.back-button,.logout-button{border:none;border-radius:8px;cursor:pointer;font-size:.9rem;font-weight:600;padding:.5rem 1rem;transition:.2s}.back-button{background:#667eea;color:#fff}.back-button:hover{background:#5a67d8;transform:translateY(-2px)}.logout-button{background:#ff4757;color:#fff}.logout-button:hover{background:#ff3747;transform:translateY(-2px)}.publisher-name{background:#f0f0f0;border-radius:8px;color:#333;font-size:1rem;font-weight:600;padding:.5rem 1rem}.channel-selector{background:#fffffff2;border-radius:16px;margin-bottom:.5rem;padding:.5rem}.channel-selector label{color:#333;display:block;font-size:1rem;font-weight:600}.channels-list{display:flex;flex-wrap:wrap;gap:.75rem}.channel-button{align-items:center;background:#f0f0f0;border:2px solid #0000;border-radius:40px;cursor:pointer;display:flex;font-size:.9rem;gap:.5rem;transition:.2s}.channel-button:hover{background:#e0e0e0;transform:translateY(-2px)}.channel-button.active{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#fff;color:#fff}.channel-icon{font-size:1.2rem}.channel-name{font-weight:500}.video-publisher-wrapper{aspect-ratio:16/9;background:#000;border-radius:16px;overflow:hidden;position:relative}.publisher-instructions{background:#fffffff2;border-radius:16px;padding:1.5rem}.publisher-instructions h3{color:#333;margin:0 0 1rem}.publisher-instructions ul{margin:0;padding-left:1.5rem}.publisher-instructions li{color:#555;font-size:.75rem;margin:.2rem 0}.stream-controls{display:flex;gap:1rem;justify-content:center;margin-bottom:.5rem}.start-stream-btn,.stop-stream-btn{border:none;border-radius:60px;cursor:pointer;font-size:.75rem;font-weight:600;min-width:200px;transition:transform .2s,opacity .2s}.start-stream-btn{background:linear-gradient(135deg,#2ed573,#1ba94c);box-shadow:0 4px 15px #2ed5734d;color:#fff}.start-stream-btn:hover{box-shadow:0 6px 20px #2ed57366;transform:translateY(-2px)}.stop-stream-btn{animation:pulse 1.5s infinite;background:linear-gradient(135deg,#ff4757,#c0392b);box-shadow:0 4px 15px #ff47574d;color:#fff}.stop-stream-btn:hover{box-shadow:0 6px 20px #ff475766;transform:translateY(-2px)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.8}}.live-badge-publisher{animation:pulse 1.5s infinite;background:#ff4757;border-radius:20px;color:#fff;font-size:.8rem;font-weight:700;margin-left:.5rem;padding:.25rem .75rem}.channel-button:disabled{cursor:not-allowed;opacity:.5}.publisher-info{align-items:center;display:flex;gap:.5rem}.publisher-main-content{grid-gap:.5rem;display:grid;gap:.5rem;grid-template-columns:1fr 320px;margin-bottom:.5rem}.video-section{background:#1a1a1a}.chat-section,.video-section{border-radius:16px;overflow:hidden}.chat-section{background:#fffffff2;display:flex;flex-direction:column;height:620px}.chat-header{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;justify-content:space-between;padding:1rem}.chat-header h3{font-size:1rem;margin:0}.channel-badge{background:#fff3;border-radius:20px;font-size:.7rem;font-weight:600;padding:.25rem .75rem}.chat-messages-container{background:#1a1a1a;flex:1 1;overflow-y:auto;padding:1rem}.chat-input-container{background:#fff;border-top:1px solid #e0e0e0;padding:1rem}.viewer-count{background:#0009;border-radius:20px;font-size:.8rem;margin-left:.5rem;padding:.25rem .75rem}@media (max-width:1024px){.publisher-main-content{grid-template-columns:1fr}.chat-section{height:400px}}@media (max-width:768px){.chat-section{height:350px}.chat-header h3{font-size:.9rem}}.chat-messages-container::-webkit-scrollbar{width:6px}.chat-messages-container::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.chat-messages-container::-webkit-scrollbar-thumb{background:#888;border-radius:3px}.chat-messages-container::-webkit-scrollbar-thumb:hover{background:#555}@media (max-width:768px){.publisher-page{padding:1rem}.publisher-header{flex-direction:column;gap:1rem}.header-left,.header-right{justify-content:space-between;width:100%}.channels-list{max-height:200px;overflow-y:auto}.channel-button{flex:1 1;justify-content:center;min-width:calc(50% - .75rem)}}
/*# sourceMappingURL=main.b56fa44e.css.map*/