:root{color:#152238;font-synthesis:none;text-rendering:optimizelegibility;background:#f7fbff;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}body{min-width:320px;margin:0}button,input,select,textarea{font:inherit}button{cursor:pointer}.app{color:#152238;background:linear-gradient(135deg,#1d72f31f,#0000 32%),linear-gradient(315deg,#57c28924,#0000 28%),#f7fbff;min-height:100vh}.app.dark{color:#eef6ff;background:linear-gradient(135deg,#3687ff29,#0000 32%),linear-gradient(315deg,#52c79324,#0000 28%),#101722}.shell{min-height:100vh}.topbar{justify-content:space-between;align-items:center;height:70px;padding:0 24px;display:flex}.brand,.user-pill,.nav-item,.icon-button,.chip,.secondary,.primary,.action-card,.subject{border:0;border-radius:14px}.brand{color:inherit;background:0 0;align-items:center;gap:10px;font-size:1.1rem;font-weight:800;display:inline-flex}.brand-mark{color:#fff;background:#1d72f3;border-radius:12px;place-items:center;width:38px;height:38px;display:grid}.user-pill{background:#ffffffc2;align-items:center;gap:10px;padding:8px 10px;display:flex;box-shadow:0 12px 40px #1e447814}.dark .user-pill,.dark .panel,.dark .chat-panel,.dark .chat-tools,.dark .paper{background:#151f2ee6}.workspace{grid-template-columns:250px minmax(0,1fr);gap:18px;padding:0 24px 24px;display:grid}.sidebar{background:#ffffffb8;border-radius:20px;align-self:start;gap:8px;padding:12px;display:grid;position:sticky;top:86px;box-shadow:0 18px 50px #1e447814}.dark .sidebar{background:#151f2edb}.nav-item{text-align:left;color:inherit;background:0 0;align-items:center;gap:10px;padding:12px;display:flex}.nav-item.active,.nav-item:hover{color:#135ec9;background:#e7f0ff}.dark .nav-item.active,.dark .nav-item:hover{color:#9ec5ff;background:#4a90ff2e}.content{min-width:0}section{max-width:1180px;margin:0 auto}.hero{grid-template-columns:1fr 420px;align-items:center;gap:38px;min-height:calc(100vh - 90px);padding:30px 0 80px;display:grid}.hero h1{color:#105fcf;margin:0;font-size:clamp(3.8rem,10vw,7.4rem);line-height:.9}.hero p,.section-title p,.welcome p{color:#536276;max-width:620px;line-height:1.6}.dark .hero p,.dark .section-title p,.dark .welcome p,.dark small,.dark .hint{color:#bac9dc}.eyebrow{color:#138267;text-transform:uppercase;letter-spacing:0;font-size:.75rem;font-weight:800}.hero-actions,.stats-row,.toolbar,.message-actions,.badge-row{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.primary,.secondary{justify-content:center;align-items:center;gap:8px;min-height:44px;padding:10px 16px;font-weight:800;display:inline-flex}.primary{color:#182235;background:#ffd84d;box-shadow:0 10px 24px #f5b00038}.secondary{color:#165fc8;background:#e9f3ff}.dark .secondary{color:#b8d5ff;background:#4a90ff2e}.theme-toggle,.icon-button{width:38px;height:38px;color:inherit;background:#ffffffb8;place-items:center;display:grid}.theme-toggle{z-index:10;position:fixed;bottom:18px;right:18px;box-shadow:0 14px 30px #1e447829}.paper,.panel,.chat-panel,.chat-tools{background:#ffffffdb;border:1px solid #5362761f;box-shadow:0 18px 50px #1e447814}.paper{border-radius:22px;gap:12px;padding:28px;display:grid;transform:rotate(-2deg)}.paper span{background:#f2f7ff;border-radius:12px;padding:12px}.section-title{align-items:center;gap:16px;margin:12px 0 22px;display:flex}.section-title>svg{color:#1d72f3;flex:none}h2{margin:6px 0;font-size:clamp(2rem,4vw,3rem)}h3{margin-top:0}.narrow{max-width:620px}.form,.panel,.chat-tools{border-radius:20px;gap:14px;padding:18px;display:grid}.grid-form{background:#ffffffdb;border-radius:20px;grid-template-columns:repeat(2,minmax(0,1fr))}label{color:inherit;gap:7px;font-weight:700;display:grid}input,select,textarea{color:#152238;background:#fff;border:1px solid #53627638;border-radius:12px;width:100%;padding:12px}textarea{resize:vertical;min-height:110px}.dark input,.dark select,.dark textarea{color:#eef6ff;background:#111c2a;border-color:#ffffff29}fieldset{border:0;grid-column:1/-1;margin:0;padding:0}legend{margin-bottom:8px;font-weight:800}.chip-grid,.quick-actions{flex-wrap:wrap;gap:8px;display:flex}.chip{color:#165fc8;background:#edf4ff;padding:9px 12px;font-weight:700}.chip.selected,.subject.selected{color:#137a5f;background:#dff7eb;outline:2px solid #57c289}.dark .chip{color:#cfe1ff;background:#ffffff14}.welcome{justify-content:space-between;align-items:end;gap:16px;margin-bottom:18px;display:flex}.stats-row span,.badge,.metric{background:#ffffffc7;border-radius:14px;align-items:center;gap:8px;padding:10px 12px;display:inline-flex}.dark .stats-row span,.dark .badge,.dark .metric{background:#ffffff14}.action-grid,.subject-grid,.metric-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;display:grid}.action-card,.subject{text-align:left;min-height:150px;color:inherit;background:#ffffffdb;border:1px solid #5362761f;gap:10px;padding:18px;display:grid;box-shadow:0 14px 34px #1e447812}.action-card:hover,.subject:hover{transition:transform .16s;transform:translateY(-2px)}.action-card svg,.subject svg,.metric svg{color:#1d72f3}.action-card span,small,.hint{color:#617083;line-height:1.5}.two-columns{grid-template-columns:minmax(0,1fr) minmax(320px,.72fr);gap:14px;margin-top:16px;display:grid}.panel.soft{background:#f2fbf7}.dark .panel.soft{background:#1b3a328c}.activity,.file-row{border-bottom:1px solid #5362761f;gap:3px;padding:12px 0;display:grid}.chat-layout{grid-template-columns:310px minmax(0,1fr);gap:14px;height:calc(100vh - 110px);display:grid}.chat-tools,.chat-panel{border-radius:20px}.chat-panel{grid-template-rows:minmax(0,1fr) auto;display:grid;overflow:hidden}.messages{align-content:start;gap:12px;padding:18px;display:grid;overflow:auto}.message{white-space:pre-wrap;background:#eef5ff;border-radius:18px;max-width:78%;padding:14px}.message.student{background:#dff7eb;justify-self:end}.dark .message{background:#4a90ff2e}.dark .message.student{background:#57c2892e}.message-head{justify-content:space-between;gap:10px;font-size:.85rem;display:flex}.composer{border-top:1px solid #5362761f;grid-template-columns:auto minmax(0,1fr) auto;gap:10px;padding:14px;display:grid}.composer textarea{min-height:58px}.send{align-self:stretch}.mic-button{align-self:stretch;min-width:48px;padding:10px}.listening{color:#137a5f;background:#dff7eb;outline:2px solid #57c289}.voice-card{background:#1d72f314;border-radius:16px;gap:10px;padding:14px;display:grid}.voice-card p{color:#617083;margin:4px 0 0;line-height:1.45}.voice-controls{flex-wrap:wrap;gap:8px;display:flex}.toolbar{background:#ffffffb8;border-radius:18px;margin-bottom:14px;padding:14px}.toolbar label{flex:1;min-width:150px}.exercise-list{gap:12px;margin-bottom:14px;display:grid}.exercise{background:#ffffffdb;border-radius:18px;gap:10px;padding:16px;display:grid}.dark .exercise,.dark .toolbar{background:#151f2edb}.result,.answer-box{color:#342b08;background:#fff7d0;border-radius:18px;gap:8px;margin-top:14px;padding:16px;display:grid}.result span{align-items:center;gap:8px;display:flex}.video-layout{grid-template-columns:300px minmax(0,1fr);gap:14px;display:grid}.video-settings{align-self:start}.video-stage{gap:12px;display:grid}.video-screen{background:linear-gradient(135deg,#1d72f32e,#0000 40%),linear-gradient(315deg,#ffd84d47,#0000 36%),#f7fbff;border:1px solid #5362761f;border-radius:22px;min-height:430px;position:relative;overflow:hidden;box-shadow:0 18px 50px #1e44781a}.dark .video-screen{background:linear-gradient(135deg,#3687ff33,#0000 40%),linear-gradient(315deg,#57c2892e,#0000 36%),#111c2a}.video-progress{background:#ffd84d;height:6px;transition:width .22s;position:absolute;top:0;left:0}.scene-visual{color:#fff;background:#1d72f3;border-radius:28px;place-items:center;width:138px;height:138px;font-size:4rem;font-weight:900;display:grid;position:absolute;top:26px;right:32px;box-shadow:0 18px 40px #1d72f338}.scene-copy{max-width:680px;position:absolute;bottom:34px;left:34px;right:34px}.scene-copy span{color:#138267;text-transform:uppercase;font-size:.8rem;font-weight:900}.scene-copy h3{margin:8px 0;font-size:clamp(2rem,5vw,4rem)}.scene-copy p{color:#536276;margin:0;font-size:1.2rem;line-height:1.5}.dark .scene-copy p{color:#c8d6e8}.video-controls{flex-wrap:wrap;gap:10px;display:flex}.caption-box{background:#ffffffd1;border:1px solid #5362761f;border-radius:16px;padding:14px}.dark .caption-box{background:#151f2edb}.caption-box p{color:#536276;margin:6px 0 0;line-height:1.55}.dark .caption-box p{color:#c8d6e8}.dropzone,.file-control{text-align:center;border:2px dashed #1d72f359;border-radius:16px;place-items:center;padding:18px}.dropzone input,.file-control input{max-width:260px}.stack{gap:8px;display:grid}.admin-actions{flex-wrap:wrap;gap:10px;margin-top:14px;display:flex}.admin-wide{margin-top:14px}.panel-head{justify-content:space-between;align-items:start;gap:14px;display:flex}.panel-head p{color:#617083;margin:4px 0 0;line-height:1.5}.user-table{gap:8px;display:grid;overflow-x:auto}.user-row{background:#ffffffb8;border-radius:12px;grid-template-columns:1.2fr .8fr 1fr .9fr 1fr .7fr;align-items:center;gap:10px;min-width:780px;padding:12px;display:grid}.dark .user-row{background:#ffffff12}.user-head{color:#536276;background:0 0;font-weight:800}.status{color:#6d5600;background:#fff7d0;border-radius:999px;justify-content:center;width:fit-content;padding:6px 10px;font-weight:800;display:inline-flex}.status.ok{color:#137a5f;background:#dff7eb}.metric-grid{margin-bottom:14px}.metric{flex-direction:column;justify-content:center;align-items:flex-start;min-height:110px}.metric strong{font-size:1.8rem}.empty,.loading{color:#536276;background:#1d72f314;border-radius:16px;padding:18px}.empty.small{padding:10px}.error{color:#b42318;font-weight:800}@media (width<=900px){.workspace{grid-template-columns:1fr;padding:0 14px 18px}.sidebar{grid-template-columns:repeat(4,1fr);position:static}.nav-item{justify-content:center}.nav-item span{display:none}.hero,.chat-layout,.two-columns,.video-layout{grid-template-columns:1fr;height:auto}.action-grid,.subject-grid,.metric-grid,.grid-form{grid-template-columns:1fr}.welcome{align-items:start;display:grid}.message{max-width:100%}.panel-head{display:grid}}@media (width<=560px){.topbar{padding:0 14px}.hero h1{font-size:4rem}.sidebar{grid-template-columns:repeat(3,1fr)}.composer{grid-template-columns:auto 1fr}.composer .send{grid-column:1/-1}.toolbar{display:grid}.video-screen{min-height:360px}.scene-visual{width:96px;height:96px;font-size:3rem;top:18px;right:18px}.scene-copy{bottom:22px;left:20px;right:20px}}
