@font-face{font-family:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/8a480f0b521d4e75-s.8e0177b5.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/7178b3e590c64307-s.b97b3418.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:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/caa3a2e1cccd8315-s.p.853070df.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:Geist Fallback;src:local(Arial);ascent-override:95.94%;descent-override:28.16%;line-gap-override:0.0%;size-adjust:104.76%}.geist_a71539c9-module__T19VSG__className{font-family:Geist,Geist Fallback;font-style:normal}.geist_a71539c9-module__T19VSG__variable{--font-geist-sans:"Geist","Geist Fallback"}
@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/4fa387ec64143e14-s.c1fdd6c2.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/bbc41e54d2fcbd21-s.799d8ef8.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:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/797e433ab948586e-s.p.dbea232f.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:Geist Mono Fallback;src:local(Arial);ascent-override:74.67%;descent-override:21.92%;line-gap-override:0.0%;size-adjust:134.59%}.geist_mono_8d43a2aa-module__8Li5zG__className{font-family:Geist Mono,Geist Mono Fallback;font-style:normal}.geist_mono_8d43a2aa-module__8Li5zG__variable{--font-geist-mono:"Geist Mono","Geist 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-ease:initial}}}@layer theme{:root,:host{--spacing:.25rem;--radius-sm:.25rem;--radius-md:.375rem;--radius-lg:.5rem;--radius-xl:.75rem;--radius-2xl:1rem;--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-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-geist-sans);--default-mono-font-family:var(--font-geist-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}.relative{position:relative}.start{inset-inline-start:var(--spacing)}.end{inset-inline-end:var(--spacing)}.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,)}.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}.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}.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,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)}}:root{--bg-base:#09090b;--bg-surface:#111116;--bg-elevated:#18181f;--bg-card:#1e1e28;--bg-overlay:#25252f;--bg-highlight:#2a2a38;--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-geist-sans,system-ui,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)}.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}.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)}.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)}.card-interactive:hover{box-shadow:var(--shadow-lg);border-color:var(--border-primary);transform:translateY(-2px)}.card-interactive.selected{border-color:var(--primary-500);box-shadow:0 0 0 3px #6366f133,var(--shadow-md);background:#6366f10f}.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-geist-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;-webkit-background-clip:text;background-clip:text;font-size:1.15rem;font-weight:700}.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-disabled);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);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)}.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-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}.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{0%,to{opacity:1}50%{opacity:.4}}.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{background:#0f0f14;flex:1;justify-content:center;align-items:center;padding:12px;display:flex;overflow:hidden}.room-stage-video{background:#18181b;border-radius:12px;width:100%;height:100%;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{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-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{padding:8px 12px}.room-controls-mobile .room-control-btn{min-width:unset;border-radius:50%;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-avatar{width:80px;height:80px;font-size:1.8rem}}@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-ease{syntax:"*";inherits:false}
