:root{--bg: #1f1f1f;--surface: #242424;--surface-2: #2e2e2e;--surface-3: #383838;--border: #404040;--text: #f0f0f0;--text-2: #b8b8b8;--muted: #888;--primary: #0e71eb;--primary-h: #1280f5;--danger: #e34234;--green: #5cb85c;--amber: #f5a623;--radius: 8px;--radius-lg: 12px;--ctrl-h: 64px;--head-h: 54px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{background:var(--bg);color:var(--text);font-family:-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;font-size:14px;line-height:1.4;-webkit-font-smoothing:antialiased}button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}a{color:var(--primary);text-decoration:none}input,select,textarea{font-family:inherit;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-size:14px;outline:none}input:focus,select:focus,textarea:focus{border-color:var(--primary);box-shadow:0 0 0 2px #0e71eb40}.muted{color:var(--muted)}.muted-2{color:var(--text-2)}.danger{color:var(--danger)}.green{color:var(--green)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 16px;border-radius:var(--radius);font-size:14px;font-weight:600;transition:background .12s,opacity .12s;border:1px solid var(--border);background:var(--surface-2);color:var(--text)}.btn:hover{background:var(--surface-3)}.btn:active{opacity:.85}.btn:disabled{opacity:.45;cursor:default;pointer-events:none}.btn-primary{background:var(--primary);border-color:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-h)}.btn-danger{background:var(--danger);border-color:var(--danger);color:#fff}.btn-danger:hover{background:#c53726}.btn-ghost{background:transparent;border-color:transparent}.btn-ghost:hover{background:var(--surface-2)}.btn-sm{padding:5px 12px;font-size:13px}.btn-block{width:100%}.btn-icon{width:32px;height:32px;padding:0;border-radius:6px;display:inline-flex;align-items:center;justify-content:center;font-size:16px;background:none;border:none;color:var(--text-2)}.btn-icon:hover{background:var(--surface-2);color:var(--text)}.field{display:flex;flex-direction:column;gap:5px}.field label,.field-label{font-size:13px;color:var(--text-2);font-weight:500}.field input,.field select,.field textarea{padding:9px 12px;width:100%}.field textarea{resize:vertical;min-height:80px}.field-hint{font-size:12px;color:var(--muted)}.form-error{color:var(--danger);font-size:13px;margin-top:4px}.divider{display:flex;align-items:center;gap:12px;color:var(--muted);font-size:13px}.divider:before,.divider:after{content:"";flex:1;height:1px;background:var(--border)}.spinner{width:36px;height:36px;border-radius:50%;border:3px solid var(--border);border-top-color:var(--primary);animation:spin .8s linear infinite}.spinner-sm{width:18px;height:18px;border-width:2px}@keyframes spin{to{transform:rotate(360deg)}}.home{min-height:100%;display:grid;place-items:center;padding:24px;background:radial-gradient(ellipse at 30% 20%,#1c2d4a 0%,var(--bg) 55%)}.home-card{width:100%;max-width:400px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:32px;box-shadow:0 24px 64px #00000080}.home-logo{display:flex;align-items:center;gap:10px;margin-bottom:24px}.home-logo-icon{width:40px;height:40px;border-radius:10px;background:var(--primary);display:grid;place-items:center;font-size:22px}.home-logo-text{font-size:22px;font-weight:700}.home-logo-text span{color:var(--primary)}.home-actions{display:flex;gap:10px;margin-bottom:24px}.home-actions .btn{flex:1;padding:12px;font-size:14px}.home-nav{display:flex;justify-content:flex-end;margin-bottom:20px}.dashboard{min-height:100%;display:flex;flex-direction:column}.dash-head{display:flex;justify-content:space-between;align-items:center;padding:0 24px;height:var(--head-h);background:var(--surface);border-bottom:1px solid var(--border)}.dash-logo{display:flex;align-items:center;gap:8px;font-weight:700;font-size:16px}.dash-logo-icon{width:28px;height:28px;border-radius:6px;background:var(--primary);display:grid;place-items:center;font-size:16px}.dash-user{display:flex;align-items:center;gap:12px}.dash-avatar{width:34px;height:34px;border-radius:50%;background:var(--primary);display:grid;place-items:center;font-size:13px;font-weight:700;color:#fff}.dash-body{flex:1;display:grid;grid-template-columns:380px 1fr;gap:0;max-width:1200px;width:100%;margin:0 auto;padding:28px 24px;gap:28px}.dash-col{display:flex;flex-direction:column;gap:20px}.dash-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.dash-section-head{padding:16px 20px;border-bottom:1px solid var(--border);font-size:15px;font-weight:600;display:flex;justify-content:space-between;align-items:center}.dash-section-body{padding:20px;display:flex;flex-direction:column;gap:14px}.meeting-card{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;display:flex;align-items:center;gap:14px}.meeting-card-icon{font-size:24px}.meeting-card-info{flex:1;min-width:0}.meeting-card-title{font-weight:600;font-size:14px;margin-bottom:3px}.meeting-card-meta{font-size:12px;color:var(--text-2)}.meeting-card-actions{display:flex;gap:6px;flex-shrink:0}.badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:999px;font-size:11px;font-weight:600}.badge-blue{background:#0e71eb33;color:#5a9cf5;border:1px solid rgba(14,113,235,.3)}.badge-green{background:#5cb85c33;color:#7ec97e;border:1px solid rgba(92,184,92,.3)}.badge-amber{background:#f5a62333;color:#f5c35a;border:1px solid rgba(245,166,35,.3)}@media (max-width: 760px){.dash-body{grid-template-columns:1fr}}.prejoin{min-height:100%;display:grid;place-items:center;padding:24px;background:radial-gradient(ellipse at 30% 20%,#1c2d4a 0%,var(--bg) 55%)}.prejoin-card{width:100%;max-width:520px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:28px;box-shadow:0 24px 64px #00000080}.prejoin-title{font-size:20px;font-weight:700;margin-bottom:20px;text-align:center}.prejoin-preview{aspect-ratio:16/9;background:#111;border-radius:var(--radius);overflow:hidden;margin-bottom:20px;position:relative;display:grid;place-items:center}.prejoin-preview video{width:100%;height:100%;object-fit:cover;transform:scaleX(-1)}.prejoin-avatar-wrap{display:flex;flex-direction:column;align-items:center;gap:10px}.prejoin-avatar{width:80px;height:80px;border-radius:50%;background:var(--primary);display:grid;place-items:center;font-size:28px;font-weight:700;color:#fff}.prejoin-name-label{font-size:16px;font-weight:600}.prejoin-toggles{display:flex;gap:12px;margin-bottom:20px;justify-content:center}.prejoin-toggle{display:flex;flex-direction:column;align-items:center;gap:4px;padding:12px 20px;border:1.5px solid var(--border);border-radius:10px;background:var(--surface-2);color:var(--text);font-size:13px;font-weight:600;min-width:110px;transition:border-color .15s,background .15s}.prejoin-toggle:hover{background:var(--surface-3)}.prejoin-toggle.off{border-color:var(--danger);color:var(--danger)}.prejoin-toggle-icon{font-size:22px}.prejoin-hint{font-size:12px;color:var(--muted);text-align:center;margin-top:12px}.room{height:100%;display:flex;flex-direction:column;background:var(--bg);overflow:hidden}.room-head{height:var(--head-h);flex-shrink:0;display:flex;align-items:center;justify-content:space-between;padding:0 16px;background:var(--surface);border-bottom:1px solid var(--border);z-index:10}.room-head-left,.room-head-right{display:flex;align-items:center;gap:10px}.room-title{font-size:15px;font-weight:600}.room-id{font-size:12px;color:var(--muted);font-variant-numeric:tabular-nums;letter-spacing:.5px;background:var(--surface-2);padding:3px 8px;border-radius:5px;border:1px solid var(--border)}.room-copy-btn{font-size:12px;color:var(--primary)}.room-copy-btn:hover{text-decoration:underline}.rec-badge{display:inline-flex;align-items:center;gap:4px;background:var(--danger);color:#fff;font-size:11px;font-weight:700;padding:3px 8px;border-radius:5px;animation:pulse 1.5s infinite}.rec-audio-info{font-weight:600;opacity:.85;font-size:10px}.rec-badge-peer{background:var(--danger)}.lock-badge{font-size:13px;color:var(--amber);font-weight:600}.waiting-pill{background:var(--primary);color:#fff;border:none;border-radius:999px;padding:4px 12px;font-size:12px;font-weight:600;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.65}}.view-toggle{display:flex;background:var(--surface-2);border-radius:7px;padding:2px;gap:2px}.view-seg{padding:5px 12px;border-radius:5px;font-size:12px;font-weight:600;color:var(--text-2);background:none;border:none;transition:background .12s,color .12s}.view-seg.active{background:var(--surface-3);color:var(--text)}.room-count{font-size:13px;color:var(--text-2)}.breakout-banner{flex-shrink:0;display:flex;align-items:center;justify-content:center;gap:10px;padding:8px 16px;flex-wrap:wrap;background:#2a1f3d;color:#d4bbff;border-bottom:1px solid #4a3a6a;font-size:13px}.breakout-banner select{padding:4px 8px;font-size:13px;border-radius:6px}.breakout-mini-btn{padding:4px 10px;border-radius:6px;font-size:12px;font-weight:600;background:#ffffff1a;color:inherit;border:1px solid rgba(255,255,255,.2)}.breakout-mini-btn:hover{background:#fff3}.stage{flex:1;display:flex;min-height:0;overflow:hidden;position:relative}.grid{flex:1;display:grid;gap:8px;padding:12px;align-content:center;min-height:0;overflow:hidden}.speaker-layout{flex:1;display:flex;flex-direction:column;padding:12px;gap:8px;min-height:0}.speaker-main{flex:1;min-height:0;display:flex;justify-content:center}.speaker-main .tile{width:100%;max-width:1200px}.filmstrip{height:116px;flex-shrink:0;display:flex;gap:8px;overflow-x:auto;padding-bottom:2px}.filmstrip .tile{width:calc(116px * 16/9);height:108px;flex-shrink:0}.filmstrip::-webkit-scrollbar{height:4px}.filmstrip::-webkit-scrollbar-thumb{background:var(--surface-3);border-radius:2px}.tile{position:relative;background:#111;border-radius:var(--radius);overflow:hidden;aspect-ratio:16/9;min-height:0;border:2px solid transparent;transition:border-color .15s}.tile-active{border-color:#57c970}.tile-pinned{border-color:var(--primary)}.tile-hand{border-color:var(--amber)}.tile video{width:100%;height:100%;object-fit:cover}.tile video.hidden{display:none}.avatar{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;background:linear-gradient(135deg,#2e3a52,#1e2530)}.avatar-circle{width:64px;height:64px;border-radius:50%;background:var(--primary);display:grid;place-items:center;font-size:22px;font-weight:700;color:#fff}.tile-label{position:absolute;left:0;right:0;bottom:0;display:flex;justify-content:space-between;align-items:center;padding:22px 8px 6px;background:linear-gradient(transparent,#000000b8);font-size:12px;font-weight:600;pointer-events:none}.tile-name{color:#fff;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tile-status-icons{display:flex;gap:5px;align-items:center}.tile-status-icons .ico{width:20px;height:20px;border-radius:4px;display:grid;place-items:center;font-size:12px}.ico-muted{background:var(--danger)}.tile-top{position:absolute;top:6px;left:6px;right:6px;display:flex;justify-content:space-between;align-items:flex-start;pointer-events:none}.tile-top .pin-btn{pointer-events:auto}.tile-badges{display:flex;gap:4px}.tile-badge{font-size:11px;font-weight:600;color:#fff;background:#0009;padding:2px 6px;border-radius:5px;pointer-events:none}.tile-badge-blue{background:var(--primary)}.tile-badge-amber{background:var(--amber);color:#000}.reaction-bubble{position:absolute;left:50%;bottom:34px;transform:translate(-50%);font-size:40px;z-index:5;pointer-events:none;animation:rfloat 3.8s ease-out forwards}@keyframes rfloat{0%{opacity:0;transform:translate(-50%,8px) scale(.5)}12%{opacity:1;transform:translate(-50%) scale(1.1)}25%{transform:translate(-50%,-4px) scale(1)}80%{opacity:1;transform:translate(-50%,-36px) scale(1)}to{opacity:0;transform:translate(-50%,-64px) scale(.9)}}.pin-btn{padding:3px 6px;border-radius:5px;font-size:12px;background:#0000008c;color:#fff;opacity:0;transition:opacity .15s}.tile:hover .pin-btn{opacity:1}.pin-btn.pinned{opacity:1;background:var(--primary)}.quality{display:inline-flex;align-items:flex-end;gap:2px;height:13px;background:#00000080;padding:2px 4px;border-radius:4px}.quality .bar{width:3px;background:#ffffff40;border-radius:1px}.quality .bar:nth-child(1){height:4px}.quality .bar:nth-child(2){height:7px}.quality .bar:nth-child(3){height:10px}.quality-good .bar.on{background:#57c970}.quality-fair .bar.on{background:var(--amber)}.quality-poor .bar.on{background:var(--danger)}.controls{height:var(--ctrl-h);flex-shrink:0;display:flex;align-items:center;justify-content:center;gap:2px;padding:0 12px;background:var(--surface);border-top:1px solid var(--border);position:relative;z-index:20}.controls-right{position:absolute;right:12px;top:50%;transform:translateY(-50%);display:flex;gap:6px}.ctrl{display:flex;flex-direction:column;align-items:center;gap:2px;min-width:70px;padding:6px 8px;border-radius:var(--radius);background:none;border:none;color:var(--text);font-size:11px;font-weight:500;transition:background .12s;position:relative}.ctrl:hover{background:var(--surface-2)}.ctrl-icon{font-size:22px;line-height:1}.ctrl.off{color:var(--danger)}.ctrl.active{color:var(--primary)}.ctrl.active .ctrl-icon-bg{background:#0e71eb26;border-radius:8px;padding:2px 4px}.ctrl-split{display:flex;align-items:center}.ctrl-caret{width:18px;height:100%;display:flex;align-items:center;justify-content:center;font-size:8px;color:var(--text-2);border-left:1px solid var(--border);padding-left:2px;margin-left:2px}.ctrl-caret:hover{color:var(--text)}.ctrl-leave{padding:9px 18px;border-radius:var(--radius);font-size:13px;font-weight:600;background:var(--danger);color:#fff;min-width:auto;flex-direction:row;gap:6px}.ctrl-leave:hover{background:#c53726}.ctrl-leave .ctrl-icon{font-size:16px}.ctrl-popover-wrap{position:relative;display:inline-flex}.reaction-bar{position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);display:flex;gap:3px;padding:8px 10px;background:var(--surface);border:1px solid var(--border);border-radius:999px;box-shadow:0 8px 24px #00000080;z-index:50;white-space:nowrap}.reaction-pick{font-size:22px;line-height:1;padding:5px;border-radius:8px;transition:transform .1s}.reaction-pick:hover{transform:scale(1.3);background:var(--surface-2)}.more-menu{position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 8px 24px #00000080;z-index:50;min-width:200px;overflow:hidden}.more-menu-item{display:flex;align-items:center;gap:10px;width:100%;padding:11px 16px;font-size:14px;color:var(--text);background:none;border:none;text-align:left;transition:background .1s}.more-menu-item:hover{background:var(--surface-2)}.more-menu-item+.more-menu-item{border-top:1px solid var(--border)}.more-menu-item .ico{font-size:16px;width:20px;text-align:center;color:var(--text-2)}.panel{width:320px;flex-shrink:0;background:var(--surface);border-left:1px solid var(--border);display:flex;flex-direction:column}.panel-head{height:52px;display:flex;align-items:center;justify-content:space-between;padding:0 16px;border-bottom:1px solid var(--border);flex-shrink:0}.panel-head h3{font-size:15px;font-weight:600}.panel-body{flex:1;overflow-y:auto;padding:12px 14px;display:flex;flex-direction:column;gap:0}.panel-body::-webkit-scrollbar{width:4px}.panel-body::-webkit-scrollbar-thumb{background:var(--surface-3);border-radius:2px}.panel-foot{padding:10px 12px;border-top:1px solid var(--border);flex-shrink:0;display:flex;gap:8px}.section-label{font-size:11px;text-transform:uppercase;letter-spacing:.6px;color:var(--muted);font-weight:600;margin:14px 0 8px}.section-label:first-child{margin-top:4px}.chat-messages{flex:1;display:flex;flex-direction:column;gap:2px}.msg{padding:6px 0}.msg-meta{display:flex;gap:8px;align-items:baseline;margin-bottom:3px}.msg-name{font-size:13px;font-weight:600;color:var(--text)}.msg-time{font-size:11px;color:var(--muted)}.msg-private-tag{font-size:11px;color:var(--primary);font-style:italic}.msg-bubble{display:inline-block;max-width:100%;word-break:break-word;padding:7px 10px;border-radius:10px;font-size:13px;line-height:1.4;background:var(--surface-2)}.msg.msg-self .msg-bubble{background:var(--primary);color:#fff}.chat-input-area{display:flex;flex-direction:column;gap:8px}.chat-to{width:100%;padding:7px 10px}.chat-input-row{display:flex;gap:8px}.chat-input-row input{flex:1;padding:8px 10px}.participant-row{display:flex;align-items:center;gap:8px;padding:8px 0;border-bottom:1px solid var(--border)}.participant-row:last-child{border-bottom:none}.participant-avatar{width:32px;height:32px;border-radius:50%;background:var(--surface-3);display:grid;place-items:center;font-size:12px;font-weight:700;color:var(--text-2);flex-shrink:0}.participant-info{flex:1;min-width:0}.participant-name{font-size:13px;font-weight:500}.participant-role{font-size:11px;color:var(--muted)}.participant-icons{display:flex;gap:5px;align-items:center;flex-shrink:0}.p-icon{font-size:14px;opacity:.5}.p-icon.active{opacity:1}.p-icon.muted-icon{color:var(--danger)}.row-actions{display:flex;gap:4px}.stat{position:relative;display:inline-block;font-size:15px;line-height:1}.stat.off{opacity:.45}.stat.off:after{content:"";position:absolute;left:-2px;right:-2px;top:50%;border-top:2px solid var(--danger);transform:rotate(-20deg)}.host-controls{background:var(--surface-2);border-radius:var(--radius);padding:10px 12px;margin-bottom:12px;display:flex;flex-direction:column;gap:6px}.toggle-row{display:flex;justify-content:space-between;align-items:center;padding:6px 0;font-size:13px}.toggle-row input[type=checkbox]{width:16px;height:16px;accent-color:var(--primary)}.waiting-section{background:#0e71eb1a;border:1px solid rgba(14,113,235,.3);border-radius:var(--radius);padding:10px 12px;margin-bottom:10px}.mini-btn{padding:4px 9px;border-radius:5px;font-size:12px;font-weight:600;border:1px solid var(--border);background:var(--surface-2);color:var(--text)}.mini-btn-primary{background:var(--primary);border-color:var(--primary);color:#fff}.mini-btn-primary:hover{background:var(--primary-h)}.mini-btn-danger{color:var(--danger)}.mini-btn-danger:hover{background:var(--danger);color:#fff;border-color:var(--danger)}.mini-btn-block{width:100%;margin-bottom:6px;text-align:center;padding:7px 9px}.poll-form{background:var(--surface-2);border-radius:var(--radius);padding:12px;margin-bottom:14px;display:flex;flex-direction:column;gap:8px}.poll-input{width:100%;padding:8px 10px}.poll-form-actions{display:flex;gap:6px;flex-wrap:wrap}.poll-card{background:var(--surface-2);border-radius:var(--radius);padding:12px;margin-bottom:10px}.poll-q{font-weight:600;font-size:14px;margin-bottom:10px}.poll-closed-tag{color:var(--muted);font-weight:400;font-size:12px}.poll-option{position:relative;display:flex;align-items:center;justify-content:space-between;width:100%;padding:8px 10px;margin-bottom:5px;overflow:hidden;background:var(--surface);border:1px solid var(--border);border-radius:6px;color:var(--text);font-size:13px;text-align:left}.poll-option:disabled{cursor:default}.poll-option.voted{border-color:var(--primary)}.poll-bar{position:absolute;left:0;top:0;bottom:0;background:#0e71eb33;transition:width .3s;z-index:0}.poll-option-label,.poll-pct{position:relative;z-index:1}.poll-pct{color:var(--muted);font-size:12px;white-space:nowrap;padding-left:6px}.poll-meta{display:flex;justify-content:space-between;align-items:center;margin-top:8px}.bg-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;margin-top:6px}.bg-option{padding:8px 6px;border:2px solid var(--border);border-radius:7px;background:var(--surface-2);color:var(--text);font-size:12px;font-weight:600;text-align:center;min-height:44px;display:flex;align-items:center;justify-content:center}.bg-option.active{border-color:var(--primary)}.breakout-create{display:flex;flex-direction:column;gap:12px}.breakout-create input{padding:8px 10px;width:100%}.breakout-actions{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.breakout-actions input{padding:7px 10px;width:100%}.breakout-room-item{margin-bottom:10px}.breakout-room-title{display:flex;align-items:center;gap:8px;margin-bottom:6px}.breakout-name-input{flex:1;padding:4px 8px;font-size:13px;font-weight:600;background:var(--surface);border:1px solid var(--border);border-radius:5px;color:var(--text)}.breakout-name-input:focus{border-color:var(--primary)}.breakout-select{padding:4px 7px;border-radius:5px;font-size:12px;max-width:46%}.breakout-member{display:flex;align-items:center;justify-content:space-between;padding:5px 0;border-bottom:1px solid var(--border);font-size:13px;gap:6px}.breakout-member:last-child{border-bottom:none}.help-alert{background:#f5a6231a;border:1px solid rgba(245,166,35,.4);border-radius:var(--radius);padding:8px 12px;margin-bottom:10px}.bm-head{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--border);flex-shrink:0}.bm-title{font-size:15px;font-weight:600}.bm-foot{display:flex;gap:8px;justify-content:flex-end;flex-wrap:wrap;padding:10px 14px;border-top:1px solid var(--border);flex-shrink:0}.bm-room-item{border-bottom:1px solid var(--border)}.bm-room-item:last-child{border-bottom:none}.bm-room-row{display:flex;align-items:center;gap:8px;padding:10px 14px;cursor:pointer;transition:background .1s;-webkit-user-select:none;user-select:none}.bm-room-row:hover{background:var(--surface-2)}.bm-caret{font-size:9px;color:var(--muted);width:10px;flex-shrink:0}.bm-rname{flex:1;font-size:14px;font-weight:500}.bm-count{font-size:12px;color:var(--muted);display:flex;align-items:center;gap:3px}.bm-joined{font-size:12px;font-weight:600;color:var(--primary);padding:2px 8px;border:1px solid var(--primary);border-radius:999px}.bm-join-btn{padding:4px 14px;border-radius:6px;font-size:13px;font-weight:600;background:var(--primary);color:#fff;border:none}.bm-join-btn:hover{background:var(--primary-h)}.bm-member-list{list-style:none;padding:0 14px 8px 30px}.bm-member{display:flex;align-items:center;gap:8px;padding:3px 0;font-size:13px}.bm-dot{width:8px;height:8px;border-radius:50%;background:var(--green);flex-shrink:0}.bm-empty{padding:4px 0;font-size:13px;color:var(--muted)}.breakout-popup{position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 8px 28px #00000080;min-width:190px;overflow:hidden;z-index:100}.breakout-popup-item{display:flex;align-items:center;gap:10px;width:100%;padding:11px 16px;font-size:14px;color:var(--text);background:none;border:none;text-align:left}.whiteboard{position:absolute;top:0;right:0;bottom:0;left:0;z-index:20;display:flex;flex-direction:column;background:var(--surface)}.wb-toolbar{display:flex;align-items:center;gap:12px;padding:9px 14px;background:var(--surface-2);border-bottom:1px solid var(--border);flex-wrap:wrap;flex-shrink:0}.wb-title{font-weight:600;font-size:14px}.wb-colors{display:flex;gap:5px}.wb-color{width:20px;height:20px;border-radius:50%;border:2px solid transparent;cursor:pointer}.wb-color.active{border-color:var(--primary);box-shadow:0 0 0 2px var(--surface-2),0 0 0 4px var(--primary)}.wb-width{width:90px;accent-color:var(--primary)}.wb-surface{flex:1;min-height:0;position:relative;background:#1e1e22}.wb-canvas{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;touch-action:none;cursor:crosshair}.countdown{font-weight:700;color:#f5c35a;font-variant-numeric:tabular-nums}.room-cover{height:100%;display:grid;place-content:center;justify-items:center;gap:16px;text-align:center;padding:24px}.room-cover h2{font-size:20px;font-weight:600}.waiting-card,.connecting-card{display:flex;flex-direction:column;align-items:center;gap:14px;text-align:center}.waiting-card p,.connecting-card p{color:var(--text-2);font-size:14px}.notice-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;display:grid;place-items:center;background:#0009}.notice-modal{width:100%;max-width:400px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;box-shadow:0 20px 60px #00000080;display:flex;flex-direction:column;gap:12px}.notice-modal h3{font-size:17px;font-weight:600}.notice-modal .btn{align-self:flex-end;margin-top:4px}.dashboard{min-height:100%;display:flex;flex-direction:column;background:radial-gradient(ellipse at 30% -10%,#1c2d4a 0%,var(--bg) 55%)}.dash-head{height:var(--head-h);flex-shrink:0;display:flex;align-items:center;justify-content:space-between;padding:0 24px;border-bottom:1px solid var(--border);background:#1f1f1fb3;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.dash-head .room-info strong{font-size:16px;font-weight:600}.dash-user{display:flex;align-items:center;gap:16px}.link-btn{background:none;border:none;color:var(--primary);font-size:13px;font-weight:600;padding:6px 2px}.link-btn:hover{color:var(--primary-h);text-decoration:underline}.dash-body{flex:1;width:100%;max-width:1080px;margin:0 auto;padding:28px 24px;display:grid;grid-template-columns:380px 1fr;gap:24px;align-items:start}@media (max-width: 880px){.dash-body{grid-template-columns:1fr}}.dash-col{display:flex;flex-direction:column;gap:20px;min-width:0}.dash-col>h3{font-size:16px;font-weight:600}.schedule-form{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;display:flex;flex-direction:column;gap:14px;box-shadow:0 4px 16px #00000040}.schedule-form h3{font-size:16px;font-weight:600}.schedule-form .field>span{font-size:13px;color:var(--text-2);font-weight:500}.field-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.schedule-form .btn-block{margin-top:4px}.schedule-form .error,.dash-body .error{color:var(--danger);font-size:13px}.calendar{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:18px;box-shadow:0 4px 16px #00000040}.section-title{font-size:14px;font-weight:600;text-align:center;margin-bottom:12px}.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.cal-dow{text-align:center;font-size:11px;color:var(--muted);font-weight:600;text-transform:uppercase;padding-bottom:4px}.cal-cell{position:relative;aspect-ratio:1;display:grid;place-items:center;border-radius:8px;font-size:13px;color:var(--text-2);background:var(--surface-2);transition:background .12s,color .12s}.cal-cell:not(.empty):hover{background:var(--surface-3);color:var(--text)}.cal-cell.empty{background:transparent}.cal-cell.today{outline:2px solid var(--primary);color:var(--text);font-weight:700}.cal-cell.has-mtg{background:#0e71eb2e;color:#6db1ff;font-weight:700}.cal-dot{position:absolute;bottom:5px;width:5px;height:5px;border-radius:50%;background:var(--primary)}.meeting-list{display:flex;flex-direction:column;gap:10px}.meeting-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;display:flex;align-items:center;justify-content:space-between;gap:12px;transition:border-color .12s}.meeting-card:hover{border-color:var(--surface-3)}.meeting-main{min-width:0}.meeting-title{font-size:15px;font-weight:600;margin-bottom:3px}.meeting-when{font-size:13px;display:flex;align-items:center;flex-wrap:wrap;gap:6px}.meeting-id{font-size:12px;margin-top:3px}.recur-badge{display:inline-block;padding:1px 8px;border-radius:10px;font-size:11px;font-weight:600;background:var(--surface-3);color:var(--text-2)}.meeting-actions{display:flex;gap:6px;flex-shrink:0}.mini-btn{padding:6px 12px;border-radius:6px;font-size:13px;font-weight:600;background:var(--surface-2);border:1px solid var(--border);color:var(--text);transition:background .12s}.mini-btn:hover{background:var(--surface-3)}.mini-btn.primary{background:var(--primary);border-color:var(--primary);color:#fff}.mini-btn.primary:hover{background:var(--primary-h)}.mini-btn.danger{color:#ff7a6b}.mini-btn.danger:hover{background:#e3423426;border-color:var(--danger)}.breakout-popup{position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 8px 24px #00000080;z-index:50;min-width:180px;overflow:hidden}.breakout-popup-item{display:block;width:100%;padding:11px 16px;text-align:left;background:none;border:none;color:var(--text);font-size:14px;cursor:pointer}.breakout-popup-item:hover{background:var(--surface-2)}.breakout-popup-item+.breakout-popup-item{border-top:1px solid var(--border)}.breakout-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:300;display:grid;place-items:center;background:#00000073}.breakout-modal{width:460px;max-width:calc(100vw - 32px);max-height:82vh;background:#fff;color:#1a1a1a;border-radius:10px;box-shadow:0 24px 70px #0000008c;display:flex;flex-direction:column;overflow:hidden}.bm-head{display:flex;align-items:center;gap:9px;padding:13px 16px;background:#f7f7f8;border-bottom:1px solid #e6e6e8}.bm-logo{width:22px;height:22px;flex-shrink:0;border-radius:6px;background:#2d8cff;color:#fff;font-size:10px;font-weight:700;display:grid;place-items:center;letter-spacing:.5px}.bm-title{flex:1;font-size:15px;font-weight:600;color:#1a1a1a}.bm-close{width:28px;height:28px;border-radius:6px;border:none;background:none;color:#555;font-size:15px;cursor:pointer;display:grid;place-items:center}.bm-close:hover{background:#e8e8ea;color:#1a1a1a}.bm-body{flex:1;overflow-y:auto}.bm-body .muted{color:#999}.bm-room-list{list-style:none}.bm-room-item{border-bottom:1px solid #efeff1}.bm-room-row{display:flex;align-items:center;gap:9px;padding:11px 16px;cursor:pointer;background:#f7f7f8}.bm-room-row:hover{background:#f0f0f2}.bm-caret{width:12px;font-size:9px;color:#888;flex-shrink:0}.bm-rname{flex:1;font-weight:600;font-size:14px;color:#1a1a1a}.bm-count{display:inline-flex;align-items:center;gap:3px;color:#555;font-size:13px;margin-right:4px}.bm-joined{color:#999;font-size:13px;font-weight:500;padding:4px 8px}.bm-join-btn{background:#2d8cff;color:#fff;border:none;border-radius:4px;padding:5px 18px;font-size:13px;font-weight:600;cursor:pointer}.bm-join-btn:hover{background:#1a7af0}.bm-member-list{list-style:none;background:#fff}.bm-member{display:flex;align-items:center;gap:9px;padding:6px 16px 6px 37px;font-size:14px;color:#2c2c2e}.bm-member:last-child{padding-bottom:9px}.bm-dot{width:8px;height:8px;border-radius:50%;background:#4caf50;flex-shrink:0}.bm-empty{padding:8px 16px 8px 37px;color:#999;font-style:italic;font-size:13px}.bm-foot{display:flex;justify-content:flex-end;gap:8px;padding:12px 16px;border-top:1px solid #e6e6e8;background:#fff}.bm-foot-btn{background:#fff;border:1px solid #c8c8cc;color:#2c2c2e;border-radius:4px;padding:6px 16px;font-size:13px;font-weight:500;cursor:pointer}.bm-foot-btn:hover{background:#f2f2f4;border-color:#b0b0b6}.cbm-overlay,.hbm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:320;display:grid;place-items:center;background:#00000073}.cbm-modal{width:420px;max-width:calc(100vw - 32px);background:#fff;color:#1a1a1a;border-radius:10px;box-shadow:0 24px 70px #0000008c;overflow:hidden}.cbm-head,.hbm .bm-head{display:flex;align-items:center;gap:9px;padding:13px 16px;background:#f7f7f8;border-bottom:1px solid #e6e6e8}.cbm-title{flex:1;font-size:15px;font-weight:600;color:#1a1a1a}.cbm-body{padding:22px 20px;text-align:center}.cbm-assign-row{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:7px;font-size:14px;color:#2c2c2e;margin-bottom:16px}.cbm-assign-row input{width:56px;padding:5px 8px;text-align:center;background:#fff;border:1px solid #c8c8cc;border-radius:4px;color:#1a1a1a}.cbm-modes{display:flex;justify-content:center;gap:28px;margin-bottom:12px}.cbm-radio{display:inline-flex;align-items:center;gap:7px;font-size:14px;color:#2c2c2e;cursor:pointer}.cbm-radio input{accent-color:#2d8cff}.cbm-hint{font-size:13px;color:#888}.cbm-foot{display:flex;justify-content:center;padding:16px;border-top:1px solid #eee}.cbm-create-btn{background:#2d8cff;color:#fff;border:none;border-radius:5px;padding:8px 28px;font-size:14px;font-weight:600;cursor:pointer}.cbm-create-btn:hover{background:#1a7af0}.cbm-create-btn.danger{background:#e34234}.cbm-create-btn.danger:hover{background:#c53726}.hbm-modal{width:480px;max-width:calc(100vw - 32px);max-height:84vh;background:#fff;color:#1a1a1a;border-radius:10px;box-shadow:0 24px 70px #0000008c;display:flex;flex-direction:column;overflow:hidden}.hbm-body{flex:1;overflow-y:auto;padding:6px 0}.hbm-status{padding:8px 16px;font-size:13px;color:#2d8cff;font-weight:600}.hbm-help{margin:6px 16px;padding:8px 12px;background:#fff4e5;border:1px solid #ffd9a0;border-radius:6px;font-size:13px;color:#7a4a00;display:flex;flex-wrap:wrap;align-items:center;gap:8px}.hbm-help-item{display:inline-flex;align-items:center;gap:6px}.hbm-room{border-bottom:1px solid #efeff1}.hbm-room-row{display:flex;align-items:center;gap:8px;padding:9px 16px}.hbm-room-row .bm-caret{background:none;border:none;cursor:pointer}.hbm-rname{flex:1;min-width:0;font-size:14px;font-weight:600;color:#1a1a1a;background:transparent;border:1px solid transparent;border-radius:4px;padding:3px 6px}.hbm-rname:hover{border-color:#d8d8dc}.hbm-rname:focus{border-color:#2d8cff;background:#fff}.hbm-rname-static{flex:1;font-size:14px;font-weight:600;color:#777;padding:3px 6px}.hbm-count{color:#777;font-size:13px}.hbm-assign{background:none;border:none;color:#2d8cff;font-size:13px;font-weight:600;cursor:pointer;padding:2px 4px}.hbm-assign:hover{text-decoration:underline}.hbm-members{padding:0 16px 8px 34px}.hbm-member{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:5px 0;font-size:14px;color:#2c2c2e}.hbm-moveto-wrap{position:relative}.hbm-moveto-btn{background:none;border:1px solid transparent;color:#2d8cff;font-size:12px;font-weight:600;padding:3px 9px;border-radius:4px;cursor:pointer;opacity:0;transition:opacity .12s,background .12s}.hbm-member:hover .hbm-moveto-btn,.hbm-moveto-wrap.open .hbm-moveto-btn{opacity:1}.hbm-moveto-btn:hover{background:#eef5ff}.hbm-moveto-menu{position:absolute;top:calc(100% + 3px);right:0;min-width:150px;background:#fff;border:1px solid #ddd;border-radius:6px;box-shadow:0 8px 24px #00000038;padding:4px;z-index:20}.hbm-moveto-item{display:block;width:100%;text-align:left;white-space:nowrap;background:none;border:none;padding:7px 12px;border-radius:4px;font-size:13px;color:#2c2c2e;cursor:pointer}.hbm-moveto-item:hover{background:#2d8cff;color:#fff}.hbm-assign.active{background:#eef5ff;border-radius:4px}.hbm-assign-picker{margin:0 16px 8px 34px;padding:6px;background:#f7f8fa;border:1px solid #e3e3e6;border-radius:6px}.hbm-assign-head{font-size:12px;font-weight:600;color:#555;padding:4px 6px 6px}.hbm-assign-pick{display:flex;align-items:center;gap:9px;padding:6px 8px;border-radius:4px;cursor:pointer;font-size:14px;color:#2c2c2e}.hbm-assign-pick:hover{background:#ececf0}.hbm-assign-pick input{accent-color:#2d8cff}.hbm-pick-name{flex:1}.hbm-pick-cur{font-size:12px;color:#999}.hbm-empty{padding:4px 0;color:#999;font-size:13px;font-style:italic}.hbm-unassigned{background:#fafafa}.hbm-foot{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:12px 16px;border-top:1px solid #e6e6e8;background:#fff}.hbm-foot-left{display:flex;align-items:center;gap:14px}.hbm-link{background:none;border:none;color:#2d8cff;font-size:13px;font-weight:600;cursor:pointer}.hbm-link:hover{text-decoration:underline}.hbm-options-wrap{position:relative}.hbm-options{position:absolute;bottom:calc(100% + 8px);left:0;width:320px;background:#fff;border:1px solid #ddd;border-radius:8px;box-shadow:0 8px 28px #00000040;padding:10px 12px;display:flex;flex-direction:column;gap:9px;z-index:5}.hbm-options label{display:flex;align-items:center;flex-wrap:wrap;gap:6px;font-size:13px;color:#2c2c2e;cursor:pointer}.hbm-options input[type=checkbox]{accent-color:#2d8cff}.hbm-options input[type=number]{width:48px;padding:2px 5px;border:1px solid #c8c8cc;border-radius:4px}.hbm-opt-sub{display:flex;align-items:center;gap:6px;font-size:13px;color:#2c2c2e;padding-left:22px}.hbm-opt-sub select{padding:2px 6px;border:1px solid #c8c8cc;border-radius:4px}.hbm-join{background:#2d8cff;color:#fff;border:none;border-radius:4px;padding:3px 14px;font-size:12px;font-weight:600;cursor:pointer}.hbm-join:hover{background:#1a7af0}.hbm-here{color:#888;font-size:12px;font-weight:600}.hbm-broadcast{display:flex;gap:8px;padding:10px 16px;border-bottom:1px solid #efeff1}.hbm-broadcast input{flex:1;padding:6px 10px;border:1px solid #c8c8cc;border-radius:5px;font-size:13px;color:#1a1a1a;background:#fff}.hbm-broadcast-btn{background:#2d8cff;color:#fff;border:none;border-radius:5px;padding:6px 14px;font-size:13px;font-weight:600;cursor:pointer}.hbm-broadcast-btn:hover{background:#1a7af0}.hbm-broadcast-btn:disabled{opacity:.5;cursor:default}.hbm-status .hbm-link{font-weight:600}.bm-foot-spacer{flex:1}.bm-leave-btn{background:#2d8cff;color:#fff;border:none;border-radius:4px;padding:6px 16px;font-size:13px;font-weight:600;cursor:pointer}.bm-leave-btn:hover{background:#1a7af0}.breakout-broadcast{position:relative;z-index:60;margin:8px auto 0;width:calc(100% - 32px);max-width:720px;background:#2d3340;border:1px solid #3a4250;border-radius:8px;padding:10px 14px;display:flex;align-items:center;gap:9px;color:#f0f0f0;font-size:14px;box-shadow:0 6px 20px #0006}.bb-from{font-weight:700;color:#6db1ff;flex-shrink:0}.bb-text{flex:1}.bb-close{background:none;border:none;color:#aaa;cursor:pointer;font-size:13px;flex-shrink:0}.bb-close:hover{color:#fff}.breakout-joining{position:fixed;top:0;right:0;bottom:0;left:0;z-index:400;display:grid;place-items:center;background:var(--bg)}.bj-card{display:flex;flex-direction:column;align-items:center;gap:20px;text-align:center}.bj-card .spinner{width:44px;height:44px;border-width:4px}.bj-title{font-size:18px;font-weight:500;color:var(--text)}
