:root{--bg: #0f1419;--bg-elevated: #1a1f2e;--bg-input: #1e2433;--border: #2d3548;--border-focus: #38bdf8;--accent: #38bdf8;--accent-soft: rgba(56, 189, 248, .14);--accent-hover: #7dd3fc;--danger: #f87171;--danger-soft: rgba(248, 113, 113, .16);--success: #4ade80;--success-glow: rgba(74, 222, 128, .45);--text: #f1f5f9;--text-muted: #94a3b8;--gradient-accent: linear-gradient(135deg, #38bdf8 0%, #818cf8 100%);--gradient-bg: linear-gradient(180deg, #0f1419 0%, #1a1f2e 50%, #0f1419 100%);--radius: 12px;--radius-sm: 8px;--font-display: "Orbitron", sans-serif;--font-body: "Outfit", system-ui, sans-serif;font-family:var(--font-body);line-height:1.5;font-weight:400;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background:var(--gradient-bg);background-attachment:fixed}#app{min-height:100vh;display:flex;flex-direction:column;align-items:stretch}#app:has(.login){justify-content:center;padding:1rem}.login{width:100%;max-width:420px;margin:0 auto;padding:2rem;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 8px 32px #00000040}.login-title{font-family:var(--font-display);font-size:2.25rem;font-weight:700;letter-spacing:.08em;text-align:center;margin:0 0 .5rem;background:var(--gradient-accent);-webkit-background-clip:text;background-clip:text;color:transparent;text-transform:uppercase}.login-sub{text-align:center;color:var(--text-muted);font-size:.9rem}.login-room-id{margin:.5rem 0 1rem;padding:.5rem .75rem;background:var(--bg-input);border-radius:var(--radius-sm);font-family:monospace;font-size:.8rem;color:var(--text-muted);word-break:break-all;margin:0 0 1.5rem}.login label{display:block;font-size:.8rem;margin-bottom:.35rem;color:var(--text-muted)}.login input{width:100%;padding:.6rem .85rem;margin-bottom:.9rem;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-input);color:var(--text);font-size:.95rem;transition:border-color .2s,box-shadow .2s}.login input::placeholder{color:var(--text-muted)}.login input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-soft)}.login-actions{display:flex;gap:.75rem;margin-top:1.25rem}.login-actions button{flex:1;padding:.65rem 1rem;border:none;border-radius:var(--radius-sm);font-size:.9rem;font-weight:600;cursor:pointer;transition:transform .15s,box-shadow .2s}.btn-create{background:var(--gradient-accent);color:#fff;font-family:var(--font-body)}.btn-create:hover{transform:translateY(-1px);filter:brightness(1.08)}.btn-join{background:var(--bg-input);color:var(--text);border:1px solid var(--border);font-family:var(--font-body)}.btn-join:hover{border-color:var(--accent);background:var(--accent-soft)}.login-error{background:var(--danger-soft);color:#fca5a5;padding:.55rem .85rem;border-radius:var(--radius-sm);font-size:.85rem;margin-bottom:.9rem;border:1px solid rgba(248,113,113,.35)}.login-support-wrap{text-align:center;margin-top:1.5rem}.login-support{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.5rem .75rem;color:var(--text-muted);font-size:.875rem;text-decoration:none;border-radius:var(--radius-sm);border:1px solid var(--border);background:transparent;transition:color .2s,border-color .2s,background .2s}.login-support:hover{color:var(--accent);border-color:var(--accent);background:var(--accent-soft)}.login-support-logo{width:24px;height:24px;object-fit:contain;flex-shrink:0;filter:invert(1) brightness(.9);opacity:.85}.login-support:hover .login-support-logo{opacity:1;filter:invert(1) brightness(1.1)}#app:has(.room){height:100vh;overflow:hidden}.room{display:flex;flex-direction:column;height:100%;min-height:0;background:var(--gradient-bg);background-attachment:fixed}.room-header{flex:0 0 auto;display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.5rem 1rem;background:var(--bg-elevated);border-bottom:1px solid var(--border)}.room-header-left{display:flex;flex-direction:column;gap:.1rem;min-width:0}.room-title{font-family:var(--font-body);font-size:.95rem;font-weight:600;color:var(--text)}.room-status{font-size:.8rem;color:var(--text-muted)}.btn-icon{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;padding:0;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-input);color:var(--text-muted);cursor:pointer;transition:color .2s,border-color .2s,box-shadow .2s}.btn-icon svg{flex-shrink:0;display:block}.btn-icon:hover{color:var(--text);border-color:var(--accent);background:var(--accent-soft)}.btn-icon.active{color:var(--success);border-color:#4ade8080;box-shadow:0 0 12px var(--success-glow)}.btn-icon.active:hover{box-shadow:0 0 16px var(--success-glow)}.btn-copy-link{flex-shrink:0;width:40px;height:40px;padding:0;display:inline-flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-input);color:var(--text-muted);cursor:pointer;transition:color .2s,border-color .2s,box-shadow .2s}.btn-copy-link:hover{color:var(--accent);border-color:var(--accent);background:var(--accent-soft)}.btn-copy-link:disabled{cursor:default;opacity:.9}.btn-copy-link svg{display:block}.room-body{flex:1;display:flex;min-height:0;gap:.75rem;padding:.75rem}.room-video{flex:1;min-width:0;display:flex;flex-direction:column;min-height:0}.room-error{flex:0 0 auto;background:var(--danger-soft);color:#fca5a5;padding:.5rem .75rem;border-radius:var(--radius-sm);font-size:.85rem;margin-bottom:.5rem;border:1px solid rgba(248,113,113,.35)}.video-grid{flex:1;min-height:0;min-width:0;display:grid;gap:.75rem;align-content:start;justify-content:center;overflow:auto;padding:.5rem}.video-grid-placeholder{grid-column:1 / -1;grid-row:1;display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:.9rem;padding:2rem}.video-grid-placeholder.hidden,.video-grid.hidden{display:none!important}.video-grid-focus-container{flex:1;min-height:0;display:flex;gap:.5rem;padding:.5rem;overflow:hidden}.video-grid-focus-container.hidden{display:none!important}.video-grid-focus-main{flex:1 1 60%;min-width:0;max-width:65%;display:flex;align-items:center;justify-content:center;overflow:hidden}.video-grid-focus-main .video-tile{width:100%;height:100%;max-width:100%;max-height:100%;aspect-ratio:auto}.video-grid-focus-sidebar{flex:1 0 200px;min-width:200px;display:grid;grid-template-columns:repeat(2,1fr);grid-template-rows:repeat(5,1fr);gap:.4rem;overflow-y:auto;aspect-ratio:2 / 5;max-height:100%;align-self:start}.video-grid-focus-sidebar .video-tile{aspect-ratio:1;width:100%;min-height:0;place-self:stretch}.video-grid-focus-sidebar .video-tile-pagination-focus{grid-column:2;grid-row:5}.video-grid[data-layout="0"],.video-grid[data-layout="1"]{grid-template-columns:1fr;grid-template-rows:1fr;place-items:center}.video-grid[data-layout="1"] .video-tile{width:100%;height:100%;max-width:100%;max-height:100%;aspect-ratio:auto}.video-grid[data-layout="2"] .video-tile,.video-grid[data-layout="3"] .video-tile,.video-grid[data-layout="4"] .video-tile{aspect-ratio:1;width:100%;max-height:100%}.video-grid[data-layout="2"]{grid-template-columns:repeat(2,minmax(0,1fr));grid-template-rows:minmax(0,1fr)}.video-grid[data-layout="3"]{grid-template-columns:repeat(3,minmax(0,1fr));grid-template-rows:minmax(0,1fr)}.video-grid[data-layout="4"]{grid-template-columns:repeat(2,minmax(0,1fr));grid-template-rows:repeat(2,minmax(0,1fr));align-content:stretch}.video-grid[data-grid] .video-tile{aspect-ratio:1;width:100%;height:auto;max-height:100%;place-self:center}.video-grid[data-grid="3"]{grid-template-columns:repeat(3,minmax(0,1fr));grid-template-rows:repeat(3,minmax(0,1fr))}.video-grid[data-grid="4"]{grid-template-columns:repeat(4,minmax(0,1fr));grid-template-rows:repeat(4,minmax(0,1fr))}.video-grid[data-grid="5"]{grid-template-columns:repeat(5,minmax(0,1fr));grid-template-rows:repeat(5,minmax(0,1fr))}.video-grid[data-grid="6"]{grid-template-columns:repeat(6,minmax(0,1fr));grid-template-rows:repeat(6,minmax(0,1fr))}.video-grid[data-pagination=true] .video-tile-pagination{grid-column:1;grid-row:6}.video-tile{position:relative;background:var(--bg-elevated);border-radius:var(--radius-sm);overflow:hidden;aspect-ratio:1;width:100%;min-width:0;min-height:0;max-width:100%;max-height:100%;place-self:center;border:1px solid var(--border);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:border-color .2s,box-shadow .2s}.video-tile:hover{border-color:var(--accent);box-shadow:0 0 12px var(--accent-soft)}.video-tile-pagination{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;cursor:default;background:var(--bg-input)!important;border-style:dashed!important}.video-tile-pagination .pagination-btns{display:flex;align-items:center;gap:.5rem}.video-tile-pagination:hover{border-color:var(--border);box-shadow:none}.pagination-label{font-size:.85rem;color:var(--text-muted)}.pagination-btn{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:1.25rem;padding:.25rem .5rem;cursor:pointer;line-height:1}.pagination-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.pagination-btn:disabled{opacity:.4;cursor:not-allowed}.video-tile video,.video-tile .tile-video{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;display:block}.video-tile .tile-video.hidden{display:none}.tile-indicators{position:absolute;bottom:.25rem;right:.25rem;display:flex;gap:.25rem;z-index:2}.tile-indicator{display:flex;align-items:center;justify-content:center;width:22px;height:22px;padding:2px;border-radius:4px;background:#00000080;color:var(--text)}.tile-indicator.muted{color:var(--text-muted)}.tile-indicator.admin-restricted{color:#ef4444;background:#ef444440}.tile-indicator:not(.muted):not(.admin-restricted){color:var(--success)}.tile-indicator-chat.hidden{display:none!important}.tile-indicator svg{width:14px;height:14px}.tile-admin-badge{position:absolute;top:.25rem;left:.25rem;display:flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:4px;background:#00000080;color:#fbbf24;z-index:2}.tile-admin-badge.hidden{display:none!important}.tile-admin-badge svg{width:14px;height:14px}.tile-top-actions{position:absolute;top:.25rem;right:.25rem;left:auto;display:flex;flex-direction:row;align-items:center;gap:.25rem;z-index:3}.tile-admin-btn{flex-shrink:0;position:relative;top:auto;right:auto;left:auto;width:28px;height:28px;padding:0;display:flex;align-items:center;justify-content:center;border:none;border-radius:4px;background:#00000080;color:var(--text);cursor:pointer;z-index:3}.tile-admin-btn:hover{background:#000000b3;color:var(--accent)}.tile-admin-btn svg{width:16px;height:16px}.tile-admin-popover{position:absolute;top:2.5rem;right:0;left:auto;margin-top:.25rem;min-width:180px;padding:.25rem;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:0 4px 12px #0000004d;z-index:10}.tile-admin-popover.hidden{display:none!important}.tile-admin-action{display:block;width:100%;padding:.5rem .75rem;text-align:left;font-size:.9rem;border:none;border-radius:4px;background:transparent;color:var(--text);cursor:pointer}.tile-admin-action:hover{background:var(--accent-soft);color:var(--accent)}.tile-admin-action-danger:hover{background:#f8717133;color:var(--error)}.tile-avatar{display:flex;align-items:center;justify-content:center;width:100%;height:100%;color:var(--text-muted);background:var(--bg-input)}.tile-avatar.hidden{display:none}.tile-avatar svg{width:48px;height:48px;opacity:.6}.video-tile .label{position:absolute;bottom:0;left:0;right:0;padding:.35rem .5rem;background:linear-gradient(transparent,#000c);font-size:.75rem;color:var(--text);font-weight:500;z-index:1}.video-tile .btn-fullscreen{flex-shrink:0;width:28px;height:28px;padding:0;border:none;border-radius:var(--radius-sm);background:#00000080;color:var(--text);font-size:.9rem;cursor:pointer;opacity:.8;transition:opacity .2s,background .2s}.video-tile:hover .btn-fullscreen{opacity:1;background:#000000a6}.video-tile .btn-fullscreen:hover{background:var(--accent)}.video-tile .btn-fullscreen-exit{display:none;flex-shrink:0;padding:.4rem .75rem;border:none;border-radius:var(--radius-sm);background:var(--danger);color:#fff;font-size:.85rem;font-weight:500;cursor:pointer;align-items:center;justify-content:center}.video-tile.screen .label{color:var(--accent)}.video-tile:fullscreen{border-radius:0;aspect-ratio:auto;max-height:none}.video-tile:fullscreen video{object-fit:contain}.video-tile:fullscreen .btn-fullscreen{display:none}.video-tile:fullscreen .btn-fullscreen-exit{display:flex!important}.chat-section{position:relative;flex:0 0 300px;min-width:280px;max-width:100%;display:flex;flex-direction:column;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden;min-height:0;transition:flex .25s ease,min-width .25s ease,opacity .25s ease}.chat-section-collapsed{flex:0 0 0!important;min-width:0!important;width:0!important;padding:0!important;margin:0!important;border:none!important;overflow:hidden;opacity:0;pointer-events:none}.chat-title{flex:0 0 auto;padding:.5rem .85rem;font-size:.85rem;font-weight:600;color:var(--text-muted);border-bottom:1px solid var(--border)}.chat-messages{flex:1;overflow-y:auto;padding:.5rem;font-size:.85rem;min-height:80px}.chat-msg{display:flex;align-items:flex-start;gap:.5rem;margin-bottom:.6rem;word-break:break-word}.chat-msg-avatar{flex-shrink:0;width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:600;color:#fff}.chat-msg-content{flex:1;min-width:0;line-height:1.4}.chat-msg-header{display:flex;align-items:baseline;justify-content:space-between;gap:.5rem;margin-bottom:.15rem}.chat-msg .author{color:var(--accent);font-weight:600}.chat-msg.own .author{color:var(--success)}.chat-msg-time{flex-shrink:0;font-size:.75rem;color:var(--text-muted)}.chat-msg-body{font-size:.9rem;color:var(--text)}.chat-quick-emojis{display:flex;gap:.25rem;padding:.25rem 0;flex-wrap:wrap}.chat-quick-emoji{width:32px;height:32px;padding:0;border:none;border-radius:var(--radius-sm);background:transparent;font-size:1.2rem;cursor:pointer;transition:background .2s}.chat-quick-emoji:hover{background:var(--bg-input)}.chat-input-row{flex:0 0 auto;display:flex;flex-direction:column;gap:.35rem;padding:.5rem;border-top:1px solid var(--border)}.chat-input-wrap{position:relative;display:flex;gap:.5rem;align-items:center}.chat-input-wrap .btn-emoji{flex-shrink:0;width:36px;height:36px;padding:0}.chat-input-row input{flex:1;padding:.5rem .65rem;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-input);color:var(--text);font-size:.9rem;transition:border-color .2s,box-shadow .2s}.chat-input-row input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-soft)}.chat-input-row .btn-send{flex-shrink:0;width:40px;height:40px;padding:0;display:inline-flex;align-items:center;justify-content:center;border:none;border-radius:var(--radius-sm);background:var(--gradient-accent);color:#fff;cursor:pointer;transition:transform .15s,filter .2s}.chat-input-row .btn-send:hover{transform:translateY(-1px);filter:brightness(1.1)}.chat-emoji-popover{position:absolute;bottom:calc(100% + .5rem);left:0;right:0;max-height:180px;overflow-y:auto;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);padding:.5rem;display:flex;flex-wrap:wrap;gap:.25rem;z-index:20;box-shadow:0 -4px 12px #0000004d}.chat-emoji-popover.hidden{display:none!important}.chat-emoji-btn{width:32px;height:32px;padding:0;border:none;border-radius:var(--radius-sm);background:transparent;font-size:1.2rem;cursor:pointer;transition:background .2s}.chat-emoji-btn:hover{background:var(--bg-input)}.controls{flex:0 0 auto;display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:.6rem 1rem;background:var(--bg-elevated);border-top:1px solid var(--border)}.controls-left{display:flex;align-items:center;gap:.5rem}.controls-center{flex:1;display:flex;justify-content:center;gap:.5rem}.controls-right{display:flex;align-items:center;gap:.5rem}.controls .btn-icon{width:44px;height:44px}.btn-chat{position:relative}.chat-badge{position:absolute;top:2px;right:2px;min-width:18px;height:18px;padding:0 5px;font-size:.7rem;font-weight:600;line-height:18px;text-align:center;color:var(--bg);background:var(--accent);border-radius:9px;box-sizing:border-box}.chat-badge.hidden{display:none!important}.participant-count-wrap{display:inline-flex;align-items:center;gap:.35rem;padding:0 .5rem;color:var(--text-muted);font-size:.9rem;font-weight:600}.participant-count-wrap svg{flex-shrink:0;opacity:.85}.btn-leave{margin-left:0;background:var(--danger)!important;border-color:var(--danger)!important;color:#fff!important}.btn-leave:hover{background:var(--danger)!important;border-color:var(--danger)!important;color:#fff!important;filter:brightness(1.1)!important}@media(max-width:640px){.room-body{flex-direction:column}.chat-section:not(.chat-section-collapsed){flex:0 0 200px;min-height:200px;min-width:100%}.chat-emoji-popover{left:.5rem;right:.5rem}.video-grid[data-layout="2"],.video-grid[data-layout="3"],.video-grid[data-layout="4"],.video-grid[data-layout="5"],.video-grid[data-layout="6"],.video-grid[data-layout="7"],.video-grid[data-layout="8"]{grid-template-columns:1fr}}.hidden{display:none!important}
