.auth-container{max-width:400px;margin:10vh auto;padding:48px 40px;background:#fff;border-radius:8px;box-shadow:0 4px 20px #00000014,0 1px 3px #0000000f;color:#232333;border:1px solid #e1e1e6;position:relative;font-family:Lato,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.auth-container:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#2d8cff,#0e71eb);border-radius:8px 8px 0 0}.auth-title{text-align:center;margin-bottom:32px;font-size:24px;font-weight:400;color:#232333;letter-spacing:-.3px;line-height:1.3}.auth-error{background:#fff2f0;color:#d93025;padding:12px 16px;border-radius:4px;margin-bottom:24px;font-size:14px;border:1px solid #ffa39e;font-weight:400}.auth-form{position:relative}.auth-form-group{margin-bottom:20px}.auth-label{display:block;margin-bottom:8px;font-weight:400;font-size:14px;color:#666;letter-spacing:0}.auth-input{width:100%;padding:12px 16px;border-radius:4px;border:1px solid #d4d4d8;background:#fff;color:#232333;font-size:14px;transition:all .2s ease;box-sizing:border-box;font-family:inherit}.auth-input::placeholder{color:#a1a1aa}.auth-input:focus{outline:none;border-color:#2d8cff;box-shadow:0 0 0 2px #2d8cff1a}.auth-submit-button{width:100%;padding:12px 16px;background:#2d8cff;color:#fff;border:none;border-radius:4px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;font-family:inherit;letter-spacing:0;margin-top:8px}.auth-submit-button:hover{background:#0e71eb}.auth-submit-button:disabled{cursor:not-allowed;opacity:.6;background:#9ca3af}.auth-submit-button:disabled:hover{background:#9ca3af}.auth-submit-button--loading{position:relative}.auth-submit-button--loading:after{content:"";position:absolute;width:16px;height:16px;margin:auto;border:2px solid transparent;border-top-color:#fff;border-radius:50%;animation:auth-loading-spin 1s ease infinite;top:50%;left:50%;transform:translate(-50%,-50%)}@keyframes auth-loading-spin{0%{transform:translate(-50%,-50%) rotate(0)}to{transform:translate(-50%,-50%) rotate(360deg)}}@media (max-width: 768px){.auth-container{margin:4vh 20px;padding:32px 24px}.auth-title{font-size:24px;margin-bottom:24px}}@media (max-width: 480px){.auth-container{margin:2vh 16px;padding:24px 20px}.auth-title{font-size:22px}.auth-input,.auth-submit-button{padding:12px 14px;font-size:15px}}.meeting-lobby-container{max-width:500px;margin:10vh auto;padding:40px 32px;background:#fff;border-radius:8px;box-shadow:0 4px 20px #00000014,0 1px 3px #0000000f;color:#232333;border:1px solid #e1e1e6;font-family:Lato,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol;position:relative;overflow:hidden}.meeting-lobby-container:before{content:"";position:absolute;top:0;left:0;right:0;height:6px;background-color:#2d8cff;border-top-left-radius:8px;border-top-right-radius:8px}.meeting-lobby-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:28px;padding-top:10px}.meeting-lobby-title{margin:0;font-size:22px;font-weight:400;color:#232333}.meeting-lobby-logout{padding:8px 16px;background-color:#f8f9fa;color:#2d8cff;border:1px solid #d1d5db;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:background-color .2s ease,border-color .2s ease}.meeting-lobby-logout:hover{background-color:#e9ecef;border-color:#adb5bd}.meeting-lobby-error{background:#fff2f0;color:#d93025;padding:12px 16px;border:1px solid #ffa39e;border-radius:6px;margin-bottom:20px;font-size:14px;text-align:left}.meeting-lobby-link-notice{background:#e8f4fd;color:#1976d2;padding:12px 16px;border:1px solid #90caf9;border-radius:6px;margin-bottom:20px;font-size:14px;text-align:left;display:flex;align-items:center;gap:8px}.meeting-lobby-user-info{margin-bottom:24px;background-color:#f8f9fa;padding:16px;border-radius:6px;border:1px solid #e1e1e6}.meeting-lobby-label{display:block;margin-bottom:6px;font-weight:500;font-size:14px;color:#374151}.meeting-lobby-user-input{width:100%;padding:10px 12px;border-radius:6px;border:1px solid #d4d4d8;background:#e9ecef;color:#4b5563;font-size:15px;box-sizing:border-box;cursor:not-allowed}.meeting-lobby-divider{display:flex;align-items:center;text-align:center;margin:28px 0;color:#6b7280;font-size:13px;font-weight:500}.meeting-lobby-divider-line{flex:1;height:1px;background-color:#e1e1e6}.meeting-lobby-divider-text{padding:0 12px}.meeting-lobby-actions{display:flex;flex-direction:column;gap:24px;margin-bottom:20px}.meeting-lobby-action-section{width:100%;display:flex;flex-direction:column;gap:12px}.meeting-lobby-join-section .meeting-lobby-input-group{display:flex;border-radius:6px;overflow:hidden;border:1px solid #d4d4d8;transition:border-color .2s ease,box-shadow .2s ease}.meeting-lobby-join-section .meeting-lobby-input-group:focus-within{border-color:#2d8cff;box-shadow:0 0 0 2px #2d8cff1a}.meeting-lobby-input{flex-grow:1;padding:12px 14px;border:none;background:#fff;color:#232333;font-size:15px;box-sizing:border-box;border-radius:0}.meeting-lobby-input:focus{outline:none}.meeting-lobby-create-input{padding:12px 14px;border:1px solid #d4d4d8;border-radius:6px;background:#fff;color:#232333;font-size:15px;box-sizing:border-box;width:100%}.meeting-lobby-create-input:focus{outline:none;border-color:#2d8cff;box-shadow:0 0 0 2px #2d8cff1a}.meeting-lobby-join-section .meeting-lobby-input{border-radius:6px 0 0 6px;border-right:none}.meeting-lobby-join-button,.meeting-lobby-create-button{padding:12px 20px;background:#2d8cff;color:#fff;border:none;border-radius:6px;font-size:15px;font-weight:500;cursor:pointer;transition:background-color .2s ease;white-space:nowrap}.meeting-lobby-join-button{border-radius:0 6px 6px 0}.meeting-lobby-create-button{width:100%}.meeting-lobby-join-button:hover,.meeting-lobby-create-button:hover{background:#0e71eb}.meeting-lobby-join-button:disabled,.meeting-lobby-create-button:disabled{background:#9ca3af;color:#e5e7eb;cursor:not-allowed}.meeting-lobby-or{display:flex;align-items:center;justify-content:center;padding:12px 0;font-size:14px;color:#6b7280;font-weight:500;position:relative}.meeting-lobby-or:before,.meeting-lobby-or:after{content:"";flex:1;height:1px;background-color:#e1e1e6}.meeting-lobby-or span{padding:0 16px}@media (max-width: 768px){.meeting-lobby-container{margin:5vh 20px;padding:32px 24px}.meeting-lobby-header{flex-direction:column;align-items:flex-start;gap:12px;margin-bottom:24px}.meeting-lobby-logout{align-self:flex-end}.meeting-lobby-actions{gap:20px}.meeting-lobby-or{padding:10px 0}}@media (max-width: 480px){.meeting-lobby-container{margin:2vh 16px;padding:24px 16px}.meeting-lobby-title{font-size:20px}.meeting-lobby-input,.meeting-lobby-create-input,.meeting-lobby-join-button,.meeting-lobby-create-button,.meeting-lobby-logout{font-size:14px;padding:10px 14px}.meeting-lobby-join-section .meeting-lobby-input-group{flex-direction:column}.meeting-lobby-join-section .meeting-lobby-input{border-radius:6px 6px 0 0;border-bottom:none;margin-bottom:0}.meeting-lobby-join-section .meeting-lobby-input:focus{border-color:#d4d4d8}.meeting-lobby-join-button{border-radius:0 0 6px 6px;width:100%;border-top:1px solid #d4d4d8}}.chat-overlay{position:fixed;top:20px;right:20px;width:380px;height:calc(100vh - 40px);z-index:1000;display:flex;align-items:stretch;justify-content:center}.chat-container{width:100%;height:100%;background:#fff;border-radius:8px;box-shadow:0 4px 20px #00000026,0 1px 3px #00000014;border:1px solid #e1e1e6;display:flex;flex-direction:column;overflow:hidden;font-family:Lato,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;position:relative}.chat-container:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#2d8cff,#0e71eb);border-top-left-radius:8px;border-top-right-radius:8px}.chat-header{background:#fff;color:#232333;padding:20px 20px 16px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #e1e1e6}.chat-title h3{margin:0;font-size:18px;font-weight:500;color:#232333;letter-spacing:-.2px}.participants-count{font-size:13px;color:#6b7280;margin-top:2px;display:block;font-weight:400}.chat-close-button{background:none;border:none;color:#6b7280;font-size:16px;cursor:pointer;padding:6px;border-radius:4px;transition:all .2s ease;width:28px;height:28px;display:flex;align-items:center;justify-content:center;font-weight:500}.chat-close-button:hover{background-color:#f3f4f6;color:#374151}.chat-messages{flex:1;overflow-y:auto;padding:16px;background:#fff;display:flex;flex-direction:column;gap:12px}.chat-messages::-webkit-scrollbar{width:6px}.chat-messages::-webkit-scrollbar-track{background:transparent}.chat-messages::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:3px}.chat-messages::-webkit-scrollbar-thumb:hover{background:#9ca3af}.chat-empty{display:flex;align-items:center;justify-content:center;height:100%;color:#6b7280;text-align:center;font-size:14px;flex-direction:column;gap:8px}.chat-empty p{margin:0;font-weight:400}.chat-message{display:flex;margin-bottom:0;animation:messageSlideIn .3s ease-out}.chat-message.own-message{justify-content:flex-end}.chat-message.other-message{justify-content:flex-start}.own-message .message-bubble{align-items:flex-end}.other-message .message-bubble{align-items:flex-start}.own-message .message-header{flex-direction:row-reverse}.own-message .message-content{background:#2d8cff;color:#fff;border-color:#2d8cff}.other-message .message-content{background:#f3f4f6;color:#232333;border-color:#e5e7eb}.chat-input-form{padding:16px;background:#fff;border-top:1px solid #e1e1e6}.chat-input-container{display:flex;gap:8px;align-items:flex-end;background:#f9fafb;border-radius:6px;padding:4px;border:1px solid #e5e7eb;transition:border-color .2s ease,box-shadow .2s ease}.chat-input-container:focus-within{border-color:#2d8cff;box-shadow:0 0 0 1px #2d8cff1a}.chat-input{flex:1;padding:10px 12px;border:none;border-radius:4px;outline:none;font-size:14px;background:transparent;color:#232333;transition:all .2s ease;resize:none;min-height:20px;max-height:100px;line-height:1.4;font-family:inherit}.chat-input::placeholder{color:#9ca3af}.chat-send-button{padding:10px 16px;background:#2d8cff;color:#fff;border:none;border-radius:4px;cursor:pointer;font-weight:500;transition:all .2s ease;font-size:14px;white-space:nowrap;display:flex;align-items:center;justify-content:center}.chat-send-button:hover:not(:disabled){background:#0e71eb}.chat-send-button:disabled{background:#9ca3af;cursor:not-allowed;color:#e5e7eb}@media (max-width: 768px){.chat-overlay{top:10px;right:10px;left:10px;width:auto;height:calc(100vh - 20px)}.chat-container{border-radius:6px}.chat-container:before{border-top-left-radius:6px;border-top-right-radius:6px}.chat-header{padding:18px 16px 14px}.chat-messages,.chat-input-form{padding:12px}}@media (max-width: 480px){.chat-overlay{top:5px;right:5px;left:5px;width:auto}.chat-header{padding:16px 14px 12px}.chat-title h3{font-size:16px}.participants-count{font-size:12px}.message-content{font-size:13px;padding:8px 12px}.chat-input{font-size:13px;padding:8px 10px}.chat-send-button{font-size:13px;padding:8px 12px}}.controls{padding:20px 24px;background-color:#fff;display:flex;justify-content:center;gap:16px;border-top:1px solid #e9ecef;box-shadow:0 -2px 8px #00000014}.control-button{padding:12px 16px;border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:600;font-size:14px;transition:all .2s ease;box-shadow:0 2px 8px #00000026}.control-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0003}.control-button--circular{border-radius:50%;width:56px;height:56px;display:flex;align-items:center;justify-content:center;font-size:18px}.control-button--mute{background-color:#6c757d}.control-button--mute.muted{background-color:#dc3545}.control-button--mute:hover{background-color:#5a6268}.control-button--mute.muted:hover{background-color:#c82333}.control-button--video{background-color:#6c757d}.control-button--video.video-off{background-color:#dc3545}.control-button--video:hover{background-color:#5a6268}.control-button--video.video-off:hover{background-color:#c82333}.control-button--screen-share{background-color:#6c757d}.control-button--screen-share.screen-sharing{background-color:#28a745}.control-button--screen-share:hover{background-color:#5a6268}.control-button--screen-share.screen-sharing:hover{background-color:#218838}.control-button--leave{padding:12px 24px;background-color:#dc3545;border-radius:8px;font-weight:700}.control-button--leave:hover{background-color:#c82333}.control-button--chat{background-color:#2d8cff;position:relative}.control-button--chat:hover{background-color:#1976d2}.control-button--chat.active{background-color:#1976d2;box-shadow:0 2px 8px #2d8cff66}.unread-badge{position:absolute;top:-8px;right:-8px;background-color:#dc3545;color:#fff;border-radius:50%;width:20px;height:20px;font-size:11px;display:flex;align-items:center;justify-content:center;font-weight:700;border:1px solid rgba(255,255,255,.8);box-shadow:0 2px 8px #dc354566,0 0 0 2px #fff3}.control-button--participants{background-color:#6c757d;position:relative;display:none}.control-button--participants:hover{background-color:#5a6268}.control-button--participants.active{background-color:#2d8cff}.participants-badge{position:absolute;top:-8px;right:-8px;background-color:#28a745;color:#fff;border-radius:50%;width:20px;height:20px;font-size:11px;display:flex;align-items:center;justify-content:center;font-weight:700;border:1px solid rgba(255,255,255,.8);box-shadow:0 2px 8px #28a74566,0 0 0 2px #fff3}@media (max-width: 768px){.control-button--participants{display:flex!important}.controls{padding:16px;gap:12px;background-color:#fff;border-top:1px solid #e9ecef;box-shadow:0 -2px 12px #0000001a}.control-button--circular{width:52px;height:52px;font-size:18px}.control-button--leave{padding:12px 20px;font-size:14px}}@media (max-width: 480px){.controls{padding:12px;gap:8px;flex-wrap:wrap;justify-content:center}.control-button--circular{width:48px;height:48px;font-size:16px}.control-button--leave{padding:10px 16px;font-size:13px;flex-basis:100%;margin-top:8px}}@media (max-width: 768px) and (orientation: landscape){.controls{padding:12px 16px}.control-button--circular{width:44px;height:44px;font-size:16px}.control-button--leave{padding:8px 16px;margin-top:0;flex-basis:auto}}@media (max-width: 360px){.control-button--circular{width:44px;height:44px;font-size:15px}.controls{gap:6px}}@media (hover: none) and (pointer: coarse){.control-button{min-height:44px}}.chat-mobile-drawer .ant-drawer-header{background-color:#f8f9fa;border-bottom:1px solid #e9ecef}.chat-mobile-drawer .ant-drawer-header .ant-drawer-title{font-size:18px;font-weight:600;color:#232333}.chat-mobile-drawer .ant-drawer-body{padding:0!important;background-color:#fff;display:flex;flex-direction:column;height:90%}.chat-mobile-container{display:flex;flex-direction:column;height:100%;min-height:70vh}.chat-mobile-messages{flex:1;overflow-y:auto;padding:16px;background:#fff;display:flex;flex-direction:column;gap:12px;-webkit-overflow-scrolling:touch}.chat-mobile-messages::-webkit-scrollbar{width:6px}.chat-mobile-messages::-webkit-scrollbar-track{background:transparent}.chat-mobile-messages::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:3px}.chat-mobile-messages::-webkit-scrollbar-thumb:hover{background:#9ca3af}.chat-mobile-empty{display:flex;align-items:center;justify-content:center;height:100%;color:#6b7280;text-align:center;font-size:14px;flex-direction:column;gap:8px}.chat-mobile-empty p{margin:0;font-weight:400}.chat-mobile-message{display:flex;animation:messageSlideIn .3s ease-out}.chat-mobile-message.own-message{justify-content:flex-end}.chat-mobile-message.other-message{justify-content:flex-start}.message-bubble{max-width:80%;min-width:80px;display:flex;flex-direction:column}.chat-mobile-message.own-message .message-bubble{align-items:flex-end}.chat-mobile-message.other-message .message-bubble{align-items:flex-start}.message-header{display:flex;align-items:baseline;margin-bottom:4px;font-size:12px;gap:6px;padding:0 2px}.chat-mobile-message.own-message .message-header{flex-direction:row-reverse}.message-sender{font-weight:500;color:#374151;font-size:12px}.message-time{color:#6b7280;font-size:11px;font-weight:400}.message-content{padding:10px 14px;border-radius:8px;word-wrap:break-word;line-height:1.4;font-size:14px;max-width:100%;position:relative;border:1px solid transparent}.chat-mobile-message.own-message .message-content{background:#2d8cff;color:#fff;border-color:#2d8cff}.chat-mobile-message.other-message .message-content{background:#f3f4f6;color:#232333;border-color:#e5e7eb}.chat-mobile-input-form{padding:16px;background:#fff;border-top:1px solid #e1e1e6;flex-shrink:0}.chat-mobile-input-container{display:flex;gap:8px;align-items:flex-end;background:#f9fafb;border-radius:6px;padding:4px;border:1px solid #e5e7eb;transition:border-color .2s ease,box-shadow .2s ease}.chat-mobile-input-container:focus-within{border-color:#2d8cff;box-shadow:0 0 0 1px #2d8cff1a}.chat-mobile-input{flex:1;padding:10px 12px;border:none;border-radius:4px;outline:none;font-size:14px;background:transparent;color:#232333;transition:all .2s ease;resize:none;min-height:20px;max-height:100px;line-height:1.4;font-family:inherit}.chat-mobile-input::placeholder{color:#9ca3af}.chat-mobile-send-button{padding:10px 16px;background:#2d8cff;color:#fff;border:none;border-radius:4px;cursor:pointer;font-weight:500;transition:all .2s ease;font-size:14px;white-space:nowrap;min-width:60px;display:flex;align-items:center;justify-content:center}.chat-mobile-send-button:hover:not(:disabled){background:#0e71eb}.chat-mobile-send-button:disabled{background:#9ca3af;cursor:not-allowed;color:#e5e7eb}@keyframes messageSlideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.participants-drawer .ant-drawer-header{background-color:#f8f9fa;border-bottom:1px solid #e9ecef}.participants-drawer .ant-drawer-header .ant-drawer-title{font-size:18px;font-weight:600;color:#232333}.participants-drawer .ant-drawer-body{padding:0!important;background-color:#fff}.drawer-participants{display:flex;flex-direction:column;gap:12px;padding:0;min-height:60vh;max-height:70vh;overflow-y:auto}.drawer-participants .participant-item{display:flex;align-items:center;gap:12px;padding:12px;border-radius:0;background-color:#f8f9fa;cursor:pointer;transition:all .2s ease}.drawer-participants .participant-item:hover{background-color:#e3f2fd;border-color:#2d8cff;transform:translateY(-1px);box-shadow:0 2px 8px #2d8cff26}.drawer-participants .participant-item.active{background-color:#e3f2fd;border-color:#2d8cff;box-shadow:0 2px 8px #2d8cff26}.drawer-participants .participant-avatar{width:40px;height:40px;border-radius:50%;background-color:#2d8cff;color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:16px;flex-shrink:0}.drawer-participants .participant-avatar.host{background-color:#ffa726}.drawer-participants .participant-avatar.local{background-color:#28a745}.drawer-participants .participant-info{flex:1;min-width:0}.drawer-participants .participant-name{font-size:14px;font-weight:600;color:#232333;margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.drawer-participants .participant-name.host{color:#f57c00}.drawer-participants .participant-name.local{color:#28a745}.drawer-participants .participant-status{display:flex;gap:8px;flex-wrap:wrap}.drawer-participants .status-indicator{background-color:#e9ecef;color:#495057;padding:2px 8px;border-radius:12px;font-size:12px;font-weight:500}.drawer-participants .status-indicator.muted{background-color:#ffebee;color:#c62828}.drawer-participants .status-indicator.video-off{background-color:#fff3e0;color:#ef6c00}.drawer-participants .status-indicator.screen-sharing{background-color:#e8f5e8;color:#2e7d32}.status-bar{padding:12px 24px;display:flex;justify-content:space-between;align-items:center;background-color:#fff;border-bottom:1px solid #e9ecef;box-shadow:0 2px 8px #00000014;position:relative}.status-bar:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(135deg,#2d8cff,#1976d2)}.status-bar-content{display:flex;align-items:center;gap:12px;font-weight:500}.connection-status-indicator{display:flex;align-items:center;gap:8px}.status-dot{width:12px;height:12px;border-radius:50%;transition:all .3s ease;position:relative}.status-dot--connected{background-color:#28a745;box-shadow:0 0 8px #28a74566}.status-dot--disconnected{background-color:#dc3545;box-shadow:0 0 8px #dc354566}.status-dot--connecting{background-color:#ffc107;box-shadow:0 0 8px #ffc10766;animation:pulse 2s infinite}@keyframes pulse{0%{transform:scale(1);opacity:1}50%{transform:scale(1.2);opacity:.7}to{transform:scale(1);opacity:1}}.status-label{font-size:13px;color:#6c757d;font-weight:500}.copy-meeting-button{background-color:#2d8cff;border:none;border-radius:6px;color:#fff;padding:8px 16px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s ease;outline:none;box-shadow:0 2px 8px #2d8cff4d;white-space:nowrap}.meeting-id-text{white-space:nowrap}.copy-meeting-button:hover{background-color:#1976d2;box-shadow:0 4px 12px #2d8cff66;transform:translateY(-1px)}.copy-meeting-button:active{transform:translateY(0);box-shadow:0 2px 8px #2d8cff4d}@media (max-width: 768px){.status-bar{padding:10px 16px}.status-bar-content{font-size:13px}.meeting-id-text{display:none}.copy-meeting-button{padding:6px 12px;font-size:12px;white-space:nowrap}}@media (max-width: 480px){.status-bar{padding:8px 12px}.status-bar-content{font-size:12px;gap:8px}.meeting-id-text{display:none}.copy-meeting-button{padding:4px 8px;font-size:11px;white-space:nowrap}}@media (max-width: 360px){.meeting-id-text{display:none}.copy-meeting-button{white-space:nowrap;font-size:10px;padding:3px 6px}}@media (hover: none) and (pointer: coarse){.copy-meeting-button{min-height:36px}}.main-video-container{position:relative;width:100%;height:100%}.main-video{width:100%;height:100%;object-fit:cover;background-color:#000}.main-video-no-stream{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background-color:#343a40;color:#fff}.main-video-loading-overlay{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center;background-color:#000000b3;color:#fff}.main-video-error-overlay{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center;background-color:#000000b3;color:#fff;flex-direction:column}.main-video-error-subtitle{font-size:.8em;margin-top:5px}.participant-thumbnail{margin-bottom:10px;cursor:pointer;border:1px solid #dee2e6;border-radius:4px;overflow:hidden;background-color:#000;position:relative;height:120px}.participant-thumbnail.active{border:2px solid #0d6efd}.participant-thumbnail-video-container{position:relative;width:100%;height:100%}.participant-thumbnail-video{width:100%;height:100%;object-fit:cover;background-color:#000}.participant-thumbnail-video.mirrored{transform:scaleX(-1)}.participant-thumbnail-video-off-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background-color:#6c757d;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#fff;z-index:1}.participant-thumbnail-avatar{font-size:36px;margin-bottom:5px}.participant-thumbnail-muted-indicator{background-color:#dc3545e6;color:#fff;border-radius:50%;width:20px;height:20px;display:flex;align-items:center;justify-content:center;font-size:12px;margin-top:5px}.participant-thumbnail-loading-indicator{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#fff;font-size:12px;background-color:#000000b3;padding:5px 10px;border-radius:4px;display:flex;align-items:center;gap:5px}.participant-thumbnail-loading-spinner{width:12px;height:12px;border:2px solid #ffffff;border-top:2px solid transparent;border-radius:50%;animation:spin 1s linear infinite}.participant-thumbnail-error-indicator{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#fff;font-size:12px;background-color:#dc3545cc;padding:5px 10px;border-radius:4px;text-align:center}.participant-thumbnail-play-button{position:absolute;bottom:5px;right:5px;color:#fff;font-size:16px;cursor:pointer}.participant-thumbnail-no-video{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background-color:#6c757d;color:#fff;font-size:24px}.participant-thumbnail-name-label{position:absolute;bottom:0;left:0;right:0;background-color:#00000080;color:#fff;padding:2px 5px;font-size:12px;text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.participant-thumbnail-status-indicators{position:absolute;top:5px;left:5px;display:flex;gap:5px}.participant-thumbnail-status-indicator{background-color:#dc3545cc;color:#fff;border-radius:50%;width:20px;height:20px;display:flex;align-items:center;justify-content:center;font-size:10px}.participant-thumbnail-status-indicator.screen-sharing{background-color:#28a745cc}.participant-thumbnail-connection-status{border-radius:50%;width:8px;height:8px}.participant-thumbnail-connection-status.connected{background-color:#28a745cc}.participant-thumbnail-connection-status.error{background-color:#dc3545cc}.participant-thumbnail-connection-status.loading{background-color:#ffc107cc}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.sidebar{width:240px;margin:8px 8px 8px 0;background-color:#fff;overflow-y:auto;display:flex;flex-direction:column;border-left:1px solid #e9ecef;box-shadow:-2px 0 8px #0000000d}.sidebar-header{padding:10px;border-bottom:1px solid #e9ecef;background-color:#fff;position:relative;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;min-height:30px}.sidebar-header:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(135deg,#2d8cff,#1976d2)}.sidebar-header h5{margin:0;color:#232333;font-weight:700;font-size:15px}.participants-count{color:#6c757d;font-size:12px;font-weight:500;margin:0}.local-participant-container{padding:10px 14px;background-color:#f8f9fa;border-bottom:1px solid #e9ecef}.remote-participants-container{padding:10px 14px;flex:1}@media (max-width: 1024px){.sidebar{width:200px}}@media (max-width: 768px){.sidebar{display:none}}.main-content{display:flex;flex:1;height:calc(100vh - 130px);overflow:hidden;background-color:#f8f9fa}.main-video-container{flex:1;padding:15px;display:flex;flex-direction:column;position:relative;background-color:#f8f9fa}.main-video-wrapper{flex:1;background-color:#000;border-radius:12px;position:relative;overflow:hidden;box-shadow:0 8px 24px #00000026;border:2px solid #e9ecef}.main-participant-name{position:absolute;bottom:24px;left:24px;background-color:#000000b3;color:#fff;padding:8px 12px;border-radius:8px;z-index:2;font-weight:600;font-size:14px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.main-video{width:100%;height:100%;object-fit:cover}.local-video-container{position:relative;width:100%;height:100%}.video-off-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,#f8f9fa,#e9ecef);display:flex;flex-direction:column;align-items:center;justify-content:center;color:#495057;z-index:1;border-radius:12px}.avatar-large{font-size:72px;margin-bottom:16px;color:#6c757d}.muted-indicator-overlay{background-color:#dc3545;color:#fff;border-radius:50%;width:44px;height:44px;display:flex;align-items:center;justify-content:center;font-size:20px;margin-top:16px;box-shadow:0 4px 12px #dc35454d}@media (max-width: 768px){.main-video-container{padding:12px;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}.main-video-display{border-radius:8px;overflow:hidden}.main-participant-name{font-size:14px;padding:8px 12px}}@media (max-width: 480px){.main-content{height:calc(100vh - 130px)}.main-video-container{padding:8px}.main-participant-name{font-size:13px;padding:6px 10px}}@media (max-width: 768px) and (orientation: landscape){.main-content{height:calc(100vh - 120px)}}@media (max-width: 360px){.main-video-container{padding:6px}}.app-container{height:100vh;display:flex;flex-direction:column;background-color:#fff;font-family:Lato,sans-serif;color:#232333}.participants-bottom-sheet{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#0009;z-index:1000;display:none;opacity:0;visibility:hidden;transition:opacity .2s cubic-bezier(.25,.46,.45,.94),visibility .2s cubic-bezier(.25,.46,.45,.94),backdrop-filter .2s cubic-bezier(.25,.46,.45,.94);-webkit-backdrop-filter:blur(0px);backdrop-filter:blur(0px);overscroll-behavior:contain;touch-action:none;-webkit-overflow-scrolling:touch;-webkit-transform:translate3d(0,0,0);transform:translateZ(0);-webkit-backface-visibility:hidden;backface-visibility:hidden;overflow:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;will-change:transform,opacity}.participants-bottom-sheet.active{opacity:1;visibility:visible;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:slideUpBackdrop .2s cubic-bezier(.25,.46,.45,.94)}.participants-bottom-sheet.closing{opacity:0;visibility:visible;-webkit-backdrop-filter:blur(0px);backdrop-filter:blur(0px);animation:slideDownBackdrop .15s cubic-bezier(.55,.06,.68,.19)}.participants-bottom-sheet.closing .bottom-sheet-content{transform:translateY(100%);-webkit-transform:translateY(100%);animation:slideDownContent .15s cubic-bezier(.55,.06,.68,.19)}.bottom-sheet-content{position:absolute;bottom:0;left:0;right:0;background-color:#fff;border-radius:10px 10px 0 0;box-shadow:0 -12px 40px #00000040;transform:translateY(100%);transition:transform .05s cubic-bezier(.25,.46,.45,.94);min-height:75vh;max-height:90vh;display:flex;flex-direction:column;overflow:hidden;will-change:transform;touch-action:pan-y;-webkit-transform:translateY(100%);-webkit-transition:-webkit-transform .05s cubic-bezier(.25,.46,.45,.94);-webkit-overflow-scrolling:touch;position:relative;-webkit-backface-visibility:hidden;backface-visibility:hidden;-webkit-font-smoothing:antialiased;isolation:isolate;contain:layout style paint}.participants-bottom-sheet.active .bottom-sheet-content{transform:translateY(0);-webkit-transform:translateY(0);animation:slideUpContent .2s cubic-bezier(.25,.46,.45,.94)}.bottom-sheet-handle{width:36px;height:4px;background-color:#d0d7de;border-radius:2px;margin:8px auto;opacity:.8;transition:all .2s ease;transform:scaleX(.8)}.participants-bottom-sheet.active .bottom-sheet-handle{animation:handleAppear .25s cubic-bezier(.25,.46,.45,.94) .1s forwards}.participants-bottom-sheet.closing .bottom-sheet-handle{animation:handleDisappear .15s cubic-bezier(.55,.06,.68,.19) forwards}.bottom-sheet-handle:hover{opacity:1;width:44px;transform:scaleX(1.1)}.bottom-sheet-header{padding:6px 24px 14px;display:flex;justify-content:space-between;align-items:center;background-color:#fff;border-bottom:1px solid #f0f0f0}.bottom-sheet-header h5{margin:0;font-size:17px;font-weight:600;color:#1a1a1a}.bottom-sheet-close{background-color:#f5f5f5;border:none;color:#666;font-size:16px;cursor:pointer;padding:8px;border-radius:20px;transition:all .2s ease;width:32px;height:32px;display:flex;align-items:center;justify-content:center}.bottom-sheet-close:hover{background-color:#e0e0e0;color:#333;transform:scale(1.05)}.bottom-sheet-participants{flex:1;overflow-y:auto;padding:0;max-height:calc(65vh - 70px);-webkit-overflow-scrolling:touch;overscroll-behavior:contain;overscroll-behavior-y:contain;touch-action:pan-y;-webkit-transform:translate3d(0,0,0);transform:translateZ(0);-webkit-backface-visibility:hidden;backface-visibility:hidden;contain:layout style paint;isolation:isolate;position:relative;z-index:1}.participant-item{display:flex;align-items:center;padding:16px 24px;border-bottom:1px solid #f0f0f0;transition:all .2s cubic-bezier(.4,0,.2,1);cursor:pointer;background-color:#fff;position:relative;overflow:hidden;opacity:0;transform:translateY(10px);animation:participantItemEnter .25s cubic-bezier(.25,.46,.45,.94) forwards;-webkit-transform:translateY(10px);-webkit-backface-visibility:hidden;backface-visibility:hidden;contain:layout style;isolation:isolate;-webkit-font-smoothing:antialiased}.participant-item:nth-child(1){animation-delay:.05s}.participant-item:nth-child(2){animation-delay:.08s}.participant-item:nth-child(3){animation-delay:.11s}.participant-item:nth-child(4){animation-delay:.14s}.participant-item:nth-child(5){animation-delay:.17s}.participant-item:nth-child(6){animation-delay:.2s}.participant-item:nth-child(n+7){animation-delay:.23s}.participants-bottom-sheet.closing .participant-item{animation:participantItemExit .2s cubic-bezier(.55,.06,.68,.19) forwards}.participants-bottom-sheet.closing .participant-item:nth-child(1){animation-delay:0s}.participants-bottom-sheet.closing .participant-item:nth-child(2){animation-delay:.02s}.participants-bottom-sheet.closing .participant-item:nth-child(3){animation-delay:.04s}.participants-bottom-sheet.closing .participant-item:nth-child(4){animation-delay:.06s}.participants-bottom-sheet.closing .participant-item:nth-child(5){animation-delay:.08s}.participants-bottom-sheet.closing .participant-item:nth-child(6){animation-delay:.1s}.participants-bottom-sheet.closing .participant-item:nth-child(n+7){animation-delay:.12s}.participant-item:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(45,140,255,.1),transparent);transition:left .3s cubic-bezier(.4,0,.2,1)}.participant-item:hover:before{left:100%}.participant-item:hover{background-color:#f8f9fa;transform:translate(4px);box-shadow:0 2px 12px #00000014}.participant-item:active{transform:translate(2px) scale(.98);background-color:#e8f4f8;transition:all .1s cubic-bezier(.4,0,.2,1)}.participant-item:active:after{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background-color:#2d8cff4d;transform:translate(-50%,-50%);animation:ripple .6s cubic-bezier(.4,0,.2,1)}.participant-item:last-child{border-bottom:none}.participant-item.active{background-color:#e3f2fd;border-left:4px solid #2d8cff;transform:translate(0)}.participant-item.active:hover{transform:translate(0)}.participant-avatar{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;color:#fff;font-size:18px;font-weight:600;margin-right:16px;flex-shrink:0;box-shadow:0 4px 12px #00000026;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.participant-avatar:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:linear-gradient(45deg,transparent 30%,rgba(255,255,255,.3) 50%,transparent 70%);transform:rotate(-45deg);transition:all .6s cubic-bezier(.4,0,.2,1);opacity:0}.participant-item:hover .participant-avatar:before{opacity:1;transform:rotate(-45deg) translate(100%)}.participant-item:hover .participant-avatar{transform:scale(1.05);box-shadow:0 6px 20px #0003}.participant-avatar.host{background:linear-gradient(135deg,#ff6b6b,#ee5a24);box-shadow:0 4px 12px #ff6b6b4d}.participant-avatar.local{background:linear-gradient(135deg,#2d8cff,#1976d2);box-shadow:0 4px 12px #2d8cff4d}.participant-info{flex:1;min-width:0}.participant-name{font-size:16px;font-weight:500;color:#1a1a1a;margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.participant-name.host:after{content:" (Host)";color:#ff6b6b;font-weight:600;font-size:14px}.participant-name.local:after{content:" (You)";color:#2d8cff;font-weight:600;font-size:14px}.participant-status{display:flex;align-items:center;gap:6px;margin-top:4px;flex-wrap:wrap}.status-indicator{display:flex;align-items:center;gap:4px;font-size:11px;font-weight:500;color:#666;background-color:#f5f6f7;padding:3px 8px;border-radius:12px;transition:all .2s cubic-bezier(.4,0,.2,1);border:1px solid transparent;animation:fadeInUp .3s cubic-bezier(.4,0,.2,1)}@keyframes slideUpBackdrop{0%{opacity:0;-webkit-backdrop-filter:blur(0px);backdrop-filter:blur(0px)}to{opacity:1;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}}@keyframes slideDownBackdrop{0%{opacity:1;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}to{opacity:0;-webkit-backdrop-filter:blur(0px);backdrop-filter:blur(0px)}}@keyframes slideUpContent{0%{transform:translateY(100%) scale(.95) translateZ(0);-webkit-transform:translateY(100%) scale(.95) translateZ(0);box-shadow:0 -5px 20px #0000001a;opacity:.8}30%{transform:translateY(40%) scale(.97) translateZ(0);-webkit-transform:translateY(40%) scale(.97) translateZ(0);box-shadow:0 -8px 30px #00000026;opacity:.9}70%{transform:translateY(-2%) scale(1.005) translateZ(0);-webkit-transform:translateY(-2%) scale(1.005) translateZ(0);box-shadow:0 -14px 45px #0000004d;opacity:.98}to{transform:translateY(0) scale(1) translateZ(0);-webkit-transform:translateY(0) scale(1) translateZ(0);box-shadow:0 -12px 40px #00000040;opacity:1}}@keyframes slideDownContent{0%{transform:translateY(0) scale(1) translateZ(0);-webkit-transform:translateY(0) scale(1) translateZ(0);box-shadow:0 -12px 40px #00000040;opacity:1}30%{transform:translateY(-2%) scale(1.005) translateZ(0);-webkit-transform:translateY(-2%) scale(1.005) translateZ(0);box-shadow:0 -14px 45px #0000004d;opacity:.98}70%{transform:translateY(40%) scale(.97) translateZ(0);-webkit-transform:translateY(40%) scale(.97) translateZ(0);box-shadow:0 -8px 30px #00000026;opacity:.9}to{transform:translateY(100%) scale(.95) translateZ(0);-webkit-transform:translateY(100%) scale(.95) translateZ(0);box-shadow:0 -5px 20px #0000001a;opacity:.8}}@keyframes handleAppear{0%{transform:scaleX(.5);opacity:.4}50%{transform:scaleX(1.2);opacity:.9}to{transform:scaleX(1);opacity:.8}}@keyframes handleDisappear{0%{transform:scaleX(1);opacity:.8}50%{transform:scaleX(1.2);opacity:.4}to{transform:scaleX(.5);opacity:.2}}@keyframes participantItemEnter{0%{opacity:0;transform:translateY(15px) translateZ(0) scale(.95);-webkit-transform:translateY(15px) translateZ(0) scale(.95)}50%{opacity:.7;transform:translateY(5px) translateZ(0) scale(.98);-webkit-transform:translateY(5px) translateZ(0) scale(.98)}to{opacity:1;transform:translateY(0) translateZ(0) scale(1);-webkit-transform:translateY(0) translateZ(0) scale(1)}}@keyframes participantItemExit{0%{opacity:1;transform:translateY(0) translateZ(0) scale(1);-webkit-transform:translateY(0) translateZ(0) scale(1)}to{opacity:0;transform:translateY(-10px) translateZ(0) scale(.9);-webkit-transform:translateY(-10px) translateZ(0) scale(.9)}}@keyframes ripple{0%{width:0;height:0;opacity:.6}to{width:200px;height:200px;opacity:0}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.status-indicator.muted{background-color:#ffebee;color:#c62828;border-color:#ffcdd2}.status-indicator.screen-sharing{background-color:#e8f5e8;color:#2e7d32;border-color:#c8e6c9;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.05);opacity:.9}}.chat-overlay{position:fixed;top:24px;right:24px;width:380px;height:calc(100vh - 48px);z-index:1000;display:flex;align-items:stretch;justify-content:center}.chat-container{width:100%;height:100%;background-color:#fff;border-radius:12px;box-shadow:0 12px 32px #00000026;border:1px solid #e9ecef;display:flex;flex-direction:column;overflow:hidden}.chat-header{background:linear-gradient(135deg,#2d8cff,#1976d2);color:#fff;padding:20px 24px;display:flex;justify-content:space-between;align-items:center;border-bottom:none;box-shadow:0 2px 8px #2d8cff33}.chat-title h3{margin:0;font-size:18px;font-weight:700;color:#fff;letter-spacing:.3px}.participants-count{font-size:13px;color:#fffc;margin-top:2px;display:block;font-weight:500}.chat-close-button{background:none;border:none;color:#fffc;font-size:18px;cursor:pointer;padding:8px;border-radius:8px;transition:all .2s ease;width:32px;height:32px;display:flex;align-items:center;justify-content:center}.chat-close-button:hover{background-color:#ffffff26;color:#fff}.mobile-header{display:none;background-color:#fff;border-bottom:1px solid #e9ecef;padding:12px 16px;box-shadow:0 2px 8px #00000014}.mobile-header-content{display:flex;justify-content:space-between;align-items:center}.mobile-participants-toggle{background:none;border:1px solid #e9ecef;border-radius:6px;padding:8px 12px;font-size:13px;color:#232333;cursor:pointer;display:flex;align-items:center;gap:6px;transition:all .2s ease}.mobile-participants-toggle:hover{background-color:#f8f9fa;border-color:#2d8cff}.mobile-participants-toggle.active{background-color:#2d8cff;color:#fff;border-color:#2d8cff}.mobile-participants-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;z-index:1000;display:none}.mobile-participants-panel{position:absolute;top:0;left:0;width:280px;height:100%;background-color:#fff;box-shadow:2px 0 12px #00000026;transform:translate(-100%);transition:transform .3s ease}.mobile-participants-overlay.active .mobile-participants-panel{transform:translate(0)}.mobile-participants-header{padding:16px;border-bottom:1px solid #e9ecef;display:flex;justify-content:space-between;align-items:center;background:linear-gradient(135deg,#2d8cff,#1976d2);color:#fff}.mobile-participants-close{background:none;border:none;color:#fff;font-size:18px;cursor:pointer;padding:4px;border-radius:4px;transition:background-color .2s ease}.mobile-participants-close:hover{background-color:#ffffff26}.mobile-participants-content{flex:1;overflow-y:auto;padding:12px}.chat-desktop{display:block}.chat-drawer{display:none}.chat-drawer .ant-drawer-header{background-color:#f8f9fa;border-bottom:1px solid #e9ecef}.chat-drawer .ant-drawer-header .ant-drawer-title{font-size:18px;font-weight:600;color:#232333}.chat-drawer .ant-drawer-body{padding:0;background-color:#fff;display:flex;flex-direction:column;height:90%}@media (min-width: 769px){.chat-desktop{display:block}}@media (max-width: 768px){.chat-desktop{display:none}}@media (max-width: 1024px){.control-button--circular{width:50px;height:50px;font-size:16px}.controls{padding:16px 20px;gap:12px}}@media (max-width: 768px){body{-webkit-touch-callout:none;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;overflow:hidden;position:fixed;width:100%;height:100%}.mobile-header{display:none}.participants-bottom-sheet{display:block!important;z-index:9999;-webkit-transform:translateZ(0);transform:translateZ(0);will-change:opacity,visibility}.participants-bottom-sheet.active{display:block!important;opacity:1!important;visibility:visible!important}.participants-bottom-sheet.closing{display:block!important;visibility:visible!important}.mobile-participants-overlay.active{display:block}.bottom-sheet-content{-webkit-transform:translateZ(0);transform:translateZ(0);will-change:transform;opacity:1;visibility:visible}.bottom-sheet-participants{-webkit-transform:translateZ(0);transform:translateZ(0);will-change:scroll-position;opacity:1;visibility:visible}.participant-item{-webkit-transform:translateZ(0);transform:translateZ(0)}}@media (max-width: 480px){.mobile-participants-panel{width:260px}.mobile-participants-header{padding:12px}.mobile-participants-content{padding:8px}}@media (max-width: 360px){.mobile-participants-panel{width:240px}}@media (hover: none) and (pointer: coarse){.mobile-participants-toggle{min-height:44px;padding:10px 14px}}
