:root{color-scheme:dark;font-family:system-ui,sans-serif;--bg: #0a0c12;--panel: #11151f;--panel-2: #161b28;--border: #1e2533;--accent: #4e9af1;--text: #e6ebf2;--muted: #8a93a6}*{box-sizing:border-box}body{margin:0;background:radial-gradient(1200px 600px at 70% -10%,#16203a 0%,var(--bg) 60%);color:var(--text)}.app{display:flex;flex-direction:column;height:100vh}.app-header{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.app-title{font-size:18px;font-weight:700}.app-floor{color:var(--muted);font-weight:400}.app-me{font-size:14px;color:var(--muted);background:var(--panel-2);border:1px solid var(--border);padding:6px 12px;border-radius:999px}.app-body{display:flex;gap:16px;padding:16px;flex:1;min-height:0}.stage{flex:1;position:relative;min-width:0;min-height:0}.floor-canvas{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:14px;border:1px solid var(--border);overflow:hidden;box-shadow:0 20px 60px #00000073}.floor-canvas canvas{display:block;width:100%;height:100%}.scene-name{font-size:12px;font-weight:600;color:#fff;background:#16203ae6;border:1px solid rgba(255,255,255,.12);padding:2px 8px;border-radius:999px;white-space:nowrap;transform:translateY(-50%);pointer-events:none;-webkit-user-select:none;user-select:none}.scene-name.self{background:#4e9af1eb}.scene-room-label{font-size:12px;font-weight:600;color:#cdd8ee;background:#0a0d1699;padding:2px 8px;border-radius:6px;white-space:nowrap;pointer-events:none;-webkit-user-select:none;user-select:none}.scene-reaction{font-size:30px;pointer-events:none;-webkit-user-select:none;user-select:none;transition:opacity .2s linear}.sidebar{width:290px;flex-shrink:0;display:flex;flex-direction:column;gap:16px;overflow-y:auto}.controls,.presence-list,.admit-panel,.appearance{background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:14px}.appearance h3{margin:0 0 10px;font-size:14px}.appearance-colors{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px}.appearance-colors .swatch{width:24px;height:24px}.appearance-accessory{display:flex;flex-direction:column;gap:6px;font-size:13px;color:var(--muted)}.reaction-bar{position:absolute;bottom:12px;left:50%;transform:translate(-50%);z-index:5;display:flex;gap:4px;background:#0a0d16d9;border:1px solid var(--border);border-radius:999px;padding:4px;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.reaction-bar button{background:transparent;border:none;font-size:20px;padding:4px 8px;border-radius:999px}.reaction-bar button:hover{background:#ffffff14}.controls-room{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.controls-buttons{display:flex;flex-wrap:wrap;gap:8px}button{background:var(--panel-2);color:var(--text);border:1px solid #2b3550;border-radius:9px;padding:9px 13px;cursor:pointer;font-size:14px;transition:background .15s,border-color .15s,transform .05s}button:hover{border-color:var(--accent)}button:active{transform:translateY(1px)}button.on{background:#1f6feb;border-color:#1f6feb}button.off{background:#2a1f24;border-color:#5b2b34}button:disabled{opacity:.6;cursor:default}.controls-status{display:flex;flex-direction:column;gap:6px;margin-top:12px;font-size:13px;color:var(--muted)}select,input[type=text]{background:var(--panel-2);color:var(--text);border:1px solid #2b3550;border-radius:9px;padding:10px;font-size:14px}input[type=text]:focus,select:focus{outline:none;border-color:var(--accent)}.badge{font-size:11px;text-transform:uppercase;padding:3px 9px;border-radius:999px;background:#2b3550}.badge-connected{background:#14532d}.badge-connecting,.badge-reconnecting{background:#5b4a2b}.badge-disconnected,.badge-error{background:#5b2b34}.dock-stack{position:absolute;bottom:12px;z-index:5;display:flex;flex-direction:column;gap:8px;max-height:calc(100% - 24px);pointer-events:none}.dock-stack>*{pointer-events:auto}.dock-stack-left{left:12px;align-items:flex-start}.dock-stack-right{right:12px;align-items:flex-end}.dock{display:flex;flex-direction:column;gap:8px;max-width:min(46vw,460px);min-height:0}.dock-left{align-items:flex-start}.dock-right{align-items:flex-end}.dock-toggle{background:#0a0d16d9;border:1px solid var(--border);border-radius:999px;padding:7px 14px;font-size:13px;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.dock-body{width:min(46vw,460px);max-height:52vh;overflow:auto;background:#0a0d16eb;border:1px solid var(--border);border-radius:12px;padding:10px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.dock-body .whiteboard,.dock-body .video-stage{margin-top:0}.chat-panel{display:flex;flex-direction:column;gap:8px;width:min(42vw,360px);height:44vh}.chat-tabs{display:flex;gap:6px}.chat-tabs button{flex:1;padding:6px 10px;font-size:13px;border:1px solid var(--border);border-radius:8px;background:#141c2d99;color:#9fb0c8}.chat-tabs button.active{background:var(--accent);color:#fff;border-color:transparent}.chat-messages{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:8px;padding-right:4px}.chat-empty{color:#6b7a93;font-size:13px;text-align:center;margin:auto 0}.chat-msg{display:flex;flex-direction:column;gap:2px;max-width:85%;align-self:flex-start}.chat-msg.self{align-self:flex-end;text-align:right}.chat-meta{font-size:11px;color:#7c8aa3}.chat-text{background:#1c263ae6;border-radius:10px;padding:6px 10px;font-size:14px;word-break:break-word}.chat-msg.self .chat-text{background:var(--accent);color:#fff}.chat-input{display:flex;gap:6px}.chat-input input{flex:1;padding:8px 10px;border-radius:8px;border:1px solid var(--border);background:#080b12e6;color:#e6edf7;font-size:14px}.chat-input button{padding:8px 14px;border-radius:8px;border:none;background:var(--accent);color:#fff;font-size:13px}.chat-input button:disabled{opacity:.5}.chat-attach-btn{padding:8px 10px;border-radius:8px;border:1px solid var(--border);background:#141c2d99}.chat-text.deleted{font-style:italic;color:#6b7a93}.chat-attachment{display:inline-block;margin-top:2px}.chat-attachment img{max-width:220px;max-height:200px;border-radius:10px;display:block}.chat-file{display:inline-block;background:#1c263ae6;border-radius:10px;padding:6px 10px;font-size:13px;color:#cfe0f5}.chat-msg-footer{position:relative;display:flex;flex-wrap:wrap;align-items:center;gap:4px;margin-top:2px}.chat-msg.self .chat-msg-footer{justify-content:flex-end}.chat-reaction{font-size:12px;padding:1px 7px;border-radius:999px;border:1px solid var(--border);background:#141c2db3}.chat-reaction.mine{border-color:var(--accent);background:#4e9af140}.chat-react-add,.chat-mini{font-size:12px;padding:1px 5px;border-radius:6px;background:transparent;border:none;opacity:.5}.chat-msg:hover .chat-react-add,.chat-msg:hover .chat-mini{opacity:.9}.chat-emoji-picker{position:absolute;bottom:100%;left:0;display:flex;gap:2px;background:#0a0d16f5;border:1px solid var(--border);border-radius:10px;padding:4px;z-index:10}.chat-emoji-picker button{background:transparent;border:none;font-size:16px;padding:2px 4px}.chat-edit{display:flex;gap:4px}.chat-edit input{flex:1;padding:5px 8px;border-radius:6px;border:1px solid var(--border);background:#080b12e6;color:#e6edf7}.chat-typing{min-height:16px;font-size:12px;color:#8aa0bf;font-style:italic;padding:0 2px}.chat-file-preview{display:flex;align-items:center;justify-content:space-between;font-size:12px;color:#cfe0f5;background:#1c263ab3;border-radius:8px;padding:4px 8px}.chat-file-preview button{background:transparent;border:none;color:#9fb0c8}.video-stage{display:flex;flex-direction:column;gap:10px}.video-main{width:100%}.video-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:10px}.video-strip{display:flex;gap:10px;overflow-x:auto;padding-bottom:4px}.video-strip .video-tile{flex:0 0 200px}.video-tile{position:relative;background:#05070c;border:1px solid var(--border);border-radius:12px;overflow:hidden;aspect-ratio:16 / 9}.video-tile.big{aspect-ratio:16 / 9;max-height:70vh}.video-tile video{width:100%;height:100%;display:block}.video-tile.fit-cover video{object-fit:cover}.video-tile.fit-contain video{object-fit:contain;background:#000}.view-switcher{position:absolute;top:12px;left:50%;transform:translate(-50%);z-index:7;display:flex;gap:4px;background:#0a0d16d9;border:1px solid var(--border);border-radius:999px;padding:4px;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.view-switcher button{background:transparent;border:none;border-radius:999px;padding:6px 12px;font-size:13px}.view-switcher button.active{background:var(--accent)}.cam-dock{display:flex;flex-direction:column;gap:8px}.cam-dock .video-tile{width:min(40vw,260px)}.cam-dock-expand{font-size:12px;padding:6px 10px}.focus-stage{position:absolute;top:0;right:0;bottom:0;left:0;z-index:6;display:flex;flex-direction:column;background:#05070cf7;border-radius:14px;overflow:hidden}.focus-bar{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-bottom:1px solid var(--border);font-weight:600}.focus-content{flex:1;min-height:0;display:flex;gap:10px;padding:12px}.focus-mode-screen{flex-direction:row}.focus-main{flex:1;min-width:0;display:flex;align-items:center;justify-content:center}.focus-main .video-tile.big{width:100%;height:100%;max-height:none;aspect-ratio:auto}.focus-side{width:200px;flex-shrink:0;display:flex;flex-direction:column;gap:10px;overflow-y:auto}.focus-gallery{flex:1;min-height:0;display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));grid-auto-rows:min-content;gap:12px;overflow-y:auto;align-content:start}.focus-gallery .video-tile{width:100%;height:100%}.focus-gallery[data-count="1"]{grid-template-columns:1fr;align-content:center;justify-items:center}.focus-gallery[data-count="1"] .video-tile{width:auto;height:100%;max-width:100%}.focus-gallery[data-count="2"]{grid-template-columns:1fr 1fr;grid-auto-rows:1fr;align-content:stretch}.focus-gallery[data-count="3"],.focus-gallery[data-count="4"]{grid-template-columns:1fr 1fr;grid-auto-rows:1fr;align-content:center}.focus-side-group{display:flex;flex-direction:column;gap:8px}.focus-side-title{font-size:12px;color:#8aa0bf;text-transform:uppercase;letter-spacing:.04em}.screen-pick{position:relative;padding:0;border:2px solid transparent;border-radius:12px;background:none;cursor:pointer;overflow:hidden}.screen-pick.active{border-color:var(--accent)}.screen-pick .video-tile{border:none;border-radius:10px}.screen-pick-label{position:absolute;left:6px;bottom:6px;font-size:11px;background:#05070cbf;padding:2px 6px;border-radius:6px}.video-tile:fullscreen{border-radius:0;aspect-ratio:auto;max-height:none}.video-tile:fullscreen video{object-fit:contain}.video-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:flex-end;justify-content:space-between;padding:8px;pointer-events:none;background:linear-gradient(to top,rgba(0,0,0,.5),transparent 35%)}.video-label{background:#0000008c;padding:3px 9px;border-radius:999px;font-size:12px}.video-actions{display:flex;gap:6px;pointer-events:auto}.video-actions button{padding:4px 8px;font-size:13px;background:#0000008c;border:1px solid rgba(255,255,255,.15)}.pomodoro{background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:14px}.pomodoro h3{margin:0 0 10px;font-size:14px}.pomodoro-idle{display:flex;flex-direction:column;gap:8px;font-size:13px;color:var(--muted)}.pomodoro-active{text-align:center}.pomodoro-phase{font-size:12px;text-transform:uppercase;color:var(--muted)}.pomodoro-time{font-size:34px;font-weight:700;margin:4px 0 10px;font-variant-numeric:tabular-nums}.pomodoro-work .pomodoro-time{color:#f2c14e}.pomodoro-break .pomodoro-time{color:#4ade80}.admit-yes{background:#2f7d6b;border-color:#2f7d6b;padding:6px 10px}.admit-no{background:#5b2b34;border-color:#5b2b34;padding:6px 10px}.presence-list li.offline{opacity:.5}.whiteboard{margin-top:12px;background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:10px}.whiteboard-bar{display:flex;align-items:center;gap:12px;margin-bottom:8px;font-size:13px}.whiteboard-colors{display:flex;gap:6px;margin-left:auto}.swatch{width:22px;height:22px;border-radius:50%;padding:0;border:2px solid transparent}.swatch.active{border-color:#fff}.whiteboard-canvas{width:100%;height:auto;aspect-ratio:1000 / 420;background:#0f1320;border:1px solid var(--border);border-radius:8px;touch-action:none;cursor:crosshair}@media (max-width: 900px){.app-body{flex-direction:column}.sidebar{width:100%;flex-direction:row;flex-wrap:wrap}.sidebar>*{flex:1 1 240px}}.presence-list h3,.admit-panel h3{margin:0 0 10px;font-size:14px}.presence-list ul,.admit-panel ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.presence-list li{display:flex;align-items:center;gap:8px;font-size:13px}.dot{width:10px;height:10px;border-radius:50%;background:var(--muted)}.dot-AVAILABLE{background:#4ade80}.dot-FOCUS{background:#f2c14e}.dot-AWAY{background:var(--muted)}.peer-room{margin-left:auto;opacity:.6}.speaking{color:#4ade80;font-size:11px}.admit-panel{border-color:#5b4a2b;background:#1c1810}.admit-panel li{display:flex;align-items:center;gap:8px;font-size:13px}.admit-name{flex:1}.admit-panel button{background:#2f7d6b;border-color:#2f7d6b;padding:6px 10px}.knock-banner{display:flex;align-items:center;gap:12px;background:#2a2417;border-bottom:1px solid #5b4a2b;padding:10px 20px}.knock-banner.waiting{background:#16263a;border-bottom-color:#2c4a6b;color:#bcd8f5}.app-message{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;text-align:center;gap:8px}.app-message.error{color:#ff8c8c}.spinner{width:36px;height:36px;border:4px solid #2b3550;border-top-color:var(--accent);border-radius:50%;animation:spin .9s linear infinite;margin-bottom:8px}@keyframes spin{to{transform:rotate(360deg)}}.login{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px}.login-card{width:100%;max-width:380px;background:var(--panel);border:1px solid var(--border);border-radius:16px;padding:28px;box-shadow:0 24px 70px #00000080}.login-brand{font-weight:800;letter-spacing:1px;color:var(--accent);font-size:13px;text-transform:uppercase}.login-card h1{margin:6px 0 4px;font-size:24px}.login-sub{margin:0 0 18px;color:var(--muted);font-size:14px}.login-card form{display:flex;flex-direction:column;gap:8px}.login-card label{font-size:13px;color:var(--muted)}.login-primary{margin-top:6px;background:var(--accent);border-color:var(--accent);font-weight:600;padding:11px}.login-hint{font-size:12px;color:var(--muted);margin:14px 0 0;line-height:1.5}.login-divider{text-align:center;color:var(--muted);font-size:12px;margin:18px 0 12px;position:relative}.login-divider:before,.login-divider:after{content:"";position:absolute;top:50%;width:28%;height:1px;background:var(--border)}.login-divider:before{left:0}.login-divider:after{right:0}.login-demo{display:flex;gap:8px}.login-demo button{flex:1;font-size:13px;padding:9px 6px}
