[data-lk-theme=default]{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;--lk-bg:#111;--lk-bg2:#1e1e1e;--lk-bg3:#2b2b2b;--lk-bg4:#373737;--lk-bg5:#444;--lk-fg:#fff;--lk-fg2:#f5f5f5;--lk-fg3:#ebebeb;--lk-fg4:#e0e0e0;--lk-fg5:#d6d6d6;--lk-border-color:#ffffff1a;--lk-accent-fg:#fff;--lk-accent-bg:#1f8cf9;--lk-accent2:#3396fa;--lk-accent3:#47a0fa;--lk-accent4:#5babfb;--lk-danger-fg:#fff;--lk-danger:#f91f31;--lk-danger2:#fa3343;--lk-danger3:#fa4756;--lk-danger4:#fb5b68;--lk-success-fg:#fff;--lk-success:#1ff968;--lk-success2:#33fa75;--lk-success3:#47fa83;--lk-success4:#5bfb90;--lk-control-fg:var(--lk-fg);--lk-control-bg:var(--lk-bg2);--lk-control-hover-bg:var(--lk-bg3);--lk-control-active-bg:var(--lk-bg4);--lk-control-active-hover-bg:var(--lk-bg5);--lk-connection-excellent:#06db4d;--lk-connection-good:#f9b11f;--lk-connection-poor:#f91f31;--lk-font-family:system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji";--lk-font-size:16px;--lk-line-height:1.5;--lk-border-radius:.5rem;--lk-box-shadow:0 .5rem 1.5rem #00000026;--lk-drop-shadow:#fff3 0px 0px 24px;--lk-grid-gap:.5rem;--lk-control-bar-height:69px;--lk-chat-header-height:69px}.lk-button,.lk-start-audio-button,.lk-chat-toggle,.lk-disconnect-button{color:var(--lk-control-fg);background-image:none;background-color:var(--lk-control-bg);border-radius:var(--lk-border-radius);cursor:pointer;white-space:nowrap;font-size:inherit;line-height:inherit;-webkit-user-select:none;user-select:none;border:0;justify-content:center;align-items:center;gap:.5rem;padding:.625rem 1rem;display:inline-flex;position:relative}.lk-button:not(:disabled):hover,.lk-start-audio-button:not(:disabled):hover,.lk-chat-toggle:not(:disabled):hover,.lk-disconnect-button:not(:disabled):hover{background-color:var(--lk-control-hover-bg)}.lk-button>svg,.lk-start-audio-button>svg,.lk-chat-toggle>svg,.lk-disconnect-button>svg{overflow:visible}.lk-button[aria-pressed=true],[aria-pressed=true].lk-start-audio-button,[aria-pressed=true].lk-chat-toggle,[aria-pressed=true].lk-disconnect-button{background-color:var(--lk-control-active-bg)}.lk-button[aria-pressed=true]:hover,[aria-pressed=true].lk-start-audio-button:hover,[aria-pressed=true].lk-chat-toggle:hover,[aria-pressed=true].lk-disconnect-button:hover{background-color:var(--lk-control-active-hover-bg)}.lk-button[data-lk-source=screen_share][data-lk-enabled=true],[data-lk-source=screen_share][data-lk-enabled=true].lk-start-audio-button,[data-lk-source=screen_share][data-lk-enabled=true].lk-chat-toggle,[data-lk-source=screen_share][data-lk-enabled=true].lk-disconnect-button{background-color:var(--lk-accent-bg)}.lk-button[data-lk-source=screen_share][data-lk-enabled=true]:hover,[data-lk-source=screen_share][data-lk-enabled=true].lk-start-audio-button:hover,[data-lk-source=screen_share][data-lk-enabled=true].lk-chat-toggle:hover,[data-lk-source=screen_share][data-lk-enabled=true].lk-disconnect-button:hover{background-color:var(--lk-accent2)}.lk-button:disabled,.lk-start-audio-button:disabled,.lk-chat-toggle:disabled,.lk-disconnect-button:disabled{opacity:.5}.lk-button-group{align-items:stretch;height:100%;display:inline-flex}.lk-button-group>.lk-button:first-child,.lk-button-group>.lk-start-audio-button:first-child,.lk-button-group>.lk-chat-toggle:first-child,.lk-button-group>.lk-disconnect-button:first-child{border-top-right-radius:0;border-bottom-right-radius:0}.lk-button-group-menu{flex-shrink:0;position:relative}.lk-button-group-menu>.lk-button,.lk-button-group-menu>.lk-start-audio-button,.lk-button-group-menu>.lk-chat-toggle,.lk-button-group-menu>.lk-disconnect-button{border-top-left-radius:0;border-bottom-left-radius:0;height:100%}.lk-button-group-menu>.lk-button:after,.lk-button-group-menu>.lk-start-audio-button:after,.lk-button-group-menu>.lk-chat-toggle:after,.lk-button-group-menu>.lk-disconnect-button:after{margin-left:0}.lk-button-menu:after{content:"";transform-origin:50%;border-bottom:.125em solid;border-left:.125em solid;width:.5em;height:.5em;margin-top:-.25rem;margin-left:.5rem;display:inline-block;transform:rotate(-45deg)}.lk-disconnect-button{color:var(--lk-danger);border:1px solid var(--lk-danger);font-weight:600}.lk-disconnect-button:not(:disabled):hover{--lk-control-hover-bg:var(--lk-danger2);color:var(--lk-danger-fg)}.lk-disconnect-button:not(:disabled):active{--lk-control-hover-bg:var(--lk-danger3);color:var(--lk-danger-fg)}.lk-chat-toggle{position:relative}.lk-chat-toggle[data-lk-unread-msgs]:not([data-lk-unread-msgs="0"]):after{content:attr(data-lk-unread-msgs);background:var(--lk-accent-bg);border-radius:50%;margin-top:.25rem;margin-left:.25rem;padding:.25rem;font-size:.5rem;line-height:.75;position:absolute;top:0;left:0}.lk-media-device-select:not(:last-child){border-bottom:1px solid var(--lk-border-color);margin-bottom:.75rem;padding-bottom:.5rem}.lk-media-device-select li:not(:last-child){margin-bottom:.25rem}.lk-media-device-select li>.lk-button{justify-content:start;width:100%;padding-block:.5rem}.lk-media-device-select li:not([data-lk-active=true])>.lk-button:not(:disabled):hover{background-color:var(--lk-bg3)}.lk-media-device-select [data-lk-active=false]>.lk-button:hover{cursor:pointer;background-color:#0000000d}.lk-media-device-select [data-lk-active=true]>.lk-button{color:var(--lk-accent-fg);background-color:var(--lk-accent-bg)}.lk-device-menu{z-index:5;white-space:nowrap;background-color:var(--lk-bg2);border:1px solid var(--lk-border-color);width:max-content;min-width:10rem;box-shadow:var(--lk-box-shadow);border-radius:.75rem;margin-bottom:.25rem;padding:.5rem;position:absolute;top:0;left:0}.lk-device-menu-heading{opacity:.65;padding:.25rem .5rem;font-weight:700}.lk-start-audio-button{color:var(--lk-accent-fg);background-color:var(--lk-accent-bg)}@media screen and (width<=600px){.lk-start-audio-button{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%)}}.lk-pagination-control{background-color:var(--lk-control-bg);border-radius:var(--lk-border-radius);opacity:0;align-items:stretch;transition:opacity .15s ease-in-out;display:flex;position:absolute;bottom:1rem;left:50%;transform:translate(-50%)}.lk-pagination-control:hover{opacity:1}.lk-pagination-control>.lk-button:first-child{border-top-right-radius:0;border-bottom-right-radius:0}.lk-pagination-control>.lk-button:first-child>svg{transform:rotate(180deg)}.lk-pagination-control>.lk-button:last-child{border-top-left-radius:0;border-bottom-left-radius:0}.lk-pagination-count{border-inline:1px solid var(--lk-bg);padding:.5rem .875rem}[data-lk-user-interaction=true].lk-pagination-control{opacity:1}.lk-pagination-indicator{height:var(--lk-grid-gap);background-color:var(--lk-bg2);width:fit-content;bottom:calc(var(--lk-grid-gap)/2);opacity:1;border-radius:2rem;align-items:center;gap:.2rem;padding:.2rem .5rem;display:flex;position:absolute;left:50%;transform:translate(-50%)}.lk-pagination-indicator span{background-color:var(--lk-fg);opacity:.35;border-radius:10000000px;width:.4rem;height:.4rem;transition:opacity .2s linear;display:inline-block}.lk-pagination-indicator span[data-lk-active]{opacity:.9}.lk-grid-layout{--lk-col-count:1;--lk-row-count:1;grid-template-columns:repeat(var(--lk-col-count), minmax(0, 1fr));grid-gap:var(--lk-grid-gap);width:100%;max-width:100%;height:100%;max-height:100%;padding:var(--lk-grid-gap);grid-auto-rows:minmax(0,1fr);display:grid}.lk-grid-layout[data-lk-pagination=true]{padding-bottom:calc(var(--lk-grid-gap)*2)}.lk-focus-layout{gap:var(--lk-grid-gap);width:100%;max-height:100%;padding:var(--lk-grid-gap);grid-template-columns:1fr 5fr;display:grid}.lk-focused-participant{position:relative}.lk-focused-participant .lk-pip-track{width:20%;height:auto;position:absolute;top:10px;right:10px}@media (width<=600px){.lk-focus-layout{grid-template-rows:5fr 1fr;grid-template-columns:1fr}.lk-carousel{order:1}}.lk-carousel{gap:var(--lk-grid-gap);max-height:100%;display:flex}.lk-carousel>*{aspect-ratio:16/10;scroll-snap-align:start;flex-shrink:0}.lk-carousel[data-lk-orientation=vertical]{scroll-snap-type:y mandatory;flex-direction:column;overflow:hidden auto}.lk-carousel[data-lk-orientation=vertical]>*{--lk-height-minus-gaps:calc(100% - calc(var(--lk-grid-gap) * calc(var(--lk-max-visible-tiles) - 1)));height:calc(var(--lk-height-minus-gaps)/var(--lk-max-visible-tiles))}.lk-carousel[data-lk-orientation=horizontal]{scroll-snap-type:x mandatory;overflow:auto hidden}.lk-carousel[data-lk-orientation=horizontal]>*{--lk-width-minus-gaps:calc(100% - var(--lk-grid-gap) * (var(--lk-max-visible-tiles) - 1));width:calc(var(--lk-width-minus-gaps)/var(--lk-max-visible-tiles))}.lk-connection-quality{width:1.5rem;height:1.5rem}.lk-track-muted-indicator-camera,.lk-track-muted-indicator-microphone{width:var(--lk-indicator-size,1rem);height:var(--lk-indicator-size,1rem);margin-inline-end:.25rem;transition:opacity .25s ease-in-out;position:relative}.lk-track-muted-indicator-camera[data-lk-muted=true]{opacity:.5}.lk-track-muted-indicator-microphone{--lk-bg:var(--lk-icon-mic)}.lk-track-muted-indicator-microphone[data-lk-muted=true]{opacity:.5}.lk-participant-name{font-size:.875rem}.lk-participant-media-video{object-fit:cover;object-position:center;background-color:#000;width:100%;height:100%}.lk-participant-media-video[data-lk-orientation=landscape]{object-fit:cover}.lk-participant-media-video[data-lk-orientation=portrait],.lk-participant-media-video[data-lk-source=screen_share]{object-fit:contain;background-color:var(--lk-bg2)}.lk-participant-media-audio{width:auto}[data-lk-facing-mode=user] .lk-participant-media-video[data-lk-local-participant=true][data-lk-source=camera]{transform:rotateY(180deg)}.lk-audio-visualizer{background:var(--lk-bg-control);aspect-ratio:16/9;border-radius:.5rem;justify-content:space-around;align-items:center;width:100%;height:100%;min-height:160px;display:flex}.lk-audio-visualizer>rect{fill:var(--lk-accent-bg);transition:transform .1s cubic-bezier(.19,.02,.09,1)}.lk-audio-visualizer>path{stroke:var(--lk-accent-bg);transition:all .1s cubic-bezier(.19,.02,.09,1)}.lk-audio-bar-visualizer{background:var(--lk-bg);justify-content:center;align-items:center;gap:var(--lk-va-bar-gap,24px);width:100%;height:100%;display:flex}.lk-audio-bar-visualizer>.lk-audio-bar{transform-origin:"center";height:100%;width:var(--lk-va-bar-width,12px);border-radius:var(--lk-va-bar-border-radius,32px);background-color:var(--lk-va-bar-bg,#8883);transition:background-color .25s ease-out}.lk-audio-bar-visualizer[data-lk-va-state=speaking]>.lk-audio-bar,.lk-audio-bar-visualizer>.lk-audio-bar.lk-highlighted,.lk-audio-bar-visualizer>[data-lk-highlighted=true]{background-color:var(--lk-fg,#888);transition:none}.lk-audio-bar-visualizer[data-lk-va-state=thinking]{transition:background-color .15s ease-out}.lk-participant-tile{--lk-speaking-indicator-width:2.5px;border-radius:var(--lk-border-radius);flex-direction:column;gap:.375rem;display:flex;position:relative;overflow:hidden}.lk-participant-tile:after{content:"";border-radius:var(--lk-border-radius);border:0px solid var(--lk-accent-bg);transition-property:border opacity;pointer-events:none;transition-duration:.4s;transition-delay:.5s;position:absolute;inset:0}.lk-participant-tile[data-lk-speaking=true]:not([data-lk-source=screen_share]):after{border-width:var(--lk-speaking-indicator-width);transition-duration:.2s;transition-delay:0s}.lk-participant-tile .lk-focus-toggle-button{border-radius:calc(var(--lk-border-radius)/2);opacity:0;background-color:#00000080;padding:.25rem;transition:opacity .2s ease-in-out .2s;position:absolute;top:.25rem;right:.25rem}.lk-participant-tile:hover .lk-focus-toggle-button,.lk-participant-tile:focus .lk-focus-toggle-button{opacity:1;transition-delay:0}.lk-participant-tile .lk-connection-quality{opacity:0;transition:opacity .2s ease-in-out .2s}.lk-participant-tile .lk-connection-quality[data-lk-quality=poor],.lk-participant-tile:hover .lk-connection-quality,.lk-participant-tile:focus .lk-connection-quality{opacity:1;transition-delay:0}.lk-participant-tile .lk-participant-placeholder{background-color:var(--lk-bg2);opacity:0;pointer-events:none;border-radius:var(--lk-border-radius);justify-content:center;align-items:center;transition:opacity .2s ease-in-out;display:flex;position:absolute;inset:0}.lk-participant-tile .lk-participant-placeholder svg{width:auto;height:100%;padding:10%}.lk-participant-tile[data-lk-video-muted=true][data-lk-source=camera] .lk-participant-placeholder{opacity:1}.lk-participant-metadata{flex-direction:row;justify-content:space-between;align-items:center;gap:.5rem;line-height:1;display:flex;position:absolute;bottom:.25rem;left:.25rem;right:.25rem}.lk-participant-metadata-item{border-radius:calc(var(--lk-border-radius)/2);background-color:#00000080;align-items:center;padding:.25rem;display:flex}.lk-toast{background-color:var(--lk-bg);border:1px solid var(--lk-border-color);border-radius:var(--lk-border-radius);box-shadow:var(--lk-box-shadow);align-items:center;gap:.5rem;padding:.75rem 1.25rem;display:flex;position:fixed;top:.75rem;left:50%;transform:translate(-50%)}.lk-spinner{animation:2s linear infinite lk-rotate}@keyframes lk-rotate{0%{transform:rotate(0)}to{transform:rotate(359deg)}}.lk-room-container{background-color:var(--lk-bg);line-height:var(--lk-line-height)}.lk-room-container{--lk-has-imported-styles:"true";width:100%;height:100%;position:relative}.lk-room-container [class^=lk-],.lk-room-container [class*=\ lk-]{box-sizing:border-box}.lk-audio-conference{width:100%;height:100%;position:relative}.lk-audio-conference-stage{grid-template-columns:repeat(3,1fr);gap:10px;width:100%;height:100%;display:grid}.lk-chat{grid-template-rows:var(--lk-chat-header-height) 1fr var(--lk-control-bar-height);background-color:var(--lk-bg2);border-left:1px solid var(--lk-border-color);align-items:end;width:max(200px,55ch);display:grid}.lk-chat-header{height:var(--lk-chat-header-height);justify-content:center;align-items:center;padding:.75rem;display:flex;position:relative}.lk-chat-header .lk-close-button{background-color:#0000;position:absolute;right:0;transform:translate(-50%)}.lk-chat-header .lk-close-button:hover{background-color:var(--lk-control-active-hover-bg)}.lk-chat-messages{flex-direction:column;gap:.25rem;width:100%;max-height:100%;display:flex;overflow:auto}.lk-chat-entry{flex-direction:column;gap:.25rem;margin:0 .25rem;display:flex}.lk-chat-entry .lk-meta-data{color:var(--lk-fg5);white-space:nowrap;padding:0 .3rem;font-size:.75rem;display:flex}.lk-chat-entry .lk-meta-data .lk-participant-name{margin-top:1rem}.lk-chat-entry .lk-meta-data .lk-timestamp{align-self:flex-end;margin-left:auto}.lk-chat-entry .lk-edit-button{float:right;background:0 0;border-radius:0;margin:0;padding:0 .25rem;font-size:12px}.lk-chat-entry .lk-message-body{word-break:break-word;border-radius:15px;width:fit-content;max-width:calc(100% - 32px);padding:.25rem .75rem;display:inline-block}.lk-chat-entry[data-lk-message-origin=local] .lk-message-body{background-color:var(--lk-bg5)}.lk-chat-entry[data-lk-message-origin=remote] .lk-message-body{background-color:var(--lk-accent4)}.lk-chat-entry a{color:inherit;text-decoration:underline}.lk-chat-entry *{margin-block:.25em}.lk-chat-entry:last-child{margin-bottom:.25rem}.lk-chat-form{border-top:1px solid var(--lk-border-color);max-height:var(--lk-control-bar-height);gap:.75rem;padding:.75rem;display:flex}.lk-chat-form-input{font-size:inherit;line-height:inherit;width:100%}@media (width<=600px){.lk-chat{max-width:100%;top:0;right:0;bottom:var(--lk-control-bar-height);position:fixed}}.lk-control-bar,.lk-agent-control-bar{border-top:1px solid var(--lk-border-color);max-height:var(--lk-control-bar-height);justify-content:center;align-items:center;gap:.5rem;padding:.75rem;display:flex}.lk-agent-control-bar{height:var(--lk-control-bar-height);--lk-bg:transparent;--lk-va-bar-width:2px;--lk-va-bar-gap:4px;--lk-va-bar-border-radius:1px}.lk-agent-control-bar .lk-audio-bar-visualizer .lk-audio-bar.lk-highlighted{filter:none}.lk-prejoin{background-color:var(--lk-bg);line-height:var(--lk-line-height)}[data-lk-theme]{font-size:var(--lk-font-size);font-family:var(--lk-font-family);color:var(--lk-fg)}[data-lk-theme] .lk-list{margin:0;padding:0;list-style:none}[data-lk-theme] .lk-form-control{font-family:var(--lk-font-family);background-color:var(--lk-control-bg);border:1px solid var(--lk-border-color);border-radius:var(--lk-border-radius);padding:.625rem 1rem}.lk-prejoin{box-sizing:border-box;background-color:var(--lk-bg);flex-direction:column;align-items:stretch;gap:1rem;width:min(100%,480px);margin-inline:auto;padding:1rem;display:flex}.lk-prejoin .lk-video-container{aspect-ratio:16/10;border-radius:var(--lk-border-radius);background-color:#000;width:100%;height:auto;position:relative;overflow:hidden}.lk-prejoin .lk-video-container video,.lk-prejoin .lk-video-container .lk-camera-off-note{object-fit:cover;width:100%;height:100%;display:block}.lk-prejoin .lk-video-container video[data-lk-facing-mode=user]{transform:rotateY(180deg)}.lk-prejoin .lk-video-container .lk-camera-off-note{aspect-ratio:16/10;background-color:#000;place-items:center;width:100%;display:grid;position:absolute;top:0;left:0}.lk-prejoin .lk-video-container .lk-camera-off-note>*{max-width:100%;height:70%}.lk-prejoin .lk-audio-container{display:none}.lk-prejoin .lk-audio-container audio{width:100%;height:auto}.lk-prejoin .lk-button-group-container{flex-wrap:nowrap;gap:1rem;display:flex}.lk-prejoin .lk-button-group-container>.lk-button-group{width:50%}.lk-prejoin .lk-button-group-container>.lk-button-group>.lk-button{justify-content:left}.lk-prejoin .lk-button-group-container>.lk-button-group>.lk-button:first-child{width:100%}@media (width<=400px){.lk-prejoin .lk-button-group-container{flex-wrap:wrap}.lk-prejoin .lk-button-group-container>.lk-button-group{width:100%}}.lk-prejoin .lk-username-container{flex-direction:column;gap:1rem;width:100%;max-width:100%;display:flex}.lk-prejoin .lk-join-button{--lk-control-fg:var(--lk-accent-fg);--lk-control-bg:var(--lk-accent-bg);--lk-control-hover-bg:var(--lk-accent2);--lk-control-active-bg:var(--lk-accent3);--lk-control-active-hover-bg:var(--lk-accent4);background-color:var(--lk-control-bg)}.lk-prejoin .lk-join-button:hover{background-color:var(--lk-control-hover-bg)}.lk-focus-layout-wrapper,.lk-grid-layout-wrapper{width:100%;height:calc(100% - var(--lk-control-bar-height));justify-content:center;display:flex;position:relative}.lk-grid-layout-wrapper{flex-direction:column;align-items:center}.lk-focus-layout-wrapper{align-items:stretch}.lk-video-conference{align-items:stretch;height:100%;display:flex;position:relative}.lk-video-conference-inner{flex-direction:column;align-items:stretch;width:100%;display:flex}.lk-settings-menu-modal{background:var(--lk-bg);border-radius:var(--lk-border-radius);padding:1rem;background-color:var(--lk-bg);border:1px solid var(--lk-border-color);border-radius:var(--lk-border-radius);box-shadow:var(--lk-box-shadow);flex-direction:column;align-items:center;gap:.5rem;min-width:50vw;max-width:100%;min-height:50vh;max-height:100%;padding:.75rem 1.25rem;display:flex;position:fixed;top:50%;left:50%;overflow-y:auto;transform:translate(-50%,-50%)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#faf8f5;--bg-alt:#f2ede7;--bg-ink:#1e1b18;--bg-hover:#1e1b1808;--bg-active:#ff7f5012;--text:#1e1b18;--text-secondary:#5a524c;--text-tertiary:#8a8078;--text-faint:#b8ada3;--coral:coral;--coral-hover:#e86a3a;--coral-bg:#ff7f5014;--coral-50:#fff5f0;--coral-100:#ffe8dc;--violet:#8b5cf6;--violet-bg:#8b5cf614;--green:#16a34a;--green-bg:#16a34a14;--red:#dc2626;--red-bg:#dc26260f;--amber:#f59e0b;--amber-bg:#f59e0b14;--teal:#14b8a6;--teal-bg:#14b8a614;--card:#fff;--border:#e2dcd5;--border-light:#ede8e2;--border-focus:var(--coral);--font-body:"Plus Jakarta Sans", system-ui, -apple-system, sans-serif;--font-mono:ui-monospace, "SF Mono", "Cascadia Code", monospace;--font-display:var(--font-body);--radius:12px;--radius-sm:8px;--radius-xs:6px;--radius-lg:16px;--radius-xl:20px;--shadow-xs:0 1px 2px #1e1b180d;--shadow-sm:0 2px 4px #1e1b180f, 0 1px 2px #1e1b180a;--shadow-md:0 4px 12px #1e1b1814, 0 2px 4px #1e1b180a;--shadow-lg:0 12px 24px #1e1b181a, 0 4px 8px #1e1b180f;--shadow-xl:0 20px 40px #1e1b181f, 0 8px 16px #1e1b180f;--transition:.18s ease;--sidebar-w:260px;--sidebar-collapsed-w:64px}.dark{--bg:#060b14;--bg-alt:#0b1320;--bg-ink:#f5f7fa;--bg-hover:#ffffff0a;--bg-active:#00d9ff14;--text:#f5f7fa;--text-secondary:#a8b3c7;--text-tertiary:#6b7280;--text-faint:#4b5563;--coral:#00d9ff;--coral-hover:#00b8d9;--coral-bg:#00d9ff1a;--coral-50:#0b1a2e;--coral-100:#0f2238;--violet:#7c5cff;--violet-bg:#7c5cff1f;--green:#22c55e;--green-bg:#22c55e1f;--red:#ef4444;--red-bg:#ef44441a;--amber:#facc15;--amber-bg:#facc151a;--teal:#14b8a6;--teal-bg:#14b8a61a;--card:#0b1320;--border:#ffffff0f;--border-light:#ffffff0d;--border-focus:var(--coral);--shadow-xs:0 1px 2px #0000004d;--shadow-sm:0 2px 4px #0000004d, 0 1px 2px #0003;--shadow-md:0 4px 12px #0006, 0 2px 4px #0000004d;--shadow-lg:0 12px 24px #0006, 0 4px 8px #0000004d;--shadow-xl:0 20px 40px #00000080, 0 8px 16px #0000004d}:focus-visible{outline:2px solid var(--coral);outline-offset:2px}html{scroll-behavior:smooth}::selection{color:var(--text);background:#00d9ff40}.dark ::selection{color:#f5f7fa;background:#00d9ff40}@keyframes fade-up{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes slide-in-right{0%{opacity:0;transform:translate(-8px)}to{opacity:1;transform:translate(0)}}body{font-family:var(--font-body);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:14px;line-height:1.6}a{color:inherit;text-decoration:none}button{cursor:pointer;font-family:var(--font-body)}input,textarea,select{font-family:var(--font-body);font-size:14px}.page-loading{min-height:60vh;color:var(--text-tertiary);justify-content:center;align-items:center;font-size:.9rem;display:flex}.form-actions{gap:.5rem;display:flex}.btn-primary{border-radius:var(--radius-sm);background:var(--coral);color:#fff;transition:background var(--transition), box-shadow var(--transition);border:none;align-items:center;gap:.4rem;padding:.55rem 1.1rem;font-size:.85rem;font-weight:600;display:inline-flex}.btn-primary:hover{background:var(--coral-hover)}.btn-primary:active{opacity:.9}.btn-primary:disabled{opacity:.4;cursor:not-allowed}.btn-primary:disabled:hover{background:var(--coral)}.btn-secondary{border-radius:var(--radius-sm);border:1px solid var(--border);color:var(--text);transition:background var(--transition), border-color var(--transition), box-shadow var(--transition);background:#fff;align-items:center;gap:.4rem;padding:.55rem 1.1rem;font-size:.85rem;font-weight:500;display:inline-flex}.btn-secondary:hover{background:var(--bg-hover);border-color:var(--text-tertiary);box-shadow:var(--shadow-xs)}.btn-danger{border-radius:var(--radius-xs);color:var(--red);transition:background var(--transition);background:0 0;border:none;align-items:center;gap:.4rem;padding:.4rem .75rem;font-size:.8rem;font-weight:500;display:inline-flex}.btn-danger:hover{background:var(--red-bg)}.btn-ghost{border-radius:var(--radius-sm);color:var(--text-secondary);transition:color var(--transition), background var(--transition);background:0 0;border:none;align-items:center;gap:.4rem;padding:.55rem 1.1rem;font-size:.85rem;font-weight:500;display:inline-flex}.btn-ghost:hover{color:var(--text);background:var(--bg-hover)}.btn-icon{border-radius:var(--radius-xs);width:32px;height:32px;color:var(--text-tertiary);transition:background var(--transition), color var(--transition);background:0 0;border:none;justify-content:center;align-items:center;display:inline-flex}.btn-icon:hover{background:var(--bg-hover);color:var(--text)}.form-group{flex-direction:column;gap:.3rem;margin-bottom:.75rem;display:flex}.form-group label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;font-size:.78rem;font-weight:600}.form-group input,.form-group textarea,.form-group select{border-radius:var(--radius-sm);border:1px solid var(--border);color:var(--text);transition:border-color var(--transition), box-shadow var(--transition);background:#fff;outline:none;padding:.55rem .75rem}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px #ff7f501a}.form-group input::placeholder,.form-group textarea::placeholder{color:var(--text-faint)}.form-hint{color:var(--text-tertiary);font-size:.72rem}.form-row{gap:1rem;display:flex}.form-row .form-group{flex:1}.form-group-input-danger{border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;font-size:.88rem;font-family:var(--font-body);transition:border-color var(--transition);outline:none;margin-top:.4rem;padding:.5rem .75rem}.form-group-input-danger:focus{border-color:var(--coral);box-shadow:0 0 0 3px #ff7f501a}.modal-overlay{z-index:100;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#1e1b184d;justify-content:center;align-items:center;padding:1rem;animation:.2s modal-overlay-in;display:flex;position:fixed;inset:0}@keyframes modal-overlay-in{0%{opacity:0}to{opacity:1}}.modal-content{border-radius:var(--radius-lg);width:100%;max-width:540px;max-height:85vh;box-shadow:var(--shadow-xl);background:#fff;border:none;animation:.25s modal-content-in;overflow-y:auto}@keyframes modal-content-in{0%{opacity:0;transform:translateY(8px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}.modal-wide{max-width:780px}.modal-header{border-bottom:1px solid var(--border-light);justify-content:space-between;align-items:center;padding:1rem 1.25rem;display:flex}.modal-header h2{font-size:1rem;font-weight:700}.modal-body{padding:1.25rem}.modal-form{flex-direction:column;gap:0;display:flex}.auth-page{background:var(--bg);justify-content:center;align-items:center;min-height:100vh;padding:2rem;display:flex}.auth-card{border-radius:var(--radius-lg);border:1px solid var(--border-light);text-align:center;width:100%;max-width:400px;box-shadow:var(--shadow-xl);background:#fff;padding:2.5rem;animation:.4s fade-up}.auth-card h1{font-family:var(--font-display);color:var(--text);letter-spacing:-.03em;margin-bottom:.15rem;font-size:1.5rem;font-weight:800}.auth-card h1:after{content:"";background:var(--coral);border-radius:2px;width:32px;height:3px;margin:.6rem auto 0;display:block}.auth-card .auth-subtitle{color:var(--text-tertiary);margin-bottom:1.5rem;font-size:.88rem}.auth-form{text-align:left;flex-direction:column;gap:0;display:flex}.auth-form input{border-radius:var(--radius-sm);border:1px solid var(--border);font-family:var(--font-body);color:var(--text);transition:border-color var(--transition), box-shadow var(--transition);background:#fff;outline:none;padding:.6rem .85rem;font-size:.88rem}.auth-form input:focus{border-color:var(--coral);box-shadow:0 0 0 3px #ff7f501a}.auth-form .form-group{margin-bottom:.75rem}.auth-form .login-error{background:var(--red-bg);color:var(--red);border-radius:var(--radius-xs);border:1px solid #dc26261f;margin-bottom:.75rem;padding:.5rem .75rem;font-size:.82rem}.auth-exists-card{border-radius:var(--radius-sm);background:#ff7f500f;border:1px solid #ff7f5033;gap:.75rem;margin-bottom:.75rem;padding:.85rem;display:flex}.auth-exists-icon{color:var(--coral);flex-shrink:0;margin-top:.1rem}.auth-exists-title{color:var(--text-primary);margin:0 0 .25rem;font-size:.88rem;font-weight:600}.auth-exists-text{color:var(--text-secondary);margin:0 0 .6rem;font-size:.8rem;line-height:1.4}.auth-exists-actions{flex-wrap:wrap;gap:.5rem;display:flex}.auth-link{color:var(--text-tertiary);margin-top:1rem;font-size:.82rem}.auth-link a{color:var(--coral);font-weight:600}.auth-link a:hover{text-decoration:underline}.auth-divider{color:var(--text-tertiary);align-items:center;gap:.75rem;margin:.75rem 0;font-size:.82rem;display:flex}.auth-divider:before,.auth-divider:after{content:"";background:var(--border);flex:1;height:1px}.input-wrapper{align-items:center;display:flex;position:relative}.input-wrapper .input-icon{color:var(--text-tertiary);pointer-events:none;flex-shrink:0;position:absolute;left:.7rem}.input-wrapper input{width:100%;padding-left:2.2rem!important}.input-wrapper input:not([type=password]):not([type=text]){padding-left:2.2rem}.input-toggle{color:var(--text-tertiary);cursor:pointer;border-radius:var(--radius-xs);background:0 0;border:none;align-items:center;padding:.25rem;display:flex;position:absolute;right:.5rem}.input-toggle:hover{color:var(--text-secondary)}.input-toggle:focus-visible{outline:2px solid var(--coral);outline-offset:1px}.field-error{color:var(--red);margin-top:.25rem;font-size:.78rem;display:block}.input-error{border-color:var(--red)!important}.input-error:focus{box-shadow:0 0 0 3px #dc26261a;border-color:var(--red)!important}.btn-full{justify-content:center;width:100%}.auth-forgot-link{color:var(--coral);font-size:.82rem;font-weight:500;text-decoration:none}.auth-forgot-link:hover{text-decoration:underline}.password-strength{align-items:center;gap:.5rem;margin-top:.4rem;display:flex}.strength-bar{background:var(--border);border-radius:2px;flex:1;height:4px;overflow:hidden}.strength-fill{height:100%;transition:width var(--transition);border-radius:2px}.strength-fill.strength-1{background:var(--red);width:33%}.strength-fill.strength-2{background:var(--amber);width:66%}.strength-fill.strength-3{background:var(--green);width:100%}.strength-label{min-width:2.5rem;font-size:.75rem;font-weight:500}.strength-label.strength-1{color:var(--red)}.strength-label.strength-2{color:var(--amber)}.strength-label.strength-3{color:var(--green)}@keyframes spin{to{transform:rotate(360deg)}}.app-layout{min-height:100vh}.app-header{border-bottom:1px solid var(--border-light);z-index:30;background:#fff;align-items:center;gap:1.5rem;height:52px;padding:0 1.5rem;display:flex;position:sticky;top:0}.app-logo img{width:auto;height:28px}.app-nav{gap:1.5rem;display:flex}.app-nav a{color:var(--text-tertiary);transition:color var(--transition), border-color var(--transition);border-bottom:2px solid #0000;padding:.25rem 0;font-size:.85rem;font-weight:500}.app-nav a:hover{color:var(--text)}.app-nav a.active{color:var(--coral);border-color:var(--coral);font-weight:600}.app-user{color:var(--text-tertiary);align-items:center;gap:.75rem;margin-left:auto;font-size:.82rem;display:flex}.app-main{max-width:960px;margin:0 auto;padding:1.5rem clamp(1rem,3vw,2rem);animation:.4s fade-up}.app-layout-sidebar{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-w);background:var(--bg);border-right:1px solid var(--border-light);z-index:40;flex-direction:column;transition:width .2s;display:flex;position:fixed;top:0;bottom:0;left:0;overflow:hidden}.sidebar.collapsed{width:var(--sidebar-collapsed-w)}.sidebar-top{align-items:center;gap:.25rem;padding:.85rem .85rem .5rem;display:flex}.sidebar-logo{flex-shrink:0;align-items:center;display:flex}.sidebar-logo img{width:auto;height:24px}.sidebar-toggle{color:var(--text-faint);border-radius:var(--radius-xs);width:28px;height:28px;transition:color var(--transition), background var(--transition);background:0 0;border:none;justify-content:center;align-items:center;margin-left:auto;display:flex}.sidebar-toggle:hover{color:var(--text);background:var(--bg-hover)}.collapsed .sidebar-toggle{display:none}.collapsed .sidebar-top{justify-content:center;padding:.85rem}.sidebar-section-label{text-transform:uppercase;letter-spacing:.08em;color:var(--text-faint);white-space:nowrap;transition:opacity var(--transition);padding:1rem .85rem .35rem;font-size:.65rem;font-weight:700;overflow:hidden}.collapsed .sidebar-section-label{opacity:0;height:0;padding:0;overflow:hidden}.sidebar-nav{flex-direction:column;flex:1;gap:2px;padding:.25rem;display:flex}.sidebar-link{border-radius:var(--radius-sm);color:var(--text-secondary);transition:color var(--transition), background var(--transition);white-space:nowrap;align-items:center;gap:.6rem;padding:.5rem .65rem;font-size:.85rem;font-weight:500;display:flex;overflow:hidden}.sidebar-link:hover{color:var(--text);background:#ffffff80}.sidebar-link.active{color:var(--coral);background:#ff7f501f;font-weight:600}.sidebar-link-icon{flex-shrink:0;width:18px;height:18px}.sidebar-link-text{transition:opacity .1s}.collapsed .sidebar-link{justify-content:center;padding:.5rem}.collapsed .sidebar-link-text{opacity:0;width:0;overflow:hidden}.sidebar-footer{border-top:1px solid var(--border-light);white-space:nowrap;padding:.85rem;overflow:hidden}.sidebar-user-row{align-items:center;gap:.5rem;display:flex}.sidebar-avatar{background:var(--coral-bg);width:30px;height:30px;color:var(--coral);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.72rem;font-weight:700;display:flex;overflow:hidden}.sidebar-avatar img{object-fit:cover;border-radius:50%;width:100%;height:100%}.sidebar-user-name{color:var(--text);text-overflow:ellipsis;flex:1;min-width:0;font-size:.8rem;font-weight:500;overflow:hidden}.sidebar-logout{color:var(--text-faint);cursor:pointer;transition:color var(--transition);background:0 0;border:none;flex-shrink:0;align-items:center;padding:.15rem;display:flex}.sidebar-logout:hover{color:var(--red)}.collapsed .sidebar-user-row .sidebar-user-name{display:none}.collapsed .sidebar-footer{text-align:center}.collapsed .sidebar-logout{font-size:0}.collapsed .sidebar-logout:after{content:"←";color:var(--text-faint);font-size:.85rem}.sidebar-main{margin-left:var(--sidebar-w);flex:1;transition:margin-left .2s}.sidebar-collapsed .sidebar-main{margin-left:var(--sidebar-collapsed-w)}.sidebar-main-inner{max-width:960px;margin:0 auto;padding:1.5rem clamp(1rem,3vw,2rem);animation:.4s fade-up}.class-detail{max-width:100%}.class-detail-header{justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.25rem;display:flex}.class-detail-header h1{letter-spacing:-.02em;font-size:1.5rem;font-weight:800}.class-detail-actions{gap:.5rem;display:flex}.class-detail-desc{color:var(--text-secondary);margin-bottom:1rem;font-size:.88rem;line-height:1.5}.class-detail-code{font-family:var(--font-mono);background:var(--bg-alt);border-radius:var(--radius-xs);color:var(--text-secondary);letter-spacing:.04em;padding:.2rem .6rem;font-size:.75rem;font-weight:600}.class-detail-invite{align-items:center;gap:.5rem;margin-top:.4rem;display:flex}.tabs{border-bottom:2px solid var(--border-light);flex-wrap:wrap;gap:0;margin-bottom:1.25rem;display:flex}.tab{color:var(--text-tertiary);transition:color var(--transition), border-color var(--transition);white-space:nowrap;cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-2px;padding:.6rem 1rem;font-size:.85rem;font-weight:500}.tab:hover{color:var(--text)}.tab.active{color:var(--coral);border-bottom-color:var(--coral);font-weight:600}.tab-header{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.tab-header h2{font-size:1rem;font-weight:700}.tab-ai-btn{color:var(--coral)!important}.tab-ai-btn:hover{background:var(--coral-bg)!important}.fab-ai{background:var(--coral);color:#fff;cursor:pointer;z-index:50;border:none;border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;transition:transform .15s,box-shadow .15s;display:flex;position:fixed;bottom:1.5rem;right:1.5rem;box-shadow:0 4px 14px #0003}.fab-ai:hover{transform:scale(1.08);box-shadow:0 6px 20px #00000040}.empty-state{text-align:center;color:var(--text-tertiary);padding:3rem 1rem}.empty-state-icon{opacity:.15;width:56px;height:56px;margin-bottom:1rem}.empty-state p{margin-bottom:.5rem;font-size:.9rem}.empty-state-sm{color:var(--text-tertiary);padding:1rem 0;font-size:.85rem}.status-badge{text-transform:uppercase;letter-spacing:.04em;white-space:nowrap;border-radius:999px;align-items:center;gap:.3rem;padding:.15rem .5rem;font-size:.7rem;font-weight:600;display:inline-flex}.status-dot{border-radius:50%;width:6px;height:6px}.status-scheduled{background:var(--bg-alt);color:var(--text-tertiary)}.status-scheduled .status-dot{background:var(--text-faint)}.status-live{background:var(--red-bg);color:var(--red)}.status-live .status-dot{background:var(--red);animation:2s infinite pulse-dot}.status-completed{background:var(--green-bg);color:var(--green)}.status-completed .status-dot{background:var(--green)}.status-cancelled{background:var(--bg-alt);color:var(--text-faint)}.status-cancelled .status-dot{background:var(--text-faint)}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.3}}.card{border:1px solid var(--border-light);border-radius:var(--radius-sm);transition:box-shadow var(--transition);background:#fff}.card:hover{box-shadow:var(--shadow-sm)}.card-body{padding:.85rem 1rem}.mural-composer{border:1px solid var(--border-light);border-radius:var(--radius-sm);background:#fff;margin-bottom:1rem;padding:.75rem}.mural-composer-toolbar{border-bottom:1px solid var(--border-light);gap:0;margin-bottom:.5rem;padding-bottom:.4rem;display:flex}.mural-toolbar-btn{color:var(--text-tertiary);border-radius:var(--radius-xs);cursor:pointer;transition:color var(--transition), background var(--transition);background:0 0;border:none;padding:.2rem .6rem;font-size:.78rem;font-weight:500}.mural-toolbar-btn:hover{color:var(--text)}.mural-toolbar-btn.active{color:var(--text);background:var(--bg-alt);font-weight:600}.mural-preview{min-height:60px;padding:.5rem 0}.mural-composer-input{resize:none;width:100%;color:var(--text);background:0 0;border:none;outline:none;min-height:80px;font-size:.88rem;line-height:1.5}.mural-composer-input::placeholder{color:var(--text-faint)}.mural-composer-actions{justify-content:space-between;align-items:center;gap:.5rem;margin-top:.5rem;display:flex}.markdown-body{color:var(--text);word-wrap:break-word;font-size:.88rem;line-height:1.6}.markdown-body p{margin:0 0 .5rem}.markdown-body p:last-child{margin-bottom:0}.markdown-body strong{font-weight:600}.markdown-body em{font-style:italic}.markdown-body code{background:var(--bg-alt);font-family:var(--font-mono);color:var(--coral);border-radius:3px;padding:.15rem .4rem;font-size:.82rem}.markdown-body pre{background:var(--bg-ink);color:#e0e0e0;border-radius:var(--radius-xs);margin:.5rem 0;padding:.75rem 1rem;overflow-x:auto}.markdown-body pre code{color:inherit;background:0 0;padding:0}.markdown-body a{color:var(--coral);text-underline-offset:2px;-webkit-text-decoration:underline #ff7f504d;text-decoration:underline #ff7f504d}.markdown-body a:hover{-webkit-text-decoration-color:var(--coral);text-decoration-color:var(--coral)}.markdown-body ul,.markdown-body ol{margin:.25rem 0;padding-left:1.5rem}.markdown-body li{margin:.15rem 0}.markdown-body blockquote{border-left:3px solid var(--coral);color:var(--text-secondary);margin:.5rem 0;padding-left:.75rem}.markdown-body hr{border:none;border-top:1px solid var(--border-light);margin:.75rem 0}.markdown-body h1,.markdown-body h2,.markdown-body h3{margin:.5rem 0 .25rem;font-weight:600}.markdown-body h1{font-size:1.15rem}.markdown-body h2{font-size:1rem}.markdown-body h3{font-size:.92rem}.markdown-body table{border-collapse:collapse;width:100%;margin:.5rem 0}.markdown-body th,.markdown-body td{border:1px solid var(--border-light);text-align:left;padding:.35rem .6rem;font-size:.82rem}.markdown-body th{background:var(--bg-alt);font-weight:600}.markdown-body img{border-radius:var(--radius-xs);max-width:100%}.post-list{flex-direction:column;gap:0;display:flex}.post-item{border-bottom:1px solid var(--border-light);padding:1rem 0}.post-item:last-child{border-bottom:none}.post-header{align-items:center;gap:.5rem;margin-bottom:.4rem;display:flex}.post-avatar{background:var(--bg-alt);width:28px;height:28px;color:var(--text-secondary);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.7rem;font-weight:700;display:flex}.post-author{color:var(--text);font-size:.82rem;font-weight:600}.post-time{color:var(--text-faint);margin-left:auto;font-size:.72rem}.post-body{color:var(--text);margin-left:2.25rem;font-size:.88rem;line-height:1.6}.post-actions{gap:.5rem;margin-top:.4rem;margin-left:2.25rem;display:flex}.post-action-btn{color:var(--text-faint);cursor:pointer;border-radius:var(--radius-xs);transition:color var(--transition), background var(--transition);background:0 0;border:none;align-items:center;gap:.3rem;padding:.2rem .4rem;font-size:.78rem;display:inline-flex}.post-action-btn:hover{color:var(--text-secondary);background:var(--bg-hover)}.post-replies{border-left:2px solid var(--border-light);margin-top:.5rem;margin-left:2.25rem;padding-left:.75rem}.reply-item{padding:.5rem 0}.reply-item+.reply-item{border-top:1px solid var(--border-light)}.reply-form{align-items:flex-start;gap:.5rem;margin-top:.5rem;margin-left:2.25rem;display:flex}.reply-form input{border-radius:var(--radius-xs);border:1px solid var(--border);outline:none;flex:1;padding:.4rem .6rem;font-size:.82rem}.reply-form input:focus{border-color:var(--border-focus)}.meeting-list{flex-direction:column;gap:.5rem;display:flex}.meeting-list>*{animation:.35s backwards slide-in-right}.meeting-list>:first-child{animation-delay:0s}.meeting-list>:nth-child(2){animation-delay:40ms}.meeting-list>:nth-child(3){animation-delay:80ms}.meeting-list>:nth-child(4){animation-delay:.12s}.meeting-list>:nth-child(5){animation-delay:.16s}.meeting-list>:nth-child(n+6){animation-delay:.2s}.meeting-card{border:1px solid var(--border-light);border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition), box-shadow var(--transition);background:#fff;justify-content:space-between;align-items:center;gap:1rem;padding:.85rem 1rem;display:flex;position:relative}.meeting-card:hover{background:var(--bg-hover);box-shadow:var(--shadow-md)}.meeting-info{flex:1;min-width:0}.meeting-title{color:var(--text);align-items:center;gap:.5rem;font-size:.9rem;font-weight:600;display:flex}.meeting-meta{color:var(--text-tertiary);margin-top:.15rem;font-size:.78rem}.meeting-actions{flex-shrink:0;gap:.4rem;display:flex}.meeting-card-live{background:linear-gradient(135deg,#fff 90%,#dc262608);border-color:#dc262633}.meeting-card-live:before{background:var(--red)!important}.meeting-card-live:hover{border-color:#dc26264d;box-shadow:0 3px 14px #dc26261a}.meeting-detail-meta{color:var(--text-secondary);align-items:center;gap:.75rem;margin-bottom:1rem;font-size:.85rem;display:flex}.meeting-detail-actions{margin-bottom:1rem}.meeting-section{margin-bottom:1.25rem}.meeting-section h3{color:var(--text);margin-bottom:.5rem;font-size:.85rem;font-weight:600}.attendance-list{flex-direction:column;gap:.25rem;display:flex}.attendance-row{border-radius:var(--radius-xs);align-items:center;gap:.75rem;padding:.4rem .6rem;font-size:.82rem;display:flex}.attendance-name{color:var(--text);font-size:.82rem;font-weight:500}.attendance-time{color:var(--text-tertiary);font-size:.78rem}.attendance-duration{color:var(--text-tertiary);margin-left:auto;font-size:.78rem}.recording-list{flex-direction:column;gap:.5rem;display:flex}.recording-card{border-radius:var(--radius-sm);border:1px solid var(--border-light);background:#fff;flex-wrap:wrap;align-items:center;gap:.75rem;padding:.75rem;display:flex}.recording-info{flex-direction:column;flex:1;display:flex}.recording-info span:first-child{font-size:.85rem;font-weight:500}.recording-meta{color:var(--text-tertiary);font-size:.72rem}.recording-actions{gap:.35rem;display:flex}.summary-content{border-radius:var(--radius-xs);background:var(--bg-alt);border:1px solid var(--border-light);flex-basis:100%;margin-top:.5rem;padding:.75rem}.summary-header{color:var(--coral);border-bottom:1px solid var(--border-light);align-items:center;gap:.4rem;margin-bottom:.5rem;padding-bottom:.4rem;font-size:.78rem;font-weight:600;display:flex}.summary-content .markdown-body{max-height:400px;font-size:.85rem;line-height:1.6;overflow-y:auto}.summary-content .markdown-body h2{margin:.75rem 0 .4rem;font-size:1rem}.summary-content .markdown-body h3{margin:.6rem 0 .3rem;font-size:.92rem}.summary-content .markdown-body ul,.summary-content .markdown-body ol{margin:.3rem 0;padding-left:1.2rem}.summary-content .markdown-body li{margin:.15rem 0}.summary-content .markdown-body p{margin:.3rem 0}.transcript-content{border-radius:var(--radius-xs);background:var(--bg-alt);flex-basis:100%;max-height:200px;margin-top:.5rem;padding:.75rem;font-size:.82rem;overflow-y:auto}.transcript-line{border-bottom:1px solid var(--border-light);gap:.5rem;padding:.3rem 0;line-height:1.5;display:flex}.transcript-line:last-child{border-bottom:none}.transcript-line strong{color:var(--coral);white-space:nowrap;font-size:.78rem}.transcript-time{color:var(--text-faint);font-family:var(--font-mono);white-space:nowrap;font-size:.7rem}.activity-list{flex-direction:column;gap:.5rem;display:flex}.activity-list>*{animation:.35s backwards slide-in-right}.activity-list>:first-child{animation-delay:0s}.activity-list>:nth-child(2){animation-delay:40ms}.activity-list>:nth-child(3){animation-delay:80ms}.activity-list>:nth-child(4){animation-delay:.12s}.activity-list>:nth-child(5){animation-delay:.16s}.activity-list>:nth-child(n+6){animation-delay:.2s}.activity-card{border:1px solid var(--border-light);border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition), box-shadow var(--transition);background:#fff;justify-content:space-between;align-items:center;gap:1rem;padding:.85rem 1rem;display:flex}.activity-card:hover{background:var(--bg-hover);box-shadow:var(--shadow-sm)}.activity-info{flex:1;min-width:0}.activity-type-badge{text-transform:uppercase;letter-spacing:.05em;border-radius:var(--radius-xs);margin-right:.4rem;padding:.1rem .4rem;font-size:.65rem;font-weight:700;display:inline-block}.badge-assignment{background:var(--coral-bg);color:var(--coral)}.badge-quiz{background:var(--violet-bg);color:var(--violet)}.badge-discussion{background:var(--green-bg);color:var(--green)}.activity-title{font-size:.9rem;font-weight:600}.activity-desc{color:var(--text-secondary);margin-top:.15rem;font-size:.82rem}.activity-meta{color:var(--text-faint);gap:.75rem;margin-top:.25rem;font-size:.75rem;display:flex}.activity-card-actions{flex-shrink:0;display:flex}.activity-detail-desc{color:var(--text-secondary);margin-bottom:.5rem;font-size:.88rem;line-height:1.5}.activity-detail-meta{color:var(--text-tertiary);gap:1rem;margin-bottom:1rem;font-size:.82rem;display:flex}.submit-form{border-radius:var(--radius-sm);border:1px solid var(--border-light);background:#fff;flex-direction:column;gap:.75rem;padding:.85rem;display:flex}.submissions-list{flex-direction:column;gap:.5rem;display:flex}.submissions-list h4{margin-bottom:.25rem;font-size:.85rem;font-weight:600}.submission-card{border-radius:var(--radius-sm);border:1px solid var(--border-light);background:#fff;flex-wrap:wrap;align-items:flex-start;gap:1rem;padding:.75rem;display:flex}.submission-info{flex:1;min-width:0}.submission-info p{color:var(--text-secondary);margin-bottom:.2rem;font-size:.85rem}.submission-author{color:var(--violet);margin-bottom:.2rem;font-size:.8rem;font-weight:600;display:block}.submission-file{color:var(--text-tertiary);margin-bottom:.15rem;font-size:.78rem;display:block}.submission-dl-link{color:var(--coral);margin-left:.4rem;font-size:.72rem;font-weight:500;text-decoration:none}.submission-dl-link:hover{text-decoration:underline}.submission-date{color:var(--text-faint);font-size:.7rem;display:block}.submission-grade-area{flex-shrink:0}.submission-grade{text-align:right}.grade-score{color:var(--coral);font-size:1rem;font-weight:700;display:block}.grade-feedback{color:var(--text-secondary);max-width:200px;margin-top:.2rem;font-size:.82rem}.grade-form{border-radius:var(--radius-sm);border:1px solid var(--border-light);background:var(--bg-alt);flex-direction:column;gap:.5rem;min-width:180px;padding:.75rem;display:flex}.material-list{flex-direction:column;gap:.5rem;display:flex}.material-card{border:1px solid var(--border-light);border-radius:var(--radius-sm);transition:background var(--transition);background:#fff;align-items:center;gap:.75rem;padding:.75rem 1rem;display:flex}.material-icon{border-radius:var(--radius-xs);background:var(--bg-alt);width:32px;height:32px;color:var(--text-tertiary);flex-shrink:0;justify-content:center;align-items:center;display:flex}.material-info{flex:1;min-width:0}.material-name{font-size:.88rem;font-weight:500}.material-size{color:var(--text-faint);font-size:.72rem}.material-actions{gap:.25rem;display:flex}.material-library-list{flex-direction:column;gap:.5rem;display:flex}.material-library-card{border:1px solid var(--border-light);border-radius:var(--radius-sm);background:#fff;align-items:center;gap:.75rem;padding:.85rem 1rem;display:flex}.material-library-info{flex-direction:column;flex:1;gap:.2rem;display:flex}.material-library-title{font-size:.88rem;font-weight:500}.material-library-meta{color:var(--text-faint);gap:.75rem;font-size:.72rem;display:flex}.material-library-classes{flex-wrap:wrap;gap:.3rem;margin-top:.3rem;display:flex}.material-class-badge{border:1px solid;border-radius:999px;align-items:center;gap:.2rem;padding:.1rem .5rem;font-size:.68rem;font-weight:500;display:inline-flex}.material-library-actions{gap:.25rem;display:flex}.share-class-list{flex-direction:column;gap:.4rem;display:flex}.share-class-row{border-radius:var(--radius-sm);border:1px solid var(--border-light);background:#fff;justify-content:space-between;align-items:center;padding:.6rem .75rem;display:flex}.share-class-info{align-items:center;gap:.5rem;display:flex}.share-class-dot{border-radius:50%;width:10px;height:10px}.share-class-name{font-size:.88rem;font-weight:500}.share-unshare-btn{color:var(--red);padding:.25rem .6rem;font-size:.78rem}.share-add-btn{padding:.25rem .6rem;font-size:.78rem}.upload-form{flex-wrap:wrap;align-items:stretch;gap:.5rem;margin-bottom:1rem;display:flex}.upload-form input[type=text],.upload-form input:not([type=file]){border:1px solid var(--border);border-radius:var(--radius-sm);min-width:200px;font-family:var(--font-body);outline:none;flex:1;padding:.5rem .75rem;font-size:.88rem}.upload-form input:focus{border-color:var(--border-focus)}.upload-file-label{border-radius:var(--radius-sm);border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;transition:border-color var(--transition);white-space:nowrap;text-overflow:ellipsis;background:#fff;align-items:center;gap:.4rem;max-width:280px;min-height:38px;padding:.5rem .85rem;font-size:.82rem;display:inline-flex;overflow:hidden}.upload-file-label:hover{border-color:var(--text-tertiary)}.upload-file-label input[type=file]{display:none}.people-teacher{background:var(--coral-50);border-radius:var(--radius-sm);border:1px solid #ff7f5026;align-items:center;gap:.75rem;margin-bottom:1rem;padding:.85rem 1rem;display:flex}.people-teacher .post-avatar{background:var(--coral);color:#fff}.people-teacher-name{font-size:.9rem;font-weight:600}.people-teacher-role{color:var(--coral);text-transform:uppercase;letter-spacing:.05em;font-size:.72rem;font-weight:600}.people-list{flex-direction:column;gap:.25rem;display:flex}.people-item{border-radius:var(--radius-sm);transition:background var(--transition);align-items:center;gap:.75rem;padding:.6rem 1rem;display:flex}.people-item:hover{background:var(--bg-hover)}.people-name{flex:1;font-size:.88rem;font-weight:500}.people-email{color:var(--text-tertiary);font-size:.78rem}.dashboard-header{margin-bottom:1.75rem}.dashboard-header h1{letter-spacing:-.02em;font-size:1.6rem;font-weight:800}.dashboard-subtitle{color:var(--text-tertiary);margin-top:.2rem;font-size:.88rem}.stat-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:.75rem;margin-bottom:2rem;display:grid}.stat-grid>*{animation:.4s backwards fade-up}.stat-grid>:first-child{animation-delay:0s}.stat-grid>:nth-child(2){animation-delay:60ms}.stat-grid>:nth-child(3){animation-delay:.12s}.stat-grid>:nth-child(4){animation-delay:.18s}.stat-grid>:nth-child(5){animation-delay:.24s}.stat-card{border-radius:var(--radius-sm);border:1px solid var(--border-light);background:#fff;flex-direction:column;padding:1rem;display:flex}.stat-card .stat-icon{border-radius:var(--radius-sm);justify-content:center;align-items:center;width:32px;height:32px;margin-bottom:.5rem;display:flex}.stat-card:first-child .stat-icon{background:var(--coral-bg);color:var(--coral)}.stat-card:nth-child(2) .stat-icon{background:var(--teal-bg);color:var(--teal)}.stat-card:nth-child(3) .stat-icon{background:var(--amber-bg);color:var(--amber)}.stat-card:nth-child(4) .stat-icon{background:var(--violet-bg);color:var(--violet)}.stat-card:nth-child(5) .stat-icon{background:var(--green-bg);color:var(--green)}.stat-value{color:var(--text);letter-spacing:-.03em;margin-bottom:.15rem;font-size:2rem;font-weight:800;line-height:1}.stat-label{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em;font-size:.72rem;font-weight:600}.dashboard-section{margin-bottom:1.5rem}.dashboard-section-header{justify-content:space-between;align-items:center;margin-bottom:.75rem;display:flex}.dashboard-section-header h2{font-size:1rem;font-weight:700}.dashboard-link{color:var(--coral);font-size:.82rem;font-weight:500}.upcoming-list{flex-direction:column;gap:.5rem;display:flex}.upcoming-card{border-radius:var(--radius-sm);border:1px solid var(--border-light);background:#fff;justify-content:space-between;align-items:center;padding:.75rem 1rem;display:flex}.upcoming-info strong{font-size:.88rem}.upcoming-meta{color:var(--text-tertiary);font-size:.78rem;display:block}.upcoming-date{color:var(--text-tertiary);white-space:nowrap;font-size:.82rem}.page-header{justify-content:space-between;align-items:center;margin-bottom:1.25rem;display:flex}.page-header h1{letter-spacing:-.02em;font-size:1.5rem;font-weight:800}.aggregate-section{margin-bottom:1.5rem}.aggregate-section h2{color:var(--text-secondary);margin-bottom:.5rem;font-size:.95rem;font-weight:600}.aggregate-list{flex-direction:column;gap:.5rem;display:flex}.aggregate-card{border-radius:var(--radius-sm);border:1px solid var(--border-light);transition:box-shadow var(--transition);background:#fff;justify-content:space-between;align-items:center;gap:1rem;padding:.75rem 1rem;display:flex}.aggregate-card:hover{box-shadow:var(--shadow-sm)}.aggregate-card-link{color:inherit;text-decoration:none;display:block}.aggregate-card-link .aggregate-card{cursor:pointer}.aggregate-color-bar{border-radius:2px;flex-shrink:0;width:4px;height:32px}.aggregate-info{flex:1;min-width:0}.aggregate-top{align-items:center;gap:.5rem;margin-bottom:.15rem;display:flex}.aggregate-top h3{font-size:.9rem;font-weight:500}.aggregate-meta{color:var(--text-tertiary);gap:.75rem;font-size:.78rem;display:flex}.aggregate-class-badge{text-transform:uppercase;letter-spacing:.05em;border-radius:var(--radius-xs);background:var(--bg-alt);color:var(--text-tertiary);margin-right:.4rem;padding:.1rem .4rem;font-size:.65rem;font-weight:700}.aggregate-link{color:var(--coral);font-size:.85rem;font-weight:500}.aggregate-link:hover{text-decoration:underline}.aggregate-actions{flex-shrink:0;align-items:center;gap:.5rem;display:flex}.aggregate-chevron{color:var(--text-faint);flex-shrink:0}.filter-tabs{gap:.35rem;margin-bottom:1rem;padding-bottom:.25rem;display:flex;overflow-x:auto}.filter-tab{border-radius:var(--radius-xs);border:1px solid var(--border-light);color:var(--text-secondary);cursor:pointer;white-space:nowrap;transition:background var(--transition), border-color var(--transition), color var(--transition);background:#fff;align-items:center;gap:.35rem;padding:.35rem .75rem;font-size:.82rem;font-weight:500;display:inline-flex}.filter-tab:hover{background:var(--bg-hover)}.filter-tab.active{background:var(--bg-active);border-color:var(--coral);color:var(--coral)}.filter-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.class-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:.75rem;margin-top:1rem;display:grid}.class-card{border:1px solid var(--border-light);border-radius:var(--radius-sm);transition:box-shadow var(--transition);background:#fff;flex-direction:column;gap:.4rem;padding:1.1rem;display:flex}.class-card:hover{box-shadow:var(--shadow-md)}.class-card h3{font-size:.95rem;font-weight:700}.class-card p{color:var(--text-tertiary);font-size:.82rem}.class-card-code{font-family:var(--font-mono);color:var(--text-faint);margin-top:auto;font-size:.72rem}.classroom{background:#0a0a0a;flex-direction:column;display:flex;position:fixed;inset:0;overflow:hidden}.classroom-topbar{z-index:20;background:#111;border-bottom:1px solid #ffffff0f;flex-shrink:0;align-items:center;gap:.75rem;padding:.5rem 1rem;display:flex}.classroom-topbar-btn{color:#ffffffb3;cursor:pointer;background:0 0;border:1px solid #ffffff1a;border-radius:6px;align-items:center;gap:.3rem;padding:.35rem .7rem;font-size:.8rem;transition:background .15s;display:inline-flex}.classroom-topbar-btn:hover{background:#ffffff0f}.classroom-error{color:#fff;background:#0a0a0a;flex-direction:column;justify-content:center;align-items:center;gap:1rem;height:100vh;display:flex}.classroom-error button{background:var(--coral);color:#fff;cursor:pointer;border:none;border-radius:8px;padding:.5rem 1rem}.classroom-topbar-title{text-align:center;color:#ffffff80;flex:1;font-size:.82rem;font-weight:500}.classroom-topbar-right{gap:.5rem;display:flex}.classroom-rec-start,.classroom-rec-stop{cursor:pointer;border-radius:999px;align-items:center;gap:.35rem;padding:.35rem .75rem;font-size:.78rem;font-weight:500;transition:all .15s;display:inline-flex}.classroom-rec-start{color:#ffffffb3;background:#ffffff0d;border:1px solid #ffffff26}.classroom-rec-start:hover{background:#ffffff1a}.classroom-rec-stop{color:#f87171;background:#ef444414;border:1px solid #ef444466}.classroom-rec-stop:hover{background:#ef444426}@keyframes rec-pulse{0%,to{opacity:1}50%{opacity:.2}}.classroom-rec-dot{background:#ef4444;border-radius:50%;width:6px;height:6px;animation:1.2s ease-in-out infinite rec-pulse}.classroom-room{flex:1;position:relative;overflow:hidden}.classroom-room>div{height:100%!important}.classroom-inner{flex-direction:column;height:100%;display:flex}.classroom-main-row{flex:1;min-height:0;display:flex;overflow:hidden}.classroom-grid-area{flex:1;min-width:0;padding:.5rem;overflow:hidden}.classroom-grid-area .lk-grid-layout{gap:.5rem!important}.classroom-tile{position:relative;overflow:hidden;background:#1a1a1a!important;border:1px solid #ffffff0a!important;border-radius:10px!important}.classroom-tile:hover{border-color:#ffffff1a!important}.classroom-focus-layout{gap:4px;height:100%;display:flex}.classroom-focus-main{flex:1;min-width:0}.classroom-focus-sidebar{flex-direction:column;gap:4px;width:160px;display:flex;overflow-y:auto}.classroom-tile-screen{width:100%;height:100%}.classroom-tile-small{aspect-ratio:16/9;width:100%}.classroom-tile-name{color:#ffffffd9;z-index:2;background:linear-gradient(#0000,#0009);padding:.5rem .75rem;font-size:.78rem;font-weight:500;position:absolute;bottom:0;left:0;right:0}.classroom-chat{background:#111;border-left:1px solid #ffffff0f;flex-direction:column;flex-shrink:0;width:0;min-width:0;transition:width .2s,min-width .2s;display:flex;overflow:hidden}.classroom-chat.open{width:340px;min-width:340px}.classroom-chat-custom-header{color:#ffffffb3;border-bottom:1px solid #ffffff0f;flex-shrink:0;justify-content:space-between;align-items:center;padding:.6rem .85rem;font-size:.82rem;font-weight:600;display:flex}.classroom-chat-close{color:#ffffff80;cursor:pointer;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;width:28px;height:28px;transition:background .15s,color .15s;display:flex}.classroom-chat-close:hover{color:#ffffffe6;background:#ffffff14}.classroom-chat-body{flex-direction:column;flex:1;min-height:0;display:flex;overflow:hidden}.meeting-chat{color:#ffffffd9;flex-direction:column;width:100%;height:100%;font-size:.82rem;display:flex}.meeting-chat-messages{flex-direction:column;flex:1;gap:.1rem;min-height:0;padding:.5rem;display:flex;overflow-y:auto}.meeting-chat-msg{border-radius:8px;padding:.35rem .5rem;transition:background .15s;position:relative}.meeting-chat-msg:hover{background:#ffffff0a}.meeting-chat-msg.mine .meeting-chat-msg-name{color:var(--coral)}.meeting-chat-msg-header{align-items:center;gap:.4rem;margin-bottom:.1rem;display:flex}.meeting-chat-msg-name{color:#ffffff8c;font-size:.72rem;font-weight:600}.meeting-chat-msg-time{color:#ffffff40;font-size:.65rem}.meeting-chat-msg-edited{color:#fff3;font-size:.6rem;font-style:italic}.meeting-chat-msg-content{word-break:break-word;font-size:.82rem;line-height:1.35}.meeting-chat-msg-actions{gap:.15rem;display:none;position:absolute;top:2px;right:4px}.meeting-chat-msg:hover .meeting-chat-msg-actions,.meeting-chat-msg:focus-within .meeting-chat-msg-actions{display:flex}.meeting-chat-msg-action{color:#ffffff73;cursor:pointer;background:#ffffff0f;border:none;border-radius:4px;justify-content:center;align-items:center;width:32px;height:32px;font-size:.75rem;transition:background .15s,color .15s;display:flex}.meeting-chat-msg-action:hover{color:#fffc;background:#ffffff1f}.meeting-chat-msg-action.danger:hover{color:#f44}.meeting-chat-reply-ref{color:#ffffff4d;border-left:2px solid #ffffff26;border-radius:0 4px 4px 0;margin-bottom:.15rem;padding:.15rem .4rem;font-size:.7rem}.meeting-chat-reply-ref-author{margin-right:.3rem;font-weight:600}.meeting-chat-reply-ref-text{opacity:.7}.meeting-chat-reply-bar{color:#ffffff73;background:#ffffff0a;border-top:1px solid #ffffff0f;align-items:center;gap:.5rem;padding:.4rem .65rem;font-size:.75rem;display:flex}.meeting-chat-reply-bar button{color:#fff6;cursor:pointer;background:0 0;border:none;margin-left:auto;padding:2px}.meeting-chat-reply-bar button:hover{color:#fffc}.meeting-chat-input-area{border-top:1px solid #ffffff0f;flex-shrink:0;align-items:center;gap:.4rem;padding:.5rem;display:flex}.meeting-chat-input-area textarea{resize:none;color:#ffffffd9;font-family:var(--font-body);background:#ffffff0f;border:1px solid #ffffff1a;border-radius:8px;outline:none;flex:1;padding:.45rem .65rem;font-size:.82rem;line-height:1.4;transition:border-color .15s}.meeting-chat-input-area textarea:focus{border-color:#ffffff40}.meeting-chat-input-area textarea::placeholder{color:#ffffff40}.meeting-chat-send{background:var(--coral);color:#fff;cursor:pointer;border:none;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;transition:opacity .15s;display:flex}.meeting-chat-send:disabled{opacity:.4;cursor:default}.meeting-chat-send:not(:disabled):hover{opacity:.85}.meeting-chat-edit-row{align-items:center;gap:.3rem;display:flex}.meeting-chat-edit-row input{color:#ffffffd9;font-family:var(--font-body);background:#ffffff0f;border:1px solid #ffffff26;border-radius:6px;outline:none;flex:1;padding:.25rem .5rem;font-size:.82rem}.meeting-chat-edit-row input:focus{border-color:#ffffff4d}.meeting-chat-edit-ok,.meeting-chat-edit-cancel{cursor:pointer;font-size:.72rem;font-family:var(--font-body);border:none;border-radius:4px;padding:.2rem .5rem}.meeting-chat-edit-ok{background:var(--coral);color:#fff}.meeting-chat-edit-cancel{color:#fff9;background:#ffffff14}.meeting-chat-reactions-bar{flex-wrap:wrap;gap:.2rem;margin-top:.15rem;display:flex}.meeting-chat-reaction-chip{cursor:pointer;color:#ffffff80;background:#ffffff08;border:1px solid #ffffff14;border-radius:12px;align-items:center;gap:.15rem;padding:.05rem .4rem;font-size:.7rem;transition:background .15s;display:flex}.meeting-chat-reaction-chip.mine{color:#ffffffb3;background:#ff7f5014;border-color:#ff7f504d}.meeting-chat-reaction-chip:hover{background:#ffffff14}.meeting-chat-emoji-picker{z-index:20;background:#222;border:1px solid #ffffff1a;border-radius:8px;gap:.2rem;padding:.3rem;display:flex;position:absolute;left:4px;box-shadow:0 4px 12px #0006}.meeting-chat-emoji-btn{cursor:pointer;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;width:36px;height:36px;font-size:1rem;transition:background .15s;display:flex}.meeting-chat-emoji-btn:hover{background:#ffffff1a}.meeting-chat-attach{color:#fff6;cursor:pointer;background:0 0;border:none;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;transition:color .15s,background .15s;display:flex}.meeting-chat-attach:hover{color:#fffc;background:#ffffff0f}.meeting-chat-attach:disabled{opacity:.3;cursor:default}.meeting-chat-pending-files{background:#ffffff05;border-top:1px solid #ffffff0f;flex-wrap:wrap;gap:.3rem;padding:.4rem .5rem;display:flex}.meeting-chat-pending-file{color:#fff9;background:#ffffff0f;border-radius:6px;align-items:center;gap:.3rem;max-width:160px;padding:.2rem .5rem;font-size:.72rem;display:flex}.meeting-chat-pending-file-name{text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.meeting-chat-pending-file-remove{color:#ffffff4d;cursor:pointer;background:0 0;border:none;align-items:center;padding:0;display:flex}.meeting-chat-pending-file-remove:hover{color:#ffffffb3}.meeting-chat-attachments{flex-direction:column;gap:.25rem;margin-top:.25rem;display:flex}.meeting-chat-attachment{border-radius:6px;overflow:hidden}.meeting-chat-attachment-preview,.meeting-chat-attachment-file{background:#ffffff0a;border-radius:6px;align-items:center;gap:.35rem;padding:.25rem .5rem;font-size:.75rem;display:flex}.meeting-chat-attachment a{color:#ffffffb3;text-overflow:ellipsis;white-space:nowrap;text-decoration:none;overflow:hidden}.meeting-chat-attachment a:hover{color:var(--coral)}.meeting-chat-attachment-size{color:#ffffff40;font-size:.65rem}.classroom-controls{z-index:10;background:#111;border-top:1px solid #ffffff0f;flex-shrink:0;justify-content:space-between;align-items:center;padding:.6rem 1rem;display:flex}.classroom-controls-left,.classroom-controls-center,.classroom-controls-right{align-items:center;gap:.4rem;display:flex}.classroom-toggle-btn,.classroom .classroom-controls .lk-button{color:#ffffffd9!important;cursor:pointer!important;background:#ffffff14!important;border:none!important;border-radius:10px!important;justify-content:center!important;align-items:center!important;width:42px!important;height:42px!important;padding:0!important;font-size:0!important;line-height:1!important;transition:background .15s,color .15s!important;display:inline-flex!important}.classroom-toggle-btn:hover,.classroom .classroom-controls .lk-button:hover{background:#ffffff26!important}.classroom-toggle-btn svg,.classroom .classroom-controls .lk-button svg{width:20px!important;height:20px!important}.classroom .classroom-controls .lk-button[aria-pressed=false][data-lk-enabled=false]{color:#f87171!important;background:#ef444426!important}.classroom .classroom-controls .lk-button[data-lk-source=screen_share][data-lk-enabled=true]{color:#60a5fa!important;background:#3b82f626!important}.classroom-ctrl-btn{color:#f87171;cursor:pointer;background:#ef44441f;border:none;border-radius:8px;align-items:center;gap:.4rem;padding:.5rem 1.25rem;font-size:.82rem;font-weight:500;transition:background .15s;display:inline-flex}.classroom-ctrl-btn:hover{background:#ef444438}.classroom-chat-toggle{color:#ffffffd9;cursor:pointer;background:#ffffff14;border:none;border-radius:10px;justify-content:center;align-items:center;width:42px;height:42px;transition:background .15s,color .15s;display:inline-flex}.classroom-chat-toggle:hover{background:#ffffff26}.classroom-chat-toggle.active{color:#a78bfa;background:#8b5cf633}.classroom .lk-focus-layout-container{height:100%!important}.classroom .lk-media-device-select{display:none}.classroom .lk-control-bar{display:none!important}.classroom .lk-device-selector button{color:#ffffffb3!important}.classroom-toolbar{z-index:10;background:#1e1e1e;border-bottom:1px solid #ffffff14;align-items:center;gap:.75rem;padding:.5rem 1rem;display:flex}.classroom-rec-btn{color:#ffffffd9;cursor:pointer;transition:all var(--transition);background:#ffffff0f;border:1px solid #fff3;border-radius:999px;align-items:center;gap:.35rem;padding:.4rem .9rem;font-size:.78rem;font-weight:500;display:inline-flex}.classroom-rec-btn:hover{background:#ffffff1f;border-color:#ffffff59}.classroom-rec-btn:disabled{opacity:.35;cursor:not-allowed}.classroom-rec-active{color:#f87171;background:#ef44441a;border-color:#ef444499}.classroom-rec-hint{color:#ffffff4d;margin-right:auto;font-size:.75rem}.onboarding-page{background:var(--bg);justify-content:center;align-items:center;min-height:100vh;padding:2rem;display:flex}.onboarding-card{border-radius:var(--radius);border:1px solid var(--border-light);text-align:center;background:#fff;width:100%;max-width:480px;padding:2.5rem}.onboarding-progress{justify-content:center;gap:.4rem;margin-bottom:1.5rem;display:flex}.onboarding-dot{background:var(--border);border-radius:50%;width:6px;height:6px;transition:background .3s,transform .3s}.onboarding-dot.active{background:var(--coral);transform:scale(1.3)}.onboarding-dot.done{background:var(--coral)}.onboarding-step-label{font-family:var(--font-mono);letter-spacing:.12em;text-transform:uppercase;color:var(--coral);margin-bottom:.5rem;font-size:.6rem;font-weight:700}.onboarding-card h1{margin-bottom:.35rem;font-size:1.35rem;font-weight:600}.onboarding-desc{color:var(--text-secondary);margin-bottom:1.5rem;font-size:.88rem;line-height:1.6}.onboarding-form{text-align:left;flex-direction:column;gap:.75rem;display:flex}.onboarding-form input{border-radius:var(--radius-sm);border:1px solid var(--border);font-family:var(--font-body);color:var(--text);transition:border-color var(--transition);background:#fff;outline:none;padding:.6rem .85rem;font-size:.88rem}.onboarding-form input:focus{border-color:var(--coral)}.onboarding-actions{justify-content:center;gap:.75rem;margin-top:1.5rem;display:flex}.role-cards{gap:1rem;margin:1rem 0;display:flex}.role-card{border-radius:var(--radius-sm);border:2px solid var(--border-light);background:var(--bg);cursor:pointer;flex-direction:column;flex:1;align-items:center;gap:.4rem;padding:1.25rem .75rem;transition:border-color .2s,background .2s;display:flex}.role-card:hover{border-color:var(--coral)}.role-card.selected{border-color:var(--coral);background:var(--bg-active)}.role-emoji{font-size:1.75rem;line-height:1}.role-card strong{color:var(--text);font-size:.9rem}.role-card span:last-child{color:var(--text-tertiary);font-size:.75rem}.onboarding-form .code-field{text-align:left}.onboarding-form .code-field label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;margin-bottom:.3rem;font-size:.78rem;font-weight:600;display:block}.onboarding-invite{text-align:center}.onboarding-code-box{border-radius:var(--radius-sm);border:1px solid var(--border-light);background:var(--bg);flex-wrap:wrap;justify-content:center;align-items:center;gap:.75rem;margin-bottom:1rem;padding:1rem 1.25rem;display:flex}.onboarding-code-box span{color:var(--text-secondary);font-size:.82rem;font-weight:500}.onboarding-code-box code{font-family:var(--font-mono);color:var(--coral);letter-spacing:.05em;font-size:1.1rem;font-weight:700}.btn-ghost-sm{border-radius:var(--radius-xs);border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;transition:background var(--transition), border-color var(--transition);background:#fff;padding:.3rem .65rem;font-size:.78rem;font-weight:500}.btn-ghost-sm:hover{background:var(--bg-hover);border-color:var(--text-tertiary)}.onboarding-hint{color:var(--text-tertiary);margin-bottom:1rem;font-size:.82rem;line-height:1.5}.onboarding-done{text-align:left}.onboarding-tips{flex-direction:column;gap:.6rem;margin-bottom:1.5rem;padding:0;list-style:none;display:flex}.onboarding-tips li{background:var(--bg);border-radius:var(--radius-sm);border:1px solid var(--border-light);color:var(--text-secondary);padding:.65rem .85rem .65rem 2.25rem;font-size:.85rem;line-height:1.45;position:relative}.onboarding-tips li:before{content:"";background:var(--coral);border-radius:50%;width:8px;height:8px;position:absolute;top:50%;left:.85rem;transform:translateY(-50%)}.onboarding-tips li strong{color:var(--text)}.onboarding-app-icon{color:#fff;background:linear-gradient(135deg,#34a853,#0f9d58);border-radius:16px;justify-content:center;align-items:center;width:56px;height:56px;margin:0 auto 1rem;display:flex}.onboarding-app-icon-desktop{background:linear-gradient(135deg, var(--coral), #e86a3a)}.onboarding-app-section{margin:1.25rem 0}.onboarding-app-btn{border-radius:var(--radius-sm);border:1px solid var(--border);cursor:pointer;transition:background var(--transition), box-shadow var(--transition);background:#fff;align-items:center;gap:.65rem;width:100%;padding:.65rem 1.25rem;display:inline-flex}.onboarding-app-btn:hover{background:var(--bg-hover);box-shadow:var(--shadow-sm)}.onboarding-app-btn small{color:var(--text-tertiary);font-size:.65rem;font-weight:500;line-height:1;display:block}.onboarding-app-btn strong{color:var(--text);font-size:.95rem;font-weight:600;line-height:1.3;display:block}.onboarding-app-btn-text{text-align:left}.onboarding-app-hint{color:var(--text-faint);margin-top:.5rem;font-size:.72rem}.onboarding-web-link{cursor:pointer;color:var(--coral);transition:opacity var(--transition);background:0 0;border:none;align-items:center;gap:.3rem;padding:0;font-size:.82rem;font-weight:500;display:inline-flex}.onboarding-web-link:hover{opacity:.8;text-decoration:underline}.verify-icon{border-radius:50%;justify-content:center;align-items:center;width:72px;height:72px;margin-bottom:1rem;display:inline-flex}.verify-icon--success{background:var(--green-bg);color:var(--green)}.verify-icon--error{background:var(--red-bg);color:var(--red)}.verify-icon--email{color:#3b82f6;background:#3b82f61a}.mural-event-card{border-radius:var(--radius-sm);border:1px solid var(--border-light);background:#fff;align-items:center;gap:.75rem;margin:.75rem 0 .5rem;padding:.75rem 1rem;display:flex}.mural-event-live{background:#dc262608;border-color:#dc262633}.mural-event-icon-wrap{border-radius:var(--radius-xs);flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;display:flex}.mural-event-body{flex-direction:column;gap:.1rem;min-width:0;display:flex}.mural-event-label{text-transform:uppercase;letter-spacing:.05em;color:var(--text-tertiary);font-size:.68rem;font-weight:600}.mural-event-title{color:var(--text);text-overflow:ellipsis;white-space:nowrap;font-size:.88rem;font-weight:500;overflow:hidden}.mural-event-meta{color:var(--text-faint);font-size:.75rem}.mural-event-actions{flex-shrink:0;align-items:center;display:flex}.check-email-text{color:var(--text-tertiary);margin-top:.5rem;font-size:.88rem;line-height:1.5}@media (width<=768px){.app-header{gap:1rem}.app-user span{display:none}.class-detail-actions,.role-cards,.form-row{flex-direction:column}.upload-form{flex-direction:column;align-items:stretch}.meeting-card{flex-direction:column;align-items:flex-start;gap:.5rem}.activity-card,.class-detail-header,.aggregate-card{flex-direction:column;align-items:flex-start}.aggregate-actions{align-self:flex-end}.filter-tabs{flex-wrap:wrap}.stat-grid{grid-template-columns:repeat(2,1fr)}.form-actions{flex-direction:column}.form-actions .btn-primary,.form-actions .btn-secondary,.form-actions .btn-ghost{justify-content:center;width:100%}.sidebar{z-index:50;transform:translate(-100%)}.sidebar.mobile-open{transform:translate(0);box-shadow:4px 0 24px #1e1b181f}.sidebar-main,.sidebar-collapsed .sidebar-main{margin-left:0!important}.sidebar-mobile-toggle{display:flex}.sidebar-overlay{display:block}.sidebar-overlay.hidden{display:none}.reunioes-card{flex-direction:column;align-items:flex-start}.reunioes-card-actions{justify-content:flex-end;width:100%}.reunioes-card-accent{border-radius:2px 2px 0 0;width:100%;height:3px}.reunioes-hero{flex-direction:column;align-items:flex-start;gap:.75rem}.reunioes-hero-stats{align-self:flex-start}}.invite-list{flex-direction:column;gap:.35rem;display:flex}.invite-item{border-radius:var(--radius-sm);border:1px solid var(--border-light);background:#fff;justify-content:space-between;align-items:center;padding:.6rem .85rem;display:flex}.invite-item.invite-inactive{opacity:.5}.invite-info{flex-direction:column;display:flex}.invite-token{font-family:var(--font-mono);color:var(--text);font-size:.78rem;font-weight:600}.invite-meta{color:var(--text-tertiary);font-size:.72rem}.invite-results{border-top:1px solid var(--border-light);flex-direction:column;gap:.35rem;margin-top:.75rem;padding-top:.75rem;display:flex}.invite-result{border-radius:var(--radius-xs);justify-content:space-between;padding:.4rem .6rem;font-size:.82rem;display:flex}.invite-result-ok{background:var(--green-bg);color:var(--green)}.invite-result-err{background:var(--red-bg);color:var(--red)}.spin{animation:1s linear infinite spin}.color-picker{flex-wrap:wrap;gap:6px;padding:.5rem 0;display:flex}.color-swatch{border-radius:var(--radius-xs);cursor:pointer;width:28px;height:28px;transition:border-color var(--transition), transform var(--transition);border:2px solid #0000}.color-swatch:hover{transform:scale(1.15)}.color-swatch-active{border-color:var(--text);box-shadow:0 0 0 2px #fff, 0 0 0 4px var(--text)}.class-banner{border-radius:var(--radius-sm);min-height:72px;margin-bottom:.75rem;padding:.75rem 1.5rem 1rem;position:relative}.class-banner-content{z-index:1;align-items:center;gap:1rem;display:flex;position:relative}.class-banner-avatar{border-radius:var(--radius-sm);color:#fff;border:2px solid #fff6;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:1rem;font-weight:700;display:flex}.class-banner-info h1{color:#fff;margin:0;font-size:1.15rem;font-weight:600;line-height:1.3}.class-banner-info .class-banner-desc{color:#fffc;margin-top:.15rem;font-size:.82rem}.class-banner-actions{z-index:2;align-items:center;gap:.4rem;display:flex;position:absolute;top:.75rem;right:.75rem}.class-banner-btn{border-radius:var(--radius-xs);color:#fff;cursor:pointer;width:30px;height:30px;transition:background var(--transition);background:#fff3;border:none;justify-content:center;align-items:center;display:flex}.class-banner-btn:hover{background:#ffffff59}.class-card-header{align-items:center;gap:.75rem;margin-bottom:.5rem;display:flex}.class-card-avatar{border-radius:var(--radius-xs);color:#fff;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:.8rem;font-weight:700;display:flex}.settings-danger-zone{border-radius:var(--radius-sm);background:#ef444408;border:1px solid #ef444426;margin-top:1.5rem;padding:1rem}.settings-danger-zone h3{color:var(--red);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.5rem;font-size:.78rem;font-weight:700}.settings-danger-zone p{color:var(--text-tertiary);margin-bottom:.75rem;font-size:.82rem}.sidebar-mobile-toggle{z-index:45;border-radius:var(--radius-sm);border:1px solid var(--border-light);width:40px;height:40px;color:var(--text-secondary);cursor:pointer;box-shadow:var(--shadow-sm);transition:background var(--transition);background:#fff;justify-content:center;align-items:center;display:none;position:fixed;top:.5rem;left:.5rem}.sidebar-mobile-toggle:hover{background:var(--bg-hover)}.sidebar-overlay{z-index:45;background:#1e1b1833;display:none;position:fixed;inset:0}.sidebar-main-mobile-bar{display:none}@media (width<=768px){.sidebar-main-mobile-bar{background:var(--card);border-bottom:1px solid var(--border-light);z-index:30;align-items:center;gap:.75rem;height:48px;padding:.5rem 1rem;display:flex;position:sticky;top:0}.sidebar-main-mobile-bar .sidebar-mobile-toggle{box-shadow:none;background:0 0;border:none;width:auto;height:auto;padding:.25rem;display:flex;position:static}.sidebar-main-mobile-bar img{height:22px}.sidebar-main-mobile-bar span{color:var(--text-secondary);font-size:.85rem;font-weight:500}}.reunioes-page{animation:.3s page-in}@keyframes page-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.reunioes-hero{border-bottom:1px solid var(--border-light);align-items:center;gap:1rem;margin-bottom:1.5rem;padding-bottom:1rem;display:flex}.reunioes-hero-icon{border-radius:var(--radius-sm);background:linear-gradient(135deg, var(--coral), #e86a3a);color:#fff;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.reunioes-hero-text h1{font-size:1.25rem;font-weight:600;line-height:1.2}.reunioes-hero-text p{color:var(--text-tertiary);margin-top:.15rem;font-size:.82rem}.reunioes-hero-stats{flex-shrink:0;margin-left:auto}.reunioes-live-badge{background:var(--red-bg);color:var(--red);border:1px solid #dc26261f;border-radius:999px;align-items:center;gap:.4rem;padding:.35rem .75rem;font-size:.75rem;font-weight:600;display:inline-flex}.reunioes-live-dot{background:var(--red);border-radius:50%;width:7px;height:7px;animation:1.5s ease-in-out infinite pulse-dot}.reunioes-filter{gap:.35rem;margin-bottom:1.25rem;padding-bottom:.25rem;display:flex;overflow-x:auto}.reunioes-filter-btn{border:1px solid var(--border-light);color:var(--text-secondary);cursor:pointer;white-space:nowrap;transition:all var(--transition);background:#fff;border-radius:999px;align-items:center;gap:.35rem;padding:.4rem .85rem;font-size:.82rem;font-weight:500;display:inline-flex}.reunioes-filter-btn:hover{background:var(--bg-hover)}.reunioes-filter-btn.active{background:var(--text);color:#fff;border-color:var(--text)}.reunioes-filter-btn.active .reunioes-filter-dot{box-shadow:0 0 0 2px #fff6}.reunioes-filter-dot{width:8px;height:8px;transition:box-shadow var(--transition);border-radius:50%;flex-shrink:0}.reunioes-empty{text-align:center;color:var(--text-tertiary);padding:4rem 1rem}.reunioes-empty-icon{background:var(--bg-alt);width:64px;height:64px;color:var(--text-faint);border-radius:50%;justify-content:center;align-items:center;margin:0 auto 1rem;display:flex}.reunioes-empty h3{color:var(--text);margin-bottom:.35rem;font-size:1rem;font-weight:600}.reunioes-empty p{font-size:.88rem}.reunioes-section{margin-bottom:2rem}.reunioes-section-past{opacity:.85}.reunioes-section-header{justify-content:space-between;align-items:center;margin-bottom:.75rem;display:flex}.reunioes-section-label{color:var(--text-secondary);align-items:center;gap:.4rem;display:flex}.reunioes-section-label h2{color:var(--text-secondary);font-size:.92rem;font-weight:600}.reunioes-section-count{color:var(--text-faint);background:var(--bg-alt);letter-spacing:.02em;border-radius:999px;padding:.2rem .55rem;font-size:.72rem;font-weight:600}.reunioes-list{flex-direction:column;gap:.5rem;display:flex}.reunioes-card{border:1px solid var(--border-light);border-radius:var(--radius-sm);transition:box-shadow var(--transition), transform .12s ease;animation:.35s backwards card-slide-in;animation-delay:var(--card-delay,0s);background:#fff;align-items:center;gap:.75rem;padding:.7rem .85rem;display:flex;position:relative;overflow:hidden}@keyframes card-slide-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.reunioes-card:hover{box-shadow:var(--shadow-md)}.reunioes-card-accent{border-radius:2px;flex-shrink:0;align-self:stretch;width:3px;min-height:28px}.reunioes-card:hover .reunioes-card-accent{width:4px}.reunioes-card-accent-muted{background:var(--border)!important}.reunioes-card-live{border-color:#dc262626}.reunioes-card-live:hover{border-color:#dc262640;box-shadow:0 2px 10px #dc262614}.reunioes-card-past{opacity:.7;transition:opacity var(--transition), box-shadow var(--transition), transform .12s ease}.reunioes-card-past:hover{opacity:1}.reunioes-card-status{flex-shrink:0;align-items:center;display:flex}.reunioes-card-live-badge{background:var(--red);color:#fff;text-transform:uppercase;letter-spacing:.04em;white-space:nowrap;border-radius:999px;align-items:center;gap:.3rem;padding:.15rem .5rem;font-size:.65rem;font-weight:700;display:inline-flex}.reunioes-card-scheduled-badge{background:var(--bg-alt);color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.04em;border-radius:999px;align-items:center;gap:.3rem;padding:.25rem .6rem;font-size:.68rem;font-weight:600;display:inline-flex}.reunioes-card-past-badge{text-transform:uppercase;letter-spacing:.04em;border-radius:999px;padding:.2rem .55rem;font-size:.65rem;font-weight:600;display:inline-block}.reunioes-card-past-completed{background:var(--green-bg);color:var(--green)}.reunioes-card-past-cancelled{background:var(--bg-alt);color:var(--text-faint)}.reunioes-card-body{flex:1;min-width:0}.reunioes-card-body h3{color:var(--text);text-overflow:ellipsis;white-space:nowrap;font-size:.88rem;font-weight:600;overflow:hidden}.reunioes-card-meta{color:var(--text-tertiary);flex-wrap:wrap;align-items:center;gap:.4rem;font-size:.75rem;display:flex}.reunioes-card-class{align-items:center;gap:.3rem;font-weight:500;display:inline-flex}.reunioes-class-dot{border-radius:50%;flex-shrink:0;width:7px;height:7px}.reunioes-card-time{align-items:center;gap:.3rem;display:inline-flex}.reunioes-card-duration{background:var(--bg-alt);border-radius:3px;padding:.1rem .35rem;font-size:.72rem}.reunioes-card-relative{color:var(--coral);font-size:.75rem;font-weight:500}.reunioes-card-actions{flex-shrink:0;align-items:center;gap:.5rem;display:flex}.reunioes-card-join{border-radius:var(--radius-sm);background:var(--coral);color:#fff;cursor:pointer;transition:background var(--transition), transform .1s ease;white-space:nowrap;border:none;align-items:center;gap:.3rem;padding:.3rem .65rem;font-size:.78rem;font-weight:600;display:inline-flex}.reunioes-card-join:hover{background:var(--coral-hover);transform:scale(1.03)}.reunioes-card-join-live{border-radius:var(--radius-sm);background:var(--red);color:#fff;cursor:pointer;white-space:nowrap;border:none;align-items:center;gap:.3rem;padding:.3rem .65rem;font-size:.78rem;font-weight:600;transition:transform .1s;display:inline-flex}.reunioes-card-join-live:hover{transform:scale(1.03)}.reunioes-card-link{color:var(--coral);transition:opacity var(--transition);align-items:center;gap:.2rem;font-size:.8rem;font-weight:500;display:inline-flex}.reunioes-card-link:hover{opacity:.8;text-decoration:underline}.profile-page{max-width:540px;margin:0 auto}.profile-page h1{letter-spacing:-.02em;margin-bottom:1.5rem;font-size:1.5rem;font-weight:800}.profile-header{align-items:center;gap:1rem;margin-bottom:1.5rem;display:flex}.profile-avatar-wrap{position:relative}.profile-avatar-img{border-radius:var(--radius-sm);object-fit:cover;width:64px;height:64px}.profile-avatar-initials{border-radius:var(--radius-sm);width:64px;height:64px;font-size:1.5rem}.profile-avatar-edit{background:var(--bg-alt);width:26px;height:26px;color:var(--text-secondary);cursor:pointer;border:2px solid var(--bg);transition:background var(--transition), color var(--transition);border-radius:50%;justify-content:center;align-items:center;display:flex;position:absolute;bottom:-4px;right:-4px}.profile-avatar-edit:hover{background:var(--coral);color:#fff}.profile-info-name{font-size:.95rem;font-weight:600}.profile-info-role{color:var(--text-tertiary);font-size:.82rem}.profile-saved{color:var(--green);font-size:.82rem;font-weight:500}.activity-detail-page{animation:.3s page-in}.activity-detail-back{margin-bottom:1rem}.activity-detail-back a{color:var(--text-tertiary);transition:color var(--transition);align-items:center;gap:.35rem;font-size:.82rem;font-weight:500;display:inline-flex}.activity-detail-back a:hover{color:var(--text)}.activity-detail-header{border-bottom:1px solid var(--border-light);margin-bottom:1.5rem;padding-bottom:1rem}.activity-detail-header-top{align-items:center;gap:.75rem;margin-bottom:.5rem;display:flex}.activity-detail-header h1{margin-bottom:.4rem;font-size:1.2rem;font-weight:600}.activity-detail-description{color:var(--text-secondary);margin-bottom:.5rem;font-size:.88rem;line-height:1.6}.activity-detail-meta{color:var(--text-tertiary);gap:1rem;font-size:.82rem;display:flex}.activity-detail-due{color:var(--text-tertiary);align-items:center;gap:.3rem;font-size:.78rem;display:inline-flex}.activity-detail-due.overdue{color:var(--red)}.activity-detail-section{margin-bottom:1.5rem}.activity-detail-section h2{margin-bottom:.75rem;font-size:1rem;font-weight:600}.activity-detail-section h3{margin-bottom:.5rem;font-size:.88rem;font-weight:600}.activity-detail-closed{color:var(--red);padding:.5rem 0;font-size:.85rem}.activity-submit-form{border-radius:var(--radius-sm);border:1px solid var(--border-light);background:var(--card);flex-direction:column;gap:.75rem;padding:1rem;display:flex}.activity-student-list{flex-direction:column;gap:.5rem;display:flex}.activity-student-group{border:1px solid var(--border-light);border-radius:var(--radius-sm);background:var(--card);overflow:hidden}.activity-student-header{cursor:pointer;transition:background var(--transition);justify-content:space-between;align-items:center;padding:.65rem .85rem;display:flex}.activity-student-header:hover{background:var(--bg-hover)}.activity-student-info{align-items:center;gap:.6rem;display:flex}.activity-student-avatar{background:var(--bg-alt);width:28px;height:28px;color:var(--text-secondary);border-radius:50%;justify-content:center;align-items:center;font-size:.7rem;font-weight:700;display:flex}.activity-student-name{font-size:.88rem;font-weight:500}.activity-student-count{color:var(--text-faint);font-size:.72rem}.activity-student-status{align-items:center;gap:.5rem;display:flex}.activity-graded-badge{color:var(--green);align-items:center;gap:.25rem;font-size:.68rem;font-weight:600;display:inline-flex}.activity-student-chevron{color:var(--text-faint);transition:transform .15s}.activity-student-chevron.rotated{transform:rotate(90deg)}.activity-student-subs{border-top:1px solid var(--border-light);padding:.75rem}.activity-sub-detail{border-radius:var(--radius-sm);border:1px solid var(--border-light);background:var(--bg);margin-bottom:.5rem;padding:.75rem}.activity-sub-detail:last-child{margin-bottom:0}.activity-sub-row{justify-content:space-between;align-items:flex-start;gap:.75rem;display:flex}.activity-sub-content{flex:1;min-width:0}.activity-sub-content p{color:var(--text);margin-bottom:.3rem;font-size:.85rem}.activity-sub-file{color:var(--text-secondary);flex-wrap:wrap;align-items:center;gap:.35rem;margin-bottom:.2rem;font-size:.78rem;display:inline-flex}.activity-sub-size{color:var(--text-faint)}.activity-sub-dl{color:var(--coral);align-items:center;gap:.2rem;font-size:.72rem;font-weight:500;display:inline-flex}.activity-sub-dl:hover{text-decoration:underline}.activity-sub-date{color:var(--text-faint);font-size:.72rem;display:block}.activity-sub-grade{text-align:right;flex-shrink:0}.grade-form-inline{border-radius:var(--radius-sm);border:1px solid var(--border-light);background:var(--card);flex-direction:column;gap:.5rem;margin-top:.75rem;padding:.75rem;display:flex}.file-preview-overlay{z-index:100;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#1e1b1866;justify-content:center;align-items:center;padding:1.5rem;display:flex;position:fixed;inset:0}.file-preview-modal{background:var(--card);border-radius:var(--radius);width:100%;max-width:800px;max-height:85vh;box-shadow:var(--shadow-xl);flex-direction:column;display:flex;overflow:hidden}.file-preview-header{border-bottom:1px solid var(--border-light);justify-content:space-between;align-items:center;padding:.65rem 1rem;font-size:.85rem;font-weight:500;display:flex}.file-preview-body{background:var(--bg-alt);flex:1;justify-content:center;align-items:center;min-height:300px;display:flex;overflow:auto}.file-preview-body img{object-fit:contain;max-width:100%;max-height:70vh}.file-preview-body iframe{border:none;width:100%;height:70vh}.activity-detail-submissions{margin-top:1rem}.generator-modal{flex-direction:column;gap:.75rem;display:flex}.gen-sources{border:1px solid var(--border);border-radius:var(--radius-sm);max-height:260px;padding:.5rem;overflow-y:auto}.gen-source-group{margin-bottom:.5rem}.gen-source-group:last-child{margin-bottom:0}.gen-source-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.03em;align-items:center;gap:.35rem;margin-bottom:.25rem;padding:.2rem 0;font-size:.78rem;font-weight:600;display:flex}.gen-source-item{border-radius:var(--radius-sm);cursor:pointer;align-items:center;gap:.5rem;padding:.35rem .5rem;font-size:.85rem;transition:background .15s;display:flex}.gen-source-item:hover{background:var(--bg-hover)}.gen-source-item.selected{background:var(--coral-bg)}.gen-source-item input[type=checkbox]{accent-color:var(--coral);width:15px;height:15px}.gen-source-item span{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.gen-meeting-item{padding:.25rem .5rem}.gen-meeting-title{font-size:.82rem;font-weight:500}.gen-source-check{color:var(--text-secondary);cursor:pointer;align-items:center;gap:.25rem;margin-left:.5rem;font-size:.78rem;display:inline-flex}.gen-source-check input{accent-color:var(--coral);width:13px;height:13px}.gen-output-types{flex-wrap:wrap;gap:.35rem;display:flex}.gen-output-btn{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);cursor:pointer;align-items:center;gap:.3rem;padding:.4rem .65rem;font-size:.82rem;transition:all .15s;display:flex}.gen-output-btn:hover{border-color:var(--coral);background:var(--coral-bg)}.gen-output-btn.active{background:var(--coral);color:#fff;border-color:var(--coral)}.gen-preview-header{align-items:center;gap:.5rem;margin-bottom:.5rem;display:flex}.gen-preview-type{border-radius:var(--radius-sm);background:var(--coral-bg);color:var(--coral);white-space:nowrap;padding:.2rem .5rem;font-size:.75rem;font-weight:600}.gen-preview-title{border:1px solid var(--border);border-radius:var(--radius-sm);outline:none;flex:1;padding:.35rem .5rem;font-size:.9rem;font-weight:500}.gen-preview-title:focus{border-color:var(--coral)}.gen-preview-content{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);max-height:350px;padding:.75rem;overflow-y:auto}.gen-quiz-preview{flex-direction:column;gap:.75rem;display:flex}.gen-quiz-q{border:1px solid var(--border);border-radius:var(--radius-sm);padding:.5rem}.gen-quiz-q-header{justify-content:space-between;align-items:flex-start;gap:.5rem;margin-bottom:.35rem;display:flex}.gen-quiz-q-header strong{font-size:.88rem}.gen-quiz-q-type{border-radius:var(--radius-sm);background:var(--bg-hover);color:var(--text-secondary);white-space:nowrap;padding:.15rem .4rem;font-size:.7rem}.gen-quiz-options{flex-direction:column;gap:.2rem;margin:.25rem 0;display:flex}.gen-quiz-opt{border-radius:var(--radius-sm);padding:.2rem .4rem;font-size:.82rem}.gen-quiz-opt.correct{color:#16a34a;background:#22c55e1f;font-weight:500}.gen-quiz-answer{color:var(--text-secondary);margin-top:.2rem;font-size:.78rem}.gen-quiz-explanation{color:var(--text-faint);margin-top:.2rem;font-size:.78rem;font-style:italic}.toast-container{z-index:10000;pointer-events:none;flex-direction:column;gap:.5rem;display:flex;position:fixed;bottom:1.5rem;right:1.5rem}.toast{border-radius:var(--radius-sm);background:var(--bg-ink);color:#fff;pointer-events:auto;cursor:pointer;align-items:center;gap:.5rem;max-width:380px;padding:.65rem 1rem;font-size:.85rem;font-weight:500;animation:.25s toast-in;display:flex;box-shadow:0 8px 24px #1e1b1833}.toast-success .toast-icon{color:#4ade80}.toast-error .toast-icon{color:#f87171}.toast-info .toast-icon{color:#60a5fa}.toast-msg{flex:1}.toast-close{color:#ffffff80;cursor:pointer;background:0 0;border:none;align-items:center;padding:2px;display:flex}.toast-close:hover{color:#fff}@keyframes toast-in{0%{opacity:0;transform:translateY(12px)scale(.96)}to{opacity:1;transform:translateY(0)scale(1)}}.recording-status-processing{color:var(--coral);align-items:center;gap:.35rem;margin-left:.5rem;font-size:.75rem;font-weight:500;display:inline-flex}.recording-pulse{background:var(--coral);border-radius:50%;width:6px;height:6px;animation:1.2s ease-in-out infinite pulse-dot}.skip-link{z-index:10000;background:var(--coral);color:#fff;border-radius:0 0 .25rem .25rem;padding:.5rem 1rem;font-weight:600;text-decoration:none;position:absolute;top:0;left:-9999px}.skip-link:focus{left:0}.dark .btn-secondary{background:var(--card);border-color:var(--border);color:var(--text)}.dark .btn-secondary:hover{background:var(--bg-hover);border-color:var(--text-tertiary)}.dark .form-group input,.dark .form-group textarea,.dark .form-group select{border-color:var(--border);color:var(--text);--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;background:#0a0f1a}.dark .form-group input:focus,.dark .form-group textarea:focus,.dark .form-group select:focus{border-color:var(--coral);box-shadow:0 0 0 3px #00d9ff1f}.dark .form-group input::placeholder,.dark .form-group textarea::placeholder{color:var(--text-faint)}.dark .form-group-input-danger{border-color:var(--border);color:var(--text);background:#0a0f1a}.dark .form-group-input-danger:focus{border-color:var(--coral);box-shadow:0 0 0 3px #00d9ff1f}.dark .modal-overlay{background:#0009}.dark .modal-content{background:var(--card);border:1px solid var(--border);box-shadow:0 0 40px #00d9ff0d}.dark .auth-card{background:var(--card);border-color:var(--border);box-shadow:0 0 40px #00d9ff0d}.dark .auth-card h1:after{background:linear-gradient(135deg,#00d9ff,#009dff)}.dark .auth-form input{border-color:var(--border);color:var(--text);background:#0a0f1a}.dark .auth-form input:focus{border-color:var(--coral);box-shadow:0 0 0 3px #00d9ff1f}.dark .auth-form .login-error{background:var(--red-bg);border-color:#ef444426}.dark .auth-exists-card{background:#00d9ff0f;border-color:#00d9ff33}.dark .auth-exists-title{color:var(--text)}.dark .auth-exists-text{color:#fff9}.dark .auth-link a{color:var(--coral)}.dark .app-header{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-color:var(--border);background:#060b14d9}.dark .sidebar{background:var(--bg);border-color:var(--border)}.dark .sidebar-link:hover{color:var(--text);background:#ffffff0a}.dark .sidebar-link.active{color:var(--coral);background:#00d9ff1a}.dark .sidebar-footer{border-color:var(--border)}.dark .sidebar-avatar{color:var(--coral);background:#00d9ff1f}.dark .card{background:var(--card);border-color:var(--border)}.dark .card:hover{box-shadow:0 0 20px #00d9ff0f}.dark .mural-composer{background:var(--card);border-color:var(--border)}.dark .mural-composer-input{color:var(--text)}.dark .mural-composer-input::placeholder{color:var(--text-faint)}.dark .markdown-body{color:var(--text)}.dark .markdown-body code{color:var(--coral);background:#00d9ff14}.dark .markdown-body pre{background:#0a0f1a}.dark .markdown-body a{color:var(--coral)}.dark .markdown-body blockquote{border-color:var(--coral);color:var(--text-secondary)}.dark .markdown-body th{background:var(--bg-alt)}.dark .post-avatar{color:var(--coral);background:#00d9ff1a}.dark .post-item,.dark .post-replies,.dark .reply-item+.reply-item{border-color:var(--border)}.dark .reply-form input{border-color:var(--border);color:var(--text);background:#0a0f1a}.dark .meeting-card{background:var(--card);border-color:var(--border)}.dark .meeting-card:hover{background:var(--bg-hover);box-shadow:0 0 20px #00d9ff0f}.dark .meeting-card-live{background:linear-gradient(135deg, var(--card) 90%, #ef44440f);border-color:#ef444440}.dark .meeting-card-live:hover{border-color:#ef444466}.dark .recording-card{background:var(--card);border-color:var(--border)}.dark .summary-content{background:var(--bg-alt);border-color:var(--border)}.dark .transcript-content{background:var(--bg-alt)}.dark .transcript-line{border-color:var(--border)}.dark .activity-card{background:var(--card);border-color:var(--border)}.dark .activity-card:hover{background:var(--bg-hover);box-shadow:0 0 20px #00d9ff0f}.dark .submit-form,.dark .submission-card{background:var(--card);border-color:var(--border)}.dark .grade-form{background:var(--bg-alt);border-color:var(--border)}.dark .material-card{background:var(--card);border-color:var(--border)}.dark .material-icon{color:var(--coral);background:#00d9ff14}.dark .material-library-card,.dark .share-class-row{background:var(--card);border-color:var(--border)}.dark .upload-file-label{background:var(--card);border-color:var(--border);color:var(--text-secondary)}.dark .people-teacher{background:#00d9ff0f;border-color:#00d9ff1f}.dark .people-teacher .post-avatar{background:var(--coral);color:#060b14}.dark .people-teacher-role{color:var(--coral)}.dark .stat-card,.dark .upcoming-card,.dark .aggregate-card{background:var(--card);border-color:var(--border)}.dark .aggregate-card:hover{box-shadow:0 0 20px #00d9ff0f}.dark .filter-tab{background:var(--card);border-color:var(--border);color:var(--text-secondary)}.dark .filter-tab:hover{background:var(--bg-hover)}.dark .filter-tab.active{border-color:var(--coral);color:var(--coral);background:#00d9ff14}.dark .class-card{background:var(--card);border-color:var(--border)}.dark .class-card:hover{box-shadow:0 0 24px #00d9ff14}.dark .toast{border:1px solid var(--border);background:#111c2b;box-shadow:0 8px 24px #0006}.dark .strength-bar,.dark .auth-divider:before,.dark .auth-divider:after{background:var(--border)}.dark .mural-toolbar-btn.active{background:var(--bg-hover)}.dark .status-scheduled,.dark .status-cancelled{background:var(--bg-alt)}.dark .aggregate-class-badge{background:var(--bg-alt);color:var(--text-tertiary)}.dark .class-detail-code{background:var(--bg-alt);color:var(--text-secondary)}.dark .sidebar-main-mobile-bar{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-color:var(--border);background:#060b14d9}.dark .sidebar-mobile-toggle{background:var(--card);border-color:var(--border);color:var(--text)}.dark .sidebar-overlay{background:#0009}.dark .gen-output-btn{background:var(--bg-alt);border-color:var(--border);color:var(--text-secondary)}.dark .gen-preview-title{border-color:var(--border);color:var(--text);background:#0a0f1a}.dark .gen-preview-content{border-color:var(--border);background:#0a0f1a}.dark .gen-quiz-q{border-color:var(--border)}.dark .quiz-question-card{background:var(--bg-alt);border-color:var(--border)}.dark .quiz-option-input,.dark .quiz-question-input{border-color:var(--border);color:var(--text);background:#0a0f1a}.dark .uc-content-card{background:var(--card);border-color:var(--border)}.dark .uc-quiz-question{border-color:var(--border)}.dark .profile-card{background:var(--card);border-color:var(--border)}.dark .profile-avatar-large{color:var(--coral);background:#00d9ff1f}.dark .onboarding-card,.dark .mural-event-card{background:var(--card);border-color:var(--border)}.dark .mural-event-live{background:#dc26260f;border-color:#dc262633}.dark .reunioes-card{background:var(--card);border-color:var(--border)}.dark .reunioes-card:hover{background:var(--bg-hover)}.dark .reunioes-card-live{border-color:#dc262633}.dark .reunioes-card-live:hover{border-color:#dc262659;box-shadow:0 2px 10px #dc26261f}.dark .reunioes-filter-btn{background:var(--card);border-color:var(--border);color:var(--text-secondary)}.dark .reunioes-filter-btn:hover{background:var(--bg-hover)}.dark .reunioes-filter-btn.active{background:var(--text);color:#060b14;border-color:var(--text)}.dark .reunioes-empty-icon,.dark .reunioes-card-duration{background:var(--bg-alt)}.dark .invite-item,.dark .activity-student-group{background:var(--card);border-color:var(--border)}.dark .activity-detail-header{border-color:var(--border)}.dark .activity-submit-form,.dark .activity-student-group,.dark .grade-form-inline{border-color:var(--border);background:var(--card)}.dark .activity-student-header:hover{background:#ffffff0a}.dark .activity-student-subs{border-top-color:var(--border)}.dark .activity-sub-detail{border-color:var(--border);background:#ffffff05}.dark .file-preview-overlay{background:#0009}.dark .file-preview-modal{background:#0b1320}.dark .file-preview-header{border-bottom-color:var(--border)}.dark .class-banner-btn{background:#00000040}.dark .class-banner-btn:hover{background:#0006}.dark .tabs{border-bottom-color:var(--border)}.dark .profile-avatar-edit{border-color:var(--card)}.dark .color-swatch-active{box-shadow:0 0 0 2px var(--card), 0 0 0 4px var(--text)}.dark .reunioes-hero{border-bottom-color:var(--border)}.dark .settings-danger-zone{background:#ef44440a;border-color:#ef444433}.dark .btn-primary{background:var(--coral);color:#060b14}.dark .btn-primary:hover{background:var(--coral-hover)}.dark .btn-primary:disabled:hover,.dark .reunioes-card-join{background:var(--coral);color:#060b14}.dark .reunioes-card-join:hover{background:var(--coral-hover);color:#060b14}.dark .classroom-error button{background:var(--coral);color:#060b14}.dark .meeting-chat-send,.dark .meeting-chat-edit-ok{color:#060b14}.dark .gen-output-btn.active{background:var(--coral);color:#060b14;border-color:var(--coral)}.dark .skip-link,.dark .people-teacher .post-avatar{background:var(--coral);color:#060b14}.dark .form-group select:focus,.dark .form-group-input-danger:focus,.dark .auth-form input:focus{box-shadow:0 0 0 3px #00d9ff1a}.theme-toggle{border-radius:var(--radius-sm);border:1px solid var(--border);width:34px;height:34px;color:var(--text-tertiary);cursor:pointer;transition:background var(--transition), color var(--transition), border-color var(--transition);background:0 0;justify-content:center;align-items:center;display:inline-flex}.theme-toggle:hover{background:var(--bg-hover);color:var(--coral);border-color:#00d9ff33}
