@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/2c55a0e60120577a-s.2a48534a.woff2)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/9c72aa0f40e4eef8-s.18a48cbc.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/ad66f9afd8947f86-s.7a40eb73.woff2)format("woff2");unicode-range:U+1F??}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/5476f68d60460930-s.c995e352.woff2)format("woff2");unicode-range:U+370-377,U+37A-37F,U+384-38A,U+38C,U+38E-3A1,U+3A3-3FF}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/2bbe8d2671613f1f-s.76dcb0b2.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/1bffadaabf893a1e-s.7cd81963.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}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/83afe278b6a6bb3c-s.p.3a6ba036.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 Fallback;src:local(Arial);ascent-override:90.44%;descent-override:22.52%;line-gap-override:0.0%;size-adjust:107.12%}.inter_7b064e0d-module__MOT0tq__className{font-family:Inter,Inter Fallback;font-style:normal}.inter_7b064e0d-module__MOT0tq__variable{--font-inter:"Inter","Inter Fallback"}
@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:100 800;font-display:swap;src:url(../media/13bf9871fe164e7f-s.f2220059.woff2)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:100 800;font-display:swap;src:url(../media/cc545e633e20c56d-s.f6f1950f.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:100 800;font-display:swap;src:url(../media/71b036adf157cdcf-s.bd5f4d11.woff2)format("woff2");unicode-range:U+370-377,U+37A-37F,U+384-38A,U+38C,U+38E-3A1,U+3A3-3FF}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:100 800;font-display:swap;src:url(../media/89b21bb081cb7469-s.51c18f09.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:100 800;font-display:swap;src:url(../media/3fe682a82f50d426-s.23358719.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}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:100 800;font-display:swap;src:url(../media/70bc3e132a0a741e-s.p.15008bfb.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:JetBrains Mono Fallback;src:local(Arial);ascent-override:75.79%;descent-override:22.29%;line-gap-override:0.0%;size-adjust:134.59%}.jetbrains_mono_9a2f2d6c-module__wsyXyG__className{font-family:JetBrains Mono,JetBrains Mono Fallback;font-style:normal}.jetbrains_mono_9a2f2d6c-module__wsyXyG__variable{--font-mono:"JetBrains Mono","JetBrains Mono Fallback"}
@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:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-ordinal:initial;--tw-slashed-zero:initial;--tw-numeric-figure:initial;--tw-numeric-spacing:initial;--tw-numeric-fraction:initial;--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-backdrop-blur:initial;--tw-backdrop-brightness:initial;--tw-backdrop-contrast:initial;--tw-backdrop-grayscale:initial;--tw-backdrop-hue-rotate:initial;--tw-backdrop-invert:initial;--tw-backdrop-opacity:initial;--tw-backdrop-saturate:initial;--tw-backdrop-sepia:initial;--tw-ease:initial}}}@layer theme{:root,:host{--font-mono:var(--font-mono);--spacing:.25rem;--radius-sm:.25rem;--radius-md:.375rem;--radius-lg:.5rem;--radius-xl:.75rem;--radius-2xl:1rem;--shadow-sm:0 1px 3px 0 #0000001a,0 1px 2px -1px #0000001a;--shadow-md:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a;--shadow-xl:0 20px 25px -5px #0000001a,0 8px 10px -6px #0000001a;--ease-out:cubic-bezier(0,0,.2,1);--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-inter);--default-mono-font-family:var(--font-mono)}}@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;-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}::-webkit-calendar-picker-indicator{line-height:1}:-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}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.static{position:static}.start{inset-inline-start:var(--spacing)}.end{inset-inline-end:var(--spacing)}.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}.inline{display:inline}.inline-block{display:inline-block}.inline-flex{display:inline-flex}.table{display:table}.flex-shrink-0{flex-shrink:0}.grow{flex-grow:1}.transform{transform:var(--tw-rotate-x,)var(--tw-rotate-y,)var(--tw-rotate-z,)var(--tw-skew-x,)var(--tw-skew-y,)}.cursor-move{cursor:move}.resize{resize:both}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.border{border-style:var(--tw-border-style);border-width:1px}.capitalize{text-transform:capitalize}.lowercase{text-transform:lowercase}.uppercase{text-transform:uppercase}.italic{font-style:italic}.tabular-nums{--tw-numeric-spacing:tabular-nums;font-variant-numeric:var(--tw-ordinal,)var(--tw-slashed-zero,)var(--tw-numeric-figure,)var(--tw-numeric-spacing,)var(--tw-numeric-fraction,)}.underline{text-decoration-line:underline}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.blur{--tw-blur:blur(8px);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,)}.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,)}.backdrop-filter{-webkit-backdrop-filter:var(--tw-backdrop-blur,)var(--tw-backdrop-brightness,)var(--tw-backdrop-contrast,)var(--tw-backdrop-grayscale,)var(--tw-backdrop-hue-rotate,)var(--tw-backdrop-invert,)var(--tw-backdrop-opacity,)var(--tw-backdrop-saturate,)var(--tw-backdrop-sepia,);backdrop-filter:var(--tw-backdrop-blur,)var(--tw-backdrop-brightness,)var(--tw-backdrop-contrast,)var(--tw-backdrop-grayscale,)var(--tw-backdrop-hue-rotate,)var(--tw-backdrop-invert,)var(--tw-backdrop-opacity,)var(--tw-backdrop-saturate,)var(--tw-backdrop-sepia,)}.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,display,content-visibility,overlay,pointer-events;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)}.ease-out{--tw-ease:var(--ease-out);transition-timing-function:var(--ease-out)}}:root{--bg-base:#09090b;--bg-surface:#111116;--bg-elevated:#18181f;--bg-card:#1e1e28;--bg-overlay:#25252f;--bg-highlight:#2a2a38;--surface-card:#1e1e28;--bg-primary:#18181f;--bg-secondary:#111116;--bg-hover:#25252f;--primary-50:#eef2ff;--primary-100:#e0e7ff;--primary-200:#c7d2fe;--primary-300:#a5b4fc;--primary-400:#818cf8;--primary-500:#6366f1;--primary-600:#4f46e5;--primary-700:#4338ca;--primary-800:#3730a3;--primary-900:#312e81;--accent-400:#c084fc;--accent-500:#a855f7;--accent-600:#9333ea;--text-primary:#f4f4f8;--text-secondary:#a1a1b5;--text-muted:#6b6b80;--text-disabled:#4a4a58;--text-inverse:#09090b;--border-subtle:#ffffff0f;--border-default:#ffffff1a;--border-strong:#ffffff2e;--border-primary:#6366f166;--success-400:#4ade80;--success-500:#22c55e;--success-bg:#22c55e1f;--warning-400:#facc15;--warning-500:#eab308;--warning-bg:#eab3081f;--error-400:#f87171;--error-500:#ef4444;--error-bg:#ef44441f;--info-400:#60a5fa;--info-500:#3b82f6;--info-bg:#3b82f61f;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:20px;--space-6:24px;--space-8:32px;--space-10:40px;--space-12:48px;--space-16:64px;--space-20:80px;--radius-sm:6px;--radius-md:10px;--radius-lg:14px;--radius-xl:20px;--radius-2xl:28px;--radius-full:9999px;--shadow-sm:0 1px 3px #0006,0 1px 2px #0000004d;--shadow-md:0 4px 16px #00000080,0 2px 6px #0000004d;--shadow-lg:0 12px 40px #0009,0 4px 16px #0006;--shadow-xl:0 24px 64px #000000b3;--shadow-primary:0 0 20px #6366f159,0 4px 16px #6366f133;--shadow-glow:0 0 40px #6366f140;--transition-fast:.12s ease;--transition-base:.2s ease;--transition-slow:.35s cubic-bezier(.4,0,.2,1);--transition-spring:.4s cubic-bezier(.34,1.56,.64,1);--z-dropdown:200;--z-sticky:300;--z-drawer:400;--z-modal:500;--z-toast:600;--z-tooltip:700}*,:before,:after{box-sizing:border-box}html{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark}body{background:var(--bg-base);color:var(--text-primary);font-family:var(--font-inter,"Inter",system-ui,-apple-system,sans-serif);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100svh;font-size:15px;line-height:1.6}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--bg-highlight);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}*{scrollbar-width:thin;scrollbar-color:var(--bg-highlight)transparent}:focus-visible{outline:2px solid var(--primary-400);outline-offset:2px;border-radius:var(--radius-sm)}::selection{color:var(--text-primary);background:#6366f14d}h1{letter-spacing:-.02em;font-size:2.25rem;font-weight:700;line-height:1.15}h2{letter-spacing:-.015em;font-size:1.75rem;font-weight:700;line-height:1.2}h3{font-size:1.375rem;font-weight:600;line-height:1.3}h4{font-size:1.125rem;font-weight:600;line-height:1.4}h5{font-size:1rem;font-weight:600}h6{font-size:.875rem;font-weight:600}p{color:var(--text-secondary)}a{color:var(--primary-400);transition:color var(--transition-fast);text-decoration:none}a:hover{color:var(--primary-300)}.btn{justify-content:center;align-items:center;gap:var(--space-2);border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-base),color var(--transition-base),border-color var(--transition-base),box-shadow var(--transition-base),transform var(--transition-fast);-webkit-user-select:none;user-select:none;white-space:nowrap;border:1px solid #0000;padding:10px 20px;font-family:inherit;font-size:.9rem;font-weight:500;text-decoration:none;display:inline-flex;position:relative;overflow:hidden}.btn:active:not(:disabled){transform:scale(.975)}.btn:disabled,.btn[aria-disabled=true]{opacity:.45;cursor:not-allowed;pointer-events:none}.btn-primary{background:linear-gradient(135deg,var(--primary-500),var(--primary-600));color:#fff;border-color:var(--primary-600);box-shadow:var(--shadow-primary)}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,var(--primary-400),var(--primary-500));box-shadow:var(--shadow-glow),var(--shadow-primary);transform:translateY(-1px)}.btn-outline{color:var(--primary-400);border-color:var(--border-primary);background:0 0}.btn-outline:hover:not(:disabled){border-color:var(--primary-400);background:#6366f114}.btn-ghost{color:var(--text-secondary);background:0 0;border-color:#0000}.btn-ghost:hover:not(:disabled){background:var(--bg-overlay);color:var(--text-primary)}.btn-danger{background:linear-gradient(135deg,var(--error-500),#dc2626);color:#fff;border-color:var(--error-500)}.btn-danger:hover:not(:disabled){background:linear-gradient(135deg,var(--error-400),var(--error-500));box-shadow:0 0 16px #ef444459}.btn-sm{border-radius:var(--radius-sm);padding:6px 14px;font-size:.8rem}.btn-lg{border-radius:var(--radius-lg);padding:14px 28px;font-size:1rem}.btn-xl{border-radius:var(--radius-lg);padding:16px 36px;font-size:1.05rem}.btn-icon{width:40px;height:40px;padding:10px}.btn-icon.btn-sm{width:32px;height:32px;padding:7px}.btn-loading{pointer-events:none;opacity:.8}.btn-loading .btn-text{opacity:0}.btn-loading:after{content:"";border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:16px;height:16px;animation:.65s linear infinite spin;position:absolute}.input-group{gap:var(--space-2);flex-direction:column;display:flex}.input-label{color:var(--text-secondary);letter-spacing:.01em;font-size:.85rem;font-weight:500}.input-label .required{color:var(--error-400);margin-left:3px}.input-wrapper{align-items:center;display:flex;position:relative}.input{background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-md);width:100%;color:var(--text-primary);transition:border-color var(--transition-base),background var(--transition-base),box-shadow var(--transition-base);outline:none;padding:11px 14px;font-family:inherit;font-size:.925rem}.input::placeholder{color:var(--text-muted)}.input:hover:not(:disabled):not(:focus){border-color:var(--border-strong);background:var(--bg-card)}.input:focus{border-color:var(--primary-400);background:var(--bg-card);box-shadow:0 0 0 3px #6366f126}.input.input-error{border-color:var(--error-500);box-shadow:0 0 0 3px #ef44441f}.input:disabled{opacity:.5;cursor:not-allowed}.input-with-icon-left{padding-left:42px}.input-with-icon-right{padding-right:42px}.input-icon{color:var(--text-muted);pointer-events:none;align-items:center;display:flex;position:absolute;top:50%;transform:translateY(-50%)}.input-icon-left{left:14px}.input-icon-right{pointer-events:auto;cursor:pointer;right:14px}.input-icon-right:hover{color:var(--text-secondary)}.input-helper{color:var(--text-muted);font-size:.8rem}select option{background:var(--bg-elevated);color:var(--text-primary)}.input-error-msg{color:var(--error-400);align-items:center;gap:4px;font-size:.8rem;display:flex}.card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);padding:var(--space-6);transition:border-color var(--transition-base),box-shadow var(--transition-base),transform var(--transition-base)}.card:not(:focus-within):hover{border-color:var(--border-default);transform:translateY(-2px);box-shadow:0 6px 24px #00000038}.card-elevated{background:var(--bg-elevated);border-color:var(--border-default);box-shadow:var(--shadow-md)}.card-glass{-webkit-backdrop-filter:blur(24px);border:1px solid var(--border-subtle);background:#1e1e28b3}.card-interactive{cursor:pointer;transition:transform var(--transition-base),box-shadow var(--transition-base),border-color var(--transition-base),background var(--transition-base)}.card-interactive:hover{box-shadow:var(--shadow-lg);border-color:var(--border-primary);transform:translateY(-2px)}.card-interactive:active{transition-duration:80ms;transform:scale(.97)}.card-interactive.selected{border-color:var(--primary-500);box-shadow:0 0 0 3px #6366f133,var(--shadow-md);background:#6366f10f}.dash-action-card .dash-action-icon{transition:transform .22s cubic-bezier(.34,1.56,.64,1),box-shadow .22s}.dash-action-card:hover .dash-action-icon{transform:scale(1.18)rotate(-4deg);box-shadow:0 6px 18px #00000040}.dash-action-card .dash-action-arrow{align-items:center;transition:transform .18s,opacity .18s;display:inline-flex}.dash-action-card:hover .dash-action-arrow{transform:translate(4px)}.dash-action-card:active .dash-action-icon{transform:scale(1.05)}.badge{border-radius:var(--radius-full);letter-spacing:.02em;border:1px solid #0000;align-items:center;gap:4px;padding:3px 10px;font-size:.75rem;font-weight:500;display:inline-flex}.badge-primary{color:var(--primary-300);background:#6366f12e;border-color:#6366f140}.badge-purple{color:var(--accent-400);background:#a855f72e;border-color:#a855f740}.badge-success{background:var(--success-bg);color:var(--success-400);border-color:#22c55e40}.badge-warning{background:var(--warning-bg);color:var(--warning-400);border-color:#eab30840}.badge-error{background:var(--error-bg);color:var(--error-400);border-color:#ef444440}.badge-info{background:var(--info-bg);color:var(--info-400);border-color:#3b82f640}.badge-muted{background:var(--bg-overlay);color:var(--text-muted);border-color:var(--border-default)}.badge-admin{color:#fbbf24;background:#fbbf2426;border-color:#fbbf2440}.badge-member{color:#34d399;background:#34d39926;border-color:#34d39940}.badge-teacher{color:var(--primary-300);background:#6366f12e;border-color:#6366f14d}.badge-student{color:var(--accent-400);background:#a855f726;border-color:#a855f740}.badge-guest{background:var(--bg-overlay);color:var(--text-muted);border-color:var(--border-default)}.avatar{letter-spacing:.02em;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-weight:600;display:inline-flex;position:relative;overflow:hidden}.avatar img{object-fit:cover;width:100%;height:100%}.avatar-xs{width:24px;height:24px;font-size:.65rem}.avatar-sm{width:32px;height:32px;font-size:.75rem}.avatar-md{width:40px;height:40px;font-size:.875rem}.avatar-lg{width:56px;height:56px;font-size:1.1rem}.avatar-xl{width:72px;height:72px;font-size:1.4rem}.avatar-2xl{width:96px;height:96px;font-size:1.8rem}.avatar-gradient-1{color:#fff;background:linear-gradient(135deg,#6366f1,#8b5cf6)}.avatar-gradient-2{color:#fff;background:linear-gradient(135deg,#06b6d4,#6366f1)}.avatar-gradient-3{color:#fff;background:linear-gradient(135deg,#f59e0b,#ef4444)}.avatar-gradient-4{color:#fff;background:linear-gradient(135deg,#10b981,#06b6d4)}.avatar-gradient-5{color:#fff;background:linear-gradient(135deg,#ec4899,#8b5cf6)}.avatar-online:after{content:"";background:var(--success-500);border:2px solid var(--bg-card);border-radius:50%;width:25%;height:25%;position:absolute;bottom:1px;right:1px}@keyframes skeleton-pulse{0%,to{opacity:.5}50%{opacity:1}}.skeleton{background:linear-gradient(90deg,var(--bg-elevated)25%,var(--bg-overlay)50%,var(--bg-elevated)75%);border-radius:var(--radius-md);background-size:200% 100%;animation:1.5s ease-in-out infinite skeleton-shimmer}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-text{border-radius:var(--radius-sm);height:1em}.skeleton-circle{border-radius:50%}.skeleton-avatar-sm{border-radius:50%;width:32px;height:32px}.skeleton-avatar-md{border-radius:50%;width:40px;height:40px}.skeleton-avatar-lg{border-radius:50%;width:56px;height:56px}.skeleton-card{border-radius:var(--radius-xl);height:160px}.divider{align-items:center;gap:var(--space-4);color:var(--text-muted);font-size:.8rem;display:flex}.divider:before,.divider:after{content:"";background:var(--border-default);flex:1;height:1px}.backdrop{-webkit-backdrop-filter:blur(4px);z-index:var(--z-modal);background:#000000a6;position:fixed;inset:0}.modal-container{padding:var(--space-4);z-index:var(--z-modal);justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--bg-card);border:1px solid var(--border-default);border-radius:var(--radius-2xl);box-shadow:var(--shadow-xl);width:100%;max-width:480px;padding:var(--space-8);animation:modal-pop var(--transition-spring)forwards}.modal-lg{max-width:640px}.modal-sm{max-width:360px}.alert{align-items:flex-start;gap:var(--space-3);padding:var(--space-4);border-radius:var(--radius-lg);border:1px solid #0000;font-size:.875rem;display:flex}.alert-error{background:var(--error-bg);color:var(--error-400);border-color:#ef444440}.alert-success{background:var(--success-bg);color:var(--success-400);border-color:#22c55e40}.alert-warning{background:var(--warning-bg);color:var(--warning-400);border-color:#eab30840}.alert-info{background:var(--info-bg);color:var(--info-400);border-color:#3b82f640}.toast{z-index:var(--z-toast);border-radius:var(--radius-xl);background:var(--bg-elevated);border:1px solid var(--border-primary);color:var(--text-primary);box-shadow:var(--shadow-xl);white-space:nowrap;pointer-events:none;align-items:center;gap:10px;padding:12px 20px;font-size:.875rem;font-weight:500;animation:.25s toast-in;display:flex;position:fixed;bottom:28px;left:50%;transform:translate(-50%)translateY(0)}.toast-info{color:var(--primary-300);border-color:#6366f166}.toast-success{color:var(--success-400);border-color:#22c55e59}.toast-warning{color:var(--warning-400);border-color:#eab30859}@keyframes toast-in{0%{opacity:0;transform:translate(-50%)translateY(12px)}to{opacity:1;transform:translate(-50%)translateY(0)}}.dropdown{background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:var(--space-2);z-index:var(--z-dropdown);min-width:200px;animation:.15s forwards fade-in-down;position:absolute}.dropdown-item{align-items:center;gap:var(--space-3);padding:var(--space-2)var(--space-3);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast);text-align:left;background:0 0;border:none;width:100%;font-family:inherit;font-size:.875rem;display:flex}.dropdown-item:hover{background:var(--bg-overlay);color:var(--text-primary)}.dropdown-item.danger{color:var(--error-400)}.dropdown-item.danger:hover{background:var(--error-bg)}.dropdown-separator{background:var(--border-subtle);height:1px;margin:var(--space-2)0}.progress-bar{background:var(--bg-overlay);border-radius:var(--radius-full);height:4px;overflow:hidden}.progress-fill{background:linear-gradient(90deg,var(--primary-500),var(--accent-500));border-radius:var(--radius-full);height:100%;transition:width .4s cubic-bezier(.4,0,.2,1)}.pill-tag{align-items:center;gap:var(--space-1);border-radius:var(--radius-full);border:1px solid var(--border-default);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-base);-webkit-user-select:none;user-select:none;background:var(--bg-elevated);padding:5px 14px;font-size:.8rem;font-weight:500;display:inline-flex}.pill-tag:hover{border-color:var(--primary-500);color:var(--primary-300);background:#6366f10f}.pill-tag.selected{border-color:var(--primary-500);color:var(--primary-300);background:#6366f12e}.code-input-container{justify-content:center;gap:6px;width:100%;display:flex}.code-input{text-align:center;background:var(--bg-elevated);border:2px solid var(--border-default);border-radius:var(--radius-lg);width:0;min-width:0;height:52px;color:var(--text-primary);caret-color:var(--primary-400);transition:border-color var(--transition-base),box-shadow var(--transition-base),background var(--transition-base);font-size:1.25rem;font-weight:700;font-family:var(--font-mono,"JetBrains Mono",monospace);outline:none;flex:1}.code-input:focus{border-color:var(--primary-400);background:var(--bg-card);box-shadow:0 0 0 4px #6366f12e}.code-input.filled{border-color:var(--primary-500);background:#6366f11a}.sidebar{background:var(--bg-surface);border-right:1px solid var(--border-subtle);width:256px;min-width:256px;height:100svh;z-index:var(--z-sticky);transition:transform var(--transition-slow);flex-direction:column;display:flex;position:fixed;top:0;left:0}.sidebar-logo{align-items:center;gap:var(--space-3);padding:var(--space-5)var(--space-5);border-bottom:1px solid var(--border-subtle);display:flex}.logo-icon{background:linear-gradient(135deg,var(--primary-500),var(--accent-500));border-radius:var(--radius-md);width:36px;height:36px;box-shadow:var(--shadow-primary);flex-shrink:0;justify-content:center;align-items:center;display:flex}.logo-text{background:linear-gradient(135deg,var(--primary-300),var(--accent-400));-webkit-text-fill-color:transparent;letter-spacing:-.02em;white-space:nowrap;text-overflow:ellipsis;-webkit-background-clip:text;background-clip:text;max-width:170px;font-size:.95rem;font-weight:700;overflow:hidden}.sidebar-nav{padding:var(--space-4)var(--space-3);flex:1;overflow-y:auto}.sidebar-section{margin-bottom:var(--space-6)}.sidebar-section-label{text-transform:uppercase;letter-spacing:.08em;color:var(--text-secondary);padding:0 var(--space-3)var(--space-2);font-size:.7rem;font-weight:600}.sidebar-link{align-items:center;gap:var(--space-3);padding:10px var(--space-3);border-radius:var(--radius-md);transition:background var(--transition-fast),color var(--transition-fast),transform var(--transition-fast);color:var(--text-muted);cursor:pointer;transition:all var(--transition-base);text-align:left;background:0 0;border:none;width:100%;font-family:inherit;font-size:.875rem;font-weight:500;text-decoration:none;display:flex}.sidebar-link:hover{background:var(--bg-elevated);color:var(--text-secondary);transform:translate(3px)}.sidebar-link:hover .link-icon{opacity:1;transition:transform var(--transition-fast),opacity var(--transition-fast);transform:scale(1.15)}.sidebar-link.active{color:var(--primary-300);border-left:2px solid var(--primary-500);padding-left:calc(var(--space-3) - 2px);background:#6366f11f}.sidebar-link .link-icon{opacity:.7;flex-shrink:0}.sidebar-link.active .link-icon{opacity:1}.sidebar-link:hover .link-icon{opacity:.9}.sidebar-badge{min-width:20px;height:20px;color:var(--primary-300);letter-spacing:.02em;background:#6366f126;border-radius:9999px;flex-shrink:0;justify-content:center;align-items:center;margin-left:auto;padding:0 6px;font-size:.68rem;font-weight:700;display:flex}.sidebar-link.active .sidebar-badge{color:var(--primary-200);background:#6366f140}.sidebar-footer{padding:var(--space-4)var(--space-3);border-top:1px solid var(--border-subtle)}.topbar{-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border-subtle);height:60px;padding:0 var(--space-6);z-index:var(--z-sticky);transition:left var(--transition-slow);background:#09090bcc;justify-content:space-between;align-items:center;display:flex;position:fixed;top:0;left:256px;right:0}.topbar-mobile{left:0}.topbar-live-indicator{border-radius:var(--radius-full);background:#ef44441a;border:1px solid #ef444433;align-items:center;gap:6px;padding:5px 12px 5px 10px;display:flex}.topbar-live-dot{background:var(--danger-400);border-radius:50%;width:7px;height:7px;animation:2s ease-in-out infinite live-pulse;box-shadow:0 0 6px #ef444480}@keyframes live-pulse{0%,to{opacity:1;transform:scale(1);box-shadow:0 0 6px #ef444480}50%{opacity:.5;transform:scale(.85);box-shadow:0 0 2px #ef444433}}.topbar-live-icon{color:var(--danger-400);animation:3s ease-in-out infinite live-icon-breathe}@keyframes live-icon-breathe{0%,to{opacity:1}50%{opacity:.4}}.topbar-live-text{letter-spacing:.1em;color:var(--danger-400);font-size:.68rem;font-weight:700}.topbar-live-count{border-radius:var(--radius-full);background:var(--danger-500);color:#fff;justify-content:center;align-items:center;min-width:16px;height:16px;padding:0 4px;font-size:.6rem;font-weight:700;display:inline-flex}.topbar-greeting{white-space:nowrap;text-overflow:ellipsis;align-items:center;min-width:0;display:flex;overflow:hidden}.topbar-nav{align-items:center;gap:2px;margin-left:4px;display:flex}.topbar-nav-link{border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;white-space:nowrap;transition:color var(--transition-fast),background var(--transition-fast),transform var(--transition-fast);background:0 0;border:none;align-items:center;gap:5px;padding:6px 10px;font-family:inherit;font-size:.82rem;font-weight:500;text-decoration:none;display:inline-flex}.topbar-nav-link:hover{background:var(--bg-elevated);color:var(--text-primary);transform:translateY(-1px)}.topbar-nav-link:active{transform:scale(.94)}.topbar-nav-link.active{color:var(--primary-300);background:#6366f11f}.topbar-badge{border-radius:var(--radius-full);background:var(--danger-500);color:#fff;justify-content:center;align-items:center;min-width:16px;height:16px;padding:0 4px;font-size:.6rem;font-weight:700;animation:2s ease-in-out infinite pulse;display:inline-flex}@keyframes msg-badge-pop{0%{opacity:0;transform:scale(.4)}60%{opacity:1;transform:scale(1.25)}80%{transform:scale(.92)}to{opacity:1;transform:scale(1)}}.topbar-badge-msg{background:var(--primary-500);animation:.45s cubic-bezier(.34,1.56,.64,1) forwards msg-badge-pop,2s ease-in-out .45s infinite pulse}.topbar-dropdown{background:var(--surface-card);border:1px solid var(--border-default);border-radius:var(--radius-lg);min-width:160px;z-index:var(--z-dropdown);box-shadow:var(--shadow-lg);padding:4px;position:absolute;top:calc(100% + 6px);left:0}.topbar-dropdown-item{border-radius:var(--radius-md);color:var(--text-muted);transition:color var(--transition-fast),background var(--transition-fast);align-items:center;gap:8px;padding:8px 10px;font-size:.82rem;font-weight:500;text-decoration:none;display:flex}.topbar-dropdown-item:hover{background:var(--bg-elevated);color:var(--text-secondary)}.topbar-dropdown-item.active{color:var(--primary-300);background:#6366f11f}.topbar-nav-mobile{display:none}.topbar-dropdown-divider{background:var(--border-subtle);height:1px;margin:4px 0}.topbar-more-dropdown{min-width:200px}.topbar-user-menu-wrapper{margin-left:auto}.topbar-nav-label-mobile{display:none}@media (max-width:600px){.topbar{padding:0 var(--space-2);gap:2px}.topbar-live-indicator{display:none}.topbar-greeting{flex-shrink:1;min-width:0;font-size:.82rem}.topbar-greeting-name,.user-menu-avatar{display:none}.user-menu-name{max-width:90px!important;font-size:.82rem!important;display:inline!important}.user-menu-chevron{display:inline-block!important}.user-menu-btn{min-width:unset;border-radius:var(--radius-sm)!important;gap:4px!important;padding:4px 6px!important}.topbar-user-menu-wrapper{flex-shrink:0;margin-left:0}.topbar-nav-label-desktop,.topbar-nav-label-mobile,.topbar-nav-link{display:none}}@media (max-width:768px){.topbar-nav{display:none}.topbar-nav-mobile{align-items:center;gap:2px;margin-left:4px;display:flex}}.app-layout{min-height:100svh;display:flex}.main-content{padding:var(--space-8);min-height:calc(100svh - 60px);transition:margin-left var(--transition-slow);flex:1;margin-top:60px;margin-left:256px}@media (max-width:768px){.sidebar{transform:translate(-100%)}.sidebar.open{box-shadow:var(--shadow-xl);transform:translate(0)}.topbar{left:0}.main-content{padding:var(--space-4);padding-top:var(--space-4);margin-left:0}#sidebar-close-btn{display:flex!important}#sidebar-toggle{display:flex}}@media (min-width:769px){#sidebar-toggle{display:none}}.auth-page{min-height:100svh;padding:var(--space-6);justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.auth-bg-glow{pointer-events:none;background:radial-gradient(circle,#6366f11f 0%,#0000 70%);width:600px;height:600px;position:absolute;top:-200px;left:50%;transform:translate(-50%)}.auth-bg-glow-bottom{pointer-events:none;background:radial-gradient(circle,#a855f714 0%,#0000 70%);width:400px;height:400px;position:absolute;bottom:-100px;right:-100px}.auth-card{background:var(--bg-card);border:1px solid var(--border-default);border-radius:var(--radius-2xl);width:100%;max-width:420px;padding:var(--space-8);box-shadow:var(--shadow-xl);z-index:1;animation:.4s cubic-bezier(.4,0,.2,1) forwards slide-up;position:relative}.auth-logo{align-items:center;gap:var(--space-3);margin-bottom:var(--space-6);flex-direction:column;display:flex}.auth-logo-icon{background:linear-gradient(135deg,var(--primary-500),var(--accent-500));border-radius:var(--radius-xl);width:52px;height:52px;box-shadow:var(--shadow-primary);justify-content:center;align-items:center;display:flex}.auth-logo-name{background:linear-gradient(135deg,var(--primary-300),var(--accent-400));-webkit-text-fill-color:transparent;letter-spacing:-.03em;-webkit-background-clip:text;background-clip:text;font-size:1.5rem;font-weight:800}.auth-title{color:var(--text-primary);text-align:center;margin-bottom:var(--space-1);font-size:1.4rem;font-weight:700}.auth-subtitle{color:var(--text-muted);text-align:center;margin-bottom:var(--space-6);font-size:.875rem}.onboard-page{min-height:100svh;padding:var(--space-6);flex-direction:column;justify-content:center;align-items:center;display:flex}.onboard-card{width:100%;max-width:620px}.role-card{align-items:center;gap:var(--space-3);padding:var(--space-6);background:var(--bg-elevated);border:2px solid var(--border-default);border-radius:var(--radius-xl);cursor:pointer;transition:all var(--transition-base);text-align:center;flex-direction:column;display:flex}.role-card:hover{border-color:var(--primary-500);box-shadow:var(--shadow-lg);background:#6366f10d;transform:translateY(-3px)}.role-card.selected{border-color:var(--primary-500);box-shadow:0 0 0 4px #6366f126,var(--shadow-md);background:#6366f11a;transform:translateY(-2px)}.role-card-icon{border-radius:var(--radius-lg);width:56px;height:56px;margin-bottom:var(--space-1);justify-content:center;align-items:center;font-size:1.75rem;display:flex}@keyframes speaker-ring{0%,to{opacity:.6;transform:scale(1)}50%{opacity:1;transform:scale(1.06)}}.speaker-ring{box-shadow:0 0 0 3px var(--primary-400),0 0 0 6px #6366f140;animation:1.2s ease-in-out infinite speaker-ring}@keyframes spin{to{transform:rotate(360deg)}}@keyframes slide-up{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes fade-in-down{0%{opacity:0;transform:translateY(-8px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes modal-pop{0%{opacity:0;transform:scale(.94)translateY(12px)}to{opacity:1;transform:scale(1)translateY(0)}}@keyframes stagger-in{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{50%{opacity:.5}}@keyframes pulse-glow{0%,to{opacity:1;text-shadow:0 0 12px #22c55e66,0 0 24px #22c55e33}50%{opacity:.8;text-shadow:0 0 20px #22c55e99,0 0 32px #22c55e4d}}.animate-slide-up{animation:.4s cubic-bezier(.4,0,.2,1) both slide-up}.animate-fade-in{animation:.3s both fade-in}.animate-modal-pop{animation:modal-pop var(--transition-spring)both}.stagger-item{opacity:0;animation:.4s cubic-bezier(.4,0,.2,1) both stagger-in}.stagger-item:first-child{animation-delay:0s}.stagger-item:nth-child(2){animation-delay:60ms}.stagger-item:nth-child(3){animation-delay:.12s}.stagger-item:nth-child(4){animation-delay:.18s}.stagger-item:nth-child(5){animation-delay:.24s}.stagger-item:nth-child(6){animation-delay:.3s}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.001ms!important;animation-duration:.001ms!important;animation-iteration-count:1!important}}.text-primary{color:var(--text-primary)}.text-secondary{color:var(--text-secondary)}.text-muted{color:var(--text-muted)}.text-gradient{background:linear-gradient(135deg,var(--primary-300),var(--accent-400));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.surface{background:var(--bg-surface)}.elevated{background:var(--bg-elevated)}.overlay{background:var(--bg-overlay)}.border-subtle{border:1px solid var(--border-subtle)}.border-default{border:1px solid var(--border-default)}.flex-center{justify-content:center;align-items:center;display:flex}.flex-between{justify-content:space-between;align-items:center;display:flex}.sr-only{clip:rect(0,0,0,0);border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.room-fullscreen{z-index:9999;color:#e4e4e7;background:#0f0f14;flex-direction:column;display:flex;position:fixed;inset:0}.room-spinner{border:3px solid var(--primary-500);border-top-color:#0000;border-radius:50%;width:48px;height:48px;margin:0 auto;animation:.8s linear infinite room-spin}@keyframes room-spin{to{transform:rotate(360deg)}}.room-layout{flex:1;height:100%;display:flex;overflow:hidden}.room-sidebar{background:#18181b;border-right:1px solid #27272a;flex-direction:column;width:280px;min-width:280px;display:flex;overflow:hidden}.room-sidebar-right{border-left:1px solid #27272a;border-right:none}.room-sidebar-header{border-bottom:1px solid #27272a;flex-shrink:0;justify-content:space-between;align-items:center;padding:12px 14px;display:flex}.room-sidebar-body{flex:1;padding:8px;overflow-y:auto}.room-center{flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}.room-topbar{background:#18181b;border-bottom:1px solid #27272a;flex-shrink:0;justify-content:space-between;align-items:center;padding:8px 16px;display:flex}.room-live-dot{background:#ef4444;border-radius:50%;width:8px;height:8px;animation:1.5s ease-in-out infinite live-glow;box-shadow:0 0 6px 2px #ef444480}@keyframes live-glow{0%{transform:scale(1);box-shadow:0 0 6px 2px #ef444480}50%{transform:scale(1.25);box-shadow:0 0 12px 4px #ef4444b3}to{transform:scale(1);box-shadow:0 0 6px 2px #ef444480}}.room-live-badge{color:#22c55e;letter-spacing:.5px;background:#22c55e1f;border-radius:4px;padding:2px 8px;font-size:.65rem;font-weight:700}.room-count-badge{color:#a1a1aa;background:#27272a;border-radius:10px;padding:1px 7px;font-size:.7rem;font-weight:600}.room-icon-btn{color:#a1a1aa;cursor:pointer;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;width:36px;height:36px;transition:all .15s;display:flex}.room-icon-btn:hover{color:#e4e4e7;background:#27272a}.room-icon-btn-sm{border-radius:6px;width:28px;height:28px}.room-participant-card{border-radius:8px;align-items:center;gap:10px;margin-bottom:2px;padding:8px 10px;transition:background .15s;display:flex}.room-participant-card:hover{background:#27272a}.room-participant-spotlight{background:#6366f126;border:1px solid #6366f14d}.room-participant-speaking{box-shadow:0 0 0 2px #22c55e}.room-participant-thumb{background:#27272a;border-radius:8px;flex-shrink:0;width:36px;height:36px;overflow:hidden}.room-participant-avatar{background:linear-gradient(135deg,var(--primary-600),var(--accent-600));color:#fff;justify-content:center;align-items:center;width:100%;height:100%;font-size:.7rem;font-weight:700;display:flex}.room-participant-name{white-space:nowrap;text-overflow:ellipsis;font-size:.82rem;font-weight:500;overflow:hidden}.room-hand-icon{font-size:.9rem;animation:.6s ease-in-out infinite alternate room-hand-wave}@keyframes room-hand-wave{0%{transform:rotate(-10deg)}to{transform:rotate(20deg)}}.room-main-stage{touch-action:manipulation;background:#0f0f14;flex:1;justify-content:center;align-items:center;min-height:0;padding:12px;display:flex;position:relative;overflow:hidden}.room-stage-video{background:#18181b;border-radius:12px;width:100%;height:100%;min-height:0;position:relative;overflow:hidden}.room-stage-speaking{box-shadow:0 0 0 3px #22c55e}.room-stage-screenshare{box-shadow:0 0 0 2px var(--primary-500)}.room-stage-placeholder{flex-direction:column;justify-content:center;align-items:center;width:100%;height:100%;display:flex}.room-stage-avatar{background:linear-gradient(135deg,var(--primary-600),var(--accent-600));color:#fff;border-radius:50%;justify-content:center;align-items:center;width:120px;height:120px;font-size:2.5rem;font-weight:700;display:flex}.room-stage-overlay{pointer-events:none;background:linear-gradient(#0000,#000000b3);padding:12px 16px;position:absolute;bottom:0;left:0;right:0}.room-stage-label{color:#fff;align-items:center;gap:8px;font-size:.85rem;font-weight:500;display:flex}.room-speaking-icon{color:#22c55e;animation:1s infinite room-pulse}.room-chat-messages{flex-direction:column;gap:2px;display:flex}.room-chat-msg{border-radius:8px;padding:8px 12px;transition:background .1s}.room-chat-msg:hover{background:#27272a}.room-chat-msg-header{justify-content:space-between;align-items:center;margin-bottom:2px;display:flex}.room-chat-sender{color:var(--primary-400);font-size:.78rem;font-weight:600}.room-chat-time{color:#52525b;font-size:.68rem}.room-chat-text{color:#d4d4d8;word-break:break-word;font-size:.83rem;line-height:1.4}.room-chat-input{border-top:1px solid #27272a;flex-shrink:0;align-items:center;gap:8px;padding:10px 12px;display:flex}.room-chat-input .input{color:#e4e4e7;background:#27272a;border-color:#3f3f46;flex:1}.room-chat-input .input:focus{border-color:var(--primary-500)}.room-send-btn{color:var(--primary-400)!important}.room-send-btn:disabled{opacity:.3;cursor:not-allowed!important}.room-chat-tabs{align-items:center;gap:2px;display:flex}.room-chat-tab{color:#71717a;cursor:pointer;white-space:nowrap;background:0 0;border:none;border-radius:6px;align-items:center;gap:4px;padding:5px 10px;font-size:.78rem;font-weight:500;transition:all .12s;display:flex}.room-chat-tab:hover{color:#a1a1aa;background:#27272a}.room-chat-tab-active{color:var(--primary-400);background:#6366f126}.room-chat-tab-active:hover{background:#6366f133}.room-controls{background:#18181b;border-top:1px solid #27272a;flex-shrink:0;justify-content:space-between;align-items:center;padding:10px 20px;display:flex}.room-controls-group{align-items:center;gap:4px;display:flex}.room-control-btn{color:#e4e4e7;cursor:pointer;background:#27272a;border:none;border-radius:10px;flex-direction:column;justify-content:center;align-items:center;gap:3px;min-width:64px;padding:8px 14px;transition:all .15s;display:flex;position:relative}.room-control-btn:hover{background:#3f3f46}.room-control-btn-off{color:#f87171;background:#ef444426}.room-control-btn-off:hover{background:#ef444440}.room-control-btn-active{color:var(--primary-400);background:#6366f133}.room-control-btn-active:hover{background:#6366f14d}.room-control-btn-hand{color:#facc15;background:#eab30826}.room-control-btn-hand:hover{background:#eab30840}.room-control-btn-leave{color:#f87171;background:#ef444426}.room-control-btn-leave:hover{color:#fff;background:#ef4444}.room-control-label{letter-spacing:.3px;font-size:.62rem;font-weight:500}.room-hand-badge{color:#0f0f14;background:#facc15;border-radius:50%;justify-content:center;align-items:center;width:18px;height:18px;font-size:.6rem;font-weight:700;display:flex;position:absolute;top:-4px;right:-4px}.room-settings-overlay{z-index:10000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.room-settings-modal{background:#1c1c20;border:1px solid #27272a;border-radius:16px;width:90%;max-width:420px;box-shadow:0 20px 60px #00000080}.room-settings-header{border-bottom:1px solid #27272a;justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.room-settings-body{padding:20px}.room-settings-section{margin-bottom:16px}.room-settings-section:last-child{margin-bottom:0}.room-settings-label{color:#a1a1aa;align-items:center;gap:6px;margin-bottom:8px;font-size:.82rem;font-weight:500;display:flex}.room-settings-body .input{color:#e4e4e7;background:#27272a;border-color:#3f3f46}.room-settings-footer{border-top:1px solid #27272a;justify-content:flex-end;padding:12px 20px;display:flex}.room-sidebar-body::-webkit-scrollbar{width:4px}.room-sidebar-body::-webkit-scrollbar-track{background:0 0}.room-sidebar-body::-webkit-scrollbar-thumb{background:#3f3f46;border-radius:4px}.room-sidebar-body::-webkit-scrollbar-thumb:hover{background:#52525b}.room-mobile-participants{-webkit-overflow-scrolling:touch;scrollbar-width:none;background:#18181b;border-bottom:1px solid #27272a;flex-shrink:0;align-items:center;gap:10px;padding:8px 12px;display:flex;overflow:auto hidden}.room-mobile-participants::-webkit-scrollbar{display:none}.room-mobile-participant{cursor:pointer;border-radius:10px;flex-direction:column;flex-shrink:0;align-items:center;gap:4px;padding:4px;transition:background .15s;display:flex}.room-mobile-participant:hover{background:#27272a}.room-mobile-participant-active{outline:2px solid var(--primary-500);outline-offset:1px;background:#6366f12e}.room-mobile-participant-thumb{background:#27272a;border-radius:50%;flex-shrink:0;width:48px;height:48px;overflow:hidden}.room-mobile-participant-name{color:#a1a1aa;white-space:nowrap;text-overflow:ellipsis;text-align:center;max-width:56px;font-size:.62rem;overflow:hidden}.room-mobile-overlay{z-index:10001;background:#00000080;justify-content:center;align-items:flex-end;display:flex;position:fixed;inset:0}.room-mobile-panel{border-radius:16px 16px 0 0;width:100%;max-height:60vh;overflow:hidden}.room-mobile-panel .room-sidebar{border:none;border-radius:16px 16px 0 0;width:100%;min-width:100%;max-height:60vh}.room-sidebar-mobile{z-index:10001;top:0;bottom:0;right:0;box-shadow:-10px 0 30px #00000080;width:85%!important;min-width:85%!important;max-width:320px!important;position:fixed!important}.room-mobile-overlay-bg{z-index:-1;background:#00000080;position:fixed;inset:0}.room-controls-mobile{-webkit-overflow-scrolling:touch;scrollbar-width:none;justify-content:flex-start;gap:4px;padding:8px 12px;overflow-x:auto}.room-controls-mobile::-webkit-scrollbar{display:none}.room-controls-mobile .room-controls-group{flex-shrink:0}.room-controls-mobile .room-control-btn{min-width:unset;border-radius:50%;flex-shrink:0;width:44px;height:44px;padding:10px 12px}.room-controls-mobile .room-control-btn-leave{border-radius:50%;width:44px;height:44px;padding:0}@media (max-width:767px){.room-layout{flex-direction:column}.room-sidebar-left{display:none}.room-topbar{padding:6px 10px}.room-topbar span{font-size:.82rem!important}.room-main-stage{padding:4px}.room-stage-layer{border-radius:0;inset:0;width:100%!important;height:100%!important}.room-stage-blackboard{box-shadow:none}.room-stage-video{border-radius:0}.room-stage-avatar{width:80px;height:80px;font-size:1.8rem}.room-bb-toolbar{flex-direction:column-reverse;left:8px;right:8px}.room-bb-toolbar-inner{-webkit-overflow-scrolling:touch;scrollbar-width:none;gap:2px;width:100%;max-width:100%;padding:4px 8px;overflow-x:auto}.room-bb-toolbar-inner::-webkit-scrollbar{display:none}.room-bb-tool-btn{border-radius:6px;width:28px;height:28px}.room-bb-size-btn{width:26px;height:26px}.room-bb-divider{height:18px;margin:0 2px}.room-bb-toolbar-inner .room-bb-color-picker,.room-bb-toolbar-inner .room-bb-size-picker{display:none}}.room-blackboard{background:#1a1a2e;width:100%;max-width:calc(177.778vh - 213.333px);height:100%;max-height:56.25vw;margin:auto;position:relative;overflow:hidden}.room-blackboard canvas{display:block}.room-stage-blackboard{box-shadow:0 0 0 2px var(--primary-500)}.room-stage-hidden{pointer-events:none;visibility:hidden;width:100%!important;height:100%!important;position:absolute!important}.room-stage-layer{inset:12px;width:auto!important;height:auto!important;position:absolute!important}.room-stage-layer-front{pointer-events:auto}.room-stage-layer-back{pointer-events:none}.room-bb-toolbar{z-index:20;flex-direction:column;align-items:flex-start;gap:8px;display:flex;position:absolute;bottom:48px;left:16px}.room-bb-toggle{color:#fff;cursor:pointer;background:#6366f1d9;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;transition:transform .15s,background .15s;display:flex;box-shadow:0 2px 12px #0006}.room-bb-toggle:hover{background:var(--primary-500);transform:scale(1.1)}.room-bb-toolbar-inner{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#18181bf2;border:1px solid #3f3f46;border-radius:12px;flex-wrap:nowrap;align-items:center;gap:4px;max-width:calc(100vw - 80px);padding:6px 10px;display:flex;overflow:visible;box-shadow:0 4px 24px #00000080}@media (max-width:767px){.room-blackboard{max-width:100%;max-height:100%}.room-stage-blackboard{box-shadow:none}.room-bb-toolbar{bottom:8px;left:8px;right:8px}}.room-bb-tool-group{align-items:center;gap:2px;display:flex}.room-bb-tool-btn{color:#a1a1aa;cursor:pointer;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;transition:all .12s;display:flex;position:relative}.room-bb-tool-btn:hover{color:#e4e4e7;background:#3f3f46}.room-bb-tool-active{color:var(--primary-400);background:#6366f133}.room-bb-tool-active:hover{background:#6366f14d}.room-bb-tool-danger:hover{color:#f87171;background:#ef444433}.room-bb-divider{background:#3f3f46;flex-shrink:0;width:1px;height:20px;margin:0 4px}.room-bb-color-dot{border:1px solid #27272a;border-radius:50%;width:8px;height:8px;position:absolute;bottom:2px;right:2px}.room-bb-size-dot{background:#e4e4e7;border-radius:50%;display:inline-block}.room-bb-size-picker{z-index:200;background:#1c1c22;border:1px solid #3f3f46;border-radius:10px;flex-direction:column;gap:2px;min-width:110px;padding:4px;display:flex;position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);box-shadow:0 4px 20px #00000080}.room-bb-size-picker-item{color:var(--text-secondary);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-radius:7px;align-items:center;gap:10px;padding:6px 10px;font-size:.82rem;transition:all .12s;display:flex}.room-bb-size-picker-item:hover{color:var(--text-primary);background:#3f3f46}.room-bb-size-picker-active{color:var(--primary-400);background:#6366f133}.room-bb-size-picker-active:hover{background:#6366f14d}.room-bb-color-picker{background:#18181b;border:1px solid #3f3f46;border-radius:10px;flex-wrap:wrap;gap:4px;width:140px;padding:8px;display:flex;position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);box-shadow:0 4px 16px #0006}.room-bb-color-swatch{cursor:pointer;border:2px solid #0000;border-radius:6px;width:24px;height:24px;transition:transform .1s,border-color .1s}.room-bb-color-swatch:hover{transform:scale(1.15)}.room-bb-color-swatch-active{border-color:#fff;box-shadow:0 0 0 1px #ffffff4d}.room-bb-color-input{cursor:pointer;background:0 0;border:none;border-radius:6px;width:24px;height:24px;padding:0}.room-bb-color-input::-webkit-color-swatch-wrapper{padding:0}.room-bb-color-input::-webkit-color-swatch{border:1px solid #52525b;border-radius:6px}.room-bb-popup-mobile.room-bb-color-picker,.room-bb-popup-mobile.room-bb-size-picker{z-index:10002;position:fixed;bottom:100px;left:50%;transform:translate(-50%)}.room-bb-text-options{gap:4px}.room-bb-select{color:#e4e4e7;cursor:pointer;text-overflow:ellipsis;background:#27272a;border:1px solid #3f3f46;border-radius:6px;max-width:88px;height:26px;padding:2px 4px;font-size:.7rem;overflow:hidden}.room-bb-select:focus{border-color:var(--primary-500);outline:none}.room-bb-fontsize-input{text-align:center;-moz-appearance:textfield;width:52px}.room-bb-fontsize-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.room-bb-fontsize-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.room-bb-cursor{pointer-events:none;z-index:15;background:#6366f1e6;border:2px solid #fff;border-radius:50%;width:14px;height:14px;transition:left 30ms linear,top 30ms linear;animation:1.2s ease-in-out infinite room-bb-cursor-blink;position:absolute;transform:translate(-6px,-6px);box-shadow:0 0 0 3px #6366f14d,0 2px 8px #00000080}@keyframes room-bb-cursor-blink{0%,to{opacity:1}50%{opacity:.5}}.room-bb-caret{pointer-events:none;z-index:16;background:#f59e0b;border-radius:1px;width:3px;animation:1s step-end infinite room-bb-caret-blink;position:absolute;box-shadow:0 0 8px #f59e0bcc,0 0 16px #f59e0b66}@keyframes room-bb-caret-blink{0%,to{opacity:1}50%{opacity:0}}.room-bb-locked-overlay{z-index:18;pointer-events:none;position:absolute;bottom:16px;left:50%;transform:translate(-50%)}.room-bb-locked-indicator{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:var(--text-secondary);background:#18181ed9;border:1px solid #ffffff1a;border-radius:20px;align-items:center;gap:6px;padding:6px 14px;font-size:.78rem;animation:.3s room-bb-locked-fade-in;display:flex;box-shadow:0 2px 12px #0006}@keyframes room-bb-locked-fade-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.room-present-menu{z-index:9999;background:#1c1c22;border:1px solid #3f3f46;border-radius:12px;min-width:220px;max-width:calc(100vw - 32px);max-height:min(400px,100vh - 120px);padding:6px;position:fixed;bottom:80px;left:50%;overflow-y:auto;transform:translate(-50%);box-shadow:0 8px 32px #00000080}.room-present-menu-item{cursor:pointer;color:var(--text-secondary);border-radius:8px;align-items:center;gap:10px;padding:8px 12px;font-size:.85rem;transition:all .12s;display:flex}.room-present-menu-item:hover{color:var(--text-primary);background:#6366f126}.room-present-menu-divider{background:#3f3f46;height:1px;margin:4px 8px}.room-present-menu-label{text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);padding:6px 12px 2px;font-size:.7rem;font-weight:600}.room-present-menu-empty{text-align:center;color:var(--text-muted);padding:16px 12px;font-size:.8rem}.room-bb-text-panel-mobile{z-index:10000;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#18181bf7;border:1px solid #3f3f46;border-radius:12px;flex-direction:column;gap:8px;min-width:180px;max-width:calc(100vw - 16px);padding:10px;display:flex;position:fixed;bottom:200px;left:8px;box-shadow:0 8px 32px #0009}.room-bb-text-panel-title{text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);padding-bottom:2px;font-size:.68rem;font-weight:600}.room-bb-text-panel-row{align-items:center;gap:4px;display:flex}.room-stage-presentation{background:#0f0f14}.room-presentation{flex-direction:column;width:100%;height:100%;min-height:0;display:flex;position:relative}.room-pres-info-trigger{z-index:10;position:absolute;top:10px;left:10px}.room-pres-info-icon{cursor:pointer;width:30px;height:30px;color:var(--text-muted);background:#0f0f14bf;border:1px solid #ffffff1a;border-radius:8px;justify-content:center;align-items:center;transition:color .15s,background .15s;display:flex}.room-pres-info-trigger:hover .room-pres-info-icon{color:var(--text-primary);background:#27272af2}.room-pres-info-panel{background:#121218f7;border:1px solid #27272a;border-radius:10px;flex-direction:column;gap:3px;min-width:210px;max-width:290px;padding:12px;display:flex;position:absolute;top:calc(100% + 6px);left:0;box-shadow:0 8px 24px #0000008c}.room-pres-info-course{color:var(--text-primary);margin-bottom:2px;font-size:.9rem;font-weight:600}.room-pres-info-topic{text-transform:uppercase;letter-spacing:.5px;color:var(--primary-400);font-size:.72rem;font-weight:600}.room-pres-info-lesson{color:var(--text-secondary);font-size:.85rem;font-weight:500}.room-pres-info-counter{color:var(--text-muted);margin-top:2px;font-size:.75rem}.room-pres-info-presenter{color:var(--text-muted);font-size:.75rem}.room-pres-lesson-picker{border-top:1px solid #27272a;flex-direction:column;gap:1px;max-height:200px;margin-top:8px;padding-top:8px;display:flex;overflow-y:auto}.room-pres-picker-topic{text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);padding:4px 6px 2px;font-size:.7rem;font-weight:600}.room-pres-picker-lesson{text-align:left;width:100%;color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:5px 8px;font-size:.82rem;transition:background .12s,color .12s;display:block}.room-pres-picker-lesson:hover{color:var(--text-primary);background:#ffffff12}.room-pres-picker-lesson.active{color:var(--primary-400);background:#6366f126}.room-pres-nav-btn{width:34px;height:34px;color:var(--text-secondary);cursor:pointer;z-index:10;background:#0f0f14bf;border:1px solid #ffffff1a;border-radius:50%;justify-content:center;align-items:center;transition:color .15s,background .15s;display:flex;position:absolute;bottom:10px}.room-pres-nav-btn:hover:not(:disabled){color:var(--text-primary);background:#27272af2}.room-pres-nav-btn:disabled{opacity:.25;cursor:not-allowed}.room-pres-nav-prev{left:10px}.room-pres-nav-next{right:10px}.room-presentation-content{overscroll-behavior:contain;touch-action:pan-y;flex:1;min-height:0;padding:50px 32px 56px;overflow-y:auto}.room-presentation-text{color:var(--text-secondary);font-size:1rem;line-height:1.7}.room-presentation-text h1,.room-presentation-text h2,.room-presentation-text h3{color:var(--text-primary);margin:20px 0 10px}.room-presentation-text p{margin:0 0 12px}.room-presentation-text img{border-radius:8px;max-width:100%;margin:12px 0}.room-presentation-text ul,.room-presentation-text ol{margin:0 0 12px;padding-left:24px}.room-presentation-video{text-align:center;margin:12px 0}.room-presentation-empty{color:var(--text-muted);flex:1;justify-content:center;align-items:center;font-size:.9rem;display:flex}.room-quiz-content{flex-direction:column;gap:24px;display:flex}.room-quiz-question{text-align:center}.room-quiz-question-number{text-transform:uppercase;letter-spacing:.5px;color:var(--primary-400);font-size:.75rem;font-weight:600}.room-quiz-question-text{color:var(--text-primary);margin:8px 0 0;font-size:1.3rem;font-weight:700}.room-quiz-timer{color:var(--text-muted);align-items:center;gap:6px;margin-top:8px;font-size:.8rem;display:inline-flex}.room-quiz-options{flex-direction:column;gap:10px;width:100%;max-width:600px;margin:0 auto;display:flex}.room-quiz-option{cursor:pointer;text-align:left;color:var(--text-secondary);background:#1c1c22;border:2px solid #3f3f46;border-radius:12px;align-items:center;gap:12px;padding:14px 18px;font-size:.95rem;transition:all .15s;display:flex}.room-quiz-option:hover:not(:disabled){border-color:var(--primary-500);background:#6366f114}.room-quiz-option:disabled{cursor:default;opacity:.7}.room-quiz-option-selected{border-color:var(--primary-500);color:var(--text-primary);background:#6366f11f}.room-quiz-option-correct{color:#4ade80;background:#22c55e1f;border-color:#22c55e}.room-quiz-option-wrong{color:#f87171;background:#ef44441f;border-color:#ef4444}.room-quiz-option-label{width:28px;height:28px;color:var(--text-primary);background:#27272a;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;font-size:.8rem;font-weight:700;display:flex}.room-quiz-option-text{flex:1}.room-quiz-option-stats{flex-shrink:0;align-items:center;gap:6px;font-size:.8rem;font-weight:600;display:flex}.room-quiz-waiting{text-align:center;color:var(--text-muted);padding:16px;font-size:.85rem}.room-quiz-progress-bar{background:var(--primary-400);flex-wrap:wrap;gap:6px 12px;padding:6px 16px;display:flex}@supports (color:color-mix(in lab, red, red)){.room-quiz-progress-bar{background:color-mix(in srgb,var(--primary-400),transparent 92%)}}.room-quiz-progress-bar{border-bottom:1px solid var(--border-light);font-size:.78rem}.room-quiz-progress-item{align-items:center;gap:6px;min-width:120px;display:flex}.room-quiz-progress-name{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;max-width:80px;overflow:hidden}.room-quiz-progress-track{background:var(--border-light);border-radius:2px;flex:1;min-width:40px;height:4px;overflow:hidden}.room-quiz-progress-fill{background:var(--primary-400);border-radius:2px;height:100%;transition:width .3s}.room-quiz-progress-count{color:var(--text-muted);white-space:nowrap;align-items:center;gap:3px;display:flex}.room-quiz-progress-submitted{background:var(--success-400)}@supports (color:color-mix(in lab, red, red)){.room-quiz-progress-submitted{background:color-mix(in srgb,var(--success-400),transparent 92%)}}.room-quiz-progress-submitted{border-radius:var(--radius-sm);padding:2px 6px}@keyframes gradeBtnPulse{0%,to{box-shadow:0 0 #6366f166}50%{box-shadow:0 0 0 6px #6366f100}}.room-grade-btn-pulse{animation:2s ease-in-out 3 gradeBtnPulse}@media (max-width:767px){.room-presentation-content{padding:46px 14px 52px}.room-presentation-text,.room-presentation-text p,.room-quiz-question-text,.room-quiz-option-text{overflow-wrap:anywhere;word-break:break-word}.room-quiz-question-text{font-size:1.05rem}.room-quiz-option{gap:8px;padding:11px 12px;font-size:.86rem}.room-bb-toolbar{max-width:calc(100% - 16px);bottom:8px;left:8px;right:8px}.room-bb-toolbar-inner{-webkit-overflow-scrolling:touch;gap:2px;width:100%;max-width:100%;padding:4px 8px;overflow:auto hidden}}.room-quiz-submitted-icon{background:var(--success-100);width:80px;height:80px;color:var(--success-500);border-radius:50%;justify-content:center;align-items:center;animation:.4s ease-out quizSubmitPop;display:flex}@keyframes quizSubmitPop{0%{opacity:0;transform:scale(0)}60%{transform:scale(1.2)}to{opacity:1;transform:scale(1)}}.room-quiz-submitted-pulse{background:var(--primary-400);border-radius:50%;width:12px;height:12px;animation:1.5s ease-in-out infinite quizPulse}@keyframes quizPulse{0%,to{opacity:.3;transform:scale(1)}50%{opacity:1;transform:scale(1.4)}}.room-quiz-join-icon{width:80px;height:80px;color:var(--primary-400);background:#6366f126;border-radius:50%;justify-content:center;align-items:center;animation:.4s ease-out quizSubmitPop;display:flex}.room-quiz-join-info{color:var(--text-muted);align-items:center;gap:8px;font-size:.85rem;display:flex}.room-grading-content{overflow-y:auto;padding:0!important}.room-grading-list{flex-direction:column;gap:6px;display:flex}.room-grading-item-card{border:1px solid var(--border-light);border-radius:10px;transition:border-color .2s;overflow:hidden}.room-grading-item-card:hover{border-color:var(--primary-400)}.room-grading-item{justify-content:space-between;align-items:center;padding:12px 16px;transition:background .15s;display:flex}.room-grading-item:hover{background:var(--hover-bg)}.room-grading-item-graded{opacity:.85}.room-grading-item-info{flex:1;align-items:center;gap:8px;display:flex}.room-grading-item-name{font-size:.9rem;font-weight:600}.room-grading-item-status{font-size:.78rem}.room-grading-status-submitted{color:var(--warning-500)}.room-grading-status-graded{color:var(--success-500);font-weight:600}.room-grading-status-revealed{color:var(--primary-400);font-weight:600}.room-grading-item-actions{align-items:center;gap:8px;display:flex}.room-grading-expand{border-top:1px solid var(--border-light);background:#0000001a;flex-direction:column;gap:12px;padding:12px 16px;display:flex}.room-grading-detail{flex-direction:column;gap:16px;padding:16px;display:flex}.room-grading-detail-header{align-items:center;gap:12px;display:flex}.room-grading-score-badge{border-radius:var(--radius-sm);padding:2px 10px;font-size:.75rem;font-weight:700}.room-grading-score-pass{color:var(--success-400);background:#22c55e26}.room-grading-score-fail{color:var(--error-400);background:#ef444426}.room-grading-summary{flex-direction:column;gap:6px;display:flex}.room-grading-summary-bar{background:var(--bg-tertiary);border-radius:3px;width:100%;height:6px;overflow:hidden}.room-grading-summary-fill{border-radius:3px;height:100%;transition:width .4s}.room-grading-summary-stats{color:var(--text-muted);justify-content:space-between;font-size:.75rem;display:flex}.room-grading-questions{flex-direction:column;gap:12px;display:flex}.room-grading-question{border:1px solid var(--border-light);border-radius:8px;padding:12px}.room-grading-question-correct{border-color:#22c55e4d}.room-grading-question-wrong{border-color:#ef44444d}.room-grading-q-header{align-items:center;gap:8px;margin-bottom:8px;display:flex}.room-grading-q-points{white-space:nowrap;border-radius:4px;padding:1px 6px;font-size:.72rem;font-weight:600}.room-grading-q-points-earned{color:var(--success-400);background:#22c55e1a}.room-grading-q-points-lost{color:var(--error-400);background:#ef44441a}.room-grading-q-points-partial{color:var(--warning-400,#f59e0b);background:#f59e0b1a}.room-grading-correct{color:var(--success-500);font-size:1.1rem;font-weight:700}.room-grading-wrong{color:var(--error-400);font-size:1.1rem;font-weight:700}.room-grading-partial{color:var(--warning-400,#f59e0b);font-size:1.1rem;font-weight:700}.room-grading-question-partial{border-left:3px solid var(--warning-400,#f59e0b)}.room-grading-q-options{flex-direction:column;gap:4px;display:flex}.room-grading-q-opt{background:var(--bg-secondary);border-radius:6px;align-items:center;gap:8px;padding:6px 10px;font-size:.85rem;display:flex}.room-grading-q-opt-correct{background:var(--success-500)}@supports (color:color-mix(in lab, red, red)){.room-grading-q-opt-correct{background:color-mix(in srgb,var(--success-500),transparent 85%)}}.room-grading-q-opt-correct{border-left:3px solid var(--success-500)}.room-grading-q-opt-wrong{background:var(--error-400)}@supports (color:color-mix(in lab, red, red)){.room-grading-q-opt-wrong{background:color-mix(in srgb,var(--error-400),transparent 85%)}}.room-grading-q-opt-wrong{border-left:3px solid var(--error-400)}.room-grading-opt-tag{white-space:nowrap;border-radius:4px;align-items:center;gap:3px;padding:1px 6px;font-size:.68rem;font-weight:600;display:inline-flex}.room-grading-opt-tag-correct{color:var(--success-400);background:#22c55e26}.room-grading-opt-tag-wrong{color:var(--error-400);background:#ef444426}.room-grading-comment{flex-direction:column;gap:6px;display:flex}.room-grading-textarea{border:1px solid var(--border-light);background:var(--bg-secondary);width:100%;color:var(--text-primary);resize:vertical;border-radius:8px;padding:10px 12px;font-family:inherit;font-size:.85rem}.room-grading-textarea:focus{border-color:var(--primary-400);outline:none}.room-grading-actions{justify-content:flex-end;gap:8px;display:flex}.room-grading-pass-toggle{background:var(--bg-secondary);border-radius:8px;align-items:center;gap:8px;margin-bottom:4px;padding:8px 12px;display:flex}.room-grading-pass-toggle label{color:var(--text-secondary);margin-right:4px;font-size:.82rem;font-weight:600}.room-grading-pass-active{color:var(--success-400,#4ade80)!important;border:1px solid var(--success-400,#4ade80)!important;background:#22c55e33!important}.room-grading-fail-active{color:var(--error-400,#f87171)!important;border:1px solid var(--error-400,#f87171)!important;background:#ef444433!important}.room-grading-text-answer{flex-direction:column;gap:10px;display:flex}.room-grading-text-row{flex-direction:column;gap:4px;display:flex}.room-grading-text-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.03em;font-size:.75rem;font-weight:600}.room-grading-text-value{background:var(--bg-secondary);border-left:3px solid var(--border-light);white-space:pre-wrap;word-break:break-word;border-radius:6px;padding:8px 12px;font-size:.88rem}.room-grading-text-correct{border-left-color:var(--success-500);background:var(--success-500)}@supports (color:color-mix(in lab, red, red)){.room-grading-text-correct{background:color-mix(in srgb,var(--success-500),transparent 90%)}}.room-grading-text-wrong{border-left-color:var(--error-400);background:var(--error-400)}@supports (color:color-mix(in lab, red, red)){.room-grading-text-wrong{background:color-mix(in srgb,var(--error-400),transparent 90%)}}.room-grading-text-actions{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.room-grading-score-input{align-items:center;gap:6px;display:flex}.room-grading-pts-input{border:1px solid var(--border-light);background:var(--bg-secondary);width:56px;color:var(--text-primary);text-align:center;border-radius:6px;padding:4px 8px;font-size:.85rem;font-weight:600}.room-quiz-text-input{width:100%;padding:0 16px}.room-quiz-text-area{border:1px solid var(--border-light);background:var(--bg-secondary);width:100%;color:var(--text-primary);resize:vertical;border-radius:10px;min-height:80px;padding:12px 14px;font-family:inherit;font-size:.95rem;transition:border-color .2s}.room-quiz-text-area:focus{border-color:var(--primary-400);box-shadow:0 0 0 2px var(--primary-400);outline:none}@supports (color:color-mix(in lab, red, red)){.room-quiz-text-area:focus{box-shadow:0 0 0 2px color-mix(in srgb,var(--primary-400),transparent 80%)}}.room-teacher-dashboard{flex-direction:column;gap:16px;display:flex;padding:16px!important}.room-teacher-stats{gap:12px;display:flex}.room-teacher-stat{background:var(--bg-secondary);border:1px solid var(--border-light);border-radius:8px;flex-direction:column;flex:1;align-items:center;gap:2px;padding:10px 8px;display:flex}.room-teacher-stat-value{font-size:1.4rem;font-weight:700;line-height:1}.room-teacher-stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:.7rem}.room-teacher-participants{flex-direction:column;gap:4px;display:flex}.room-teacher-participant{background:var(--bg-secondary);border:1px solid var(--border-light);border-radius:8px;justify-content:space-between;align-items:center;gap:12px;padding:10px 14px;transition:background .15s;display:flex}.room-teacher-participant:hover{background:var(--hover-bg)}.room-teacher-participant-submitted{border-color:#22c55e33}.room-teacher-participant-info{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.room-teacher-participant-name{font-size:.88rem;font-weight:600}.room-teacher-participant-badge{border-radius:4px;align-items:center;gap:4px;padding:2px 8px;font-size:.7rem;font-weight:600;display:inline-flex}.room-teacher-badge-submitted{color:var(--success-400);background:#22c55e26}.room-teacher-badge-graded{color:var(--primary-400);background:#6366f126}.room-teacher-badge-working{color:var(--warning-500);background:#eab30826}.room-teacher-participant-actions{flex-shrink:0;gap:6px;display:flex}.quiz-reveal-overlay{z-index:10000;background:#000c;justify-content:center;align-items:center;animation:.3s ease-out fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInScale{0%{opacity:0;transform:scale(.7)}to{opacity:1;transform:scale(1)}}.quiz-reveal-container{flex-direction:column;align-items:center;gap:24px;width:90%;max-width:480px;display:flex}.quiz-reveal-countdown{flex-direction:column;align-items:center;gap:32px;display:flex}.quiz-reveal-student-name{color:#fff;text-align:center;font-size:1.8rem;font-weight:700}.quiz-reveal-countdown-number{color:var(--primary-400);font-size:8rem;font-weight:900;line-height:1;animation:.4s ease-out countPop}@keyframes countPop{0%{opacity:0;transform:scale(2)}60%{transform:scale(.9)}to{opacity:1;transform:scale(1)}}.quiz-reveal-result{flex-direction:column;align-items:center;gap:20px;animation:.5s ease-out slideUp;display:flex;position:relative}@keyframes slideUp{0%{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}.quiz-reveal-confetti{pointer-events:none;z-index:10001;position:fixed;inset:0;overflow:hidden}.quiz-reveal-confetti:before,.quiz-reveal-confetti:after{content:"";width:10px;height:10px;animation:3s ease-in forwards confettiFall;position:absolute;top:-10%}.quiz-reveal-confetti:before{background:var(--primary-400);box-shadow:30px 0 0 var(--success-500),60px 20px 0 var(--warning-500),-30px 10px 0 var(--error-400),90px -10px 0 var(--primary-300),-60px 30px 0 var(--success-400),120px 5px 0 var(--warning-400),-20px -5px 0 var(--primary-500),150px 25px 0 var(--error-300);border-radius:50%;animation-delay:0s;left:20%}.quiz-reveal-confetti:after{background:var(--warning-500);box-shadow:-30px 5px 0 var(--primary-400),-60px 15px 0 var(--success-500),30px 0px 0 var(--error-400),-90px 25px 0 var(--warning-300),60px 10px 0 var(--primary-300),-120px 20px 0 var(--success-400),20px -10px 0 var(--warning-500),-150px 30px 0 var(--error-300);border-radius:2px;animation-delay:.2s;right:20%}@keyframes confettiFall{0%{opacity:1;transform:translateY(0)rotate(0)}to{opacity:0;transform:translateY(120vh)rotate(720deg)}}.quiz-reveal-certificate{background:linear-gradient(145deg,#0f0c29 0%,#1a1a3e 40%,#24243e 70%,#0f3460 100%);border:2px solid #6366f166;border-radius:16px;flex-direction:column;align-items:center;gap:6px;width:100%;max-width:520px;padding:36px 32px 28px;display:flex;position:relative;overflow:hidden;box-shadow:0 0 60px #6366f126,0 20px 60px #0006}.quiz-reveal-certificate:before{content:"";pointer-events:none;border:1px solid #6366f126;border-radius:12px;position:absolute;inset:8px}.quiz-reveal-certificate:after{content:"";pointer-events:none;border-top:2px solid #6366f166;border-left:2px solid #6366f166;width:30px;height:30px;position:absolute;top:16px;left:16px}.quiz-cert-header{flex-direction:column;align-items:center;gap:6px;margin-bottom:4px;display:flex}.quiz-cert-trophy{color:#fbbf24;filter:drop-shadow(0 0 12px #fbbf2480)}.quiz-cert-header-label{color:#ffffff59;letter-spacing:3px;text-transform:uppercase;font-size:.65rem;font-weight:600}.quiz-cert-title{color:#fff;text-align:center;margin:0;font-size:1.5rem;font-weight:700}.quiz-cert-subtitle{color:#fff6;margin:2px 0;font-size:.78rem}.quiz-cert-name{color:#818cf8;text-align:center;border-bottom:1px solid #818cf840;padding-bottom:2px;font-size:1.7rem;font-weight:800}.quiz-cert-quiz{color:#e2e8f0;margin-top:2px;font-size:1.05rem;font-weight:600}.quiz-cert-scores{justify-content:center;gap:12px;width:100%;margin:16px 0 12px;display:flex}.quiz-cert-score-box{background:#6366f114;border:1px solid #6366f133;border-radius:10px;flex-direction:column;flex:1;align-items:center;gap:4px;min-width:100px;max-width:150px;padding:14px 16px 10px;display:flex}.quiz-cert-score-box-pass{background:#22c55e14;border-color:#22c55e40}.quiz-cert-score-box-fail{background:#ef444414;border-color:#ef444433}.quiz-cert-score-box-value{color:#fff;font-size:1.3rem;font-weight:800}.quiz-cert-score-box-pct{font-size:1.6rem}.quiz-cert-score-box-pass .quiz-cert-score-box-value{color:#22c55e}.quiz-cert-score-box-fail .quiz-cert-score-box-value{color:#ef4444}.quiz-cert-score-box-pass .quiz-cert-score-box-pct{color:#22c55e}.quiz-cert-score-box-fail .quiz-cert-score-box-pct{color:#ef4444}.quiz-cert-score-box-label{color:#ffffff59;letter-spacing:1px;text-transform:uppercase;font-size:.65rem;font-weight:600}.quiz-cert-comment{color:#ffffff73;text-align:center;max-width:360px;margin:4px 0;font-size:.82rem;font-style:italic;line-height:1.5}.quiz-cert-date{color:#ffffff40;margin-top:4px;font-size:.72rem}.quiz-cert-footer{color:#ffffff26;letter-spacing:2px;text-transform:uppercase;text-align:center;border-top:1px solid #6366f126;width:120px;margin-top:8px;padding-top:8px;font-size:.65rem;font-weight:600}.quiz-reveal-actions{gap:12px;display:flex}@media (max-width:560px){.quiz-reveal-container{width:95%;max-width:none}.quiz-reveal-certificate{max-width:none;padding:28px 20px 22px}.quiz-cert-title{font-size:1.2rem}.quiz-cert-name{font-size:1.3rem}.quiz-cert-quiz{font-size:.9rem}.quiz-cert-scores{gap:8px}.quiz-cert-score-box{min-width:0;padding:10px 8px 8px}.quiz-cert-score-box-value{font-size:1rem}.quiz-cert-score-box-pct{font-size:1.2rem}.quiz-reveal-student-name{font-size:1.3rem}.quiz-reveal-countdown-number{font-size:5rem}}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-ordinal{syntax:"*";inherits:false}@property --tw-slashed-zero{syntax:"*";inherits:false}@property --tw-numeric-figure{syntax:"*";inherits:false}@property --tw-numeric-spacing{syntax:"*";inherits:false}@property --tw-numeric-fraction{syntax:"*";inherits:false}@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-backdrop-blur{syntax:"*";inherits:false}@property --tw-backdrop-brightness{syntax:"*";inherits:false}@property --tw-backdrop-contrast{syntax:"*";inherits:false}@property --tw-backdrop-grayscale{syntax:"*";inherits:false}@property --tw-backdrop-hue-rotate{syntax:"*";inherits:false}@property --tw-backdrop-invert{syntax:"*";inherits:false}@property --tw-backdrop-opacity{syntax:"*";inherits:false}@property --tw-backdrop-saturate{syntax:"*";inherits:false}@property --tw-backdrop-sepia{syntax:"*";inherits:false}@property --tw-ease{syntax:"*";inherits:false}
