/*! tailwindcss v4.1.3 | MIT License | https://tailwindcss.com */
@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:rotateX(0);--tw-rotate-y:rotateY(0);--tw-rotate-z:rotateZ(0);--tw-skew-x:skewX(0);--tw-skew-y:skewY(0);--tw-border-style:solid;--tw-outline-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial;--tw-ease:initial}}}@font-face{font-family:Inter;font-style:normal;font-weight:400;font-display:swap;src:url(/static/fonts/inter/Inter-400.woff2)format("woff2")}@font-face{font-family:Inter;font-style:normal;font-weight:500;font-display:swap;src:url(/static/fonts/inter/Inter-500.woff2)format("woff2")}@font-face{font-family:Inter;font-style:normal;font-weight:600;font-display:swap;src:url(/static/fonts/inter/Inter-600.woff2)format("woff2")}@font-face{font-family:Inter;font-style:normal;font-weight:700;font-display:swap;src:url(/static/fonts/inter/Inter-700.woff2)format("woff2")}@layer theme{:root,:host{--font-sans:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;--font-mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;--radius-xs:3px;--radius-sm:5px;--radius-md:6px;--radius-lg:8px;--ease-in-out:cubic-bezier(.4,0,.2,1);--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4,0,.2,1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono);--color-surface-page:#f4f6f5;--color-surface-card:#fff;--color-brand:#0f3d34;--color-brand-hover:#0b2e28;--color-success:#16a34a;--color-warning:#d97706;--color-error:#dc2626;--color-tile-bg:#0b2e28;--shadow-card:0 1px 3px #0000000a;--shadow-panel:0 4px 16px #0000001a;--shadow-btn-primary:0 2px 6px #0000000f,0 10px 20px #0000001a}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.collapse{visibility:collapse}.visible{visibility:visible}.sr-only{clip:rect(0,0,0,0);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.absolute{position:absolute}.fixed{position:fixed}.static{position:static}.container{width:100%}@media (min-width:40rem){.container{max-width:40rem}}@media (min-width:48rem){.container{max-width:48rem}}@media (min-width:64rem){.container{max-width:64rem}}@media (min-width:80rem){.container{max-width:80rem}}@media (min-width:96rem){.container{max-width:96rem}}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.hidden\!{display:none!important}.inline{display:inline}.inline-block{display:inline-block}.transform{transform:var(--tw-rotate-x)var(--tw-rotate-y)var(--tw-rotate-z)var(--tw-skew-x)var(--tw-skew-y)}.resize{resize:both}.border{border-style:var(--tw-border-style);border-width:1px}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.filter{filter:var(--tw-blur,)var(--tw-brightness,)var(--tw-contrast,)var(--tw-grayscale,)var(--tw-hue-rotate,)var(--tw-invert,)var(--tw-saturate,)var(--tw-sepia,)var(--tw-drop-shadow,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.ease-in-out{--tw-ease:var(--ease-in-out);transition-timing-function:var(--ease-in-out)}}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(/static/fonts/inter-latin.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(/static/fonts/inter-latin-ext.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%}body{font-family:var(--font-sans);background:var(--color-surface-page);color:var(--text-body);-webkit-font-smoothing:antialiased}.hidden{display:none!important}.sr-only{clip:rect(0,0,0,0);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.page{flex-direction:column;min-height:100vh;display:flex}.header{background:var(--surface-card);border-bottom:1px solid #e0e5e3;justify-content:space-between;align-items:center;padding:1rem 2rem;display:flex}.header-brand{align-items:center;gap:.625rem;text-decoration:none;display:flex}.header-mark{background:var(--color-brand);border-radius:var(--radius-sm);color:#fff;letter-spacing:.02em;justify-content:center;align-items:center;width:32px;height:32px;font-size:.75rem;font-weight:700;display:flex}.header-name{color:var(--text-heading);font-size:.9375rem;font-weight:600}.header-sub{color:var(--text-muted);font-size:.6875rem}.header-actions{align-items:center;gap:.75rem;display:flex}.nav-links{gap:.5rem;display:flex}.nav-link{color:var(--text-body);border-radius:var(--radius-sm);padding:.4375rem .75rem;font-size:.8125rem;font-weight:500;text-decoration:none;transition:background .15s,color .15s}.nav-link:hover{background:var(--surface-subtle);color:var(--text-heading)}.btn{cursor:pointer;border-radius:var(--radius-sm);border:none;justify-content:center;align-items:center;padding:.5rem 1rem;font-family:inherit;font-size:.875rem;font-weight:600;line-height:1.4;text-decoration:none;transition:background .15s,box-shadow .15s;display:inline-flex}.btn-primary{background:var(--color-brand);color:#fff;box-shadow:var(--shadow-btn-primary)}.btn-primary:hover{background:var(--color-brand-hover)}.btn-secondary{background:var(--surface-subtle);color:var(--text-heading)}.btn-secondary:hover{background:var(--border)}.btn-ghost{color:var(--color-brand);background:0 0}.btn-ghost:hover{background:var(--surface-subtle)}.btn-block{width:100%;padding:.75rem 1rem}.input{width:100%;color:var(--text-heading);background:var(--surface-card);border:1px solid var(--border-input);border-radius:var(--radius-sm);padding:.625rem .75rem;font-family:inherit;font-size:.875rem;transition:border-color .15s,box-shadow .15s}.input:focus{border-color:var(--color-brand);outline:none;box-shadow:0 0 0 2px #0f3d341f}.input::placeholder{color:var(--text-placeholder)}.input+.btn{margin-top:.5rem}.card{background:var(--surface-card);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-card);padding:1.25rem}.card-label{color:var(--text-label);text-transform:uppercase;letter-spacing:.06em;margin-bottom:.75rem;font-size:.6875rem;font-weight:600}.name-prompt{border-top:1px solid #e0e5e3;margin-top:.75rem;padding-top:.75rem;display:none}.name-prompt.show{display:block}.name-prompt label{color:var(--text-secondary);margin-bottom:.375rem;font-size:.8125rem;font-weight:500;display:block}.name-prompt .btn{margin-top:.5rem}.error-message{color:var(--color-error);border-radius:var(--radius-sm);background:#dc26260f;border:1px solid #dc262633;margin-bottom:1rem;padding:.625rem .75rem;font-size:.8125rem}.footer{text-align:center;color:var(--text-muted);border-top:1px solid #e0e5e3;padding:1rem 2rem;font-size:.75rem}.hero{flex-direction:column;flex:1;justify-content:center;align-items:center;padding:3rem 2rem 2rem;display:flex}.hero-content{text-align:center;max-width:520px;margin-bottom:2.5rem}.hero-title{color:var(--text-heading);margin-bottom:.75rem;font-size:2.25rem;font-weight:700;line-height:1.2}.hero-sub{color:var(--text-label);font-size:1rem;line-height:1.5}.cards{gap:1rem;width:100%;max-width:640px;display:flex}.features{justify-content:center;gap:2.5rem;padding:1.5rem 2rem 2rem;display:flex}.feature{align-items:center;gap:.5rem;display:flex}.feature-icon{width:32px;height:32px;color:var(--color-brand);background:var(--surface-subtle);border-radius:var(--radius-sm);justify-content:center;align-items:center;display:flex}.feature-icon svg{width:18px;height:18px}.feature-text{color:var(--text-secondary);font-size:.8125rem;font-weight:500}.join-main{flex:1;justify-content:center;align-items:center;padding:2rem;display:flex}.join-card{background:var(--surface-card);border:1px solid var(--border);border-radius:var(--radius-md);width:100%;max-width:400px;box-shadow:var(--shadow-card);padding:2rem}.join-label{color:var(--text-label);text-transform:uppercase;letter-spacing:.06em;margin-bottom:.375rem;font-size:.6875rem;font-weight:600}.join-title{color:var(--text-heading);margin-bottom:1.5rem;font-size:1.25rem;font-weight:700}.form-group{margin-bottom:1rem}.form-group label{color:var(--text-secondary);margin-bottom:.375rem;font-size:.8125rem;font-weight:500;display:block}#prejoinScreen{z-index:50;background:var(--color-surface-page);position:fixed;inset:0}.pj-header{align-items:center;gap:.625rem;padding:1rem 1.5rem;display:flex;position:absolute;top:0;left:0;right:0}.pj-mark{background:var(--color-brand);border-radius:var(--radius-sm);color:#fff;justify-content:center;align-items:center;width:32px;height:32px;font-size:.75rem;font-weight:700;display:flex}.pj-title{color:var(--text-heading);font-size:.9375rem;font-weight:600}.pj-container{justify-content:center;align-items:center;min-height:100vh;padding:1rem;display:flex}.pj-content{flex-direction:column;gap:2rem;width:100%;max-width:960px;display:flex}.pj-video-section{flex:1;min-width:0}.pj-form-section{width:100%;max-width:300px;margin:0 auto}.pj-video-wrap{background:var(--color-tile-bg);border-radius:var(--radius-md);border:1px solid var(--border);width:100%;box-shadow:var(--shadow-card);padding-bottom:56.25%;position:relative;overflow:hidden}.pj-video-wrap video,.pj-video-wrap #prejoinAvatar,.pj-video-wrap #prejoinPermissionPrompt{width:100%;height:100%;position:absolute;top:0;left:0}.pj-video-wrap video{object-fit:cover;transform:scaleX(-1)}#prejoinAvatar{background:var(--color-tile-bg);justify-content:center;align-items:center;display:flex}.pj-avatar-circle{border-radius:var(--radius-md);background:#ffffff14;justify-content:center;align-items:center;width:96px;height:96px;display:flex}.pj-avatar-circle svg{color:#fff6;width:48px;height:48px}#prejoinPermissionPrompt{background:#0b2e28eb;justify-content:center;align-items:center;display:flex}.pj-perm-inner{text-align:center;padding:1.5rem}.pj-perm-icon{border-radius:var(--radius-md);background:#ffffff14;justify-content:center;align-items:center;width:64px;height:64px;margin:0 auto .75rem;display:flex}.pj-perm-icon svg{color:#fff;width:32px;height:32px}.pj-perm-text{color:#ffffffd9;margin-bottom:.25rem;font-size:.9375rem}.pj-perm-sub{color:#ffffff73;font-size:.8125rem}.pj-controls{z-index:10;background:linear-gradient(#0000,#0b2e28b3);justify-content:center;gap:.75rem;padding:1.25rem;display:flex;position:absolute;bottom:0;left:0;right:0}.pj-ctrl-btn{border-radius:var(--radius-md);cursor:pointer;background:#ffffff1f;border:none;justify-content:center;align-items:center;width:48px;height:48px;transition:background .15s;display:flex}.pj-ctrl-btn:hover{background:#fff3}.pj-ctrl-btn svg{color:#fff;width:22px;height:22px}.pj-ctrl-btn.off{background:var(--color-error)}.pj-ctrl-btn.off:hover{background:#b91c1c}.pj-devices{flex-wrap:wrap;gap:.75rem;margin-top:1rem;display:flex}.pj-device-row{flex:1;align-items:center;gap:.5rem;min-width:180px;display:flex}.pj-device-row svg{width:18px;height:18px;color:var(--text-muted);flex-shrink:0}.pj-device-select{border-radius:var(--radius-sm);border:1px solid var(--border-input);background:var(--surface-card);color:var(--text-body);flex:1;padding:.5rem .625rem;font-family:inherit;font-size:.8125rem}.pj-form h1{color:var(--text-heading);margin-bottom:.375rem;font-size:1.25rem;font-weight:700}.pj-form .pj-room-info{color:var(--text-muted);margin-bottom:1.25rem;font-size:.875rem}.pj-form .pj-room-info strong{color:var(--text-heading);font-weight:500}.pj-input-group{margin-bottom:.75rem}.pj-input-group label{color:var(--text-secondary);margin-bottom:.375rem;font-size:.8125rem;font-weight:500;display:block}.pj-input-wrap{position:relative}.pj-input{border-radius:var(--radius-sm);border:1px solid var(--border-input);background:var(--surface-card);width:100%;color:var(--text-heading);padding:.625rem .75rem;font-family:inherit;font-size:.875rem;transition:border-color .15s,box-shadow .15s}.pj-input:focus{border-color:var(--color-brand);outline:none;box-shadow:0 0 0 2px #0f3d341f}.pj-input::placeholder{color:var(--text-placeholder)}.pj-char-count{color:var(--text-muted);font-size:.6875rem;position:absolute;top:50%;right:.625rem;transform:translateY(-50%)}.pj-submit{border-radius:var(--radius-sm);background:var(--color-brand);color:#fff;cursor:pointer;width:100%;box-shadow:var(--shadow-btn-primary);border:none;padding:.75rem 1rem;font-family:inherit;font-size:.875rem;font-weight:600;transition:background .15s}.pj-submit:hover{background:var(--color-brand-hover)}.pj-hint{text-align:center;color:var(--text-muted);margin-top:.75rem;font-size:.8125rem}.pj-error{border-radius:var(--radius-sm);color:var(--color-error);background:#dc26260d;border:1px solid #dc262633;margin-bottom:.75rem;padding:.625rem .75rem;font-size:.8125rem}#waitingRoom{z-index:50;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#f4f6f5d9;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.wr-card{background:var(--surface-card);border:1px solid var(--border);border-radius:var(--radius-md);text-align:center;width:100%;max-width:380px;box-shadow:var(--shadow-panel);padding:2.5rem 2rem}.wr-icon{background:var(--surface-subtle);border-radius:var(--radius-md);justify-content:center;align-items:center;width:56px;height:56px;margin:0 auto 1.25rem;display:flex}.wr-icon svg{width:28px;height:28px;color:var(--color-brand)}.wr-title{color:var(--text-heading);margin-bottom:.375rem;font-size:1.125rem;font-weight:700}.wr-text{color:var(--text-muted);margin-bottom:1.5rem;font-size:.875rem}.wr-leave{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface-card);color:var(--text-body);cursor:pointer;padding:.625rem 1.25rem;font-family:inherit;font-size:.8125rem;font-weight:500;transition:background .15s}.wr-leave:hover{background:var(--surface-subtle)}#appContainer>*{min-height:0}#videoArea{flex:1;display:flex;overflow:hidden}#gridModeContainer{flex-direction:column;flex:1;display:flex;overflow:hidden}#videoGridContainer{flex:1;height:100%;min-height:0}.video-grid-container{box-sizing:border-box;flex:1;place-content:stretch;gap:.5rem;width:100%;height:100%;min-height:0;padding:.75rem;display:grid}.participant-tile{background:var(--color-tile-bg);border-radius:var(--radius-md);border:1px solid var(--border);flex-direction:column;height:100%;min-height:0;transition:border-color .2s,box-shadow .2s;display:flex;position:relative;overflow:hidden}.participant-tile.speaking{border-color:var(--color-success);box-shadow:0 0 0 2px #16a34a40}.participant-tile video{object-fit:cover;flex:1;width:100%;height:100%;min-height:0}.participant-tile.local video{transform:scaleX(-1)}.participant-tile.screen-share video{background:#000;object-fit:contain!important}.participant-info{z-index:10;background:linear-gradient(#0000,#0b2e2866,#0b2e28d9);flex-shrink:0;justify-content:space-between;align-items:flex-end;min-height:36px;padding:.375rem .625rem;display:flex;position:absolute;bottom:0;left:0;right:0}.participant-name{color:#fff;text-shadow:0 1px 2px #0000004d;text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:.8125rem;font-weight:600;overflow:hidden}.mic-indicator{margin-left:.5rem;font-size:.875rem}.mic-indicator.active{color:var(--color-success)}.mic-indicator.muted{color:var(--color-error)}.participant-tile.audio-only{background:var(--color-tile-bg);justify-content:center;align-items:center;display:flex}.host-badge-small{background:var(--color-warning);color:#fff;border-radius:var(--radius-xs);text-transform:uppercase;letter-spacing:.04em;margin-right:.375rem;padding:.0625rem .3125rem;font-size:.5625rem;font-weight:700}#presentationModeContainer{background:var(--color-surface-page);flex-direction:row;height:100%;min-height:0;display:flex}.presentation-main-stage{flex:1;justify-content:center;align-items:center;min-width:0;min-height:0;padding:.75rem;display:flex}.presentation-main-stage .participant-tile{width:100%;height:100%}.presentation-main-stage .participant-tile video{object-fit:contain!important}.presentation-filmstrip{background:var(--surface-card);border-left:1px solid var(--border);flex-direction:column;gap:.375rem;width:180px;min-width:180px;padding:.375rem;display:flex;overflow:hidden auto}.presentation-filmstrip .participant-tile{flex-shrink:0;width:100%;height:110px;min-height:110px}.presentation-filmstrip .participant-tile video{object-fit:cover}.presentation-filmstrip .participant-info{min-height:28px;padding:.25rem .5rem}.presentation-filmstrip .participant-name{font-size:.6875rem}.presentation-filmstrip .audio-avatar{width:44px;height:44px;font-size:1.125rem}.presentation-filmstrip::-webkit-scrollbar{width:3px}.presentation-filmstrip::-webkit-scrollbar-track{background:0 0}.presentation-filmstrip::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}.controls-bar{background:var(--surface-card);border-top:1px solid #e0e5e3;padding:.625rem 1rem}.controls-inner{justify-content:space-between;align-items:center;display:flex}.ctrl-left{flex:1;align-items:center;gap:.625rem;display:flex}.ctrl-mark{background:var(--color-brand);border-radius:var(--radius-sm);color:#fff;justify-content:center;align-items:center;width:32px;height:32px;font-size:.6875rem;font-weight:700;display:flex}.ctrl-room-name{color:var(--text-heading);font-size:.8125rem;font-weight:600}.ctrl-meta{align-items:center;gap:.5rem;display:flex}.ctrl-time{color:var(--text-muted);font-size:.6875rem}.ctrl-rec{color:var(--color-error);align-items:center;font-size:.6875rem;font-weight:600;display:none}.ctrl-rec-dot{background:var(--color-error);border-radius:50%;width:6px;height:6px;margin-right:.25rem;animation:1.5s infinite recPulse}.ctrl-center{align-items:center;gap:.5rem;display:flex}.ctrl-btn{border-radius:var(--radius-sm);background:var(--surface-subtle);border:1px solid var(--border);cursor:pointer;justify-content:center;align-items:center;width:44px;height:44px;transition:background .15s,border-color .15s;display:flex;position:relative}.ctrl-btn:hover{background:var(--color-surface-page);border-color:var(--border-input)}.ctrl-btn svg{width:20px;height:20px;color:var(--text-heading)}.ctrl-btn.active{background:var(--color-brand);border-color:var(--color-brand)}.ctrl-btn.active svg{color:#fff}.ctrl-btn:disabled{opacity:.35;cursor:not-allowed}.ctrl-btn.danger{background:var(--color-error);border-color:var(--color-error)}.ctrl-btn.danger svg{color:#fff}.ctrl-btn.danger:hover{background:#b91c1c}.ctrl-right{flex:1;justify-content:flex-end;align-items:center;gap:.5rem;display:flex}.ctrl-badge{background:var(--color-brand);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:16px;height:16px;font-size:.5625rem;font-weight:700;display:flex;position:absolute;top:-3px;right:-3px}.device-control-wrapper{position:relative}.device-dropdown-toggle{background:var(--surface-card);border:1px solid var(--border);width:16px;height:16px;color:var(--text-muted);cursor:pointer;z-index:10;border-radius:50%;justify-content:center;align-items:center;transition:background .15s;display:flex;position:absolute;top:-4px;right:-4px}.device-dropdown-toggle:hover{background:var(--surface-subtle)}.device-dropdown-toggle svg{width:10px;height:10px}.device-dropdown{background:var(--surface-card);border:1px solid var(--border);border-radius:var(--radius-md);min-width:220px;max-width:280px;box-shadow:var(--shadow-panel);z-index:100;margin-bottom:8px;position:absolute;bottom:100%;left:50%;overflow:hidden;transform:translate(-50%)}.device-dropdown-header{color:var(--text-label);text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid #e0e5e3;padding:.625rem .75rem;font-size:.6875rem;font-weight:600}.device-dropdown-list{max-height:180px;overflow-y:auto}.device-dropdown-item{color:var(--text-body);cursor:pointer;align-items:center;gap:.5rem;padding:.625rem .75rem;font-size:.8125rem;transition:background .1s;display:flex}.device-dropdown-item:hover{background:var(--surface-subtle)}.device-dropdown-item.active{color:var(--color-brand);background:#0f3d340f}.device-dropdown-item.active:before{content:"";background:var(--color-brand);border-radius:50%;flex-shrink:0;width:6px;height:6px}.device-dropdown-item:not(.active):before{content:"";flex-shrink:0;width:6px;height:6px}.panel-float{z-index:40;background:#fff;border:1px solid #e0e5e3;border-radius:6px;flex-direction:column;width:320px;max-height:60vh;display:flex;position:fixed;bottom:5rem;right:1rem;overflow:hidden;box-shadow:0 4px 16px #0000001a}.panel-float .panel-header{border-bottom:1px solid #e0e5e3;justify-content:space-between;align-items:center;padding:.75rem 1rem;display:flex}.panel-float .panel-title{color:var(--text-heading);font-size:.875rem;font-weight:600}.panel-close{cursor:pointer;color:var(--text-muted);background:0 0;border:none;justify-content:center;align-items:center;padding:.125rem;display:flex}.panel-close:hover{color:var(--text-heading)}.panel-close svg{width:16px;height:16px}#participantsPanel{width:280px}.participants-list{max-height:340px;padding:.625rem .75rem;overflow-y:auto}.participants-section{margin-bottom:.75rem}.section-header{justify-content:space-between;align-items:center;margin-bottom:.375rem;padding:.375rem 0;display:flex}.section-title{color:var(--text-label);text-transform:uppercase;letter-spacing:.05em;font-size:.625rem;font-weight:600}.section-count{color:var(--text-muted);background:var(--surface-subtle);border-radius:var(--radius-xs);padding:.0625rem .375rem;font-size:.6875rem}.admit-all-btn{width:100%;color:var(--color-brand);cursor:pointer;text-align:right;background:0 0;border:none;margin-bottom:.5rem;padding:.375rem .5rem;font-family:inherit;font-size:.75rem;font-weight:500;transition:color .15s}.admit-all-btn:hover{color:var(--color-brand-hover)}.participant-item{border-radius:var(--radius-sm);align-items:center;gap:.625rem;padding:.5rem;transition:background .1s;display:flex}.participant-item:hover{background:var(--surface-subtle)}.participant-item.waiting{background:var(--surface-subtle);border:1px solid var(--border);margin-bottom:.375rem}.participant-avatar{border-radius:var(--radius-sm);background:var(--color-brand);color:#fff;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;font-size:.6875rem;font-weight:700;display:flex}.waiting-avatar{background:var(--color-warning)!important}.participant-item.host .participant-avatar{background:var(--color-warning)}.participant-item.local{background:#0f3d340a}.participant-info-row{flex:1;min-width:0}.participant-name-row{align-items:center;gap:.375rem;display:flex}.participant-name-text{color:var(--text-heading);text-overflow:ellipsis;white-space:nowrap;font-size:.8125rem;font-weight:500;overflow:hidden}.host-badge{color:var(--text-muted);font-size:.625rem}.participant-actions{flex-shrink:0;align-items:center;gap:.375rem;display:flex}.action-btn{border-radius:var(--radius-sm);cursor:pointer;border:none;padding:.25rem .5rem;font-family:inherit;font-size:.75rem;font-weight:500;transition:all .1s}.action-btn.admit{color:var(--color-brand);background:0 0}.action-btn.admit:hover{background:#0f3d340f}.action-btn.deny{color:var(--text-muted);background:0 0;padding:.25rem;display:flex}.action-btn.deny:hover{color:var(--color-error);background:#dc26260d}.participant-status-icons{flex-shrink:0;align-items:center;gap:.25rem;display:flex}.status-icon{color:var(--text-muted);display:flex}.status-icon.active{color:var(--color-success)}.status-icon.muted{color:var(--color-error)}#chatPanel{width:340px}.chat-messages{scroll-behavior:smooth;max-height:320px;padding:.75rem;overflow-y:auto}.chat-message{flex-direction:column;gap:.125rem;margin-bottom:.625rem;display:flex}.chat-message.own{align-items:flex-end}.chat-message-header{color:var(--text-muted);gap:.375rem;font-size:.6875rem;display:flex}.chat-bubble{border-radius:var(--radius-md);word-wrap:break-word;max-width:80%;padding:.5rem .75rem;font-size:.8125rem;line-height:1.45}.chat-message:not(.own) .chat-bubble{background:var(--surface-subtle);color:var(--text-heading)}.chat-message.own .chat-bubble{background:var(--color-brand);color:#fff}.chat-message.system .chat-bubble{color:var(--text-muted);text-align:center;background:0 0;font-size:.6875rem;font-style:italic}.chat-input-bar{border-top:1px solid #e0e5e3;gap:.5rem;padding:.75rem;display:flex}.chat-input-bar textarea{resize:none;border:1px solid var(--border-input);border-radius:var(--radius-sm);color:var(--text-heading);background:var(--surface-card);flex:1;padding:.5rem .625rem;font-family:inherit;font-size:.8125rem;line-height:1.4}.chat-input-bar textarea:focus{border-color:var(--color-brand);outline:none}.chat-input-bar textarea::placeholder{color:var(--text-placeholder)}.chat-send{background:var(--color-brand);border-radius:var(--radius-sm);cursor:pointer;border:none;justify-content:center;align-items:center;padding:0 .75rem;transition:background .15s;display:flex}.chat-send:hover{background:var(--color-brand-hover)}.chat-send svg{color:#fff;width:18px;height:18px}#toast{z-index:50;background:var(--surface-card);border:1px solid var(--border);border-radius:var(--radius-md);max-width:320px;box-shadow:var(--shadow-panel);color:var(--text-heading);padding:.75rem 1rem;font-size:.8125rem;position:fixed;bottom:5rem;right:1rem}#appContainer{flex-direction:column;height:100vh;min-height:0;display:flex}.room-topbar{background:var(--surface-card);border-bottom:1px solid #e0e5e3;flex-shrink:0;justify-content:space-between;align-items:center;padding:.5rem 1rem;display:flex}.topbar-left{align-items:center;gap:.625rem;display:flex}.topbar-right{align-items:center;gap:.75rem;display:flex}.room-body{background:var(--color-surface-page);flex:1;min-height:0;display:flex;overflow:hidden}.main-video{background:var(--color-tile-bg);border-radius:var(--radius-md);flex:1;justify-content:center;align-items:center;min-width:0;min-height:0;margin:.5rem;display:flex;position:relative;overflow:hidden}.main-video video{object-fit:contain;width:100%;height:100%}.main-video.audio-only{flex-direction:column;justify-content:center;align-items:center;display:flex}.video-sidebar{background:var(--surface-card);border-left:1px solid var(--border);flex-direction:column;gap:.375rem;width:220px;min-width:220px;padding:.5rem;display:flex;overflow:hidden auto}.video-tile{background:var(--color-tile-bg);border-radius:var(--radius-md);border:1px solid var(--border);cursor:pointer;transition:border-color .2s;position:relative;overflow:hidden}.video-tile:hover{border-color:var(--border-input)}.video-tile.pinned{border-color:var(--color-success);box-shadow:0 0 0 2px #16a34a40}.video-tile video{object-fit:cover;width:100%;height:100%;display:block}.video-tile.audio-only{flex-direction:column;justify-content:center;align-items:center;display:flex}.video-tile.screen-share video{object-fit:contain;background:#000}.participant-label{color:#fff;text-shadow:0 1px 2px #0000004d;text-overflow:ellipsis;white-space:nowrap;background:linear-gradient(#0000,#0b2e28d9);padding:.375rem .5rem;font-size:.75rem;font-weight:600;position:absolute;bottom:0;left:0;right:0;overflow:hidden}.audio-avatar{border-radius:var(--radius-md);color:#fff;text-transform:uppercase;background:#ffffff14;justify-content:center;align-items:center;width:56px;height:56px;font-size:1.5rem;font-weight:700;display:flex}.room-sidebar-panel{background:var(--surface-card);border-left:1px solid var(--border);flex-direction:column;width:280px;min-width:280px;display:flex}.sidebar-tabs{border-bottom:1px solid #e0e5e3;display:flex}.sidebar-tab{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;flex:1;padding:.625rem;font-family:inherit;font-size:.8125rem;font-weight:500;transition:all .15s}.sidebar-tab:hover{color:var(--text-heading)}.sidebar-tab.active{color:var(--color-brand);border-bottom-color:var(--color-brand)}.tab-panel{flex-direction:column;flex:1;display:none;overflow:hidden}.tab-panel.active{display:flex}.status-chip{border-radius:var(--radius-xs);padding:.125rem .5rem;font-size:.6875rem;font-weight:600;display:none}.status-chip.connected{color:var(--color-success);background:#16a34a1a;display:inline-block}.status-chip.connecting{color:var(--color-warning);background:#d977061a;display:inline-block}.status-chip.disconnected{color:var(--color-error);background:#dc26261a;display:inline-block}.toast-msg{z-index:50;background:var(--surface-card);border:1px solid var(--border);border-radius:var(--radius-md);max-width:320px;box-shadow:var(--shadow-panel);color:var(--text-heading);white-space:nowrap;padding:.75rem 1rem;font-size:.8125rem;display:none;position:fixed;bottom:5rem;left:50%;transform:translate(-50%)}.toast-msg.show{display:block}.pj-error.show{display:block!important}@media (max-width:768px){.room-body{flex-direction:column}.video-sidebar{border-top:1px solid #e0e5e3;border-left:none;flex-direction:row;width:100%;min-width:100%;height:140px;min-height:140px;overflow:auto hidden}.video-tile{min-width:160px;min-height:100%}.room-sidebar-panel{border-top:1px solid #e0e5e3;border-left:none;width:100%;min-width:100%;max-height:40vh}}@keyframes recPulse{0%,to{opacity:1}50%{opacity:.35}}@keyframes panelUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes pulseBadge{0%,to{opacity:1}50%{opacity:.65}}#participantCount.has-waiting{background:var(--color-warning);animation:2s infinite pulseBadge}.video-grid-container.participant-count-1{grid-template-rows:1fr;grid-template-columns:1fr}.video-grid-container.participant-count-2{grid-template-rows:1fr;grid-template-columns:repeat(2,1fr)}.video-grid-container.participant-count-3,.video-grid-container.participant-count-4{grid-template-rows:repeat(2,1fr);grid-template-columns:repeat(2,1fr)}.video-grid-container.participant-count-3 .participant-tile:nth-child(3){grid-column:1/-1;justify-self:center;width:50%}.video-grid-container.participant-count-5,.video-grid-container.participant-count-6{grid-template-rows:repeat(2,1fr);grid-template-columns:repeat(3,1fr)}.video-grid-container.participant-count-5 .participant-tile:nth-child(5){grid-column:2/3}.video-grid-container.participant-count-7,.video-grid-container.participant-count-8,.video-grid-container.participant-count-9{grid-template-rows:repeat(3,1fr);grid-template-columns:repeat(3,1fr)}.video-grid-container.participant-count-7 .participant-tile:nth-child(7){grid-column:2/3}.video-grid-container.participant-count-10,.video-grid-container.participant-count-11,.video-grid-container.participant-count-12{grid-template-rows:repeat(3,1fr);grid-template-columns:repeat(4,1fr)}.video-grid-container.participant-count-13,.video-grid-container.participant-count-14,.video-grid-container.participant-count-15,.video-grid-container.participant-count-16{grid-template-rows:repeat(4,1fr);grid-template-columns:repeat(4,1fr)}.video-grid-container.participant-count-20{grid-template-rows:repeat(4,1fr);grid-template-columns:repeat(5,1fr)}.video-grid-container.participant-count-25{grid-template-rows:repeat(5,1fr);grid-template-columns:repeat(5,1fr)}@media (min-width:1024px){.pj-content{flex-direction:row;align-items:center;gap:2.5rem}.pj-form-section{flex-shrink:0;margin:0}}@media (max-width:640px){.cards{flex-direction:column}.hero-title{font-size:1.75rem}.features{flex-direction:column;align-items:center;gap:1rem}.header{padding:.75rem 1rem}.panel-float{width:auto;max-height:55vh;bottom:4.5rem;left:.5rem;right:.5rem}#participantsPanel,#chatPanel{width:auto}.video-grid-container{gap:.375rem;padding:.375rem}.participant-tile{min-height:100px}.video-grid-container.participant-count-5,.video-grid-container.participant-count-6,.video-grid-container.participant-count-7,.video-grid-container.participant-count-8,.video-grid-container.participant-count-9{grid-template-columns:repeat(2,1fr)}#presentationModeContainer{flex-direction:column}.presentation-filmstrip{border-top:1px solid #e0e5e3;border-left:none;flex-direction:row;width:100%;min-width:100%;height:120px;min-height:120px;overflow:auto hidden}.presentation-filmstrip .participant-tile{width:140px;min-width:140px;height:100%}}.participants-list::-webkit-scrollbar{width:4px}.chat-messages::-webkit-scrollbar{width:4px}.participants-list::-webkit-scrollbar-track{background:0 0}.chat-messages::-webkit-scrollbar-track{background:0 0}.participants-list::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}.chat-messages::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}.video-tile{aspect-ratio:16/9;min-height:unset;width:100%;height:auto}.video-tile.audio-only{aspect-ratio:16/9;min-height:unset}#videoSidebar.video-grid-container{box-sizing:border-box;align-content:center;justify-items:center;gap:.5rem;width:100%;height:100%;min-height:0;padding:.75rem;display:grid}#videoSidebar.participant-count-1{grid-template-columns:1fr}#videoSidebar.participant-count-2,#videoSidebar.participant-count-3,#videoSidebar.participant-count-4{grid-template-columns:repeat(2,1fr)}#videoSidebar.participant-count-5,#videoSidebar.participant-count-6,#videoSidebar.participant-count-7,#videoSidebar.participant-count-8,#videoSidebar.participant-count-9{grid-template-columns:repeat(3,1fr)}#videoSidebar .video-tile{width:100%;max-width:100%}#videoSidebar.participant-count-1 .video-tile{max-width:960px}@media (max-width:640px){#videoSidebar.participant-count-3,#videoSidebar.participant-count-4,#videoSidebar.participant-count-5,#videoSidebar.participant-count-6,#videoSidebar.participant-count-7,#videoSidebar.participant-count-8,#videoSidebar.participant-count-9{grid-template-columns:repeat(2,1fr)}}@media (min-width:641px) and (max-width:1024px){#videoSidebar.participant-count-5,#videoSidebar.participant-count-6,#videoSidebar.participant-count-7,#videoSidebar.participant-count-8,#videoSidebar.participant-count-9{grid-template-columns:repeat(3,1fr)}}#appContainer{height:100dvh}body.mobile-speaker-mode{width:100%;height:100dvh;position:fixed;overflow:hidden}#selfViewPip{z-index:35;cursor:grab;background:#0b2e28;border:2px solid #fff3;border-radius:8px;width:120px;height:90px;transition:width .2s,height .2s;display:none;position:fixed;bottom:5.5rem;right:.75rem;overflow:hidden;box-shadow:0 4px 12px #0000004d}#selfViewPip video{object-fit:cover;width:100%;height:100%;transform:scaleX(-1)}#selfViewPip .pip-label{color:#fff;background:linear-gradient(#0000,#0009);padding:2px 6px;font-size:.625rem;font-weight:600;position:absolute;bottom:0;left:0;right:0}#selfViewPip .pip-avatar{color:#fff;background:#0b2e28;justify-content:center;align-items:center;width:100%;height:100%;font-size:1.5rem;font-weight:700;display:flex}#selfViewPip.expanded{width:180px;height:135px}@media (max-width:640px){#appContainer{height:100dvh;padding-bottom:env(safe-area-inset-bottom,0px)}#videoArea{flex:1;position:relative}body.mobile-speaker-mode #gridModeContainer{flex-direction:column;height:100%;display:flex}body.mobile-speaker-mode #videoSidebar{display:none!important}body.mobile-speaker-mode #presentationModeContainer{flex:1;display:flex!important}body.mobile-speaker-mode .presentation-main-stage{background:#0b2e28;padding:0}body.mobile-speaker-mode .presentation-main-stage video{object-fit:cover;width:100%;height:100%}body.mobile-speaker-mode #mainVideo{background:#0b2e28;border-radius:0;width:100%;height:100%;margin:0}body.mobile-speaker-mode #mainVideo video{object-fit:cover}body.mobile-speaker-mode .presentation-filmstrip{display:none}body.mobile-speaker-mode #selfViewPip{display:block}.controls-bar{padding-bottom:calc(.625rem + env(safe-area-inset-bottom,0px))}.ctrl-left{display:none}.ctrl-center{flex:1;justify-content:center}.ctrl-right{flex:0}.ctrl-btn{width:40px;height:40px}.ctrl-btn svg{width:18px;height:18px}#hostControls>div{gap:.25rem!important}.panel-float{width:auto;max-height:55vh;bottom:4.5rem;left:.5rem;right:.5rem}#waitingRoom{padding-bottom:env(safe-area-inset-bottom,0px)}}@media (min-width:641px){#selfViewPip{display:none!important}}.video-tile.active-speaker{border-color:#16a34a;box-shadow:0 0 0 2px #16a34a4d}@media (max-width:640px){body.mobile-speaker-mode #mainVideo video,body.mobile-speaker-mode .presentation-main-stage video{background:#0b2e28;object-fit:contain!important}input,textarea,select{font-size:16px!important}.panel-float{left:calc(.5rem + env(safe-area-inset-left,0px));right:calc(.5rem + env(safe-area-inset-right,0px));max-height:50vh}.panel-float .participants-list,.panel-float .chat-messages{-webkit-overflow-scrolling:touch;flex:1;max-height:none;overflow-y:auto}.chat-input-bar{flex-shrink:0}}.pj-form-section{padding-left:1rem;padding-right:1rem}#joinModal{z-index:50!important;background:#f4f6f5!important;position:fixed!important;inset:0!important}#joinModal .pj-container{justify-content:center;align-items:center;min-height:100vh}#joinModal .pj-content{justify-content:center;align-items:center}#joinModal .pj-form-section{width:100%;max-width:420px}html,body{background:#f4f6f5!important}@media (min-width:641px){#videoSidebar.video-grid-container{align-content:stretch;height:100%}#videoSidebar .video-tile{aspect-ratio:unset;height:100%;min-height:0}#videoSidebar.participant-count-1,#videoSidebar.participant-count-2{grid-template-rows:1fr}#videoSidebar.participant-count-3,#videoSidebar.participant-count-4{grid-template-rows:repeat(2,1fr)}#videoSidebar .video-tile video{object-fit:contain;background:#0b2e28}}@property --tw-rotate-x{syntax:"*";inherits:false;initial-value:rotateX(0)}@property --tw-rotate-y{syntax:"*";inherits:false;initial-value:rotateY(0)}@property --tw-rotate-z{syntax:"*";inherits:false;initial-value:rotateZ(0)}@property --tw-skew-x{syntax:"*";inherits:false;initial-value:skewX(0)}@property --tw-skew-y{syntax:"*";inherits:false;initial-value:skewY(0)}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}@property --tw-ease{syntax:"*";inherits:false}