@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";*{margin:0;padding:0;box-sizing:border-box}:root{--primary: #6366f1;--primary-dark: #4f46e5;--bg-dark: #000000;--bg-dark-secondary: #0a0a0a;--text-primary: #ffffff;--text-secondary: #9ca3af;--border-color: rgba(255, 255, 255, .1)}html{scroll-behavior:smooth}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--bg-dark);color:var(--text-primary);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.container{max-width:1200px;margin:0 auto;padding:0 20px}button{font-family:inherit;cursor:pointer;border:none;outline:none;transition:all .2s ease}a{color:inherit;text-decoration:none;transition:color .2s ease}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:1.2}.btn{padding:12px 32px;border-radius:50px;font-size:14px;font-weight:500;transition:all .2s ease}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-dark);transform:translateY(-1px)}.btn-secondary{background:#ffffff0d;color:#fff;border:1px solid var(--border-color)}.btn-secondary:hover{background:#ffffff1a}.gradient-text{background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:80px 20px 40px;position:relative;background:linear-gradient(180deg,rgba(99,102,241,.05) 0%,transparent 50%)}.hero-content{max-width:900px;margin:0 auto;text-align:center}.hero-badge{display:inline-block;padding:6px 16px;background:#6366f11a;border:1px solid rgba(99,102,241,.2);border-radius:50px;font-size:12px;color:#a5b4fc;margin-bottom:24px}.hero-title{font-size:clamp(36px,5vw,64px);font-weight:700;margin-bottom:24px;letter-spacing:-.02em}.hero-gradient{background:linear-gradient(135deg,#818cf8,#06b6d4);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-description{font-size:20px;color:var(--text-secondary);max-width:600px;margin:0 auto 40px;line-height:1.6}.hero-buttons{display:flex;gap:16px;justify-content:center;margin-bottom:80px;flex-wrap:wrap}.hero-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;max-width:400px;margin:0 auto}.hero-stat{text-align:center}.hero-stat-value{font-size:28px;font-weight:700;color:#fff;margin-bottom:4px}.hero-stat-label{font-size:13px;color:var(--text-secondary)}@media (max-width: 640px){.hero-buttons{flex-direction:column;align-items:center}.hero-buttons button{width:100%;max-width:280px}}.footer{padding:48px 20px 32px;border-top:1px solid rgba(255,255,255,.08);background:var(--bg-dark)}.footer-container{max-width:1200px;margin:0 auto}.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:64px;margin-bottom:48px}.footer-brand{display:flex;align-items:center;gap:8px;margin-bottom:16px}.footer-logo{width:32px;height:32px;color:var(--primary)}.footer-title{font-size:18px;font-weight:600;background:linear-gradient(135deg,#6366f1,#8b5cf6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.footer-description{color:var(--text-secondary);font-size:14px;line-height:1.6;margin-bottom:24px;max-width:400px}.footer-social{display:flex;gap:16px}.footer-social-link{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#ffffff0d;border-radius:8px;color:var(--text-secondary);transition:all .2s}.footer-social-link:hover{background:#6366f133;color:var(--primary)}.footer-column h3{font-size:14px;font-weight:600;margin-bottom:16px;color:#fff}.footer-links{display:flex;flex-direction:column;gap:12px}.footer-link{color:var(--text-secondary);font-size:14px;transition:color .2s}.footer-link:hover{color:var(--primary)}.footer-bottom{padding-top:32px;border-top:1px solid rgba(255,255,255,.08);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:24px}.footer-copyright{color:var(--text-secondary);font-size:13px}.footer-legal{display:flex;gap:24px;flex-wrap:wrap}.footer-legal-link{color:var(--text-secondary);font-size:13px;transition:color .2s}.footer-legal-link:hover{color:var(--primary)}@media (max-width: 768px){.footer-grid{grid-template-columns:1fr;gap:32px}.footer-bottom{flex-direction:column;align-items:flex-start}}.modal-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#000000d9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:9999;display:flex;align-items:center;justify-content:center;overflow:auto;padding:20px}.login-modal{background:linear-gradient(135deg,#1a1a1a,#0f0f0f);border:1px solid rgba(99,102,241,.2);border-radius:20px;padding:40px;width:100%;max-width:440px;max-height:90vh;overflow-y:auto;position:relative;box-shadow:0 20px 60px #00000080,0 0 100px #6366f11a;margin:auto;scrollbar-width:thin;scrollbar-color:rgba(99,102,241,.3) transparent}.login-modal::-webkit-scrollbar{width:6px}.login-modal::-webkit-scrollbar-track{background:transparent}.login-modal::-webkit-scrollbar-thumb{background:#6366f14d;border-radius:3px}.login-modal::-webkit-scrollbar-thumb:hover{background:#6366f180}.modal-close{position:absolute;top:20px;right:20px;width:32px;height:32px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:#ffffff80;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;z-index:10}.modal-close:hover{background:#ffffff1a;color:#ffffffe6;transform:rotate(90deg)}.login-modal-brand{display:flex;flex-direction:column;align-items:center;margin-bottom:32px}.login-modal-logo{width:56px;height:56px;margin-bottom:16px;color:var(--primary);filter:drop-shadow(0 0 20px rgba(99,102,241,.3))}.login-modal-brand-name{font-size:24px;font-weight:700;background:linear-gradient(135deg,#6366f1,#8b5cf6);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent;margin-bottom:8px}.login-modal-header{text-align:center;margin-bottom:28px}.login-modal-title{font-size:22px;font-weight:600;margin-bottom:6px;color:#fff}.login-modal-subtitle{color:#fff9;font-size:14px;line-height:1.5}.login-tabs{display:flex;gap:8px;margin-bottom:24px;background:#ffffff08;padding:4px;border-radius:10px}.login-tab{flex:1;padding:10px;background:transparent;border:none;color:#ffffff80;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.login-tab:hover{color:#ffffffb3}.login-tab.active{background:#6366f126;color:#fff;box-shadow:0 2px 8px #6366f133}.login-form{display:flex;flex-direction:column;gap:18px}.form-group{display:flex;flex-direction:column;gap:8px}.form-label{font-size:13px;font-weight:500;color:#fffc;letter-spacing:.3px}.form-input{padding:12px 16px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:10px;color:#fff;font-size:14px;transition:all .2s ease;outline:none}.form-input:focus{border-color:#6366f180;background:#ffffff14;box-shadow:0 0 0 3px #6366f11a}.form-input::-moz-placeholder{color:#ffffff4d}.form-input::placeholder{color:#ffffff4d}.form-checkbox-group{display:flex;align-items:center;gap:8px}.form-checkbox{width:18px;height:18px;accent-color:var(--primary);cursor:pointer}.form-checkbox-label{font-size:13px;color:#ffffffb3;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.form-footer{display:flex;justify-content:space-between;align-items:center;margin-top:4px}.form-link{font-size:13px;color:var(--primary);cursor:pointer;transition:opacity .2s ease;text-decoration:none}.form-link:hover{opacity:.8;text-decoration:underline}.login-submit{width:100%;padding:14px;background:linear-gradient(135deg,#6366f1,#8b5cf6);border:none;color:#fff;border-radius:10px;font-size:15px;font-weight:600;margin-top:8px;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 12px #6366f14d}.login-submit:hover{transform:translateY(-1px);box-shadow:0 6px 20px #6366f166}.login-submit:active{transform:translateY(0)}.divider{display:flex;align-items:center;gap:16px;margin:24px 0}.divider-line{flex:1;height:1px;background:#ffffff1a}.divider-text{font-size:12px;color:#fff6;text-transform:uppercase;letter-spacing:1px}.social-login{display:flex;gap:12px}.social-button{flex:1;padding:11px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:10px;display:flex;align-items:center;justify-content:center;gap:8px;font-size:14px;color:#fffc;cursor:pointer;transition:all .2s ease}.social-button:hover{background:#ffffff14;border-color:#fff3;color:#fff}@media (max-width: 480px){.modal-overlay{padding:10px}.login-modal{padding:30px 20px}.modal-close{top:15px;right:15px}.login-modal-logo{width:48px;height:48px}.login-modal-brand-name,.login-modal-title{font-size:20px}.social-login{flex-direction:column}}.navbar{position:fixed;top:0;left:0;right:0;z-index:1000;background:#000c;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--border-color)}.navbar-container{max-width:1200px;margin:0 auto;padding:0 20px}.navbar-content{display:flex;align-items:center;justify-content:space-between;height:56px}.navbar-brand{display:flex;align-items:center;gap:8px}.navbar-logo{width:28px;height:28px;color:var(--primary)}.navbar-title{font-size:16px;font-weight:500;color:#fff}.navbar-menu{display:flex;align-items:center;gap:12px}.navbar-input{padding:6px 12px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:6px;color:#fff;font-size:13px;width:140px;transition:all .2s}.navbar-input:focus{outline:none;border-color:var(--primary);background:#ffffff14}.navbar-input::-moz-placeholder{color:#fff6}.navbar-input::placeholder{color:#fff6}.room-type-toggle{display:flex;background:#ffffff0d;border-radius:6px;padding:2px}.toggle-option{padding:4px 12px;font-size:13px;color:#fff9;background:transparent;border-radius:4px;transition:all .2s;cursor:pointer}.toggle-option.active{background:#6366f133;color:#fff}.toggle-option:hover:not(.active){color:#fffc}.navbar-create-btn{padding:6px 16px;background:#ffffff1a;color:#fff;border:1px solid rgba(255,255,255,.2);border-radius:6px;font-size:13px;font-weight:500;transition:all .2s;cursor:pointer}.navbar-create-btn:hover{background:#ffffff26;border-color:#ffffff4d}.navbar-cta{padding:6px 20px;background:var(--primary);color:#fff;border-radius:50px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s}.navbar-cta:hover{background:var(--primary-dark)}.navbar-admin-btn{padding:6px 20px;background:#8b5cf61a;border:1px solid rgba(139,92,246,.3);color:#8b5cf6;border-radius:50px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s;margin-right:8px}.navbar-admin-btn:hover{background:#8b5cf633;transform:translateY(-1px)}.navbar-logout{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#ef4444}.navbar-logout:hover{background:#ef444433}.navbar-mobile-toggle{display:none;padding:8px;background:transparent;color:var(--text-secondary);cursor:pointer}.navbar-mobile-menu{display:none;position:absolute;top:100%;left:0;right:0;background:#000000f2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-top:1px solid var(--border-color);padding:16px 20px}.navbar-mobile-menu.open{display:block}.navbar-input-mobile{width:100%;padding:10px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:6px;color:#fff;font-size:14px;margin-bottom:12px}.room-type-toggle-mobile{display:flex;background:#ffffff0d;border-radius:6px;padding:2px;margin-bottom:12px}.navbar-mobile-create{display:block;width:100%;padding:10px;background:#ffffff1a;color:#fff;border:1px solid rgba(255,255,255,.2);border-radius:6px;font-size:14px;font-weight:500;margin-bottom:8px;cursor:pointer}.navbar-mobile-cta{display:block;width:100%;padding:10px;background:var(--primary);color:#fff;border-radius:50px;text-align:center;font-size:14px;font-weight:500;cursor:pointer}@media (max-width: 768px){.navbar-menu{display:none}.navbar-mobile-toggle{display:block}}.navbar-mobile-cta{width:100%;padding:12px;background:var(--primary);color:#fff;border-radius:50px;text-align:center;font-size:14px;font-weight:500;cursor:pointer}.navbar-mobile-admin{width:100%;padding:12px;background:#8b5cf61a;border:1px solid rgba(139,92,246,.3);color:#8b5cf6;border-radius:50px;text-align:center;font-size:14px;font-weight:500;cursor:pointer;margin-bottom:8px}.navbar-mobile-logout{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#ef4444}.create-room{min-height:100vh;background:var(--bg-dark);display:flex;align-items:center;justify-content:center;padding:20px}.create-room-container{max-width:500px;width:100%;background:#0a0a0a;border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:48px}.create-room-back{display:inline-flex;align-items:center;gap:8px;color:var(--text-secondary);font-size:14px;margin-bottom:32px;cursor:pointer;transition:color .2s}.create-room-back:hover{color:#fff}.create-room-header{text-align:center;margin-bottom:40px}.create-room-title{font-size:36px;font-weight:700;margin-bottom:12px;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.create-room-subtitle{font-size:16px;color:var(--text-secondary)}.create-room-form{display:flex;flex-direction:column;gap:32px}.form-field{display:flex;flex-direction:column;gap:12px}.form-field-label{font-size:14px;font-weight:500;color:#fff}.room-name-input{padding:16px;background:#ffffff0d;border:2px solid rgba(255,255,255,.1);border-radius:12px;color:#fff;font-size:16px;transition:all .2s}.room-type-options{display:grid;grid-template-columns:1fr 1fr;gap:16px}.room-type-option{position:relative;cursor:pointer}.room-type-radio{position:absolute;opacity:0}.room-type-label{display:block;padding:20px;background:#ffffff05;border:2px solid rgba(255,255,255,.1);border-radius:12px;text-align:center;transition:all .2s}.room-type-radio:checked+.room-type-label{background:#6366f11a;border-color:var(--primary)}.room-type-label:hover{background:#ffffff0d;border-color:#fff3}.room-type-icon{font-size:32px;margin-bottom:8px}.room-type-name{font-size:16px;font-weight:600;color:#fff;margin-bottom:4px}.room-type-desc{font-size:12px;color:var(--text-secondary);line-height:1.4}.create-room-submit{padding:18px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:12px;font-size:18px;font-weight:600;cursor:pointer;transition:all .2s;margin-top:16px}.create-room-submit:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 30px #6366f14d}.create-room-submit:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 640px){.create-room-container{padding:32px 24px}.room-type-options{grid-template-columns:1fr}}.modal-overlay{position:fixed;inset:0;background:#000c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:2000;padding:20px}.existing-room-dialog{background:#0a0a0a;border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:32px;max-width:480px;width:100%;text-align:center}.existing-room-dialog h2{font-size:24px;font-weight:600;margin-bottom:16px;color:#fff}.existing-room-dialog p{font-size:16px;color:var(--text-secondary);margin-bottom:32px}.dialog-buttons{display:flex;gap:16px;justify-content:center}.dialog-buttons button{padding:12px 32px}.contact{min-height:100vh;background:var(--bg-dark);padding-top:80px;padding-bottom:40px}.contact-container{max-width:600px;margin:0 auto;padding:0 20px}.contact-header{text-align:center;margin-bottom:48px}.contact-title{font-size:48px;font-weight:700;margin-bottom:16px;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.contact-subtitle{font-size:18px;color:var(--text-secondary);margin-bottom:8px}.contact-email{font-size:16px;color:var(--primary);text-decoration:none;transition:opacity .2s}.contact-email:hover{opacity:.8}.contact-form{background:#ffffff05;border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:32px}.contact-form-group{margin-bottom:24px}.contact-form-label{display:block;font-size:14px;font-weight:500;color:#fff;margin-bottom:8px}.contact-form-input,.contact-form-textarea{width:100%;padding:12px 16px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:#fff;font-size:14px;font-family:inherit;transition:all .2s}.contact-form-input:focus,.contact-form-textarea:focus{outline:none;border-color:var(--primary);background:#ffffff14}.contact-form-input::-moz-placeholder,.contact-form-textarea::-moz-placeholder{color:#ffffff4d}.contact-form-input::placeholder,.contact-form-textarea::placeholder{color:#ffffff4d}.contact-form-textarea{min-height:120px;resize:vertical}.contact-form-submit{width:100%;padding:14px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s}.contact-form-submit:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 30px #6366f14d}.contact-form-submit:disabled{opacity:.5;cursor:not-allowed}.contact-success{background:#10b9811a;border:1px solid rgba(16,185,129,.3);color:#10b981;padding:16px;border-radius:8px;text-align:center;margin-top:24px}.contact-error{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#ef4444;padding:16px;border-radius:8px;text-align:center;margin-top:24px}.contact-back{display:inline-flex;align-items:center;gap:8px;color:var(--text-secondary);font-size:14px;margin-bottom:32px;cursor:pointer;transition:color .2s;text-decoration:none;background:transparent}.contact-back:hover{color:#fff;background:transparent}.room-lobby{min-height:100vh;background:var(--bg-dark);display:flex;align-items:center;justify-content:center;padding:20px}.room-lobby-container{max-width:800px;width:100%;background:#ffffff05;border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:32px}.room-lobby-header{text-align:center;margin-bottom:32px}.room-lobby-title{font-size:32px;font-weight:700;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:12px}.room-moderated-badge{display:inline-block;padding:4px 12px;background:#667eea1a;border:1px solid rgba(102,126,234,.3);border-radius:20px;font-size:12px;color:#667eea;font-weight:600}.room-lobby-content{display:flex;flex-direction:column;gap:24px}.room-video-preview{position:relative;width:100%;aspect-ratio:16/9;background:#000;border-radius:12px;overflow:hidden;display:flex;align-items:center;justify-content:center}.room-preview-video{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;transform:scaleX(-1)}.room-preview-video.video-disabled{display:none}.room-permissions-message{text-align:center;color:#ffffffb3}.permission-icon{color:#ffffff4d;margin-bottom:16px}.room-permissions-message p{margin-bottom:16px;font-size:14px}.room-retry-permissions{padding:8px 20px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.room-retry-permissions:hover{transform:translateY(-2px);box-shadow:0 10px 30px #6366f14d}.room-video-off-overlay{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#000c;color:#ffffffb3}.room-video-off-overlay svg{color:#ffffff4d;margin-bottom:12px}.room-video-off-overlay p{font-size:14px}.room-lobby-controls{display:flex;flex-direction:column;gap:20px}.room-media-controls{display:flex;gap:12px;justify-content:center}.room-media-button{width:56px;height:56px;border-radius:50%;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.room-media-button:hover:not(:disabled){background:#ffffff26;transform:scale(1.05)}.room-media-button:disabled{opacity:.5;cursor:not-allowed}.room-media-button.media-disabled{background:#ef444433;border-color:#ef44444d;color:#ef4444}.room-name-input-group{width:100%}.room-name-input{width:100%;padding:12px 16px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:#fff;font-size:16px;transition:all .2s}.room-name-input:focus{outline:none;border-color:var(--primary);background:#ffffff14}.room-name-input::-moz-placeholder{color:#ffffff4d}.room-name-input::placeholder{color:#ffffff4d}.room-error-message{padding:12px;background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#ef4444;border-radius:8px;text-align:center;font-size:14px}.room-lobby-actions{display:flex;gap:12px;justify-content:center}.room-cancel-button{padding:12px 32px;background:transparent;border:1px solid rgba(255,255,255,.2);color:#ffffffb3;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s}.room-cancel-button:hover:not(:disabled){border-color:#ffffff4d;color:#fff}.room-join-button{padding:12px 32px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s}.room-join-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 30px #6366f14d}.room-join-button:disabled{opacity:.5;cursor:not-allowed}.room{min-height:100vh;background:var(--bg-dark);display:flex;flex-direction:column}.room-header{background:#00000080;border-bottom:1px solid rgba(255,255,255,.1);padding:16px 24px;display:flex;justify-content:space-between;align-items:center}.room-info{display:flex;flex-direction:column;align-items:flex-start;gap:5px}.room-connection-info{display:flex;align-items:center;gap:15px;font-size:14px;color:#9ca3af}.sfu-indicator{color:#10b981;font-weight:500}.p2p-indicator{color:#6366f1;font-weight:500}.room-name{font-size:20px;font-weight:600;color:#fff;margin:0}.room-participant-count{font-size:14px;color:#ffffff80}.room-leave-button{padding:8px 20px;background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#ef4444;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.room-leave-button:hover{background:#ef444433}.room-main{flex:1;padding:24px;overflow-y:auto}.room-video-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:16px;max-width:1400px;margin:0 auto}.room-video-container{position:relative;aspect-ratio:16/9;background:#000;border-radius:12px;overflow:hidden}.room-video{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;transform:scaleX(-1)}.room-video-label{position:absolute;bottom:12px;left:12px;padding:4px 12px;background:#000000b3;color:#fff;border-radius:4px;font-size:14px;font-weight:500}.room-controls{background:#00000080;border-top:1px solid rgba(255,255,255,.1);padding:16px 24px;display:flex;justify-content:center;gap:12px}.room-control-button{padding:10px 20px;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.room-control-button:hover{background:#ffffff26}.room-control-button.control-disabled{background:#ef44441a;border-color:#ef44444d;color:#ef4444}@media (max-width: 768px){.room-lobby-container{padding:24px}.room-lobby-title{font-size:24px}.room-lobby-actions{flex-direction:column}.room-cancel-button,.room-join-button{width:100%}.room-video-grid{grid-template-columns:1fr}}.admin-recordings{padding:20px;max-width:1400px;margin:0 auto}.admin-recordings h2{margin-bottom:20px;color:#333}.controls{display:flex;gap:20px;margin-bottom:30px;padding:20px;background:#f5f5f5;border-radius:8px;align-items:center;flex-wrap:wrap}.date-selector,.room-selector{display:flex;align-items:center;gap:10px}.date-selector label,.room-selector label{font-weight:600;color:#555}.date-selector input,.room-selector select{padding:8px 12px;border:1px solid #ddd;border-radius:4px;font-size:14px;background:#fff}.controls button{padding:8px 20px;background:#4caf50;color:#fff;border:none;border-radius:4px;cursor:pointer;font-weight:600;transition:background .3s}.controls button:hover:not(:disabled){background:#45a049}.controls button:disabled{background:#ccc;cursor:not-allowed}.error{background:#ffebee;color:#c62828;padding:12px;border-radius:4px;margin-bottom:20px;border-left:4px solid #c62828}.recordings-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:20px}.room-card{background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:20px;box-shadow:0 2px 4px #0000001a;transition:box-shadow .3s}.room-card:hover{box-shadow:0 4px 8px #00000026}.room-card h3{margin:0 0 15px;color:#2196f3;font-size:18px;border-bottom:2px solid #e3f2fd;padding-bottom:10px}.room-stats{display:flex;justify-content:space-between;margin-bottom:15px;font-size:14px;color:#666}.room-stats span{background:#f5f5f5;padding:4px 8px;border-radius:4px}.participants{margin-bottom:15px}.participants strong{display:block;margin-bottom:8px;color:#555;font-size:14px}.participants ul{list-style:none;padding:0;margin:0}.participants li{background:#e3f2fd;padding:4px 8px;border-radius:4px;margin-bottom:4px;font-size:13px;color:#1976d2}.recordings-list{margin-top:15px}.recordings-list strong{display:block;margin-bottom:10px;color:#555;font-size:14px}.recording-item{display:flex;justify-content:space-between;align-items:center;padding:8px;margin-bottom:8px;background:#fafafa;border:1px solid #e0e0e0;border-radius:4px;transition:background .2s}.recording-item:hover{background:#f5f5f5}.recording-info{display:flex;align-items:center;gap:10px;flex:1}.recording-type{font-size:18px}.recording-user{font-weight:500;color:#333;font-size:13px}.recording-time{color:#666;font-size:12px}.archived{font-size:16px;title:"Archived to S3"}.recording-item button{padding:4px 12px;background:#2196f3;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:12px;transition:background .2s}.recording-item button:hover{background:#1976d2}.no-recordings{padding:15px;background:#fff3e0;border-radius:4px;border-left:4px solid #ff9800}.no-recordings em{color:#666;font-size:13px}.activity-summary{margin-top:8px;font-size:13px;color:#555}.no-data{grid-column:1 / -1;text-align:center;padding:40px;color:#999;font-size:16px;background:#fafafa;border-radius:8px}.video-player-modal{position:fixed;inset:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:10000;padding:20px}.modal-content{background:#fff;border-radius:8px;width:100%;max-width:900px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:15px 20px;border-bottom:1px solid #e0e0e0;background:#f5f5f5}.modal-header h3{margin:0;font-size:16px;color:#333;display:flex;align-items:center;gap:15px}.recording-timestamp{font-size:13px;color:#666;font-weight:400}.modal-header button{background:none;border:none;font-size:24px;cursor:pointer;color:#666;padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background .2s}.modal-header button:hover{background:#e0e0e0}.video-container{position:relative;flex:1;display:flex;align-items:center;justify-content:center;background:#000;min-height:400px}.video-container video{width:100%;height:auto;max-height:calc(90vh - 100px)}.video-container .loading{position:absolute;color:#fff;font-size:14px;background:#000000b3;padding:10px 20px;border-radius:4px}.config-container{min-height:100vh;background:linear-gradient(135deg,#0f0f0f,#1a1a1a);padding:2rem}.config-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:3rem;padding-bottom:1.5rem;border-bottom:1px solid rgba(255,255,255,.1)}.config-title-section{flex:1}.config-title{font-size:2.5rem;font-weight:700;background:linear-gradient(135deg,#6366f1,#8b5cf6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0 0 .5rem}.config-subtitle{color:#fff9;font-size:1.1rem;margin:0}.config-logout{padding:.75rem 1.5rem;background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#ef4444;border-radius:8px;font-weight:500;cursor:pointer;transition:all .2s}.config-logout:hover{background:#ef444433;transform:translateY(-1px)}.config-tabs{display:flex;gap:1rem;margin-bottom:2rem;border-bottom:2px solid rgba(255,255,255,.1)}.config-tab{background:none;border:none;color:#fff9;font-size:1rem;font-weight:500;padding:.75rem 1.5rem;cursor:pointer;position:relative;transition:color .3s ease}.config-tab:hover{color:#ffffffe6}.config-tab.active{color:#4fd1c5}.config-tab.active:after{content:"";position:absolute;bottom:-2px;left:0;right:0;height:2px;background:#4fd1c5}.config-message{padding:1rem;border-radius:8px;margin-bottom:2rem;font-weight:500}.config-message.success{background:#22c55e1a;border:1px solid rgba(34,197,94,.3);color:#22c55e}.config-message.error{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#ef4444}.config-section{background:#ffffff08;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:2rem;margin-bottom:2rem}.config-section-title{font-size:1.5rem;font-weight:600;color:#fff;margin:0 0 .5rem}.config-section-description{color:#fff9;margin:0 0 2rem}.config-options{display:flex;flex-direction:column;gap:1rem;margin-bottom:2rem}.config-option{display:flex;align-items:flex-start;padding:1rem;background:#ffffff05;border:1px solid rgba(255,255,255,.1);border-radius:8px;cursor:pointer;transition:all .2s}.config-option:hover{background:#ffffff0d;border-color:#6366f14d}.config-option input[type=radio]{margin-top:.25rem;margin-right:1rem;width:20px;height:20px;accent-color:#6366f1;cursor:pointer}.config-option-content{flex:1}.config-option-title{font-weight:600;color:#fff;margin-bottom:.25rem}.config-option-description{color:#fff9;font-size:.9rem}.config-actions{display:flex;justify-content:flex-end;gap:1rem}.config-save{padding:.75rem 2rem;background:linear-gradient(135deg,#6366f1,#8b5cf6);border:none;color:#fff;border-radius:8px;font-weight:600;font-size:1rem;cursor:pointer;transition:all .2s}.config-save:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 20px #6366f14d}.config-save:disabled{opacity:.5;cursor:not-allowed}.config-info{background:#6366f10d;border:1px solid rgba(99,102,241,.2);border-radius:12px;padding:1.5rem}.config-info h3{color:#8b5cf6;margin:0 0 1rem;font-size:1.1rem}.config-info ul{margin:0;padding-left:1.5rem;color:#fffc}.config-info li{margin-bottom:.5rem;line-height:1.6}.config-info strong{color:#fff}.config-info-box{padding:1rem;background-color:#e0f2fe;border:1px solid #0284c7;border-radius:.375rem;margin-bottom:1.5rem}.config-info-box p{margin:0;color:#075985}.config-info-box a{color:#0284c7;text-decoration:underline}.config-info-box a:hover{color:#0369a1}.config-loading,.config-error{display:flex;justify-content:center;align-items:center;min-height:50vh;font-size:1.2rem;color:#fff9}.sfu-loading{text-align:center;padding:2rem;color:#fff9}.sfu-status{display:flex;flex-direction:column;gap:1.5rem}.sfu-overview{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem;padding:1rem;background:#ffffff0d;border-radius:8px}.sfu-metric{display:flex;flex-direction:column;gap:.25rem}.sfu-metric-label{font-size:.875rem;color:#fff9}.sfu-metric-value{font-size:1.5rem;font-weight:600;color:#fff}.sfu-tasks{display:flex;flex-direction:column;gap:1rem}.sfu-tasks-title{font-size:1.25rem;font-weight:600;color:#fff;margin:0}.sfu-task-list{display:flex;flex-direction:column;gap:.75rem}.sfu-task{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:#ffffff0d;border-radius:8px;border:1px solid rgba(255,255,255,.1)}.sfu-task-info{display:flex;flex-direction:column;gap:.5rem}.sfu-task-id{font-weight:600;color:#fff}.sfu-task-stats{display:flex;gap:1rem;font-size:.875rem;color:#fff9}.sfu-task-stats span{white-space:nowrap}.sfu-task-ip{font-size:.875rem;color:#ffffff80}.sfu-task-stop{padding:.5rem 1rem;background:#ef4444;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:.875rem;transition:background .2s}.sfu-task-stop:hover:not(:disabled){background:#dc2626}.sfu-actions{display:flex;gap:1rem;margin-top:1rem}.sfu-action-button{padding:.75rem 1.5rem;background:#3b82f6;color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:1rem;font-weight:500;transition:background .2s}.sfu-action-button.secondary{background:#ffffff1a}.sfu-action-button:hover:not(:disabled){background:#2563eb}.sfu-action-button.secondary:hover:not(:disabled){background:#ffffff26}.sfu-action-button:disabled{opacity:.5;cursor:not-allowed}.sfu-no-data{text-align:center;padding:2rem;color:#fff9}.sfu-no-data p{margin-bottom:1rem}@media (max-width: 768px){.config-container{padding:1rem}.config-header{flex-direction:column;align-items:flex-start;gap:1rem}.config-title{font-size:2rem}.config-section{padding:1.5rem}}.sfu-main-content{padding:0;background:none;min-height:auto}.sfu-container{max-width:1200px;margin:0 auto;padding:2rem;background:linear-gradient(135deg,#0f0f0f,#1a1a1a);min-height:100vh}.sfu-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1rem;border-bottom:1px solid rgba(255,255,255,.1)}.sfu-title-section{flex:1}.sfu-title{font-size:2rem;font-weight:700;background:linear-gradient(135deg,#6366f1,#8b5cf6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0}.sfu-subtitle{color:#fff9;margin-top:.5rem;font-size:1.1rem}.sfu-header-actions{display:flex;gap:1rem;align-items:center}.auto-refresh-toggle{display:flex;align-items:center;gap:.5rem;cursor:pointer;color:#ffffffb3;font-weight:500}.auto-refresh-toggle input[type=checkbox]{cursor:pointer;accent-color:#6366f1;width:18px;height:18px}.sfu-logout{padding:.75rem 1.5rem;background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#ef4444;border-radius:8px;font-weight:500;cursor:pointer;transition:all .2s}.sfu-logout:hover{background:#ef444433;transform:translateY(-1px)}.sfu-message{padding:1rem;border-radius:8px;margin-bottom:2rem;font-weight:500}.sfu-message.success{background:#22c55e1a;border:1px solid rgba(34,197,94,.3);color:#22c55e}.sfu-message.error{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#ef4444}.sfu-main{position:relative}.sfu-main.disabled{opacity:.5;pointer-events:none}.sfu-disabled-overlay{position:absolute;inset:0;background:#0f0f0ff2;display:flex;align-items:center;justify-content:center;z-index:10;pointer-events:all;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.sfu-disabled-message{text-align:center;padding:2rem;background:#ffffff08;border:1px solid rgba(255,255,255,.1);border-radius:12px;box-shadow:0 20px 40px #0000004d;max-width:600px}.sfu-disabled-message h2{color:#fff;margin-bottom:1rem;font-size:1.5rem;font-weight:600}.sfu-disabled-message p{color:#ffffffb3;margin:1rem 0;line-height:1.6}.sfu-disabled-message ul{text-align:left;display:inline-block;margin:1rem 0;color:#fffc}.sfu-disabled-message li{margin-bottom:.5rem}.sfu-disabled-message a{color:#4fd1c5;text-decoration:none;font-weight:500}.sfu-disabled-message a:hover{text-decoration:underline;color:#81e6d9}.sfu-cleanup-warning{margin-top:2rem;padding:1rem;background:#f59e0b1a;border:1px solid rgba(245,158,11,.3);border-radius:8px}.warning-text{color:#f59e0b;font-weight:500;margin-bottom:1rem}.sfu-stop-all-button{padding:.5rem 1rem;background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#ef4444;border-radius:6px;cursor:pointer;font-weight:500;transition:all .2s}.sfu-stop-all-button:hover{background:#ef444433}.sfu-overview{margin-bottom:2rem}.sfu-overview-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem}.sfu-metric-card{background:#ffffff08;border:1px solid rgba(255,255,255,.1);padding:1rem;border-radius:12px;display:flex;flex-direction:column;align-items:center;text-align:center;transition:all .2s}.sfu-metric-card:hover{background:#ffffff0d;border-color:#6366f14d}.sfu-metric-label{font-size:.875rem;color:#fff9;margin-bottom:.5rem;font-weight:500}.sfu-metric-value{font-size:1.5rem;font-weight:700;color:#fff}.sfu-metric-value.enabled{color:#10b981}.sfu-metric-value.disabled{color:#ef4444}.sfu-tasks{margin-top:2rem}.sfu-tasks-title{font-size:1.5rem;font-weight:600;margin-bottom:1rem;color:#fff}.sfu-task-list{display:flex;flex-direction:column;gap:1rem}.sfu-task-card{background:#ffffff08;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:1.5rem;transition:all .2s}.sfu-task-card:hover{background:#ffffff0d;border-color:#6366f14d;transform:translateY(-1px)}.sfu-task-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid rgba(255,255,255,.1)}.sfu-task-id{font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:.875rem;color:#fffc;font-weight:500}.sfu-task-definition{font-size:.875rem;color:#fff9}.sfu-task-stop{padding:.375rem .75rem;background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#ef4444;border-radius:6px;cursor:pointer;font-size:.875rem;font-weight:500;transition:all .2s}.sfu-task-stop:hover:not(:disabled){background:#ef444433;transform:translateY(-1px)}.sfu-task-stop:disabled{opacity:.5;cursor:not-allowed}.sfu-task-details{display:flex;flex-direction:column;gap:1rem}.sfu-task-info-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;row-gap:.75rem}@media (max-width: 1200px){.sfu-task-info-grid{grid-template-columns:repeat(3,1fr)}}@media (max-width: 768px){.sfu-task-info-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 480px){.sfu-task-info-grid{grid-template-columns:1fr}}.sfu-task-info-item{display:flex;flex-direction:column;align-items:flex-start;gap:.25rem;min-width:0}.sfu-task-info-item .label{font-size:.875rem;color:#fff9;font-weight:500}.sfu-task-info-item .value{font-size:.875rem;color:#fff;font-family:Monaco,Menlo,Ubuntu Mono,monospace;word-break:break-word;width:100%;font-weight:500}.sfu-task-info-item .value.status-running{color:#10b981;font-weight:600}.sfu-task-info-item .value.status-starting{color:#f59e0b;font-weight:600}.sfu-task-info-item .value.status-stopping{color:#ef4444;font-weight:600}.sfu-task-rooms{margin-top:1rem;padding:1rem;background:#ffffff05;border:1px solid rgba(255,255,255,.05);border-radius:8px}.sfu-task-rooms h4{margin:0 0 .75rem;font-size:.875rem;font-weight:600;color:#fffc}.sfu-room-list{display:flex;flex-wrap:wrap;gap:.5rem}.sfu-room-item{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .5rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:6px;font-size:.875rem}.room-name{font-weight:500;color:#fff}.room-peers{color:#fff9;font-size:.75rem}.sfu-task-footer{display:flex;justify-content:space-between;margin-top:1rem;padding-top:1rem;border-top:1px solid rgba(255,255,255,.1)}.timestamp{font-size:.75rem;color:#ffffff80;font-family:Monaco,Menlo,Ubuntu Mono,monospace}.sfu-no-tasks{text-align:center;padding:3rem;background:#ffffff08;border:2px dashed rgba(255,255,255,.1);border-radius:12px;color:#fff9}.sfu-start-button{margin-top:1rem;padding:.75rem 1.5rem;background:linear-gradient(135deg,#6366f1,#8b5cf6);border:none;color:#fff;border-radius:8px;cursor:pointer;font-weight:600;font-size:1rem;transition:all .2s}.sfu-start-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 20px #6366f14d}.sfu-start-button:disabled{opacity:.5;cursor:not-allowed}.sfu-actions{display:flex;gap:1rem;justify-content:center;margin-top:2rem}.sfu-action-button{padding:.75rem 1.5rem;background:linear-gradient(135deg,#6366f1,#8b5cf6);border:none;color:#fff;border-radius:8px;cursor:pointer;font-weight:600;transition:all .2s}.sfu-action-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 20px #6366f14d}.sfu-action-button.secondary{background:#ffffff1a;border:1px solid rgba(255,255,255,.2)}.sfu-action-button.secondary:hover:not(:disabled){background:#ffffff26;transform:translateY(-1px);box-shadow:0 5px 15px #ffffff1a}.sfu-action-button:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}.sfu-loading,.sfu-error{text-align:center;padding:3rem;font-size:1.125rem;color:#fff9;background:#ffffff08;border-radius:12px;border:1px solid rgba(255,255,255,.1)}@media (max-width: 768px){.sfu-container{padding:1rem}.sfu-header{flex-direction:column;align-items:flex-start;gap:1rem}.sfu-title{font-size:1.75rem}.sfu-task-card{padding:1rem}.sfu-actions{flex-direction:column;align-items:center}.sfu-action-button{width:100%;max-width:300px}}.app{min-height:100vh;background:var(--bg-dark)}
