*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0f172a;--surface:#1e293b;--surface2:#334155;--border:#475569;--text:#f1f5f9;--text-muted:#94a3b8;--accent:#3b82f6;--accent-hover:#2563eb;--danger:#ef4444;--success:#22c55e}[data-theme=light]{--bg:#f8fafc;--surface:#ffffff;--surface2:#e2e8f0;--border:#cbd5e1;--text:#0f172a;--text-muted:#64748b}@media (min-width:769px){html{scrollbar-gutter:stable}}body,html{height:100%;width:100%;background:var(--bg);font-family:system-ui,-apple-system,sans-serif;font-size:14px;overflow-x:hidden;-webkit-text-size-adjust:100%}body,button,html{color:var(--text)}button{cursor:pointer;border:1px solid var(--border);border-radius:6px;padding:6px 14px;background:var(--surface2);font-size:13px;transition:background .15s}button:hover:not(:disabled){background:var(--border)}button:disabled{opacity:.4;cursor:not-allowed}button.primary{background:var(--accent);border-color:var(--accent);color:#fff;font-weight:600}button.primary:hover:not(:disabled){background:var(--accent-hover);border-color:var(--accent-hover)}button.danger{background:var(--danger);border-color:var(--danger);color:#fff}input,textarea{background:var(--surface);border:1px solid var(--border);border-radius:6px;color:var(--text);font-size:13px;padding:6px 10px;outline:none}input:focus,textarea:focus{border-color:var(--accent)}.app{position:relative;display:flex;flex-direction:column;min-height:100vh;padding:16px max(16px,env(safe-area-inset-right)) max(16px,env(safe-area-inset-bottom)) max(16px,env(safe-area-inset-left));gap:16px;max-width:100%;overflow-x:hidden}.media-error{background:#7f1d1d;border:1px solid var(--danger);color:#fecaca;padding:10px 14px;border-radius:6px;font-size:13px;cursor:pointer}.connect-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;min-height:60vh}.connect-screen h1{font-size:24px;font-weight:700}.app-logo{height:256px;width:auto;object-fit:contain}.app-logo-light{display:none}.app-logo-dark,[data-theme=light] .app-logo-light{display:block}[data-theme=light] .app-logo-dark{display:none}.app-logo-subtitle{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:3px;font-weight:300;margin-top:-2px}.connect-screen p{color:var(--text-muted)}.connect-error,.connect-screen p{text-align:center;max-width:380px}.connect-error{color:#ef4444;font-size:13px}.spinner-inline{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite;vertical-align:middle;margin-right:6px}.copyright{color:var(--text-muted);font-size:11px;text-align:center;padding:16px 0}.copyright-room{font-size:9px;padding:0;opacity:.9;position:absolute;bottom:2px}.room-list{max-width:540px;margin:0 auto;width:100%;display:flex;flex-direction:column;gap:16px;padding-top:28px}.room-list h2{font-size:18px}.create-form{display:flex;gap:8px;flex-wrap:wrap}.create-form input{flex:1 1;min-width:120px}.create-form .primary{flex-shrink:0}.rooms-table{display:flex;flex-direction:column;gap:8px}.room-row{display:flex;align-items:center;justify-content:space-between;background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:10px 14px}.room-row .room-name{font-weight:600}.room-row .room-id{color:var(--text-muted);font-size:12px}.room-row.room-full{opacity:.5}.room-occupancy{font-size:13px;font-weight:600;color:var(--text-muted);white-space:nowrap}.no-rooms{color:var(--text-muted);text-align:center;padding:24px 0}.room-container{display:grid;grid-template-columns:1fr 1fr;grid-gap:16px;gap:16px;max-width:100%;min-width:0}@media (max-width:768px){.room-container{grid-template-columns:1fr}.canvas-container{min-height:300px}}.peer-indicator{display:flex;align-items:center;gap:5px;font-size:12px;color:var(--text-muted)}.peer-dot{width:7px;height:7px;border-radius:50%;background:var(--text-muted);flex-shrink:0}.peer-indicator.connected .peer-dot{background:var(--success)}.peer-indicator.connected{color:var(--success)}.peer-indicator.reconnecting .peer-dot{background:#f59e0b}.peer-indicator.reconnecting{color:#f59e0b}.peer-indicator.disconnected .peer-dot{background:var(--danger)}.peer-indicator.disconnected{color:var(--danger)}.relay-badge{font-size:10px;font-weight:600;background:#f59e0b;color:#000;padding:1px 5px;border-radius:3px;margin-left:2px}.video-panel{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:12px;display:flex;flex-direction:column;gap:10px;min-width:0}.video-panel h3{font-size:14px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.videos{display:flex;flex-direction:column;gap:8px}.video-wrapper{width:100%;height:340px;position:relative;background:#000;border-radius:8px;overflow:hidden;isolation:isolate;border:2px solid transparent;transition:border-color .2s ease,box-shadow .2s ease}.audio-placeholder.speaking,.video-wrapper.speaking{border-color:#22c55e;box-shadow:0 0 12px rgba(34,197,94,.4)}.video-wrapper video{width:100%;height:100%;object-fit:contain;display:block}.video-wrapper video.local-video-mirrored{transform:scaleX(-1)}.video-wrapper .label{position:absolute;bottom:6px;left:8px;font-size:11px;background:rgba(0,0,0,.55);border-radius:4px;padding:2px 6px;color:#fff}.no-remote{justify-content:center;width:100%;height:340px;background:var(--surface2);border-radius:8px}.no-remote,.video-toggle{display:flex;align-items:center;color:var(--text-muted);font-size:13px}.video-toggle{gap:6px;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.video-toggle input{display:none}.video-toggle-slider{position:relative;width:32px;height:18px;background:var(--surface2);border-radius:9px;transition:background .2s}.video-toggle-slider:after{content:"";position:absolute;top:2px;left:2px;width:14px;height:14px;background:var(--text-muted);border-radius:50%;transition:transform .2s,background .2s}.video-toggle input:checked+.video-toggle-slider{background:#3b82f6}.video-toggle input:checked+.video-toggle-slider:after{transform:translateX(14px);background:#fff}.video-toggle i{font-size:12px}.audio-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;width:100%;height:340px;background:var(--surface2);border-radius:8px;color:var(--text-muted);isolation:isolate;position:relative;border:2px solid transparent;transition:border-color .2s ease,box-shadow .2s ease}.audio-placeholder i.fa-headset{font-size:48px;opacity:.6}.audio-placeholder span{font-size:13px}.audio-placeholder .media-controls{position:absolute;top:8px;left:8px}.fullscreen-btn{position:absolute;top:8px;right:8px;width:36px;height:36px;padding:0;border-radius:50%;font-size:14px;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.5);border-color:transparent;color:#fff;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:10}.fullscreen-btn:hover:not(:disabled){background:rgba(0,0,0,.7)}.video-wrapper:-webkit-full-screen{width:100%;height:100%;border-radius:0;background:#000}.video-wrapper:fullscreen{width:100%;height:100%;border-radius:0;background:#000}.video-wrapper:-webkit-full-screen video{width:100%;height:100%;object-fit:contain}.video-wrapper:fullscreen video{width:100%;height:100%;object-fit:contain}.video-wrapper:-webkit-full-screen .video-paint-canvas{border-radius:0}.video-wrapper:fullscreen .video-paint-canvas{border-radius:0}.latency-ms{color:var(--text-muted);font-size:11px;line-height:1}.latency-ms.good{color:#22c55e}.latency-ms.medium{color:#f59e0b}.latency-ms.bad{color:#ef4444}.latency-ms.unknown{color:var(--text-muted)}.whiteboard{height:100%;background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:12px;display:flex;flex-direction:column;gap:10px;min-width:0}.whiteboard h3{font-size:14px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.toolbar{gap:6px}.toolbar,.toolbar-group{display:flex;flex-wrap:wrap;align-items:center}.toolbar-group{gap:4px;border:1px solid var(--border);border-radius:8px;padding:4px;background:var(--surface2)}.color-swatch{width:22px;height:22px;border-radius:50%;border:2px solid transparent;padding:0;min-width:unset;flex-shrink:0}.color-swatch.active{border-color:var(--accent);outline:2px solid var(--accent);outline-offset:1px}.width-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;padding:0;min-width:unset;border-radius:6px}.width-btn.active{background:var(--accent);border-color:var(--accent)}.width-dot{border-radius:50%;background:var(--text);flex-shrink:0}.tool-btn{width:32px;height:32px;padding:0;border-radius:6px;font-size:14px;display:flex;align-items:center;justify-content:center;min-width:unset;flex-shrink:0}.tool-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}.whiteboard-header{min-height:28px}.whiteboard-header,.whiteboard-toggles{display:flex;align-items:center;gap:8px}.whiteboard-toggles{width:100%}.whiteboard-header-buttons{display:flex;align-items:center;gap:4px;margin-left:auto;margin-right:40px;flex-shrink:0}.whiteboard-header-buttons.no-toggles{margin-left:0}.toolbar-row{display:flex;align-items:center;gap:6px;flex-wrap:nowrap}.toolbar-actions-group{gap:4px}.toolbar-fullscreen-btn{width:32px;height:32px;padding:0;display:flex;align-items:center;justify-content:center;font-size:14px;min-width:unset;flex-shrink:0}.canvas-container{position:relative;flex:1 1;min-height:0}.canvas-wrap{position:relative;width:100%;height:100%}.canvas-overlays{position:absolute;inset:0;overflow:visible;pointer-events:none;container-type:inline-size}.canvas-overlays>*{pointer-events:auto}.whiteboard-canvas{width:100%;height:100%;border-radius:8px;background:#ffffff;display:block;touch-action:none;cursor:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24'%3E%3Cline x1='12' y1='3' x2='12' y2='21' stroke='white' stroke-width='3' stroke-linecap='round'/%3E%3Cline x1='3' y1='12' x2='21' y2='12' stroke='white' stroke-width='3' stroke-linecap='round'/%3E%3Cline x1='12' y1='3' x2='12' y2='21' stroke='%23222' stroke-width='1.5' stroke-linecap='round'/%3E%3Cline x1='3' y1='12' x2='21' y2='12' stroke='%23222' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E") 12 12,crosshair}.whiteboard-canvas--text-tool{cursor:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24'%3E%3Cline x1='12' y1='3' x2='12' y2='21' stroke='white' stroke-width='3' stroke-linecap='round'/%3E%3Cline x1='3' y1='12' x2='21' y2='12' stroke='white' stroke-width='3' stroke-linecap='round'/%3E%3Cline x1='12' y1='3' x2='12' y2='21' stroke='%23222' stroke-width='1.5' stroke-linecap='round'/%3E%3Cline x1='3' y1='12' x2='21' y2='12' stroke='%23222' stroke-width='1.5' stroke-linecap='round'/%3E%3Ctext x='16' y='9' font-size='9' font-family='sans-serif' font-weight='bold' fill='%23222'%3ET%3C/text%3E%3C/svg%3E") 12 12,crosshair}.whiteboard:-webkit-full-screen{background:var(--bg);border:none;border-radius:0;padding:8px 12px;gap:8px;width:100%;height:100%;overflow:hidden}.whiteboard:-webkit-full-screen,.whiteboard:fullscreen{background:var(--bg);border:none;border-radius:0;padding:8px 12px;gap:8px;width:100%;height:100%;overflow:hidden}.whiteboard:-webkit-full-screen .canvas-container{flex:1 1;min-height:0;display:flex;align-items:center;justify-content:center;container-type:size}.whiteboard:-webkit-full-screen .canvas-container,.whiteboard:fullscreen .canvas-container{flex:1 1;min-height:0;display:flex;align-items:center;justify-content:center;container-type:size}.whiteboard:-webkit-full-screen .canvas-wrap{position:relative;aspect-ratio:2/1;width:min(100%,calc(2 * 100cqh))}.whiteboard:-webkit-full-screen .canvas-wrap,.whiteboard:fullscreen .canvas-wrap{position:relative;aspect-ratio:2/1;width:min(100%,calc(2 * 100cqh))}.whiteboard:-webkit-full-screen .whiteboard-canvas{border-radius:4px}.whiteboard:-webkit-full-screen .whiteboard-canvas,.whiteboard:fullscreen .whiteboard-canvas{border-radius:4px}.whiteboard:-webkit-full-screen .toolbar{gap:6px;flex-shrink:0}.whiteboard:-webkit-full-screen .toolbar,.whiteboard:fullscreen .toolbar{gap:6px;flex-shrink:0}.whiteboard:-webkit-full-screen .toolbar-group{gap:2px;padding:3px}.whiteboard:-webkit-full-screen .toolbar-group,.whiteboard:fullscreen .toolbar-group{gap:2px;padding:3px}.whiteboard:-webkit-full-screen .whiteboard-toggles .toggle-switch{display:none!important}.whiteboard:-webkit-full-screen .whiteboard-toggles .toggle-switch,.whiteboard:fullscreen .whiteboard-toggles .toggle-switch{display:none!important}.whiteboard:-webkit-full-screen .whiteboard-header-buttons{margin-right:0}.whiteboard:-webkit-full-screen .whiteboard-header-buttons,.whiteboard:fullscreen .whiteboard-header-buttons{margin-right:0}.sticky-note{position:absolute;border-radius:max(2px,.33cqw);box-shadow:0 2px 6px rgba(0,0,0,.15);display:flex;flex-direction:column;overflow:hidden;font-size:max(7px,1cqw);cursor:-webkit-grab;cursor:grab;-webkit-user-select:none;-moz-user-select:none;user-select:none;touch-action:none}.sticky-note-delete{position:absolute;top:max(1px,.17cqw);right:max(1px,.17cqw);width:max(14px,1.5cqw);height:max(14px,1.5cqw);padding:0;border:none;border-radius:50%;background:rgba(0,0,0,.15);color:#333;font-size:max(8px,.92cqw);line-height:1;display:flex;align-items:center;justify-content:center;cursor:pointer;min-width:unset}.sticky-note-delete:hover{background:rgba(0,0,0,.3)}.sticky-note-text{flex:1 1;padding:max(10px,1.83cqw) max(3px,.5cqw) max(3px,.5cqw);font-size:max(7px,1cqw);color:#1a1a1a;outline:none;overflow:hidden;word-break:break-word;cursor:text;-webkit-user-select:text;-moz-user-select:text;user-select:text}.text-overlay{position:absolute;min-width:40px;min-height:32px;padding:6px 14px 4px 4px;-webkit-user-select:none;-moz-user-select:none;user-select:none;touch-action:none;z-index:2;border:1px solid transparent;transition:border-color .15s,background .15s}.text-overlay-drag{height:max(14px,1.17cqw);cursor:-webkit-grab;cursor:grab;flex-shrink:0;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .15s;touch-action:none}.text-overlay--active .text-overlay-drag,.text-overlay--tool-active .text-overlay-drag{opacity:1}.text-overlay-drag:after{content:"";width:24px;height:3px;border-radius:2px;background:var(--accent);opacity:.5}.text-overlay-content{outline:none;white-space:pre-wrap;word-break:break-word;min-width:40px;background:transparent;cursor:text;-webkit-user-select:text;-moz-user-select:text;user-select:text;font-size:max(8px,calc(var(--text-font-cqw, 1.5) * 1cqw))}.text-overlay-delete{position:absolute;top:-9px;right:-9px;width:max(18px,1.67cqw);height:max(18px,1.67cqw);padding:0;border:none;border-radius:50%;background:rgba(239,68,68,.85);color:#fff;font-size:max(9px,1cqw);line-height:1;display:flex;align-items:center;justify-content:center;cursor:pointer;min-width:unset;opacity:0;transition:opacity .15s;z-index:3}.text-overlay-delete:hover{background:rgba(220,38,38,1)}.text-overlay--active{border:1px dashed var(--accent)}.text-overlay--active .text-overlay-delete{opacity:1}.text-overlay--tool-active{background:rgba(59,130,246,.08);border:1px dashed rgba(59,130,246,.3)}.text-overlay--tool-active .text-overlay-delete{opacity:1}.text-overlay-resize{position:absolute;top:0;right:max(-4px,-.33cqw);width:max(12px,1cqw);height:100%;cursor:ew-resize;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .15s;touch-action:none}.text-overlay--active .text-overlay-resize,.text-overlay--tool-active .text-overlay-resize{opacity:1}.text-overlay-resize:after{content:"";width:3px;height:24px;max-height:60%;border-radius:2px;background:var(--accent);opacity:.6}@media (max-width:768px){.text-overlay-drag{height:28px}.text-overlay-drag:after{width:36px;height:4px}.text-overlay-delete{top:-11px;right:-11px;width:22px;height:22px;font-size:12px}.text-overlay-resize{width:16px}.text-overlay-resize:after{width:3px;height:24px}}.bottom-panel-wrapper{grid-column:1/-1;display:flex;flex-direction:column;min-width:0}.bottom-panel{display:grid;grid-template-columns:1fr 1fr;grid-gap:16px;gap:16px;min-width:0;height:400px;min-height:200px;max-height:80vh}.bottom-panel>.bottom-right,.bottom-panel>.chat{overflow:hidden;min-height:0}.bottom-resize-handle{height:14px;cursor:ns-resize;display:flex;align-items:center;justify-content:center;-webkit-user-select:none;-moz-user-select:none;user-select:none;touch-action:none;flex-shrink:0}.bottom-resize-handle:after{content:"";width:40px;height:4px;border-radius:2px;background:var(--border);transition:background .15s}.bottom-resize-handle.active:after,.bottom-resize-handle:hover:after{background:var(--text-muted)}.bottom-resize-handle.active:after{width:60px;background:var(--accent)}.bottom-right{display:flex;gap:16px;min-width:0;min-height:0;overflow:hidden}.bottom-right .file-transfer,.bottom-right .investing-widget,.bottom-right .notepad,.bottom-right .widget-container{flex:1 1;min-width:0}@media (max-width:1024px){.bottom-right{flex-direction:column;overflow-y:auto}.bottom-right .investing-widget,.bottom-right .notepad,.bottom-right .widget-container{flex:1 1;width:100%;min-height:150px}}@media (max-width:768px){.whiteboard{min-height:70vh}.whiteboard-header-buttons{margin-right:0}.toolbar{gap:8px}.toolbar-group{gap:3px;padding:3px}.color-swatch{width:20px;height:20px}.tool-btn,.width-btn{width:28px;height:28px}.tool-btn{font-size:13px}.bottom-panel{grid-template-columns:1fr;height:auto!important;max-height:none}.bottom-panel>.bottom-right,.bottom-panel>.chat{overflow:visible;min-height:auto}.bottom-panel>.chat{height:auto;min-height:200px;max-height:400px}.bottom-right{flex-direction:column;overflow:visible}.bottom-right .notepad{min-height:180px;max-height:300px;overflow:visible}.bottom-right .notepad .notepad-editor{min-height:120px;max-height:200px}.bottom-right .widget-container{min-height:200px;max-height:350px;overflow:visible}.bottom-resize-handle{display:none}.notepad{width:100%}}.chat{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:12px;display:flex;flex-direction:column;gap:10px;height:100%;min-height:0}.chat h3{font-size:14px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.messages{flex:1 1;overflow-y:auto;display:flex;flex-direction:column;gap:6px;min-height:0;padding:4px 8px 4px 0;scrollbar-color:var(--border) transparent}.messages::-webkit-scrollbar{width:6px}.messages::-webkit-scrollbar-track{background:transparent}.messages::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.messages::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.message{display:flex;flex-direction:column;gap:2px}.message .sender{font-size:11px;color:var(--text-muted)}.message.self .sender{color:var(--accent);text-align:right}.message .bubble{background:var(--surface2);border-radius:8px;padding:6px 10px;max-width:80%;word-break:break-word;font-size:13px}.message.self .bubble{background:var(--accent);color:#fff;margin-left:auto}.message.ai-message .sender{color:var(--accent);font-weight:600}.message.ai-message .bubble{border-left:3px solid var(--accent);max-width:95%;line-height:1.45}.message.ai-message .bubble code{background:var(--bg);padding:1px 4px;border-radius:3px;font-size:12px;font-family:monospace}.message.ai-message .bubble pre{background:var(--bg);padding:8px;border-radius:6px;overflow-x:auto;margin:4px 0;font-size:12px}.message.ai-message .bubble pre code{background:none;padding:0}.ai-typing-dots{display:inline-flex;gap:3px;align-items:center}.ai-typing-dots span{width:5px;height:5px;border-radius:50%;background:var(--accent);animation:ai-dot-pulse 1.2s infinite}.ai-typing-dots span:nth-child(2){animation-delay:.2s}.ai-typing-dots span:nth-child(3){animation-delay:.4s}@keyframes ai-dot-pulse{0%,to{opacity:.3}50%{opacity:1}}.ai-cursor{animation:ai-blink .8s step-end infinite;color:var(--accent);font-weight:700}@keyframes ai-blink{50%{opacity:0}}.ai-error-badge{color:#ef4444;font-size:11px;font-style:italic}.ai-image-shimmer{position:relative;width:280px;max-width:100%;height:180px;border-radius:12px;background:var(--surface,var(--card));border:1px solid var(--border);overflow:hidden;display:flex;align-items:center;justify-content:center}.shimmer-glow{position:absolute;inset:0;background:linear-gradient(110deg,transparent 25%,rgba(255,255,255,.06) 37%,transparent 50%);background-size:200% 100%;animation:shimmer-sweep 1.8s ease-in-out infinite}[data-theme=light] .shimmer-glow{background:linear-gradient(110deg,transparent 25%,rgba(0,0,0,.04) 37%,transparent 50%);background-size:200% 100%}@keyframes shimmer-sweep{0%{background-position:200% 0}to{background-position:-200% 0}}.shimmer-content{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:10px}.shimmer-icon{font-size:24px;color:var(--accent);animation:shimmer-pulse 2s ease-in-out infinite}@keyframes shimmer-pulse{0%,to{opacity:.4;transform:scale(1)}50%{opacity:1;transform:scale(1.1)}}.shimmer-text{color:var(--text-muted);font-size:13px;font-weight:500}.ai-image-card{border-radius:12px;overflow:hidden;background:var(--surface,var(--card));border:1px solid var(--border);box-shadow:0 2px 12px rgba(0,0,0,.12);max-width:320px;animation:img-fade-in .4s ease}@keyframes img-fade-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.ai-image-frame{position:relative;line-height:0}.ai-image-preview{width:100%;display:block;cursor:pointer;transition:transform .2s ease,filter .2s ease}.ai-image-preview:hover{transform:scale(1.02);filter:brightness(1.05)}.ai-image-caption{padding:8px 12px;margin:0;color:var(--text-muted);font-size:12px;line-height:1.4;border-top:1px solid var(--border)}.ai-image-actions{display:flex;align-items:center;justify-content:flex-end;padding:4px 8px 8px}.file-image-name{flex:1 1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:11px;color:var(--text-muted)}.ai-image-download{background:none;border:1px solid var(--border);border-radius:6px;color:var(--text-muted);font-size:13px;padding:4px 8px;cursor:pointer;transition:all .15s ease;text-decoration:none;display:inline-flex;align-items:center}.ai-image-download:hover{color:var(--accent);border-color:var(--accent)}.ai-image-error{display:flex;align-items:center;color:#ef4444;font-size:13px;font-style:italic}.ai-lightbox-overlay{position:fixed;inset:0;z-index:10000;background:rgba(0,0,0,.88);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);display:flex;align-items:center;justify-content:center;padding:20px;animation:lb-fade-in .2s ease}@keyframes lb-fade-in{0%{opacity:0}to{opacity:1}}.ai-lightbox-content{position:relative;max-width:90vw;max-height:90vh;display:flex;flex-direction:column;align-items:center;animation:lb-scale-in .25s ease}@keyframes lb-scale-in{0%{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}.ai-lightbox-content img{max-width:100%;max-height:78vh;border-radius:12px;object-fit:contain;box-shadow:0 8px 40px rgba(0,0,0,.5)}.ai-lightbox-close{position:absolute;top:-12px;right:-12px;width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.15);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);color:#fff;border:none;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s ease;z-index:1}.ai-lightbox-close:hover{background:rgba(255,255,255,.3)}.ai-lightbox-caption{color:#d1d5db;margin:12px 0 0;text-align:center;max-width:600px;font-size:14px;line-height:1.4}.ai-lightbox-download{margin-top:12px;background:var(--accent);color:#fff;border:none;border-radius:8px;padding:8px 20px;font-size:14px;cursor:pointer;transition:opacity .15s ease;text-decoration:none;display:inline-flex;align-items:center}.ai-lightbox-download:hover{opacity:.85}[data-theme=light] .ai-image-card{box-shadow:0 2px 12px rgba(0,0,0,.08)}@media (max-width:768px){.ai-image-shimmer{width:100%}.ai-image-card{max-width:100%}.ai-lightbox-content{max-width:95vw}.ai-lightbox-close{top:-8px;right:-8px;width:32px;height:32px}}.chat-input-row,.chat-name-row{display:flex;gap:6px}.chat-input-row input{flex:1 1}.chat-settings-wrap{position:relative}.chat-settings-btn{width:34px;height:34px;padding:0;border-radius:6px;font-size:14px;display:flex;align-items:center;justify-content:center;background:var(--surface,var(--card));border:1px solid var(--border);color:var(--text-muted);cursor:pointer;transition:color .15s,border-color .15s}.chat-settings-btn:hover{color:var(--accent);border-color:var(--accent)}.chat-settings-popover{position:absolute;bottom:calc(100% + 8px);left:50%;transform:translateX(-50%);background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:10px 12px;box-shadow:0 4px 20px rgba(0,0,0,.2);z-index:100;min-width:180px;animation:settings-pop .15s ease}@keyframes settings-pop{0%{opacity:0;transform:translateX(-50%) translateY(4px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}.chat-settings-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);margin-bottom:8px}.chat-settings-pills{display:flex;gap:4px}.chat-settings-pill{flex:1 1;display:flex;flex-direction:column;align-items:center;gap:2px;padding:6px 4px;border-radius:8px;border:1px solid var(--border);background:var(--surface,var(--card));cursor:pointer;transition:all .15s ease}.chat-settings-pill:hover{border-color:var(--accent)}.chat-settings-pill.active{background:var(--accent);border-color:var(--accent);color:#fff}.chat-settings-pill .pill-label{font-size:12px;font-weight:600}.chat-settings-pill .pill-desc{font-size:10px;opacity:.7}.chat-settings-pill.active .pill-desc{opacity:.9}.emoji-btn{width:34px;height:34px;padding:0;border-radius:6px;font-size:18px;display:flex;align-items:center;justify-content:center;min-width:unset;flex-shrink:0;line-height:1}.emoji-picker{display:flex;flex-wrap:wrap;gap:2px;padding:6px;background:var(--surface2);border:1px solid var(--border);border-radius:8px}.emoji-item{width:32px;height:32px;padding:0;border:none;border-radius:4px;background:transparent;font-size:18px;display:flex;align-items:center;justify-content:center;cursor:pointer;min-width:unset}.emoji-item:hover{background:var(--border)}.notepad{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:12px;display:flex;flex-direction:column;gap:10px;flex:1 1;min-width:120px;min-height:0;overflow:hidden}.notepad h3{font-size:14px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.notepad-toolbar{display:flex;align-items:center;gap:3px;flex-wrap:wrap}.notepad-toolbar button{width:28px;height:26px;padding:0;border:none;border-radius:4px;background:transparent;color:var(--text);font-size:12px;display:flex;align-items:center;justify-content:center;cursor:pointer;min-width:unset}.notepad-toolbar button:hover{background:var(--surface2)}.notepad-toolbar-sep{width:1px;height:18px;background:var(--border);margin:0 2px;flex-shrink:0}.notepad-color-picker{position:absolute;top:100%;left:0;margin-top:4px;display:flex;gap:3px;padding:5px;background:var(--surface);border:1px solid var(--border);border-radius:6px;box-shadow:0 4px 12px rgba(0,0,0,.2);z-index:20}.notepad-color-swatch{width:18px;height:18px;border-radius:50%;padding:0;min-width:unset;cursor:pointer}.notepad-editor{flex:1 1;min-height:0;font-size:13px;padding:8px 10px;background:var(--surface);border:1px solid var(--border);border-radius:6px;color:var(--text);outline:none;overflow-y:auto;word-break:break-word;line-height:1.5}.notepad-editor:focus{border-color:var(--accent)}.notepad-editor:empty:before{content:attr(data-placeholder);color:var(--text-muted);pointer-events:none}.file-transfer{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:12px;display:flex;flex-direction:column;gap:10px}.file-transfer h3{font-size:14px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.file-pick-row{display:flex;flex-direction:column;align-items:flex-start;gap:8px}.file-pick-row input[type=file]{width:100%;min-width:0}.received-files{display:flex;flex-direction:column;gap:6px}.received-file{display:flex;align-items:center;justify-content:space-between;background:var(--surface2);border-radius:8px;padding:8px 12px;font-size:13px}.received-file a{color:var(--accent);text-decoration:none}.received-file a:hover{text-decoration:underline}.theme-toggle{top:12px;right:12px;width:36px;height:36px;border-radius:50%;align-items:center;justify-content:center;padding:0;font-size:18px;background:var(--surface2);border:1px solid var(--border);line-height:1;z-index:20}.media-controls,.theme-toggle{position:absolute;display:flex}.media-controls{top:8px;left:8px;flex-direction:column;gap:6px;z-index:10}.media-controls button{width:36px;height:36px;padding:0;border-radius:50%;font-size:14px;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.5);border-color:transparent;color:#fff;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.media-controls button:hover:not(:disabled){background:rgba(0,0,0,.7)}.media-controls button.off{background:var(--danger);border-color:transparent;color:#fff}.media-controls button.active{background:var(--accent);border-color:transparent;color:#fff}.copy-link-btn{font-size:13px;padding:4px 12px;border-radius:6px;display:inline-flex;align-items:center;gap:4px;white-space:nowrap}.copy-link-btn .copy-label{display:inline}.hangup-btn,.leave-btn{font-size:13px;padding:4px 12px;border-radius:6px;display:inline-flex;align-items:center;gap:4px;white-space:nowrap}.hangup-btn{background:var(--danger);border-color:var(--danger);color:#fff}.hangup-btn:hover:not(:disabled){background:#dc2626;border-color:#dc2626}@media (max-width:1300px){.copy-link-btn .copy-label,.hangup-label,.leave-label,.save-load-label{display:none}.copy-link-btn,.hangup-btn,.leave-btn,.save-load-btn{padding:4px 8px}}@media (max-width:768px){.theme-toggle{right:1px}.video-panel>div:first-child{padding-right:40px}.audio-placeholder .media-controls,.media-controls{left:auto;right:8px}.device-picker{left:auto;right:0}}.copy-link-icon{width:32px;height:32px;padding:0;border-radius:6px;font-size:13px;display:flex;align-items:center;justify-content:center}.spinner{width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}.image-overlay{position:absolute;background:transparent;border:2px solid transparent;cursor:-webkit-grab;cursor:grab;touch-action:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.image-overlay:hover{border-color:var(--accent)}.image-overlay-delete{position:absolute;top:2px;right:2px;width:18px;height:18px;padding:0;border:none;border-radius:50%;background:rgba(0,0,0,.5);color:#fff;font-size:11px;line-height:1;display:none;align-items:center;justify-content:center;cursor:pointer;min-width:unset}.image-overlay:hover .image-overlay-delete{display:flex}.image-resize-handle{position:absolute;bottom:0;right:0;width:14px;height:14px;cursor:nwse-resize;background:var(--accent);border-radius:2px 0;opacity:0;touch-action:none}.image-overlay:hover .image-resize-handle{opacity:1}.toggle-switch{display:flex;align-items:center;gap:6px;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.toggle-switch input{display:none}.toggle-slider{position:relative;width:34px;height:18px;background:var(--border);border-radius:9px;transition:background .2s;flex-shrink:0}.toggle-slider:after{content:"";position:absolute;top:2px;left:2px;width:14px;height:14px;background:#fff;border-radius:50%;transition:transform .2s}.toggle-switch input:checked+.toggle-slider{background:var(--accent)}.toggle-switch input:checked+.toggle-slider:after{transform:translateX(16px)}.toggle-label{font-size:12px;color:var(--text-muted)}.toggle-disabled{opacity:.4;cursor:not-allowed;pointer-events:none}.save-load-btn{font-size:13px;padding:4px 12px;border-radius:6px;display:inline-flex;align-items:center;gap:4px;white-space:nowrap}.more-menu-btn{padding:0;font-size:13px;display:flex;min-width:unset}@media (max-width:1024px){.more-menu-container{display:block}}.more-menu-dropdown{top:calc(100% + 4px);border-radius:8px;padding:4px;gap:2px;box-shadow:0 4px 12px rgba(0,0,0,.2)}.more-menu-dropdown button{gap:8px;border-radius:6px;white-space:nowrap}.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);display:flex;align-items:center;justify-content:center;z-index:100;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:20px;width:90%;max-width:400px;display:flex;flex-direction:column;gap:12px}.modal.modal-wide{max-width:520px}.modal h3{font-size:16px;margin:0}.modal form{display:flex;flex-direction:column;gap:10px}.modal-error{background:#7f1d1d;border:1px solid var(--danger);color:#fecaca;padding:6px 10px;border-radius:6px;font-size:13px}.modal-actions{display:flex;gap:8px;justify-content:flex-end}.password-prompt{display:flex;flex-direction:column;gap:8px;font-size:13px;padding:10px;background:var(--surface2);border-radius:8px}.password-prompt input{width:100%}.password-prompt-actions{display:flex;gap:8px}.saved-states-list{display:flex;flex-direction:column;gap:6px;max-height:320px;overflow-y:auto}.save-mode-toggle{display:grid;grid-template-columns:1fr 1fr;border:1px solid var(--border);border-radius:8px;overflow:hidden}.save-mode-toggle button{border:0;border-radius:0;background:var(--surface2);color:var(--text-muted);padding:8px 10px;font-size:13px}.save-mode-toggle button.active{background:var(--accent);color:#fff}.save-existing-row{display:flex;gap:8px}.save-existing-row select{flex:1 1;min-width:0}.saved-state-row{display:flex;align-items:center;justify-content:space-between;gap:8px;background:var(--surface2);border-radius:8px;padding:8px 12px}.saved-state-info{display:flex;flex-direction:column;gap:2px;min-width:0}.saved-state-name{font-weight:600;font-size:13px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.saved-state-date{font-size:11px;color:var(--text-muted)}.saved-state-actions{display:flex;gap:6px;flex-shrink:0}.saved-state-actions button{padding:4px 10px;font-size:12px}.start-call-btn{font-size:13px;padding:4px 12px;border-radius:6px;display:inline-flex;align-items:center;gap:4px;white-space:nowrap;background:var(--success);border-color:var(--success);color:#fff;font-weight:600}.start-call-btn:hover:not(:disabled){background:#16a34a;border-color:#16a34a}.start-call-btn.video{background:var(--accent);border-color:var(--accent)}.start-call-btn.video:hover:not(:disabled){background:var(--accent-hover);border-color:var(--accent-hover)}.call-requesting{display:flex;align-items:center;gap:8px}.call-requesting-text{font-size:13px;color:var(--text-muted);animation:pulse-text 1.5s ease-in-out infinite}@keyframes pulse-text{0%,to{opacity:1}50%{opacity:.4}}.cancel-call-btn{font-size:13px;padding:4px 12px;border-radius:6px;display:inline-flex;align-items:center;gap:4px;white-space:nowrap}.call-incoming{display:flex;align-items:center;gap:8px}.call-incoming-text{font-size:13px;font-weight:600;color:var(--success);animation:pulse-text 1.5s ease-in-out infinite}.accept-call-btn{font-size:13px;padding:4px 12px;border-radius:6px;display:inline-flex;align-items:center;gap:4px;white-space:nowrap;background:var(--success);border-color:var(--success);color:#fff}.accept-call-btn:hover:not(:disabled){background:#16a34a;border-color:#16a34a}.decline-call-btn{font-size:13px;padding:4px 12px;border-radius:6px;display:inline-flex;align-items:center;gap:4px;white-space:nowrap;background:var(--danger);border-color:var(--danger);color:#fff}.decline-call-btn:hover:not(:disabled){background:#dc2626;border-color:#dc2626}.call-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;width:100%;height:calc(76vh + 8px);background:var(--surface2);border-radius:8px;color:var(--text-muted);font-size:14px}.call-incoming-actions{display:flex;gap:12px;margin-top:4px}.incoming-call-modal-overlay{position:fixed;inset:0;z-index:60;background:rgba(2,6,23,.55);backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;padding:16px}.incoming-call-modal{width:min(420px,100%);background:var(--surface);border:1px solid var(--border);border-radius:14px;box-shadow:0 20px 48px rgba(0,0,0,.35);padding:20px 18px;display:flex;flex-direction:column;align-items:center;gap:12px;text-align:center}.incoming-call-modal h3{margin:0;font-size:20px}.incoming-call-modal p{margin:0;color:var(--text-muted);font-size:14px}.incoming-call-modal-actions{display:flex;gap:10px;width:100%;justify-content:center;margin-top:2px}.call-pulse{width:48px;height:48px;border-radius:50%;background:var(--accent);animation:call-ring 1.5s ease-in-out infinite}.call-pulse.incoming{background:var(--success)}@keyframes call-ring{0%{transform:scale(1);opacity:1}50%{transform:scale(1.3);opacity:.5}to{transform:scale(1);opacity:1}}@media (max-width:1024px){.accept-call-label,.cancel-call-label,.decline-call-label,.start-call-label{display:none}.accept-call-btn,.cancel-call-btn,.decline-call-btn,.start-call-btn{padding:4px 8px}}@media (max-width:768px){.call-placeholder{height:38vh}.incoming-call-modal{padding:18px 14px;border-radius:12px}.incoming-call-modal h3{font-size:18px}.incoming-call-modal-actions .accept-call-btn,.incoming-call-modal-actions .decline-call-btn{min-width:120px}}.chat.disabled,.file-transfer.disabled{opacity:.45;pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.attach-btn{width:34px;height:34px;padding:0;border-radius:6px;font-size:16px;display:flex;align-items:center;justify-content:center;min-width:unset;flex-shrink:0}.file-message .file-bubble{display:flex;align-items:center;gap:8px;font-size:13px}.file-message .file-bubble:has(.ai-image-card){display:block;padding:0;overflow:hidden}.file-download-link{color:var(--accent);text-decoration:none;font-weight:600;margin-left:auto}.file-download-link:hover{text-decoration:underline}.investing-widget{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:12px;display:flex;flex-direction:column;gap:8px;min-width:0;min-height:0;flex:1 1;overflow:hidden}.investing-widget h3{font-size:14px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin:0}.market-header{display:flex;align-items:center;justify-content:space-between;gap:6px;flex-wrap:wrap;min-width:0}.range-switcher{display:flex;gap:2px;background:var(--surface2);border-radius:6px;padding:2px;flex-shrink:0}.range-btn{padding:2px 8px;border:none;border-radius:4px;font-size:11px;font-weight:600;background:transparent;color:var(--text-muted);min-width:unset;cursor:pointer}.range-btn.active{background:var(--accent);color:#fff}.range-btn:hover:not(.active){color:var(--text)}.market-grid{display:grid;grid-template-columns:repeat(2,1fr);grid-gap:6px;gap:6px;flex:1 1;min-height:0;overflow-y:auto}@media (min-width:400px){.market-grid{grid-template-columns:repeat(3,1fr)}}.market-loading{grid-column:1/-1;color:var(--text-muted);text-align:center;padding:16px;font-size:13px}.market-card{background:var(--surface2);border-radius:8px;padding:6px 8px;display:flex;flex-direction:column;gap:1px;min-width:0;overflow:hidden}.market-card-top{display:flex;align-items:center;justify-content:space-between;gap:4px}.market-label{font-size:11px;color:var(--text-muted);font-weight:600;text-transform:uppercase}.market-label,.market-price{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.market-price{font-size:13px;font-weight:700}.market-change{font-size:11px;font-weight:600;white-space:nowrap;flex-shrink:0}.price-up{color:#22c55e}.price-down{color:#ef4444}.sparkline{display:block;width:100%;height:24px;margin-top:2px}.template-menu{position:absolute;top:100%;right:0;margin-top:4px;background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:4px;display:flex;flex-direction:column;gap:2px;z-index:20;min-width:160px;box-shadow:0 4px 12px rgba(0,0,0,.2)}.template-menu button{text-align:left;padding:6px 10px;border:none;border-radius:6px;font-size:13px;white-space:nowrap}.template-menu button:hover{background:var(--surface2)}.remote-cursor{position:absolute;pointer-events:none;z-index:15;transform:translate(-4px,-4px);transition:left .05s linear,top .05s linear}.remote-cursor-dot{width:8px;height:8px;border-radius:50%;background:#f59e0b;border:1.5px solid #fff;box-shadow:0 1px 4px rgba(0,0,0,.3)}.remote-cursor-label{position:absolute;left:12px;top:-2px;background:#f59e0b;color:#000;font-size:10px;font-weight:600;padding:1px 5px;border-radius:3px;white-space:nowrap;box-shadow:0 1px 3px rgba(0,0,0,.2)}.device-picker-container{position:relative}.device-picker{position:absolute;bottom:calc(100% + 8px);left:0;background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:10px 12px;display:flex;flex-direction:column;gap:10px;min-width:220px;box-shadow:0 4px 16px rgba(0,0,0,.3);z-index:200}.device-picker-label{display:flex;flex-direction:column;gap:4px;font-size:11px;color:var(--text-muted);font-weight:600;text-transform:uppercase;letter-spacing:.04em}.device-picker-label select{margin-top:2px;padding:5px 8px;border-radius:5px;border:1px solid var(--border);background:var(--surface2);color:var(--text);font-size:12px;cursor:pointer;width:100%}.device-picker-toggle{display:flex;align-items:center;justify-content:space-between;gap:8px;font-size:11px;color:var(--text-muted);font-weight:600;text-transform:uppercase;letter-spacing:.04em;padding:2px 0}.device-picker-toggle .toggle-switch{position:relative;width:32px;height:18px;background:var(--surface2);border:1px solid var(--border);border-radius:9px;cursor:pointer;flex-shrink:0;transition:background .2s}.device-picker-toggle .toggle-switch.on{background:var(--accent);border-color:var(--accent)}.device-picker-toggle .toggle-switch:after{content:"";position:absolute;top:2px;left:2px;width:12px;height:12px;border-radius:50%;background:#fff;transition:transform .2s}.device-picker-toggle .toggle-switch.on:after{transform:translateX(14px)}@media (max-width:768px){.notepad{width:100%;flex:none}.file-pick-row{flex-direction:row;align-items:center}.file-pick-row input[type=file]{flex:1 1;width:0}}.participant-selector{display:flex;border:1px solid var(--border);border-radius:8px;overflow:hidden;flex-shrink:0}.participant-pill{display:flex;align-items:center;gap:5px;padding:6px 10px;border:none;border-radius:0;background:var(--surface2);color:var(--text-muted);font-size:12px;font-weight:600;cursor:pointer;min-width:unset;transition:background .15s,color .15s}.participant-pill+.participant-pill{border-left:1px solid var(--border)}.participant-pill:hover:not(.active){background:var(--border)}.participant-pill.active{background:var(--accent);color:#fff}.participant-icons{display:flex;gap:2px;font-size:10px}.videos-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:8px;gap:8px}.video-cell{position:relative;transition:transform .25s ease,z-index 0s}.video-cell.speaking{transform:scale(1.03);z-index:2}.video-cell .audio-placeholder,.video-cell .no-remote,.video-cell .video-wrapper{height:300px}.video-cell.empty{border:2px dashed var(--border);border-radius:8px}.video-cell.empty .no-remote{background:transparent}@media (max-width:768px){.videos-grid{grid-template-columns:1fr}.video-cell .audio-placeholder,.video-cell .no-remote,.video-cell .video-wrapper{height:250px}.video-cell.speaking{transform:scale(1.02)}}.peer-status-chip{position:absolute;bottom:8px;right:8px;display:flex;flex-direction:column;gap:1px;font-size:11px;background:rgba(0,0,0,.55);border-radius:6px;padding:4px 8px;color:#fff;z-index:5}.save-load-desktop{display:inline-flex;align-items:center;gap:4px}.more-menu-container{display:none}.more-menu-btn{width:28px;padding:3.5px 8px;display:inline-flex;align-items:center;justify-content:center;font-size:14px;background:var(--surface);border:1px solid var(--border);border-radius:6px;color:var(--text);cursor:pointer}.more-menu-btn:hover{background:var(--surface2)}.more-menu-dropdown{position:absolute;top:100%;right:0;margin-top:4px;display:flex;flex-direction:column;min-width:120px;background:var(--surface);border:1px solid var(--border);border-radius:6px;box-shadow:0 4px 12px rgba(0,0,0,.25);z-index:30;overflow:hidden}.more-menu-dropdown button{display:flex;align-items:center;gap:6px;width:100%;padding:8px 12px;border:none;border-radius:0;background:none;color:var(--text);font-size:13px;cursor:pointer;text-align:left}.more-menu-dropdown button:hover{background:var(--surface2)}@media (max-width:700px){.save-load-desktop{display:none}.more-menu-container{display:block}}.room-password-input{padding:8px 10px;border:1px solid var(--border);border-radius:6px;background:var(--surface);color:var(--text);font-size:13px;outline:none}.room-password-input:focus{border-color:var(--accent)}.room-lock-icon{color:var(--text-muted);margin-right:6px;font-size:12px}.join-password-input{padding:6px 8px;border:1px solid var(--border);border-radius:6px;background:var(--surface);color:var(--text);font-size:13px;outline:none;width:140px}.join-password-input:focus{border-color:var(--accent)}.room-password-prompt{display:flex;flex-direction:column;align-items:center;gap:10px;margin-bottom:10px}.room-password-prompt .room-password-input{width:260px;max-width:100%;text-align:center}.peer-mic-off{position:absolute;bottom:10px;left:10px;background:rgba(0,0,0,.6);border-radius:50%;width:28px;height:28px;justify-content:center;font-size:13px;z-index:5}.peer-mic-off,.peer-mic-off-inline{color:var(--danger);display:flex;align-items:center}.peer-mic-off-inline{gap:4px;font-size:12px;margin-top:4px;opacity:.8}.lobby-error{display:flex;align-items:center;justify-content:center;gap:10px;padding:8px 16px;background:#7f1d1d;border:1px solid var(--danger);color:#fecaca;border-radius:8px;font-size:13px;margin:8px auto;max-width:480px}.lobby-error button{background:none;border:none;color:#fecaca;padding:2px 6px;font-size:14px;cursor:pointer;min-width:unset;opacity:.7}.lobby-error button:hover{opacity:1}.confirm-modal-overlay{position:fixed;inset:0;z-index:60;background:rgba(2,6,23,.55);backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;padding:16px}.confirm-modal{width:min(380px,100%);background:var(--surface);border:1px solid var(--border);border-radius:14px;box-shadow:0 20px 48px rgba(0,0,0,.35);padding:24px 20px;display:flex;flex-direction:column;align-items:center;gap:12px;text-align:center}.confirm-modal h3{margin:0;font-size:20px}.confirm-modal p{margin:0;color:var(--text-muted);font-size:14px;line-height:1.5}.confirm-modal-actions{display:flex;gap:10px;width:100%;justify-content:center;margin-top:4px}.confirm-cancel-btn{border-radius:8px;background:var(--surface2);border:1px solid var(--border);color:var(--text)}.confirm-cancel-btn,.confirm-close-btn{padding:10px 24px;font-size:14px;font-weight:600}.confirm-close-btn{border-radius:8px;background:var(--danger);border:1px solid var(--danger);color:#fff}.confirm-close-btn:hover:not(:disabled){background:#dc2626;border-color:#dc2626}.leave-btn.close-room{background:var(--danger);border-color:var(--danger);color:#fff}.leave-btn.close-room:hover:not(:disabled){background:#dc2626;border-color:#dc2626}@media (max-width:768px){.confirm-modal{padding:20px 16px;border-radius:12px}.confirm-modal-actions{flex-direction:column}.confirm-cancel-btn,.confirm-close-btn{width:100%;padding:12px}}.call-duration{font-size:11px;font-feature-settings:"tnum";font-variant-numeric:tabular-nums;color:var(--text-muted)}.chat-toast{position:fixed;left:50%;bottom:24px;transform:translateX(-50%);z-index:1200;padding:10px 14px;border-radius:12px;background:rgba(20,24,35,.94);color:#fff;font-size:13px;box-shadow:0 8px 22px rgba(0,0,0,.28);animation:toast-slide-in .2s ease-out}@keyframes toast-slide-in{0%{opacity:0;transform:translate(-50%,8px)}to{opacity:1;transform:translate(-50%)}}@keyframes rec-pulse{0%,to{opacity:1}50%{opacity:.3}}.rec-btn{color:#94a3b8}.rec-btn .fa-circle{font-size:10px}.rec-btn.pending{color:#f59e0b}.rec-btn.pending,.rec-btn.recording{animation:rec-pulse 1.2s ease-in-out infinite}.rec-btn.recording{color:#ef4444}.recording-indicator{display:flex;align-items:center;gap:5px;font-size:12px;font-weight:600;color:#ef4444;padding:2px 8px;border-radius:4px;background:rgba(239,68,68,.1)}.recording-indicator.pending{color:#f59e0b;background:rgba(245,158,11,.1)}.rec-dot{width:8px;height:8px;border-radius:50%;background:currentColor;animation:rec-pulse 1.2s ease-in-out infinite}.rec-duration{font-weight:400;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.recording-consent-overlay{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.5);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.recording-consent-modal{background:var(--bg);border:1px solid var(--border);border-radius:12px;padding:28px 32px;text-align:center;max-width:340px;width:90%;box-shadow:0 12px 40px rgba(0,0,0,.3)}.recording-consent-icon{font-size:28px;color:#ef4444;margin-bottom:12px;animation:rec-pulse 1.2s ease-in-out infinite}.recording-consent-modal h3{margin:0 0 8px;font-size:18px}.recording-consent-modal p{margin:0 0 20px;color:var(--text-muted);font-size:14px}.recording-consent-actions{display:flex;gap:10px;justify-content:center}.recording-consent-actions button{padding:8px 24px;font-size:14px;border-radius:6px;min-width:100px}.video-name-badge{position:absolute;bottom:8px;left:8px;background:rgba(0,0,0,.6);color:#fff;font-size:12px;padding:2px 8px;border-radius:4px;z-index:5;pointer-events:auto;max-width:calc(100% - 56px);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:inline-flex;align-items:center}.video-name-badge.local{cursor:pointer}.video-name-badge.local:hover{background:rgba(0,0,0,.8)}.peer-mic-icon{margin-left:6px;font-size:11px;color:var(--danger)}.video-name-input{background:transparent;border:none;color:#fff;font-size:12px;width:100px;outline:none;padding:0}.widget-container{display:flex;flex-direction:column;gap:0;min-height:0;overflow:hidden}.widget-switcher{display:flex;gap:0;margin-bottom:4px}.widget-tab{flex:1 1;padding:5px 10px;font-size:12px;border:1px solid var(--border);background:var(--bg);color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;gap:4px;transition:background .15s,color .15s}.widget-tab:first-child{border-radius:6px 0 0 6px}.widget-tab:last-child{border-radius:0 6px 6px 0}.widget-tab.active{background:var(--accent);color:#fff;border-color:var(--accent)}.widget-tab i{font-size:11px}.symbol-selector-btn{padding:4px 8px!important;font-size:12px}.symbol-selector-dropdown{position:absolute;right:0;top:100%;background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:8px;z-index:100;width:220px;max-width:calc(100vw - 32px);max-height:300px;overflow-y:auto;box-shadow:0 4px 12px rgba(0,0,0,.15)}.symbol-group{margin-bottom:6px}.symbol-group-label{font-size:10px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:2px;padding:2px 0}.symbol-option{display:flex;align-items:center;gap:6px;padding:2px 4px;font-size:12px;cursor:pointer;border-radius:4px}.symbol-option:hover{background:var(--bg)}.symbol-option input[type=checkbox]{width:14px;height:14px;margin:0;cursor:pointer}.news-widget{padding:8px;display:flex;flex-direction:column;flex:1 1;min-height:0;overflow:hidden}.news-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.news-header h3{margin:0;font-size:14px}.news-list{display:flex;flex-direction:column;gap:4px;flex:1 1;min-height:0;overflow-y:auto}.news-empty{color:var(--text-muted);text-align:center;padding:16px;font-size:13px}.news-item{display:flex;flex-direction:column;gap:2px;padding:6px 8px;border-radius:6px;text-decoration:none;color:var(--text);border:1px solid var(--border);transition:background .15s}.news-item:hover{background:var(--bg)}.news-title{font-size:12px;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.news-meta{display:flex;align-items:center;gap:8px;font-size:10px;color:var(--text-muted)}.news-source{font-weight:600}.news-time{opacity:.7}.vp-container{position:absolute;inset:0;z-index:6;pointer-events:none;will-change:transform}.video-paint-canvas{inset:0;width:100%;height:100%;touch-action:none;cursor:crosshair;border-radius:8px;transform:translateZ(0)}.video-paint-canvas,.vp-clear-btn{position:absolute;pointer-events:auto}.vp-clear-btn{bottom:6px;right:6px;z-index:1;background:rgba(0,0,0,.55);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);border:none;border-radius:6px;color:#ef4444;cursor:pointer;padding:4px 6px;font-size:12px;min-width:unset;opacity:.5;transition:opacity .15s}.vp-clear-btn:hover{opacity:1;color:#fca5a5}.vp-active-badge{position:absolute;top:6px;right:6px;z-index:1;pointer-events:none;background:rgba(0,0,0,.45);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);border-radius:4px;padding:2px 5px;font-size:10px;color:var(--accent);opacity:.6}.vp-clear-all-btn{background:none;border:1px solid var(--border);border-radius:5px;color:#ef4444;cursor:pointer;padding:2px 6px;font-size:11px;min-width:unset;opacity:.7;transition:opacity .15s;margin-left:4px}.vp-clear-all-btn:hover{opacity:1;background:rgba(239,68,68,.1)}@media (max-width:1000px){.vp-container{display:none}}.pip-container{position:fixed;z-index:1000;display:flex;gap:10px;align-items:flex-end;pointer-events:none;transition:inset .3s ease;-webkit-user-select:none;-moz-user-select:none;user-select:none;animation:pip-fade-in .25s ease}.pip-container.pip-br{inset:auto 16px 16px auto}.pip-container.pip-bl{inset:auto auto 16px 16px}.pip-container.pip-tl{inset:16px auto auto 16px}.pip-container.pip-tr{inset:16px 16px auto auto}@keyframes pip-fade-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.pip-bubble{pointer-events:auto;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:4px;transition:transform .15s ease;touch-action:manipulation;-webkit-touch-callout:none}.pip-bubble:hover{transform:scale(1.08)}.pip-bubble:active{transform:scale(.95)}.pip-bubble .pip-bubble-initial,.pip-bubble .pip-bubble-video{width:84px;height:84px;border-radius:50%;object-fit:cover;border:2px solid var(--border);box-shadow:0 2px 12px rgba(0,0,0,.35);transition:border-color .2s ease,box-shadow .2s ease;background:var(--surface2)}.pip-bubble .pip-bubble-initial{display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:700;color:var(--text-muted)}.pip-bubble.speaking .pip-bubble-initial,.pip-bubble.speaking .pip-bubble-video{border-color:#22c55e;box-shadow:0 0 12px rgba(34,197,94,.5),0 2px 12px rgba(0,0,0,.35)}.pip-bubble-name{font-size:10px;color:#fff;background:rgba(0,0,0,.55);padding:1px 6px;border-radius:6px;max-width:72px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:center}@media (max-width:768px){.pip-container.pip-br{inset:auto 12px 12px auto}.pip-container.pip-bl{inset:auto auto 12px 12px}.pip-container.pip-tl{inset:12px auto auto 12px}.pip-container.pip-tr{inset:12px 12px auto auto}.pip-container{gap:8px}.pip-bubble .pip-bubble-initial,.pip-bubble .pip-bubble-video{width:50px;height:50px}.pip-bubble .pip-bubble-initial{font-size:18px}.pip-bubble-name{font-size:9px;max-width:60px}}