:root{--bg:#0d0d0d;--surface:#161616;--surface2:#1e1e1e;--surface3:#282828;--border:#333;--text:#f5f5f5;--text-muted:#888;--accent:#3498db;--accent2:#2980b9;--green:#22c55e;--red:#ef4444;--blue:#3b82f6;--orange:#f97316;--yellow:#eab308;--cyan:#1abc9c}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;background:var(--bg);color:var(--text);min-height:100vh;min-height:100dvh;overflow:hidden;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none;touch-action:pan-y}
@media(max-width:1024px){body{overflow-y:auto;overflow-x:hidden}}
button{cursor:pointer;border:none;background:none;color:inherit;font:inherit}
input,select{font:inherit}
::-webkit-scrollbar{width:6px;height:6px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}

/* LOADING / AUTH CHECK */
.loading-overlay{position:fixed;inset:0;background:var(--bg);display:flex;align-items:center;justify-content:center;z-index:9999;padding:20px;text-align:center}
.loading-card{background:var(--surface);border-radius:20px;padding:28px;max-width:420px;width:100%;box-shadow:0 25px 50px rgba(0,0,0,.5)}
.loading-icon{width:56px;height:56px;border-radius:16px;background:linear-gradient(135deg,var(--accent),var(--cyan));display:flex;align-items:center;justify-content:center;margin:0 auto 14px;font-size:22px}
.loading-title{font-size:18px;font-weight:700;margin-bottom:8px}
.loading-text{font-size:14px;color:var(--text-muted);line-height:1.5}
.loading-actions{margin-top:16px;display:flex;gap:10px;justify-content:center;flex-wrap:wrap}
.loading-btn{padding:10px 16px;border-radius:10px;background:var(--accent);color:#fff;text-decoration:none;font-size:13px;font-weight:600}
.loading-btn.secondary{background:var(--surface2);color:var(--text)}
.loading-overlay.hidden{display:none}
.is-hidden{display:none}
.text-muted-small{font-size:12px;color:var(--text-muted)}

/* QUIZ MODAL STYLES */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.8);display:flex;align-items:center;justify-content:center;z-index:10000;padding:20px}
.modal-content{background:var(--surface);border-radius:16px;max-width:500px;width:100%;box-shadow:0 25px 50px rgba(0,0,0,0.5)}
.modal-header{padding:20px 24px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.modal-header h3{font-size:18px;display:flex;align-items:center;gap:8px}
.modal-close{background:none;border:none;font-size:24px;color:var(--text-muted);cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:8px}
.modal-close:hover{background:var(--surface2)}
.modal-body{padding:24px}
.quiz-link-container{margin:16px 0}
.quiz-link-container label{display:block;font-size:13px;color:var(--text-muted);margin-bottom:8px}
.link-input-group{display:flex;gap:8px}
.link-input-group input{flex:1;padding:12px;background:var(--surface2);border:1px solid var(--border);border-radius:8px;color:var(--text);font-family:monospace;font-size:14px}
.btn-copy{padding:12px 16px;background:var(--accent);color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600}
.btn-copy:hover{background:var(--accent2)}
.quiz-info{font-size:13px;color:var(--text-muted);margin-top:12px}
.modal-actions{padding:16px 24px 24px;display:flex;gap:12px;justify-content:flex-end}
.btn-primary,.btn-secondary{padding:10px 20px;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer}
.btn-primary{background:var(--accent);color:#fff}
.btn-primary:hover{background:var(--accent2)}
.btn-secondary{background:var(--surface2);color:var(--text)}
.btn-secondary:hover{background:var(--surface3)}

/* PRE-JOIN */
.prejoin-overlay{position:fixed;inset:0;background:var(--bg);display:none;z-index:9998;padding:20px;overflow-y:auto}
.prejoin-overlay.active{display:flex;align-items:center;justify-content:center}
.prejoin-container{width:100%;max-width:900px;display:grid;grid-template-columns:1fr 1fr;gap:24px;background:var(--surface);border-radius:24px;overflow:hidden}
@media(max-width:768px){.prejoin-container{grid-template-columns:1fr;max-width:500px}}
.prejoin-preview{background:var(--bg);display:flex;flex-direction:column;padding:24px}
.prejoin-video-wrapper{position:relative;width:100%;aspect-ratio:16/9;background:var(--surface2);border-radius:16px;overflow:hidden;margin-bottom:16px}
.prejoin-video-wrapper video{width:100%;height:100%;object-fit:cover;transform:scaleX(-1)}
.prejoin-video-off{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--surface2);color:var(--text-muted)}
.prejoin-video-off i{font-size:48px;margin-bottom:12px}
.prejoin-video-off.hidden{display:none}
.prejoin-controls{display:flex;justify-content:center;gap:16px}
.prejoin-toggle{width:56px;height:56px;border-radius:50%;background:var(--surface2);display:flex;align-items:center;justify-content:center;font-size:20px;transition:.15s}
.prejoin-toggle:hover{background:var(--surface3)}
.prejoin-toggle.off{background:var(--red);color:#fff}
.prejoin-form{padding:32px;display:flex;flex-direction:column}
.prejoin-form h2{font-size:24px;margin-bottom:8px}
.prejoin-form>p{color:var(--text-muted);margin-bottom:24px;font-size:14px}
.prejoin-user{display:flex;align-items:center;gap:12px;padding:16px;background:var(--surface2);border-radius:12px;margin-bottom:20px}
.prejoin-user-avatar{width:48px;height:48px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:18px}
.prejoin-user-avatar img{width:100%;height:100%;border-radius:50%;object-fit:cover}
.prejoin-user-info h4{font-size:16px}
.prejoin-user-info p{font-size:13px;color:var(--text-muted)}
.prejoin-room-input{display:flex;gap:8px;margin-bottom:16px}
.prejoin-room-prefix{background:var(--surface2);border:1px solid var(--border);border-radius:12px;padding:14px 16px;font-weight:700;color:var(--accent);font-size:13px}
.prejoin-room-input input{flex:1;background:var(--surface2);border:1px solid var(--border);border-radius:12px;padding:14px 16px;color:var(--text);font-size:16px;font-weight:600;font-family:monospace;letter-spacing:3px;text-transform:uppercase}
.prejoin-room-input input:focus{outline:none;border-color:var(--accent)}
.device-select-group{margin-bottom:16px}
.device-select-group label{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-muted);margin-bottom:6px}
.device-select-group label i{font-size:14px}
.device-select-group select{width:100%;padding:12px 14px;background:var(--surface2);border:1px solid var(--border);border-radius:10px;color:var(--text);font-size:14px}
.prejoin-form .btn-primary{margin-top:auto}
.btn-logout{margin-top:16px;padding:12px;background:transparent;border:1px solid var(--border);border-radius:10px;color:var(--text-muted);font-size:14px}
.btn-logout:hover{background:var(--surface2);color:var(--text)}

/* MAIN APP */
.app-container{display:none;height:100vh;height:100dvh;flex-direction:column}
.app-container.active{display:flex}

/* TOP HEADER */
.top-header{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0;gap:12px}
.header-left{display:flex;align-items:center;gap:12px}
.header-logo{display:flex;align-items:center;gap:8px;font-weight:700;font-size:16px}
.header-logo .logo-icon{width:32px;height:32px;background:linear-gradient(135deg,var(--accent),var(--cyan));border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:14px}
.room-badge{display:flex;align-items:center;gap:8px;padding:6px 12px;background:var(--surface2);border-radius:8px;font-size:12px}
.room-badge-id{font-family:monospace;font-weight:600;color:var(--accent);letter-spacing:1px}
.room-badge-sep{color:var(--border)}
.room-badge i{color:var(--green)}
.header-center{flex:1;display:flex;justify-content:center}
.meeting-timer{display:flex;align-items:center;gap:8px;padding:6px 14px;background:var(--surface2);border-radius:8px;font-size:13px;font-family:monospace}
.meeting-timer i{color:var(--red)}
.meeting-timer.recording i{animation:blink 1s infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}
.header-right{display:flex;align-items:center;gap:8px}
.header-btn{width:40px;height:40px;border-radius:10px;background:var(--surface2);display:flex;align-items:center;justify-content:center;font-size:16px;transition:.15s;position:relative}
.header-btn:hover{background:var(--surface3)}
.header-btn.active{background:var(--accent);color:#fff}
.header-btn.danger{background:var(--red);color:#fff}
.header-btn-badge{position:absolute;top:-4px;right:-4px;min-width:18px;height:18px;background:var(--accent);border-radius:9px;font-size:10px;font-weight:600;display:flex;align-items:center;justify-content:center;padding:0 5px}

/* HEADER MENU DROPDOWN */
.header-menu-container{position:relative}
.header-menu{position:absolute;top:calc(100% + 8px);right:0;background:var(--surface);border:1px solid var(--border);border-radius:12px;min-width:200px;padding:8px;box-shadow:0 10px 40px rgba(0,0,0,.5);z-index:1000;opacity:0;visibility:hidden;transform:translateY(-8px);transition:.15s}
.header-menu.active{opacity:1;visibility:visible;transform:translateY(0)}
.header-menu-item{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:8px;font-size:14px;width:100%;text-align:left;transition:.15s}
.header-menu-item:hover{background:var(--surface2)}
.header-menu-item i{width:20px;text-align:center;font-size:15px;color:var(--text-muted)}
.header-menu-item span{flex:1}
.header-menu-item .menu-badge{background:var(--accent);color:#fff;padding:2px 8px;border-radius:10px;font-size:11px;font-weight:600}
.header-menu-item.active i{color:var(--accent)}
.header-menu-item.danger{color:var(--red)}
.header-menu-item.danger i{color:var(--red)}
.header-menu-divider{height:1px;background:var(--border);margin:8px 0}
@media(max-width:600px){.header-logo span{display:none}.room-badge{display:none}.meeting-timer span{display:none}}

/* MAIN CONTENT */
.main-content{flex:1;display:flex;overflow:hidden;position:relative; margin-top: 0;} /* Desktop default */

@media(max-width:1024px) and (orientation:portrait){
    .main-content { margin-top: 60px; } /* Push content down on mobile due to fixed header */
}

/* VIDEO AREA */
.video-area{flex:1;display:flex;flex-direction:column;min-width:0;position:relative}
.video-grid{flex:1;display:grid;gap:6px;padding:8px;overflow:hidden}
.video-grid.auto-layout{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));grid-auto-rows:1fr}
.video-grid[data-count="1"]{grid-template-columns:1fr}
.video-grid[data-count="2"]{grid-template-columns:repeat(2,1fr)}
.video-grid[data-count="3"],.video-grid[data-count="4"]{grid-template-columns:repeat(2,1fr);grid-template-rows:repeat(2,1fr)}
.video-grid[data-count="5"],.video-grid[data-count="6"]{grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(2,1fr)}
.video-grid[data-count="7"],.video-grid[data-count="8"],.video-grid[data-count="9"]{grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(3,1fr)}
.video-grid.pinned-view{grid-template-columns:1fr 280px;grid-template-rows:1fr}
.video-grid.pinned-view .video-tile.pinned{grid-row:1;grid-column:1}
.video-grid.pinned-view .video-tiles-strip{grid-row:1;grid-column:2;display:flex;flex-direction:column;gap:6px;overflow-y:auto}
@media(max-width:768px){.video-grid.pinned-view{grid-template-columns:1fr;grid-template-rows:1fr 120px}.video-grid.pinned-view .video-tiles-strip{flex-direction:row;overflow-x:auto}.video-grid.pinned-view .video-tiles-strip .video-tile{min-width:160px;height:100%}}
.video-tile{position:relative;background:var(--surface);border-radius:12px;overflow:hidden;display:flex;align-items:center;justify-content:center}
.video-tile video{width:100%;height:100%;object-fit:cover}
.video-tile.mirror video{transform:scaleX(-1)}
.video-tile-overlay{position:absolute;inset:0;pointer-events:none}
.video-tile-top{position:absolute;top:8px;left:8px;right:8px;display:flex;justify-content:space-between;pointer-events:auto}
.video-tile-actions{display:flex;gap:4px;opacity:0;transition:.2s}
.video-tile:hover .video-tile-actions{opacity:1}
.video-tile-action{width:28px;height:28px;border-radius:6px;background:rgba(0,0,0,.6);display:flex;align-items:center;justify-content:center;font-size:12px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}
.video-tile-action:hover{background:var(--accent)}
.video-tile-action.pinned{background:var(--accent)}
.video-tile-status{display:flex;gap:4px}
.video-tile-status span{width:24px;height:24px;border-radius:6px;background:rgba(0,0,0,.6);display:flex;align-items:center;justify-content:center;font-size:10px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}
.video-tile-status .muted{color:var(--red)}
.video-tile-bottom{position:absolute;bottom:0;left:0;right:0;padding:8px 12px;background:linear-gradient(transparent,rgba(0,0,0,.7));display:flex;align-items:center;justify-content:space-between}
.video-tile-name{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:500}
.video-tile-name .speaking{width:8px;height:8px;background:var(--green);border-radius:50%;animation:pulse-speak 1s infinite}
@keyframes pulse-speak{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.3);opacity:.7}}
.video-placeholder{width:80px;height:80px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center;font-size:32px;font-weight:700}

