:root{color-scheme:dark}*,*:before,*:after{box-sizing:border-box}body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;background:#0b0d10;color:#e8eef7;min-height:100vh;min-height:100dvh}.hidden{display:none!important}.join-screen{display:flex;align-items:center;justify-content:center;min-height:100vh;min-height:100dvh;padding:20px}.join-card{background:#0f141c;border:1px solid #1c2330;border-radius:16px;padding:36px 40px;width:100%;max-width:440px;text-align:center}.join-card h1{margin:0 0 4px;font-size:24px;font-weight:800}.join-card .subtitle{color:#6b7d99;font-size:13px;margin:0 0 24px}.field-group{margin-bottom:14px;text-align:left}.field-group label{display:block;font-size:12px;color:#6b7d99;margin-bottom:4px;font-weight:500}.field-group input,.field-group select{width:100%;padding:11px 14px;background:#0b0d10;border:1px solid #1c2330;border-radius:10px;color:#e8eef7;font-size:14px}.field-group input:focus,.field-group select:focus{border-color:#22c55e;outline:none}.field-row{display:flex;gap:12px}.field-row .field-group{flex:1}.code-input{text-align:center;font-size:24px!important;letter-spacing:8px;font-weight:700;text-transform:uppercase}.preview-wrap{margin:16px 0;border-radius:12px;overflow:hidden;background:#000;aspect-ratio:16/9;max-height:220px;position:relative}.preview-wrap video{width:100%;height:100%;object-fit:cover;display:block;transform:scaleX(-1)}.btn-join{width:100%;padding:14px;background:#22c55e;border:none;border-radius:12px;color:#fff;font-size:15px;font-weight:700;cursor:pointer;margin-top:8px;transition:background .15s}.btn-join:hover{background:#16a34a}.btn-join:disabled{opacity:.5;cursor:not-allowed}.btn-code{width:100%;padding:14px;background:#22c55e;border:none;border-radius:12px;color:#fff;font-size:15px;font-weight:700;cursor:pointer;margin-top:4px}.btn-code:hover{background:#16a34a}.btn-code:disabled{opacity:.5;cursor:not-allowed}.status-msg{color:#f59e0b;font-size:13px;margin-top:10px;min-height:20px}.error-msg{color:#ef4444}.room-name-display{background:#1c2330;padding:8px 16px;border-radius:10px;font-size:14px;color:#93bbfc;margin-bottom:16px;font-weight:600}.conf-view{display:flex;flex-direction:column;height:100vh;height:100dvh;transition:margin-right .2s ease}.conf-view.panel-open{margin-right:320px}.conf-header{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;background:#0f141c;border-bottom:1px solid #1c2330;flex-shrink:0}.conf-header-left{display:flex;align-items:center;gap:10px}.conf-room-name{font-weight:700;font-size:15px}.conf-badge{background:#1c2330;padding:3px 10px;border-radius:999px;font-size:12px;color:#6b7d99}.conf-header-right{display:flex;align-items:center;gap:8px}.conf-header-btn{background:#1c2330;border:none;color:#b9c7dd;padding:6px 10px;border-radius:8px;cursor:pointer;font-size:12px;font-weight:600;display:flex;align-items:center;gap:5px;transition:background .15s}.conf-header-btn:hover{background:#2a3548}.conf-header-btn.active-toggle{background:#3b82f6;color:#fff}.conf-header-btn.active-speaker-on{background:#22c55e;color:#fff}.conf-header-btn.active-speaker-off{background:#1c2330;color:#6b7d99}.conf-header-btn svg{width:16px;height:16px}.conf-lock-icon{color:#f59e0b;display:flex;align-items:center;margin-left:6px}.conf-lock-icon svg{width:16px;height:16px}.conf-thumbs{display:flex;gap:8px;padding:8px 12px;background:#0b0d10;border-bottom:1px solid #1c2330;flex-shrink:0;overflow-x:auto;align-items:center}.conf-thumb{position:relative;width:120px;min-width:120px;height:72px;border-radius:8px;overflow:hidden;background:#111;cursor:pointer;border:2px solid transparent;transition:border-color .15s;flex-shrink:0}.conf-thumb:hover{border-color:#2a3548}.conf-thumb.selected{border-color:#3b82f6}.conf-thumb.is-self{border-color:#3b82f644}.conf-thumb.is-self.selected{border-color:#3b82f6}.conf-thumb.is-screen{border-color:#f59e0b44}.conf-thumb.is-screen.selected{border-color:#f59e0b}.conf-thumb video{width:100%;height:100%;object-fit:cover;display:block}.conf-thumb-name{position:absolute;bottom:0;left:0;right:0;padding:2px 6px;background:#000000b3;font-size:10px;color:#e8eef7;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.conf-thumb-avatar{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:700;color:#6b7d99;background:#1c2330}.conf-thumb-muted{position:absolute;top:4px;right:4px;background:#ef4444d9;width:18px;height:18px;border-radius:50%;display:none;align-items:center;justify-content:center}.conf-thumb-muted svg{width:10px;height:10px}.role-badge{position:absolute;top:4px;left:4px;background:#3b82f6d9;padding:1px 6px;border-radius:4px;font-size:9px;color:#fff;font-weight:600;text-transform:uppercase}.conf-thumb-pin{position:absolute;top:4px;left:4px;background:#3b82f6d9;width:18px;height:18px;border-radius:50%;display:flex;align-items:center;justify-content:center}.conf-thumb-pin svg{width:10px;height:10px}.conf-thumb-host{position:absolute;bottom:0;right:4px;color:#f59e0b;display:flex;align-items:center;justify-content:center;padding-bottom:2px}.conf-thumb-host svg{width:12px;height:12px}.conf-thumb-menu-btn{position:absolute;top:4px;right:24px;background:#000000b3;border:none;color:#b9c7dd;width:20px;height:18px;border-radius:4px;cursor:pointer;display:none;align-items:center;justify-content:center;font-size:12px;font-weight:700;z-index:2;line-height:0;padding:0}.conf-thumb:hover .conf-thumb-menu-btn{display:flex}.conf-thumb-menu-btn:hover{background:#3b82f6b3;color:#fff}.conf-thumb-menu{position:absolute;top:24px;right:4px;background:#1c2330;border:1px solid #2a3548;border-radius:8px;overflow:hidden;z-index:5;min-width:100px;box-shadow:0 4px 12px #00000080}.conf-thumb-menu-item{display:block;width:100%;padding:8px 12px;background:none;border:none;color:#e8eef7;font-size:12px;cursor:pointer;text-align:left}.conf-thumb-menu-item:hover{background:#2a3548}.conf-thumb-menu-item.danger{color:#ef4444}.conf-thumb-menu-item.danger:hover{background:#3b1515}.conf-spotlight-wrap{flex:1;overflow:hidden;display:flex;align-items:center;justify-content:center;background:#000;position:relative}.conf-spotlight{width:100%;height:100%;position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden}.conf-spotlight video{width:100%;height:100%;object-fit:contain;display:block}.conf-spotlight-name{position:absolute;bottom:14px;left:16px;background:#000000b3;padding:5px 14px;border-radius:8px;font-size:14px;color:#e8eef7;font-weight:600;z-index:2;pointer-events:none}.conf-spotlight-role{font-size:11px;color:#93bbfc;font-weight:500;margin-left:8px}.conf-spotlight-avatar{width:120px;height:120px;border-radius:50%;background:#1c2330;display:flex;align-items:center;justify-content:center;font-size:48px;font-weight:700;color:#6b7d99}.conf-spotlight-muted{position:absolute;bottom:14px;right:16px;background:#ef4444d9;width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;z-index:2}.conf-spotlight-muted svg{width:16px;height:16px}.conf-fullscreen-btn{position:absolute;top:12px;right:16px;background:#0009;border:none;color:#b9c7dd;padding:8px;border-radius:8px;cursor:pointer;z-index:3;line-height:0}.conf-fullscreen-btn:hover{background:#3b82f699;color:#fff}.conf-fullscreen-btn svg{width:20px;height:20px}.conf-grid{flex:1;overflow-y:auto;padding:12px;display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:10px;background:#0b0d10}.conf-grid-tile{position:relative;border-radius:10px;overflow:hidden;background:#111;aspect-ratio:16/9;border:2px solid #1c2330}.conf-grid-tile video{width:100%;height:100%;object-fit:cover;display:block}.conf-grid-tile-name{position:absolute;bottom:0;left:0;right:0;padding:6px 10px;background:linear-gradient(transparent,#000c);font-size:13px;color:#e8eef7;font-weight:600;display:flex;align-items:center;gap:6px}.conf-grid-tile-name .role-badge{position:static;font-size:9px;padding:1px 6px}.conf-grid-tile-avatar{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:48px;font-weight:700;color:#6b7d99;background:#1c2330}.conf-grid-tile-muted{position:absolute;top:8px;right:8px;background:#ef4444d9;width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center}.conf-grid-tile-muted svg{width:12px;height:12px}.chat-panel{position:fixed;top:0;right:-340px;width:320px;height:100%;background:#0f141c;border-left:1px solid #1c2330;z-index:10;display:flex;flex-direction:column;transition:right .25s ease}.chat-panel{transition:right .2s ease}.chat-panel.open{right:0}.chat-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid #1c2330;flex-shrink:0}.chat-header-title{font-weight:700;font-size:15px}.chat-close-btn{background:none;border:none;color:#6b7d99;cursor:pointer;padding:4px;line-height:0}.chat-close-btn:hover{color:#e8eef7}.chat-close-btn svg{width:18px;height:18px}.chat-messages{flex:1;overflow-y:auto;padding:12px 16px;display:flex;flex-direction:column;gap:10px}.chat-msg{display:flex;flex-direction:column;gap:2px}.chat-msg-header{display:flex;align-items:center;gap:6px;font-size:12px}.chat-msg-name{font-weight:700;color:#93bbfc}.chat-msg-role{background:#3b82f64d;padding:0 5px;border-radius:3px;font-size:10px;color:#93bbfc;font-weight:600;text-transform:uppercase}.chat-msg-time{color:#4a5568;font-size:10px;margin-left:auto}.chat-msg-text{font-size:13px;color:#d1dae8;line-height:1.4;word-wrap:break-word}.chat-input-wrap{padding:12px 16px;border-top:1px solid #1c2330;display:flex;gap:8px;flex-shrink:0;align-items:flex-end}.chat-input{flex:1;padding:10px 12px;background:#0b0d10;border:1px solid #1c2330;border-radius:8px;color:#e8eef7;font-size:13px;outline:none;resize:none;min-height:36px;max-height:120px;overflow-y:auto;line-height:1.4;font-family:inherit}.chat-input:focus{border-color:#3b82f6}.chat-send-btn{background:#3b82f6;border:none;color:#fff;padding:0 14px;border-radius:8px;cursor:pointer;font-size:13px;font-weight:600}.chat-send-btn:hover{background:#2563eb}.chat-attach-btn{background:none;border:none;color:#6b7d99;cursor:pointer;font-size:16px;padding:4px 6px;line-height:1;flex-shrink:0}.chat-attach-btn:hover{color:#e8eef7}.chat-file-card{background:#1c2330;border:1px solid #2a3548;border-radius:8px;padding:8px 12px;margin-top:4px;font-size:12px}.chat-file-card a{color:#93bbfc;text-decoration:none}.chat-file-card a:hover{text-decoration:underline}.chat-file-size{color:#6b7d99;font-size:11px;margin-left:6px}.chat-image-card{border-top:1px solid #1c2330;border-bottom:1px solid #1c2330;margin-top:6px;padding:8px 0;text-align:center}.chat-file-thumb{max-width:200px;max-height:140px;border-radius:6px;cursor:pointer;display:inline-block;object-fit:contain}.chat-file-thumb:hover{opacity:.85}.chat-image-footer{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:6px;font-size:11px;color:#6b7d99}.chat-image-dl{background:none;border:none;color:#6b7d99;cursor:pointer;padding:2px;line-height:1;display:flex;align-items:center}.chat-image-dl:hover{color:#93bbfc}.chat-image-dl svg{width:14px;height:14px}.chat-image-popup{position:fixed;inset:0;background:#000000e6;z-index:500;display:flex;align-items:center;justify-content:center}.chat-image-popup img{max-width:90%;max-height:85%;border-radius:8px;object-fit:contain}.chat-image-popup-close{position:absolute;top:16px;right:20px;background:#ffffff26;border:none;color:#fff;width:36px;height:36px;border-radius:50%;font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center}.chat-image-popup-close:hover{background:#ffffff4d}.chat-image-popup-dl{position:absolute;bottom:20px;right:20px;background:#ffffff26;border:none;color:#fff;padding:8px 16px;border-radius:8px;font-size:13px;cursor:pointer;display:flex;align-items:center;gap:6px;text-decoration:none}.chat-image-popup-dl:hover{background:#ffffff4d}.chat-image-popup-dl svg{width:16px;height:16px}.chat-badge{position:absolute;top:-4px;right:-4px;background:#ef4444;color:#fff;font-size:10px;font-weight:700;min-width:18px;height:18px;border-radius:9px;display:flex;align-items:center;justify-content:center;padding:0 4px}.conf-toast{position:fixed;top:60px;left:50%;transform:translate(-50%);background:#1c2330;border:1px solid #2a3548;padding:10px 20px;border-radius:10px;font-size:13px;color:#e8eef7;z-index:20;pointer-events:none;animation:toastIn .3s ease,toastOut .3s ease 2.7s forwards}@keyframes toastIn{0%{opacity:0;transform:translate(-50%) translateY(-10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@keyframes toastOut{0%{opacity:1}to{opacity:0}}.conf-controls{display:flex;align-items:center;justify-content:center;gap:12px;padding:14px 16px;background:#0f141c;border-top:1px solid #1c2330;flex-shrink:0}.conf-ctrl-wrap{display:flex;flex-direction:column;align-items:center;position:relative}.conf-ctrl-btn{width:48px;height:48px;border-radius:50%;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.conf-ctrl-btn svg{width:22px;height:22px}.conf-ctrl-btn.active{background:#1c2330;color:#e8eef7}.conf-ctrl-btn.active:hover{background:#2a3548}.conf-ctrl-btn.muted-state{background:#ef4444;color:#fff}.conf-ctrl-btn.muted-state:hover{background:#dc2626}.conf-ctrl-btn.leave{background:#ef4444;color:#fff;width:56px;height:48px;border-radius:24px}.conf-ctrl-btn.leave:hover{background:#dc2626}.conf-ctrl-btn.screen-active{background:#3b82f6;color:#fff}.conf-ctrl-btn.recording{background:#ef4444;color:#fff;animation:recPulse 1.5s ease infinite}@keyframes recPulse{0%,to{opacity:1}50%{opacity:.6}}.conf-ctrl-btn.chat-active{background:#3b82f6;color:#fff}.conf-ctrl-label{font-size:10px;color:#6b7d99;text-align:center;margin-top:4px}.reactions-popup{position:absolute;bottom:60px;left:50%;transform:translate(-50%);background:#1c2330;border:1px solid #2a3548;border-radius:12px;padding:8px;display:flex;gap:4px;z-index:20}.reactions-popup button{background:none;border:none;font-size:24px;cursor:pointer;padding:6px 8px;border-radius:8px;transition:background .15s}.reactions-popup button:hover{background:#2a3548}.reaction-float{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:32px;pointer-events:none;z-index:10;animation:reactionFloat 2.5s ease forwards}@keyframes reactionFloat{0%{opacity:1;transform:translate(-50%,-50%)}to{opacity:0;transform:translate(-50%,-100%)}}.conf-ctrl-btn.hand-raised{background:#f59e0b;color:#fff}.conf-ctrl-btn.hand-raised:hover{background:#d97706}.thumb-hand{position:absolute;top:4px;left:4px;font-size:14px;z-index:5}.grid-tile-hand{position:absolute;top:8px;left:8px;font-size:18px;z-index:5}.spotlight-hand-badge{position:absolute;bottom:14px;left:50%;transform:translate(-50%);background:#f59e0be6;padding:5px 14px;border-radius:8px;font-size:13px;color:#fff;font-weight:600;z-index:2;pointer-events:none}.waiting-spinner{width:40px;height:40px;border:4px solid #1c2330;border-top-color:#22c55e;border-radius:50%;animation:waitSpin .8s linear infinite;margin:0 auto}@keyframes waitSpin{to{transform:rotate(360deg)}}#passcodeGroup{margin-top:10px}#passcodeGroup input{text-align:center;font-size:18px!important;letter-spacing:4px;font-weight:600}.polls-panel{position:fixed;top:0;right:-340px;width:320px;height:100%;background:#0f141c;border-left:1px solid #1c2330;z-index:10;display:flex;flex-direction:column;transition:right .25s ease}.polls-panel{transition:right .2s ease}.polls-panel.open{right:0}.polls-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid #1c2330;flex-shrink:0}.polls-header-title{font-weight:700;font-size:15px}.polls-close-btn{background:none;border:none;color:#6b7d99;cursor:pointer;padding:4px;line-height:0}.polls-close-btn:hover{color:#e8eef7}.polls-close-btn svg{width:18px;height:18px}.polls-body{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:12px}.polls-empty{color:#6b7d99;font-size:13px;text-align:center;margin-top:40px}.poll-create-form{display:flex;flex-direction:column;gap:10px}.poll-create-form input{width:100%;padding:10px 12px;background:#0b0d10;border:1px solid #1c2330;border-radius:8px;color:#e8eef7;font-size:13px;outline:none}.poll-create-form input:focus{border-color:#3b82f6}.poll-create-form input::placeholder{color:#4a5568}.poll-add-option-btn{background:none;border:1px dashed #2a3548;color:#6b7d99;padding:8px;border-radius:8px;cursor:pointer;font-size:12px}.poll-add-option-btn:hover{border-color:#3b82f6;color:#93bbfc}.poll-launch-btn{background:#3b82f6;border:none;color:#fff;padding:10px;border-radius:8px;cursor:pointer;font-size:13px;font-weight:600}.poll-launch-btn:hover{background:#2563eb}.poll-launch-btn:disabled{opacity:.5;cursor:not-allowed}.poll-card{background:#1c2330;border-radius:10px;padding:14px}.poll-card-question{font-size:14px;font-weight:600;margin-bottom:10px}.poll-card-option{display:flex;align-items:center;gap:8px;margin-bottom:6px;font-size:13px}.poll-card-bar-wrap{flex:1;height:24px;background:#0b0d10;border-radius:6px;overflow:hidden;position:relative}.poll-card-bar{height:100%;background:#3b82f6;border-radius:6px;transition:width .3s ease;min-width:0}.poll-card-bar-label{position:absolute;top:0;left:8px;line-height:24px;font-size:12px;color:#e8eef7;font-weight:500;white-space:nowrap}.poll-card-count{font-size:12px;color:#6b7d99;min-width:30px;text-align:right}.poll-card-status{font-size:11px;color:#6b7d99;margin-top:8px}.poll-end-btn{background:#ef4444;border:none;color:#fff;padding:6px 14px;border-radius:6px;cursor:pointer;font-size:12px;font-weight:600;margin-top:8px}.poll-end-btn:hover{background:#dc2626}.poll-vote-overlay{position:fixed;bottom:80px;left:50%;transform:translate(-50%);background:#1c2330;border:1px solid #2a3548;border-radius:14px;padding:20px 24px;z-index:15;width:320px;max-width:90vw;box-shadow:0 8px 24px #00000080;animation:toastIn .3s ease}.poll-vote-question{font-size:15px;font-weight:700;margin-bottom:14px;text-align:center}.poll-vote-options{display:flex;flex-direction:column;gap:8px}.poll-vote-btn{width:100%;padding:12px;background:#0b0d10;border:1px solid #2a3548;border-radius:10px;color:#e8eef7;font-size:14px;font-weight:600;cursor:pointer;transition:all .15s}.poll-vote-btn:hover{border-color:#3b82f6;background:#111827}.poll-vote-btn.voted{background:#3b82f6;border-color:#3b82f6;color:#fff;pointer-events:none}@media(max-width:700px){.join-card{padding:24px 20px}.conf-thumb{width:90px;min-width:90px;height:54px}.conf-header{flex-wrap:wrap;gap:6px;padding:8px 12px}.conf-header-left{flex-wrap:wrap;gap:6px;min-width:0}.conf-header-right{flex-wrap:wrap;gap:6px}.conf-room-name{font-size:13px}.conf-header-btn{padding:4px 8px;font-size:11px}.conf-controls{flex-wrap:wrap;gap:6px;padding:8px 10px}.conf-ctrl-btn{width:40px;height:40px}.conf-ctrl-btn svg{width:18px;height:18px}.conf-ctrl-btn.leave{width:48px;height:40px}.conf-ctrl-label{font-size:9px;margin-top:2px}.field-row{flex-direction:column;gap:0}.chat-panel,.polls-panel{width:280px;right:-300px}.conf-view.panel-open{margin-right:280px}.conf-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));padding:8px;gap:6px}}.upcoming-card{background:#0f141c;border:1px solid #1c2330;border-radius:10px;padding:10px 14px;margin-bottom:6px;cursor:pointer;transition:border-color .15s}.upcoming-card:hover{border-color:#22c55e}.caption-overlay{position:absolute;bottom:60px;left:50%;transform:translate(-50%);max-width:80%;text-align:center;z-index:5;pointer-events:none}.caption-line{background:#000c;color:#fff;padding:6px 16px;border-radius:6px;font-size:16px;display:inline-block}.caption-input-bar{display:flex;gap:8px;padding:8px 16px;background:#0f141c;border-top:1px solid #1c2330;flex-shrink:0}.caption-input-bar input{flex:1;padding:8px 12px;background:#0b0d10;border:1px solid #1c2330;border-radius:8px;color:#e8eef7;font-size:13px}.caption-input-bar input:focus{border-color:#3b82f6;outline:none}.caption-input-bar button{padding:8px 16px;background:#3b82f6;border:none;border-radius:8px;color:#fff;font-size:13px;cursor:pointer}.breakout-toast{background:#f59e0b;color:#000}
