:root{--color-primary:#1d4ed8;--color-primary-light:#2563eb;--color-secondary:#38bdf8;--color-accent:#60a5fa;--color-danger:#ef4444;--color-warning:#f59e0b;--color-success:#10b981;--color-bg:#eff6ff;--color-card:#fff;--color-text:#172554;--color-border:#bfdbfe;--shadow-sm:0 1px 3px #1e40af14;--shadow-md:0 8px 20px #1e40af1f;--shadow-lg:0 16px 35px #1e40af2e;--radius-sm:6px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px}#root,body,html{min-height:100%}body{background:var(--color-bg);color:var(--color-text);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}body.dashboard-no-scroll{overflow:hidden}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.page-header{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;margin-bottom:1.5rem}.page-header h2{color:var(--color-text);font-size:1.5rem;font-weight:600;margin:0}.card{background:var(--color-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden}.badge{border-radius:var(--radius-sm);display:inline-block;font-size:.75rem;font-weight:500;padding:.25rem .6rem}.badge-success{background:#d1fae5;color:#065f46}.badge-warning{background:#fef3c7;color:#92400e}.badge-danger{background:#fee2e2;color:#991b1b}.badge-info{background:#dbeafe;color:#1e40af}.dashboard-layout{background:#f1f5f9;background:var(--color-bg,#f1f5f9);display:flex;height:100vh;height:100dvh;max-height:100vh;max-height:100dvh;overflow:hidden}.sidebar{background:linear-gradient(180deg,#1e3a8a,#1d4ed8 55%,#2563eb);color:#fff;display:flex;flex-direction:column;flex-shrink:0;transition:width .25s ease;width:260px}.sidebar.closed{width:72px}.sidebar-header{align-items:center;border-bottom:1px solid #ffffff1a;display:flex;justify-content:space-between;padding:1.25rem}.logo{color:#fff;font-size:1.25rem;font-weight:700;margin:0;overflow:hidden;white-space:nowrap}.sidebar.closed .logo{display:none}.sidebar-toggle{align-items:center;background:#ffffff1a;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:.75rem;height:28px;justify-content:center;width:28px}.sidebar-toggle:hover{background:#fff3}.sidebar-nav{flex:1 1;overflow-y:auto;padding:1rem .75rem}.nav-item{align-items:center;background:none;border:none;border-radius:8px;color:#ffffffd9;cursor:pointer;display:flex;font-size:.95rem;gap:.75rem;margin-bottom:.25rem;padding:.75rem 1rem;text-align:left;text-decoration:none;transition:all .2s;width:100%}.nav-item:hover{background:#ffffff1a;color:#fff}.nav-item.active{background:#bfdbfe59;color:#fff}.nav-icon{flex-shrink:0;font-size:1.25rem}.nav-label{white-space:nowrap}.sidebar.closed .nav-label{display:none}.sidebar-footer{border-top:1px solid #ffffff1a;padding:1rem .75rem}.logout-btn{color:#ffffffb3}.logout-btn:hover{background:#f8717126;color:#f87171}.main-content{display:flex;flex:1 1;flex-direction:column;min-height:0;min-width:0}.top-header{align-items:center;background:linear-gradient(135deg,#fff,#eff6ff);box-shadow:0 1px 3px #0000000f;display:flex;justify-content:space-between;padding:1rem 1.5rem}.page-title{color:#0f172a;color:var(--color-text,#0f172a);font-size:1.25rem;font-weight:600;margin:0}.header-actions{align-items:center;display:flex;gap:.75rem}.user-name{color:#64748b;color:var(--color-text-muted,#64748b);font-size:.9rem}.user-avatar{align-items:center;background:linear-gradient(135deg,var(--color-secondary),var(--color-primary));border-radius:50%;color:#fff;display:flex;font-size:.9rem;font-weight:600;height:36px;justify-content:center;width:36px}.content-area{-webkit-overflow-scrolling:touch;background:linear-gradient(180deg,#eff6ff,#f8fbff);flex:1 1;min-height:0;overflow-x:hidden;overflow-y:auto;overscroll-behavior-y:contain;padding:1.5rem}.landing-page{background:linear-gradient(135deg,#0f172a,#1e293b 40%,#0f172a);color:#fff;min-height:100vh}.landing-nav{align-items:center;display:flex;justify-content:space-between;padding:1.5rem 2rem}.landing-logo{font-size:1.5rem;font-weight:700}.landing-nav-links a{border-radius:8px;color:#ffffffe6;font-weight:500;padding:.5rem 1rem;text-decoration:none;transition:background .2s}.landing-nav-links a:hover{background:#ffffff1a}.landing-hero{margin:0 auto;max-width:720px;padding:6rem 2rem;text-align:center}.hero-badge{background:#10b98140;border:1px solid #10b98180;display:inline-block;font-size:.85rem;letter-spacing:.05em;margin-bottom:1rem;padding:.35rem .9rem;text-transform:uppercase}.landing-hero h1{font-size:3rem;font-weight:700;line-height:1.2;margin:0 0 1.5rem}.hero-courses{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;margin-top:2rem}.hero-course-tag{background:#ffffff14;border-radius:6px;color:#ffffffe6;font-size:.8rem;padding:.4rem .8rem}.landing-hero p{color:#ffffffd9;font-size:1.25rem;line-height:1.6;margin:0 0 2rem}.cta-primary{background:#06b6d4;border-radius:10px;color:#fff;display:inline-block;font-size:1.1rem;font-weight:600;padding:1rem 2rem;text-decoration:none;transition:transform .2s,box-shadow .2s}.cta-primary:hover{box-shadow:0 10px 25px #0003;transform:translateY(-2px)}.cta-secondary{border:2px solid #ffffff80;border-radius:10px;color:#fff;font-weight:600;margin-left:1rem;padding:1rem 2rem;text-decoration:none;transition:all .2s}.cta-secondary:hover{background:#ffffff1a}.nav-btn-primary{background:#fff3;border-radius:8px;padding:.5rem 1rem}.landing-features{margin:0 auto;max-width:1000px;padding:4rem 2rem}.landing-features h2{font-size:1.75rem;margin:0 0 2rem;text-align:center}.features-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.feature-card{background:#ffffff0d;border-radius:12px;padding:1.5rem}.feature-icon{display:block;font-size:2rem;margin-bottom:.5rem}.feature-card h3{font-size:1.1rem;margin:0 0 .5rem}.feature-card p{color:#fffc;font-size:.9rem;margin:0}.landing-footer{color:#fff9;font-size:.9rem;padding:2rem;text-align:center}.auth-page{align-items:center;background:linear-gradient(135deg,#1e3a5f,#0d2137 50%,#0a1628);display:flex;justify-content:center;min-height:100vh;padding:2rem}.auth-card{background:#fff;border-radius:16px;box-shadow:0 25px 50px -12px #00000040;max-width:420px;padding:2.5rem;width:100%}.auth-header{margin-bottom:1.5rem;text-align:center}.auth-header h1{color:#1e3a5f;font-size:1.5rem;margin:0 0 .5rem}.auth-header p{color:#6b7280;font-size:.95rem;margin:0}.auth-form .form-group{margin-bottom:1.25rem}.auth-form label{color:#374151;display:block;font-size:.875rem;font-weight:500;margin-bottom:.5rem}.auth-form input{border:1px solid #d1d5db;border-radius:8px;box-sizing:border-box;font-size:1rem;padding:.75rem 1rem;width:100%}.auth-form input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f626;outline:none}.auth-form input.input-readonly{background:#f3f4f6;color:#6b7280;cursor:default}.form-error{color:#dc2626;display:block;font-size:.8rem;margin-top:.25rem}.auth-error{background:#fef2f2;border-radius:6px;margin-bottom:1rem;padding:.5rem}.role-toggle{display:flex;gap:.5rem}.role-btn{background:#fff;border:1px solid #d1d5db;border-radius:8px;cursor:pointer;flex:1 1;font-size:.95rem;padding:.75rem;transition:all .2s}.role-btn.active{background:#1e3a5f;border-color:#1e3a5f;color:#fff}.submit-btn{background:linear-gradient(135deg,#1e3a5f,#2d5a87);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;margin-top:.5rem;padding:.875rem;width:100%}.submit-btn:hover{opacity:.95}.submit-btn:disabled{cursor:not-allowed;opacity:.7}.submit-btn-secondary{background:#e5e7eb;color:#374151;margin-top:.5rem}.submit-btn-secondary:hover{opacity:.9}.auth-footer{color:#6b7280;font-size:.9rem;margin-top:1.5rem;text-align:center}.auth-footer a{color:#1e3a5f;font-weight:500}.auth-success{text-align:center}.auth-success-green{background:#ecfdf5;border-radius:6px;color:#065f46;font-size:.9rem;margin-bottom:1rem;padding:.5rem}.auth-loading-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0711209e;display:flex;inset:0;justify-content:center;padding:1rem;position:fixed;z-index:1200}.auth-loading-card{background:linear-gradient(180deg,#fff,#f8fafc);border:1px solid #dbe6f2;border-radius:16px;box-shadow:0 24px 48px #0f172a47;max-width:360px;padding:1.2rem 1rem;text-align:center;width:100%}.auth-loading-card h3{color:#0f172a;font-size:1.02rem;margin:.4rem 0 .25rem}.auth-loading-card p{color:#64748b;font-size:.88rem;margin:0}.auth-loading-spinner{animation:auth-spin .9s linear infinite;border-color:#2563eb #06b6d4 #dbeafe #dbeafe;border-radius:50%;border-style:solid;border-width:5px;height:54px;margin:0 auto .25rem;width:54px}@keyframes auth-spin{to{transform:rotate(1turn)}}.auth-login .auth-card{border:1px solid #dbe6f2;box-shadow:0 30px 52px #02061747;max-width:460px}.auth-login-switch{grid-gap:.4rem;background:#e2e8f0;border-radius:12px;display:grid;gap:.4rem;grid-template-columns:1fr 1fr;margin-bottom:1rem;padding:.35rem}.auth-login-switch-btn{border-radius:10px;color:#334155;font-size:.88rem;font-weight:700;padding:.55rem .6rem;text-align:center;text-decoration:none;transition:all .22s ease}.auth-login-switch-btn:hover{background:#f8fafc}.auth-login-switch-btn.active{background:#fff;box-shadow:0 2px 8px #0f172a1f;color:#0f172a}.auth-role-header{border:1px solid #0000;border-radius:14px;margin-bottom:1.2rem;padding:.9rem .8rem}.auth-role-icon{background:#ffffffb3;border-radius:12px;display:grid;font-size:1.6rem;height:52px;margin:0 auto .55rem;place-items:center;width:52px}.auth-role-header h1{font-size:1.15rem;margin:0}.auth-role-header h2{font-size:1.25rem;line-height:1.2;margin:.18rem 0 .3rem}.auth-role-header p{font-size:.88rem;margin:0}.auth-role-student{background:linear-gradient(180deg,#ecfeff,#eff6ff);border-color:#bae6fd}.auth-role-student h1,.auth-role-student h2{color:#0c4a6e}.auth-role-student p{color:#155e75}.auth-role-teacher{background:linear-gradient(180deg,#f5f3ff,#eef2ff);border-color:#c7d2fe}.auth-role-teacher h1,.auth-role-teacher h2{color:#312e81}.auth-role-teacher p{color:#4338ca}.auth-role-neutral{background:linear-gradient(180deg,#f8fafc,#f1f5f9);border-color:#e2e8f0}.teacher-overview{margin:0 auto;max-width:1200px}.teacher-overview .overview-hero{background:radial-gradient(80% 120% at 0 0,#38bdf852,#0000 55%),radial-gradient(90% 120% at 100% 100%,#2563eb57,#0000 55%),linear-gradient(125deg,#1e3a8a,#1d4ed8 50%,#2563eb);border-radius:20px;box-shadow:0 20px 40px #0f172a47;color:#f8fafc;display:flex;gap:1.5rem;justify-content:space-between;margin-bottom:1.5rem;overflow:hidden;padding:1.75rem;position:relative}.teacher-overview .overview-hero:after{background:#38bdf829;border-radius:999px;content:"";height:220px;position:absolute;right:-80px;top:-80px;width:220px}.hero-copy{flex:1 1;position:relative;z-index:1}.hero-badge{align-items:center;background:#0f172a73;border:1px solid #94a3b859;border-radius:999px;color:#bfdbfe;display:inline-flex;font-size:.75rem;font-weight:600;letter-spacing:.03em;margin-bottom:.8rem;padding:.3rem .7rem}.hero-copy h2{font-size:1.8rem;font-weight:700;margin:0 0 .45rem}.hero-copy p{color:#e2e8f0f2;margin:0;max-width:680px}.hero-metrics{display:flex;flex-wrap:wrap;gap:.8rem;margin-top:1rem}.hero-metric{background:#0f172a80;border:1px solid #94a3b847;border-radius:12px;min-width:170px;padding:.7rem .8rem}.hero-metric-label{color:#cbd5e1;display:block;font-size:.75rem;margin-bottom:.2rem}.hero-metric strong{font-size:1.05rem}.hero-actions{display:flex;flex-direction:column;gap:.7rem;justify-content:center;position:relative;z-index:1}.hero-btn{border-radius:10px;font-size:.9rem;font-weight:600;padding:.7rem 1rem;text-align:center;text-decoration:none}.hero-btn-primary{background:linear-gradient(90deg,#38bdf8,#1d4ed8);color:#fff}.hero-btn-secondary{background:#0f172a80;border:1px solid #94a3b861;color:#e2e8f0}.overview-status{background:#e0f2fe;border-radius:10px;color:#0c4a6e;font-size:.9rem;margin:.85rem 0 1.25rem;padding:.75rem .9rem}.overview-status-error{background:#fee2e2;color:#7f1d1d}.stats-grid{grid-gap:1.25rem;display:grid;gap:1.25rem;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));margin-bottom:2rem}.stat-card{align-items:center;background:linear-gradient(180deg,#fff,#f8fafc);border:1px solid #e2e8f0;border-radius:16px;box-shadow:0 8px 24px #0f172a0f;color:inherit;display:flex;gap:1rem;padding:1.25rem;text-decoration:none;transition:box-shadow .2s ease,transform .2s ease}.stat-card:hover{box-shadow:0 18px 32px #0f172a1f;transform:translateY(-2px)}.stat-icon{background:linear-gradient(135deg,#dbeafe,#ecfeff);border-radius:12px;display:grid;font-size:1.35rem;height:44px;place-items:center;width:44px}.stat-content{display:flex;flex-direction:column}.stat-value{color:#0f172a;font-size:1.35rem;font-weight:700}.stat-label{color:#475569;font-size:.875rem}.stat-trend{color:#0ea5e9;font-size:.75rem;font-weight:600;margin-top:.25rem}.overview-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:1.4fr 1fr}@media (max-width:900px){.teacher-overview .overview-hero{flex-direction:column;padding:1.25rem}.hero-actions{flex-direction:row}.overview-grid{grid-template-columns:1fr}}.overview-section{background:linear-gradient(180deg,#fff,#f8fbff);border:1px solid #bfdbfe;border-radius:16px;box-shadow:0 10px 26px #1e40af14;padding:1.35rem}.overview-section .section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem}.overview-section h3{color:#0f172a;font-size:1.05rem;font-weight:700;margin:0}.link-more{color:#0ea5e9;font-size:.82rem;font-weight:600;text-decoration:none}.link-more:hover{text-decoration:underline}.class-list{display:flex;flex-direction:column;gap:.75rem}.class-item{align-items:center;background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;display:flex;justify-content:space-between;padding:.8rem}.class-info{display:flex;flex-direction:column}.class-title-row{align-items:center;display:flex;flex-wrap:wrap;gap:.5rem}.class-title-row strong{font-size:.95rem}.class-live-pill{background:#dcfce7;border:1px solid #86efac;border-radius:6px;color:#166534;font-size:.65rem;font-weight:700;letter-spacing:.04em;padding:.2rem .45rem;text-transform:uppercase}.class-meta{color:#64748b;font-size:.8rem;margin-top:.25rem}.btn-start{background:linear-gradient(90deg,#38bdf8,#1d4ed8);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:.875rem;font-weight:500;padding:.5rem .9rem;text-decoration:none}.btn-start:hover{filter:brightness(1.05)}.btn-start-live{background:linear-gradient(90deg,#22c55e,#15803d)}.btn-start-disabled{background:#cbd5e1;cursor:not-allowed}.empty-state{font-size:.9rem;margin:0}.quick-actions{display:flex;flex-wrap:wrap;gap:.75rem}.action-btn{background:#eff6ff;border:1px solid #bfdbfe;border-radius:9px;color:#0f172a;font-size:.9rem;font-weight:600;padding:.6rem 1rem;text-decoration:none;transition:background .2s ease,transform .2s ease}.action-btn:hover{background:#dbeafe;transform:translateY(-1px)}.teacher-courses .page-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1.2rem}.teacher-courses h2{color:#0f172a;font-size:1.5rem;font-weight:700;margin:0}.btn-primary{background:linear-gradient(90deg,#06b6d4,#2563eb);border:none}.btn-primary:hover{filter:brightness(1.06)}.filters{display:flex;gap:1rem;margin-bottom:1.5rem}.search-input{flex:1 1;max-width:360px}.filter-select,.search-input{background:#fff;border:1px solid #cbd5e1;border-radius:10px;font-size:.95rem;padding:.6rem 1rem}.btn-export{background:#f3f4f6;border:1px solid #d1d5db;border-radius:8px;cursor:pointer;padding:.6rem 1rem}.course-link{align-items:center;color:inherit;display:flex;gap:.75rem;text-decoration:none}.course-thumb{font-size:1.5rem}.filters-bar{flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem}.course-link:hover{text-decoration:underline}.btn-danger{color:#dc2626}.btn-danger:hover{background:#fee2e2}.courses-table-wrap{background:linear-gradient(180deg,#fff,#f8fafc);border:1px solid #e2e8f0;border-radius:16px;box-shadow:0 16px 30px #0f172a14;overflow:hidden}.courses-table{border-collapse:collapse;width:100%}.courses-table td,.courses-table th{padding:1rem 1.25rem;text-align:left}.courses-table th{background:#f1f5f9;color:#475569;font-size:.8rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.courses-table td{border-top:1px solid #edf2f7}.status-badge{border-radius:6px;font-size:.8rem;font-weight:500;padding:.25rem .6rem}.status-badge.published{background:#d1fae5;color:#065f46}.status-badge.draft{background:#fef3c7;color:#92400e}.btn-sm{background:#eef2f7;border:1px solid #dbe3ec;border-radius:8px;color:#0f172a;cursor:pointer;font-size:.85rem;font-weight:600;margin-right:.5rem;padding:.35rem .75rem;text-decoration:none}.btn-sm:hover{background:#e2e8f0}.modal-overlay{align-items:center;background:#00000080;display:flex;inset:0;justify-content:center;padding:1rem;position:fixed;z-index:1000}.modal-content{background:#fff;border-radius:12px;box-shadow:0 25px 50px -12px #00000040;display:flex;flex-direction:column;max-height:90vh;overflow:hidden}.modal-small{max-width:400px;width:100%}.modal-medium{max-width:560px;width:100%}.modal-large{max-width:720px;width:100%}.modal-header{align-items:center;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:1.25rem 1.5rem}.modal-header h3{font-size:1.25rem;font-weight:600;margin:0}.modal-close{background:none;border:none;color:#6b7280;cursor:pointer;font-size:1.5rem;line-height:1}.modal-close:hover{color:#1f2937}.modal-body{overflow-y:auto;padding:1.5rem}.course-detail{box-sizing:border-box;margin:0 auto;max-width:74rem;padding:0 0 2rem;width:100%}.course-detail-page-bg{background:radial-gradient(circle at 0 0,#3b82f61f 0,#3b82f600 35%),radial-gradient(circle at 100% 0,#14b8a61f 0,#14b8a600 30%);min-height:100%}.detail-card{background:linear-gradient(180deg,#fff,#f8fbff);border:1px solid #e2e8f0;border-radius:18px;box-shadow:0 14px 34px #0f172a14;margin-bottom:1.1rem;padding:1rem 1.15rem}.detail-card--flush{overflow:hidden;padding:0}.detail-card__title{color:#64748b;font-size:.7rem;font-weight:600;letter-spacing:.08em;margin:0 0 1rem;text-transform:uppercase}.course-detail .back-link{align-items:center;background:#e2e8f0;border-radius:999px;color:#0f172a;display:inline-flex;font-size:.84rem;font-weight:600;gap:.25rem;margin-bottom:1rem;padding:.35rem .75rem;text-decoration:none;transition:all .2s ease}.course-detail .back-link:hover{background:#cbd5e1}.course-hero{background:radial-gradient(circle at 10% 0,#38bdf82e,#0000 32%),linear-gradient(160deg,#0f172a,#1e293b 55%,#0b1120);border:none;box-shadow:0 24px 44px #0f172a47;color:#f8fafc;display:flex;flex-direction:column;gap:1.2rem;padding:1.2rem}.course-hero__top{align-items:flex-start;display:flex;gap:1rem}.course-hero__thumb{align-items:center;background:#0f172a73;border:1px solid #94a3b859;border-radius:14px;display:flex;flex-shrink:0;font-size:2.3rem;height:56px;justify-content:center;line-height:1;width:56px}.course-hero__main{flex:1 1;min-width:0}.course-hero__title{color:#f8fafc;font-size:1.6rem;font-weight:700;line-height:1.25;margin:0 0 .5rem}.course-hero__chips{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:.6rem}.course-chip{align-items:center;background:#0f172a6b;border:1px solid #94a3b859;border-radius:999px;color:#cbd5e1;display:inline-flex;font-size:.78rem;padding:.33rem .6rem}.course-chip strong{color:#f8fafc;font-weight:600;margin-right:.35rem}.course-chip code{background:#0f172a80;border-radius:4px;color:#bfdbfe;font-size:.75rem;padding:.1rem .35rem}.course-hero__link{font-size:.9rem;font-weight:500}.course-hero__link a{color:#67e8f9;font-weight:600}.course-hero__desc{color:#dbeafe;font-size:.95rem;line-height:1.5;margin:.5rem 0 0}.course-hero__actions{display:flex;flex-wrap:wrap;gap:.6rem;padding-top:.1rem}.live-link-row{align-items:center;display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.65rem}.live-link-input{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;color:#334155;flex:1 1;font-size:.85rem;min-width:220px;padding:.45rem .6rem}.live-link-status{color:#64748b;font-size:.75rem}.course-hero__batch-pick{display:flex;flex-direction:column;gap:.35rem;margin-top:.75rem}.course-hero__batch-label{color:#cbd5e1;font-size:.7rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.live-batch-select{background:#0f172a80;border:1px solid #94a3b859;border-radius:8px;color:#f8fafc;font-size:.875rem;max-width:100%;padding:.45rem .6rem}.course-hero__live-hint{color:#cbd5e1;font-size:.8rem;margin:.75rem 0 0}.course-hero__live-error{font-size:.85rem;margin:.5rem 0 0}.live-copy-toast{color:#86efac;font-size:.78rem;margin:.55rem 0 0}.batches-section{margin-bottom:1.15rem}.batches-section__head{margin:0 0 1rem;padding:1rem 1.1rem 0}.batches-section__title{color:#0f172a;font-size:1.125rem;font-weight:700;margin:0}.batches-section__sub{color:#64748b;font-size:.875rem;margin:.35rem 0 0}.batch-grid{grid-gap:1.25rem;gap:1.25rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));padding:0 1.1rem 1.1rem}.batch-card{background:linear-gradient(180deg,#fff,#f8fafc);border:1px solid #e2e8f0;border-radius:14px;box-shadow:0 12px 26px #0f172a14;display:flex;flex-direction:column;overflow:hidden}.batch-card--unified{min-height:0}.batch-card__head{align-items:flex-start;background:#fff;border-bottom:1px solid #f1f5f9;display:flex;gap:.75rem;justify-content:space-between;padding:.95rem 1rem .85rem}.batch-card__livekit{white-space:nowrap}.batch-card__title-row{align-items:center;display:flex;flex-wrap:wrap;gap:.5rem .75rem}.batch-card__name{color:#0f172a;font-size:1.05rem;font-weight:600;margin:0}.batch-card__badge{background:#dcfce7;border-radius:6px;color:#166534;display:inline-block;font-size:.7rem;font-weight:600;letter-spacing:.03em;padding:.2rem .55rem;text-transform:uppercase}.batch-card__badge--muted{background:#f1f5f9;color:#64748b}.batch-card__actions{flex-shrink:0}.batch-card__meta-panel{padding:0 1rem 1rem}.batch-card__meta{grid-gap:.6rem .85rem;background:#f8fafc;border:1px solid #f1f5f9;border-radius:10px;display:grid;gap:.6rem .85rem;grid-template-columns:1fr;padding:.75rem .85rem}@media (min-width:420px){.batch-card__meta{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (min-width:640px){.batch-card__meta{grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}}.batch-card__field{display:flex;flex-direction:column;gap:.2rem}.batch-card__label{color:#94a3b8;font-size:.65rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.batch-card__value{color:#334155;font-size:.875rem;word-break:break-word}.batch-card__value--mono{color:#475569;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:.75rem;line-height:1.35}.students-section{margin-bottom:1.25rem}.students-section__head{margin:0 0 1rem;padding:1rem 1.1rem 0}.students-section__title{color:#0f172a;font-size:1.125rem;font-weight:700;margin:0}.students-section__sub{color:#64748b;font-size:.875rem;margin:.35rem 0 0}.student-groups{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));padding:0 1.1rem 1.1rem}.student-group-card{background:linear-gradient(180deg,#fff,#f8fafc);border:1px solid #e0e7ff;border-radius:14px;box-shadow:0 12px 24px #4f46e51f;overflow:hidden}.student-group-card__head{align-items:center;background:linear-gradient(180deg,#fafaff,#fff);border-bottom:1px solid #eef2ff;display:flex;flex-wrap:wrap;gap:.75rem;justify-content:space-between;padding:.9rem 1rem}.student-group-card__title{color:#312e81;font-size:1rem;font-weight:600;margin:0}.student-group-card__count{background:#eef2ff;border-radius:6px;color:#6366f1;font-size:.75rem;font-weight:600;padding:.25rem .55rem}.student-group-card__body{padding:.85rem 1rem 1rem}.batch-students-empty{background:linear-gradient(180deg,#fafbfc,#f8fafc);border:1px dashed #cbd5e1;border-radius:10px;color:#94a3b8;font-size:.8125rem;line-height:1.45;margin:0;padding:.85rem .75rem;text-align:center}.batch-students-empty__lead{color:#64748b;font-weight:500;margin:0 0 .4rem}.batch-students-empty__hint{color:#94a3b8;font-size:.75rem;line-height:1.4;margin:0}.student-cards{display:flex;flex-direction:column;gap:.65rem;list-style:none;margin:0;padding:0}.student-card{align-items:flex-start;background:#fff;border:1px solid #eef2f7;border-radius:10px;box-shadow:0 1px 2px #0f172a0a;display:flex;gap:.65rem;padding:.65rem .8rem}.student-card__avatar{align-items:center;background:linear-gradient(145deg,#e0f2fe,#dbeafe);border-radius:8px;color:#0369a1;display:flex;flex-shrink:0;font-size:.9rem;font-weight:700;height:36px;justify-content:center;width:36px}.student-card__body{flex:1 1;min-width:0}.student-card__name{color:#0f172a;font-size:.95rem;font-weight:600;line-height:1.3;margin:0 0 .35rem}.student-card__line{color:#64748b;font-size:.8125rem;margin:0 0 .2rem;word-break:break-word}.student-card__id{align-items:center;border-top:1px solid #f1f5f9;color:#64748b;display:flex;flex-wrap:wrap;font-size:.75rem;gap:.35rem;margin:.45rem 0 0;padding-top:.45rem}.student-card__id-label{color:#94a3b8;font-size:.65rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase}.student-card__id code{background:#f1f5f9;border-radius:4px;color:#475569;font-size:.72rem;padding:.15rem .4rem}.section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem}.section-header h2{font-size:1.25rem;margin:0}.modules-list{display:flex;flex-direction:column;gap:.75rem}.module-card{background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000000f;gap:1rem;padding:1rem}.module-card,.module-order{align-items:center;display:flex}.module-order{background:#1e3a5f;border-radius:50%;color:#fff;font-weight:600;height:36px;justify-content:center;width:36px}.module-info h3{font-size:1rem;margin:0 0 .25rem}.module-info span{color:#6b7280;font-size:.85rem}.module-actions{margin-left:auto}.course-detail .btn-primary{align-items:center;background:linear-gradient(90deg,#06b6d4,#2563eb);border:none;border-radius:10px;color:#fff;display:inline-flex;font-weight:600;justify-content:center;padding:.6rem 1rem;text-decoration:none}.course-detail .btn-primary:hover{filter:brightness(1.06)}.course-detail .btn-secondary{background:#0f172a14;border:1px solid #cbd5e1;border-radius:10px;color:#0f172a;font-weight:600;padding:.6rem 1rem}.course-detail .btn-secondary:hover{background:#0f172a24}@media (max-width:900px){.course-detail{max-width:100%}.course-hero{padding:1rem}.course-hero__top{flex-direction:column}.batch-grid,.batches-section__head,.student-groups,.students-section__head{padding-left:.8rem;padding-right:.8rem}}.teacher-students .page-header{margin-bottom:1rem}.teacher-students .page-header h2{color:#0f172a;font-size:1.5rem;font-weight:700;margin:0}.teacher-students .filters-bar{margin-bottom:1rem}.teacher-students .search-input{background:#fff;border:1px solid #cbd5e1;border-radius:10px;padding:.65rem .8rem;width:min(420px,100%)}.students-table-wrap{background:linear-gradient(180deg,#fff,#f8fafc);border:1px solid #e2e8f0;border-radius:14px;box-shadow:0 10px 24px #0f172a14;overflow:hidden}.students-table{border-collapse:collapse;width:100%}.students-table td,.students-table th{border-top:1px solid #eef2f7;padding:.9rem 1rem;text-align:left;vertical-align:top}.students-table th{background:#f1f5f9;border-top:none;color:#475569;font-size:.76rem;letter-spacing:.05em;text-transform:uppercase}.student-cell{align-items:center;display:flex;gap:.7rem}.student-avatar{background:linear-gradient(135deg,#06b6d4,#3b82f6);border-radius:8px;color:#fff;display:grid;font-size:.82rem;font-weight:700;height:32px;place-items:center;width:32px}.student-live-classes{--ls-surface:#fff;--ls-surface-soft:#f8fafc;--ls-text:#0f172a;--ls-muted:#64748b;--ls-border:#e2e8f0;--ls-ring:#bfdbfe;margin:0 auto;max-width:1180px;padding-bottom:1.2rem}.live-hero{align-items:center;background:var(--ls-surface);border:1px solid var(--ls-border);border-radius:14px;box-shadow:0 10px 24px #0f172a0f;display:flex;gap:.8rem;justify-content:space-between;margin-bottom:1rem;padding:1.1rem 1.2rem}.live-hero-left{min-width:0}.live-hero-right{align-items:center;display:flex;gap:1rem}.live-badge{background:#eff6ff;border:1px solid #dbeafe;border-radius:999px;color:#1e40af;display:inline-block;font-size:.68rem;font-weight:700;letter-spacing:.08em;margin-bottom:.4rem;padding:.18rem .58rem;text-transform:uppercase}.live-hero h2{color:var(--ls-text);font-size:1.25rem;font-weight:700;margin:0 0 .2rem}.live-hero p{color:var(--ls-muted);font-size:.86rem;margin:0}.live-count{min-width:120px;text-align:right}.live-count strong{color:var(--ls-text);display:block;font-size:1.45rem;line-height:1}.live-count span{color:#64748b;display:block;font-size:.66rem;letter-spacing:.08em;margin-top:.16rem;text-transform:uppercase}.btn-live-primary{background:linear-gradient(135deg,#22c55e,#16a34a);border:1px solid #bbf7d066;border-radius:999px;color:#fff;font-size:.88rem;font-weight:700;padding:.6rem 1rem;text-decoration:none;transition:transform .14s ease,box-shadow .14s ease;white-space:nowrap}.btn-live-primary:hover{box-shadow:0 10px 18px #22c55e4d;transform:translateY(-1px)}.live-kpi-row{grid-gap:.65rem;display:grid;gap:.65rem;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));margin-bottom:.9rem}.live-kpi-card{background:var(--ls-surface);border:1px solid var(--ls-border);border-radius:12px;box-shadow:0 4px 12px #0f172a0a;padding:.64rem .78rem}.live-kpi-card span{color:var(--ls-muted);display:block;font-size:.74rem;letter-spacing:.06em;text-transform:uppercase}.live-kpi-card strong{color:var(--ls-text);font-size:1.05rem}.live-search-wrap{margin-bottom:.95rem}.live-board-head{align-items:flex-start;display:flex;gap:1rem;justify-content:space-between;margin-bottom:.45rem}.live-board-head h3{color:var(--ls-text);font-size:1rem;font-weight:700;margin:0}.live-board-head p{color:var(--ls-muted);font-size:.8rem;margin:.2rem 0 0}.live-search-label{color:#334155;display:block;font-size:.78rem;font-weight:700;letter-spacing:.04em;margin-bottom:.35rem;text-transform:uppercase}.live-search-input{background:#fff;border:1px solid var(--ls-border);border-radius:10px;box-shadow:none;font-size:.9rem;padding:.58rem .68rem;width:100%}.live-search-input:focus{border-color:#93c5fd;outline:2px solid var(--ls-ring);outline-offset:1px}.live-class-list{grid-gap:.7rem;display:grid;gap:.7rem}.live-class-card{align-items:center;animation:fadeSlideUp .26s ease both;background:var(--ls-surface);border:1px solid var(--ls-border);border-radius:12px;box-shadow:0 4px 12px #0f172a0d;display:flex;gap:.9rem;justify-content:space-between;padding:.85rem .9rem}.live-class-card:nth-child(2){animation-delay:40ms}.live-class-card:nth-child(3){animation-delay:80ms}.live-class-card:nth-child(4){animation-delay:.12s}.live-class-card.is-active{background:#f8fffb;border-color:#bbf7d0;box-shadow:0 8px 20px #16a34a1a}.live-card-main{flex:1 1;min-width:0}.live-card-actions{justify-content:flex-end}.class-top,.live-card-actions{align-items:center;display:flex}.class-top{flex-wrap:wrap;gap:.6rem;margin-bottom:.2rem}.class-top h3{color:var(--ls-text);font-size:.98rem;margin:0}.course-line{color:var(--ls-text);font-size:.9rem;font-weight:600;margin:0 0 .22rem}.batch-line{color:#475569;font-size:.82rem;margin:0 0 .38rem}.class-meta{display:flex;flex-wrap:wrap;gap:.35rem}.class-meta span{border:1px solid #e2e8f0;color:#1e40af;font-size:.7rem;font-weight:500;padding:.16rem .48rem}.class-meta span,.status-pill{background:#f8fafc;border-radius:999px}.status-pill{align-items:center;border:1px solid #cbd5e1;color:#475569;display:inline-flex;font-size:.66rem;font-weight:700;gap:.32rem;padding:.16rem .5rem;text-transform:capitalize}.status-pill.upcoming{background:#eff6ff;border-color:#93c5fd;color:#1d4ed8}.status-pill.active{background:#ecfdf5;border-color:#86efac;color:#047857}.status-pill.completed{background:#f1f5f9;border-color:#cbd5e1;color:#64748b}.status-icon{border-radius:999px;display:inline-block;height:8px;width:8px}.status-icon.active{background:#16a34a;box-shadow:0 0 0 4px #22c55e2e}.status-icon.upcoming{background:#2563eb}.status-icon.completed{background:#64748b}.livekit-tag{background:#ecfeff;border:1px solid #a5f3fc;border-radius:999px;color:#0f766e;display:inline-block;font-size:.72rem;margin-top:.5rem;padding:.15rem .48rem}.btn-join{background:#1d4ed8;border:1px solid #1d4ed8;border-radius:9px;display:inline-block;font-size:.8rem;font-weight:700;padding:.5rem .82rem;transition:background .14s ease;white-space:nowrap}.btn-join:hover{background:#1e40af}.live-state{background:#f8fafc;border:1px dashed #cbd5e1;border-radius:10px;margin-bottom:.7rem;padding:.75rem .9rem;text-align:center}.live-state p{color:#64748b;font-size:.82rem;margin:0}.live-state.error{background:#fef2f2;border-color:#fecaca;border-style:solid}.live-state.error p{color:#991b1b}.live-state.muted{border-color:#e2e8f0;border-style:solid}.live-class-card-skeleton{pointer-events:none}.live-skeleton-chip,.live-skeleton-cta,.live-skeleton-line{animation:skeletonPulse 1.3s ease-in-out infinite;background:linear-gradient(90deg,#e6eef9 25%,#f5f9ff 37%,#e6eef9 63%);background-size:300% 100%;border-radius:8px}.live-skeleton-line{height:12px;margin-bottom:10px}.live-skeleton-line.w40{width:40%}.live-skeleton-line.w55{width:55%}.live-skeleton-line.w70{width:70%}.live-skeleton-chip-row{display:flex;gap:8px;margin-top:8px}.live-skeleton-chip{border-radius:999px;height:22px;width:86px}.live-skeleton-cta{border-radius:10px;height:38px;width:118px}@media (max-width:920px){.live-hero{align-items:flex-start;flex-direction:column}.live-hero-right{justify-content:space-between;width:100%}.live-count{min-width:0;text-align:left}.live-board-head{flex-direction:column;gap:.4rem}}@media (max-width:820px){.live-class-card{align-items:flex-start;flex-direction:column}.live-card-actions{width:100%}.btn-join,.btn-live-primary{text-align:center;width:100%}}.teacher-live-classes .teacher-hero-actions{align-items:center;display:flex;flex-wrap:wrap;gap:.55rem;justify-content:flex-end}@media (max-width:820px){.teacher-live-classes .teacher-hero-actions{justify-content:flex-start;width:100%}}.teacher-live-classes .btn-start-session{background:#0f766e;border:1px solid #0f766e;border-radius:9px;color:#fff;cursor:pointer;font:inherit;font-size:.8rem;font-weight:700;padding:.5rem .82rem;text-decoration:none;transition:background .14s ease;white-space:nowrap}.teacher-live-classes .btn-start-session:hover:not(:disabled){background:#115e59}.teacher-live-classes .btn-start-session:disabled{cursor:not-allowed;opacity:.5}.teacher-live-classes .teacher-join-link{text-align:center}.teacher-live-classes .live-class-tabs{display:flex;flex-wrap:wrap;gap:.55rem;margin-bottom:.8rem}.teacher-live-classes .tab{background:#f8fafc;border:1px solid #cfe0f5;border-radius:999px;color:#334155;cursor:pointer;font-size:.76rem;font-weight:600;padding:.4rem .85rem;transition:background .12s ease,color .12s ease}.teacher-live-classes .tab:hover{background:#f1f5f9}.teacher-live-classes .tab.active{background:#1d4ed8;border-color:#0000;color:#fff}.teacher-live-classes button.teacher-hero-cta{border:none;cursor:pointer;font:inherit}.teacher-live-classes .teacher-card-actions{align-items:center;display:flex;flex-wrap:wrap;gap:.45rem;justify-content:flex-end}.teacher-live-classes .btn-end-session{background:#dc2626;border-color:#dc2626}.teacher-live-classes .btn-end-session:hover:not(:disabled){background:#b91c1c}.teacher-live-classes .teacher-link-btn{align-items:center;display:inline-flex;justify-content:center;text-decoration:none}.teacher-live-classes .live-class-card{border-radius:12px}@media (max-width:820px){.teacher-live-classes .teacher-card-actions{justify-content:flex-start;width:100%}}.assignment-system-card{background:linear-gradient(180deg,#fff,#f8fafc);border:1px solid #e2e8f0;border-radius:14px;box-shadow:0 10px 24px #0f172a14}.assignment-page-header{align-items:center;display:flex;gap:.75rem;justify-content:space-between;margin-bottom:1rem}.assignment-page-header h2{color:#0f172a;font-size:1.45rem;margin:0}.assignment-toolbar{display:flex;flex-wrap:wrap;gap:.65rem;margin-bottom:1rem}.assignment-input,.assignment-select,.assignment-textarea{background:#fff;border:1px solid #cbd5e1;border-radius:10px;font-size:.92rem;padding:.62rem .75rem}.assignment-input{flex:1 1;min-width:220px}.assignment-list{grid-gap:.9rem;display:grid;gap:.9rem;grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.assignment-item{color:inherit;padding:.95rem;text-decoration:none}.assignment-item h3{color:#0f172a;font-size:1.04rem;margin:0 0 .4rem}.assignment-meta{color:#64748b;font-size:.84rem;margin:0}.assignment-status{border-radius:999px;display:inline-flex;font-size:.74rem;font-weight:700;letter-spacing:.03em;margin-top:.7rem;padding:.2rem .62rem;text-transform:uppercase}.assignment-status.pending{background:#fef9c3;color:#854d0e}.assignment-status.draft{background:#e2e8f0;color:#334155}.assignment-status.submitted{background:#d1fae5;color:#166534}.assignment-status.graded{background:#dbeafe;color:#1d4ed8}.assignment-empty,.assignment-error,.assignment-loading{border-radius:12px;padding:1rem}.assignment-loading{background:#f8fafc;border:1px solid #e2e8f0}.assignment-empty{background:#f8fafc;border:1px dashed #cbd5e1;color:#64748b}.assignment-error{background:#fef2f2;border:1px solid #fecaca;color:#991b1b}.assignment-detail-layout{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:2fr 1fr}.assignment-primary,.assignment-secondary{padding:1rem}.assignment-question{color:#334155;line-height:1.55;margin:0 0 .85rem}.editor-wrap{background:#fff;border:1px solid #cbd5e1;border-radius:12px;overflow:hidden}.editor-toolbar{background:#f8fafc;border-bottom:1px solid #e2e8f0;display:flex;flex-wrap:wrap;gap:.4rem;padding:.55rem}.editor-btn{background:#fff;border:1px solid #dbe3ec;border-radius:8px;cursor:pointer;font-size:.82rem;padding:.34rem .52rem}.editor-btn:hover{background:#eef2f7}.editor-content{color:#0f172a;min-height:240px;outline:none;padding:.85rem}.assignment-actions-row{align-items:center;display:flex;gap:.75rem;justify-content:space-between;margin-top:.75rem}.save-indicator{color:#64748b;font-size:.82rem}.btn-primary-soft{background:linear-gradient(90deg,#06b6d4,#2563eb);border:none;border-radius:10px;color:#fff;cursor:pointer;font-weight:600;padding:.56rem .88rem}.btn-primary-soft:disabled{cursor:not-allowed;opacity:.65}.btn-secondary-soft{background:#f8fafc;border:1px solid #cbd5e1;border-radius:10px;color:#0f172a;cursor:pointer;font-weight:600;padding:.56rem .88rem}.history-list{display:flex;flex-direction:column;gap:.45rem;max-height:360px;overflow:auto}.history-item{background:#fff;border:1px solid #e2e8f0;border-radius:10px;padding:.55rem .7rem}.history-time{color:#64748b;font-size:.78rem}.review-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1.1fr 1fr}.submission-answer{padding:1rem}.answer-render{background:#fff;border:1px solid #e2e8f0;border-radius:12px;color:#0f172a;line-height:1.6;min-height:220px;padding:.85rem}.feedback-form{padding:1rem}.feedback-form h3{margin:0 0 .7rem}.feedback-actions{display:flex;gap:.55rem;margin-top:.75rem}.kpi-row{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));margin-bottom:1rem}.kpi-card{padding:.85rem}.kpi-card .label{color:#64748b;display:block;font-size:.76rem;letter-spacing:.03em;text-transform:uppercase}.kpi-card .value{color:#0f172a;display:block;font-size:1.2rem;font-weight:700;margin-top:.25rem}@media (max-width:980px){.assignment-detail-layout,.review-grid{grid-template-columns:1fr}}.teacher-assignments .page-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1.5rem}.teacher-assignments h2{color:#1f2937;font-size:1.5rem;font-weight:600;margin:0}.assignments-list{display:flex;flex-direction:column;gap:1rem}.assignment-card{align-items:center;background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000000f;display:flex;justify-content:space-between;padding:1.25rem}.assignment-info h3{font-size:1.1rem;margin:0 0 .25rem}.assignment-info p{color:#6b7280;font-size:.9rem;margin:0 0 .5rem}.submission-progress{align-items:center;display:flex;gap:.75rem}.submission-progress .progress-bar{background:#e5e7eb;border-radius:3px;height:6px;overflow:hidden;width:120px}.submission-progress .progress-fill{background:#3b82f6;border-radius:3px;height:100%}.submission-progress span{color:#6b7280;font-size:.85rem}.assignment-title{color:inherit;text-decoration:none}.assignment-title:hover{text-decoration:underline}.form-group input,.form-group select,.form-group textarea{border:1px solid #d1d5db;border-radius:6px;box-sizing:border-box;padding:.5rem;width:100%}.form-row{display:flex;gap:1rem}.form-row .form-group{flex:1 1}.batch-preview{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;color:#334155;font-size:.85rem;margin-bottom:1rem;padding:.65rem .75rem}.modal-actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:1rem}.assignment-detail .back-link{color:#1e3a5f;display:inline-block;margin-bottom:1rem;text-decoration:none}.assignment-header h1{font-size:1.5rem;margin:0 0 .5rem}.assignment-header p{color:#6b7280;margin:0 0 1.5rem}.submissions-section h2{font-size:1.25rem;margin:0 0 1rem}.submissions-table-wrap{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000000f;overflow:hidden}.submissions-table{border-collapse:collapse;width:100%}.submissions-table td,.submissions-table th{padding:1rem;text-align:left}.submissions-table th{background:#f9fafb;color:#6b7280;font-size:.8rem;font-weight:600;text-transform:uppercase}.submissions-table td{border-top:1px solid #f3f4f6}.student-overview .overview-welcome{margin-bottom:1.5rem}.student-overview .overview-welcome h2{font-size:1.5rem;font-weight:600;margin:0 0 .25rem}.student-overview .overview-welcome p{color:var(--color-text-muted);font-size:.95rem;margin:0}.student-overview .empty-state{color:var(--color-text-muted);font-size:.9rem;margin:0}.student-overview .stats-grid{grid-gap:1.25rem;display:grid;gap:1.25rem;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));margin-bottom:2rem}.student-overview .stat-card{align-items:center;background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000000f;color:inherit;display:flex;gap:1rem;padding:1.25rem;text-decoration:none;transition:box-shadow .2s,transform .2s}.student-overview .stat-card:hover{box-shadow:0 4px 12px #00000014;transform:translateY(-2px)}.student-overview .stat-icon{font-size:2rem}.student-overview .stat-value{color:var(--color-primary);font-size:1.5rem;font-weight:700}.student-overview .stat-label{color:#6b7280;font-size:.875rem}.student-overview .overview-section{background:linear-gradient(180deg,#fff,#f8fbff);border:1px solid var(--color-border);border-radius:12px;box-shadow:var(--shadow-sm);padding:1.5rem}.student-overview .overview-section h3{color:#374151;font-size:1.1rem;font-weight:600;margin:0 0 1rem}.student-overview .class-item{align-items:center;background:#eff6ff;border:1px solid var(--color-border);border-radius:8px;display:flex;justify-content:space-between;margin-bottom:.5rem;padding:.75rem}.btn-join{background:linear-gradient(135deg,var(--color-primary),var(--color-primary-light));border-radius:6px;color:#fff;font-size:.875rem;font-weight:500;padding:.5rem 1rem;text-decoration:none}.btn-join:hover{filter:brightness(1.05)}.student-courses{margin:0 auto;max-width:1240px;padding-bottom:1.5rem}.courses-hero{align-items:center;background:radial-gradient(75% 130% at 0 0,#38bdf83d,#0000 50%),radial-gradient(90% 130% at 100% 100%,#6366f147,#0000 55%),linear-gradient(130deg,#020617,#111827 45%,#0b1120);border-radius:16px;box-shadow:0 24px 45px #02061759;color:#f8fafc;display:flex;gap:1.5rem;justify-content:space-between;margin-bottom:1.35rem;padding:1.4rem 1.5rem}.courses-badge{background:#1e40af3d;border:1px solid #bfdbfe52;border-radius:999px;color:#dbeafe;display:inline-flex;font-size:.75rem;font-weight:700;letter-spacing:.07em;margin-bottom:.4rem;padding:.2rem .65rem;text-transform:uppercase}.courses-hero h2{font-size:1.9rem;font-weight:800;letter-spacing:-.015em;margin:0 0 .35rem}.courses-hero p{color:#cbd5e1;font-size:.93rem;margin:0;max-width:620px}.courses-hero-right{align-items:flex-end;display:flex;flex-direction:column;gap:.75rem}.courses-active-count{text-align:right}.courses-active-count strong{color:#86efac;display:block;font-size:1.9rem;line-height:1}.courses-active-count span{color:#bbf7d0;font-size:.75rem;letter-spacing:.11em;text-transform:uppercase}.courses-hero-right .btn-primary{background:linear-gradient(135deg,#1d4ed8,#2563eb);border:1px solid #93c5fd4d;border-radius:10px;text-decoration:none}.courses-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(290px,1fr))}.course-card{background:linear-gradient(180deg,#fff,#f8fafc);border:1px solid #e2e8f0;border-radius:14px;box-shadow:0 10px 24px #0f172a14;color:inherit;display:block;padding:1rem;text-decoration:none;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease}.course-card:hover{border-color:#93c5fde6;box-shadow:0 18px 32px #0f172a1f;transform:translateY(-3px)}.course-card-head{align-items:center;display:flex;justify-content:space-between;margin-bottom:.6rem}.course-thumb{font-size:2.4rem}.course-status{background:#10b98124;border:1px solid #10b98159;border-radius:999px;color:#047857;font-size:.72rem;font-weight:700;letter-spacing:.05em;padding:.2rem .55rem;text-transform:uppercase}.course-card h3{color:#0f172a;font-size:1.08rem;font-weight:700;margin:0 0 .2rem}.course-card p{color:#64748b;font-size:.88rem;margin:0 0 .6rem}.course-meta{display:flex;flex-wrap:wrap;gap:.35rem;margin-bottom:.7rem}.course-meta span{background:#eef2ff;border:1px solid #c7d2fe;border-radius:999px;color:#4338ca;font-size:.75rem;font-weight:600;padding:.18rem .5rem}.subscription-strip{display:flex;flex-wrap:wrap;gap:.35rem;margin-bottom:.68rem}.subscription-strip span{background:#f1f5f9;border:1px solid #cbd5e1;border-radius:999px;color:#475569;font-size:.74rem;font-weight:600;padding:.16rem .5rem}.subscription-strip .payment-chip.success{background:#ecfdf5;border-color:#86efac;color:#047857}.subscription-strip .live-chip{background:#eff6ff;border-color:#93c5fd;color:#1d4ed8}.batch-info-strip{grid-gap:.28rem .6rem;background:linear-gradient(180deg,#f8fbff,#f1f5f9);border:1px solid #dbeafe;border-radius:10px;color:#334155;display:grid;font-size:.78rem;gap:.28rem .6rem;grid-template-columns:1fr 1fr;margin-bottom:.7rem;padding:.58rem .68rem}.batch-info-strip strong{color:#64748b;font-weight:700}.curriculum-inline-note{background:#ecfeff;border:1px solid #a5f3fc;border-radius:8px;color:#0f766e;font-size:.78rem;margin-bottom:.65rem;padding:.35rem .5rem}.course-card .progress-bar{background:#e5e7eb;border-radius:999px;height:7px;margin-bottom:.45rem;overflow:hidden}.course-card .progress-fill{background:linear-gradient(90deg,#2563eb,#10b981);border-radius:999px;height:100%}.course-card-footer{align-items:center;display:flex;gap:.65rem;justify-content:space-between}.progress-text{color:#64748b;font-size:.82rem}.open-course{color:#1d4ed8;font-size:.82rem;font-weight:700}.empty-courses{background:#f8fafc;border:1px dashed #cbd5e1;border-radius:12px;margin-top:1rem;padding:2.2rem 1.4rem;text-align:center}.empty-courses.loading{background:#eff6ff;border-color:#dbeafe;border-style:solid}.empty-courses p{color:#64748b;margin:0 0 .9rem}.empty-courses .btn-primary{text-decoration:none}@media (max-width:900px){.courses-hero{flex-direction:column}.courses-hero,.courses-hero-right{align-items:flex-start}.courses-active-count{text-align:left}}@media (max-width:640px){.courses-hero{padding:1.1rem 1rem}.courses-hero h2{font-size:1.5rem}.batch-info-strip,.courses-grid{grid-template-columns:1fr}}.student-course-detail .back-link{color:#1e3a5f;display:inline-block;margin-bottom:1rem;text-decoration:none}.course-header h1{font-size:1.5rem;margin:0 0 .25rem}.course-header p{color:#6b7280;margin:0 0 1rem}.progress-bar-large{background:#e5e7eb;border-radius:4px;height:8px;margin-bottom:.5rem}.progress-bar-large .progress-fill{background:linear-gradient(90deg,#3b82f6,#10b981);border-radius:4px;height:100%}.modules-section h2{font-size:1.25rem;margin:1.5rem 0 1rem}.module-item{align-items:center;background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000000f;display:flex;gap:1rem;margin-bottom:.5rem;padding:1rem}.module-status{font-size:1.25rem}.module-item h3{font-size:1rem;margin:0 0 .25rem}.module-item p{color:#6b7280;font-size:.85rem;margin:0}.module-item .btn-sm{margin-left:auto}.course-purchase{margin:0 auto;max-width:1240px;padding:.25rem 0 2rem}.catalog-section{margin-bottom:2rem}.catalog-section-title{color:#0f172a;color:var(--color-text,#0f172a);font-size:1.45rem;font-weight:800;letter-spacing:-.01em;margin:0 0 .35rem}.catalog-section-sub{font-size:.95rem;margin:0 0 1.1rem;max-width:700px}.catalog-section-sub,.catalog-status-msg{color:#64748b;color:var(--color-text-muted,#64748b)}.catalog-status-msg{font-size:.9rem;margin:0 0 1rem}.catalog-status-warn{background:linear-gradient(135deg,#fffbeb,#fef3c7);border:1px solid #fcd34d;border-radius:10px;color:#9a3412;padding:.7rem .9rem}.catalog-status-msg .link-retry{background:none;border:none;color:#1d4ed8;cursor:pointer;font-size:inherit;padding:0;text-decoration:underline}.purchase-header{align-items:center;background:radial-gradient(80% 120% at 0 0,#38bdf840 0,#0000 50%),radial-gradient(70% 120% at 100% 100%,#6366f159 0,#0000 55%),linear-gradient(130deg,#020617,#111827 45%,#0b1120);border-radius:18px;box-shadow:0 24px 45px #02061773;color:#e5e7eb;display:flex;gap:1.5rem;justify-content:space-between;margin-bottom:1.6rem;padding:1.5rem 1.65rem}.purchase-header h1{color:#f8fafc;font-size:2rem;font-weight:800;letter-spacing:-.015em;margin:0 0 .45rem}.purchase-header p{color:#d1d5db;font-size:.96rem;line-height:1.55;margin:0;max-width:620px}.purchase-badge{align-items:center;background:#1e40af38;border:1px solid #bfdbfe59;border-radius:999px;color:#dbeafe;display:inline-flex;font-size:.75rem;gap:.3rem;letter-spacing:.08em;margin-bottom:.55rem;padding:.22rem .7rem;text-transform:uppercase}.purchase-header-meta{color:#e5e7eb;display:flex;flex-wrap:wrap;font-size:.8rem;gap:.55rem;margin-top:.85rem}.purchase-header-meta span{background:#0f172a94;border:1px solid #94a3b859;border-radius:999px;padding:.25rem .62rem}.purchase-header-highlight{align-items:center;background:linear-gradient(135deg,#10b9812e,#22c55e1a);border:1px solid #34d3998c;border-radius:999px;display:flex;flex-direction:column;justify-content:center;min-width:160px;padding:.85rem 1.2rem}.purchase-count{color:#bbf7d0;font-size:1.9rem;font-weight:800;line-height:1}.purchase-count-label{color:#a7f3d0;font-size:.72rem;letter-spacing:.13em;margin-top:.18rem;text-transform:uppercase}.alert-banner{align-items:flex-start;background:linear-gradient(135deg,#fb923c,#facc15);border-radius:12px;box-shadow:0 12px 24px #fb923c47;color:#111827;display:flex;gap:.72rem;margin:0 0 1.35rem;padding:.85rem 1rem}.alert-banner .alert-icon{flex-shrink:0;font-size:1.3rem}.alert-banner .alert-content strong{display:block;font-weight:800;margin-bottom:.18rem}.alert-banner .alert-content p{font-size:.9rem;margin:0}.alert-banner .highlight{font-weight:800;text-decoration:underline}.payment-success-toast{align-items:center;background:linear-gradient(135deg,#ecfdf5,#d1fae5);border:1px solid #6ee7b7;border-radius:12px;color:#065f46;display:flex;font-size:.93rem;gap:1rem;justify-content:space-between;margin-bottom:1.2rem;padding:.85rem 1rem}.payment-success-toast .toast-dismiss{background:#0000;border:none;color:#065f46;cursor:pointer;font-size:1.2rem;line-height:1;padding:0 .25rem}.filters-bar{background:#fff;border:1px solid #e2e8f0d9;border-radius:14px;box-shadow:0 10px 22px #0f172a0f;display:flex;gap:.85rem;margin-bottom:1.2rem;padding:.8rem}.filters-bar .search-input{border:1px solid #cbd5e1;border-radius:10px;flex:1 1;font-size:.95rem;min-width:220px;padding:.7rem .95rem;transition:border-color .2s,box-shadow .2s}.filters-bar .search-input:focus{border-color:#60a5fa;box-shadow:0 0 0 3px #60a5fa33;outline:none}.filters-bar .filter-select{background:#fff;border:1px solid #cbd5e1;border-radius:10px;font-size:.95rem;padding:.7rem .95rem}.courses-catalog{grid-gap:1.2rem;display:grid;gap:1.2rem;grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.purchase-card{background:linear-gradient(180deg,#fff,#f8fafc);border:1px solid #e2e8f0f2;border-radius:14px;box-shadow:0 10px 24px #0f172a14;overflow:hidden;padding:1.15rem;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease}.purchase-card:hover{border-color:#93c5fde6;box-shadow:0 18px 34px #0f172a21;transform:translateY(-3px)}.purchase-card-header{align-items:center;display:flex;gap:.5rem;margin-bottom:.85rem}.purchase-card .course-tag{font-size:1.2rem}.purchase-card .course-thumb{font-size:1.9rem}.purchase-card .level-badge{background:#06b6d41f;border-radius:999px;color:#0e7490;font-size:.74rem;font-weight:700;margin-left:auto;padding:.24rem .58rem}.purchase-card h3{color:#0f172a;font-size:1.15rem;font-weight:700;margin:0 0 .45rem}.purchase-card .course-desc{-webkit-line-clamp:2;-webkit-box-orient:vertical;color:#64748b;display:-webkit-box;font-size:.9rem;line-height:1.5;margin:0 0 .85rem;overflow:hidden}.purchase-batch-strip{background:linear-gradient(180deg,#f8fafc,#f1f5f9);border:1px solid #dbeafe;border-radius:10px;font-size:.8rem;margin:0 0 .82rem;padding:.65rem .72rem}.purchase-batch-row{grid-gap:.35rem .5rem;align-items:baseline;display:grid;gap:.35rem .5rem;grid-template-columns:66px 1fr;padding:.2rem 0}.purchase-batch-label{color:#64748b;font-weight:700}.purchase-batch-value{color:#0f172a;line-height:1.35}.purchase-batch-value.batch-mode-pill{background:#0ea5e924;border-radius:999px;color:#0369a1;display:inline-block;font-size:.72rem;font-weight:700;padding:.12rem .46rem;text-transform:capitalize;width:fit-content}.purchase-no-batch{background:#f8fafc;border:1px dashed #cbd5e1;border-radius:8px;color:#64748b;font-size:.8rem;margin:0 0 .72rem;padding:.45rem .6rem}.purchase-card .course-meta{color:#64748b;font-size:.84rem;margin-bottom:.85rem}.purchase-card-footer{align-items:center;border-top:1px solid #e2e8f0;display:flex;gap:.95rem;justify-content:space-between;padding-top:.9rem}.purchase-card .price-block{align-items:baseline;display:flex;gap:.45rem}.purchase-card .price{color:#0f766e;font-size:1.22rem;font-weight:800}.purchase-card .original-price{color:#94a3b8;font-size:.88rem;text-decoration:line-through}.purchase-card .btn-primary{background:linear-gradient(135deg,#0f172a,#1d4ed8);border:1px solid #1d4ed826;border-radius:10px;color:#fff;font-size:.86rem;font-weight:700;padding:.5rem 1rem;text-decoration:none}.empty-state{background:#f8fafc;border:1px dashed #cbd5e1;border-radius:12px;color:#64748b;padding:2.2rem 1rem;text-align:center}.subscriptions-section{border:1px solid #e2e8f0f2;border-radius:14px;box-shadow:0 10px 24px #0f172a0f;margin-bottom:1.35rem;padding:1.2rem 1.35rem}.subscriptions-header{align-items:center;display:flex;gap:1rem;justify-content:space-between;margin-bottom:.45rem}.subscriptions-section h3{font-size:1.1rem;font-weight:700;margin:0}.btn-refresh-subs{background:#fff;border:1px solid #cbd5e1;border-radius:8px;cursor:pointer;font-size:.82rem;padding:.38rem .75rem}.btn-refresh-subs:disabled{cursor:not-allowed;opacity:.6}.subs-api-note{color:#64748b;font-size:.85rem;margin:0 0 .65rem}.subs-error{color:#b91c1c;font-size:.9rem;margin:0 0 .75rem}.subs-empty{color:#64748b;font-size:.94rem;margin:0}.subs-count{font-size:.95rem;margin:0 0 .75rem}.subs-list{display:flex;flex-direction:column;gap:.7rem;list-style:none;margin:0;padding:0}.subs-item{align-items:flex-start;background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;display:flex;gap:1rem;justify-content:space-between;padding:.75rem .9rem}.subs-item strong{display:block;margin-bottom:.2rem}.subs-meta{color:#64748b;display:block;font-size:.8rem}.subs-price{color:#0f766e;font-weight:800;white-space:nowrap}.features-banner{background:radial-gradient(80% 120% at 100% 0,#38bdf83d,#0000 50%),linear-gradient(135deg,#0f172a,#1e293b);border-radius:14px;box-shadow:0 14px 30px #0f172a40;color:#fff;margin-bottom:1.2rem;padding:1.35rem 1.5rem}.features-banner h3{font-size:1.08rem;font-weight:700;margin:0 0 1rem}.features-banner .features-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}.features-banner .feature-item{align-items:flex-start;display:flex;gap:.82rem}.features-banner .feature-icon{flex-shrink:0;font-size:1.6rem}.features-banner .feature-item strong{display:block;font-size:.95rem;margin-bottom:.2rem}.features-banner .feature-item p{font-size:.84rem;margin:0;opacity:.92}@media (max-width:960px){.purchase-header{align-items:flex-start;flex-direction:column}.purchase-header-highlight{align-self:flex-start}.filters-bar{flex-direction:column}.filters-bar .search-input{max-width:none}}@media (max-width:640px){.course-purchase{padding-bottom:1.2rem}.purchase-header{border-radius:14px;padding:1.2rem 1rem}.purchase-header h1{font-size:1.55rem}.purchase-header-meta span{font-size:.74rem}.catalog-section-title{font-size:1.2rem}.courses-catalog{grid-template-columns:1fr}.features-banner,.purchase-card,.subscriptions-section{padding:1rem}}.batch-details-section h2{font-size:1.25rem;font-weight:600;margin:0 0 1.25rem}.batch-selection-hint{color:#64748b;color:var(--color-text-muted,#64748b);font-size:.9rem;margin:-.5rem 0 1rem}.batch-details-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.batch-detail-card{background:linear-gradient(180deg,#f8fafc,#fff);border:1px solid #e2e8f0;border:1px solid var(--color-border,#e2e8f0);border-radius:10px;border-radius:var(--radius-md,10px);padding:1.1rem 1.25rem}.batch-detail-card.selectable{cursor:pointer;transition:border-color .2s ease,box-shadow .2s ease,transform .2s ease}.batch-detail-card.selectable:hover{border-color:#93c5fd;box-shadow:0 8px 24px #3b82f626;transform:translateY(-1px)}.batch-detail-card.selected{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb33}.batch-detail-header{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.85rem}.batch-type-pill{background:#0ea5e926;color:#0369a1;font-size:.8rem}.batch-mode-pill,.batch-type-pill{border-radius:999px;display:inline-block;font-weight:600;padding:.25rem .65rem}.batch-mode-pill{background:#6366f11f;color:#4338ca;font-size:.75rem}.batch-select-pill{background:#2563eb1f;border-radius:999px;color:#1d4ed8;display:inline-block;font-size:.75rem;font-weight:700;margin-left:auto;padding:.25rem .65rem}.batch-detail-dl{margin:0}.batch-dl-row{grid-gap:.5rem 1rem;border-bottom:1px solid #e2e8f0cc;display:grid;font-size:.9rem;gap:.5rem 1rem;grid-template-columns:110px 1fr;padding:.35rem 0}.batch-dl-row:last-child{border-bottom:none}.batch-dl-row dt{color:#64748b;color:var(--color-text-muted,#64748b);font-weight:600;margin:0}.batch-dl-row dd{color:#0f172a;color:var(--color-text,#0f172a);margin:0}.course-purchase-detail{margin:0 auto;max-width:1100px;padding-bottom:1.5rem}.back-link{align-items:center;color:#2563eb;display:inline-flex;font-size:.9rem;font-weight:600;gap:.4rem;margin-bottom:1rem;text-decoration:none}.back-link:hover{text-decoration:underline}.detail-hero{background:radial-gradient(70% 120% at 0 0,#38bdf83d,#0000 50%),radial-gradient(80% 120% at 100% 100%,#6366f142,#0000 55%),linear-gradient(130deg,#020617,#111827 45%,#0b1120);border-radius:16px;box-shadow:0 20px 42px #02061759;color:#f8fafc;display:flex;gap:1.5rem;justify-content:space-between;margin-bottom:1.5rem;padding:1.6rem}.hero-content{flex:1 1}.hero-content .course-tag{display:block;font-size:1.4rem;margin-bottom:.4rem}.detail-hero h1{font-size:2rem;font-weight:800;letter-spacing:-.01em;margin:0 0 .75rem}.detail-hero .course-desc{color:#d1d5db;font-size:.96rem;line-height:1.6;margin:0 0 .9rem;max-width:760px}.hero-meta{align-items:center;display:flex;font-size:.9rem;gap:.8rem;margin-bottom:.9rem}.hero-meta .level-badge{background:#38bdf833;border:1px solid #7dd3fc73;border-radius:999px;color:#e0f2fe;font-size:.75rem;font-weight:700;letter-spacing:.05em;padding:.24rem .65rem;text-transform:uppercase}.hero-features{display:flex;flex-wrap:wrap;margin-bottom:1.2rem}.hero-feature-tag{background:#1e40af3d;border:1px solid #bfdbfe47;border-radius:999px;color:#dbeafe;font-size:.8rem;padding:.32rem .7rem}.hero-actions .btn-primary{background:linear-gradient(135deg,#1d4ed8,#2563eb);border:1px solid #93c5fd52;border-radius:10px;box-shadow:0 12px 22px #2563eb47;color:#fff;font-weight:700}.hero-price{align-self:flex-start;background:#0f172a73;border:1px solid #94a3b84d;border-radius:12px;flex-shrink:0;min-width:180px;padding:.6rem .8rem;text-align:right}.hero-price .price{color:#86efac;display:block;font-size:1.9rem;font-weight:800;line-height:1.1}.hero-price .original-price{color:#cbd5e1;font-size:.95rem;text-decoration:line-through}.curriculum-section,.features-section{border:1px solid #e2e8f0;border-radius:14px;box-shadow:0 10px 24px #0f172a0f;margin-bottom:1.25rem;padding:1.2rem 1.3rem}.curriculum-section h2,.features-section h2{font-size:1.15rem;font-weight:700;margin:0 0 1rem}.curriculum-list{display:flex;flex-direction:column;gap:1.1rem}.curriculum-section-item{padding:.9rem 1rem}.curriculum-section-item h4{font-size:.95rem;font-weight:700;margin:0 0 .55rem}.curriculum-section-item ul{padding-left:1.2rem}.curriculum-section-item li{font-size:.9rem;margin-bottom:.28rem}.curriculum-files-hint{color:#64748b;font-size:.9rem;margin:0 0 .9rem}.curriculum-summary{display:flex;flex-wrap:wrap;gap:.45rem;margin:0 0 .9rem}.curriculum-summary span{background:#eef2ff;border:1px solid #c7d2fe;border-radius:999px;color:#3730a3;font-size:.78rem;padding:.28rem .6rem}.curriculum-file-list{display:flex;flex-direction:column;gap:.7rem;list-style:none;margin:0;padding:0}.curriculum-file-item{align-items:center;background:linear-gradient(180deg,#fff,#f8fafc);border:1px solid #e2e8f0;border-radius:10px;display:flex;gap:.9rem;padding:.8rem .9rem}.curriculum-file-icon{flex-shrink:0;font-size:1.35rem}.curriculum-file-meta{flex:1 1;min-width:0}.curriculum-file-meta strong{display:block;font-size:.93rem;margin-bottom:.1rem}.curriculum-file-type{color:#64748b;font-size:.76rem;letter-spacing:.05em;text-transform:uppercase}.curriculum-file-missing{color:#b45309;display:block;font-size:.78rem;margin-top:.3rem}.btn-curriculum-download{background:linear-gradient(135deg,#0f172a,#1d4ed8);border:none;border-radius:9px;color:#fff;cursor:pointer;flex-shrink:0;font-size:.82rem;font-weight:700;padding:.42rem .9rem;text-decoration:none}.btn-curriculum-download:hover{opacity:.94}.btn-curriculum-download.disabled{background:#cbd5e1;box-shadow:none;color:#334155;cursor:not-allowed}.included-features{grid-gap:.9rem;display:grid;gap:.9rem;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.included-feature{background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;display:flex;gap:.85rem;padding:.88rem}.included-feature .feature-icon{flex-shrink:0;font-size:1.5rem}.included-feature strong{display:block;font-size:.92rem;margin-bottom:.18rem}.included-feature p{color:#64748b;font-size:.84rem;margin:0}.purchase-modal-content{padding:.3rem 0}.purchase-modal-content p{margin:0 0 .9rem}.purchase-benefits{margin:0 0 1.2rem;padding-left:1.2rem}.purchase-benefits li{margin-bottom:.45rem}.payment-hint{color:#64748b;font-size:.85rem;margin-bottom:.7rem!important}.payment-error{background:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#b91c1c;font-size:.88rem;margin-bottom:1rem;padding:.58rem .72rem}@media (max-width:960px){.detail-hero{flex-direction:column;padding:1.25rem}.hero-price{align-self:flex-start;text-align:left}}@media (max-width:640px){.course-purchase-detail{padding-bottom:1rem}.detail-hero h1{font-size:1.5rem}.hero-features{gap:.4rem}.hero-feature-tag{font-size:.74rem}.curriculum-section,.features-section{padding:1rem}.curriculum-file-item{align-items:flex-start;flex-wrap:wrap}}.purchased-course-detail{margin:0 auto;max-width:1120px;padding-bottom:1.5rem}.course-not-found{background:#f8fafc;border:1px dashed #cbd5e1;border-radius:12px;color:#64748b;padding:2rem;text-align:center}.purchased-course-detail .back-link{align-items:center;color:#2563eb;display:inline-flex;font-size:.9rem;font-weight:600;gap:.4rem;margin-bottom:1rem;text-decoration:none}.purchased-course-detail .back-link:hover{text-decoration:underline}.purchased-hero{background:radial-gradient(72% 120% at 0 0,#38bdf838,#0000 50%),radial-gradient(85% 120% at 100% 100%,#6366f142,#0000 55%),linear-gradient(130deg,#020617,#111827 45%,#0b1120);border-radius:16px;box-shadow:0 24px 44px #02061759;color:#f8fafc;display:flex;gap:1.5rem;justify-content:space-between;margin-bottom:1.25rem;padding:1.6rem}.hero-left{flex:1 1}.purchased-hero .course-tag{display:block;font-size:1.35rem;margin-bottom:.35rem}.purchased-hero h1{font-size:1.95rem;font-weight:800;letter-spacing:-.01em;margin:0 0 .65rem}.purchased-hero p{color:#d1d5db;font-size:.95rem;line-height:1.55;margin:0 0 .8rem}.meta-chips{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:.8rem}.meta-chips span{background:#1e40af3d;border:1px solid #bfdbfe4d;border-radius:999px;color:#dbeafe;font-size:.76rem;font-weight:700;padding:.2rem .55rem}.meta-chips .payment-chip.success{background:#10b98133;border-color:#34d39973;color:#bbf7d0}.progress-block{margin-top:.5rem;max-width:520px}.progress-bar-large{background:#94a3b859;border-radius:999px;height:9px;margin-bottom:.45rem;overflow:hidden}.progress-fill{background:linear-gradient(90deg,#06b6d4,#6366f1);border-radius:999px;height:100%;transition:width .3s}.progress-block span{color:#cbd5e1;font-size:.84rem}.hero-right{display:flex;flex-direction:column;gap:.75rem;width:320px}.enrollment-stats{grid-gap:.5rem;display:grid;gap:.5rem;grid-template-columns:1fr}.stat-item{background:#0f172a73;border:1px solid #94a3b84d;border-radius:10px;padding:.55rem .7rem}.stat-item .label{color:#94a3b8;display:block;font-size:.73rem;letter-spacing:.06em;margin-bottom:.15rem;text-transform:uppercase}.stat-item strong{color:#f8fafc;font-size:.92rem}.hero-features{grid-gap:.45rem;display:grid;gap:.45rem}.mini-feature{align-items:center;color:#e2e8f0;display:flex;font-size:.82rem;gap:.45rem}.batch-section,.curriculum-section{border:1px solid #e2e8f0;border-radius:14px;box-shadow:0 10px 22px #0f172a0f;margin-bottom:1.2rem;padding:1.2rem 1.3rem}.batch-section h2,.curriculum-section h2{font-size:1.12rem;font-weight:700;margin:0 0 .9rem}.batch-grid{grid-gap:.6rem;display:grid;gap:.6rem;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.batch-item{background:linear-gradient(180deg,#f8fbff,#f1f5f9);border:1px solid #dbeafe;border-radius:10px;padding:.65rem .72rem}.batch-item .label{color:#64748b;display:block;font-size:.76rem;letter-spacing:.05em;margin-bottom:.15rem;text-transform:uppercase}.batch-item strong{color:#0f172a;font-size:.9rem}.batch-status{color:#1d4ed8!important;text-transform:capitalize}.livekit-note{color:#0f766e;font-size:.83rem;margin:.8rem 0 0}.curriculum-download-card{background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;margin-bottom:.95rem;padding:.8rem .9rem}.curriculum-download-card p{color:#64748b;font-size:.88rem;margin:0 0 .65rem}.curriculum-actions{display:flex;flex-wrap:wrap;gap:.5rem}.curriculum-list{grid-gap:.7rem;display:grid;gap:.7rem}.curriculum-section-item{background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;padding:.85rem .95rem}.curriculum-section-item h4{color:#0f766e;font-size:.92rem;margin:0 0 .45rem}.curriculum-section-item ul{margin:0;padding-left:1.1rem}.curriculum-section-item li{color:#64748b;font-size:.86rem;margin-bottom:.25rem}.curriculum-empty{color:#64748b;font-size:.9rem;margin:0}.course-actions{display:flex;gap:.75rem}.course-actions .btn-primary,.course-actions .btn-secondary{border-radius:10px;text-decoration:none}@media (max-width:960px){.purchased-hero{flex-direction:column}.hero-right{width:100%}}@media (max-width:640px){.purchased-hero{padding:1.2rem 1rem}.purchased-hero h1{font-size:1.5rem}.batch-grid{grid-template-columns:1fr}.course-actions{flex-direction:column}}.profile-page h2{font-size:1.5rem;margin:0 0 1.5rem}.profile-form{max-width:560px}.profile-avatar-section{align-items:center;display:flex;gap:1rem;margin-bottom:2rem}.avatar-preview{align-items:center;background:linear-gradient(135deg,#3b82f6,#8b5cf6);border-radius:50%;color:#fff;display:flex;font-size:2rem;font-weight:600;height:80px;justify-content:center;width:80px}.form-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 1fr}.form-group{margin-bottom:1rem}.form-group.full-width{grid-column:1/-1}.form-group label{display:block;font-weight:500;margin-bottom:.5rem}.form-group input,.form-group textarea{border:1px solid #d1d5db;border-radius:8px;box-sizing:border-box;padding:.75rem;width:100%}.form-actions{margin-top:1.5rem}.lc-root:-moz-full-screen,.lc-root:-ms-fullscreen,.lc-root:-webkit-full-screen,.lc-root:fullscreen{box-sizing:border-box;height:100vh;height:100dvh;max-height:none;min-height:100vh;min-height:100dvh;overflow:hidden;width:100vw}.lc-root.lc-root--presenting .lc-presenting-shell{padding:0 0 calc(4.5rem + env(safe-area-inset-bottom, 0px))}.lc-root.lc-root--presenting:-webkit-full-screen .lc-presenting-shell,.lc-root.lc-root--presenting:fullscreen .lc-presenting-shell{padding-bottom:calc(4.25rem + env(safe-area-inset-bottom, 0px))}.lc-root{--lc-bg:#1a1a1a;--lc-surface:#252423;--lc-surface-2:#2d2c2c;--lc-border:#ffffff14;--lc-text:#f5f5f5;--lc-muted:#a19f9d;--lc-accent:#464eb8;--lc-accent-hover:#5b63c4;--lc-danger:#c50f1f;--lc-danger-hover:#a80d1b;--lc-dock-bg:#252423eb;--lc-blur:blur(12px);--lc-vh:100dvh;background:var(--lc-bg);background-image:radial-gradient(ellipse 120% 80% at 50% -20%,#464eb81f,#0000 50%);color:var(--lc-text);display:flex;flex-direction:column;font-family:Segoe UI,system-ui,-apple-system,sans-serif;height:100vh;height:var(--lc-vh);max-height:100vh;max-height:var(--lc-vh);min-height:100vh;min-height:var(--lc-vh);overflow:hidden;overscroll-behavior:none}.lc-topbar{background:var(--lc-surface);border-bottom:1px solid var(--lc-border);flex-shrink:0;gap:1rem;justify-content:space-between;min-height:48px;padding:0 1rem 0 .75rem;z-index:20}.lc-topbar,.lc-topbar-start{align-items:center;display:flex}.lc-topbar-start{gap:.5rem;min-width:0}.lc-meeting-info,.lc-topbar-start{position:relative}.lc-meeting-chip{align-items:center;background:#0000;border:none;border-radius:6px;color:inherit;cursor:pointer;display:flex;gap:.5rem;margin:.25rem 0;max-width:min(420px,70vw);padding:.35rem .65rem .35rem .5rem;text-align:left;transition:background .15s ease}.lc-meeting-chip:hover{background:#ffffff0f}.lc-meeting-chip-text{display:flex;flex-direction:column;gap:.1rem;min-width:0}.lc-meeting-title{font-size:.9375rem;font-weight:600;letter-spacing:-.01em}.lc-meeting-meta,.lc-meeting-title{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.lc-meeting-meta{color:var(--lc-muted);font-size:.6875rem}.lc-meeting-chevron{color:var(--lc-muted);flex-shrink:0;font-size:.65rem}.lc-popover{background:var(--lc-surface-2);border:1px solid var(--lc-border);border-radius:8px;box-shadow:0 8px 32px #00000073;left:0;padding:1rem;position:absolute;top:calc(100% + 6px);width:min(340px,calc(100vw - 2rem));z-index:50}.lc-popover-label{color:var(--lc-muted);font-size:.6875rem;font-weight:600;letter-spacing:.06em;margin:0 0 .35rem;text-transform:uppercase}.lc-popover-code{background:#00000059;border-radius:6px;color:#e2e2e2;display:block;font-size:.75rem;margin:0 0 .75rem;padding:.5rem .65rem;word-break:break-all}.lc-popover-row{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.75rem}.lc-popover-copy{background:#ffffff14;border:1px solid var(--lc-border);border-radius:4px;color:var(--lc-text);cursor:pointer;font-size:.8125rem;font-weight:500;padding:.4rem .85rem}.lc-popover-copy:hover{background:#ffffff1f}.lc-popover-hint{color:var(--lc-muted);font-size:.75rem;line-height:1.45;margin:0}.lc-popover-link{color:#a6c8ff;display:inline-block;font-size:.8125rem;font-weight:500;margin-top:.65rem;text-decoration:none}.lc-popover-link:hover{color:#c8deff;text-decoration:underline}.lc-topbar-end{align-items:center;display:flex;flex-shrink:0;gap:.5rem}.lc-pill-btn{align-items:center;background:#ffffff0f;border:1px solid var(--lc-border);border-radius:4px;color:var(--lc-text);cursor:pointer;display:inline-flex;font-size:.8125rem;font-weight:500;gap:.35rem;padding:.4rem .75rem;transition:background .15s ease,border-color .15s ease}.lc-pill-btn:hover{background:#ffffff1a}.lc-pill-btn.is-active{background:#464eb840;border-color:#464eb880}.lc-btn-link{align-items:center;background:#ffffff14;border:1px solid var(--lc-border);border-radius:4px;color:var(--lc-text);cursor:pointer;display:inline-flex;font-size:.8125rem;font-weight:500;padding:.45rem .85rem;text-decoration:none;transition:background .15s ease}.lc-btn-link:hover{background:#ffffff1f}.lc-btn-leave{align-items:center;background:var(--lc-danger);border:none;border-radius:4px;color:#fff;cursor:pointer;display:inline-flex;font-size:.8125rem;font-weight:600;gap:.35rem;padding:.45rem 1rem;transition:background .15s ease}.lc-btn-leave:hover{background:var(--lc-danger-hover)}.lc-body{overflow:hidden;position:relative}.lc-body,.lc-stage{display:flex;flex:1 1;min-height:0}.lc-stage{flex-direction:column;min-width:0;overflow:auto;overflow-x:hidden;overscroll-behavior:contain;scrollbar-gutter:stable}.lc-stage.lc-stage--presenting-focus{flex:1 1 auto;min-height:0;overflow:hidden}.lc-presenting-shell{box-sizing:border-box;padding:.25rem .75rem calc(5.5rem + env(safe-area-inset-bottom, 0px));width:100%}.lc-presenting-shell,.lc-presenting-stage-wrap{display:flex;flex:1 1;flex-direction:column;min-height:0;min-width:0}.lc-presenting-stage-wrap:-moz-full-screen,.lc-presenting-stage-wrap:-ms-fullscreen,.lc-presenting-stage-wrap:-webkit-full-screen,.lc-presenting-stage-wrap:fullscreen{background:#0a0a0a;box-sizing:border-box;height:100vh;height:100dvh;max-height:none;padding:.35rem;width:100vw;z-index:2147483640}.lc-presenting-stage{display:flex;flex:1 1;flex-direction:column;min-height:0;min-width:0}.lc-presenting-stage>.lc-tile{flex:1 1 auto;margin:0 auto;max-width:none;min-height:0;width:100%}.lc-tile.lc-tile--presenting-main{aspect-ratio:unset;display:flex;flex-direction:column;max-height:none}.lc-presenting-stage .lc-tile--screenshare{flex:1 1 auto;max-height:none;min-height:0}.lc-presenting-stage .lc-tile--presenting-main.lc-tile--screenshare{flex:1 1 auto;min-height:0}.lc-presenting-stage .lc-tile--presenting-compact{flex:1 1 auto;max-height:none;min-height:0}.lc-presenting-stage .lc-tile--presenting-compact .lc-local-video-share-preview{flex:1 1 auto;max-height:none!important;min-height:0}.lc-presenting-stage .lc-tile--presenting-main>video{flex:1 1 auto;min-height:0;object-fit:contain;object-position:center center;width:100%}.lc-presenting-filmstrip{display:flex;flex:0 0 auto;flex-direction:row;flex-wrap:nowrap;gap:10px;max-width:100%;overflow-x:auto;overflow-y:hidden;padding-top:10px}.lc-presenting-filmstrip:empty{display:none}.lc-tile.lc-tile--filmstrip{aspect-ratio:16/9;flex:0 0 auto;max-height:none;width:clamp(140px,24vw,260px)}.lc-tile.lc-tile--filmstrip video{object-fit:cover}.lc-gallery{grid-gap:10px;align-content:start;box-sizing:border-box;display:grid;flex:1 1;gap:10px;justify-content:center;padding:1rem 1rem 6rem}.lc-gallery.lc-gallery--solo{grid-template-columns:minmax(200px,1fr) minmax(200px,1fr);margin:0 auto;max-width:860px;width:100%}@media (max-width:720px){.lc-gallery.lc-gallery--solo{grid-template-columns:1fr}}.lc-gallery.lc-gallery--grid{grid-template-columns:repeat(auto-fit,minmax(min(100%,240px),1fr));margin:0 auto;max-width:960px;width:100%}.lc-gallery.lc-gallery--local-presenting.lc-gallery--solo{align-content:stretch;grid-template-columns:1fr;max-width:none;width:100%}.lc-gallery.lc-gallery--local-presenting.lc-gallery--solo .lc-tile--empty{display:none}.lc-gallery.lc-gallery--local-presenting.lc-gallery--grid{max-width:none;width:100%}.lc-gallery.lc-gallery--local-presenting.lc-gallery--grid .lc-tile--local{grid-column:1/-1}.lc-gallery.lc-gallery--local-presenting .lc-tile.lc-tile--presenting-compact{max-height:none;min-height:calc(100vh - 120px);min-height:calc(100dvh - 120px);min-height:calc(var(--lc-vh, 100dvh) - 120px)}.lc-gallery.lc-gallery--local-presenting .lc-local-video-share-preview{flex:1 1 auto;flex-shrink:1;max-height:none;min-height:min(52dvh,240px)}.lc-gallery.lc-gallery--grid:has(.lc-tile--screenshare){max-width:none;width:100%}.lc-gallery.lc-gallery--grid:has(.lc-tile--screenshare) .lc-tile--screenshare{grid-column:1/-1;max-height:none;min-height:calc(100vh - 120px);min-height:calc(100dvh - 120px);min-height:calc(var(--lc-vh, 100dvh) - 120px)}.lc-tile{aspect-ratio:16/9;background:#111;border:1px solid var(--lc-border);border-radius:8px;box-shadow:0 4px 24px #00000059;overflow:hidden;position:relative}.lc-tile video{background:#0a0a0a;height:100%;object-fit:cover;width:100%}.lc-tile.lc-tile--screenshare{aspect-ratio:auto;border-radius:0;box-shadow:none;max-height:calc(100dvh - 168px);max-height:calc(var(--lc-vh, 100dvh) - 168px);min-height:min(36dvh,300px)}.lc-tile.lc-tile--screenshare video{background:#0a0a0a;border-radius:0;object-fit:contain;object-position:center center}.lc-gallery .lc-tile.lc-tile--local.lc-tile--presenting-compact{border-radius:0;box-shadow:none}.lc-tile.lc-tile--presenting-compact{align-items:stretch;aspect-ratio:unset;background:#111;display:flex;flex-direction:column;min-height:0}.lc-local-video-share-preview{background:#0a0a0a;flex-shrink:0;max-height:min(18vh,140px);max-height:min(18dvh,140px);min-height:72px;object-fit:contain;object-position:center center;width:100%}.lc-local-share-placeholder{align-items:center;background:#050505;color:#cbd5e1;display:flex;flex:1 1 auto;flex-direction:column;gap:.35rem;justify-content:center;min-height:220px;padding:1rem;text-align:center}.lc-local-share-placeholder strong{color:#f8fafc;font-size:.95rem}.lc-local-share-placeholder span{color:#94a3b8;font-size:.78rem}.lc-presenting-strip{align-items:center;background:#0f172ad9;border-top:1px solid var(--lc-border);color:#cbd5e1;display:flex;flex-shrink:0;gap:.55rem;padding:.45rem .55rem}.lc-presenting-strip svg{color:#93c5fd;flex-shrink:0;margin-top:.1rem}.lc-presenting-strip-text{display:flex;flex:1 1;flex-direction:column;gap:.2rem;min-width:0}.lc-presenting-strip-title{color:#f1f5f9;font-size:.8125rem;font-weight:600}.lc-presenting-strip-sub{color:#94a3b8;font-size:.6875rem;line-height:1.4}.lc-tile.lc-tile--presenting-share-surface{cursor:default}.lc-presenting-toggle{align-self:center;background:#ffffff14;border:1px solid #94a3b859;border-radius:6px;color:#e2e8f0;cursor:pointer;flex-shrink:0;font-size:.7rem;font-weight:600;padding:.35rem .55rem;white-space:nowrap}.lc-presenting-toggle:hover{background:#ffffff24}.lc-tile.lc-tile--presenting-compact .lc-tile-bar{border-radius:0 0 7px 7px;bottom:auto;left:auto;margin-top:0;position:relative;right:auto}.lc-tile-bar{align-items:center;background:linear-gradient(#0000,#000000bf);bottom:0;display:flex;font-size:.8125rem;font-weight:500;gap:.5rem;justify-content:space-between;left:0;padding:.45rem .65rem;position:absolute;right:0}.lc-tile-bar span:first-child{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.lc-tile-badge{background:#464eb880;border-radius:3px;color:#cde;flex-shrink:0;font-size:.625rem;font-weight:600;letter-spacing:.04em;padding:.15rem .4rem;text-transform:uppercase}.lc-tile.lc-tile--local .lc-tile-badge{background:#0078d473}.lc-tile-warn{background:#b42828d9;border-radius:4px;font-size:.6875rem;left:.5rem;padding:.35rem .5rem;position:absolute;right:.5rem;text-align:center;top:.5rem}.lc-tile.lc-tile--empty{align-items:center;background:linear-gradient(145deg,var(--lc-surface-2),#1e1e1e);display:flex;flex-direction:column;justify-content:center;padding:1.25rem;text-align:center}.lc-tile-empty-title{color:var(--lc-text);font-size:1rem;font-weight:600;margin:0 0 .5rem}.lc-tile-empty-text{color:var(--lc-muted);font-size:.8125rem;line-height:1.5;margin:0;max-width:280px}.lc-tile-empty-status{color:#7fba00;font-size:.75rem;margin:.75rem 0 0}.lc-tile-empty-status.lc-status-warn{color:#ffb900}.lc-tile-empty-status.lc-status-err{color:#f1707b}.lc-rail{background:var(--lc-surface);border-left:1px solid var(--lc-border);display:flex;flex-direction:column;flex-shrink:0;min-height:0;width:300px;z-index:10}.lc-rail-header{border-bottom:1px solid var(--lc-border);font-size:.9375rem;font-weight:600;padding:1rem 1rem .5rem}.lc-rail-list{flex:1 1;list-style:none;margin:0;min-height:0;overflow-y:auto;padding:.5rem}.lc-rail-item{align-items:center;border-radius:6px;display:flex;font-size:.8125rem;gap:.65rem;margin-bottom:2px;padding:.6rem .65rem}.lc-rail-item:hover{background:#ffffff0d}.lc-rail-avatar{align-items:center;background:linear-gradient(135deg,#464eb8,#323996);border-radius:50%;display:flex;flex-shrink:0;font-size:.75rem;font-weight:600;height:32px;justify-content:center;width:32px}.lc-rail-meta{flex:1 1;min-width:0}.lc-rail-name{display:block;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.lc-rail-role{color:var(--lc-muted);display:block;font-size:.6875rem;text-transform:capitalize}.lc-chat-rail{background:var(--lc-surface);border-left:1px solid var(--lc-border);display:flex;flex-direction:column;flex-shrink:0;min-height:0;overflow:hidden;width:300px;z-index:10}.lc-chat-header{align-items:center;border-bottom:1px solid var(--lc-border);color:var(--lc-text);display:flex;flex-shrink:0;font-size:.9375rem;font-weight:600;gap:.5rem;justify-content:space-between;padding:1rem 1rem .5rem}.lc-chat-header span:first-child{padding-left:0}.lc-chat-close{align-items:center;background:#0000;border:none;border-radius:4px;color:var(--lc-muted);cursor:pointer;display:flex;font-size:1.2rem;height:1.75rem;justify-content:center;line-height:1;width:1.75rem}.lc-chat-close:hover{background:#ffffff1a;color:var(--lc-text)}.lc-chat-messages{-webkit-overflow-scrolling:touch;display:flex;flex:1 1;flex-direction:column;gap:.35rem;min-height:0;overflow-x:hidden;overflow-y:auto;padding:.45rem .5rem}.lc-chat-empty{color:var(--lc-muted);font-size:.75rem;line-height:1.4;margin:0;padding:.5rem .35rem;text-align:center}.lc-chat-msg{background:#0000;border-bottom:1px solid var(--lc-border);border-radius:0;padding:.35rem .45rem}.lc-chat-msg:last-child{border-bottom:none}.lc-chat-msg-line{align-items:center;display:flex;gap:.35rem;justify-content:space-between;margin-bottom:.2rem}.lc-chat-author{color:#c8e0ff;font-size:.6875rem;font-weight:600;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.lc-chat-time{color:var(--lc-muted);flex-shrink:0;font-size:.625rem}.lc-chat-msg-text{color:#ececec;font-size:.8125rem;line-height:1.35;margin:0;word-break:break-word}.lc-chat-error{color:#f1707b;font-size:.6875rem;padding:.25rem .5rem}.lc-chat-compose,.lc-chat-error{border-top:1px solid var(--lc-border);flex-shrink:0}.lc-chat-compose{align-items:center;background:#00000059;display:flex;gap:.35rem;padding:.45rem .5rem}.lc-chat-input{background:#ffffff12;border:1px solid #ffffff1a;border-radius:6px;color:var(--lc-text);flex:1 1;font-size:.8125rem;min-width:0;outline:none;padding:.4rem .5rem}.lc-chat-input:focus{background:#ffffff17;border-color:#464eb88c}.lc-chat-send{background:var(--lc-accent);border:none;border-radius:6px;color:#fff;cursor:pointer;flex-shrink:0;font-size:.75rem;font-weight:600;padding:.4rem .55rem}.lc-chat-send:hover:not(:disabled){background:var(--lc-accent-hover)}.lc-chat-send:disabled{cursor:not-allowed;opacity:.45}.lc-dock{bottom:0;display:flex;justify-content:center;left:0;padding:.75rem 1rem 1.25rem;pointer-events:none;position:fixed;right:0;z-index:30}.lc-dock-inner{backdrop-filter:var(--lc-blur);-webkit-backdrop-filter:var(--lc-blur);background:var(--lc-dock-bg);border:1px solid var(--lc-border);border-radius:999px;box-shadow:0 8px 32px #0006;flex-wrap:wrap;gap:.35rem;padding:.45rem .65rem;pointer-events:auto}.lc-dock-btn,.lc-dock-inner{align-items:center;display:flex;justify-content:center}.lc-dock-btn{background:#0000;border:none;border-radius:8px;color:var(--lc-text);cursor:pointer;flex-direction:column;font-size:.625rem;font-weight:500;gap:.2rem;min-width:3.25rem;padding:.45rem .5rem .35rem;transition:background .12s ease}.lc-dock-btn:hover{background:#ffffff14}.lc-dock-btn:active{background:#ffffff1f}.lc-dock-btn svg{opacity:.95}.lc-dock-btn.lc-dock-btn--danger{color:#ff99a4}.lc-dock-btn.lc-dock-btn--danger:hover{background:#c50f1f59}.lc-dock-btn.is-active{background:#c50f1f73;color:#fff}.lc-dock-btn.is-active:hover{background:#c50f1f8c}.lc-dock-btn:disabled{cursor:not-allowed;opacity:.45}.lc-dock-sep{background:var(--lc-border);flex-shrink:0;height:2rem;margin:0 .25rem;width:1px}.lc-wb-backdrop{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000a6;display:flex;inset:0;justify-content:center;padding:1rem;position:fixed;z-index:100}.lc-wb-modal{background:var(--lc-surface);border:1px solid var(--lc-border);border-radius:12px;box-shadow:0 24px 64px #0000008c;display:flex;flex-direction:column;max-height:min(90vh,720px);overflow:hidden;width:min(920px,100%)}.lc-wb-header{align-items:center;border-bottom:1px solid var(--lc-border);display:flex;justify-content:space-between;padding:.85rem 1rem}.lc-wb-header h3{font-size:1rem;font-weight:600;margin:0}.lc-wb-close{align-items:center;background:#0000;border:none;border-radius:4px;color:var(--lc-muted);cursor:pointer;display:flex;font-size:1.25rem;height:2rem;justify-content:center;line-height:1;width:2rem}.lc-wb-close:hover{background:#ffffff14;color:var(--lc-text)}.lc-wb-body{overflow:auto;padding:1rem}.lc-wb-canvas,.whiteboard-canvas{background:#fff;border-radius:8px;cursor:crosshair;display:block;height:auto;max-width:100%;min-height:280px;width:100%}.form-error.lc-inline-err{font-size:.8125rem;margin-top:.5rem}.lc-root .lc-rec-indicator{align-items:center;background:#0000008c;border:1px solid #ffffff24;border-radius:4px;box-shadow:inset 0 1px 0 #ffffff0f;display:inline-flex;flex-shrink:0;gap:.35rem;padding:.15rem .5rem .15rem .4rem;position:relative}.lc-root .lc-rec-indicator--host{border-color:#f8717159}.lc-root .lc-rec-indicator--guest{border-color:#94a3b859}.lc-root .lc-rec-indicator__dot{animation:lc-rec-dot-pulse 1.35s ease-out infinite;background:#e11d48;border-radius:50%;box-shadow:0 0 0 0 #e11d48a6;flex-shrink:0;height:9px;width:9px}.lc-root .lc-rec-indicator--guest .lc-rec-indicator__dot{background:#fb7185;box-shadow:0 0 0 0 #fb71858c}@keyframes lc-rec-dot-pulse{0%{box-shadow:0 0 0 0 #e11d488c}70%{box-shadow:0 0 0 7px #e11d4800}to{box-shadow:0 0 0 0 #e11d4800}}.lc-root .lc-rec-indicator__rec{color:#ffffffe0;font-size:.625rem;font-weight:700;letter-spacing:.08em;line-height:1;-webkit-user-select:none;user-select:none}.lc-root .lc-rec-indicator__time{font-feature-settings:"tnum";border-left:1px solid #ffffff2e;color:#fff;font-size:.8125rem;font-variant-numeric:tabular-nums;font-weight:600;letter-spacing:.02em;line-height:1.2;margin-left:.1rem;min-width:2.65rem;padding-left:.15rem}.lc-root .lc-rec-zoom-idle{align-items:center;background:#00000059;border:1px solid #ffffff1f;border-radius:4px;color:#f1f5f9;cursor:pointer;display:inline-flex;flex-shrink:0;font-size:.75rem;font-weight:600;gap:.35rem;padding:.2rem .55rem .2rem .4rem;transition:background .15s ease,border-color .15s ease}.lc-root .lc-rec-zoom-idle:hover:not(:disabled){background:#ffffff14;border-color:#ffffff38}.lc-root .lc-rec-zoom-idle:disabled{cursor:wait;opacity:.65}.lc-root .lc-rec-zoom-idle--hint{border-color:#f8717173}.lc-root .lc-rec-zoom-idle__dot{background:#0000;border:2px solid #ffffff59;border-radius:50%;flex-shrink:0;height:8px;width:8px}.lc-root .lc-rec-zoom-idle--hint .lc-rec-zoom-idle__dot{background:#f8717126;border-color:#f87171bf}.lc-root .lc-rec-zoom-idle__label{letter-spacing:.02em;-webkit-user-select:none;user-select:none}.lc-rec-indicator-sr{clip:rect(0,0,0,0);border:0;height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;white-space:nowrap;width:1px}.lc-rec-pill{background:#47556959;border:1px solid #94a3b873;border-radius:4px;color:#e2e8f0;flex-shrink:0;font-size:.6875rem;font-weight:700;letter-spacing:.04em;padding:.28rem .55rem;text-transform:uppercase}.lc-rec-pill--warn{background:#eab30833;border-color:#facc1573;color:#fef08a;font-weight:600}.lc-rec-pill--subtle,.lc-rec-pill--warn{font-size:.75rem;letter-spacing:0;text-transform:none}.lc-rec-pill--subtle{background:#94a3b826;border-color:#94a3b859;color:#cbd5e1;font-weight:500}.live-class-room{min-height:100vh;min-height:100dvh}.past-recordings-page{display:flex;flex-direction:column;gap:1rem;margin:0 auto;max-width:1200px}.past-rec-hero{align-items:center;background:radial-gradient(90% 120% at 0 0,#3b82f63d,#0000 55%),radial-gradient(85% 110% at 100% 100%,#0e74903d,#0000 50%),linear-gradient(140deg,#0b1324,#0f172a 55%,#111827);border-radius:16px;color:#e2e8f0;display:flex;gap:1rem;justify-content:space-between;padding:1.2rem 1.3rem}.past-rec-badge{background:#1e293b73;border:1px solid #94a3b859;border-radius:999px;display:inline-block;font-size:.72rem;font-weight:700;letter-spacing:.06em;margin-bottom:.35rem;padding:.2rem .55rem;text-transform:uppercase}.past-rec-hero h2{font-size:1.6rem;margin:0 0 .3rem}.past-rec-hero p{color:#cbd5e1;margin:0}.past-rec-refresh{background:#0f172a73;border:1px solid #94a3b866;border-radius:10px;color:#f8fafc;cursor:pointer;font-weight:700;padding:.5rem .9rem}.past-rec-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:minmax(280px,380px) minmax(0,1fr);min-height:560px}.past-rec-left,.past-rec-right{background:#fff;border:1px solid #e2e8f0;border-radius:14px;padding:.9rem}.past-rec-toolbar input{border:1px solid #cbd5e1;border-radius:10px;font-size:.9rem;padding:.55rem .7rem;width:100%}.past-rec-list-scroll{margin:.75rem 0 0;max-height:470px;overflow-y:auto;overscroll-behavior:contain;padding-right:2px}.past-rec-course-group{margin-bottom:1rem}.past-rec-course-group:last-child{margin-bottom:0}.past-rec-course-title{color:#64748b;font-size:.7rem;font-weight:800;letter-spacing:.06em;margin:0 0 .45rem .15rem;text-transform:uppercase}.past-rec-batch-group{border-left:2px solid #e2e8f0;margin:0 0 .75rem .25rem;padding-left:.35rem}.past-rec-batch-group:last-child{margin-bottom:0}.past-rec-batch-title{color:#334155;font-size:.78rem;font-weight:700;margin:0 0 .4rem .1rem}.past-rec-list{display:flex;flex-direction:column;gap:.55rem;list-style:none;margin:0;padding:0}.past-rec-list--nested{margin-top:0}.past-rec-player-course{color:#0f172a;font-weight:600}.past-rec-item{background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;cursor:pointer;padding:.62rem .68rem;text-align:left;width:100%}.past-rec-item.active{background:#eff6ff;border-color:#60a5fa}.past-rec-item-title{color:#0f172a;font-size:.9rem;font-weight:700}.past-rec-item-meta{align-items:center;color:#64748b;display:flex;font-size:.78rem;gap:.5rem;justify-content:space-between;margin-top:.28rem}.past-rec-tag{border-radius:999px;font-size:.67rem;font-weight:700;padding:.12rem .46rem}.past-rec-tag.mp4{background:#dcfce7;border:1px solid #86efac;color:#166534}.past-rec-tag.other{background:#f1f5f9;border:1px solid #cbd5e1;color:#475569}.past-rec-player-head h3{color:#0f172a;font-size:1.08rem;margin:0}.past-rec-player-head p{color:#64748b;font-size:.86rem;margin:.28rem 0 .85rem}.past-rec-player{background:#000;border-radius:12px;max-height:560px;width:100%}.past-rec-fallback{border:1px dashed #cbd5e1;border-radius:10px;color:#334155;padding:1rem}.past-rec-fallback a{color:#2563eb;font-weight:700;text-decoration:none}.past-rec-fallback a:hover{text-decoration:underline}.past-rec-state{color:#64748b;margin:.9rem 0 0}.past-rec-state.error{color:#b91c1c}@media (max-width:960px){.past-rec-grid{grid-template-columns:1fr}}*{box-sizing:border-box}:root{--color-surface:#fff;--color-surface-soft:#f8fbff;--color-bg-subtle:#f3f7ff;--color-text:#0f172a;--color-text-muted:#64748b;--color-border:#dbe6f3;--color-primary:#2563eb;--color-primary-light:#3b82f6;--color-success:#16a34a;--color-danger:#dc2626;--shadow-sm:0 6px 16px #0f172a0d;--shadow-md:0 12px 28px #0f172a1a;--radius-md:12px;--radius-lg:16px}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}a{color:inherit}.btn-primary{background:linear-gradient(135deg,#2563eb,#3b82f6);background:linear-gradient(135deg,var(--color-primary),var(--color-primary-light));border:1px solid #93c5fd80;border-radius:10px;color:#fff;cursor:pointer;font-weight:600;padding:.6rem 1.25rem}.btn-primary:hover{filter:brightness(1.05)}.btn-secondary{background:#eff6ff;border:1px solid #dbe6f3;border:1px solid var(--color-border);border-radius:10px;color:#0f172a;color:var(--color-text);cursor:pointer;font-weight:600;padding:.6rem 1rem}.btn-secondary:hover{background:#dbeafe}@keyframes fadeSlideUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes skeletonPulse{0%{background-position:100% 50%}to{background-position:0 50%}}
/*# sourceMappingURL=main.ba5518c4.css.map*/