@import "https://fonts.googleapis.com/css2?family=Syne:wght@400;500;600;700&family=DM+Sans:wght@300;400;500&display=swap";:root{--bg:#0a0d14;--surface:#111827;--surface2:#1a2235;--border:#ffffff12;--border-hi:#ffffff24;--accent:#3b82f6;--accent-glow:#3b82f64d;--green:#22c55e;--red:#ef4444;--text:#f1f5f9;--text-muted:#64748b;--text-dim:#334155;--radius:12px;--radius-sm:8px;--ctrl-h:72px;--header-h:52px;--panel-w:320px;--font-display:"Syne", sans-serif;--font-body:"DM Sans", sans-serif}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{width:100%;height:100%;overflow:hidden}body{font-family:var(--font-body);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased}button{cursor:pointer;background:0 0;border:none;font-family:inherit}input,textarea,select{background:var(--surface2);border:1px solid var(--border);color:var(--text);border-radius:var(--radius-sm);outline:none;width:100%;padding:10px 14px;font-family:inherit;transition:border-color .2s}input:focus,textarea:focus,select:focus{border-color:var(--accent)}select option{background:var(--surface2)}.app{flex-direction:column;height:100%;display:flex;position:relative}.reconnect-banner{z-index:9999;color:#fef3c7;text-align:center;background:#92400e;padding:8px;font-size:13px;font-weight:500;position:fixed;top:0;left:0;right:0}.lobby{background:radial-gradient(ellipse 80% 60% at 20% 40%, #3b82f614 0%, transparent 70%), radial-gradient(ellipse 60% 80% at 80% 70%, #6366f10f 0%, transparent 70%), var(--bg);justify-content:center;align-items:center;height:100%;display:flex}.lobby-card{border:1px solid var(--border-hi);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#111827e6;border-radius:20px;gap:40px;width:90%;max-width:820px;padding:40px;display:flex;box-shadow:0 40px 80px #00000080}.lobby-preview{border-radius:var(--radius);background:var(--surface2);flex:1;justify-content:center;align-items:center;min-height:260px;display:flex;position:relative;overflow:hidden}.lobby-preview video{object-fit:cover;border-radius:var(--radius);width:100%;height:100%;transform:scaleX(-1)}.preview-error{color:var(--text-muted);text-align:center;padding:20px;font-size:13px}.preview-label{color:var(--text-muted);letter-spacing:.08em;text-transform:uppercase;background:#00000080;border-radius:20px;padding:3px 10px;font-size:11px;position:absolute;bottom:10px;left:50%;transform:translate(-50%)}.lobby-form{flex-direction:column;flex:1;justify-content:center;gap:12px;display:flex}.logo{font-family:var(--font-display);color:var(--text);align-items:center;gap:10px;margin-bottom:8px;font-size:20px;font-weight:700;display:flex}.lobby-form h1{font-family:var(--font-display);font-size:26px;font-weight:700;line-height:1.2}.lobby-form p{color:var(--text-muted);margin-bottom:4px;font-size:14px}.lobby-form label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-top:4px;font-size:12px;font-weight:500}.room-id-row{gap:8px;display:flex}.room-id-row input{font-family:var(--font-display);letter-spacing:.12em;flex:1}.copy-btn{border-radius:var(--radius-sm);border:1px solid var(--border);color:var(--text-muted);background:var(--surface2);padding:10px 12px;transition:all .2s}.copy-btn:hover{border-color:var(--accent);color:var(--accent)}.join-btn{border-radius:var(--radius-sm);background:var(--accent);color:#fff;font-family:var(--font-display);box-shadow:0 4px 20px var(--accent-glow);margin-top:8px;padding:14px;font-size:15px;font-weight:600;transition:all .2s}.join-btn:hover:not(:disabled){box-shadow:0 8px 30px var(--accent-glow);background:#2563eb;transform:translateY(-1px)}.join-btn:disabled{opacity:.4;cursor:not-allowed}.lobby-tabs{background:var(--surface2);border-radius:var(--radius-sm);gap:0;margin:2px 0 4px;padding:3px;display:flex}.lobby-tab{color:var(--text-muted);font-size:13px;font-weight:500;font-family:var(--font-body);border-radius:6px;flex:1;padding:8px 12px;transition:all .18s}.lobby-tab.active{background:var(--surface);color:var(--text);box-shadow:0 1px 4px #0000004d}.lobby-tab:hover:not(.active){color:var(--text)}.room-id-input{font-family:var(--font-display);letter-spacing:.12em;color:var(--accent);cursor:default;-webkit-user-select:all;user-select:all}.room-share-hint{color:var(--text-dim);margin-top:-4px;font-size:11px}.lobby-footer{color:var(--text-dim);text-align:center;margin-top:4px;font-size:11px}.room{background:var(--bg);flex-direction:column;height:100%;display:flex}.room-header{height:var(--header-h);border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:10;background:#0a0d14e6;flex-shrink:0;justify-content:space-between;align-items:center;padding:0 20px;display:flex}.logo-sm{font-family:var(--font-display);align-items:center;gap:8px;font-size:16px;font-weight:700;display:flex}.room-info{align-items:center;gap:10px;display:flex}.room-id-tag{color:var(--text-muted);font-size:12px;font-family:var(--font-display);letter-spacing:.06em}.copy-room-btn{border:1px solid var(--border);color:var(--text-muted);border-radius:20px;padding:4px 10px;font-size:11px;transition:all .2s}.copy-room-btn:hover{border-color:var(--accent);color:var(--accent)}.room-body{flex:1;min-height:0;display:flex;overflow:hidden}.video-grid{grid-template-columns:repeat(var(--grid-cols,1), 1fr);flex:1;align-content:center;gap:8px;padding:12px;display:grid;overflow:auto}.video-tile{border-radius:var(--radius);background:var(--surface);aspect-ratio:16/9;border:2px solid #0000;transition:border-color .2s;position:relative;overflow:hidden}.video-tile.speaking{border-color:var(--green)}.video-tile.screen-share{aspect-ratio:16/9;grid-column:1/-1}.speaking-ring{border-radius:var(--radius);border:2px solid var(--green);pointer-events:none;z-index:2;animation:1.5s ease-in-out infinite pulse-ring;position:absolute;inset:0}@keyframes pulse-ring{0%,to{opacity:1}50%{opacity:.4}}.video-tile video{object-fit:cover;width:100%;height:100%;display:block}.avatar-fallback{background:linear-gradient(135deg, var(--surface2), var(--surface));justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.avatar-fallback span{background:var(--accent);width:64px;height:64px;font-family:var(--font-display);color:#fff;border-radius:50%;justify-content:center;align-items:center;font-size:22px;font-weight:700;display:flex}.tile-label{z-index:3;background:linear-gradient(#0000,#000000b3);justify-content:space-between;align-items:center;padding:8px 12px;display:flex;position:absolute;bottom:0;left:0;right:0}.tile-name{color:#fff;align-items:center;gap:6px;font-size:13px;font-weight:500;display:flex}.host-badge{text-transform:uppercase;letter-spacing:.08em;background:var(--accent);color:#fff;border-radius:4px;padding:2px 6px;font-size:9px;font-weight:700}.tile-icons{color:var(--red);gap:4px;display:flex}.controls-bar{height:var(--ctrl-h);border-top:1px solid var(--border);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);z-index:20;background:#0a0d14f5;flex-shrink:0;justify-content:space-between;align-items:center;padding:0 24px;display:flex;position:relative}.controls-left{min-width:140px}.controls-right{justify-content:flex-end;min-width:140px;display:flex}.controls-center{align-items:center;gap:8px;display:flex}.room-time{color:var(--text-muted);font-size:13px;font-family:var(--font-display)}.ctrl-btn{border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface);color:var(--text);align-items:center;gap:7px;padding:10px 14px;font-size:13px;font-weight:500;transition:all .18s;display:flex;position:relative}.ctrl-btn:hover{background:var(--surface2);border-color:var(--border-hi)}.ctrl-btn.active{border-color:var(--accent);color:var(--accent);background:#3b82f61f}.ctrl-btn.active-danger{border-color:var(--red);color:var(--red);background:#ef44441a}.ctrl-btn.active-green{border-color:var(--green);color:var(--green);background:#22c55e1a}.badge{background:var(--red);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:18px;height:18px;font-size:10px;font-weight:700;display:flex;position:absolute;top:-6px;right:-6px}.leave-btn{color:var(--red);background:#ef444426;border-color:#ef44444d;padding:10px 20px}.leave-btn:hover{background:var(--red);color:#fff;border-color:var(--red)}.host-ctrl-btn{border-radius:var(--radius-sm);color:#fbbf24;background:#facc151a;border:1px solid #facc154d;padding:8px 16px;font-size:12px;font-weight:600;transition:all .2s}.host-ctrl-btn:hover{background:#facc1533}.settings-panel{bottom:calc(var(--ctrl-h) + 10px);background:var(--surface);border:1px solid var(--border-hi);border-radius:var(--radius);z-index:100;flex-direction:column;gap:10px;width:320px;padding:20px;display:flex;position:absolute;left:50%;transform:translate(-50%);box-shadow:0 20px 50px #00000080}.settings-panel h3{font-family:var(--font-display);margin-bottom:4px;font-size:15px;font-weight:600}.settings-panel label{text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin-top:4px;font-size:11px}.side-panel{width:var(--panel-w);border-left:1px solid var(--border);background:var(--surface);flex-direction:column;flex-shrink:0;display:flex;overflow:hidden}.panel-header{border-bottom:1px solid var(--border);flex-shrink:0;align-items:center;gap:10px;padding:16px 20px;display:flex}.panel-header h2{font-family:var(--font-display);flex:1;font-size:15px;font-weight:600}.count-badge{background:var(--surface2);color:var(--text-muted);border-radius:20px;padding:2px 9px;font-size:12px;font-weight:600}.messages-list{scrollbar-width:thin;scrollbar-color:var(--surface2) transparent;flex-direction:column;flex:1;gap:12px;padding:16px;display:flex;overflow-y:auto}.empty-state{text-align:center;color:var(--text-dim);margin-top:40px;font-size:13px}.message{flex-direction:column;max-width:85%;display:flex}.message-me{align-self:flex-end;align-items:flex-end}.message-them{align-self:flex-start;align-items:flex-start}.msg-author{color:var(--text-muted);margin-bottom:3px;font-size:11px}.msg-bubble{word-break:break-word;border-radius:16px;padding:9px 13px;font-size:13px;line-height:1.5}.message-me .msg-bubble{background:var(--accent);color:#fff;border-bottom-right-radius:4px}.message-them .msg-bubble{background:var(--surface2);color:var(--text);border-bottom-left-radius:4px}.msg-time{color:var(--text-dim);margin-top:3px;font-size:10px}.chat-input-row{border-top:1px solid var(--border);flex-shrink:0;align-items:flex-end;gap:8px;padding:12px 16px;display:flex}.chat-input-row textarea{resize:none;border-radius:var(--radius-sm);flex:1;padding:9px 12px;font-size:13px;line-height:1.5}.chat-input-row button{border-radius:var(--radius-sm);background:var(--accent);color:#fff;flex-shrink:0;padding:9px 12px;transition:all .2s}.chat-input-row button:hover:not(:disabled){background:#2563eb}.chat-input-row button:disabled{opacity:.35;cursor:not-allowed}.participants-list{flex-direction:column;flex:1;gap:2px;padding:8px 12px;list-style:none;display:flex;overflow-y:auto}.participant-item{border-radius:var(--radius-sm);align-items:center;gap:12px;padding:10px;transition:background .15s;display:flex}.participant-item:hover{background:var(--surface2)}.participant-avatar{background:linear-gradient(135deg, var(--accent), #6366f1);width:36px;height:36px;font-family:var(--font-display);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:14px;font-weight:700;display:flex}.participant-info{flex:1;min-width:0}.participant-name{white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:500;display:block;overflow:hidden}.participant-badges{flex-wrap:wrap;gap:4px;margin-top:3px;display:flex}.badge-host{color:var(--accent);text-transform:uppercase;background:#3b82f633;border-radius:4px;padding:1px 6px;font-size:9px;font-weight:700}.badge-muted{color:var(--red);background:#ef444426;border-radius:4px;padding:1px 6px;font-size:9px}.badge-video{color:var(--text-muted);background:#64748b33;border-radius:4px;padding:1px 6px;font-size:9px}.host-actions{gap:6px;display:flex}.action-btn{border:1px solid var(--border);background:var(--surface2);width:28px;height:28px;color:var(--text-muted);border-radius:6px;justify-content:center;align-items:center;transition:all .15s;display:flex}.action-btn:hover{border-color:var(--border-hi);color:var(--text)}.action-btn.danger:hover{border-color:var(--red);color:var(--red);background:#ef44441a}.loading-screen,.error-screen{background:var(--bg);flex-direction:column;justify-content:center;align-items:center;gap:16px;height:100%;display:flex}.spinner{border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:40px;height:40px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.loading-screen p{color:var(--text-muted);font-size:14px}.error-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);text-align:center;flex-direction:column;align-items:center;gap:16px;max-width:400px;padding:40px;display:flex}.error-card h2{font-family:var(--font-display);font-size:20px}.error-card p{color:var(--text-muted);font-size:14px;line-height:1.6}.error-card button{border-radius:var(--radius-sm);background:var(--accent);color:#fff;font-family:var(--font-display);padding:12px 28px;font-weight:600;transition:all .2s}.error-card button:hover{background:#2563eb}@media (width<=900px){.lobby-card{flex-direction:column;gap:24px;max-width:480px;margin:0 16px;padding:28px 24px}.lobby-preview{border-radius:var(--radius);min-height:200px}.side-panel{top:var(--header-h);right:0;bottom:var(--ctrl-h);width:min(var(--panel-w), 100vw);z-index:50;animation:.22s slide-in-right;position:fixed;box-shadow:-8px 0 32px #0006}@keyframes slide-in-right{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}.settings-panel{bottom:var(--ctrl-h);border-radius:var(--radius) var(--radius) 0 0;width:100%;max-height:70vh;animation:.22s slide-up;position:fixed;left:0;right:0;overflow-y:auto;transform:none}@keyframes slide-up{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}.ctrl-btn{padding:9px 11px}.ctrl-divider,.controls-left .room-time,.leave-btn span,.controls-right{display:none}}@media (width<=600px){:root{--ctrl-h:60px;--header-h:48px;--panel-w:100vw}.lobby{align-items:flex-start;padding-top:0}.lobby-card{border-top:none;border-left:none;border-right:none;border-radius:0;flex-direction:column;gap:20px;max-width:100%;min-height:100%;margin:0;padding:20px 16px 32px;overflow-y:auto}.lobby-preview{border-radius:var(--radius);min-height:220px}.lobby-preview video{object-position:center top}.lobby-form h1{font-size:22px}.join-btn{padding:16px;font-size:16px}.room-header{height:var(--header-h);padding:0 12px}.logo-sm span,.participant-count-tag{display:none}.room-id-tag{font-size:11px}.video-grid{gap:5px;padding:6px;grid-template-columns:repeat(min(var(--grid-cols,1), 2), 1fr)!important}.video-tile.screen-share{grid-column:1/-1}.tile-label{padding:6px 8px}.tile-name{font-size:11px}.controls-bar{height:var(--ctrl-h);scrollbar-width:none;padding:0 8px;overflow:auto hidden}.controls-bar::-webkit-scrollbar{display:none}.controls-left,.controls-right{display:none}.controls-center{justify-content:space-around;gap:4px;width:100%}.ctrl-btn{border-radius:var(--radius-sm);flex-direction:column;gap:3px;min-width:44px;padding:8px;font-size:10px}.ctrl-btn .mobile-label{color:inherit;font-size:9px;line-height:1;display:block}.leave-btn{flex-direction:column;gap:3px;padding:8px}.leave-btn span{font-size:9px;display:block}.side-panel{inset:0;bottom:var(--ctrl-h);top:var(--header-h);border-left:none;border-top:1px solid var(--border);z-index:60;width:100%;animation:.25s cubic-bezier(.32,.72,0,1) slide-up-mobile;position:fixed}@keyframes slide-up-mobile{0%{transform:translateY(100%)}to{transform:translateY(0)}}.panel-header{padding:14px 16px}.panel-header h2{font-size:14px}.messages-list{gap:10px;padding:12px}.msg-bubble{padding:8px 11px;font-size:13px}.chat-input-row{gap:6px;padding:10px 12px}.chat-input-row textarea{font-size:14px}.settings-panel{bottom:var(--ctrl-h);border-radius:var(--radius) var(--radius) 0 0;z-index:80;width:100%;max-height:65vh;animation:.25s cubic-bezier(.32,.72,0,1) slide-up-mobile;position:fixed;top:auto;left:0;right:0;overflow-y:auto;transform:none}.settings-panel select{font-size:16px}.recording-body{gap:12px;padding:12px}.rec-timer{font-size:18px}.rec-preview{max-height:130px}.recording-topbar{font-size:11px}}@media (width<=380px){.ctrl-btn{min-width:38px;padding:6px}.ctrl-btn svg{width:18px;height:18px}.ctrl-btn .mobile-label{display:none}.video-grid{padding:4px;grid-template-columns:1fr!important}}@media (hover:none) and (pointer:coarse){.ctrl-btn,.copy-btn{min-width:44px;min-height:44px}.join-btn{min-height:52px}.action-btn{min-width:36px;min-height:36px}.ctrl-btn:hover{background:var(--surface);border-color:var(--border)}.join-btn:hover{transform:none}button{touch-action:manipulation}.participant-item:hover{background:0 0}}.recording-topbar{z-index:9998;color:#fca5a5;letter-spacing:.04em;background:#ef444426;border-bottom:1px solid #ef44444d;justify-content:center;align-items:center;gap:8px;height:28px;font-size:12px;font-weight:600;display:flex;position:fixed;top:0;left:0;right:0}.rec-dot-sm{background:var(--red);border-radius:50%;width:8px;height:8px;animation:1.2s ease-in-out infinite rec-blink}@keyframes rec-blink{0%,to{opacity:1}50%{opacity:.2}}.room:has(.recording-topbar) .room-header{top:28px}.ctrl-btn.active-rec{border-color:var(--red);color:var(--red);background:#ef44441f;position:relative}.rec-badge-dot{background:var(--red);border-radius:50%;width:7px;height:7px;animation:1.2s ease-in-out infinite rec-blink;position:absolute;top:6px;right:6px}.ctrl-divider{background:var(--border);width:1px;height:28px;margin:0 4px}.participant-count-tag{color:var(--text-muted);background:var(--surface2);border:1px solid var(--border);border-radius:20px;align-items:center;gap:5px;padding:3px 10px;font-size:12px;display:flex}.recording-panel{min-width:var(--panel-w);max-width:var(--panel-w)}.recording-body{flex-direction:column;flex:1;gap:14px;padding:16px;display:flex;overflow-y:auto}.rec-live-badge{text-transform:uppercase;letter-spacing:.08em;color:var(--red);background:#ef44441f;border:1px solid #ef444440;border-radius:20px;align-items:center;gap:6px;padding:3px 9px;font-size:10px;font-weight:700;display:flex}.rec-dot{background:var(--red);border-radius:50%;width:6px;height:6px;animation:1.2s ease-in-out infinite rec-blink}.rec-status-card{border-radius:var(--radius);background:var(--surface2);border:1px solid var(--border);align-items:center;gap:14px;padding:16px;transition:all .25s;display:flex}.rec-status-card.active{background:#ef44440f;border-color:#ef444459}.rec-icon-wrap{color:var(--text-muted);flex-shrink:0}.rec-status-card.active .rec-icon-wrap{color:var(--red)}.rec-status-text{flex-direction:column;gap:4px;display:flex}.rec-status-label{color:var(--text);font-size:13px;font-weight:600}.rec-timer{font-size:22px;font-weight:700;font-family:var(--font-display);color:var(--red);letter-spacing:.04em}.rec-status-sub{color:var(--text-muted);font-size:12px}.rec-info-box{border-radius:var(--radius-sm);color:var(--text-muted);background:#3b82f60f;border:1px solid #3b82f626;align-items:flex-start;gap:8px;padding:12px;font-size:12px;line-height:1.6;display:flex}.rec-info-box svg{color:var(--accent);flex-shrink:0;margin-top:1px}.rec-start-btn{border-radius:var(--radius-sm);color:var(--red);font-size:14px;font-weight:600;font-family:var(--font-display);background:#ef44441f;border:1px solid #ef44444d;justify-content:center;align-items:center;gap:8px;padding:13px;transition:all .2s;display:flex}.rec-start-btn:hover{background:var(--red);color:#fff;border-color:var(--red);box-shadow:0 4px 20px #ef44444d}.rec-stop-btn{border-radius:var(--radius-sm);background:var(--red);border:1px solid var(--red);color:#fff;font-size:14px;font-weight:600;font-family:var(--font-display);justify-content:center;align-items:center;gap:8px;padding:13px;transition:all .2s;animation:2s ease-in-out infinite rec-pulse-btn;display:flex}@keyframes rec-pulse-btn{0%,to{box-shadow:0 0 #ef444466}50%{box-shadow:0 0 0 8px #ef444400}}.rec-stop-btn:hover{background:#dc2626}.rec-download-section{border-radius:var(--radius);background:#22c55e0d;border:1px solid #22c55e40;flex-direction:column;gap:12px;padding:14px;display:flex}.rec-download-header{color:var(--green);align-items:center;gap:8px;font-size:13px;font-weight:600;display:flex}.rec-filesize{color:var(--text-muted);background:var(--surface2);border-radius:20px;margin-left:auto;padding:2px 8px;font-size:11px;font-weight:400}.rec-preview{border-radius:var(--radius-sm);object-fit:contain;background:#000;width:100%;max-height:160px}.rec-download-actions{gap:8px;display:flex}.rec-download-btn{border-radius:var(--radius-sm);background:var(--green);color:#fff;font-size:13px;font-weight:600;font-family:var(--font-display);flex:1;justify-content:center;align-items:center;gap:7px;padding:10px;transition:all .2s;display:flex}.rec-download-btn:hover{background:#16a34a}.rec-dismiss-btn{border-radius:var(--radius-sm);border:1px solid var(--border);color:var(--text-muted);background:var(--surface2);padding:10px 16px;font-size:13px;transition:all .2s}.rec-dismiss-btn:hover{border-color:var(--red);color:var(--red)}