/* SHARED CONTENT */
.shared-content{display:none;position:absolute;inset:8px;background:var(--surface);border-radius:12px;overflow:hidden;z-index:5}
.shared-content.active{display:flex;flex-direction:column}
.shared-content-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--surface2)}
.shared-content-header h4{font-size:14px;display:flex;align-items:center;gap:8px}
.shared-content-header h4 i{color:var(--accent)}
.shared-content-body{flex:1;display:flex;align-items:center;justify-content:center;overflow:hidden}
.shared-content-body video,.shared-content-body canvas{max-width:100%;max-height:100%;object-fit:contain}
#whiteboardCanvas{background:#fff;cursor:crosshair}
.whiteboard-tools{display:flex;gap:8px;padding:8px 16px;background:var(--surface2);border-top:1px solid var(--border)}
.whiteboard-tool{width:36px;height:36px;border-radius:8px;background:var(--surface);display:flex;align-items:center;justify-content:center;font-size:14px}
.whiteboard-tool:hover{background:var(--surface3)}
.whiteboard-tool.active{background:var(--accent);color:#fff}
.whiteboard-tool input[type="color"]{width:100%;height:100%;border:none;padding:0;cursor:pointer;border-radius:8px}

/* STUDENTS PANEL */
.students-panel{width:280px;background:var(--surface);border-left:1px solid var(--border);display:flex;flex-direction:column;transform:translateX(100%);transition:transform .3s ease;position:absolute;right:0;top:0;bottom:0;z-index:20}
.students-panel.open{transform:translateX(0)}
.panel-header{display:flex;align-items:center;justify-content:space-between;padding:16px;border-bottom:1px solid var(--border)}
.panel-header h3{font-size:16px;display:flex;align-items:center;gap:8px}
.panel-header h3 i{color:var(--accent)}
.panel-close{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center}
.panel-close:hover{background:var(--surface2)}
.students-list{flex:1;overflow-y:auto;padding:12px}
.student-item{display:flex;align-items:center;gap:12px;padding:12px;border-radius:10px;margin-bottom:8px;background:var(--surface2)}
.student-item:hover{background:var(--surface3)}
.student-avatar{width:40px;height:40px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:14px;flex-shrink:0}
.student-avatar img{width:100%;height:100%;border-radius:50%;object-fit:cover}
.student-info{flex:1;min-width:0}
.student-info h5{font-size:14px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.student-info p{font-size:11px;color:var(--text-muted);display:flex;align-items:center;gap:4px}
.student-info p i{font-size:8px}
.student-info p .online{color:var(--green)}
.student-actions{display:flex;gap:4px}
.student-action{width:28px;height:28px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:12px;background:var(--surface)}
.student-action:hover{background:var(--accent);color:#fff}
.student-action.muted{color:var(--red)}
.student-hand{color:var(--yellow);animation:wave 0.5s ease-in-out infinite alternate}
@keyframes wave{0%{transform:rotate(-10deg)}100%{transform:rotate(10deg)}}

/* CHAT PANEL */
.chat-panel{width:340px;background:var(--surface);border-left:1px solid var(--border);display:flex;flex-direction:column;transform:translateX(100%);transition:transform .3s ease;position:absolute;right:0;top:0;bottom:0;z-index:18}
.chat-panel.open{transform:translateX(0)}
.chat-messages{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:12px}
.chat-message{max-width:85%;padding:10px 14px;border-radius:12px;font-size:14px;line-height:1.4;word-wrap:break-word}
.chat-message.sent{align-self:flex-end;background:var(--accent);color:#fff;border-bottom-right-radius:4px}
.chat-message.received{align-self:flex-start;background:var(--surface2);border-bottom-left-radius:4px}
.chat-message-header{display:flex;align-items:center;gap:6px;margin-bottom:4px;font-size:11px;opacity:0.8}
.chat-message-header .sender{font-weight:600}
.chat-message-header .time{opacity:0.7}
.chat-input-container{padding:12px;border-top:1px solid var(--border);display:flex;gap:8px}
.chat-input{flex:1;padding:12px 16px;background:var(--surface2);border:1px solid var(--border);border-radius:24px;color:var(--text);font-size:14px;resize:none}
.chat-input:focus{outline:none;border-color:var(--accent)}
.chat-send{width:44px;height:44px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center;font-size:16px;color:#fff;flex-shrink:0}
.chat-send:hover{background:var(--accent2)}
.chat-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--text-muted);text-align:center;padding:20px}
.chat-empty i{font-size:48px;margin-bottom:12px;opacity:0.5}
@media(max-width:768px){.chat-panel{position:fixed;width:100%;height:70vh;bottom:0;left:0;right:0;top:auto;transform:translateY(100%);border-left:none;border-top:1px solid var(--border);border-radius:20px 20px 0 0}.chat-panel.open{transform:translateY(0)}}

/* RAISE HAND */
.control-btn.hand-raised{background:var(--yellow);color:#000}
.control-btn.hand-raised i{animation:wave 0.5s ease-in-out infinite alternate}
.video-tile-hand{position:absolute;top:8px;right:8px;width:32px;height:32px;background:var(--yellow);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:16px;animation:pulse 1s ease-in-out infinite;z-index:5}
@keyframes pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.1)}}

/* TRANSCRIPT PANEL */
.transcript-panel{width:360px;background:var(--surface);border-left:1px solid var(--border);display:flex;flex-direction:column;transform:translateX(100%);transition:width .3s ease,transform .3s ease;position:absolute;right:0;top:0;bottom:0;z-index:15}
.transcript-panel.open{transform:translateX(0)}
.transcript-panel.expanded{width:50vw}
@media(max-width:768px){.transcript-panel{width:100%}.transcript-panel.expanded{width:100%}}
.transcript-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--border);gap:8px;flex-wrap:wrap}
.transcript-header-left{display:flex;align-items:center;gap:10px}
.transcript-header-left h3{font-size:15px;display:flex;align-items:center;gap:8px}
.transcript-header-left h3 i{color:var(--accent)}
.btn-auto-tts{display:flex;align-items:center;gap:6px;padding:6px 12px;background:var(--surface2);border-radius:8px;font-size:12px;font-weight:500;transition:.15s}
.btn-auto-tts:hover{background:var(--surface3)}
.btn-auto-tts i{font-size:14px}
.btn-auto-tts.active{background:var(--green);color:#fff}
.btn-auto-tts .queue-count{background:var(--accent);padding:1px 6px;border-radius:8px;font-size:10px;display:none}
.btn-auto-tts .queue-count.show{display:inline}
.transcript-header-right{display:flex;align-items:center;gap:6px}
.transcript-view-toggle{display:flex;background:var(--surface2);border-radius:6px;padding:2px}
.transcript-view-toggle button{padding:5px 10px;border-radius:5px;font-size:11px;font-weight:500;color:var(--text-muted)}
.transcript-view-toggle button.active{background:var(--accent);color:#fff}
.transcript-expand{width:28px;height:28px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:12px}
.transcript-expand:hover{background:var(--surface2)}
.transcript-content{flex:1;overflow:hidden;display:flex;flex-direction:column}
.transcript-unified{flex:1;overflow-y:auto;padding:12px;scroll-behavior:smooth}
.transcript-unified.hidden{display:none}
.transcript-entry{margin-bottom:16px;padding:14px;background:var(--surface2);border-radius:12px}
.transcript-entry-header{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.transcript-entry-avatar{width:28px;height:28px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600}
.transcript-entry-name{font-weight:600;font-size:13px}
.transcript-entry-time{font-size:11px;color:var(--text-muted);margin-left:auto}
.transcript-entry-original{font-size:13px;line-height:1.5;padding:10px 12px;background:var(--surface);border-radius:8px;margin-bottom:8px;border-left:3px solid var(--text-muted);color:var(--text-muted)}
.transcript-entry-translation{font-size:14px;line-height:1.5;padding:10px 12px;background:rgba(52,152,219,.1);border-radius:8px;border-left:3px solid var(--accent)}
.transcript-entry-actions{display:flex;gap:8px;margin-top:10px}
.btn-play-entry{display:flex;align-items:center;gap:5px;padding:6px 12px;background:var(--surface);border-radius:6px;font-size:11px;transition:.15s}
.btn-play-entry:hover{background:var(--accent);color:#fff}
.btn-play-entry.playing{background:var(--green);color:#fff}
.transcript-split{flex:1;display:none;overflow:hidden}
.transcript-split.active{display:flex}
.transcript-column{flex:1;display:flex;flex-direction:column;min-width:0}
.transcript-column:first-child{border-right:1px solid var(--border)}
.transcript-column-header{padding:10px 14px;background:var(--surface2);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted)}
.transcript-column-content{flex:1;overflow-y:auto;padding:12px;scroll-behavior:smooth}
.transcript-line{margin-bottom:14px;padding-bottom:14px;border-bottom:1px solid var(--border)}
.transcript-line:last-child{border-bottom:none}
.transcript-line-header{display:flex;align-items:center;gap:6px;margin-bottom:6px}
.transcript-line-avatar{width:20px;height:20px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:600}
.transcript-line-name{font-size:11px;font-weight:600}
.transcript-line-time{font-size:10px;color:var(--text-muted);margin-left:auto}
.transcript-line-text{font-size:13px;line-height:1.5}
.transcript-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px;text-align:center;color:var(--text-muted)}
.transcript-empty i{font-size:48px;margin-bottom:16px;opacity:.5}
.transcript-empty p{font-size:14px}

/* SETTINGS MODAL */
.settings-overlay{position:fixed;inset:0;background:rgba(0,0,0,.7);display:none;align-items:center;justify-content:center;z-index:1000;padding:20px}
.settings-overlay.open{display:flex}
.settings-modal{background:var(--surface);border-radius:20px;width:100%;max-width:600px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column}
.settings-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border)}
.settings-header h2{font-size:20px;display:flex;align-items:center;gap:10px}
.settings-header h2 i{color:var(--accent)}
.settings-close{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:16px}
.settings-close:hover{background:var(--surface2)}
.settings-tabs{display:flex;padding:0 24px;gap:4px;border-bottom:1px solid var(--border);overflow-x:auto}
.settings-tab{padding:14px 20px;font-size:14px;font-weight:500;color:var(--text-muted);border-bottom:2px solid transparent;white-space:nowrap}
.settings-tab:hover{color:var(--text)}
.settings-tab.active{color:var(--accent);border-bottom-color:var(--accent)}
.settings-content{flex:1;overflow-y:auto;padding:24px}
.settings-section{display:none}
.settings-section.active{display:block}
.settings-section h4{font-size:14px;font-weight:600;margin-bottom:16px;color:var(--text-muted);display:flex;align-items:center;gap:8px}
.settings-section h4 i{font-size:14px}
.setting-row{margin-bottom:20px}
.setting-row label{display:block;font-size:13px;font-weight:500;margin-bottom:8px}
.setting-row select,.setting-row input[type="text"]{width:100%;padding:12px 14px;background:var(--surface2);border:1px solid var(--border);border-radius:10px;color:var(--text);font-size:14px}
.setting-row select:focus,.setting-row input:focus{outline:none;border-color:var(--accent)}
.setting-row-inline{display:flex;align-items:center;justify-content:space-between;padding:12px 0;border-bottom:1px solid var(--border)}
.setting-row-inline label{margin-bottom:0}
.toggle-switch{width:48px;height:26px;background:var(--surface2);border-radius:13px;position:relative;cursor:pointer;transition:.2s}
.toggle-switch::after{content:'';position:absolute;top:3px;left:3px;width:20px;height:20px;background:var(--text);border-radius:50%;transition:.2s}
.toggle-switch.active{background:var(--green)}
.toggle-switch.active::after{left:25px}
.settings-footer{display:flex;justify-content:flex-end;gap:12px;padding:16px 24px;border-top:1px solid var(--border)}
.btn-settings-save{padding:12px 24px;background:var(--accent);color:#fff;border-radius:10px;font-weight:600}
.btn-settings-save:hover{background:var(--accent2)}

/* CONTROL BAR - ENLARGED FOR MOBILE */
.control-bar{display:flex;align-items:center;justify-content:center;padding:16px 20px;background:var(--surface);border-top:1px solid var(--border);gap:10px;flex-shrink:0;position:relative}
.control-btn{display:flex;flex-direction:column;align-items:center;gap:6px;padding:14px 20px;border-radius:14px;background:var(--surface2);transition:.15s;min-width:80px}
.control-btn:hover{background:var(--surface3)}
.control-btn i{font-size:22px}
.control-btn span{font-size:11px;color:var(--text-muted);font-weight:500}
.control-btn.active{background:var(--accent)}
.control-btn.active span{color:#fff}
.control-btn.muted{background:var(--red)}
.control-btn.muted span{color:#fff}
.control-btn.danger{background:var(--red)}
.control-btn.danger:hover{background:#dc2626}
.control-btn.danger span{color:#fff}
.mic-visualizer{display:flex;align-items:flex-end;gap:3px;height:28px;padding:6px 8px;background:var(--surface2);border-radius:10px;min-width:42px}
.mic-visualizer span{display:block;width:4px;height:6px;background:var(--accent);border-radius:4px;opacity:.5;transition:height .08s ease, opacity .15s ease}
.mic-visualizer.active span{opacity:1}
.mic-visualizer.muted{opacity:.4}
.control-divider{width:1px;height:44px;background:var(--border);margin:0 10px}
.control-bar-left,.control-bar-right{position:absolute;display:flex;align-items:center;gap:10px}
.control-bar-left{left:20px}
.control-bar-right{right:20px}
@media(max-width:768px){
  .control-bar{padding:16px 12px;gap:8px}
  .control-btn{min-width:70px;padding:12px 16px}
  .control-btn i{font-size:20px}
  .control-btn span{font-size:10px;display:block}
  .mic-visualizer{height:22px;min-width:36px;padding:4px 6px}
  .mic-visualizer span{width:3px}
  .control-divider{display:none}
  .control-bar-left,.control-bar-right{position:static}
  .control-bar{flex-wrap:wrap;gap:8px;justify-content:space-around;padding-top:14px;padding-bottom:calc(14px + env(safe-area-inset-bottom))}
}

/* TOAST */
.toast{position:fixed;bottom:100px;left:50%;transform:translateX(-50%);background:var(--surface);border:1px solid var(--border);padding:14px 24px;border-radius:12px;font-size:14px;z-index:2000;display:none;animation:fadeUp .3s}
.toast.show{display:block}
@keyframes fadeUp{from{opacity:0;transform:translateX(-50%) translateY(20px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}

/* MOBILE & TABLET RESPONSIVE - PORTRAIT */
@media(max-width:1024px) and (orientation:portrait){
  body{padding-bottom:calc(80px + env(safe-area-inset-bottom))} /* Space for bottom nav */
  .app-container{height:100vh;height:100dvh;overflow:hidden;padding-top:env(safe-area-inset-top)}
  
  .main-content{flex-direction:column;overflow:hidden;height:100%}
  .video-area{flex:1;overflow-y:auto;padding-bottom:10px}
  .video-grid{height:auto;min-height:0;overflow:visible;padding-bottom:80px} /* Scrollable content */
  
  /* Sticky Header - FIXED positioning for mobile */
  .top-header{position:fixed;top:0;left:0;right:0;z-index:100;background:rgba(22,22,22,0.95);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:none;box-shadow:0 4px 20px rgba(0,0,0,0.2);padding-top:max(10px, env(safe-area-inset-top))}
  
  /* Mobile Bottom Nav (Zoom Style) */
  .control-bar{
    position:fixed;
    bottom:0;
    left:0;
    right:0;
    background:rgba(22,22,22,0.95);
    -webkit-backdrop-filter:blur(10px);
    backdrop-filter:blur(10px);
    padding:12px 0 calc(12px + env(safe-area-inset-bottom));
    border-top:1px solid rgba(255,255,255,0.1);
    justify-content:space-evenly; /* Spread items evenly */
    gap:0;
    z-index:200;
  }
  
  .control-btn{
    background:transparent;
    padding:6px;
    min-width:64px;
    gap:4px;
    border-radius:8px;
  }
  .control-btn:hover{background:rgba(255,255,255,0.05)}
  .control-btn.active{background:transparent} /* No bg for active state on mobile nav, just color */
  .control-btn.active i{color:var(--green)}
  .control-btn.active span{color:var(--green)}
  
  .control-btn i{font-size:24px;margin-bottom:2px}
  .control-btn span{font-size:10px;font-weight:500;color:#999}
  
  /* Hide less important buttons on mobile nav bar, move to 'More' */
  #btnWhiteboard, #btnTools, #btnRecord, #btnTranscribe, #btnQuiz, #btnChat, #btnRaiseHand { display:none; } 
  
  /* Ensure critical buttons are visible + Chat/Hand moved to More or kept if space permits. 
     User requested specific layout. Let's keep Mic, Cam, Leave, and maybe Menu triggers.
     Actually, let's keep Mic, Cam, Chat, Hand, Leave as primary. 
  */
  #btnMic, #btnCamera, #btnChat, #btnRaiseHand, #btnLeave { display:flex; }
  
  /* Leave button specific styling for nav */
  #btnLeave{color:var(--red)}
  #btnLeave span{color:var(--red)}
  #btnLeave.danger{background:transparent}
  
  /* Panels - Bottom Sheet Style */
  .students-panel, .chat-panel, .transcript-panel{
    position:fixed;
    inset:auto 0 0 0;
    top:auto;
    bottom:0;
    height:75vh;
    width:100%;
    transform:translateY(100%);
    border-radius:24px 24px 0 0;
    border:none;
    box-shadow:0 -10px 40px rgba(0,0,0,0.5);
    transition:transform 0.3s cubic-bezier(0.2, 0.8, 0.2, 1);
    z-index:300;
  }
  .students-panel.open, .chat-panel.open, .transcript-panel.open{
    transform:translateY(0);
  }
  
  /* Shared Content */
  .shared-content{z-index:80;margin-top:60px} /* Below header */
}

/* SMALL PHONES */
@media(max-width:480px){
  .control-btn{min-width:50px}
  .control-btn span{font-size:9px}
  .video-grid.auto-layout{grid-template-columns:1fr 1fr} /* 2-col grid default */
}
