:root{--font-family:system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono:ui-monospace, "SFMono-Regular", "SF Mono", Menlo, Monaco, Consolas, monospace;--color-bg:#0b0d10;--color-bg-top:#0b0d10;--color-surface:#121417;--color-surface-muted:#1a1d22;--color-surface-hover:#23272e;--color-text:#e2e8f0;--color-text-muted:#94a3b8;--color-accent:#1665d8;--color-accent-strong:#60a5fa;--color-accent-soft:#60a5fa38;--color-border:#2b3038;--color-border-strong:#3a414d;--color-on-accent:#fff;--focus-ring:0 0 0 2px #60a5fa57;--shadow-overlay:0 20px 48px #02061780;--color-primary:var(--color-accent);--color-primary-light:var(--color-accent-strong);--color-primary-dark:#1e40af;--color-success:#10b981;--color-danger:#ef4444;--color-danger-light:#f87171;--color-warning:#f59e0b;--color-dark:var(--color-bg);--color-dark-lighter:var(--color-surface);--color-dark-tertiary:var(--color-surface-muted);--color-light:#f4f6f9;--color-gray:#64748b;--color-gray-light:var(--color-text-muted);--text-dark:#1e293b;--text-light:var(--color-text);--text-secondary:var(--color-text-muted);--bg-primary:var(--color-bg);--bg-secondary:var(--color-surface);--bg-tertiary:var(--color-surface-muted);--text:var(--color-text);--accent:var(--color-accent);--accent-hover:var(--color-accent-strong);--danger:var(--color-danger);--border:var(--color-border);--hover-bg:var(--color-surface-hover);--input-bg:var(--color-surface-muted);--input-border:var(--color-border);--shadow:#02061780;--radius:8px;--radius-lg:12px;--radius-full:9999px;--space-xs:.5rem;--space-s:.75rem;--space-m:1rem;--space-l:1.5rem;--space-xl:2rem;--space-xxl:3rem;--transition:.2s cubic-bezier(.4, 0, .2, 1);--transition-slow:.3s cubic-bezier(.4, 0, .2, 1);color-scheme:dark}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-family);background:linear-gradient(180deg, var(--color-bg-top), var(--color-bg));color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh;line-height:1.5}.hidden{display:none!important}.screen{min-height:100vh;padding:var(--space-l);flex-direction:column;justify-content:center;align-items:center;display:flex}.container{text-align:center;width:100%;max-width:440px}h1{background:linear-gradient(135deg, var(--accent), var(--accent-hover));-webkit-text-fill-color:transparent;letter-spacing:-.03em;-webkit-background-clip:text;background-clip:text;margin-bottom:.5rem;font-size:3rem;font-weight:800}.subtitle{color:var(--text-secondary);margin-bottom:var(--space-xxl);font-size:1rem;font-weight:400}.landing-view{animation:.3s fadeIn}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.name-input-group{margin-bottom:var(--space-xl)}.name-input-group input{width:100%;height:56px;padding:0 var(--space-l);background:var(--input-bg);border:1px solid var(--input-border);border-radius:var(--radius);color:var(--text);transition:all var(--transition);text-align:center;font-size:1.125rem}.name-input-group input::placeholder{color:var(--text-secondary)}.name-input-group input:hover{background:#ffffff0f;border-color:#ffffff26}.name-input-group input:focus{border-color:var(--accent);background:#ffffff0f;outline:none;box-shadow:0 0 0 3px #6366f11a}.action-buttons{gap:var(--space-m);margin-bottom:var(--space-l);flex-direction:column;display:flex}.btn{justify-content:center;align-items:center;gap:var(--space-xs);padding:0 var(--space-l);background:var(--bg-tertiary);height:48px;color:var(--text);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;transition:all var(--transition);white-space:nowrap;font-size:1rem;font-weight:500;display:inline-flex}.btn:hover{background:var(--hover-bg);border-color:#ffffff26}.btn:active{transform:scale(.98)}.btn:disabled{opacity:.4;cursor:not-allowed;pointer-events:none}.btn-large{height:56px;font-size:1.0625rem}.btn-primary{background:var(--accent);border-color:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-hover);border-color:var(--accent-hover);box-shadow:0 4px 12px #6366f14d}.btn-secondary{border-color:var(--border);color:var(--text);background:0 0}.btn-secondary:hover{background:var(--hover-bg);border-color:#fff3}.btn-link{color:var(--text-secondary);padding:var(--space-xs);cursor:pointer;background:0 0;border:none;height:auto;font-size:.875rem;text-decoration:none}.btn-link:hover{color:var(--text);background:0 0}.join-form-simple{margin-bottom:var(--space-l)}.form-group-inline{gap:var(--space-s);display:flex}.form-group-inline input{min-width:0;height:48px;padding:0 var(--space-l);background:var(--input-bg);border:1px solid var(--input-border);border-radius:var(--radius);color:var(--text);transition:all var(--transition);flex:1;font-size:1rem}.form-group-inline input:focus{border-color:var(--accent);background:#ffffff0f;outline:none}.form-group-inline .btn{flex-shrink:0}.landing-advanced{margin-top:var(--space-l);padding-top:var(--space-l);border-top:1px solid var(--border);animation:.3s fadeIn}.advanced-content{gap:var(--space-m);flex-direction:column;display:flex}.form-group-compact input{width:100%;height:44px;padding:0 var(--space-m);background:var(--input-bg);border:1px solid var(--input-border);border-radius:var(--radius);color:var(--text);transition:all var(--transition);font-size:.9375rem}.form-group-compact input::placeholder{color:var(--text-secondary)}.form-group-compact input:focus{border-color:var(--accent);background:#ffffff0f;outline:none}.form-grid-compact{gap:var(--space-s);grid-template-columns:minmax(0,1fr) 96px;display:grid}.form-grid-compact input{min-width:0;height:44px;padding:0 var(--space-m);background:var(--input-bg);border:1px solid var(--input-border);border-radius:var(--radius);color:var(--text);transition:all var(--transition);font-size:.9375rem}.form-grid-compact input:focus{border-color:var(--accent);background:#ffffff0f;outline:none}.meeting-created{align-items:center;gap:var(--space-l);flex-direction:column;display:flex}.created-icon{width:64px;height:64px;color:var(--color-success);background:#10b98126;border-radius:50%;justify-content:center;align-items:center;font-size:2rem;font-weight:600;display:flex}.meeting-created h3{color:var(--text);font-size:1.5rem;font-weight:600}.created-details{width:100%;padding:var(--space-s) var(--space-m);background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-secondary);text-align:left;gap:4px;font-size:.875rem;display:grid}.created-details p:first-child{color:var(--text);font-weight:600}.share-link-group{gap:var(--space-s);width:100%;padding:var(--space-m);background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius);display:flex}.share-link-group input{min-width:0;color:var(--text-secondary);background:0 0;border:none;outline:none;flex:1;font-family:monospace;font-size:.875rem}.btn-icon-inline{color:var(--text-secondary);cursor:pointer;padding:var(--space-xs);border-radius:var(--radius);transition:all var(--transition);background:0 0;border:none;justify-content:center;align-items:center;display:flex}.btn-icon-inline:hover{color:var(--accent);background:var(--hover-bg)}.spinner{border:3px solid var(--bg-tertiary);border-top-color:var(--accent);width:48px;height:48px;margin-bottom:var(--space-l);border-radius:50%;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}#meeting{justify-content:flex-start;align-items:stretch;height:100dvh;padding:0;overflow:hidden}.meeting-header{padding:var(--space-m) var(--space-l);-webkit-backdrop-filter:blur(20px);z-index:100;background:#0f0f17cc;border-bottom:1px solid #ffffff0d;justify-content:space-between;align-items:center;display:flex;position:sticky;top:0}.header-left{align-items:center;gap:var(--space-l);display:flex}.room-info{align-items:center;gap:var(--space-m);display:flex}.room-code{color:var(--text);font-family:monospace;font-size:1rem;font-weight:600}.participant-count{color:var(--text-secondary);font-size:.875rem;font-weight:400}.status-indicators{gap:var(--space-s);align-items:center;display:flex}.status-badge{border-radius:6px;align-items:center;gap:4px;padding:4px 8px;font-size:.75rem;font-weight:600;display:inline-flex}.status-badge.recording{color:var(--danger);background:#ef444426}.status-badge.locked{color:var(--color-warning);background:#f59e0b26}.status-badge.connection-status{color:var(--color-primary-light);background:#60a5fa29}.status-badge.connection-status.failed,.status-badge.connection-status.disconnected{color:var(--danger);background:#ef444429}.status-badge .icon{width:12px;height:12px}.connection-quality{font-size:.75rem}.connection-quality.good{color:var(--color-success)}.connection-quality.fair{color:var(--color-warning)}.connection-quality.poor{color:var(--danger)}.connection-quality.unknown{color:var(--text-secondary)}.btn-invite{align-items:center;gap:var(--space-xs);padding:0 var(--space-m);background:var(--accent);color:#fff;cursor:pointer;height:36px;transition:all var(--transition);border:none;border-radius:8px;font-size:.875rem;font-weight:500;display:flex}.btn-invite:hover{background:var(--accent-hover);box-shadow:0 2px 8px #6366f14d}.btn-invite .icon{width:16px;height:16px}.btn-invite.invite-copied{background:var(--color-success);border-color:var(--color-success);animation:.3s invite-pop}@keyframes invite-pop{0%{transform:scale(1)}50%{transform:scale(1.15)}to{transform:scale(1)}}.video-container{flex:1;justify-content:center;align-items:center;min-height:0;display:flex;position:relative;overflow:hidden}.video-grid{padding:var(--space-l);flex:1;place-content:center;gap:12px;width:100%;height:100%;min-height:0;display:grid}.video-grid:empty{display:none}.video-grid.single{grid-template-columns:1fr;max-width:min(1200px,100%)}.video-grid.pair{grid-template-columns:repeat(2,1fr);max-width:min(1400px,100%)}.video-grid.triple{grid-template-rows:repeat(2,1fr);grid-template-columns:repeat(2,1fr);max-width:min(1400px,100%)}.video-grid.triple .video-item:first-child{grid-column:1/-1}.video-grid.quad{grid-template-rows:repeat(2,1fr);grid-template-columns:repeat(2,1fr);max-width:min(1400px,100%)}.video-grid.page-9{grid-template-rows:repeat(3,1fr);grid-template-columns:repeat(3,1fr);max-width:min(1600px,100%)}.video-grid.has-pinned{grid-template-rows:minmax(0,1fr);grid-template-columns:minmax(0,1fr);max-width:min(1400px,100%)}.video-item{background:var(--bg-secondary);border-radius:var(--radius);aspect-ratio:16/9;border:1px solid #ffffff0d;position:relative;overflow:hidden}.video-item video{object-fit:cover;width:100%;height:100%}.video-item.remote{cursor:zoom-in}.video-item.remote.pinned{cursor:zoom-out;outline:2px solid var(--accent)}.video-item.local video{transform:scaleX(-1)}.video-label{padding:var(--space-m);opacity:1;background:linear-gradient(#0000,#000000b3);justify-content:space-between;align-items:center;display:flex;position:absolute;bottom:0;left:0;right:0}.video-label span{font-size:.875rem;font-weight:500}.status-icons{align-items:center;gap:6px;display:flex}.status-icons .icon{width:16px;height:16px}.muted-indicator,.muted-icon,.hand-indicator,.hand-icon,.video-off-indicator,.video-off-icon{display:none}.muted-indicator.visible,.muted-icon.visible,.hand-indicator.visible,.hand-icon.visible,.video-off-indicator.visible,.video-off-icon.visible{display:inline-flex}.video-item.hand-raised{border-color:var(--color-warning);box-shadow:0 0 0 1px color-mix(in srgb, var(--color-warning) 70%, transparent), 0 16px 36px #00000047}.tile-hand-badge,.reaction-badge{z-index:6;border-radius:var(--radius-full);color:#fff;pointer-events:none;border:1px solid #ffffff2e;justify-content:center;align-items:center;font-weight:700;line-height:1;display:inline-flex;position:absolute;box-shadow:0 10px 24px #00000052}.tile-hand-badge{top:var(--space-s);right:var(--space-s);background:color-mix(in srgb, var(--color-warning) 92%, #111827);min-height:32px;color:var(--text-dark);gap:.4rem;padding:0 .75rem;font-size:.75rem}.tile-hand-badge .icon{width:16px;height:16px}.video-item.local .tile-hand-badge{width:30px;min-height:30px;padding:0;top:8px;right:8px}.video-item.local .tile-hand-badge span{display:none}.video-item.local{aspect-ratio:16/9;z-index:10;border-radius:var(--radius);width:180px;transition:all var(--transition);border:2px solid #ffffff26;position:absolute;bottom:16px;left:16px;box-shadow:0 4px 16px #0006}.video-item.local:hover{transform:scale(1.05)}.video-item.local .video-label{opacity:1;padding:var(--space-xs);background:linear-gradient(#0000,#000c)}.video-nav-btn{backdrop-filter:blur(8px);color:#fff;cursor:pointer;z-index:5;opacity:0;width:40px;height:40px;transition:all var(--transition);background:#0006;border:none;border-radius:50%;justify-content:center;align-items:center;display:flex;position:absolute;top:50%;transform:translateY(-50%)}.video-container:hover .video-nav-btn{opacity:1}.video-nav-btn:hover{background:#0009}.video-nav-prev{left:var(--space-m)}.video-nav-next{right:var(--space-m)}.video-pagination{bottom:var(--space-m);backdrop-filter:blur(8px);padding:6px var(--space-m);z-index:5;background:#00000080;border-radius:20px;font-size:.8125rem;position:absolute;left:50%;transform:translate(-50%)}.controls{justify-content:center;align-items:center;gap:var(--space-m);padding:var(--space-l);background:var(--bg-secondary);border-top:1px solid var(--border);display:flex}.control-group{gap:var(--space-s);align-items:center;display:flex}.control-group.advanced{padding-left:var(--space-m);border-left:1px solid var(--border)}.control-btn{width:48px;height:48px;color:var(--text);cursor:pointer;transition:all var(--transition);background:#ffffff14;border:none;border-radius:50%;justify-content:center;align-items:center;display:flex;position:relative}.control-btn:hover{background:#ffffff1f}.control-btn:active{transform:scale(.95)}.control-btn.off,.control-btn.danger{background:var(--danger);color:#fff}.control-btn.danger:hover{background:var(--color-danger-light)}.control-btn.active{background:var(--color-warning);color:var(--text-dark)}.control-btn.recording{background:var(--danger);color:#fff;animation:2s infinite pulse}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.control-btn .icon{fill:currentColor;width:22px;height:22px}.reaction-picker{z-index:120;gap:var(--space-xs);padding:var(--space-s);border:1px solid var(--border);border-radius:var(--radius-full);box-shadow:0 16px 40px var(--shadow);background:#1a1d22f5;display:flex;position:fixed;bottom:5.5rem;left:50%;transform:translate(-50%)}.reaction-picker button{background:var(--bg-tertiary);cursor:pointer;width:44px;height:44px;color:var(--color-text);transition:transform var(--transition), background var(--transition);border:0;border-radius:50%}.reaction-icon{fill:none;stroke:currentColor;stroke-width:1.5px;width:22px;height:22px}.reaction-picker button:hover{background:var(--hover-bg);transform:translateY(-2px)}.reaction-burst{z-index:7;pointer-events:none;color:#fff;text-shadow:0 8px 24px #0006;line-height:1;animation:1.8s forwards reactionBurst;position:absolute;top:45%;left:50%;transform:translate(-50%,-50%)}.reaction-burst .reaction-icon{stroke-width:1.25px;filter:drop-shadow(0 10px 22px #00000073);width:clamp(2.6rem,8vw,5rem);height:clamp(2.6rem,8vw,5rem)}.reaction-badge{top:var(--space-s);left:var(--space-s);background:color-mix(in srgb, var(--color-surface) 78%, transparent);backdrop-filter:blur(12px);width:42px;height:42px;animation:2.6s forwards reactionBadge}.reaction-badge .reaction-icon{width:22px;height:22px}@keyframes reactionBurst{0%{opacity:0;transform:translate(-50%,-35%)scale(.7)}15%{opacity:1;transform:translate(-50%,-50%)scale(1.05)}to{opacity:0;transform:translate(-50%,-130%)scale(1.25)}}@keyframes reactionBadge{0%{opacity:0;transform:translateY(6px)scale(.92)}12%,82%{opacity:1;transform:translateY(0)scale(1)}to{opacity:0;transform:translateY(-4px)scale(.96)}}.unread-dot{background:var(--danger);border:2px solid var(--bg-secondary);border-radius:50%;width:8px;height:8px;position:absolute;top:8px;right:8px}.chat-panel{backdrop-filter:blur(20px);background:#1a1a28f2;border-left:1px solid #ffffff14;flex-direction:column;width:340px;display:flex;position:absolute;top:0;bottom:0;right:0}.chat-panel.hidden,.participants-panel.hidden{display:none!important}.chat-header{padding:var(--space-l);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;display:flex}.chat-header h3{font-size:1rem;font-weight:600}.btn-icon{color:var(--text-secondary);cursor:pointer;padding:var(--space-xs);transition:all var(--transition);background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;display:flex}.btn-icon:hover{color:var(--text);background:var(--hover-bg)}.btn-icon .icon{width:20px;height:20px}.chat-messages{padding:var(--space-l);gap:var(--space-m);flex-direction:column;flex:1;display:flex;overflow-y:auto}.chat-message{max-width:85%;padding:var(--space-s) var(--space-m);background:var(--bg-tertiary);border-radius:12px;animation:.2s messageAppear}@keyframes messageAppear{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.chat-message.me{background:var(--accent);color:#fff;border-radius:12px 12px 2px;align-self:flex-end}.chat-message:not(.me){border-radius:12px 12px 12px 2px}.chat-message-header{justify-content:space-between;gap:var(--space-s);margin-bottom:4px;font-size:.75rem;display:flex}.chat-message-meta{align-items:center;gap:var(--space-xs);display:inline-flex}.chat-reply-btn{color:inherit;cursor:pointer;font:inherit;opacity:.72;background:0 0;border:0;padding:0}.chat-reply-btn:hover{opacity:1;text-decoration:underline}.chat-message.me .chat-message-header{color:#fffc}.chat-message:not(.me) .chat-message-header{color:var(--text-secondary)}.chat-message-text{word-break:break-word;font-size:.9375rem;line-height:1.4}.reply-indicator,.chat-reply-preview{border-left:2px solid var(--accent);color:var(--text-secondary);font-size:.75rem}.reply-indicator{margin-bottom:var(--space-xs);padding-left:var(--space-s)}.chat-reply-preview{background:var(--bg-tertiary);align-items:center;gap:var(--space-s);padding:var(--space-s) var(--space-l);justify-content:space-between;display:flex}.reply-label,.reply-name{display:block}.reply-name{color:var(--text);font-weight:600}.reply-text{text-overflow:ellipsis;white-space:nowrap;max-width:240px;display:block;overflow:hidden}.chat-input-container{gap:var(--space-s);padding:var(--space-l);border-top:1px solid var(--border);display:flex}.chat-input-container input{padding:var(--space-s) var(--space-m);background:var(--input-bg);border:1px solid var(--input-border);color:var(--text);border-radius:20px;flex:1;font-size:.875rem}.chat-input-container input:focus{border-color:var(--accent);outline:none}.chat-input-container input[type=file]{display:none}.participants-panel{backdrop-filter:blur(20px);background:#1a1a28f2;border-left:1px solid #ffffff14;flex-direction:column;align-self:stretch;width:340px;display:flex}.participants-header{padding:var(--space-l);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;display:flex}.participants-header h3{font-size:1rem;font-weight:600}.participants-list{padding:var(--space-s);flex:1;overflow-y:auto}.participant-item{padding:var(--space-s) var(--space-m);margin-bottom:var(--space-xs);background:var(--bg-tertiary);justify-content:space-between;align-items:center;gap:var(--space-s);border-radius:8px;min-height:44px;display:flex}.participant-info{align-items:center;gap:var(--space-s);flex:1;min-width:0;display:flex}.participant-name{white-space:nowrap;text-overflow:ellipsis;min-width:0;font-size:.9375rem;font-weight:500;overflow:hidden}.participant-badges{flex-shrink:0;align-items:center;gap:4px;display:flex}.badge-icon{width:14px;height:14px}.badge-icon.hand{color:var(--color-warning)}.badge-icon.muted{color:var(--color-danger)}.participant-actions{flex-shrink:0;gap:4px;display:flex}.participant-action-btn{width:32px;height:32px;color:var(--text-secondary);background:#ffffff0f;border-radius:6px;justify-content:center;align-items:center;display:flex}.participant-action-btn:hover{color:var(--text);background:#ffffff1f}.participant-action-btn[data-action=kick]{color:var(--color-danger)}.participant-action-btn[data-action=kick]:hover{background:#ef444426}.participant-action-btn .icon{width:16px;height:16px}.badge{border-radius:6px;padding:3px 8px;font-size:.6875rem;font-weight:600}.badge.moderator{color:var(--color-primary-light);background:#818cf833}.badge.hand{color:var(--color-warning);background:#f59e0b33}.badge.muted{color:var(--danger);background:#ef444433}.waiting-room-section{border-top:1px solid var(--border);padding:var(--space-l)}.waiting-room-section h4{color:var(--text-secondary);margin-bottom:var(--space-m);text-transform:uppercase;letter-spacing:.05em;font-size:.875rem;font-weight:600}.waiting-item{padding:var(--space-s);background:var(--bg-tertiary);margin-bottom:var(--space-s);border-radius:8px;justify-content:space-between;align-items:center;display:flex}.btn-admit,.btn-reject{padding:6px var(--space-m);cursor:pointer;transition:opacity var(--transition);border:none;border-radius:6px;font-size:.75rem;font-weight:500}.btn-admit{background:var(--color-success);color:#fff}.btn-reject{background:var(--danger);color:#fff}.btn-admit:hover,.btn-reject:hover{opacity:.85}.file-transfer-panel{right:var(--space-l);background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius);width:min(340px,100vw - 2rem);padding:var(--space-m);box-shadow:0 16px 40px var(--shadow);z-index:100;position:fixed;bottom:6rem}.file-transfer-panel h4{margin-bottom:var(--space-s);font-size:.875rem}.file-transfer-list{gap:var(--space-s);flex-direction:column;display:flex}.file-transfer-item{background:var(--bg-tertiary);border-radius:var(--radius);padding:var(--space-s)}.file-info{margin-bottom:var(--space-s);gap:2px;display:grid}.file-name{text-overflow:ellipsis;white-space:nowrap;font-size:.875rem;font-weight:600;overflow:hidden}.file-size,.file-sender{color:var(--text-secondary);font-size:.75rem}.progress-bar{background:var(--bg-primary);border-radius:var(--radius-full);height:6px;overflow:hidden}.progress-fill{background:var(--accent);height:100%;transition:width var(--transition)}.progress-width-0{width:0%}.progress-width-25{width:25%}.progress-width-50{width:50%}.progress-width-75{width:75%}.progress-width-100{width:100%}.file-actions{gap:var(--space-xs);margin-top:var(--space-s);justify-content:flex-end;display:flex}.btn-accept,.btn-download,.btn-cancel{background:var(--accent);color:#fff}.btn-accept,.btn-download,.btn-cancel,.btn-reject{cursor:pointer;padding:6px var(--space-s);border:0;border-radius:6px;font-size:.75rem;font-weight:600}.mobile-menu{background:var(--bg-secondary);border-top:1px solid var(--border);border-radius:var(--radius-lg) var(--radius-lg) 0 0;z-index:1000;flex-direction:column;max-height:70vh;animation:.3s slideUp;display:flex;position:fixed;bottom:0;left:0;right:0;overflow-y:scroll}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.mobile-menu-handle{background:var(--border);width:40px;height:4px;margin:var(--space-s) auto;border-radius:2px}.mobile-menu-content{padding:var(--space-m);gap:var(--space-xs);flex-direction:column;padding-bottom:5.5rem;display:flex}.mobile-menu-item{align-items:center;gap:var(--space-m);padding:var(--space-s) var(--space-m);background:var(--bg-tertiary);border-radius:var(--radius);color:var(--text);cursor:pointer;transition:background var(--transition);border:none;font-size:1rem;display:flex;position:relative;overflow:hidden}.mobile-menu-item span{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.mobile-menu-item:hover{background:var(--hover-bg)}.mobile-menu-item .icon{fill:currentColor;width:22px;height:22px}.mobile-menu-item .unread-dot{border:none;margin-left:auto;position:static}.mobile-backdrop{z-index:999;touch-action:none;background:#0009;animation:.2s fadeIn;position:fixed;inset:0}#error .container{padding:var(--space-xl);background:var(--bg-secondary);border-radius:var(--radius-lg);border:1px solid var(--border)}#error h1{color:var(--danger);-webkit-text-fill-color:var(--danger);background:0 0}#error-message{color:var(--text-secondary);margin:var(--space-l) 0}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#ffffff26}.desktop-only{display:flex}.mobile-only{display:none}.icon{fill:currentColor;width:20px;height:20px}@media (width<=768px){h1{font-size:2.5rem}.container{max-width:100%}#meeting{position:fixed;inset:0}.meeting-header{z-index:50;padding:var(--space-s) var(--space-m);padding-top:calc(var(--space-s) + env(safe-area-inset-top,0px));position:fixed;top:0;left:0;right:0}.controls{z-index:50;padding:var(--space-s) var(--space-m);padding-bottom:calc(var(--space-s) + env(safe-area-inset-bottom,0px));gap:var(--space-s);scrollbar-width:none;position:fixed;bottom:0;left:0;right:0;overflow-x:auto}.controls::-webkit-scrollbar{display:none}.video-container{top:calc(52px + env(safe-area-inset-top,0px));bottom:calc(68px + env(safe-area-inset-bottom,0px));margin:0;position:fixed;left:0;right:0;overflow:hidden}.video-grid{grid-auto-rows:1fr;align-content:center;gap:6px;width:100%;height:100%;margin:2rem 1rem}.video-grid.single,.video-grid.pair{grid-template-columns:1fr}.video-grid.triple,.video-grid.quad,.video-grid.page-9{grid-template-columns:repeat(2,1fr)}.video-grid.triple .video-item:first-child{grid-column:1/-1}.video-item{aspect-ratio:auto;min-height:0;max-height:40vh;overflow:hidden}.video-item video{object-fit:cover;width:100%;height:100%}.video-item .video-label{opacity:1}.video-item.local{aspect-ratio:3/4;width:100px;max-height:none;bottom:12px;right:var(--space-s);left:auto}.video-nav-btn{opacity:1;background:#0009;width:36px;height:36px;top:auto;bottom:12px;transform:none}.video-nav-prev{left:auto;right:calc(50% + 50px)}.video-nav-next{left:calc(50% + 50px);right:auto}.video-pagination{bottom:12px}.room-code{font-size:.875rem}.participant-count{font-size:.8125rem}.status-indicators,.btn-invite span,.control-group.advanced{display:none}.control-btn{width:48px;min-width:48px;height:48px}.participant-item{flex-wrap:wrap}.participant-info{width:100%}.participant-actions{width:100%;padding-top:var(--space-xs)}.chat-panel,.participants-panel{z-index:100;border-left:none;width:100%;position:absolute;inset:0}.chat-messages,.participants-list{min-height:0;max-height:calc(100dvh - 200px)}.desktop-only{display:none!important}.mobile-only{display:flex!important}}@media (width<=480px){.screen{padding:var(--space-m)}#landing .container,#error .container{padding:1.25rem}.form-group-inline{grid-template-columns:minmax(0,1fr);display:grid}.form-group-inline input,.form-group-inline .btn{width:100%}.form-grid-compact{grid-template-columns:minmax(0,1fr)}}#landing{background:linear-gradient(180deg, var(--color-bg-top), var(--color-bg))}#landing .container,#error .container{border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);max-width:420px;box-shadow:var(--shadow-overlay);padding:1.75rem}#landing h1{color:var(--color-text-muted);text-transform:uppercase;margin-bottom:2rem;font-size:.8125rem;font-weight:800;line-height:1.2}h1{color:var(--color-text);-webkit-text-fill-color:currentColor;letter-spacing:0;background:0 0}.subtitle,.participant-count,.connection-quality.unknown,.btn-link,.share-link-group input,.chat-message:not(.me) .chat-message-header,.file-size,.file-sender{color:var(--color-text-muted)}#landing .name-input-group{margin-bottom:2.5rem}#landing .action-buttons{gap:.75rem;margin-bottom:1.25rem}.name-input-group input,.form-group-inline input,.form-group-compact input,.form-grid-compact input,.share-link-group,.created-details,.chat-input-container input{border-color:var(--color-border);background:var(--color-surface-muted)}.name-input-group input::placeholder,.form-group-inline input::placeholder,.form-group-compact input::placeholder,.form-grid-compact input::placeholder,.chat-input-container input::placeholder{color:color-mix(in srgb, var(--color-text-muted) 62%, var(--color-text));opacity:1}.name-input-group input:hover,.form-group-inline input:hover,.form-group-compact input:hover,.form-grid-compact input:hover,.chat-input-container input:hover{border-color:var(--color-border-strong);background:var(--color-surface-hover)}.name-input-group input:focus,.form-group-inline input:focus,.form-group-compact input:focus,.form-grid-compact input:focus,.chat-input-container input:focus{border-color:var(--color-accent);background:var(--color-surface-muted);box-shadow:var(--focus-ring)}.btn,.btn-invite,.btn-admit,.btn-download,.btn-accept{border-radius:var(--radius);box-shadow:none}.btn-primary,.btn-invite,.btn-accept,.btn-download{background:var(--color-accent);color:var(--color-on-accent)}.btn-primary:hover,.btn-invite:hover,.btn-accept:hover,.btn-download:hover{background:var(--color-accent-strong);box-shadow:none}.btn-secondary,.mobile-menu-item,.participant-item,.waiting-item,.file-transfer-item,.chat-message,.reaction-picker button{border:1px solid var(--color-border);background:var(--color-surface-muted)}.btn-secondary{color:var(--color-text)}.btn:disabled{opacity:1}.btn-primary:disabled{border-color:var(--color-border);background:var(--color-surface-muted);color:var(--color-text-muted)}.btn-link{color:var(--color-text-muted)}.btn-secondary:hover,.mobile-menu-item:hover,.participant-action-btn:hover,.reaction-picker button:hover{border-color:var(--color-border-strong);background:var(--color-surface-hover)}.meeting-header{background:color-mix(in srgb, var(--color-surface) 88%, transparent);border-bottom:1px solid var(--color-border);box-shadow:0 1px 0 color-mix(in srgb, var(--color-border) 68%, transparent)}.controls{background:var(--color-surface);border-top:1px solid var(--color-border);gap:.5rem}.control-group{gap:.5rem}.control-btn,.participant-action-btn,.btn-icon,.btn-icon-inline,.video-nav-btn{border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface-muted);color:var(--color-text);box-shadow:none}.control-btn:hover,.participant-action-btn:hover,.btn-icon:hover,.btn-icon-inline:hover,.video-nav-btn:hover{border-color:var(--color-border-strong);background:var(--color-surface-hover);color:var(--color-text)}.control-btn.off,.control-btn.danger,.control-btn.recording{border-color:var(--danger);background:var(--danger);color:#fff}.control-btn.active{border-color:var(--color-warning);background:var(--color-warning);color:var(--text-dark)}.video-item{border-color:var(--color-border);border-radius:var(--radius);background:var(--color-surface)}.video-item.remote.pinned{outline-color:var(--color-accent)}.chat-panel,.participants-panel,.mobile-menu,.file-transfer-panel{background:color-mix(in srgb, var(--color-surface) 96%, transparent);border-color:var(--color-border);box-shadow:var(--shadow-overlay)}.chat-header,.participants-header,.waiting-room-section,.chat-input-container,.reply-indicator,.chat-reply-preview{border-color:var(--color-border)}.chat-message.me{background:var(--color-accent);color:var(--color-on-accent)}.badge.moderator,.status-badge.connection-status{background:var(--color-accent-soft);color:var(--color-accent-strong)}::-webkit-scrollbar-thumb{background:var(--color-border-strong)}