.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:1rem}.login-container{width:100%;max-width:400px}.login-header{text-align:center;margin-bottom:2rem}.login-header h1{font-size:2rem;margin-bottom:.5rem;background:linear-gradient(135deg,#4f46e5,#7c3aed);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.login-header p{color:var(--text-muted)}.login-form{background:var(--bg-card);padding:2rem;border-radius:1rem;box-shadow:0 4px 6px #0000004d}.login-form h2{margin-bottom:1.5rem;font-size:1.25rem}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.5rem;font-size:.875rem;color:var(--text-muted)}.login-form button[type=submit]{width:100%;margin-top:1rem}.login-footer{text-align:center;margin-top:1rem}.link-button{background:none;color:var(--primary);padding:.5rem;font-size:.875rem}.link-button:hover{text-decoration:underline}.forgot-password{text-align:right;margin-top:-.5rem;margin-bottom:.5rem}.forgot-password a{color:var(--text-muted);font-size:.875rem;text-decoration:none}.forgot-password a:hover{color:var(--primary);text-decoration:underline}.success-message{background:var(--bg-card);padding:1.5rem;border-radius:.5rem;text-align:center;color:var(--text-muted);margin-bottom:1rem}.success-message p{margin:.5rem 0}.npc-dialogue-panel{position:fixed;bottom:24px;right:24px;width:400px;max-height:70vh;background:#1a1a2e;border-radius:12px;box-shadow:0 8px 32px #0006;display:flex;flex-direction:column;z-index:1000;overflow:hidden}.dialogue-header{display:flex;justify-content:space-between;align-items:center;padding:16px;background:#16213e;border-bottom:1px solid #0f3460}.npc-info{display:flex;align-items:center;gap:12px}.npc-name{margin:0;font-size:18px;color:#e94560}.speaking-indicator{font-size:12px;color:#94a3b8;animation:pulse 1s infinite}.dialogue-actions{display:flex;gap:8px}.dialogue-actions button{background:none;border:none;cursor:pointer;font-size:18px;padding:4px 8px;border-radius:4px;transition:background .2s}.dialogue-actions button:hover{background:#ffffff1a}.voice-toggle.active{background:#e9456033}.close-btn{color:#94a3b8}.close-btn:hover{color:#e94560}.dialogue-messages{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:12px;min-height:200px;max-height:400px}.dialogue-empty{text-align:center;color:#64748b;padding:40px}.message-bubble{max-width:85%;padding:10px 14px;border-radius:12px;position:relative}.message-bubble.user{align-self:flex-end;background:#e94560;color:#fff;border-bottom-right-radius:4px}.message-bubble.npc{align-self:flex-start;background:#0f3460;color:#e2e8f0;border-bottom-left-radius:4px}.message-sender{font-size:11px;font-weight:600;margin-bottom:4px;opacity:.8}.message-content{font-size:14px;line-height:1.4}.message-time{font-size:10px;opacity:.6;margin-top:4px;display:flex;align-items:center;gap:4px}.transcribed-badge{font-size:12px}.listening-indicator{display:flex;gap:4px;padding:10px;align-self:flex-start}.listening-indicator .dot{width:8px;height:8px;background:#e94560;border-radius:50%;animation:bounce .6s infinite alternate}.listening-indicator .dot:nth-child(2){animation-delay:.2s}.listening-indicator .dot:nth-child(3){animation-delay:.4s}@keyframes bounce{0%{transform:translateY(0)}to{transform:translateY(-6px)}}.quest-offer{margin:12px;padding:16px;background:linear-gradient(135deg,#1e3a5f,#16213e);border:1px solid #e94560;border-radius:8px}.quest-offer-header{display:flex;align-items:center;gap:8px;font-size:12px;color:#e94560;text-transform:uppercase;letter-spacing:1px;margin-bottom:8px}.quest-title{margin:0 0 8px;color:gold;font-size:16px}.quest-description{margin:0 0 12px;font-size:13px;color:#cbd5e1;line-height:1.4}.quest-objectives{font-size:12px;color:#94a3b8;margin-bottom:12px}.quest-objectives ul{margin:4px 0 0;padding-left:20px}.quest-objectives li{margin:4px 0}.quest-actions{display:flex;gap:8px}.quest-actions button{flex:1;padding:8px 16px;border:none;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;transition:transform .1s,opacity .2s}.quest-actions button:hover{transform:translateY(-1px)}.quest-actions button:active{transform:translateY(0)}.accept-btn{background:#e94560;color:#fff}.decline-btn{background:#334155;color:#94a3b8}.decline-btn:hover{color:#fff}.memories-panel{margin:12px;padding:12px;background:#0f3460;border-radius:8px;font-size:13px}.memories-panel h4{margin:0 0 12px;color:#e2e8f0;font-size:14px}.no-memories{color:#64748b;font-style:italic}.memories-list{list-style:none;margin:0;padding:0}.memory-item{display:flex;justify-content:space-between;align-items:flex-start;padding:8px 0;border-bottom:1px solid #1e3a5f}.memory-item:last-child{border-bottom:none}.memory-fact{flex:1;color:#cbd5e1}.memory-category{font-size:10px;background:#16213e;color:#64748b;padding:2px 6px;border-radius:4px;margin-left:8px}.relationship-score{margin-top:12px;padding-top:12px;border-top:1px solid #1e3a5f;text-align:center;font-weight:600;color:#e94560}.dialogue-input{padding:12px 16px;background:#16213e;border-top:1px solid #0f3460;display:flex;gap:8px}.text-input{flex:1;padding:10px 14px;background:#0f3460;border:1px solid #1e3a5f;border-radius:8px;color:#e2e8f0;font-size:14px;outline:none}.text-input:focus{border-color:#e94560}.text-input::placeholder{color:#475569}.send-btn{padding:10px 20px;background:#e94560;border:none;border-radius:8px;color:#fff;font-weight:600;cursor:pointer;transition:opacity .2s}.send-btn:disabled{opacity:.5;cursor:not-allowed}.send-btn:hover:not(:disabled){opacity:.9}.voice-mode-input{flex:1;display:flex;flex-direction:column;align-items:center;gap:8px}.push-to-talk{width:100%;padding:16px;background:#0f3460;border:2px solid #1e3a5f;border-radius:8px;color:#e2e8f0;font-size:14px;cursor:pointer;transition:all .2s}.push-to-talk:hover{border-color:#e94560}.push-to-talk.recording{background:#7f1d1d;border-color:#e94560;animation:recording-pulse 1s infinite}@keyframes recording-pulse{0%,to{box-shadow:0 0 #e9456066}50%{box-shadow:0 0 0 8px #e9456000}}.voice-hint{font-size:11px;color:#475569}.quest-mini-tracker{position:fixed;top:24px;right:24px;width:220px;background:#1a1a2ef2;border-radius:8px;padding:12px;cursor:pointer;z-index:100;transition:transform .2s}.quest-mini-tracker:hover{transform:scale(1.02)}.mini-tracker-header{display:flex;align-items:center;gap:8px;margin-bottom:8px;font-weight:600;color:#e2e8f0}.quest-icon{font-size:18px}.quest-count{font-size:13px}.mini-quest-item{padding:8px;background:#16213e;border-radius:6px;margin-bottom:6px}.mini-quest-item.ready{border:1px solid #ffd700}.mini-quest-title{display:block;font-size:12px;color:#cbd5e1;margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mini-progress-bar{height:4px;background:#0f3460;border-radius:2px;overflow:hidden}.mini-progress-fill{height:100%;background:#e94560;transition:width .3s ease}.ready-indicator{display:block;font-size:10px;color:gold;margin-top:4px}.more-quests{display:block;text-align:center;font-size:11px;color:#64748b;margin-top:4px}.quest-log-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000}.quest-log-panel{width:90%;max-width:800px;max-height:80vh;background:#1a1a2e;border-radius:12px;overflow:hidden;display:flex;flex-direction:column}.quest-log-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;background:#16213e;border-bottom:1px solid #0f3460}.quest-log-header h2{margin:0;color:#e94560;font-size:20px}.quest-log-header .close-btn{background:none;border:none;color:#94a3b8;font-size:20px;cursor:pointer}.quest-log-header .close-btn:hover{color:#e94560}.quest-log-content{display:flex;flex:1;overflow:hidden}.quest-list{width:280px;border-right:1px solid #0f3460;overflow-y:auto;padding:12px}.quest-list-item{padding:12px;background:#16213e;border-radius:6px;margin-bottom:8px;cursor:pointer;transition:background .2s}.quest-list-item:hover{background:#1e3a5f}.quest-list-item.selected{background:#0f3460;border:1px solid #e94560}.quest-list-item.ready{border-left:3px solid #ffd700}.quest-list-info{display:flex;justify-content:space-between;margin-bottom:6px}.quest-list-title{font-size:13px;color:#e2e8f0;font-weight:500}.quest-list-progress{font-size:12px;color:#64748b}.quest-list-bar{height:3px;background:#0f3460;border-radius:2px;overflow:hidden}.quest-list-fill{height:100%;background:#e94560}.quest-details{flex:1;padding:20px;overflow-y:auto}.quest-details-content{color:#e2e8f0}.quest-details-title{margin:0 0 8px;color:gold;font-size:22px}.quest-details-description{color:#94a3b8;line-height:1.5;margin-bottom:20px}.quest-objectives h4,.quest-rewards h4{color:#e94560;font-size:14px;text-transform:uppercase;margin:0 0 12px}.objective-item{display:flex;align-items:center;gap:8px;padding:10px;background:#16213e;border-radius:6px;margin-bottom:8px}.objective-item.completed{opacity:.7}.objective-item.completed .objective-check{color:#22c55e}.objective-check{font-size:16px;color:#64748b}.objective-text{flex:1;font-size:13px}.objective-progress{font-size:12px;color:#64748b}.quest-rewards{margin-top:20px}.quest-rewards ul{list-style:none;padding:0;margin:0}.quest-rewards li{padding:8px 12px;background:#16213e;border-radius:4px;margin-bottom:6px;font-size:13px}.quest-ready-notice{margin-top:20px;padding:12px;background:#ffd7001a;border:1px solid #ffd700;border-radius:6px;color:gold;text-align:center;font-size:14px}.quest-celebration{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#000c;z-index:2000;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.celebration-content{text-align:center;animation:scaleIn .5s ease}@keyframes scaleIn{0%{transform:scale(.8);opacity:0}to{transform:scale(1);opacity:1}}.celebration-icon{font-size:64px;animation:bounce .5s ease infinite alternate}.celebration-content h2{color:gold;font-size:32px;margin:16px 0 8px}.celebration-content h3{color:#e2e8f0;font-size:20px;font-weight:400;margin:0 0 24px}.celebration-rewards{display:flex;flex-direction:column;gap:8px}.celebration-reward{padding:12px 24px;background:#e9456033;border-radius:8px;color:#e2e8f0;font-size:16px;animation:slideUp .5s ease forwards;opacity:0}.celebration-reward:nth-child(1){animation-delay:.2s}.celebration-reward:nth-child(2){animation-delay:.4s}.celebration-reward:nth-child(3){animation-delay:.6s}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.lecture-status-bar{position:fixed;top:0;left:50%;transform:translate(-50%);display:flex;align-items:center;justify-content:space-between;gap:16px;padding:8px 16px;background:#1a1a2ef2;border-radius:0 0 8px 8px;z-index:500;min-width:300px}.lecture-status-info{display:flex;align-items:center;gap:8px}.status-indicator{width:10px;height:10px;border-radius:50%;animation:pulse 2s infinite}.status-indicator.active{background:#22c55e}.status-indicator.paused{background:#fbbf24;animation:none}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.lecture-title{color:#e2e8f0;font-size:14px;font-weight:500}.paused-badge{background:#fbbf24;color:#000;font-size:10px;padding:2px 6px;border-radius:4px;font-weight:600}.context-toggle{background:none;border:none;color:#94a3b8;cursor:pointer;font-size:12px;padding:4px 8px}.context-toggle:hover{color:#e2e8f0}.lecture-context-panel{position:fixed;top:48px;left:24px;width:320px;max-height:calc(100vh - 72px);background:#1a1a2ef2;border-radius:8px;overflow:hidden;display:flex;flex-direction:column;z-index:400}.instructor-controls{padding:12px;background:#16213e;border-bottom:1px solid #0f3460}.instructor-controls h4{margin:0 0 8px;font-size:12px;color:#94a3b8;text-transform:uppercase}.control-buttons{display:flex;gap:8px}.control-buttons button{flex:1;padding:8px 12px;border:none;border-radius:6px;font-size:12px;font-weight:600;cursor:pointer;transition:opacity .2s}.control-buttons button:hover{opacity:.9}.pause-btn{background:#fbbf24;color:#000}.resume-btn{background:#22c55e;color:#fff}.end-btn{background:#e94560;color:#fff}.context-section{padding:12px;border-bottom:1px solid #0f3460}.context-section h4{margin:0 0 8px;font-size:12px;color:#e94560;text-transform:uppercase}.context-section p{margin:0;color:#e2e8f0;font-size:14px;line-height:1.4}.empty-state{color:#64748b;font-style:italic;font-size:13px}.exercise-card{margin:12px;padding:12px;background:#16213e;border-radius:8px;border-left:3px solid #fbbf24}.exercise-card.completed{border-left-color:#22c55e;opacity:.8}.exercise-header{display:flex;align-items:center;gap:6px;margin-bottom:8px}.exercise-icon{font-size:16px}.exercise-label{font-size:11px;color:#fbbf24;text-transform:uppercase;font-weight:600}.exercise-card.completed .exercise-label{color:#22c55e}.exercise-title{margin:0 0 6px;color:#e2e8f0;font-size:14px}.exercise-instructions{margin:0;color:#94a3b8;font-size:13px;line-height:1.4}.exercise-status{display:flex;align-items:center;gap:6px;margin-top:8px;font-size:11px;color:#fbbf24}.pulse-dot{width:6px;height:6px;background:#fbbf24;border-radius:50%;animation:pulse 1s infinite}.takeaways-list{list-style:none;margin:0;padding:0;max-height:200px;overflow-y:auto}.takeaway-item{display:flex;gap:8px;padding:8px 0;border-bottom:1px solid #0f3460;font-size:13px;color:#e2e8f0;animation:slideIn .3s ease}@keyframes slideIn{0%{opacity:0;transform:translate(-10px)}to{opacity:1;transform:translate(0)}}.takeaway-bullet{color:#e94560}.takeaway-content{flex:1;line-height:1.4}.takeaway-topic{font-size:10px;background:#0f3460;color:#64748b;padding:2px 6px;border-radius:4px;align-self:flex-start}.transcript{flex:1;min-height:150px;display:flex;flex-direction:column}.transcript-container{flex:1;max-height:300px;overflow-y:auto;font-size:13px;line-height:1.5;color:#94a3b8;padding-right:8px;position:relative}.transcript-segment{margin-bottom:8px}.segment-speaker{color:#e94560;font-weight:500;margin-right:4px}.segment-text{color:#cbd5e1}.scroll-to-bottom{position:sticky;bottom:0;width:100%;padding:6px;background:#e94560;border:none;color:#fff;font-size:12px;cursor:pointer}.catchup-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:2000}.catchup-modal{width:90%;max-width:500px;background:#1a1a2e;border-radius:12px;overflow:hidden}.catchup-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;background:#16213e;border-bottom:1px solid #0f3460}.catchup-header h3{margin:0;color:#e2e8f0;font-size:18px}.catchup-header .close-btn{background:none;border:none;color:#94a3b8;font-size:18px;cursor:pointer}.catchup-content{padding:20px;max-height:400px;overflow-y:auto}.catchup-summary{font-family:inherit;white-space:pre-wrap;margin:0;color:#e2e8f0;font-size:14px;line-height:1.6}.loading{text-align:center;color:#64748b;padding:40px}.catchup-footer{padding:12px 20px;background:#16213e;border-top:1px solid #0f3460;text-align:right}.got-it-btn{padding:10px 24px;background:#e94560;border:none;border-radius:6px;color:#fff;font-weight:600;cursor:pointer}.got-it-btn:hover{opacity:.9}.game-canvas-container{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;background:#0f0f23}.game-canvas{border:2px solid #333;border-radius:4px;image-rendering:pixelated;image-rendering:crisp-edges}.game-canvas:focus{outline:none;border-color:var(--primary)}.controls-hint{position:absolute;bottom:1rem;left:50%;transform:translate(-50%);background:#000000b3;padding:.5rem 1rem;border-radius:.5rem;font-size:.875rem;color:var(--text-muted)}[data-lk-theme=default]{color-scheme:dark;--lk-bg: #111;--lk-bg2: rgb(29.75, 29.75, 29.75);--lk-bg3: rgb(42.5, 42.5, 42.5);--lk-bg4: rgb(55.25, 55.25, 55.25);--lk-bg5: #444444;--lk-fg: #fff;--lk-fg2: rgb(244.8, 244.8, 244.8);--lk-fg3: rgb(234.6, 234.6, 234.6);--lk-fg4: rgb(224.4, 224.4, 224.4);--lk-fg5: rgb(214.2, 214.2, 214.2);--lk-border-color: rgba(255, 255, 255, .1);--lk-accent-fg: #fff;--lk-accent-bg: #1f8cf9;--lk-accent2: rgb(50.867826087, 150.2, 249.532173913);--lk-accent3: rgb(70.7356521739, 160.4, 250.0643478261);--lk-accent4: rgb(90.6034782609, 170.6, 250.5965217391);--lk-danger-fg: #fff;--lk-danger: #f91f31;--lk-danger2: rgb(249.532173913, 50.867826087, 67.2713043478);--lk-danger3: rgb(250.0643478261, 70.7356521739, 85.5426086957);--lk-danger4: rgb(250.5965217391, 90.6034782609, 103.8139130435);--lk-success-fg: #fff;--lk-success: #1ff968;--lk-success2: rgb(50.867826087, 249.532173913, 117.3930434783);--lk-success3: rgb(70.7356521739, 250.0643478261, 130.7860869565);--lk-success4: rgb(90.6034782609, 250.5965217391, 144.1791304348);--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 rgba(0, 0, 0, .15);--lk-drop-shadow: rgba(255, 255, 255, .2) 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{position:relative;display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.625rem 1rem;color:var(--lk-control-fg);background-image:none;background-color:var(--lk-control-bg);border:0;border-radius:var(--lk-border-radius);cursor:pointer;white-space:nowrap;font-size:inherit;line-height:inherit;-webkit-user-select:none;user-select:none}.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{display:inline-flex;align-items:stretch;height:100%}.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{position:relative;flex-shrink:0}.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{height:100%;border-top-left-radius:0;border-bottom-left-radius:0}.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{display:inline-block;content:"";width:.5em;height:.5em;margin-top:-.25rem;margin-left:.5rem;border-left:.125em solid;border-bottom:.125em solid;transform:rotate(-45deg);transform-origin:center center}.lk-disconnect-button{font-weight:600;color:var(--lk-danger);border:1px solid var(--lk-danger)}.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);position:absolute;top:0;left:0;padding:.25rem;margin-left:.25rem;margin-top:.25rem;border-radius:50%;font-size:.5rem;line-height:.75;background:var(--lk-accent-bg)}.lk-media-device-select:not(:last-child){padding-bottom:.5rem;margin-bottom:.75rem;border-bottom:1px solid var(--lk-border-color)}.lk-media-device-select li:not(:last-child){margin-bottom:.25rem}.lk-media-device-select li>.lk-button{width:100%;justify-content:start;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{width:max-content;position:absolute;top:0;left:0;z-index:5;min-width:10rem;padding:.5rem;margin-bottom:.25rem;white-space:nowrap;background-color:var(--lk-bg2);border:1px solid var(--lk-border-color);border-radius:.75rem;box-shadow:var(--lk-box-shadow)}.lk-device-menu-heading{padding:.25rem .5rem;font-weight:700;opacity:.65}.lk-start-audio-button{color:var(--lk-accent-fg);background-color:var(--lk-accent-bg)}@media screen and (max-width: 600px){.lk-start-audio-button{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%)}}.lk-pagination-control{position:absolute;bottom:1rem;left:50%;transform:translate(-50%);display:flex;align-items:stretch;background-color:var(--lk-control-bg);border-radius:var(--lk-border-radius);transition:opacity ease-in-out .15s;opacity:0}.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{padding:.5rem .875rem;border-inline:1px solid var(--lk-bg)}[data-lk-user-interaction=true].lk-pagination-control{opacity:1}.lk-pagination-indicator{position:absolute;height:var(--lk-grid-gap);background-color:var(--lk-bg2);width:fit-content;padding:.2rem .5rem;bottom:calc(var(--lk-grid-gap)/2);left:50%;transform:translate(-50%);border-radius:2rem;opacity:1;display:flex;gap:.2rem;align-items:center}.lk-pagination-indicator span{display:inline-block;width:.4rem;height:.4rem;border-radius:9999999px;background-color:var(--lk-fg);opacity:.35;transition:opacity linear .2s}.lk-pagination-indicator span[data-lk-active]{opacity:.9}.lk-grid-layout{--lk-col-count: 1;--lk-row-count: 1;display:grid;grid-template-columns:repeat(var(--lk-col-count),minmax(0,1fr));grid-auto-rows:minmax(0,1fr);grid-gap:var(--lk-grid-gap);width:100%;height:100%;max-width:100%;max-height:100%;padding:var(--lk-grid-gap)}.lk-grid-layout[data-lk-pagination=true]{padding-bottom:calc(var(--lk-grid-gap)*2)}.lk-focus-layout{display:grid;grid-template-columns:1fr 5fr;gap:var(--lk-grid-gap);width:100%;max-height:100%;padding:var(--lk-grid-gap)}.lk-focused-participant{position:relative}.lk-focused-participant .lk-pip-track{position:absolute;top:10px;right:10px;width:20%;height:auto}@media (max-width: 600px){.lk-focus-layout{grid-template-columns:1fr;grid-template-rows:5fr 1fr}.lk-carousel{order:1}}.lk-carousel{max-height:100%;display:flex;gap:var(--lk-grid-gap)}.lk-carousel>*{flex-shrink:0;aspect-ratio:16/10;scroll-snap-align:start}.lk-carousel[data-lk-orientation=vertical]{flex-direction:column;scroll-snap-type:y mandatory;overflow-y:auto;overflow-x:hidden}.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-y:hidden;overflow-x:auto}.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{position:relative;width:var(--lk-indicator-size, 1rem);height:var(--lk-indicator-size, 1rem);margin-inline-end:.25rem;transition:opacity .25s ease-in-out}.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{width:100%;height:100%;object-fit:cover;object-position:center;background-color:#000}.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{width:100%;height:100%;min-height:160px;background:var(--lk-bg-control);aspect-ratio:16/9;border-radius:.5rem;display:flex;justify-content:space-around;align-items:center}.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:.1s cubic-bezier(.19,.02,.09,1)}.lk-audio-bar-visualizer{display:flex;align-items:center;justify-content:center;width:100%;height:100%;background:var(--lk-bg);gap:var(--lk-va-bar-gap, 24px)}.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, rgba(136, 136, 136, .2));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, rgb(136, 136, 136));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;position:relative;display:flex;flex-direction:column;gap:.375rem;overflow:hidden;border-radius:var(--lk-border-radius)}.lk-participant-tile:after{content:"";position:absolute;top:0;bottom:0;left:0;right:0;border-radius:var(--lk-border-radius);border:0px solid var(--lk-accent-bg);transition-property:border opacity;transition-delay:.5s;transition-duration:.4s;pointer-events:none}.lk-participant-tile[data-lk-speaking=true]:not([data-lk-source=screen_share]):after{transition-delay:0s;transition-duration:.2s;border-width:var(--lk-speaking-indicator-width)}.lk-participant-tile .lk-focus-toggle-button{position:absolute;top:.25rem;right:.25rem;padding:.25rem;background-color:#00000080;border-radius:calc(var(--lk-border-radius)/2);opacity:0;transition:opacity .2s ease-in-out;transition-delay:.2s}.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;transition-delay:.2s}.lk-participant-tile .lk-connection-quality[data-lk-quality=poor]{opacity:1;transition-delay:0}.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{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background-color:var(--lk-bg2);opacity:0;transition:opacity .2s ease-in-out;pointer-events:none;border-radius:var(--lk-border-radius)}.lk-participant-tile .lk-participant-placeholder svg{height:100%;width:auto;padding:10%}.lk-participant-tile[data-lk-video-muted=true][data-lk-source=camera] .lk-participant-placeholder{opacity:1}.lk-participant-metadata{position:absolute;right:.25rem;bottom:.25rem;left:.25rem;display:flex;flex-direction:row;align-items:center;justify-content:space-between;gap:.5rem;line-height:1}.lk-participant-metadata-item{display:flex;align-items:center;padding:.25rem;background-color:#00000080;border-radius:calc(var(--lk-border-radius)/2)}.lk-toast{position:fixed;top:.75rem;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;background-color:var(--lk-bg);border:1px solid var(--lk-border-color);border-radius:var(--lk-border-radius);box-shadow:var(--lk-box-shadow)}.lk-spinner{animation:lk-rotate 2s infinite linear}@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{position:relative;width:100%;height:100%;--lk-has-imported-styles: "true"}.lk-room-container *[class^=lk-],.lk-room-container *[class*=" lk-"]{box-sizing:border-box}.lk-audio-conference{position:relative;width:100%;height:100%}.lk-audio-conference-stage{width:100%;height:100%;display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.lk-chat{display:grid;grid-template-rows:var(--lk-chat-header-height) 1fr var(--lk-control-bar-height);width:clamp(200px,55ch,60ch);background-color:var(--lk-bg2);border-left:1px solid var(--lk-border-color);align-items:end}.lk-chat-header{height:var(--lk-chat-header-height);padding:.75rem;position:relative;display:flex;align-items:center;justify-content:center}.lk-chat-header .lk-close-button{position:absolute;right:0;transform:translate(-50%);background-color:#0000}.lk-chat-header .lk-close-button:hover{background-color:var(--lk-control-active-hover-bg)}.lk-chat-messages{display:flex;width:100%;max-height:100%;flex-direction:column;gap:.25rem;overflow:auto}.lk-chat-entry{display:flex;flex-direction:column;gap:.25rem;margin:0 .25rem}.lk-chat-entry .lk-meta-data{font-size:.75rem;color:var(--lk-fg5);white-space:nowrap;padding:0 .3rem;display:flex}.lk-chat-entry .lk-meta-data .lk-participant-name{margin-top:1rem}.lk-chat-entry .lk-meta-data .lk-timestamp{margin-left:auto;align-self:flex-end}.lk-chat-entry .lk-edit-button{background:none;float:right;margin:0;padding:0 .25rem;border-radius:0;font-size:12px}.lk-chat-entry .lk-message-body{display:inline-block;border-radius:15px;padding:.25rem .75rem;word-break:break-word;width:fit-content;max-width:calc(100% - 32px)}.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{text-decoration:underline;color:inherit}.lk-chat-entry *{margin-block-start:.25em;margin-block-end:.25em}.lk-chat-entry:last-child{margin-bottom:.25rem}.lk-chat-form{display:flex;gap:.75rem;padding:.75rem;border-top:1px solid var(--lk-border-color);max-height:var(--lk-control-bar-height)}.lk-chat-form-input{font-size:inherit;line-height:inherit;width:100%}@media (max-width: 600px){.lk-chat{position:fixed;top:0;right:0;max-width:100%;bottom:var(--lk-control-bar-height)}}.lk-control-bar,.lk-agent-control-bar{display:flex;gap:.5rem;align-items:center;justify-content:center;padding:.75rem;border-top:1px solid var(--lk-border-color);max-height:var(--lk-control-bar-height)}.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{list-style:none;margin:0;padding:0}[data-lk-theme] .lk-form-control{font-family:var(--lk-font-family);padding:.625rem 1rem;background-color:var(--lk-control-bg);border:1px solid var(--lk-border-color);border-radius:var(--lk-border-radius)}.lk-prejoin{box-sizing:border-box;display:flex;flex-direction:column;align-items:center;padding:1rem;gap:1rem;margin-inline:auto;background-color:var(--lk-bg);width:min(100%,480px);align-items:stretch}.lk-prejoin .lk-video-container{position:relative;width:100%;height:auto;aspect-ratio:16/10;background-color:#000;border-radius:var(--lk-border-radius);overflow:hidden}.lk-prejoin .lk-video-container video,.lk-prejoin .lk-video-container .lk-camera-off-note{display:block;width:100%;height:100%;object-fit:cover}.lk-prejoin .lk-video-container video[data-lk-facing-mode=user]{transform:rotateY(180deg)}.lk-prejoin .lk-video-container .lk-camera-off-note{position:absolute;top:0;left:0;width:100%;aspect-ratio:16/10;background-color:#000;display:grid;place-items:center}.lk-prejoin .lk-video-container .lk-camera-off-note>*{height:70%;max-width:100%}.lk-prejoin .lk-audio-container{display:none}.lk-prejoin .lk-audio-container audio{width:100%;height:auto}.lk-prejoin .lk-button-group-container{display:flex;flex-wrap:nowrap;gap:1rem}.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 (max-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{display:flex;flex-direction:column;gap:1rem;width:100%;max-width:100%}.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{position:relative;display:flex;justify-content:center;width:100%;height:calc(100% - var(--lk-control-bar-height))}.lk-grid-layout-wrapper{flex-direction:column;align-items:center}.lk-focus-layout-wrapper{align-items:stretch}.lk-video-conference{position:relative;display:flex;align-items:stretch;height:100%}.lk-video-conference-inner{display:flex;flex-direction:column;align-items:stretch;width:100%}.lk-settings-menu-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--lk-bg);padding:1rem;display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:.75rem 1.25rem;background-color:var(--lk-bg);border:1px solid var(--lk-border-color);border-radius:var(--lk-border-radius);box-shadow:var(--lk-box-shadow);min-width:50vw;min-height:50vh;max-width:100%;max-height:100%;overflow-y:auto}.video-overlay{position:absolute;bottom:1rem;right:1rem;background:var(--bg-card);border-radius:.75rem;padding:1rem;min-width:300px;max-width:500px;max-height:80vh;overflow:auto;box-shadow:0 4px 12px #0006;z-index:50}.video-overlay-minimized{min-width:unset;max-width:unset;padding:.5rem 1rem}.video-overlay-loading{min-height:100px}.video-loading{display:flex;align-items:center;justify-content:center;padding:2rem;color:var(--text-muted)}.connection-status{font-size:.75rem;color:var(--text-muted);padding:.25rem .5rem;background:#0003;border-radius:.25rem;margin-bottom:.5rem}.video-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem;font-weight:500;gap:.5rem}.video-header .video-controls{display:flex;gap:.25rem;margin-left:auto}.fullscreen-btn,.minimize-btn{padding:.25rem .5rem;background:transparent;border:1px solid var(--text-muted);border-radius:.25rem;color:var(--text);cursor:pointer;font-size:1rem;line-height:1;display:flex;align-items:center;justify-content:center}.fullscreen-btn:hover,.minimize-btn:hover{background:#ffffff1a}.video-overlay-fullscreen{position:fixed;top:0;left:0;right:0;bottom:0;max-width:none;max-height:none;min-width:100vw;min-height:100vh;border-radius:0;z-index:9999;background:#000}.video-overlay-fullscreen .video-header{position:absolute;top:0;left:0;right:0;padding:1rem;background:linear-gradient(to bottom,rgba(0,0,0,.8),transparent);z-index:10}.video-overlay-fullscreen .lk-video-conference{height:100vh}.participant-count{font-size:.75rem;color:var(--text-muted)}.video-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem;margin-bottom:.75rem}.video-participant{display:flex;flex-direction:column;align-items:center}.video-placeholder{width:100%;aspect-ratio:4/3;background:#1a1a2e;border-radius:.5rem;display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:.75rem}.participant-name{margin-top:.25rem;font-size:.75rem;color:var(--text-muted)}.video-controls{display:flex;gap:.5rem;justify-content:center}.control-btn{flex:1;padding:.5rem;border-radius:.5rem;font-size:.875rem;background:#333;color:var(--text)}.control-btn:hover{background:#444}.control-btn.active{background:var(--error)}.lecture-broadcast{position:fixed;bottom:1rem;right:1rem;background:var(--bg-card, #1a1a2e);border-radius:.75rem;overflow:hidden;box-shadow:0 4px 20px #00000080;z-index:100;width:400px;max-width:calc(100vw - 2rem)}.lecture-broadcast-minimized{width:auto;min-width:200px}.lecture-broadcast-fullscreen{position:fixed;top:0;left:0;right:0;bottom:0;width:100vw;height:100vh;max-width:none;border-radius:0;z-index:9999;background:#000}.broadcast-header{display:flex;justify-content:space-between;align-items:center;padding:.5rem .75rem;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.lecture-broadcast-fullscreen .broadcast-header{position:absolute;top:0;left:0;right:0;z-index:10;background:linear-gradient(to bottom,rgba(0,0,0,.8),transparent);padding:1rem}.broadcast-info{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.broadcast-live-badge{background:#ef4444;color:#fff;font-size:.625rem;font-weight:700;padding:.125rem .375rem;border-radius:.25rem;text-transform:uppercase;letter-spacing:.05em;animation:pulse-live 2s ease-in-out infinite}@keyframes pulse-live{0%,to{opacity:1}50%{opacity:.7}}.broadcast-title{color:#fff;font-size:.875rem;font-weight:500;max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.lecture-broadcast-fullscreen .broadcast-title{max-width:none;font-size:1rem}.broadcast-viewers{color:#ffffffb3;font-size:.75rem}.screen-share-badge{background:#3b82f6;color:#fff;font-size:.625rem;padding:.125rem .375rem;border-radius:.25rem}.broadcast-controls{display:flex;gap:.25rem}.broadcast-btn{padding:.375rem;background:#ffffff1a;border:none;border-radius:.25rem;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s ease}.broadcast-btn:hover{background:#fff3}.broadcast-btn.leave-btn{background:#ef44444d}.broadcast-btn.leave-btn:hover{background:#ef444480}.presenter-view{position:relative;background:#000;aspect-ratio:16 / 9}.lecture-broadcast-fullscreen .presenter-view{width:100%;height:100%;aspect-ratio:unset}.presenter-video{width:100%;height:100%;object-fit:contain}.presenter-placeholder{display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1a1a2e,#0f0f1a);aspect-ratio:16 / 9}.lecture-broadcast-fullscreen .presenter-placeholder{width:100%;height:100%;aspect-ratio:unset}.waiting-text{color:#ffffff80;font-size:.875rem}.presenter-pip{position:absolute;bottom:.75rem;right:.75rem;width:120px;border-radius:.5rem;overflow:hidden;box-shadow:0 2px 8px #0006;border:2px solid rgba(255,255,255,.2)}.lecture-broadcast-fullscreen .presenter-pip{width:200px;bottom:1.5rem;right:1.5rem}.pip-video{width:100%;aspect-ratio:4 / 3;object-fit:cover}.lecture-broadcast .lk-room-container{background:transparent}.lecture-broadcast .lk-participant-tile{border-radius:0}.user-list{position:absolute;top:1rem;right:1rem;background:var(--bg-card);border-radius:.75rem;padding:.75rem;min-width:180px;max-height:300px;overflow-y:auto;box-shadow:0 4px 12px #0006;z-index:40}.user-list-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:.5rem;border-bottom:1px solid #333;margin-bottom:.5rem;font-weight:500;font-size:.875rem}.user-count{background:var(--primary);color:#fff;font-size:.75rem;padding:.125rem .5rem;border-radius:9999px}.user-list-items{list-style:none}.user-item{display:flex;align-items:center;gap:.5rem;padding:.375rem 0}.user-avatar{width:24px;height:24px;background:var(--primary);border-radius:4px}.user-name{font-size:.875rem;color:var(--text)}.admin-toggle-btn{position:fixed;top:70px;right:20px;padding:8px 16px;background:#7c3aed;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;z-index:100;transition:background .2s}.admin-toggle-btn:hover{background:#6d28d9}.admin-panel-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000}.admin-panel{background:#1e1e2e;border-radius:12px;width:90%;max-width:800px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 20px 60px #00000080}.admin-panel-header{display:flex;justify-content:space-between;align-items:center;padding:16px 24px;background:#2d2d3d;border-bottom:1px solid #3d3d4d}.admin-panel-header h2{margin:0;color:#fff;font-size:18px}.close-btn{background:none;border:none;color:#888;font-size:24px;cursor:pointer;padding:0;line-height:1}.close-btn:hover{color:#fff}.admin-error{padding:12px 24px;background:#dc2626;color:#fff;font-size:14px}.admin-loading{padding:24px;text-align:center;color:#888}.admin-panel-content{flex:1;overflow-y:auto;padding:24px}.buildings-list{display:flex;flex-direction:column;gap:16px}.building-card{display:flex;gap:16px;background:#2d2d3d;border-radius:8px;padding:16px;transition:opacity .2s}.building-card.inactive{opacity:.5}.building-color{width:48px;height:48px;border-radius:8px;flex-shrink:0}.building-info{flex:1;min-width:0}.building-info h3{margin:0 0 4px;font-size:16px;color:#fff}.building-short{margin:0 0 4px;font-size:12px;color:#7c3aed;text-transform:uppercase}.building-desc{margin:0 0 8px;font-size:13px;color:#888}.building-pos{margin:0;font-size:11px;color:#666}.building-actions{display:flex;flex-direction:column;gap:8px}.building-actions button{padding:6px 12px;border:none;border-radius:4px;cursor:pointer;font-size:12px;background:#3d3d4d;color:#fff;transition:background .2s}.building-actions button:hover{background:#4d4d5d}.building-actions .delete-btn{background:#dc2626}.building-actions .delete-btn:hover{background:#b91c1c}.building-editor{color:#fff}.building-editor h3{margin:0 0 20px;font-size:18px}.form-group{margin-bottom:16px}.form-group label{display:block;margin-bottom:6px;font-size:13px;color:#888}.form-group input[type=text],.form-group input[type=number],.form-group textarea,.form-group select{width:100%;padding:10px 12px;background:#2d2d3d;border:1px solid #3d3d4d;border-radius:6px;color:#fff;font-size:14px}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:#7c3aed}.form-group textarea{min-height:80px;resize:vertical}.form-group input[type=color]{width:60px;height:36px;padding:2px;cursor:pointer}.form-group input[type=checkbox]{width:auto}.form-row{display:flex;gap:16px}.form-row .form-group{flex:1}.editor-actions{display:flex;gap:12px;margin-top:24px;padding-top:24px;border-top:1px solid #3d3d4d}.editor-actions button{padding:10px 24px;border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500}.save-btn{background:#22c55e;color:#fff}.save-btn:hover{background:#16a34a}.cancel-btn{background:#3d3d4d;color:#fff}.cancel-btn:hover{background:#4d4d5d}.admin-tabs{display:flex;gap:4px;padding:12px 24px;background:#2d2d3d;border-bottom:1px solid #3d3d4d}.admin-tab{padding:8px 20px;background:transparent;border:none;border-radius:6px;color:#888;cursor:pointer;font-size:14px;transition:all .2s}.admin-tab:hover{color:#fff;background:#ffffff0d}.admin-tab.active{color:#fff;background:#7c3aed}.building-generator{color:#fff}.generator-desc{color:#888;font-size:14px;margin:0 0 20px;line-height:1.5}.building-generator .form-group textarea{font-family:inherit}.char-count{display:block;text-align:right;font-size:12px;color:#666;margin-top:4px}.generate-btn{width:100%;padding:12px 24px;background:#7c3aed;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:background .2s}.generating-status{display:flex;align-items:center;justify-content:center;gap:12px;padding:20px;color:#888;font-size:14px}.loading-spinner{width:20px;height:20px;border:2px solid #3d3d4d;border-top-color:#7c3aed;border-radius:50%;animation:spin 1s linear infinite}.generated-result{margin-top:24px;padding-top:24px;border-top:1px solid #3d3d4d;text-align:center}.generated-result h4{margin:0 0 16px;font-size:16px;color:#fff}.generated-image-container{display:inline-block;padding:20px;background:#1a1a2e;border-radius:8px;border:1px solid #3d3d4d}.generated-image-container img{display:block;image-rendering:pixelated;image-rendering:crisp-edges;max-width:200px;height:auto}.download-hint{margin:12px 0;font-size:12px;color:#666}.regenerate-btn{padding:8px 20px;background:#3d3d4d;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:13px;transition:background .2s}.regenerate-btn:hover:not(:disabled){background:#4d4d5d}.regenerate-btn:disabled{opacity:.5;cursor:not-allowed}.profile-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.profile-modal{background:var(--bg-card, #1e1e2e);border-radius:1rem;width:90%;max-width:600px;max-height:85vh;display:flex;flex-direction:column;box-shadow:0 8px 24px #00000080;overflow:hidden}.profile-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;background:#2d2d3d;border-bottom:1px solid #3d3d4d}.profile-header h2{margin:0;font-size:1.25rem;color:var(--text, #fff)}.profile-header .close-btn{background:transparent;color:var(--text-muted, #888);font-size:1.75rem;width:2rem;height:2rem;padding:0;border:none;border-radius:.5rem;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.profile-header .close-btn:hover{background:#333;color:var(--text, #fff)}.profile-tabs{display:flex;gap:4px;padding:.75rem 1.5rem;background:#2d2d3d;border-bottom:1px solid #3d3d4d}.profile-tab{padding:.625rem 1.25rem;background:transparent;border:none;border-radius:.5rem;color:var(--text-muted, #888);cursor:pointer;font-size:.9rem;transition:all .2s}.profile-tab:hover{color:var(--text, #fff);background:#ffffff0d}.profile-tab.active{color:#fff;background:var(--primary, #7c3aed)}.profile-error{padding:.75rem 1.5rem;background:#dc2626;color:#fff;font-size:.875rem}.profile-content{flex:1;overflow-y:auto;padding:1.5rem}.avatar-section{display:flex;flex-direction:column;gap:1.5rem}.current-avatar h3,.avatar-generator h3{margin:0 0 .75rem;font-size:1rem;color:var(--text, #fff)}.avatar-preview-box{width:80px;height:80px;border-radius:.5rem;border:2px solid #3d3d4d;background:#1a1a2e;display:flex;align-items:center;justify-content:center;overflow:hidden}.avatar-image{width:64px;height:64px;image-rendering:pixelated;image-rendering:crisp-edges}.avatar-placeholder{width:100%;height:100%;background:linear-gradient(135deg,#7c3aed,#a855f7);display:flex;align-items:center;justify-content:center;font-size:2rem;font-weight:700;color:#fff}.generator-hint{color:var(--text-muted, #888);font-size:.875rem;margin:0 0 1rem;line-height:1.5}.avatar-description-input{width:100%;padding:.875rem;background:#2a2a3e;border:2px solid #3d3d4d;border-radius:.5rem;color:var(--text, #fff);font-size:.9rem;resize:vertical;min-height:80px;font-family:inherit}.avatar-description-input:focus{outline:none;border-color:var(--primary, #7c3aed)}.avatar-description-input::placeholder{color:var(--text-muted, #888);opacity:.7}.char-count{text-align:right;font-size:.75rem;color:var(--text-muted, #666);margin-top:.25rem}.generate-btn{width:100%;margin-top:1rem;padding:.875rem 1.5rem;background:var(--primary, #7c3aed);color:#fff;border:none;border-radius:.5rem;cursor:pointer;font-size:.9rem;font-weight:500;transition:background .2s}.generate-btn:hover:not(:disabled){background:#6d28d9}.generate-btn:disabled{opacity:.5;cursor:not-allowed}.generating-status{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:1rem;color:var(--text-muted, #888);font-size:.875rem}.loading-spinner{width:20px;height:20px;border:2px solid #3d3d4d;border-top-color:var(--primary, #7c3aed);border-radius:50%;animation:spin 1s linear infinite}.generated-preview{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid #3d3d4d}.generated-preview h4{margin:0 0 1rem;font-size:.95rem;color:var(--text, #fff);text-align:center}.sprite-directions{display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap}.sprite-direction{display:flex;flex-direction:column;align-items:center;gap:.375rem;padding:.75rem;background:#1a1a2e;border-radius:.5rem;border:1px solid #3d3d4d}.sprite-direction img{width:48px;height:48px;image-rendering:pixelated;image-rendering:crisp-edges}.sprite-direction span{font-size:.7rem;color:var(--text-muted, #888)}.sprite-saved-note{text-align:center;color:#4ade80;font-size:.875rem;margin:1rem 0 0}.pet-section{display:flex;flex-direction:column;gap:1.5rem}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;gap:1rem;color:var(--text-muted, #888)}.pet-preview-area{display:flex;flex-direction:column;align-items:center;gap:1rem}.pet-preview-box{width:100px;height:100px;border-radius:.75rem;border:2px solid #3d3d4d;background:#1a1a2e;display:flex;align-items:center;justify-content:center;position:relative}.pet-preview-box[data-enabled=true]{border-color:var(--primary, #7c3aed)}.pet-preview-display{display:flex;flex-direction:column;align-items:center;gap:.5rem}.pet-preview-display .pet-emoji{font-size:2.5rem}.pet-color-indicator{width:24px;height:8px;border-radius:4px}.preview-empty{color:var(--text-muted, #666);font-size:.875rem}.pet-toggle{display:flex;align-items:center;gap:.75rem;cursor:pointer;font-size:.9rem;color:var(--text, #fff)}.pet-toggle input{display:none}.pet-toggle .toggle-slider{width:44px;height:24px;background:#3d3d4d;border-radius:12px;position:relative;transition:background .2s}.pet-toggle .toggle-slider:after{content:"";position:absolute;width:18px;height:18px;background:#fff;border-radius:50%;top:3px;left:3px;transition:transform .2s}.pet-toggle input:checked+.toggle-slider{background:var(--primary, #7c3aed)}.pet-toggle input:checked+.toggle-slider:after{transform:translate(20px)}.pet-options{display:flex;flex-direction:column;gap:1.25rem}.option-group{display:flex;flex-direction:column;gap:.5rem}.option-group label{font-size:.875rem;font-weight:500;color:var(--text, #fff)}.pet-type-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:.5rem}.pet-type-btn{display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:.75rem .5rem;background:#2a2a3e;border:2px solid transparent;border-radius:.5rem;cursor:pointer;transition:all .2s}.pet-type-btn:hover{background:#333;border-color:#444}.pet-type-btn.active{background:var(--primary, #7c3aed);border-color:var(--primary, #7c3aed)}.pet-type-btn .pet-emoji{font-size:1.5rem}.pet-type-btn .pet-label{font-size:.75rem;color:var(--text, #fff)}.color-picker{display:flex;gap:.5rem;flex-wrap:wrap}.color-btn{width:36px;height:36px;border-radius:50%;border:3px solid transparent;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;color:#fff;font-size:.75rem;text-shadow:0 1px 2px rgba(0,0,0,.5)}.color-btn:hover{transform:scale(1.1)}.color-btn.active{border-color:var(--primary, #7c3aed);box-shadow:0 0 0 2px #1e1e2e,0 0 0 4px var(--primary, #7c3aed)}.pet-actions{margin-top:.5rem}.save-btn{width:100%;padding:.875rem 1.5rem;background:var(--primary, #7c3aed);color:#fff;border:none;border-radius:.5rem;cursor:pointer;font-size:.9rem;font-weight:500;transition:background .2s}.save-btn:hover:not(:disabled){background:#6d28d9}.save-btn:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 480px){.profile-modal{width:95%;max-height:90vh}.profile-content{padding:1rem}.sprite-directions{gap:.5rem}.sprite-direction{padding:.5rem}.sprite-direction img{width:40px;height:40px}}.world-page{display:flex;flex-direction:column;height:100vh;overflow:hidden}.world-header{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:var(--bg-card);border-bottom:1px solid #333;z-index:100}.header-left{display:flex;align-items:center;gap:1rem}.header-left h1{font-size:1.25rem;margin:0}.status{font-size:.75rem;padding:.25rem .5rem;border-radius:.25rem}.status.connected{background:#22c55e33;color:var(--success)}.status.disconnected{background:#ef444433;color:var(--error)}.header-right{display:flex;align-items:center;gap:1rem}.username{color:var(--text-muted)}.profile-btn{background:transparent;color:var(--text-muted);padding:.5rem 1rem;border:1px solid #444;font-size:.875rem}.profile-btn:hover{background:#ffffff0d;color:var(--text);border-color:var(--primary)}.logout-btn{background:transparent;color:var(--text-muted);padding:.5rem 1rem;border:1px solid #444;font-size:.875rem}.logout-btn:hover{background:#ffffff0d;color:var(--text)}.world-main{flex:1;position:relative;overflow:hidden}:root{--primary: #4f46e5;--primary-hover: #4338ca;--bg-dark: #1a1a2e;--bg-card: #16213e;--text: #eee;--text-muted: #888;--error: #ef4444;--success: #22c55e}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;background:var(--bg-dark);color:var(--text);min-height:100vh}#root{width:100%;height:100vh}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;gap:1rem}.loading-spinner{width:40px;height:40px;border:4px solid var(--bg-card);border-top-color:var(--primary);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}button{cursor:pointer;border:none;padding:.75rem 1.5rem;border-radius:.5rem;font-size:1rem;font-weight:500;transition:background-color .2s}button.primary{background:var(--primary);color:#fff}button.primary:hover{background:var(--primary-hover)}button.primary:disabled{opacity:.6;cursor:not-allowed}input{width:100%;padding:.75rem;border:1px solid #333;border-radius:.5rem;background:var(--bg-dark);color:var(--text);font-size:1rem}input:focus{outline:none;border-color:var(--primary)}.error-message{color:var(--error);font-size:.875rem}
