:root,[data-theme=dark]{--bg:#0f172a;--bg-surface:#1e293b;--bg-elevated:#253147;--bg-card:#1e293b;--bg-hover:#253147;--bg-muted:#1a2334;--bg-input:#0f172a;--border:#334155;--border-subtle:#1e293b;--text:#f1f5f9;--text-secondary:#cbd5e1;--text-muted:#94a3b8;--text-faint:#64748b;--accent:#6366f1;--accent-hover:#818cf8;--danger:#ef4444;--success:#22c55e;--warning:#f59e0b;--pill-green-bg:#22c55e26;--pill-green:#4ade80;--pill-red-bg:#ef444426;--pill-red:#f87171;--pill-amber-bg:#f59e0b26;--pill-amber:#fbbf24;--pill-blue-bg:#6366f12e;--pill-blue:#a5b4fc;--pill-zinc-bg:#94a3b82e;--pill-zinc:#cbd5e1;--shadow:0 1px 2px #0006;--shadow-lg:0 10px 25px #00000073;--backdrop:#02061799;--radius:10px}[data-theme=light]{--bg:#f8fafc;--bg-surface:#fff;--bg-elevated:#f1f5f9;--bg-card:#fff;--bg-hover:#f1f5f9;--bg-muted:#f1f5f9;--bg-input:#fff;--border:#e2e8f0;--border-subtle:#f1f5f9;--text:#0f172a;--text-secondary:#334155;--text-muted:#64748b;--text-faint:#94a3b8;--accent:#4f46e5;--accent-hover:#6366f1;--danger:#dc2626;--success:#16a34a;--warning:#d97706;--pill-green-bg:#16a34a1f;--pill-green:#15803d;--pill-red-bg:#dc26261a;--pill-red:#b91c1c;--pill-amber-bg:#d977061f;--pill-amber:#b45309;--pill-blue-bg:#4f46e51a;--pill-blue:#4338ca;--pill-zinc-bg:#64748b1a;--pill-zinc:#475569;--shadow:0 1px 2px #0f172a0d;--shadow-lg:0 10px 25px #0f172a1a;--backdrop:#0f172a66}html,body{overscroll-behavior:none}body{transition:background-color .2s,color .2s}.dashboard-icon-btn{width:32px;height:32px;color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;transition:background .15s,color .15s;display:inline-flex}.dashboard-icon-btn:hover{background:var(--bg-hover);color:var(--text)}.pill{border-radius:999px;align-items:center;gap:4px;padding:2px 8px;font-size:12px;font-weight:500;display:inline-flex}.pill:before{content:"";opacity:.6;background:currentColor;border-radius:50%;width:6px;height:6px}.pill-green{background:var(--pill-green-bg);color:var(--pill-green)}.pill-red{background:var(--pill-red-bg);color:var(--pill-red)}.pill-amber{background:var(--pill-amber-bg);color:var(--pill-amber)}.pill-blue{background:var(--pill-blue-bg);color:var(--pill-blue)}.pill-zinc{background:var(--pill-zinc-bg);color:var(--pill-zinc)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-sans), -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;background:var(--bg);color:var(--text);font-feature-settings:"ss01", "ss02", "cv01", "cv02";min-height:100vh}code,pre,kbd,samp,.mono,[data-mono]{font-family:var(--font-mono), "JetBrains Mono", "SF Mono", "Cascadia Code", monospace;font-feature-settings:"zero", "ss01"}.home{justify-content:center;align-items:center;min-height:100vh;padding:2rem;display:flex}.home-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);width:100%;max-width:420px;padding:3rem}.home-card h1{margin-bottom:.5rem;font-size:1.75rem}.subtitle{color:var(--text-muted);margin-bottom:2rem}.brand-logo{margin:0 auto 1rem;display:block}.section{margin-bottom:1.5rem}.section h2{color:var(--text-muted);margin-bottom:.75rem;font-size:1rem}.home-join h2{color:var(--text);font-size:1.05rem}.join-row{align-items:stretch;gap:.5rem;display:flex}.join-row input,.join-row .btn-primary{box-sizing:border-box;height:46px;margin:0;padding:0 1rem;font-size:1rem}.join-row input{flex:2 1 0;width:auto;min-width:0}.join-row .btn-primary{white-space:nowrap;flex:1 1 0}.home-host{margin-bottom:0}.host-cta{gap:.6rem;display:flex}.host-cta .btn-secondary{flex:1}.divider{color:var(--text-muted);align-items:center;gap:.75rem;margin:1.5rem 0;font-size:.85rem;display:flex}.divider:before,.divider:after{content:"";background:var(--border);flex:1;height:1px}input[type=text],input[type=email],input[type=password]{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);width:100%;color:var(--text);outline:none;margin-bottom:.75rem;padding:.75rem 1rem;font-size:.95rem;transition:border-color .15s}input[type=text]:focus,input[type=email]:focus,input[type=password]:focus{border-color:var(--accent)}.btn-primary,.btn-secondary{border-radius:var(--radius);cursor:pointer;border:none;width:100%;padding:.75rem 1rem;font-size:.95rem;font-weight:600;transition:background .15s}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover:not(:disabled){background:var(--accent-hover)}.btn-primary:disabled{opacity:.5;cursor:default}.btn-google{border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-elevated);width:100%;color:var(--text);cursor:pointer;padding:.75rem 1rem;font-size:.95rem;font-weight:600;transition:background .15s,border-color .15s}.btn-google:hover{background:var(--bg-surface);border-color:var(--accent)}.btn-link{color:var(--text-muted);cursor:pointer;background:0 0;border:none;font-size:.85rem;text-decoration:underline}.auth-bar{justify-content:space-between;align-items:center;margin-bottom:.75rem;padding:.5rem 0;display:flex}.auth-user{color:var(--text-muted);font-size:.9rem}.auth-hint{color:var(--text-muted);margin-bottom:.75rem;font-size:.9rem}.auth-error{color:var(--danger);margin-bottom:.5rem;font-size:.85rem}.auth-legal{color:var(--text-muted);text-align:center;margin-top:.75rem;font-size:.75rem}.auth-legal a{color:var(--accent);text-decoration:none}.auth-legal a:hover{text-decoration:underline}.auth-tabs{border:1px solid var(--border);border-radius:var(--radius);gap:0;margin-bottom:1rem;display:flex;overflow:hidden}.auth-tab{background:var(--bg);color:var(--text-muted);cursor:pointer;border:none;flex:1;padding:.6rem 1rem;font-size:.9rem;font-weight:600;transition:background .15s,color .15s}.auth-tab:not(:last-child){border-right:1px solid var(--border)}.auth-tab--active{background:var(--bg-elevated);color:var(--text)}.auth-tab:hover:not(.auth-tab--active){background:var(--bg-surface)}.auth-form{flex-direction:column;display:flex}.btn-secondary{background:var(--bg-elevated);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){background:var(--border)}.btn-secondary:disabled{opacity:.5;cursor:default}.prejoin{overscroll-behavior:contain;justify-content:center;align-items:center;height:100dvh;padding:2rem;display:flex;overflow-y:auto}@media (max-width:640px){.prejoin{align-items:flex-start;padding:.75rem}}.prejoin-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);width:100%;max-width:480px;padding:2rem}.prejoin-card h2{margin-bottom:.25rem}.camera-preview{border-radius:var(--radius);aspect-ratio:16/9;background:#000;margin:1.5rem 0;position:relative;overflow:hidden}.camera-preview video{object-fit:cover;width:100%;height:100%;transform:scaleX(-1)}.camera-off{color:var(--text-muted);justify-content:center;align-items:center;font-size:1.1rem;display:flex;position:absolute;inset:0}.device-toggles{gap:.75rem;margin-bottom:1.5rem;display:flex}.toggle{border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);color:var(--text);cursor:pointer;flex:1;padding:.5rem;font-size:.85rem}.prejoin-actions{gap:.75rem;margin-top:1rem;display:flex}.prejoin-actions .btn-secondary{flex:none;width:auto;padding:.75rem 1.5rem}.prejoin-actions .btn-primary{flex:1}.error{color:var(--danger);margin:1rem 0}.room{flex-direction:column;height:100dvh;min-height:0;display:flex;overflow:hidden}.room-header{background:var(--bg-surface);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:.85rem;padding:.75rem 1.5rem;display:flex}.room-name{font-weight:600}.room-timer{color:var(--text-muted);padding-left:.25rem;font-family:JetBrains Mono,monospace;font-size:.85rem}.room-status{color:var(--text-muted);padding-left:.25rem;font-size:.85rem}.room-theme-toggle{border:1px solid var(--border);width:32px;height:32px;color:var(--text-muted);cursor:pointer;background:0 0;border-radius:8px;justify-content:center;align-items:center;margin-left:auto;transition:background .15s,color .15s,border-color .15s;display:inline-flex}.room-theme-toggle:hover{background:var(--bg-hover);color:var(--text);border-color:var(--text-muted)}.video-grid{flex:1;place-items:center stretch;gap:8px;min-height:0;padding:8px;display:grid;overflow:hidden}.grid-1{grid-template-columns:minmax(0,1fr)}.grid-2{grid-template-rows:minmax(0,1fr);grid-template-columns:minmax(0,1fr) minmax(0,1fr);align-items:center}.grid-4{grid-template-rows:minmax(0,1fr) minmax(0,1fr);grid-template-columns:minmax(0,1fr) minmax(0,1fr)}.grid-6{grid-template-rows:repeat(2,minmax(0,1fr));grid-template-columns:repeat(3,minmax(0,1fr))}.grid-9{grid-template-rows:repeat(3,minmax(0,1fr));grid-template-columns:repeat(3,minmax(0,1fr))}.grid-12{grid-template-rows:repeat(3,minmax(0,1fr));grid-template-columns:repeat(4,minmax(0,1fr))}.grid-16{grid-template-rows:repeat(4,minmax(0,1fr));grid-template-columns:repeat(4,minmax(0,1fr))}.grid-many{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.layout-spotlight{flex:1;gap:8px;padding:8px;display:flex;overflow:hidden}.spotlight-main{flex:1;align-items:stretch;min-width:0;display:flex}.spotlight-main .video-tile{aspect-ratio:auto;width:100%;height:100%}.spotlight-main .video-tile video{object-fit:contain}.spotlight-filmstrip{flex-direction:column;gap:6px;width:180px;min-width:180px;display:flex;overflow:hidden auto}.spotlight-filmstrip .video-tile{aspect-ratio:1;flex-shrink:0;min-height:0}.spotlight-filmstrip .video-tile video{object-fit:cover}.video-tile{border-radius:var(--radius);background:#000;border:2px solid #0000;transition:border-color .2s;position:relative;overflow:hidden}.video-tile:not(.screen-tile){aspect-ratio:16/9;min-height:140px}.grid-2 .video-tile:not(.screen-tile),.grid-4 .video-tile:not(.screen-tile),.grid-6 .video-tile:not(.screen-tile),.grid-9 .video-tile:not(.screen-tile),.grid-12 .video-tile:not(.screen-tile),.grid-16 .video-tile:not(.screen-tile){aspect-ratio:auto;width:100%;height:100%;min-height:0}.video-tile.active-speaker{border-color:var(--accent)}.video-tile:not(.screen-tile) video{object-fit:cover;background:0 0;width:100%;height:100%;position:absolute;inset:0}.video-tile video.mirrored{transform:scaleX(-1)}.video-off-overlay{background:var(--bg-elevated);color:var(--text-muted);justify-content:center;align-items:center;font-size:3rem;font-weight:700;display:flex;position:absolute;inset:0}.tile-label{background:linear-gradient(#0000,#000000b3);align-items:center;gap:.4rem;padding:.4rem .75rem;display:flex;position:absolute;bottom:0;left:0;right:0}.tile-name{color:#fff;font-size:.8rem}.mute-indicator{background:var(--danger);border-radius:50%;width:8px;height:8px}.controls{background:var(--bg-surface);border-top:1px solid var(--border);justify-content:center;align-items:center;gap:1rem;padding:1rem;display:flex}.controls-inactive .control-btn:not(.leave){opacity:.4;pointer-events:none;filter:grayscale(.4)}.control-btn{border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-elevated);min-width:62px;color:var(--text);cursor:pointer;letter-spacing:.01em;flex-direction:column;justify-content:center;align-items:center;gap:.2rem;padding:.55rem .9rem;font-size:.7rem;font-weight:500;transition:background .15s,color .15s,border-color .15s;display:flex;position:relative}.control-btn svg{display:block}.control-label{opacity:.85;font-size:.7rem;line-height:1}.control-btn:hover{background:var(--border)}.control-btn.off,.control-btn.recording{color:var(--danger);border-color:var(--danger)}.control-btn.leave{background:var(--danger);color:#fff;border:none}.control-btn.leave:hover{background:#dc2626}.controls-more-item.more-item-foldable{display:none}@media (max-width:640px){.control-foldable{display:none}.controls-more-item.more-item-foldable{display:flex}.controls{gap:.4rem;padding:.55rem .4rem}.control-btn{min-width:0;padding:.5rem .55rem}.control-btn .control-label{display:none}}.controls-more{position:relative}.controls-more-menu{background:var(--bg-elevated);border:1px solid var(--border);z-index:20;border-radius:8px;flex-direction:column;gap:2px;min-width:220px;padding:.35rem;display:flex;position:absolute;bottom:calc(100% + .5rem);right:0;box-shadow:0 8px 24px #00000059}.controls-more-item{color:var(--text);text-align:left;cursor:pointer;background:0 0;border:none;border-radius:6px;align-items:center;gap:.6rem;padding:.55rem .7rem;font-size:.85rem;transition:background .12s;display:flex}.controls-more-item:hover:not(:disabled){background:var(--border)}.controls-more-item:disabled{opacity:.4;cursor:not-allowed}.controls-more-item.active{color:var(--accent)}.controls-more-item svg{flex-shrink:0}.btn-toggle-advanced{color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:.5rem 0;font-size:.85rem;text-decoration:underline}.advanced-options{margin:1rem 0}.option-group{margin-bottom:1.25rem}.option-group h3{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.5rem;font-size:.85rem}.option-row{justify-content:space-between;align-items:center;gap:.75rem;margin-bottom:.5rem;font-size:.9rem;display:flex}.option-row select,.option-row input[type=number]{background:var(--bg);border:1px solid var(--border);color:var(--text);border-radius:6px;max-width:220px;padding:.4rem .5rem;font-size:.85rem}.option-note{color:var(--text-muted);background:var(--bg);border-radius:6px;padding:.5rem;font-size:.8rem}.e2ee-badge{color:var(--success);font-size:.85rem;font-weight:600}.e2ee-indicator{background:var(--success);color:var(--bg);border-radius:4px;padding:.15rem .5rem;font-size:.7rem;font-weight:700}.device-settings{grid-template-columns:1fr 1fr;gap:.4rem;margin:.5rem 0;display:grid;overflow:hidden}.device-select{flex-direction:column;gap:.15rem;font-size:.8rem;display:flex}.device-label{color:var(--text-muted);font-size:.7rem;font-weight:500}.device-select select{border:1px solid var(--border);background:var(--bg);color:var(--text);appearance:none;text-overflow:ellipsis;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%236b7b95'/%3E%3C/svg%3E");background-position:right .4rem center;background-repeat:no-repeat;border-radius:4px;width:100%;min-width:0;padding:.35rem 1.5rem .35rem .35rem;font-size:.75rem}.device-toggles{flex-wrap:wrap;gap:.4rem;margin:.5rem 0;display:flex}.toggle{border:1px solid var(--border);background:var(--bg-elevated);color:var(--text);cursor:pointer;border-radius:6px;padding:.4rem .75rem;font-size:.8rem}.toggle.on{border-color:var(--accent);color:var(--accent)}.toggle.off{border-color:var(--danger);color:var(--danger)}.preview-blur{filter:blur(8px)}.btn-toggle-advanced{color:var(--text-muted);cursor:pointer;text-align:left;background:0 0;border:none;padding:.25rem 0;font-size:.75rem}.btn-toggle-advanced:hover{color:var(--text)}.prejoin-gear{cursor:pointer;color:var(--text-muted);border-radius:var(--radius);background:0 0;border:none;align-items:center;padding:.3rem;transition:color .15s,background .15s;display:inline-flex}.prejoin-gear:hover{color:var(--text);background:var(--bg-elevated)}.prejoin-settings{background:var(--bg);border-radius:var(--radius);border:1px solid var(--border);margin:.25rem 0 .5rem;padding:.75rem}.prejoin-settings .device-settings{margin-bottom:0}.prejoin-settings .advanced-media{background:0 0;border:none;padding:.5rem 0 0}.advanced-media{background:var(--bg);border-radius:var(--radius);border:1px solid var(--border);margin:.25rem 0 .5rem;padding:.5rem}.codec-checks,.mode-select{margin-bottom:.4rem}.codec-row{flex-wrap:wrap;gap:.75rem;margin-top:.2rem;display:flex}.codec-check{cursor:pointer;align-items:center;gap:.25rem;font-size:.8rem;display:flex}.codec-check input{cursor:pointer;accent-color:var(--accent)}.codec-check span{-webkit-user-select:none;user-select:none}.connection-error{border:1px solid var(--danger);border-radius:var(--radius);color:var(--text);text-align:center;background:#ef444426;flex-direction:column;align-items:center;gap:.5rem;margin:.5rem 1rem;padding:1rem;font-size:.9rem;display:flex}.connection-error strong{color:var(--danger)}.connection-error p{color:var(--text-muted);margin:0;font-size:.85rem}.connection-failed-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;background:#05070ed9;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.connection-failed-card{background:var(--bg-surface);border:1px solid var(--danger);border-radius:var(--radius);text-align:center;max-width:440px;padding:1.75rem 2rem;box-shadow:0 20px 50px #00000080}.connection-failed-card h2{color:var(--danger);margin:0 0 .75rem;font-size:1.2rem}.connection-failed-card p{color:var(--text-muted);margin:0 0 .75rem;font-size:.9rem;line-height:1.5}.connection-failed-detail{color:var(--danger);background:#ef444414;border-radius:4px;padding:.4rem .6rem;font-family:monospace;font-size:.78rem}.connection-failed-actions{justify-content:center;gap:.75rem;margin-top:1.25rem;display:flex}.reaction-float-layer{pointer-events:none;z-index:5;position:absolute;inset:0;overflow:hidden}.reaction-float{filter:drop-shadow(0 2px 6px #0000008c);will-change:transform, opacity;font-size:2.6rem;animation:2.1s cubic-bezier(.22,1,.36,1) forwards reaction-rise;position:absolute;bottom:18%}@keyframes reaction-rise{0%{opacity:0;transform:translateY(20px)scale(.5)}15%{opacity:1;transform:translateY(0)scale(1.2)}30%{opacity:1;transform:translateY(-20px)scale(1)}to{opacity:0;transform:translateY(-160px)scale(.85)}}.reaction-picker{background:var(--bg-elevated);border:1px solid var(--border);z-index:20;border-radius:999px;gap:.35rem;padding:.4rem .6rem;display:flex;position:absolute;bottom:calc(100% + .5rem);left:50%;transform:translate(-50%);box-shadow:0 8px 24px #00000059}.reaction-picker button{cursor:pointer;background:0 0;border:none;border-radius:999px;padding:.25rem .45rem;font-size:1.5rem;line-height:1;transition:background .12s,transform .12s}.reaction-picker button:hover{background:var(--border);transform:scale(1.18)}.dashboard-advanced-toggle{margin-left:.5rem;font-size:.8rem}.dashboard-create-advanced{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;gap:.55rem;width:100%;margin-top:.75rem;padding:.75rem 1rem;display:flex}.dashboard-option{color:var(--text);align-items:center;gap:.6rem;font-size:.85rem;display:flex}.dashboard-option>span:first-child{color:var(--text-muted);flex:0 0 150px}.dashboard-lang-row{flex-wrap:wrap;flex:1;gap:.5rem;display:flex}.dashboard-lang-chip{border:1px solid var(--border,#2a3a5c);cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:999px;align-items:center;gap:.35rem;padding:.25rem .6rem;font-size:.85rem;display:inline-flex}.dashboard-lang-chip input{margin:0}.dashboard-option input[type=number],.dashboard-option select{background:var(--bg-elevated);color:var(--text);border:1px solid var(--border);border-radius:6px;flex:1;padding:.35rem .5rem;font-size:.85rem}.dashboard-option input[type=checkbox]{width:16px;height:16px;accent-color:var(--accent)}.connection-banner{text-align:center;border-radius:var(--radius);margin:0 1rem;padding:.5rem 1rem;font-size:.85rem}.connection-banner.connecting{color:var(--accent);background:#6366f126;animation:1.5s ease-in-out infinite pulse}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.status-connecting{color:var(--accent)}.status-error{color:var(--danger)}.precall{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);margin:.75rem 0;padding:.75rem}.precall h3{margin:0 0 .25rem;font-size:.95rem}.precall-desc{color:var(--text-muted);margin-bottom:.5rem;font-size:.8rem}.precall-running{color:var(--text-muted);font-size:.85rem;font-style:italic}.precall-results{flex-direction:column;gap:.5rem;display:flex}.precall-row{align-items:flex-start;gap:.5rem;font-size:.85rem;display:flex}.precall-row p{margin:0}.precall-row small{color:var(--text-muted);font-size:.7rem}.precall-row strong{font-size:.8rem}.precall-icon{text-align:center;flex-shrink:0;width:1.2rem;margin-top:.1rem;font-size:1rem}.precall-pass{color:var(--success)}.precall-fail{color:var(--danger)}.precall-pending{color:var(--text-muted)}.precall-actions{gap:.5rem;margin-top:.5rem;display:flex}.room-body{flex:1;min-height:0;display:flex;overflow:hidden}.room-body .video-grid{flex:1;min-height:0}.chat-panel{background:var(--bg-surface);border-left:1px solid var(--border);flex-direction:column;flex-shrink:0;width:320px;display:flex}@media (max-width:640px){.chat-panel{z-index:200;border-left:none;width:100%;position:fixed;inset:0}}.chat-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:.75rem 1rem;font-size:.9rem;font-weight:600;display:flex}.chat-close{color:var(--text-muted);cursor:pointer;background:0 0;border:none;font-size:1.3rem;line-height:1}.chat-close:hover{color:var(--text)}.chat-messages{flex:1;padding:.75rem;overflow-y:auto}.chat-empty{color:var(--text-muted);text-align:center;padding:2rem 0;font-size:.85rem}.chat-msg{margin-bottom:.75rem}.chat-msg-local .chat-sender{color:var(--accent)}.chat-msg-header{justify-content:space-between;align-items:baseline;margin-bottom:.15rem;display:flex}.chat-sender{color:var(--text-muted);font-size:.75rem;font-weight:600}.chat-time{color:var(--text-muted);font-size:.65rem}.chat-text{color:var(--text);word-break:break-word;white-space:pre-wrap;font-size:.85rem;line-height:1.4}.chat-input-row{border-top:1px solid var(--border);align-items:center;gap:.4rem;padding:.6rem;display:flex}.chat-input-row input{border:1px solid var(--border);background:var(--bg);color:var(--text);border-radius:6px;outline:none;flex:1;padding:.5rem .6rem;font-size:.85rem}.chat-input-row input:focus{border-color:var(--accent)}.chat-emoji-toggle{cursor:pointer;background:0 0;border:none;border-radius:4px;padding:.2rem;font-size:1.2rem}.chat-emoji-toggle.active{background:var(--border)}.chat-send{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:6px;padding:.5rem .75rem;font-size:.8rem;font-weight:500}.chat-send:hover{background:var(--accent-hover)}.chat-send:disabled{opacity:.4;cursor:default}.emoji-picker{border-top:1px solid var(--border);background:var(--bg-elevated);max-height:180px;padding:.5rem;overflow-y:auto}.emoji-group-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin:.25rem 0;font-size:.65rem;font-weight:600}.emoji-grid{flex-wrap:wrap;gap:2px;display:flex}.emoji-btn{cursor:pointer;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;width:32px;height:32px;font-size:1.2rem;display:flex}.emoji-btn:hover{background:var(--border)}.unread-badge{background:var(--danger);color:#fff;border-radius:50%;justify-content:center;align-items:center;min-width:16px;height:16px;margin-left:.3rem;padding:0 4px;font-size:.6rem;font-weight:700;display:inline-flex}.control-btn.active{border-color:var(--accent);color:var(--accent)}.participant-panel{background:var(--bg-surface);border-left:1px solid var(--border);flex-direction:column;flex-shrink:0;width:320px;display:flex}.participant-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:.75rem 1rem;font-size:.9rem;font-weight:600;display:flex}.participant-list{flex:1;padding:.5rem;overflow-y:auto}.participant-item{border-radius:6px;justify-content:space-between;align-items:center;padding:.5rem;transition:background .15s;display:flex}.participant-item:hover{background:var(--bg-elevated)}.participant-speaking{border-left:2px solid var(--success);background:#22c55e1a}.participant-info{flex:1;align-items:center;gap:.5rem;min-width:0;display:flex}.participant-avatar{background:var(--bg-elevated);width:28px;height:28px;color:var(--text-muted);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.75rem;font-weight:600;display:flex}.participant-name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:.82rem;overflow:hidden}.participant-actions{flex-shrink:0;align-items:center;gap:.35rem;display:flex}.participant-track-icon{opacity:.7;font-size:.85rem}.participant-track-icon.track-off{opacity:.4}.participant-action-btn{border:1px solid var(--border);background:var(--bg-elevated);color:var(--text-muted);cursor:pointer;border-radius:4px;padding:.2rem .5rem;font-size:.7rem;transition:background .15s}.participant-action-btn:hover{background:var(--border);color:var(--text)}.participant-action-btn:disabled{opacity:.4;cursor:default}.participant-action-remove{border-color:var(--danger);color:var(--danger)}.participant-action-remove:hover{background:var(--danger);color:#fff}.lobby-screen{background:var(--bg);justify-content:center;align-items:center;height:100vh;display:flex}.lobby-card{text-align:center;background:var(--bg-surface);border-radius:var(--radius);border:1px solid var(--border);max-width:400px;padding:2rem 3rem}.lobby-title{color:var(--text);margin:0 0 .5rem;font-size:1.3rem;font-weight:700}.lobby-subtitle{color:var(--text-muted);margin:0 0 1.5rem;font-size:.9rem}.lobby-preview{border-radius:var(--radius);background:var(--bg-elevated);width:200px;height:150px;margin:0 auto 1rem;overflow:hidden}.lobby-preview video{object-fit:cover;width:100%;height:100%}.lobby-avatar{width:100%;height:100%;color:var(--text-muted);justify-content:center;align-items:center;font-size:2.5rem;font-weight:700;display:flex}.lobby-spinner{border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:24px;height:24px;margin:.5rem auto;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.lobby-waiting-text{color:var(--text-muted);margin:0;font-size:.85rem}.lobby-notification{background:var(--bg-elevated);border-bottom:1px solid var(--border);padding:.5rem 1rem}.lobby-notification-item{color:var(--text);align-items:center;gap:.75rem;padding:.4rem 0;font-size:.85rem;display:flex}.btn-lobby-admit{background:var(--success);color:#fff;cursor:pointer;border:none;border-radius:4px;padding:.25rem .75rem;font-size:.75rem;font-weight:500}.btn-lobby-admit:hover{filter:brightness(1.1)}.btn-lobby-deny{border:1px solid var(--danger);color:var(--danger);cursor:pointer;background:0 0;border-radius:4px;padding:.25rem .75rem;font-size:.75rem;font-weight:500}.btn-lobby-deny:hover{background:var(--danger);color:#fff}.quality-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px;margin-right:.3rem;display:inline-block}.quality-good{background:var(--success)}.quality-fair{background:#eab308}.quality-poor{background:var(--danger)}.quality-warning{color:#eab308;text-align:center;background:#eab30826;border-bottom:1px solid #eab3084d;padding:.4rem;font-size:.8rem}.video-tile{cursor:pointer;transition:border-color .15s}.video-off-overlay{background:var(--bg);justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.video-off-avatar{background:var(--accent);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:64px;height:64px;font-size:1.5rem;font-weight:700;display:flex}.pin-badge{background:#00000080;border-radius:4px;padding:2px 6px;font-size:.8rem;position:absolute;top:6px;right:6px}.screen-badge{background:var(--accent);color:#fff;border-radius:3px;margin-right:.3rem;padding:.1rem .3rem;font-size:.6rem;font-weight:700}.video-tile.screen-tile{aspect-ratio:16/9;grid-column:1/-1}.video-tile.screen-tile video{object-fit:contain;background:#000;width:100%;height:100%;position:absolute;inset:0}.video-tile.screen-tile .tile-label:before{content:"Screen";background:var(--accent);color:#fff;border-radius:3px;margin-right:.4rem;padding:.1rem .4rem;font-size:.65rem;font-weight:700}.video-tile.pinned{grid-area:span 2/1/auto/-1}.tile-controls{opacity:0;gap:4px;transition:opacity .15s;display:flex;position:absolute;top:6px;right:6px}.video-tile:hover .tile-controls{opacity:1}.tile-ctrl-btn{color:#fff;cursor:pointer;background:#0009;border:none;border-radius:4px;justify-content:center;align-items:center;width:28px;height:28px;font-size:.7rem;display:flex}.tile-ctrl-btn:hover{background:#000c}.tile-ctrl-btn.active{background:var(--accent)}.mute-indicator{flex-shrink:0;margin-right:2px;font-size:.75rem}.volume-bar{background:0 0;height:3px;position:absolute;bottom:0;left:0;right:0}.volume-bar-fill{background:var(--success);border-radius:0 0 var(--radius) var(--radius);height:100%;transition:width .1s}.whip-overlay{z-index:100;background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.whip-modal{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);width:460px;max-width:90vw;max-height:90vh;padding:1.5rem;overflow-y:auto}.whip-header{justify-content:space-between;align-items:center;margin-bottom:.5rem;display:flex}.whip-header h3{margin:0;font-size:1.1rem}.whip-close{color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:0;font-size:1.4rem;line-height:1}.whip-close:hover{color:var(--text)}.whip-desc{color:var(--text-muted);margin-bottom:1rem;font-size:.85rem;line-height:1.5}.whip-generate{width:100%}.whip-result label{color:var(--text-muted);margin-top:.75rem;margin-bottom:.25rem;font-size:.75rem;font-weight:600;display:block}.whip-result label:first-child{margin-top:0}.whip-copy-row{gap:.5rem;display:flex}.whip-copy-row input{border:1px solid var(--border);background:var(--bg);color:var(--text);border-radius:4px;flex:1;padding:.5rem;font-family:monospace;font-size:.8rem}.btn-copy{background:var(--accent);color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:4px;padding:.5rem .75rem;font-size:.8rem}.btn-copy:hover{background:var(--accent-hover)}.btn-copy.copied{background:var(--success)}.whip-instructions{color:var(--text-muted);margin-top:1rem;font-size:.8rem;line-height:1.6}.whip-instructions strong{color:var(--text)}.whip-instructions ol{margin:.25rem 0;padding-left:1.25rem}.whip-expires{color:var(--text-muted);margin-top:.5rem;font-size:.75rem;font-style:italic}.admin-layout{min-height:100vh;display:flex}.admin-sidebar{background:var(--bg);border-right:1px solid var(--border);flex-direction:column;width:220px;padding:1.5rem 1rem;display:flex}.admin-logo{color:var(--accent);align-items:center;gap:.5rem;margin-bottom:2rem;font-size:1.1rem;font-weight:700;display:flex}.admin-nav{flex-direction:column;flex:1;gap:1.2rem;display:flex}.admin-nav-group{flex-direction:column;display:flex}.admin-nav-group-label{font-family:var(--font-mono), monospace;letter-spacing:.2em;text-transform:uppercase;color:var(--text-faint);padding:0 .75rem .4rem;font-size:.62rem;font-weight:600}.admin-nav-item{text-align:left;width:100%;color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:5px;padding:.5rem .75rem;font-size:.88rem;transition:background .15s,color .15s;display:block}.admin-nav-item:hover{background:var(--bg-elevated);color:var(--text-secondary)}.admin-nav-item.active{background:var(--bg-elevated);color:var(--text);position:relative}.admin-nav-item.active:before{content:"";background:linear-gradient(180deg, var(--opc-hero-from), var(--opc-hero-via));border-radius:1px;width:2px;position:absolute;top:25%;bottom:25%;left:-1rem}.admin-back{color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:.5rem 0;font-size:.85rem}.admin-user{border-top:1px solid var(--opc-rule);flex-direction:column;gap:.55rem;padding-top:.85rem;display:flex}.admin-user-identity{flex-direction:column;gap:.15rem;display:flex}.admin-user-name{color:var(--text);text-overflow:ellipsis;white-space:nowrap;font-size:.85rem;font-weight:500;overflow:hidden}.admin-user-email{font-family:var(--font-mono), monospace;color:var(--text-muted);text-overflow:ellipsis;white-space:nowrap;font-size:.7rem;overflow:hidden}.admin-user-role{font-family:var(--font-mono), monospace;letter-spacing:.16em;text-transform:uppercase;color:var(--pill-blue);background:var(--pill-blue-bg);border-radius:3px;align-self:flex-start;margin-top:.3rem;padding:.1rem .45rem;font-size:.62rem}.admin-user-actions{justify-content:space-between;align-items:center;gap:.4rem;display:flex}.admin-user-icon{border:1px solid var(--opc-rule);cursor:pointer;color:var(--text-muted);background:0 0;border-radius:5px;padding:.3rem .5rem;font-size:.85rem;transition:color .15s,border-color .15s,background .15s}.admin-user-icon:hover{color:var(--text);border-color:var(--opc-rule-strong);background:var(--bg-elevated)}.admin-user-signout{border:1px solid var(--opc-rule);color:var(--text-secondary);cursor:pointer;font-family:var(--font-mono), monospace;letter-spacing:.1em;text-transform:uppercase;background:0 0;border-radius:5px;flex:1;padding:.4rem .85rem;font-size:.72rem;transition:color .15s,border-color .15s,background .15s}.admin-user-signout:hover{color:var(--danger);border-color:var(--danger);background:#ef44440f}.admin-back-prominent{text-align:left;background:var(--bg-elevated,#ffffff0a);border:1px solid var(--border,#2a3a5c);width:100%;color:var(--text,#e2e8f0);cursor:pointer;border-radius:6px;margin:.5rem 0 1rem;padding:.6rem .9rem;font-size:.9rem;font-weight:500;transition:background .15s,border-color .15s;display:block}.admin-back-prominent:hover{border-color:var(--accent,#5dd6c0);color:var(--accent,#5dd6c0);background:#5dd6c014}.admin-content{flex:1;padding:2rem;overflow-y:auto}.admin-topbar{border-bottom:1px solid var(--opc-rule);justify-content:flex-end;align-items:center;gap:.6rem;margin-bottom:1rem;padding-bottom:.85rem;display:flex}.admin-topbar .admin-user-name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;max-width:24rem;font-size:.85rem;font-weight:500;overflow:hidden}.admin-topbar .admin-user-role{font-family:var(--font-mono), monospace;letter-spacing:.12em;text-transform:uppercase;color:var(--pill-blue);background:var(--pill-blue-bg);border-radius:3px;align-self:center;margin:0;padding:.12rem .4rem;font-size:.6rem}.admin-topbar .admin-user-signout{flex:none}.admin-header{flex-wrap:wrap;align-items:center;gap:1.5rem;margin-bottom:1.5rem;display:flex}.admin-header h1{margin:0;font-size:1.5rem}.server-stats{color:var(--text-muted);gap:1rem;font-size:.85rem;display:flex}.server-stats .stat strong{color:var(--text)}.system-stats-panel{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:1.5rem;padding:1rem 1.25rem}.system-stats-grid{grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:1rem;display:grid}.stat-tile{background:var(--bg-elevated);border-radius:6px;flex-direction:column;gap:.15rem;padding:.5rem .75rem;display:flex}.stat-tile .stat-label{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);font-size:.7rem}.stat-tile .stat-value{font-variant-numeric:tabular-nums;color:var(--text);font-size:1.35rem;font-weight:600}.stat-tile .stat-value.caution{color:#d49a3a}.stat-tile .stat-value.warn{color:#d4624a}.stat-tile .stat-sub{color:var(--text-muted);font-size:.72rem}.system-workers-details{color:var(--text-muted);margin-top:.75rem;font-size:.8rem}.system-workers-details summary{cursor:pointer;-webkit-user-select:none;user-select:none;padding:.25rem 0}.system-workers-table{border-collapse:collapse;width:100%;margin-top:.5rem}.system-workers-table th,.system-workers-table td{text-align:left;font-variant-numeric:tabular-nums;padding:.25rem .5rem}.system-workers-table th{color:var(--text);border-bottom:1px solid var(--border);font-weight:600}.system-workers-table td.warn{color:#d4624a}.sessions-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem;display:grid}.session-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;text-align:left;padding:1rem;transition:border-color .15s}.session-card:hover{border-color:var(--accent)}.session-card-header{justify-content:space-between;align-items:center;margin-bottom:.5rem;display:flex}.session-room-id{font-family:monospace;font-weight:600}.session-card-body{color:var(--text-muted);font-size:.85rem}.session-participants{margin-top:.25rem;display:block}.badge{background:var(--bg-elevated);border-radius:12px;padding:.2rem .6rem;font-size:.75rem}.badge-active{background:var(--success);color:var(--bg)}.badge-automated{color:#f59e0b;background:#f59e0b2e;border:1px solid #f59e0b73}.badge-muted{color:var(--text-muted)}.session-card-automated{border-color:#f59e0b59}.session-card-footer{border-top:1px solid var(--border);color:var(--text-muted);justify-content:space-between;align-items:center;margin-top:.65rem;padding-top:.5rem;font-size:.7rem;display:flex}.session-card-id{font-family:monospace}.session-card-age{color:var(--text-muted)}.empty-state{color:var(--text-muted);text-align:center;padding:3rem;font-size:.95rem}.empty-state p{margin:0 0 .75rem}.empty-state p:last-child{margin-bottom:0}.admin-empty-hint{text-align:left;max-width:42rem;color:var(--text-muted);margin-left:auto;margin-right:auto;font-size:.85rem;line-height:1.5}.admin-empty-hint a{color:var(--accent)}.admin-empty-hint code{font-size:.88em}.admin-api-error{border-radius:var(--radius);border:1px solid var(--error,#c44);background:color-mix(in srgb, var(--error,#c44) 12%, var(--bg-surface));margin:1rem 0;padding:1rem 1.25rem;font-size:.9rem}.admin-api-error-detail{background:var(--bg);white-space:pre-wrap;word-break:break-word;border-radius:6px;max-height:12rem;margin:.75rem 0 0;padding:.75rem;font-size:.8rem;overflow-y:auto}.admin-api-error-hint{color:var(--text-muted);margin:.75rem 0 0;font-size:.85rem;line-height:1.45}.admin-api-error-hint code{font-size:.8em}.admin-api-warning{border-radius:var(--radius);border:1px solid var(--border);background:var(--bg-elevated);color:var(--text-muted);margin:1rem 0;padding:.75rem 1rem;font-size:.85rem}.admin-api-warning strong{color:var(--text)}.session-dashboard{flex-direction:column;height:100%;display:flex}.session-header{flex-wrap:wrap;align-items:center;gap:1rem;margin-bottom:1rem;display:flex}.session-header h2{margin:0;font-family:monospace;font-size:1.2rem}.session-badges{gap:.5rem;display:flex}.session-actions{gap:.5rem;margin-left:auto;display:flex}.btn-back{color:var(--text-muted);cursor:pointer;background:0 0;border:none;font-size:.9rem}.session-tabs{border-bottom:1px solid var(--border);gap:0;margin-bottom:1rem;display:flex}.session-tabs button{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;padding:.6rem 1rem;font-size:.9rem}.session-tabs button.active{color:var(--accent);border-bottom-color:var(--accent)}.session-tab-content{flex:1;overflow-y:auto}.peer-cards{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1rem;display:grid}.peer-card{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius);padding:1rem;position:relative}.peer-card-header{align-items:center;gap:.75rem;margin-bottom:.75rem;display:flex}.peer-name{font-size:.95rem;font-weight:600}.peer-actions{flex-wrap:wrap;gap:.4rem;display:flex}.btn-sm{background:var(--bg-surface);border:1px solid var(--border);color:var(--text);cursor:pointer;border-radius:6px;padding:.3rem .6rem;font-size:.75rem}.btn-sm:hover{background:var(--bg-elevated)}.btn-sm.active{border-color:var(--accent);color:var(--accent)}.btn-sm.btn-danger{background:var(--bg-surface);border:1px solid var(--danger);color:var(--danger);padding:.3rem .6rem;font-size:.75rem;font-weight:400}.btn-sm.btn-danger:hover{background:var(--danger);color:#fff}.btn-icon{color:var(--text-muted);cursor:pointer;background:0 0;border:none;font-size:1.2rem}.peer-detail{border-top:1px solid var(--border);margin-top:.75rem;padding-top:.75rem}.peer-detail-header{justify-content:space-between;align-items:center;margin-bottom:.5rem;display:flex}.peer-detail-title{text-transform:uppercase;color:var(--text-muted);letter-spacing:.05em;font-size:.8rem;font-weight:600}.peer-detail-row{align-items:center;gap:.5rem;margin-bottom:.3rem;font-size:.8rem;display:flex}.peer-detail-label{color:var(--text-muted);min-width:90px}.peer-detail-section{margin-top:.6rem}.peer-detail-section-title{text-transform:uppercase;color:var(--text-muted);letter-spacing:.05em;margin-bottom:.3rem;font-size:.75rem;font-weight:600;display:block}.peer-detail-empty{color:var(--text-muted);font-size:.8rem;font-style:italic}.peers-split{gap:1rem;height:calc(100vh - 220px);display:flex}.peers-list{border-right:1px solid var(--border);flex-direction:column;flex:0 0 200px;gap:2px;padding-right:1rem;display:flex;overflow-y:auto}.peer-list-item{border-radius:var(--radius);color:var(--text);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:.5rem;width:100%;padding:.6rem .75rem;font-size:.85rem;display:flex}.peer-list-item:hover{background:var(--bg-elevated)}.peer-list-item.selected{background:var(--accent);color:#fff}.peer-list-item.selected .badge{color:#fff;background:#fff3}.peer-list-name{font-weight:500}.peers-detail{flex:1;padding:0 .5rem;overflow-y:auto}.peer-panel-header{align-items:center;gap:.5rem;margin-bottom:.75rem;display:flex}.peer-panel-header h3{margin:0;font-size:1.1rem}.stat-warn{color:var(--danger);font-weight:600}.accordion{border-bottom:1px solid var(--border)}.accordion-header{width:100%;color:var(--text);cursor:pointer;text-transform:uppercase;letter-spacing:.04em;background:0 0;border:none;align-items:center;padding:.6rem 0;font-size:.8rem;font-weight:600;display:flex}.accordion-header:hover{color:var(--accent)}.accordion-body{padding:0 0 .75rem}.peer-detail-table{border-collapse:collapse;table-layout:auto;width:100%;font-size:.75rem}.peer-detail-table th{text-align:left;color:var(--text-muted);border-bottom:1px solid var(--border);white-space:nowrap;padding:.25rem .4rem;font-weight:500}.peer-detail-table td{text-overflow:ellipsis;white-space:nowrap;border-bottom:1px solid #33415566;max-width:200px;padding:.25rem .4rem;overflow:hidden}.peer-detail-table tr.slot-empty td{opacity:.5}.peer-detail-table code{background:var(--bg);border-radius:3px;padding:.1rem .3rem;font-size:.7rem}.kind-badge{text-transform:uppercase;border-radius:3px;padding:.1rem .35rem;font-size:.65rem;font-weight:600;display:inline-block}.kind-audio{color:var(--success);background:#22c55e26}.kind-video{color:var(--accent);background:#6366f126}.codec-pt{margin-right:.3rem}.badge-role{color:var(--accent);background:#6366f126}.badge-e2ee{color:var(--success);background:#22c55e26}.peer-detail-subs{flex-wrap:wrap;gap:.3rem;display:flex}.sub-id{background:var(--bg);border-radius:3px;padding:.15rem .4rem;font-size:.7rem}.audio-meter{background:var(--bg);border-radius:3px;width:60px;height:6px;overflow:hidden}.audio-meter-fill{background:var(--success);transform-origin:0;border-radius:3px;height:100%;transition:transform .1s ease-out}.conditioner-row{align-items:center;gap:.5rem;display:flex}.conditioner-row select{border:1px solid var(--border);background:var(--bg);color:var(--text);border-radius:4px;max-width:200px;padding:.4rem;font-size:.8rem}.conditioner-sliders{color:var(--text-muted);grid-template-columns:1fr 1fr;gap:.15rem .75rem;margin-top:.4rem;font-size:.75rem;display:grid}.conditioner-sliders label{white-space:nowrap;align-items:center;gap:.3rem;display:flex}.conditioner-sliders input[type=range]{width:160px;accent-color:var(--accent)}.slider-wrap{align-items:center;gap:.2rem;display:flex}.slider-bound{color:var(--text-muted);min-width:1.5em;font-size:.6rem}.conditioner-readonly{opacity:.6}.conditioner-readonly input[type=range]{pointer-events:none}.conditioner-dropdown{box-shadow:none;background:0 0;border:none;border-radius:0;margin:0;padding:0;position:static}.conditioner-header{justify-content:space-between;align-items:center;margin-bottom:.75rem;display:flex}.conditioner-tabs{gap:0;margin-bottom:.75rem;display:flex}.conditioner-tabs button{background:var(--bg);border:1px solid var(--border);color:var(--text-muted);cursor:pointer;flex:1;padding:.4rem;font-size:.8rem}.conditioner-tabs button:first-child{border-radius:6px 0 0 6px}.conditioner-tabs button:last-child{border-radius:0 6px 6px 0}.conditioner-tabs button.active{background:var(--accent);color:#fff;border-color:var(--accent)}.conditioner-presets{grid-template-columns:1fr 1fr;gap:.4rem;display:grid}.preset-btn{background:var(--bg);border:1px solid var(--border);cursor:pointer;text-align:left;color:var(--text);border-radius:6px;padding:.5rem}.preset-btn.selected{border-color:var(--accent);background:var(--bg-elevated)}.preset-name{text-transform:capitalize;font-size:.8rem;font-weight:600;display:block}.preset-detail{color:var(--text-muted);font-size:.7rem;display:block}.conditioner-custom label{color:var(--text-muted);margin-bottom:.5rem;font-size:.8rem;display:block}.conditioner-custom input[type=range]{width:100%;accent-color:var(--accent);margin-top:.25rem}.conditioner-apply{width:100%;margin-top:.75rem}.packet-inspector{flex-direction:column;height:100%;display:flex}.packet-controls{flex-wrap:wrap;align-items:center;gap:.5rem;margin-bottom:.75rem;display:flex}.packet-controls select{background:var(--bg);border:1px solid var(--border);color:var(--text);border-radius:6px;padding:.3rem .5rem;font-size:.8rem}.packet-sparklines{margin-bottom:.75rem}.packet-downloads{flex-wrap:wrap;gap:.4rem;margin-bottom:.75rem;display:flex}.packet-summary{gap:1.5rem;margin-bottom:.75rem;font-size:.85rem;display:flex}.pkt-stat{color:var(--text-muted)}.pkt-stat:first-child{color:var(--text);font-weight:600}.stream-table{max-height:250px;font-family:JetBrains Mono,monospace;font-size:.75rem;overflow-y:auto}.stream-header-row,.stream-row{grid-template-columns:36px 100px 52px 100px 60px 80px 80px 55px 45px 40px;align-items:center;gap:.25rem;padding:.35rem .5rem;display:grid}.stream-header-row{color:var(--text-muted);border-bottom:1px solid var(--border);background:var(--bg-surface);font-weight:700;position:sticky;top:0}.stream-row{border-bottom:1px solid var(--border)}.stream-row:hover{background:var(--bg-elevated)}.dir-badge{border-radius:3px;padding:1px 4px;font-size:.65rem;font-weight:700}.dir-badge.send{color:#4ade80;background:#4ade801a}.dir-badge.recv{color:#60a5fa;background:#60a5fa1a}.capture-section{border-top:1px solid var(--border);margin-top:1.5rem;padding-top:1rem}.capture-section h4{color:var(--text-muted);margin-bottom:.5rem;font-size:.85rem}.capture-controls{flex-wrap:wrap;align-items:center;gap:.75rem;display:flex}.capture-progress{color:var(--accent);align-items:center;gap:.5rem;font-size:.8rem;display:flex}.capture-timer{font-family:JetBrains Mono,monospace;font-size:.8rem}.capture-bar{background:var(--border);border-radius:2px;width:100px;height:4px;overflow:hidden}.capture-fill{background:var(--accent);height:100%;transition:width .5s linear}.capture-result{align-items:center;gap:.5rem;display:flex}.btn-success{background:var(--success);color:#fff;text-decoration:none}.btn-success:hover{opacity:.9}.btn-record{background:var(--danger);color:#fff}.btn-record:hover{opacity:.9}.btn-record.recording{animation:1s ease-in-out infinite pulse}.section-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin:1rem 0 .4rem;font-size:.8rem}.stream-header-row-sm,.stream-row-sm{grid-template-columns:44px 110px 44px 90px 90px 80px;align-items:center;gap:.25rem;padding:.25rem .5rem;font-family:JetBrains Mono,monospace;font-size:.75rem;display:grid}.stream-header-row-sm{color:var(--text-muted);border-bottom:1px solid var(--border);font-weight:700}.stream-row-sm{border-bottom:1px solid var(--border)}.stream-row-sm:hover{background:var(--bg-elevated)}.sig-table{max-height:200px;font-family:JetBrains Mono,monospace;font-size:.72rem;overflow-y:auto}.sig-header,.sig-row{grid-template-columns:50px 110px 60px 1fr;align-items:center;gap:.5rem;padding:.2rem .5rem;display:grid}.sig-header{color:var(--text-muted);border-bottom:1px solid var(--border);font-weight:600}.sig-row{border-bottom:1px solid var(--border)}.sig-row:hover{background:var(--bg-elevated)}.sig-dir{font-size:.65rem;font-weight:600}.sig-proto{font-weight:600}.sig-peer{color:var(--text-muted);text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.sig-detail{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.packet-table{flex:1;font-family:JetBrains Mono,monospace;font-size:.75rem;overflow-y:auto}.packet-header-row,.packet-row{grid-template-columns:60px 90px 55px 80px 50px 1fr;align-items:center;gap:.25rem;padding:.2rem .5rem;display:grid}.packet-header-row{color:var(--text-muted);border-bottom:1px solid var(--border);background:var(--bg-surface);font-weight:700;position:sticky;top:0}.packet-row{border-bottom:1px solid var(--border)}.packet-row:hover{background:var(--bg-elevated)}.proto-rtp-audio{color:#60a5fa}.proto-rtp-video{color:#4ade80}.proto-rtcp{color:#fbbf24}.proto-dtls{color:#fb923c}.proto-stun{color:#94a3b8}.sparkline{align-items:center;gap:.4rem;display:inline-flex}.sparkline-label{color:var(--text-muted);font-size:.7rem}.sparkline canvas{display:block}.log-stream{flex-direction:column;height:100%;display:flex}.log-controls{align-items:center;gap:.75rem;margin-bottom:.75rem;display:flex}.log-status{font-size:.8rem}.log-status.connected{color:var(--success)}.log-status.disconnected{color:var(--danger)}.log-count{color:var(--text-muted);font-size:.8rem}.log-viewer{background:var(--bg);border-radius:var(--radius);flex:1;padding:.5rem;font-family:JetBrains Mono,monospace;font-size:.75rem;overflow-y:auto}.log-row{cursor:pointer;flex-wrap:wrap;align-items:baseline;gap:.5rem;padding:.15rem .5rem;display:flex}.log-row:hover{background:var(--bg-elevated)}.log-time{color:var(--text-muted);min-width:80px}.log-level{text-transform:uppercase;min-width:40px;font-size:.65rem;font-weight:600}.log-module{color:var(--accent);min-width:80px}.log-msg{flex:1}.log-json{background:var(--bg);border-radius:var(--radius);grid-template-columns:1fr;gap:1px;width:100%;margin:.25rem 0;padding:.5rem .75rem;font-size:.72rem;display:grid}.log-field{border-bottom:1px solid #ffffff0a;gap:.5rem;padding:.15rem 0;display:flex}.log-field-key{color:var(--accent);flex-shrink:0;min-width:100px;font-weight:600}.log-field-val{color:var(--text-muted);word-break:break-all;font-family:JetBrains Mono,monospace}.log-debug{color:var(--text-muted)}.log-info .log-level{color:#60a5fa}.log-warn .log-level{color:#f59e0b}.log-error .log-level{color:var(--danger)}.log-error{background:#ef44440d}@media (max-width:640px){.home-card,.prejoin-card{padding:1.5rem}.controls{gap:.5rem}.control-btn{padding:.6rem .8rem;font-size:.8rem}.admin-sidebar{display:none}.admin-content{padding:1rem}.peer-cards{grid-template-columns:1fr}.packet-table{font-size:.65rem}.grid-2{grid-template-rows:repeat(2,minmax(0,1fr));grid-template-columns:minmax(0,1fr)}.grid-4{grid-template-rows:repeat(2,minmax(0,1fr));grid-template-columns:repeat(2,minmax(0,1fr))}.grid-6{grid-template-rows:repeat(3,minmax(0,1fr));grid-template-columns:repeat(2,minmax(0,1fr))}.grid-9{grid-template-rows:repeat(5,minmax(0,1fr));grid-template-columns:repeat(2,minmax(0,1fr))}.grid-many{grid-template-columns:repeat(2,minmax(0,1fr))}.video-grid .video-tile:not(.screen-tile){aspect-ratio:auto;width:100%;height:100%;min-height:0}.layout-spotlight{flex-direction:column}.spotlight-filmstrip{flex-direction:row;width:auto;min-width:0;height:100px;min-height:100px;overflow:auto hidden}.spotlight-filmstrip .video-tile{aspect-ratio:1;width:auto;height:100%;min-height:0}}.pcap-viewer{flex-direction:column;gap:.75rem;height:calc(100vh - 2rem);display:flex}.pcap-dropzone{border:2px dashed var(--border);border-radius:var(--radius);background:var(--bg-surface);cursor:pointer;flex:1;justify-content:center;align-items:center;transition:border-color .15s,background .15s;display:flex}.pcap-dropzone.drag-over{border-color:var(--accent);background:var(--bg-elevated)}.pcap-dropzone-content{text-align:center;flex-direction:column;align-items:center;gap:.75rem;display:flex}.pcap-dropzone-icon{font-size:3rem}.pcap-dropzone-content h2{font-size:1.2rem;font-weight:600}.pcap-dropzone-content p{color:var(--text-muted);font-size:.85rem}.pcap-file-input{display:none}.pcap-loading,.pcap-error{flex-direction:column;flex:1;justify-content:center;align-items:center;gap:1rem;display:flex}.pcap-loading-spinner{border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:32px;height:32px;animation:.8s linear infinite spin}.pcap-error{color:var(--danger)}.pcap-toolbar{background:var(--bg-surface);border-radius:var(--radius);border:1px solid var(--border);justify-content:space-between;align-items:center;padding:.5rem .75rem;display:flex}.pcap-filename{color:var(--text-muted);font-family:SF Mono,Cascadia Code,Fira Code,monospace;font-size:.85rem}.pcap-summary{background:var(--bg-surface);border-radius:var(--radius);border:1px solid var(--border);flex-direction:column;gap:.5rem;padding:.75rem;display:flex}.pcap-summary-row{flex-wrap:wrap;align-items:center;gap:1.5rem;display:flex}.pcap-stat{flex-direction:column;align-items:center;display:flex}.pcap-stat-value{font-family:SF Mono,Cascadia Code,monospace;font-size:1.1rem;font-weight:700}.pcap-stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.7rem}.pcap-rtcp-counts{gap:.75rem}.pcap-mini-stat{background:var(--bg-elevated);border-radius:4px;padding:.15rem .5rem;font-family:SF Mono,Cascadia Code,monospace;font-size:.75rem}.pcap-mini-stat.warn{color:#fbbf24}.pcap-ssrc-table{font-family:SF Mono,Cascadia Code,monospace;font-size:.75rem}.pcap-ssrc-header,.pcap-ssrc-row{grid-template-columns:1fr .5fr .5fr .5fr .5fr;align-items:center;gap:.5rem;padding:.25rem .5rem;display:grid}.pcap-ssrc-header{color:var(--text-muted);border-bottom:1px solid var(--border);font-weight:600}.pcap-ssrc-row{cursor:pointer;border-radius:3px}.pcap-ssrc-row:hover{background:var(--bg-elevated)}.pcap-filter-bar{flex-direction:column;gap:.4rem;display:flex}.pcap-filter-input-row{align-items:center;gap:.5rem;display:flex}.pcap-filter-input{background:var(--bg-surface);border:1px solid var(--border);color:var(--text);border-radius:5px;outline:none;flex:1;padding:.4rem .6rem;font-family:SF Mono,Cascadia Code,monospace;font-size:.8rem}.pcap-filter-input:focus{border-color:var(--accent)}.pcap-filter-count{color:var(--text-muted);white-space:nowrap;font-size:.75rem}.pcap-quick-filters{flex-wrap:wrap;align-items:center;gap:.3rem;display:flex}.pcap-qf{background:var(--bg-surface);border:1px solid var(--border);color:var(--text-muted);cursor:pointer;border-radius:4px;padding:.2rem .5rem;font-size:.7rem;transition:all .1s}.pcap-qf:hover{color:var(--text);border-color:var(--text-muted)}.pcap-qf.active{color:var(--accent);border-color:var(--accent);background:var(--bg-elevated)}.pcap-qf-select{background:var(--bg-surface);border:1px solid var(--border);color:var(--text-muted);border-radius:4px;padding:.2rem .4rem;font-family:SF Mono,Cascadia Code,monospace;font-size:.7rem}.pcap-main-content{flex-direction:column;flex:1;gap:.5rem;min-height:0;display:flex}.pcap-packet-list{border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-surface);flex-direction:column;flex:1;min-height:200px;display:flex;overflow:hidden}.pcap-list-header{color:var(--text-muted);border-bottom:1px solid var(--border);background:var(--bg-elevated);padding:.3rem .5rem;font-size:.7rem;font-weight:600;display:flex}.pcap-sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.pcap-sortable:hover{color:var(--text)}.pcap-list-viewport{flex:1;position:relative;overflow-y:auto}.pcap-list-spacer{width:100%;position:relative}.pcap-row{cursor:pointer;box-sizing:border-box;border-left:3px solid #0000;align-items:center;width:100%;padding:0 .5rem;font-family:SF Mono,Cascadia Code,monospace;font-size:.75rem;display:flex}.pcap-row:hover{background:var(--bg-elevated)}.pcap-row.selected{background:#6366f126;border-left-color:var(--accent)!important}.pcap-col-num{width:45px;color:var(--text-muted);flex-shrink:0}.pcap-col-time{flex-shrink:0;width:60px}.pcap-col-src{width:100px;color:var(--text-muted);flex-shrink:0;font-size:.7rem}.pcap-col-dir{text-align:center;flex-shrink:0;width:20px;font-weight:700}.pcap-col-dir.in{color:#4fc3f7}.pcap-col-dir.out{color:#f48fb1}.pcap-col-dst{width:100px;color:var(--text-muted);flex-shrink:0;font-size:.7rem}.pcap-col-proto{flex-shrink:0;width:45px;font-weight:700}.pcap-col-len{width:35px;color:var(--text-muted);text-align:right;flex-shrink:0}.pcap-col-info{text-overflow:ellipsis;white-space:nowrap;flex:1;padding-left:.5rem;overflow:hidden}.pcap-detail{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);grid-template-columns:1fr 1fr;gap:.5rem;max-height:350px;padding:.5rem;display:grid;overflow-y:auto}.pcap-detail-tree{font-size:.75rem;overflow-y:auto}.tree-section{margin-left:.75rem}.tree-section>.tree-summary{cursor:pointer;color:var(--text);-webkit-user-select:none;user-select:none;padding:.15rem 0;font-weight:600;list-style:none}.tree-section>.tree-summary:before{content:"▶ ";color:var(--text-muted);font-size:.6rem;transition:transform .1s;display:inline-block}.tree-section[open]>.tree-summary:before{transform:rotate(90deg)}.tree-children{border-left:1px solid var(--border);margin-left:.3rem;padding-left:.5rem}.tree-field{padding:.1rem 0;font-family:SF Mono,Cascadia Code,monospace}.tree-label{color:var(--text-muted);margin-right:.4rem}.tree-value{color:var(--text)}.tree-ext-item{border-radius:3px}.tree-ext-item:hover{background:#6366f114}.pcap-hex-dump{background:var(--bg);border-radius:6px;padding:.5rem;font-family:SF Mono,Cascadia Code,Fira Code,monospace;font-size:.7rem;line-height:1.6;overflow-y:auto}.hex-line{white-space:pre;gap:.75rem;display:flex}.hex-offset{color:var(--text-muted);min-width:3ch}.hex-bytes{color:var(--text)}.hex-bytes span{margin-right:.3ch}.hex-ascii{color:var(--text-muted)}.hex-hl{background:#6366f14d;border-radius:2px;color:#c7d2fe!important}.pcap-error-inline{color:var(--danger);padding:.3rem 0;font-size:.8rem}.pcap-files{flex-direction:column;gap:.4rem;margin-top:.5rem;display:flex}.pcap-file-row{background:var(--bg-elevated);border-radius:4px;align-items:center;gap:.5rem;padding:.3rem .5rem;font-size:.75rem;display:flex}.pcap-file-peer{color:var(--text-muted);min-width:80px}.pcap-file-name{color:var(--text);flex:1;font-size:.7rem}.pcap-file-hint{color:var(--text-muted);margin-top:.3rem;font-size:.7rem}.pcap-file-hint a{color:var(--accent)}.recordings-page{flex-direction:column;gap:1.5rem;display:flex}.recordings-header{flex-wrap:wrap;align-items:center;gap:1rem;display:flex}.recordings-header h1{margin:0;font-size:1.5rem}.recordings-session-select{background:var(--bg);border:1px solid var(--border);color:var(--text);border-radius:6px;min-width:250px;padding:.4rem .6rem;font-size:.85rem}.recordings-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1rem;display:grid}.recording-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.recording-card-preview{background:var(--bg-elevated);justify-content:center;align-items:center;height:80px;display:flex}.recording-card-icon{color:var(--text-muted);font-family:monospace;font-size:1.5rem;font-weight:700}.recording-card-info{padding:.75rem}.recording-card-title{margin-bottom:.4rem;font-size:.9rem;font-weight:600}.recording-card-meta{color:var(--text-muted);flex-wrap:wrap;gap:.75rem;margin-bottom:.5rem;font-size:.75rem;display:flex}.recording-card-actions{gap:.4rem;display:flex}.btn-danger{background:var(--danger);color:#fff;cursor:pointer;border:none;border-radius:6px;padding:.35rem .75rem;font-size:.8rem}.recording-indicator{color:var(--danger);letter-spacing:.05em;align-items:center;gap:.35rem;font-size:.75rem;font-weight:700;display:inline-flex}.recording-dot{background:var(--danger);border-radius:50%;width:8px;height:8px;animation:1.2s ease-in-out infinite recording-pulse}@keyframes recording-pulse{0%,to{opacity:1;box-shadow:0 0 4px var(--danger)}50%{opacity:.4;box-shadow:0 0 8px var(--danger)}}.control-btn.recording{color:var(--danger)!important;background:#ef444426!important}.recording-indicator.encrypted{color:#fbbf24}.recording-indicator.encrypted .recording-dot{background:#fbbf24;box-shadow:0 0 4px #fbbf24}.recording-overlay{z-index:110;background:#000000b3;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.recording-modal{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);width:520px;max-width:calc(100vw - 2rem);max-height:calc(100vh - 2rem);padding:1.5rem;overflow-y:auto}.recording-header{justify-content:space-between;align-items:center;margin-bottom:.75rem;display:flex}.recording-header h3{margin:0;font-size:1.1rem}.recording-close{color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:0;font-size:1.5rem;line-height:1}.recording-desc{color:var(--text-muted);margin:0 0 1rem;font-size:.875rem}.recording-mode-row,.recording-target-row{flex-direction:column;gap:.5rem;margin-bottom:1rem;display:flex}.recording-target{border:1px solid var(--border);cursor:pointer;border-radius:6px;align-items:flex-start;gap:.75rem;padding:.6rem .75rem;transition:border-color .15s,background .15s;display:flex}.recording-target:hover:not(.disabled){border-color:var(--accent)}.recording-target.active{border-color:var(--accent);background:#3b82f614}.recording-target.disabled{opacity:.45;cursor:not-allowed}.recording-target input[type=radio]{flex-shrink:0;margin-top:.25rem}.recording-target strong{font-size:.9rem;display:block}.recording-target span{color:var(--text-muted);margin-top:.2rem;font-size:.78rem;display:block}.recording-mode.disabled{opacity:.45;cursor:not-allowed}.recording-mode{border:1px solid var(--border);cursor:pointer;border-radius:6px;align-items:flex-start;gap:.75rem;padding:.75rem;transition:border-color .15s,background .15s;display:flex}.recording-mode:hover{border-color:var(--accent)}.recording-mode.active{border-color:var(--accent);background:#3b82f614}.recording-mode input[type=radio]{flex-shrink:0;margin-top:.25rem}.recording-mode strong{font-size:.9rem;display:block}.recording-mode span{color:var(--text-muted);margin-top:.25rem;font-size:.8rem;display:block}.lock-badge{font-size:.85rem}.recording-key-section{border:1px solid var(--border);background:#00000026;border-radius:6px;margin-bottom:1rem;padding:1rem}.recording-key-source{gap:1rem;margin-bottom:.75rem;font-size:.85rem;display:flex}.recording-key-source label{cursor:pointer;align-items:center;gap:.4rem;display:flex}.recording-key-display label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.25rem;font-size:.75rem;display:block}.recording-key-row{gap:.5rem;margin-bottom:.75rem;display:flex}.recording-key-row input{font-family:var(--font-mono,monospace);background:var(--bg-base);border:1px solid var(--border);color:var(--text);-webkit-user-select:all;user-select:all;border-radius:4px;flex:1;padding:.5rem;font-size:.8rem}.recording-key-warning{color:#fde68a;background:#fbbf241a;border-left:3px solid #fbbf24;border-radius:0 4px 4px 0;margin-bottom:.75rem;padding:.625rem .75rem;font-size:.8rem}.recording-key-warning strong{color:#fbbf24}.recording-ack{cursor:pointer;align-items:center;gap:.5rem;font-size:.85rem;display:flex}.recording-key-paste textarea{box-sizing:border-box;width:100%;font-family:var(--font-mono,monospace);background:var(--bg-base);border:1px solid var(--border);color:var(--text);resize:vertical;border-radius:4px;padding:.5rem;font-size:.8rem}.recording-key-error{color:var(--danger);margin-top:.5rem;font-size:.8rem}.recording-actions{justify-content:flex-end;gap:.75rem;padding-top:.5rem;display:flex}.recording-actions .btn-primary,.recording-actions .btn-secondary{padding:.5rem 1rem;font-size:.85rem}.recording-actions .btn-primary:disabled{opacity:.5;cursor:not-allowed}.encryption-badge{cursor:help;margin-left:.5rem;font-size:.85rem;display:inline-block}.encryption-fp{font-family:var(--font-mono,monospace);color:#fbbf24;opacity:.85;font-size:.7rem}.mix-indicator{color:#a78bfa;letter-spacing:.05em;align-items:center;gap:.35rem;font-size:.75rem;font-weight:700;display:inline-flex}.mix-dot{background:#8b5cf6;border-radius:50%;width:8px;height:8px;animation:1.2s ease-in-out infinite mix-pulse}@keyframes mix-pulse{0%,to{opacity:1;box-shadow:0 0 4px #8b5cf6}50%{opacity:.45;box-shadow:0 0 8px #a78bfa}}.control-btn.compositing{color:#c4b5fd!important;background:#8b5cf633!important}.caption-overlay{color:#0f172a;border-radius:var(--radius);-webkit-backdrop-filter:blur(12px);background:#ffffffeb;border:1px solid #0f172a14;flex-direction:column;justify-content:flex-end;height:9.5rem;margin:0 1rem .5rem;padding:.5rem 1.1rem;display:flex;position:relative;overflow:hidden;box-shadow:0 6px 22px #0f172a2e}.caption-line{white-space:normal;word-break:break-word;flex:none;padding:.1rem 0;font-size:1.1rem;line-height:1.45;animation:.15s ease-out caption-in}.caption-partial .caption-text{color:#475569}.caption-final .caption-text{color:#0f172a}.caption-speaker{color:var(--accent);margin-right:.4rem;font-size:.95rem;font-weight:600}@keyframes caption-in{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.captioner-panel textarea{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--text);padding:.5rem;font-family:inherit;font-size:.9rem}.captioner-panel textarea:focus{outline:1px solid var(--accent)}.captioner-preview{flex:1;padding:.75rem;font-size:.9rem;line-height:1.4;overflow-y:auto}.dashboard-brand{color:var(--accent);align-items:center;gap:.5rem;font-size:1.2rem;font-weight:700;display:flex}.brand-link{color:var(--accent);text-decoration:none}.dashboard-user{color:var(--text-muted);align-items:center;gap:1rem;font-size:.85rem;display:flex}.dashboard-actions{flex-wrap:wrap;gap:1rem;margin-bottom:2rem;display:flex}.dashboard-create,.dashboard-join{align-items:center;gap:.5rem;display:flex}.dashboard-create input,.dashboard-join input{width:220px;margin-bottom:0}.dashboard-grid{grid-template-columns:1fr 1fr;gap:1.5rem;display:grid}.dashboard-section{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem}.dashboard-section h2{color:var(--text-muted);margin-bottom:1rem;font-size:1rem}.active-sessions{flex-direction:column;gap:.5rem;display:flex}.active-session-card{background:var(--bg-elevated);border-radius:8px;align-items:center;gap:.75rem;padding:.75rem;display:flex}.active-session-name{flex:1;font-family:monospace;font-weight:600}.active-session-meta{color:var(--text-muted);font-size:.8rem}.dashboard-table{border-collapse:collapse;width:100%;font-size:.85rem}.dashboard-table th{text-align:left;color:var(--text-muted);border-bottom:1px solid var(--border);padding:.5rem;font-size:.75rem;font-weight:600}.dashboard-table td{border-bottom:1px solid #ffffff0a;padding:.5rem}.dashboard-table tr:hover td{background:var(--bg-elevated)}.table-link{color:var(--accent);text-decoration:none}.table-link:hover{text-decoration:underline}.status-badge{background:var(--bg-elevated);border-radius:10px;padding:.15rem .5rem;font-size:.7rem}.status-active{background:var(--success);color:var(--bg)}.status-ended,.text-muted{color:var(--text-muted)}.empty-hint{color:var(--text-muted);font-size:.85rem}.error-text{color:var(--danger);margin-top:.25rem;font-size:.85rem}.page-title{margin-bottom:1.5rem;font-size:1.5rem}.org-settings{max-width:720px;margin:0 auto;padding:2rem}.org-info-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:1.5rem;padding:1rem}.org-info-row{justify-content:space-between;padding:.3rem 0;display:flex}.org-info-label{color:var(--text-muted);font-size:.85rem}.org-info-value{font-weight:600}.org-section{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:1.5rem;padding:1.25rem}.org-section h2{margin-bottom:.5rem;font-size:1rem}.section-hint{color:var(--text-muted);margin-bottom:.75rem;font-size:.85rem}.invite-link-box{background:var(--bg);border-radius:6px;align-items:center;gap:.5rem;margin-top:.75rem;padding:.5rem .75rem;display:flex}.invite-link-url{color:var(--accent);word-break:break-all;flex:1;font-size:.8rem}.role-badge{background:var(--bg-elevated);border-radius:10px;padding:.15rem .5rem;font-size:.7rem}.role-admin{background:var(--accent);color:#fff}@media (max-width:768px){.dashboard-grid{grid-template-columns:1fr}.dashboard-actions{flex-direction:column}.dashboard-create input,.dashboard-join input{width:100%}}.analytics-page{flex-direction:column;gap:1.5rem;display:flex}.analytics-header{flex-wrap:wrap;align-items:center;gap:1rem;display:flex}.analytics-header h1{margin:0;font-size:1.5rem}.analytics-section-title{color:var(--text-muted);margin:.5rem 0 0;font-size:1.1rem;font-weight:600}.date-range{align-items:center;gap:.75rem;margin-left:auto;display:flex}.date-range-label{color:var(--text-muted);align-items:center;gap:.4rem;font-size:.8rem;display:flex}.date-range-input{background:var(--bg);border:1px solid var(--border);color:var(--text);border-radius:6px;outline:none;padding:.35rem .5rem;font-size:.8rem}.date-range-input:focus{border-color:var(--accent)}.kpi-row{flex-wrap:wrap;gap:.75rem;display:flex}.kpi-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);flex:1;min-width:130px;padding:1rem}.kpi-label{color:var(--text-muted);margin-bottom:.25rem;font-size:.75rem}.kpi-value{font-size:1.5rem;font-weight:700;line-height:1.2}.kpi-subtitle{color:var(--text-muted);margin-top:.25rem;font-size:.75rem}.analytics-charts-row{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.analytics-chart-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);padding:1rem}.analytics-chart-card h3{color:var(--text-muted);margin-bottom:.75rem;font-size:.9rem}.chart-empty{height:140px;color:var(--text-muted);border:1px dashed var(--border);border-radius:6px;justify-content:center;align-items:center;font-size:.85rem;display:flex}.chart-tooltip{background:var(--bg-surface);border:1px solid var(--border);color:var(--text);border-radius:6px;padding:.4rem .6rem;font-size:.75rem;box-shadow:0 4px 12px #00000059}.chart-tooltip-date{color:var(--text-muted);margin-bottom:.15rem}.chart-tooltip-value strong{color:var(--text)}.recharts-cartesian-axis-tick-value{fill:var(--text-muted)}.recharts-legend-item-text{color:var(--text-muted)!important}.session-picker{align-items:center;gap:.4rem;display:flex}.session-picker-label{color:var(--text-muted);font-size:.8rem}.session-picker-select{background:var(--bg);border:1px solid var(--border);color:var(--text);border-radius:6px;outline:none;max-width:320px;padding:.35rem .5rem;font-size:.8rem}.session-picker-select:focus{border-color:var(--accent)}.analytics-filter-banner{color:var(--text);background:#6366f11f;border:1px solid #6366f159;border-radius:6px;align-items:center;gap:.6rem;padding:.55rem .85rem;font-size:.82rem;display:flex}.analytics-filter-banner code{background:#00000040;border-radius:4px;padding:.05rem .35rem;font-size:.78rem}.btn-link{color:var(--accent);cursor:pointer;background:0 0;border:none;padding:0;font-size:.8rem;text-decoration:underline}.btn-link:hover{color:var(--text)}.analytics-breakdowns{grid-template-columns:repeat(3,1fr);gap:1rem;display:grid}.bar-breakdown{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);padding:1rem}.bar-breakdown-title{color:var(--text-muted);margin-bottom:.75rem;font-size:.9rem}.bar-breakdown-empty{color:var(--text-muted);font-size:.85rem}.bar-row{align-items:center;gap:.5rem;margin-bottom:.4rem;font-size:.8rem;display:flex}.bar-label{min-width:70px;color:var(--text)}.bar-track{background:var(--bg);border-radius:3px;flex:1;height:6px;overflow:hidden}.bar-fill{background:var(--accent);border-radius:3px;height:100%;transition:width .3s}.bar-value{color:var(--text-muted);white-space:nowrap;text-align:right;min-width:60px;font-size:.7rem}.analytics-nav-cards{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.analytics-nav-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;text-align:left;padding:1.25rem;transition:border-color .15s}.analytics-nav-card:hover{border-color:var(--accent)}.analytics-nav-card h3{margin-bottom:.25rem;font-size:1rem}.analytics-nav-card p{color:var(--text-muted);margin:0;font-size:.8rem}.metric-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:.75rem;display:grid}.metric-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);padding:.75rem}.metric-card-header{justify-content:space-between;align-items:center;margin-bottom:.25rem;display:flex}.metric-card-name{font-size:.85rem;font-weight:600}.metric-card-samples{color:var(--text-muted);font-size:.7rem}.metric-card-value{margin-bottom:.25rem;font-size:1.25rem;font-weight:700}.metric-card-unit{color:var(--text-muted);font-size:.75rem;font-weight:400}.metric-card-percentiles{color:var(--text-muted);gap:1rem;margin-bottom:.5rem;font-size:.7rem;display:flex}.quality-score{text-align:center;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem}.quality-score-number{font-size:3rem;font-weight:800;line-height:1}.quality-score-label{margin-top:.25rem;font-size:1rem;font-weight:600}.quality-score-detail{color:var(--text-muted);margin-top:.5rem;font-size:.8rem}.quality-score-excellent .quality-score-number,.quality-score-excellent .quality-score-label{color:var(--success)}.quality-score-fair .quality-score-number,.quality-score-fair .quality-score-label{color:#f59e0b}.quality-score-poor .quality-score-number,.quality-score-poor .quality-score-label{color:var(--danger)}.engagement-table{border-collapse:collapse;width:100%;font-size:.85rem}.engagement-table th{text-align:left;color:var(--text-muted);border-bottom:1px solid var(--border);padding:.5rem;font-size:.75rem;font-weight:600}.engagement-table td{border-bottom:1px solid #ffffff0a;padding:.5rem}.engagement-table tr:hover td{background:var(--bg-elevated)}.engagement-sparklines{flex-direction:column;gap:.5rem;display:flex}.engagement-sparkline-row{align-items:center;gap:.75rem;display:flex}.engagement-sparkline-label{min-width:120px;font-size:.8rem}.hand-raised-indicator{z-index:6;pointer-events:none;background:#fbbf24f2;border-radius:50%;justify-content:center;align-items:center;width:34px;height:34px;font-size:1.3rem;animation:1.8s ease-in-out infinite hand-raised-pulse;display:flex;position:absolute;top:8px;right:8px;box-shadow:0 3px 10px #00000073}@keyframes hand-raised-pulse{0%,to{transform:scale(1);box-shadow:0 3px 10px #00000073}50%{transform:scale(1.08);box-shadow:0 4px 14px #fbbf2499}}.control-btn.hand-raised,.control-btn.active.hand-raised{box-shadow:0 0 0 2px #fbbf2459;color:#1a1625!important;background:#fbbf24!important;border-color:#fbbf24!important}.control-btn.hand-raised svg,.control-btn.active.hand-raised svg{stroke:#1a1625}.control-btn.hand-raised:hover,.control-btn.active.hand-raised:hover{background:#f59e0b!important}.btn-sm{padding:.35rem .75rem;font-size:.8rem}@media (max-width:768px){.analytics-charts-row,.analytics-breakdowns,.analytics-nav-cards,.metric-grid{grid-template-columns:1fr}.date-range{margin-left:0}}.dashboard{max-width:1100px;margin:0 auto;padding:2rem 1.5rem 3rem}.dashboard-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1.5rem;display:flex}.dashboard-brand{color:var(--accent);font-size:1.15rem;font-weight:700}.dashboard-user{align-items:center;gap:1.25rem;font-size:.9rem;display:flex}.dashboard-user-name{color:var(--text);font-weight:500}.dashboard-nav-link{cursor:pointer;color:var(--text-muted);background:0 0;border:none;padding:0;font-family:inherit;font-size:.9rem;transition:color .15s}.dashboard-nav-link:hover{color:var(--accent)}.dashboard-main{flex-direction:column;gap:2.5rem;display:flex}.dashboard-hero{border:1px solid var(--border);background:linear-gradient(135deg,#6366f114,#6366f105);border-radius:14px;grid-template-columns:1fr auto;gap:2rem;padding:2.5rem 2rem;display:grid}.hero-primary h1{color:var(--text);margin:0 0 .5rem;font-size:1.75rem;font-weight:700;line-height:1.2}.hero-sub{color:var(--text-muted);max-width:36rem;margin:0 0 1.5rem}.hero-actions{flex-wrap:wrap;align-items:center;gap:1.25rem;display:flex}.hero-hint{color:var(--text-muted);font-size:.85rem}.hero-stats{align-self:center;gap:1.25rem;display:flex}.hero-stat{text-align:center;border-left:1px solid var(--border);min-width:5rem;padding:.75rem 1rem}.hero-stat:first-child{border-left:none}.hero-stat-value{color:var(--text);font-size:1.75rem;font-weight:700;display:block}.hero-stat-label{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);font-size:.75rem;display:block}.btn-lg{padding:.7rem 1.5rem;font-size:1rem}.btn-ghost{border:1px solid var(--border);color:var(--text);cursor:pointer;background:0 0;border-radius:6px;padding:.5rem 1rem;font-family:inherit;transition:border-color .15s,color .15s}.btn-ghost:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.btn-ghost:disabled{opacity:.5;cursor:not-allowed}.sr-only{clip:rect(0 0 0 0);white-space:nowrap;width:1px;height:1px;position:absolute;overflow:hidden}.dashboard-section{flex-direction:column;gap:1rem;display:flex}.section-head{border-bottom:1px solid var(--border);align-items:baseline;gap:.75rem;padding-bottom:.5rem;display:flex}.section-head h2{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin:0;font-size:.95rem;font-weight:600}.section-count{background:var(--bg-elevated);color:var(--text);border-radius:999px;padding:.1rem .5rem;font-size:.75rem;font-weight:600}.section-empty{background:var(--bg-surface);border:1px dashed var(--border);color:var(--text-muted);border-radius:10px;flex-direction:column;justify-content:center;align-items:center;gap:.5rem;padding:2rem;display:flex}.active-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1rem;display:grid}.active-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:10px;flex-direction:column;gap:.6rem;padding:1rem;transition:border-color .15s,transform .15s;display:flex}.active-card:hover{border-color:var(--accent);transform:translateY(-1px)}.active-card header{align-items:center;gap:.5rem;display:flex}.active-dot{background:var(--success);border-radius:50%;width:8px;height:8px;animation:1.6s infinite dash-pulse;box-shadow:0 0 #22c55e99}@keyframes dash-pulse{0%,to{box-shadow:0 0 #22c55e99}70%{box-shadow:0 0 0 6px #22c55e00}}.active-code{color:var(--text);font-family:ui-monospace,JetBrains Mono,monospace;font-size:.85rem}.active-meta{color:var(--text-muted);margin:0;font-size:.85rem}.recent-table{border-collapse:collapse;width:100%;font-size:.9rem}.recent-table th,.recent-table td{text-align:left;padding:.65rem .75rem}.recent-table thead{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.75rem}.recent-table tbody tr{border-top:1px solid var(--border)}.recent-table tbody tr:hover{background:var(--bg-elevated)}.recent-link{color:var(--text);font-weight:500}.recent-link:hover{color:var(--accent)}.recent-code{color:var(--text-muted);font-family:ui-monospace,JetBrains Mono,monospace;font-size:.8rem}.text-muted{color:var(--text-muted);font-size:.85rem}.status-pill{text-transform:uppercase;letter-spacing:.05em;border-radius:999px;padding:.15rem .55rem;font-size:.7rem;font-weight:600}.status-pill.status-active{color:var(--success);background:#22c55e26}.status-pill.status-ended{background:var(--bg-elevated);color:var(--text-muted)}.nm-overlay{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:100;background:#0f172a4d;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.nm-modal{background:color-mix(in srgb, var(--bg-surface) 86%, transparent);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid var(--border);border-radius:12px;flex-direction:column;width:100%;max-width:560px;max-height:90vh;display:flex;box-shadow:0 30px 60px #00000080}.nm-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;display:flex}.nm-header h2{margin:0;font-size:1.15rem}.nm-close{color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:0 .25rem;font-size:1.5rem;line-height:1}.nm-close:hover{color:var(--text)}.nm-body{flex-direction:column;gap:1.5rem;min-height:21rem;padding:1.25rem 1.5rem;display:flex;overflow-y:auto}@media (max-width:640px){.nm-overlay{padding:0}.nm-modal{border:none;border-radius:0;width:100%;max-width:100%;height:100%;max-height:100%}.nm-body{gap:1rem;min-height:0}}.nm-tabs{margin:0;padding:0 1.5rem}.nm-tab-dot{background:var(--accent);vertical-align:middle;border-radius:50%;width:6px;height:6px;margin-left:.4rem;display:inline-block}.nm-pw-block{flex-direction:column;align-items:stretch;gap:.6rem}.nm-pw{background:var(--bg-input);border:1px solid var(--border);border-radius:6px;align-items:center;transition:border-color .12s;display:flex;overflow:hidden}.nm-pw:focus-within{border-color:var(--accent)}.nm-pw-error{border-color:var(--danger)}.nm-pw-input{min-width:0;color:var(--text);font-size:.95rem;font-family:var(--font-mono,monospace);letter-spacing:.02em;background:0 0;border:none;flex:1;padding:.6rem .8rem}.nm-pw-input:focus{outline:none}.nm-pw-btn{border:none;border-left:1px solid var(--border);width:38px;color:var(--text-muted);cursor:pointer;background:0 0;justify-content:center;align-self:stretch;align-items:center;transition:color .12s,background .12s;display:inline-flex}.nm-pw-btn:hover{color:var(--text);background:var(--bg-hover)}.nm-pw-btn[aria-pressed=true]{color:var(--accent)}.nm-pw-hint{color:var(--text-muted);margin:0;font-size:.8rem}.nm-pw-hint-error{color:var(--danger)}.nm-field{flex-direction:column;gap:.4rem;display:flex}.nm-field>span{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.8rem}.nm-field input[type=text]{background:var(--bg-elevated);border:1px solid var(--border);color:var(--text);border-radius:6px;padding:.6rem .8rem;font-family:inherit;font-size:.95rem}.nm-field input:focus{border-color:var(--accent);outline:none}.nm-field-prominent input[type=text]{padding:.75rem .9rem;font-size:1.05rem}.nm-section{flex-direction:column;gap:.75rem;display:flex}.nm-section h3{text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);border-bottom:1px solid var(--border);margin:0;padding-bottom:.4rem;font-size:.75rem}.nm-section-note{color:var(--text-muted);text-transform:none;letter-spacing:0;margin-left:.5rem;font-weight:400}.nm-section[aria-disabled=true]{opacity:.55}.nm-row{cursor:pointer;align-items:flex-start;gap:.75rem;padding:.5rem 0;display:flex}.nm-row input[type=checkbox]{margin-top:.2rem}.nm-row-text{flex-direction:column;gap:.15rem;max-width:62ch;display:flex}.nm-row-text strong{color:var(--text);font-size:.9rem;font-weight:500}.nm-row-text em{color:var(--text-muted);font-size:.8rem;font-style:normal}.nm-row-select{align-items:center}.nm-row-select select,.nm-row-select input[type=number],.nm-select{background:var(--bg-elevated);border:1px solid var(--border);min-width:11rem;color:var(--text);border-radius:6px;margin-left:auto;padding:.45rem .6rem;font-family:inherit;font-size:.9rem}.nm-row-indent{flex-wrap:wrap;align-items:center;padding-left:1.5rem}.nm-grid-2{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.nm-tab-desc{color:var(--text-muted);border-bottom:1px dashed var(--border);margin:0 0 .5rem;padding:.4rem 0;font-size:.82rem;line-height:1.5}.nm-card{background:#6366f10d;border:1px solid #6366f12e;border-radius:10px;margin-top:.25rem;padding:.75rem .9rem}.nm-card-head{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;align-items:baseline;gap:.5rem;margin:-.1rem 0 .5rem;font-size:.78rem;display:flex}.nm-card-head em{text-transform:none;letter-spacing:0;color:var(--text-muted);font-size:.78rem;font-style:normal}.nm-card-grid{grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:.55rem .75rem;display:grid}.nm-langs{flex-wrap:wrap;gap:.4rem;display:flex}.nm-lang-chip{border:1px solid var(--border);cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:999px;align-items:center;gap:.35rem;padding:.3rem .7rem;font-size:.85rem;transition:all .15s;display:inline-flex}.nm-lang-chip.on{border-color:var(--accent);color:var(--accent);background:#6366f126}.nm-lang-chip input{display:none}.nm-error{color:var(--danger);background:#ef44441a;border-radius:6px;margin:0;padding:.6rem .8rem;font-size:.85rem}.nm-footer{border-top:1px solid var(--border);justify-content:flex-end;gap:.75rem;padding:1rem 1.5rem;display:flex}@media (max-width:720px){.dashboard-hero{grid-template-columns:1fr}.hero-stats{justify-content:flex-start}.nm-grid-2{grid-template-columns:1fr}}.dashboard-user .btn-primary{padding:.45rem 1rem;font-size:.9rem}.dashboard-user-sep{background:var(--border);width:1px;height:20px;margin:0 .25rem;display:inline-block}a.dashboard-brand,a.admin-logo{cursor:pointer;text-decoration:none}a.dashboard-brand:hover,a.admin-logo:hover{opacity:.85}.member-cell{flex-direction:column;gap:.15rem;display:flex}.member-name{color:var(--text);font-size:.9rem;font-weight:500}.member-email{color:var(--text-muted);font-size:.8rem}.member-role{background:var(--bg-elevated);border:1px solid var(--border);color:var(--text);border-radius:6px;padding:.3rem .5rem;font-family:inherit;font-size:.85rem}.member-role:disabled{opacity:.7;cursor:not-allowed}.member-must-change{color:#f59e0b;text-transform:uppercase;letter-spacing:.05em;background:#f59e0b26;border-radius:999px;margin-left:.5rem;padding:.1rem .45rem;font-size:.7rem;font-weight:600}.member-actions{gap:.75rem;display:flex}.member-action{font-size:.85rem}.member-action:disabled{opacity:.4;cursor:not-allowed}.pwd-once{background:var(--bg-elevated);border:1px solid var(--border);border-radius:8px;align-items:center;gap:.75rem;padding:.75rem 1rem;display:flex}.pwd-once code{color:var(--text);-webkit-user-select:all;user-select:all;flex:1;font-family:ui-monospace,JetBrains Mono,monospace;font-size:1rem}.recording-card-preview{cursor:pointer;background:var(--bg-elevated);aspect-ratio:16/9;border:none;border-radius:8px 8px 0 0;justify-content:center;align-items:center;padding:0;display:flex;position:relative;overflow:hidden}.recording-card-preview:disabled{cursor:default}.recording-thumb-img{object-fit:cover;width:100%;height:100%;display:block}.recording-thumb-placeholder{width:100%;height:100%;color:var(--text-muted);letter-spacing:.1em;background:linear-gradient(135deg, var(--bg-elevated), #6366f114);justify-content:center;align-items:center;font-family:ui-monospace,JetBrains Mono,monospace;font-size:1.1rem;display:flex}.recording-thumb-placeholder.errored{color:var(--text-muted)}.recording-play-overlay{color:#ffffffeb;opacity:0;text-shadow:0 2px 12px #0009;pointer-events:none;justify-content:center;align-items:center;font-size:2.5rem;transition:opacity .15s;display:flex;position:absolute;inset:0}.recording-card-preview:hover .recording-play-overlay{opacity:1}.recording-player-video{background:#000;border-radius:6px;width:100%;max-height:70vh}.recordings-toolbar{align-items:center;gap:.75rem;display:flex}.room-features{flex-wrap:wrap;gap:.35rem;display:flex}.room-features span{background:var(--bg-elevated);border:1px solid var(--border);color:var(--text);letter-spacing:.05em;border-radius:4px;padding:.1rem .45rem;font-size:.7rem;font-weight:600;display:inline-block}.sessions-row{cursor:pointer}.sessions-row:hover{background:var(--bg-elevated)}.status-pill.status-live{color:var(--success);background:#22c55e26;align-items:center;gap:.35rem;display:inline-flex}.status-pill.status-idle{background:var(--bg-elevated);color:var(--text-muted)}.status-dot{background:var(--success);border-radius:50%;width:6px;height:6px;animation:1.6s infinite dash-pulse;display:inline-block}.manage-head{background:var(--bg-surface);border:1px solid var(--border);border-radius:12px;justify-content:space-between;align-items:center;gap:1.5rem;padding:1.5rem 1.75rem;display:flex}.manage-title{margin:0 0 .5rem;font-size:1.4rem}.manage-meta{flex-wrap:wrap;align-items:center;gap:.75rem;display:flex}.manage-saved{color:var(--success);font-size:.8rem;font-weight:600}.manage-actions{align-items:center;gap:.6rem;display:flex}.btn-danger{background:var(--danger);color:#fff;cursor:pointer;border:none;border-radius:6px;padding:.55rem 1rem;font-family:inherit;font-size:.9rem;font-weight:500}.btn-danger:hover{filter:brightness(.9)}.manage-settings{background:var(--bg-surface);border:1px solid var(--border);border-radius:10px;flex-direction:column;gap:.4rem;padding:.75rem 1rem;display:flex}.pager{justify-content:center;align-items:center;gap:1.5rem;padding:1rem 0;display:flex}.pager .btn-link[disabled]{opacity:.4;cursor:not-allowed}.caption-overlay-close{color:#0f172a8c;cursor:pointer;background:0 0;border:none;border-radius:4px;padding:2px 6px;font-size:1.1rem;line-height:1;position:absolute;top:4px;right:6px}.caption-overlay-close:hover{color:#0f172a;background:#0f172a14}.caption-overlay-lang{color:#0f172a;cursor:pointer;background:#ffffffb3;border:1px solid #0f172a26;border-radius:4px;padding:2px 6px;font-size:.75rem;line-height:1;position:absolute;top:4px;right:30px}:root,[data-theme=dark]{--opc-rule:#94a3b824;--opc-rule-strong:#94a3b847;--opc-hero-from:#6366f1;--opc-hero-via:#22d3ee;--opc-hero-to:#a3ffae;--opc-grid:#6366f10f;--opc-cursor:#f1f5f9;--opc-bar-bg:#6366f12e;--opc-bar:#818cf8;--opc-drawer-bg:#0c1424;--opc-card:#182238;--opc-elev:#1f2c47}[data-theme=light]{--opc-rule:#0f172a1a;--opc-rule-strong:#0f172a33;--opc-hero-from:#4f46e5;--opc-hero-via:#0891b2;--opc-hero-to:#16a34a;--opc-grid:#4f46e50d;--opc-cursor:#0f172a;--opc-bar-bg:#4f46e51a;--opc-bar:#4f46e5;--opc-drawer-bg:#fff;--opc-card:#fff;--opc-elev:#f1f5f9}.opc-page{flex-direction:column;gap:1.75rem;max-width:1320px;margin:0 auto;padding:0 .25rem 4rem;display:flex}.opc-hero{flex-direction:column;gap:.65rem;padding-bottom:.5rem;display:flex}.opc-hero-eyebrow{font-family:var(--font-mono), monospace;letter-spacing:.22em;text-transform:uppercase;color:var(--text-faint);align-items:center;gap:.5rem;font-size:.68rem;display:inline-flex}.opc-hero-eyebrow a,.opc-hero-eyebrow .opc-crumb{color:var(--text-muted);text-decoration:none;transition:color .15s}.opc-hero-eyebrow a:hover{color:var(--text)}.opc-hero-eyebrow .opc-crumb-sep{color:var(--text-faint);opacity:.6}.opc-hero-title-row{flex-wrap:wrap;align-items:baseline;gap:1rem;display:flex}.opc-hero-title{letter-spacing:-.01em;color:var(--text);margin:0;font-size:1.85rem;font-weight:600;line-height:1.1}.opc-hero-sub{color:var(--text-muted);font-size:.95rem}.opc-hero-actions{white-space:nowrap;flex-wrap:nowrap;align-items:center;gap:.5rem;margin-left:auto;display:inline-flex}.opc-hero-actions .btn-primary,.opc-hero-actions .btn-secondary,.opc-hero-actions .opc-drawer-trigger{padding:.4rem .85rem;font-size:.82rem}@media (max-width:720px){.opc-hero-actions{flex-wrap:wrap}}.opc-hero-meta{font-family:var(--font-mono), monospace;color:var(--text-muted);flex-wrap:wrap;align-items:center;gap:1.25rem;font-size:.78rem;display:flex}.opc-hero-meta strong{color:var(--text);font-weight:600}.opc-hero-meta .opc-dot{background:var(--success);border-radius:50%;width:7px;height:7px;margin-right:.45rem;animation:2.2s ease-in-out infinite opc-pulse;display:inline-block;box-shadow:0 0 0 3px #22c55e29}.opc-hero-meta .opc-dot.dead{background:var(--text-faint);box-shadow:none;animation:none}@keyframes opc-pulse{0%,to{box-shadow:0 0 0 3px #22c55e29}50%{box-shadow:0 0 0 5px #22c55e14}}.opc-hero-bar{background:linear-gradient(90deg, var(--opc-hero-from) 0%, var(--opc-hero-via) 45%, var(--opc-hero-to) 100%);border-radius:2px;height:2px;position:relative;overflow:hidden}.opc-hero-bar:after{content:"";background:linear-gradient(90deg,#0000 0%,#ffffff73 50%,#0000 100%);animation:6s ease-in-out infinite opc-hero-sweep;position:absolute;inset:0;transform:translate(-100%)}@keyframes opc-hero-sweep{0%,60%{transform:translate(-100%)}to{transform:translate(220%)}}.opc-section{border-top:1px solid var(--opc-rule);flex-direction:column;gap:.85rem;padding-top:1.25rem;display:flex}.opc-section-head{flex-wrap:wrap;align-items:baseline;gap:.85rem;display:flex}.opc-section-label{font-family:var(--font-mono), monospace;letter-spacing:.18em;text-transform:uppercase;color:var(--text-muted);margin:0;font-size:.72rem;font-weight:600}.opc-section-count{font-family:var(--font-mono), monospace;color:var(--text-faint);font-size:.72rem}.opc-section-aside{font-family:var(--font-mono), monospace;letter-spacing:.06em;text-transform:uppercase;color:var(--text-faint);align-items:center;gap:.5rem;margin-left:auto;font-size:.72rem;display:flex}.opc-section-aside a,.opc-section-aside button{color:var(--text-muted);cursor:pointer;font:inherit;letter-spacing:inherit;text-transform:inherit;background:0 0;border:0;padding:0;text-decoration:none;transition:color .15s}.opc-section-aside a:hover,.opc-section-aside button:hover{color:var(--text)}.opc-rule{background:var(--opc-rule);width:100%;height:1px}.opc-kpis{border:1px solid var(--opc-rule);background:var(--bg-surface);border-radius:6px;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:0;display:grid;overflow:hidden}.opc-kpi{flex-direction:column;gap:.45rem;padding:1.1rem 1.25rem 1rem;display:flex;position:relative}.opc-kpi+.opc-kpi{border-left:1px solid var(--opc-rule)}@media (max-width:720px){.opc-kpi+.opc-kpi{border-left:0;border-top:1px solid var(--opc-rule)}}.opc-kpi-label{font-family:var(--font-mono), monospace;letter-spacing:.18em;text-transform:uppercase;color:var(--text-faint);font-size:.66rem;font-weight:600}.opc-kpi-value{font-family:var(--font-mono), monospace;color:var(--text);letter-spacing:-.01em;font-variant-numeric:tabular-nums;font-size:1.55rem;font-weight:600}.opc-kpi-sub{color:var(--text-muted);font-size:.78rem;font-family:var(--font-mono), monospace;font-variant-numeric:tabular-nums}.opc-kpi-spark{height:22px;color:var(--opc-bar);margin-top:.2rem}.opc-kpi.warn .opc-kpi-value,.opc-kpi.warn .opc-kpi-spark{color:var(--warning)}.opc-kpi.bad .opc-kpi-value,.opc-kpi.bad .opc-kpi-spark{color:var(--danger)}.opc-kpi.good .opc-kpi-value,.opc-kpi.good .opc-kpi-spark{color:var(--success)}.opc-meter{font-family:var(--font-mono), monospace;flex-direction:column;gap:.4rem;display:flex}.opc-meter-label{letter-spacing:.18em;text-transform:uppercase;color:var(--text-faint);font-size:.66rem;font-weight:600}.opc-meter-value{color:var(--text);font-variant-numeric:tabular-nums;font-size:1.05rem;font-weight:600}.opc-meter-bar{background:var(--opc-bar-bg);border-radius:2px;height:4px;position:relative;overflow:hidden}.opc-meter-fill{background:var(--opc-bar);height:100%;transition:width .6s cubic-bezier(.4,0,.2,1)}.opc-meter.warn .opc-meter-fill{background:var(--warning)}.opc-meter.bad .opc-meter-fill{background:var(--danger)}.opc-meter-sub{color:var(--text-muted);font-size:.7rem}.opc-meter.infinite .opc-meter-bar{background:repeating-linear-gradient(45deg, var(--opc-bar-bg) 0 6px, transparent 6px 12px)}.opc-meter.infinite .opc-meter-fill{display:none}.opc-license{background:radial-gradient(at top right, #6366f11a, transparent 55%), linear-gradient(135deg, var(--bg-surface) 0%, var(--bg-muted) 100%);border:1px solid var(--opc-rule);border-radius:6px;padding:1.5rem 1.5rem 1.4rem;position:relative;overflow:hidden}.opc-license:before{content:"";background-image:linear-gradient(var(--opc-grid) 1px, transparent 1px), linear-gradient(90deg, var(--opc-grid) 1px, transparent 1px);pointer-events:none;opacity:.7;background-position:-1px -1px;background-size:28px 28px;position:absolute;inset:0}.opc-license>*{position:relative}.opc-license-head{flex-wrap:wrap;align-items:baseline;gap:1rem;margin-bottom:1.2rem;display:flex}.opc-license-edition{font-family:var(--font-mono), monospace;letter-spacing:.18em;text-transform:uppercase;color:var(--text);font-size:.92rem;font-weight:600}.opc-license-name{color:var(--text-muted);font-size:.85rem}.opc-license-features{flex-wrap:wrap;gap:.4rem;display:flex}.opc-license-feat{font-family:var(--font-mono), monospace;letter-spacing:.12em;text-transform:uppercase;background:var(--bg-elevated);color:var(--text-muted);border:1px solid var(--opc-rule);border-radius:3px;padding:.2rem .55rem;font-size:.66rem}.opc-license-status{font-family:var(--font-mono), monospace;letter-spacing:.14em;text-transform:uppercase;background:var(--pill-green-bg);color:var(--pill-green);border-radius:999px;align-items:center;gap:.4rem;margin-left:auto;padding:.25rem .6rem;font-size:.72rem;display:inline-flex}.opc-license-status.expiring{background:var(--pill-amber-bg);color:var(--pill-amber)}.opc-license-status.expired{background:var(--pill-red-bg);color:var(--pill-red)}.opc-license-status .opc-dot{background:currentColor;border-radius:50%;width:6px;height:6px;box-shadow:0 0 0 3px #4ade802e}.opc-license-meters{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1.5rem;display:grid}.opc-license-foot{font-family:var(--font-mono), monospace;color:var(--text-muted);border-top:1px solid var(--opc-rule);flex-wrap:wrap;gap:1.5rem;margin-top:1.2rem;padding-top:.9rem;font-size:.76rem;display:flex}.opc-list{border:1px solid var(--opc-rule);background:var(--bg-surface);border-radius:6px;flex-direction:column;display:flex;overflow:hidden}.opc-list-row{grid-template-columns:var(--opc-list-cols,1fr auto);text-align:left;cursor:pointer;color:inherit;background:0 0;border:0;align-items:center;gap:1rem;width:100%;padding:.7rem 1rem;font-size:.88rem;text-decoration:none;transition:background .12s;display:grid}.opc-list-row+.opc-list-row{border-top:1px solid var(--opc-rule)}.opc-list-row:hover{background:var(--bg-elevated)}.opc-list-row:disabled,.opc-list-row.no-hover{cursor:default}.opc-list-row:disabled:hover,.opc-list-row.no-hover:hover{background:0 0}.opc-list-pri{color:var(--text);font-weight:500}.opc-list-sec{color:var(--text-muted);font-family:var(--font-mono), monospace;font-variant-numeric:tabular-nums;font-size:.78rem}.opc-list-time{color:var(--text-faint);font-family:var(--font-mono), monospace;font-variant-numeric:tabular-nums;text-align:right;font-size:.74rem}.opc-list-empty{text-align:center;color:var(--text-muted);padding:2rem 1rem;font-size:.85rem}.opc-table{border-collapse:collapse;width:100%;font-size:.86rem}.opc-table thead{font-family:var(--font-mono), monospace;letter-spacing:.18em;text-transform:uppercase;color:var(--text-faint);font-size:.66rem}.opc-table th,.opc-table td{text-align:left;border-bottom:1px solid var(--opc-rule);vertical-align:middle;padding:.55rem .85rem}.opc-table th{padding-top:.4rem;padding-bottom:.4rem;font-weight:600}.opc-table tbody tr{transition:background .12s}.opc-table tbody tr:hover{background:var(--bg-elevated)}.opc-table tbody tr.is-row-link{cursor:pointer}.opc-table td.mono,.opc-table td .mono{font-family:var(--font-mono), monospace;font-variant-numeric:tabular-nums;color:var(--text-muted)}.opc-table td.num{text-align:right;font-variant-numeric:tabular-nums;font-family:var(--font-mono), monospace}.opc-table td.muted{color:var(--text-muted)}.opc-table .opc-table-name{color:var(--text);font-weight:500}.opc-table .opc-cell-code{font-family:var(--font-mono), monospace;color:var(--text-muted);font-size:.78rem}.opc-chip{font-family:var(--font-mono), monospace;letter-spacing:.14em;text-transform:uppercase;background:var(--bg-elevated);color:var(--text-muted);border:1px solid var(--opc-rule);border-radius:3px;align-items:center;gap:.35rem;padding:.15rem .5rem;font-size:.66rem;font-weight:600;display:inline-flex}.opc-chip.live{background:var(--pill-green-bg);color:var(--pill-green);border-color:#0000}.opc-chip.ended{background:var(--bg-elevated);color:var(--text-muted)}.opc-chip.warn{background:var(--pill-amber-bg);color:var(--pill-amber);border-color:#0000}.opc-chip.bad{background:var(--pill-red-bg);color:var(--pill-red);border-color:#0000}.opc-chip.info{background:var(--pill-blue-bg);color:var(--pill-blue);border-color:#0000}.opc-chip .opc-dot{background:currentColor;border-radius:50%;width:6px;height:6px}.opc-chip.live .opc-dot{animation:2s ease-in-out infinite opc-pulse-small}@keyframes opc-pulse-small{0%,to{opacity:1}50%{opacity:.4}}.opc-drawer-trigger{font-family:var(--font-mono), monospace;letter-spacing:.1em;text-transform:uppercase;color:var(--text-secondary);border:1px solid var(--opc-rule);cursor:pointer;background:0 0;border-radius:5px;align-items:center;gap:.4rem;padding:.45rem .85rem;font-size:.74rem;transition:background .15s,border-color .15s,color .15s;display:inline-flex}.opc-drawer-trigger:hover{background:var(--bg-elevated);color:var(--text);border-color:var(--opc-rule-strong)}.opc-drawer-scrim{background:var(--backdrop);z-index:90;opacity:0;animation:.18s forwards opc-fade-in;position:fixed;inset:0}@keyframes opc-fade-in{to{opacity:1}}.opc-drawer{background:var(--opc-drawer-bg);border-left:1px solid var(--opc-rule);width:min(440px,92vw);height:100vh;box-shadow:var(--shadow-lg);z-index:100;flex-direction:column;animation:.22s cubic-bezier(.2,.7,.3,1) forwards opc-drawer-in;display:flex;position:fixed;top:0;right:0;transform:translate(100%)}@keyframes opc-drawer-in{to{transform:translate(0)}}.opc-drawer-head{border-bottom:1px solid var(--opc-rule);align-items:baseline;gap:.6rem;padding:1.1rem 1.4rem .9rem;display:flex}.opc-drawer-eyebrow{font-family:var(--font-mono), monospace;letter-spacing:.18em;text-transform:uppercase;color:var(--text-faint);font-size:.66rem}.opc-drawer-title{color:var(--text);margin:0;font-size:1.1rem;font-weight:600}.opc-drawer-close{color:var(--text-muted);cursor:pointer;background:0 0;border:0;margin-left:auto;padding:0 4px;font-size:1.3rem;line-height:1}.opc-drawer-close:hover{color:var(--text)}.opc-drawer-body{flex-direction:column;flex:1;gap:1.25rem;padding:1rem 1.4rem 1.4rem;display:flex;overflow-y:auto}.opc-drawer-group{border-top:1px solid var(--opc-rule);flex-direction:column;gap:.5rem;padding-top:.9rem;display:flex}.opc-drawer-group:first-child{border-top:0;padding-top:0}.opc-drawer-group-label{font-family:var(--font-mono), monospace;letter-spacing:.18em;text-transform:uppercase;color:var(--text-faint);margin-bottom:.2rem;font-size:.66rem}.opc-drawer-saved{background:var(--pill-green-bg);color:var(--pill-green);font-family:var(--font-mono), monospace;letter-spacing:.16em;text-transform:uppercase;z-index:110;pointer-events:none;border-radius:4px;padding:.5rem 1rem;font-size:.7rem;animation:1.4s forwards opc-toast;position:fixed;bottom:24px;right:24px}@keyframes opc-toast{0%{opacity:0;transform:translateY(8px)}20%,80%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(8px)}}.opc-room-grid{border:1px solid var(--opc-rule);background:var(--bg-surface);border-radius:6px;grid-template-columns:1fr;gap:0;display:grid;overflow:hidden}.opc-room-stat{border-bottom:1px solid var(--opc-rule);grid-template-columns:repeat(auto-fit,minmax(140px,1fr));display:grid}.opc-room-stat:last-child{border-bottom:0}.opc-room-stat-cell{border-right:1px solid var(--opc-rule);flex-direction:column;gap:.35rem;padding:.9rem 1.1rem;display:flex}.opc-room-stat-cell:last-child{border-right:0}.opc-room-stat-label{font-family:var(--font-mono), monospace;letter-spacing:.18em;text-transform:uppercase;color:var(--text-faint);font-size:.62rem}.opc-room-stat-value{font-family:var(--font-mono), monospace;color:var(--text);font-variant-numeric:tabular-nums;font-size:1.05rem;font-weight:500}.opc-meeting-row td:first-child{padding-left:1rem}.opc-meeting-row .opc-meeting-when{align-items:center;gap:.55rem;display:flex}.opc-meeting-row .opc-meeting-when strong{color:var(--text);font-variant-numeric:tabular-nums;font-weight:500;font-family:var(--font-mono), monospace}.opc-meeting-row .opc-meeting-when small{color:var(--text-faint);font-size:.72rem;font-family:var(--font-mono), monospace}.opc-meeting-row .opc-meeting-who{color:var(--text-muted);font-size:.82rem}.opc-cockpit{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:.85rem;display:grid}.opc-cockpit-card{background:var(--bg-surface);border:1px solid var(--opc-rule);text-align:left;cursor:pointer;font:inherit;color:inherit;border-radius:6px;flex-direction:column;gap:.55rem;padding:1rem 1.1rem;text-decoration:none;transition:border-color .15s,transform .15s;display:flex;position:relative;overflow:hidden}.opc-cockpit-card:hover{border-color:var(--opc-rule-strong);transform:translateY(-1px)}.opc-cockpit-card:before{content:"";background:linear-gradient(90deg, var(--opc-hero-from), var(--opc-hero-via));opacity:0;height:2px;transition:opacity .15s;position:absolute;top:0;left:0;right:0}.opc-cockpit-card:hover:before{opacity:1}.opc-cockpit-card.is-automated:before{opacity:.7;background:linear-gradient(90deg, var(--warning), var(--opc-hero-via))}.opc-cockpit-card-head{justify-content:space-between;align-items:baseline;gap:.5rem;display:flex}.opc-cockpit-card-code{font-family:var(--font-mono), monospace;color:var(--text);font-size:.92rem;font-weight:600}.opc-cockpit-card-body{color:var(--text-muted);font-size:.82rem;font-family:var(--font-mono), monospace;font-variant-numeric:tabular-nums;flex-wrap:wrap;gap:.85rem;display:flex}.opc-cockpit-card-people{color:var(--text-secondary);font-size:.78rem}.opc-cockpit-card-foot{font-family:var(--font-mono), monospace;color:var(--text-faint);border-top:1px solid var(--opc-rule);justify-content:space-between;align-items:baseline;gap:.5rem;margin-top:.2rem;padding-top:.55rem;font-size:.7rem;display:flex}.opc-overview-grid{border:1px solid var(--opc-rule);background:var(--bg-surface);border-radius:6px;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));display:grid;overflow:hidden}.opc-overview-cell{border-right:1px solid var(--opc-rule);border-bottom:1px solid var(--opc-rule);flex-direction:column;gap:.4rem;padding:1rem 1.1rem;display:flex}.opc-overview-cell:nth-last-child(-n+4){border-bottom:0}.opc-overview-cell:last-child{border-right:0}.opc-spark{width:100%;height:22px;display:block;overflow:visible}.opc-spark path{fill:none;stroke:currentColor;stroke-width:1.4px;stroke-linecap:round;stroke-linejoin:round;vector-effect:non-scaling-stroke}.opc-spark .opc-spark-fill{fill:currentColor;opacity:.12;stroke:none}.opc-activity{font-family:var(--font-mono), monospace;border:1px solid var(--opc-rule);background:var(--bg-surface);border-radius:6px;flex-direction:column;font-size:.82rem;display:flex;overflow:hidden}.opc-activity-row{grid-template-columns:auto auto 1fr;align-items:baseline;gap:.85rem;padding:.55rem 1rem;display:grid}.opc-activity-row+.opc-activity-row{border-top:1px solid var(--opc-rule)}.opc-activity-time{color:var(--text-faint);font-variant-numeric:tabular-nums}.opc-activity-icon{color:var(--text-muted);text-align:center;width:1.1em}.opc-activity-text{color:var(--text-secondary)}.opc-activity-text strong{color:var(--text);font-weight:500}.opc-activity-text code{color:var(--text-muted);padding:0 .15rem;font-size:.78rem}.opc-tabs{border-bottom:1px solid var(--opc-rule);gap:.25rem;margin-bottom:0;display:flex}.opc-tab{font-family:var(--font-mono), monospace;letter-spacing:.14em;text-transform:uppercase;cursor:pointer;color:var(--text-muted);background:0 0;border:0;padding:.7rem 1.1rem;font-size:.74rem;font-weight:500;transition:color .15s;position:relative}.opc-tab:hover{color:var(--text-secondary)}.opc-tab.active{color:var(--text)}.opc-tab.active:after{content:"";background:linear-gradient(90deg, var(--opc-hero-from), var(--opc-hero-via));height:2px;position:absolute;bottom:-1px;left:0;right:0}.opc-empty{text-align:center;color:var(--text-muted);border:1px dashed var(--opc-rule);border-radius:6px;padding:2.5rem 1.5rem;font-size:.9rem}.opc-empty-eyebrow{font-family:var(--font-mono), monospace;letter-spacing:.18em;text-transform:uppercase;color:var(--text-faint);margin-bottom:.4rem;font-size:.66rem;display:block}.opc-skel{background:linear-gradient(90deg, var(--bg-elevated) 0%, var(--bg-muted) 50%, var(--bg-elevated) 100%);background-size:200% 100%;border-radius:3px;height:.9em;animation:1.2s ease-in-out infinite opc-skel}@keyframes opc-skel{0%{background-position:200% 0}to{background-position:-200% 0}}.beta-badge{background:var(--pill-amber-bg);color:var(--pill-amber);border:1px solid var(--pill-amber);letter-spacing:.12em;text-transform:uppercase;vertical-align:middle;white-space:nowrap;border-radius:999px;padding:.1rem .45rem;font-size:.62rem;font-weight:700;line-height:1.4;display:inline-block}.beta-inline{color:var(--text-muted);align-items:center;gap:.5rem;margin:.6rem 0 0;font-size:.8rem;display:flex}.beta-notice{border:1px solid var(--pill-amber);background:var(--pill-amber-bg);border-radius:var(--radius);align-items:flex-start;gap:.7rem;margin:0 0 1.25rem;padding:.7rem .9rem;font-size:.85rem;display:flex}.beta-notice .beta-badge{flex:none;margin-top:.1rem}.beta-notice-body{color:var(--text-secondary);flex:1;line-height:1.45}.beta-notice-body strong{color:var(--text)}.beta-notice-dismiss{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:6px;flex:none;padding:.15rem .35rem;font-size:.85rem;line-height:1}.beta-notice-dismiss:hover{color:var(--text);background:var(--bg-hover)}.admin-tenant-switch{padding:.4rem .75rem .6rem}.admin-tenant-switch-label{letter-spacing:.14em;text-transform:uppercase;color:var(--text-faint);margin-bottom:.3rem;font-size:.62rem;display:block}.admin-tenant-select{background:var(--bg-input);width:100%;color:var(--text);border:1px solid var(--border);cursor:pointer;border-radius:8px;padding:.4rem .5rem;font-size:.85rem}.opc-callout{border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-muted);padding:.75rem .9rem;font-size:.85rem}.saml-sp-details{grid-template-columns:max-content 1fr;gap:.25rem .9rem;margin:.5rem 0 0;display:grid}.saml-sp-details dt{color:var(--text-muted)}.saml-sp-details dd{word-break:break-all;margin:0}.opc-pager{border-top:1px solid var(--border-subtle);color:var(--text-muted);justify-content:space-between;align-items:center;gap:1rem;margin-top:.75rem;padding-top:.6rem;font-size:.82rem;display:flex}.opc-pager-controls{align-items:center;gap:.5rem;display:inline-flex}.opc-pager-page{font-family:var(--font-mono);color:var(--text-secondary)}.nm-subfield{color:var(--text-muted);flex-direction:column;flex:calc(50% - .25rem);gap:.2rem;min-width:120px;font-size:.78rem;display:flex}.nm-subfield .nm-select{width:100%;min-width:0}.nm-card-grid .nm-subfield{flex:none;width:100%}.replay-root{background:var(--bg,#0b0d11);height:100vh;color:var(--text,#e5e7eb);flex-direction:column;display:flex}.replay-stage{flex:1;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.replay-video,.replay-tile-video{background:#000;max-width:100%;max-height:100%}.replay-grid{gap:4px;width:100%;height:100%;padding:4px;display:grid}.replay-grid[data-tile-count="1"]{grid-template-columns:1fr}.replay-grid[data-tile-count="2"]{grid-template-columns:1fr 1fr}.replay-grid[data-tile-count="3"],.replay-grid[data-tile-count="4"]{grid-template-rows:1fr 1fr;grid-template-columns:1fr 1fr}.replay-grid[data-tile-count="5"],.replay-grid[data-tile-count="6"],.replay-grid[data-tile-count="7"],.replay-grid[data-tile-count="8"],.replay-grid[data-tile-count="9"]{grid-template-rows:repeat(3,1fr);grid-template-columns:repeat(3,1fr)}.replay-grid .replay-tile-video{object-fit:cover;width:100%;height:100%}.replay-overlay{pointer-events:none;position:absolute;inset:0}.replay-loading,.replay-error{text-align:center;color:var(--text,#e5e7eb);padding:2rem}.replay-error h2{color:#f87171;margin-bottom:.5rem}.btn-downloading{isolation:isolate;position:relative;overflow:hidden;opacity:1!important;cursor:progress!important}.btn-downloading:before{content:"";width:var(--progress,0%);z-index:-1;background:linear-gradient(90deg,#22c55e4d 0%,#22c55e73 100%);transition:width .12s ease-out;position:absolute;inset:0}.btn-downloading:after{content:"";z-index:-1;background:repeating-linear-gradient(45deg,#fff0 0 12px,#ffffff14 12px 24px);animation:1.2s linear infinite downloading-stripes;position:absolute;inset:0}@keyframes downloading-stripes{0%{background-position:0 0}to{background-position:34px 0}}.recording-player-modal{max-width:1080px}.recording-player-replay-host{min-height:60vh;padding:0}.recording-player-replay-host .replay-root{border-radius:6px;height:70vh;overflow:hidden}.room-recordings-page{max-width:920px;color:var(--text,#e5e7eb);margin:0 auto;padding:2rem 1.5rem 4rem}.room-recordings-header{flex-wrap:wrap;justify-content:space-between;align-items:baseline;gap:1rem;margin-bottom:1.5rem;display:flex}.room-recordings-header h1{margin:0;font-size:1.5rem}.room-recordings-list{flex-direction:column;gap:.75rem;margin:0;padding:0;list-style:none;display:flex}.room-recording-card{background:var(--surface,#1b1f27);border:1px solid var(--border,#94a3b82e);border-radius:8px;justify-content:space-between;align-items:center;gap:1rem;padding:.9rem 1.1rem;display:flex}.room-recording-meta{flex-direction:column;gap:.25rem;min-width:0;display:flex}.room-recording-meta strong{font-size:1rem}.room-recording-meta .text-muted{font-size:.85rem}.room-recording-actions{flex-shrink:0;gap:.5rem;display:flex}.room-recording-card .encryption-badge{filter:saturate(80%);margin-left:.4rem;font-size:.95rem}.e2ee-playback{background:var(--bg,#0b0d11);width:100%;height:100%;color:var(--text,#e5e7eb);justify-content:center;align-items:center;padding:2rem;display:flex}.e2ee-playback-card{background:var(--surface,#1b1f27);border:1px solid var(--border,#94a3b82e);border-radius:10px;width:100%;max-width:640px;padding:1.75rem 1.75rem 1.5rem}.e2ee-playback-card h2{margin:0 0 .75rem;font-size:1.25rem}.e2ee-playback-card .text-muted{font-size:.92rem;line-height:1.45}.e2ee-fingerprint code{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.85rem}.e2ee-passphrase-form{flex-direction:column;gap:.6rem;margin-top:1.2rem;display:flex}.e2ee-passphrase-form label{color:var(--text-muted,#e5e7ebb3);font-size:.85rem;font-weight:500}.e2ee-passphrase-form input{border:1px solid var(--border,#94a3b840);color:var(--text,#e5e7eb);background:#00000040;border-radius:6px;padding:.55rem .7rem;font-size:1rem}.e2ee-passphrase-form input:focus{outline:1px solid var(--accent,#6366f1);border-color:var(--accent,#6366f1)}.e2ee-passphrase-form button{align-self:flex-start}.e2ee-actions{margin:1rem 0 .75rem}.e2ee-decrypt-instructions{border:1px solid var(--border,#94a3b826);background:#0003;border-radius:6px;margin-top:1.2rem;padding:.8rem 1rem}.e2ee-decrypt-instructions summary{cursor:pointer;margin-bottom:.5rem;font-size:.9rem;font-weight:500}.e2ee-decrypt-instructions ol{margin:.5rem 0 0;padding-left:1.2rem;font-size:.88rem;line-height:1.6}.e2ee-decrypt-instructions pre{background:#0b0d11;border-radius:5px;margin:.4rem 0;padding:.6rem .8rem;font-size:.82rem;overflow-x:auto}.e2ee-key-display{-webkit-user-select:all;user-select:all;word-break:break-all;white-space:pre-wrap}
