*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:15px;line-height:1.7;color:var(--text-primary);background:var(--bg-base);overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}:root{--navy-50: #f0f4ff;--navy-100: #dbe4ff;--navy-200: #bac8ff;--navy-300: #91a7ff;--navy-400: #748ffc;--navy-500: #5c7cfa;--navy-600: #4c6ef5;--navy-700: #3b5bdb;--navy-800: #1e3a5f;--navy-900: #0f1d30;--navy-950: #0a1628;--amber-50: #fff9e6;--amber-100: #ffecb3;--amber-200: #ffe082;--amber-300: #ffd54f;--amber-400: #ffca28;--amber-500: #f59e0b;--amber-600: #e68a00;--amber-700: #cc7a00;--emerald-50: #ecfdf5;--emerald-100: #d1fae5;--emerald-200: #a7f3d0;--emerald-300: #6ee7b7;--emerald-400: #34d399;--emerald-500: #10b981;--emerald-600: #059669;--rose-50: #fff1f2;--rose-100: #ffe4e6;--rose-400: #fb7185;--rose-500: #f43f5e;--rose-600: #e11d48;--slate-50: #f8fafc;--slate-100: #f1f5f9;--slate-200: #e2e8f0;--slate-300: #cbd5e1;--slate-400: #94a3b8;--slate-500: #64748b;--slate-600: #475569;--slate-700: #334155;--slate-800: #1e293b;--slate-900: #0f172a;--bg-base: var(--slate-900);--bg-surface: var(--slate-800);--bg-elevated: var(--slate-700);--bg-card: rgba(30, 41, 59, .8);--bg-card-hover: rgba(51, 65, 85, .8);--bg-glass: rgba(15, 23, 42, .6);--text-primary: var(--slate-100);--text-secondary: var(--slate-400);--text-muted: var(--slate-500);--text-accent: var(--amber-400);--text-heading: #ffffff;--border-subtle: rgba(148, 163, 184, .1);--border-default: rgba(148, 163, 184, .15);--border-strong: rgba(148, 163, 184, .25);--accent-primary: var(--amber-500);--accent-glow: rgba(245, 158, 11, .15);--success: var(--emerald-500);--error: var(--rose-500);--font-sans: "Inter", -apple-system, sans-serif;--font-serif: "Source Serif 4", Georgia, serif;--text-xs: .75rem;--text-sm: .8125rem;--text-base: .9375rem;--text-md: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 1.875rem;--text-4xl: 2.25rem;--sp-1: .25rem;--sp-2: .5rem;--sp-3: .75rem;--sp-4: 1rem;--sp-5: 1.25rem;--sp-6: 1.5rem;--sp-8: 2rem;--sp-10: 2.5rem;--sp-12: 3rem;--sp-16: 4rem;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--radius-xl: 24px;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 12px rgba(0, 0, 0, .3);--shadow-lg: 0 8px 30px rgba(0, 0, 0, .4);--shadow-glow: 0 0 20px var(--accent-glow);--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .25s cubic-bezier(.4, 0, .2, 1);--transition-slow: .4s cubic-bezier(.4, 0, .2, 1);--sidebar-width: 300px;--sidebar-collapsed: 0px;--topbar-height: 60px;--content-max-width: 900px}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--slate-600);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--slate-500)}:focus-visible{outline:2px solid var(--accent-primary);outline-offset:2px}::selection{background:var(--amber-500);color:var(--slate-900)}h1,h2,h3,h4,h5,h6{font-family:var(--font-sans);color:var(--text-heading);line-height:1.3;font-weight:700}p{font-family:var(--font-serif);color:var(--text-primary);line-height:1.8}a{color:var(--amber-400);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--amber-300)}img,svg{display:block;max-width:100%}button{font-family:var(--font-sans);cursor:pointer;border:none;background:none;color:inherit}.text-accent{color:var(--text-accent)}.text-muted{color:var(--text-muted)}.text-success{color:var(--success)}.font-serif{font-family:var(--font-serif)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}@keyframes fadeIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.animate-fade-in{animation:fadeIn .5s ease-out forwards}.animate-slide-in{animation:slideInLeft .4s ease-out forwards}.illustration-container{margin:var(--sp-6) 0;text-align:center}.illustration-img{max-width:480px;margin:0 auto;border-radius:var(--radius-lg);border:1px solid var(--border-subtle);box-shadow:var(--shadow-md);transition:transform var(--transition-base)}.illustration-img:hover{transform:scale(1.02)}.loading-screen{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;display:flex;align-items:center;justify-content:center;background:var(--bg-base);transition:opacity .6s ease,visibility .6s ease}.loading-screen.hidden{opacity:0;visibility:hidden;pointer-events:none}.loading-content{text-align:center}.loading-logo{margin-bottom:var(--sp-8)}.loading-icon{font-size:3rem;display:block;margin-bottom:var(--sp-4);animation:pulse 2s ease-in-out infinite}.loading-logo h1{font-size:var(--text-2xl);background:linear-gradient(135deg,var(--amber-400),var(--amber-200));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.loading-logo p{color:var(--text-secondary);font-size:var(--text-sm);margin-top:var(--sp-2)}.loading-bar{width:200px;height:3px;background:var(--border-subtle);border-radius:var(--radius-full);overflow:hidden;margin:0 auto}.loading-bar-fill{height:100%;width:40%;background:linear-gradient(90deg,var(--amber-500),var(--amber-300));border-radius:var(--radius-full);animation:shimmer 1.5s infinite;background-size:200% 100%}.app-shell{display:flex;min-height:100vh;background:var(--bg-base)}.sidebar{position:fixed;top:0;left:0;bottom:0;width:var(--sidebar-width);background:linear-gradient(180deg,#0f172afa,#0a1628fa);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-right:1px solid var(--border-subtle);display:flex;flex-direction:column;z-index:100;transition:transform var(--transition-base);overflow:hidden}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:var(--sp-5) var(--sp-5);border-bottom:1px solid var(--border-subtle);flex-shrink:0}.brand{display:flex;align-items:center;gap:var(--sp-3)}.brand-icon{font-size:1.5rem}.brand-text h2{font-size:var(--text-md);font-weight:700;background:linear-gradient(135deg,var(--amber-400),var(--amber-200));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.brand-subtitle{font-size:var(--text-xs);color:var(--text-muted);display:block}.sidebar-toggle{padding:var(--sp-2);border-radius:var(--radius-sm);color:var(--text-secondary);transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center;background:transparent;border:none;cursor:pointer}.sidebar-toggle:hover{color:var(--text-primary);background:var(--bg-elevated)}body.sidebar-collapsed .sidebar{transform:translate(-100%);pointer-events:none}body.sidebar-collapsed .main-content{margin-left:0}.sidebar-expand-btn{position:fixed;top:12px;left:12px;z-index:110;width:40px;height:40px;border-radius:var(--radius-md);background:var(--bg-elevated, rgba(28, 34, 48, .95));border:1px solid var(--border-subtle);color:var(--text-secondary);display:none;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 4px 12px #00000059;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);transition:all var(--transition-fast)}.sidebar-expand-btn:hover{color:var(--amber-300, #fbbf24);border-color:var(--amber-500, #f59e0b);transform:translate(2px)}body.sidebar-collapsed .sidebar-expand-btn{display:flex}@media(max-width:768px){.sidebar-toggle{display:none}body.sidebar-collapsed .sidebar{transform:translate(-100%)}body.sidebar-collapsed .main-content{margin-left:0}body.sidebar-collapsed .sidebar-expand-btn{display:none}}.sidebar-progress{display:flex;align-items:center;gap:var(--sp-4);padding:var(--sp-4) var(--sp-5);border-bottom:1px solid var(--border-subtle);flex-shrink:0}.progress-ring-container{position:relative;width:56px;height:56px;flex-shrink:0}.progress-ring{transform:rotate(-90deg)}.progress-ring-bg{fill:none;stroke:var(--border-subtle);stroke-width:4}.progress-ring-fill{fill:none;stroke:var(--emerald-400);stroke-width:4;stroke-linecap:round;stroke-dasharray:150.796;stroke-dashoffset:150.796;transition:stroke-dashoffset .8s ease}.progress-percent{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-size:var(--text-xs);font-weight:700;color:var(--emerald-400)}.progress-info{display:flex;flex-direction:column;gap:2px}.progress-label{font-size:var(--text-xs);font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.progress-detail{font-size:var(--text-sm);color:var(--text-primary)}.module-nav{flex:1;overflow-y:auto;padding:var(--sp-3) 0}.nav-group{margin-bottom:var(--sp-1)}.nav-group-header{display:flex;align-items:center;gap:var(--sp-3);width:100%;padding:var(--sp-3) var(--sp-5);font-size:var(--text-sm);font-weight:600;color:var(--text-secondary);transition:all var(--transition-fast);text-align:left}.nav-group-header:hover{color:var(--text-primary);background:var(--bg-card)}.nav-group-icon{font-size:1rem}.nav-group-title{flex:1}.nav-chevron{transition:transform var(--transition-fast);flex-shrink:0}.nav-group-header.expanded .nav-chevron{transform:rotate(90deg)}.nav-group-items{max-height:0;overflow:hidden;transition:max-height var(--transition-slow)}.nav-group-items.expanded{max-height:500px}.nav-item{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-2) var(--sp-5) var(--sp-2) var(--sp-10);font-size:var(--text-sm);color:var(--text-secondary);transition:all var(--transition-fast);text-decoration:none;border-left:2px solid transparent;position:relative}.nav-item:hover{color:var(--text-primary);background:var(--bg-card);border-left-color:var(--amber-500)}.nav-item.active{color:var(--amber-400);background:var(--accent-glow);border-left-color:var(--amber-500);font-weight:500}.nav-item-num{font-size:var(--text-xs);font-weight:700;color:var(--text-muted);min-width:20px;font-variant-numeric:tabular-nums}.nav-item.active .nav-item-num{color:var(--amber-500)}.nav-item-title{flex:1}.nav-item-status{width:8px;height:8px;border-radius:50%;background:var(--border-subtle);flex-shrink:0}.nav-item-status.completed{background:var(--emerald-400);box-shadow:0 0 6px #10b98166}.nav-item-status.in-progress{background:var(--amber-400);box-shadow:0 0 6px #f59e0b66}.sidebar-footer{display:none;align-items:center;justify-content:center;gap:var(--sp-2);padding:var(--sp-4) var(--sp-5);border-top:1px solid var(--border-subtle);flex-shrink:0}.btn-icon{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:var(--radius-md);color:var(--text-secondary);transition:all var(--transition-fast)}.btn-icon:hover{color:var(--text-primary);background:var(--bg-elevated)}.lang-indicator{font-size:var(--text-xs);font-weight:700;letter-spacing:.03em}.main-content{flex:1;margin-left:var(--sidebar-width);min-height:100vh;display:flex;flex-direction:column;transition:margin-left var(--transition-base)}.topbar{position:sticky;top:0;z-index:50;display:flex;align-items:center;gap:var(--sp-4);padding:0 var(--sp-8);height:var(--topbar-height);background:#0f172acc;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border-subtle)}.topbar-actions{display:flex;align-items:center;gap:var(--sp-3);margin-left:auto;flex-shrink:0}.mobile-menu-toggle{display:none;padding:var(--sp-2);color:var(--text-secondary)}.breadcrumb{flex:1;font-size:var(--text-sm);color:var(--text-secondary);display:flex;align-items:center;gap:var(--sp-2)}.breadcrumb .separator{color:var(--text-muted)}.breadcrumb .current{color:var(--text-primary);font-weight:500}.lang-switch{display:flex;background:var(--bg-surface);border-radius:var(--radius-full);padding:3px;border:1px solid var(--border-subtle)}.lang-btn{padding:var(--sp-1) var(--sp-3);font-size:var(--text-xs);font-weight:600;border-radius:var(--radius-full);color:var(--text-muted);transition:all var(--transition-fast)}.lang-btn:hover{color:var(--text-primary)}.lang-btn.active{background:var(--amber-500);color:var(--slate-900);box-shadow:0 1px 4px #f59e0b4d}.btn-search{display:flex;align-items:center;gap:var(--sp-2);padding:var(--sp-2) var(--sp-4);background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-full);color:var(--text-muted);font-size:var(--text-sm);transition:all var(--transition-fast);cursor:pointer}.btn-search:hover{color:var(--text-primary);border-color:var(--amber-500);background:#f59e0b14}.btn-search svg{flex-shrink:0}.btn-search-label{font-family:var(--font-sans);color:var(--text-muted)}.btn-search-kbd{font-family:var(--font-sans);font-size:10px;background:var(--bg-elevated);color:var(--text-muted);padding:1px 6px;border-radius:3px;border:1px solid var(--border-default);margin-left:var(--sp-2)}.content-area{flex:1;padding:var(--sp-8);max-width:1200px;width:100%;margin:0 auto}.sidebar-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;z-index:99}@media(max-width:1024px){.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.main-content{margin-left:0}.mobile-menu-toggle{display:flex}.sidebar-overlay.active{display:block}}@media(max-width:640px){.content-area{padding:var(--sp-4)}.topbar{padding:0 var(--sp-4)}.lang-switch{display:none}.sidebar-footer{display:flex}.btn-search-label,.btn-search-kbd{display:none}.btn-search{padding:var(--sp-2);border-radius:var(--radius-md)}.topbar-actions{flex-shrink:1;min-width:0;flex-wrap:wrap}#user-badge>.user-badge-name{display:none}#user-badge .badge-guest .badge-guest-label,.breadcrumb{display:none}.module-hero h1{font-size:1.4rem;word-break:break-word;overflow-wrap:anywhere;max-width:100%}html,body{overflow-x:hidden;max-width:100vw}}.card{background:var(--bg-card);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--sp-6);transition:all var(--transition-base)}.card:hover{border-color:var(--border-default);box-shadow:var(--shadow-md)}.card-accent{border-left:3px solid var(--amber-500)}.card-success{border-left:3px solid var(--emerald-500)}.card-header{display:flex;align-items:center;gap:var(--sp-3);margin-bottom:var(--sp-4)}.card-icon{width:40px;height:40px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:1.2rem;background:var(--accent-glow);flex-shrink:0}.card-title{font-size:var(--text-lg);font-weight:700}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--sp-2);padding:var(--sp-3) var(--sp-6);font-size:var(--text-sm);font-weight:600;border-radius:var(--radius-md);transition:all var(--transition-fast);white-space:nowrap;cursor:pointer;border:none}.btn-primary{background:linear-gradient(135deg,var(--amber-500),var(--amber-600));color:var(--slate-900);box-shadow:0 2px 8px #f59e0b4d}.btn-primary:hover{background:linear-gradient(135deg,var(--amber-400),var(--amber-500));transform:translateY(-1px)}.btn-secondary{background:var(--bg-elevated);color:var(--text-primary);border:1px solid var(--border-default)}.btn-secondary:hover{background:var(--bg-card-hover)}.btn-ghost{background:transparent;color:var(--text-secondary)}.btn-ghost:hover{background:var(--bg-card);color:var(--text-primary)}.btn-success{background:linear-gradient(135deg,var(--emerald-500),var(--emerald-600));color:#fff}.btn-sm{padding:var(--sp-2) var(--sp-4);font-size:var(--text-xs)}.btn-lg{padding:var(--sp-4) var(--sp-8);font-size:var(--text-md)}.badge{display:inline-flex;align-items:center;gap:var(--sp-1);padding:2px var(--sp-3);font-size:var(--text-xs);font-weight:600;border-radius:var(--radius-full);background:var(--bg-elevated);color:var(--text-secondary)}.badge-amber{background:#f59e0b26;color:var(--amber-400)}.badge-emerald{background:#10b98126;color:var(--emerald-400)}.tabs{display:flex;gap:var(--sp-1);border-bottom:1px solid var(--border-subtle);margin-bottom:var(--sp-6)}.tab{padding:var(--sp-3) var(--sp-4);font-size:var(--text-sm);font-weight:500;color:var(--text-muted);border-bottom:2px solid transparent;transition:all var(--transition-fast);cursor:pointer;background:none;border-top:none;border-left:none;border-right:none}.tab:hover{color:var(--text-primary)}.tab.active{color:var(--amber-400);border-bottom-color:var(--amber-500)}.accordion{border:1px solid var(--border-subtle);border-radius:var(--radius-md);overflow:hidden}.accordion-item{border-bottom:1px solid var(--border-subtle)}.accordion-item:last-child{border-bottom:none}.accordion-trigger{display:flex;align-items:center;gap:var(--sp-3);width:100%;padding:var(--sp-4) var(--sp-5);font-size:var(--text-base);font-weight:600;color:var(--text-primary);background:var(--bg-card);text-align:left;transition:all var(--transition-fast)}.accordion-trigger:hover{background:var(--bg-card-hover)}.accordion-trigger .chevron{margin-left:auto;transition:transform var(--transition-fast)}.accordion-trigger.open .chevron{transform:rotate(180deg)}.accordion-body{max-height:0;overflow:hidden;transition:max-height var(--transition-slow)}.accordion-body.open{max-height:2000px}.accordion-content{padding:var(--sp-4) var(--sp-5)}.exercise-container{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);overflow:hidden;margin:var(--sp-6) 0}.exercise-header{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-4) var(--sp-6);background:linear-gradient(135deg,#f59e0b14,#f59e0b05);border-bottom:1px solid var(--border-subtle)}.exercise-type-icon{width:36px;height:36px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:1.1rem;background:var(--accent-glow)}.exercise-title{font-size:var(--text-md);font-weight:700;flex:1}.exercise-score{display:flex;align-items:center;gap:var(--sp-2);font-size:var(--text-sm);font-weight:600;color:var(--emerald-400)}.exercise-body{padding:var(--sp-6)}.exercise-footer{display:flex;align-items:center;justify-content:space-between;padding:var(--sp-4) var(--sp-6);border-top:1px solid var(--border-subtle);background:#0f172a66}.exercise-container[data-submitted="1"] .exercise-body{pointer-events:none;opacity:.85}.exercise-container[data-submitted="1"] .exercise-footer button:disabled{opacity:.55;cursor:not-allowed}.quiz-option{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-3) var(--sp-4);margin-bottom:var(--sp-2);border:1px solid var(--border-subtle);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.quiz-option:hover{border-color:var(--amber-500);background:var(--accent-glow)}.quiz-option.selected{border-color:var(--amber-500);background:#f59e0b1a}.quiz-option.correct{border-color:var(--emerald-500);background:#10b9811a}.quiz-option.incorrect{border-color:var(--rose-500);background:#f43f5e1a}.quiz-radio{width:18px;height:18px;border:2px solid var(--text-muted);border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.quiz-option.selected .quiz-radio{border-color:var(--amber-500)}.quiz-option.selected .quiz-radio:after{content:"";width:8px;height:8px;border-radius:50%;background:var(--amber-500)}.quiz-option.correct .quiz-radio{border-color:var(--emerald-500);background:var(--emerald-500)}.quiz-label{font-size:var(--text-sm);color:var(--text-primary);line-height:1.5}.quiz-multi .quiz-radio{border-radius:4px}.quiz-multi .quiz-option.selected .quiz-radio:after{border-radius:1px;width:10px;height:10px}.quiz-q-timer{margin:0 0 var(--sp-3);padding:6px 10px;background:#f59e0b0f;border:1px solid rgba(245,158,11,.18);border-radius:var(--radius-sm);display:flex;align-items:center;gap:var(--sp-3)}.quiz-q-timer-bar{flex:1;position:relative;height:4px;border-radius:2px;background:#ffffff0f;overflow:hidden}.quiz-q-timer-fill{display:block;height:100%;width:100%;background:linear-gradient(90deg,var(--amber-400, #fbbf24),var(--amber-500, #f59e0b));transition:width .25s linear}.quiz-q-timer-text{display:inline-flex;align-items:center;gap:4px;font-size:.75rem;font-weight:700;color:var(--amber-300, #fcd34d);font-variant-numeric:tabular-nums;white-space:nowrap}.quiz-q-timer-emoji{font-size:.95rem}.quiz-q-timer-low{background:#f43f5e1a;border-color:#f43f5e4d}.quiz-q-timer-low .quiz-q-timer-fill{background:linear-gradient(90deg,var(--rose-400, #fb7185),var(--rose-500, #f43f5e));animation:quiz-q-timer-pulse .5s ease-in-out infinite alternate}.quiz-q-timer-low .quiz-q-timer-text{color:var(--rose-300, #fda4af)}@keyframes quiz-q-timer-pulse{0%{opacity:.85}to{opacity:1}}.quiz-question-locked .quiz-option{pointer-events:none;opacity:.55}.quiz-question-locked .quiz-q-timer{background:#64748b1a;border-color:#64748b40}.quiz-question-locked .quiz-q-timer-fill{background:#64748b80}.quiz-question-locked .quiz-q-timer-text{color:var(--text-muted)}.quiz-question-locked .quiz-q-timer-text:after{content:" · time up";color:var(--rose-300, #fda4af);font-weight:600}.quiz-pre-start{padding:var(--sp-6);text-align:center;background:#f59e0b0a;border:1px dashed rgba(245,158,11,.3);border-radius:var(--radius-md)}.quiz-pre-start-ended{background:#94a3b80f;border-color:#94a3b84d;color:var(--text-muted)}.quiz-pre-start-ended .quiz-pre-start-icon{animation:none;opacity:.7}.quiz-pre-start p{margin:0 0 var(--sp-3)}.quiz-pre-start p:last-child{margin-bottom:0}.quiz-pre-start-icon{font-size:2.5rem;margin-bottom:var(--sp-3);opacity:.85;animation:quiz-pre-start-pulse 1.6s ease-in-out infinite}@keyframes quiz-pre-start-pulse{0%,to{transform:scale(1);opacity:.85}50%{transform:scale(1.08);opacity:1}}.quiz-start-btn{font-size:1rem;padding:var(--sp-3) var(--sp-6);margin:var(--sp-2) 0 var(--sp-3)}.quiz-question-seq{display:none}.quiz-question-seq.quiz-question-active{display:block;animation:quiz-q-slide-in .4s cubic-bezier(.22,.61,.36,1)}@keyframes quiz-q-slide-in{0%{opacity:0;transform:translate(36px) scale(.985)}to{opacity:1;transform:translate(0) scale(1)}}@media(prefers-reduced-motion:reduce){.quiz-question-seq.quiz-question-active{animation:none}}.quiz-q-progress{display:inline-block;margin-bottom:var(--sp-3);padding:2px 10px;font-size:.72rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--amber-300, #fcd34d);background:#f59e0b1a;border:1px solid rgba(245,158,11,.25);border-radius:var(--radius-full)}.quiz-q-controls{margin-top:var(--sp-4);padding-top:var(--sp-3);border-top:1px dashed var(--border-subtle);display:flex;justify-content:flex-end;gap:var(--sp-2)}.quiz-advance-btn,.quiz-q-submit-btn{min-width:110px}.exercise-container:has(.quiz-attempt-info[data-sequential="1"]) .exercise-footer button{display:none}.quiz-question-submitted .quiz-q-submit-btn{background:var(--bg-surface);color:var(--text-muted);border-color:var(--border-subtle)}.quiz-q-waiting{margin-left:var(--sp-2);font-size:.78rem;color:var(--text-muted);font-style:italic;align-self:center}.quiz-q-instructor-progress{justify-content:flex-start}.quiz-q-submit-progress{display:inline-flex;align-items:center;gap:4px;padding:4px 12px;font-size:.78rem;color:var(--text-muted);background:#64748b14;border:1px solid rgba(100,116,139,.2);border-radius:var(--radius-full);font-variant-numeric:tabular-nums}.quiz-q-submit-count{font-weight:700;color:var(--amber-300, #fcd34d)}.quiz-q-submit-total{color:var(--text-primary)}.quiz-podium-card{padding:var(--sp-6);text-align:center;background:linear-gradient(180deg,#f59e0b1a,#f59e0b05);border:1px solid rgba(245,158,11,.3);border-radius:var(--radius-lg)}.quiz-podium-title{font-size:1.5rem;font-weight:800;margin-bottom:var(--sp-4);background:linear-gradient(90deg,var(--amber-300, #fcd34d),var(--amber-500, #f59e0b));-webkit-background-clip:text;background-clip:text;color:transparent}.quiz-podium-list{display:flex;flex-direction:column;gap:var(--sp-2);max-width:460px;margin:0 auto}.quiz-podium-row{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:var(--sp-3);padding:var(--sp-3) var(--sp-4);border-radius:var(--radius-md);background:#ffffff08;border:1px solid var(--border-subtle)}.quiz-podium-row-1{background:#f59e0b1f;border-color:#f59e0b66;transform:scale(1.04)}.quiz-podium-row-2{background:#94a3b81a;border-color:#94a3b84d}.quiz-podium-row-3{background:#b453091a;border-color:#b453094d}.quiz-podium-medal{font-size:1.5rem}.quiz-podium-name{text-align:left;font-weight:600;color:var(--text-primary)}.quiz-podium-score{font-weight:700;font-variant-numeric:tabular-nums;color:var(--amber-300, #fcd34d)}.quiz-podium-mine{margin-top:var(--sp-4);padding:var(--sp-3);font-size:.9rem;color:var(--text-muted);background:#ffffff08;border-radius:var(--radius-md)}.pmf-fx-mute{position:fixed;right:var(--sp-4);bottom:var(--sp-4);z-index:1000;width:38px;height:38px;border-radius:50%;border:1px solid var(--border-default);background:var(--bg-surface);color:var(--text-primary);cursor:pointer;font-size:1.05rem;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-md);transition:transform var(--transition-fast),background var(--transition-fast)}.pmf-fx-mute:hover{transform:scale(1.08);background:var(--bg-elevated)}@media print{.pmf-fx-mute{display:none!important}}.quiz-streak-badge{display:inline-block;margin-left:6px;padding:2px 10px;font-weight:700;font-size:.75rem;color:var(--bg-app, #0f172a);background:linear-gradient(90deg,#fb7185,#f59e0b);border-radius:var(--radius-full);animation:streak-pop .4s ease-out}@keyframes streak-pop{0%{transform:scale(.8);opacity:0}60%{transform:scale(1.1);opacity:1}to{transform:scale(1)}}.quiz-question-revealing .quiz-option{position:relative;pointer-events:none;overflow:hidden}.quiz-question-revealing .quiz-option.correct{border-color:var(--emerald-500);background:#10b98114;animation:quiz-reveal-correct .6s ease-out}@keyframes quiz-reveal-correct{0%{transform:scale(1)}40%{transform:scale(1.025);box-shadow:0 0 0 4px #10b98133}to{transform:scale(1)}}.quiz-reveal-count{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:flex-end;padding-right:var(--sp-3);pointer-events:none;z-index:1}.quiz-reveal-bar{position:absolute;left:0;top:0;bottom:0;background:linear-gradient(90deg,#f59e0b2e,#f59e0b0f);z-index:0;animation:quiz-reveal-bar-grow .6s ease-out}.quiz-question-revealing .quiz-option.correct .quiz-reveal-bar{background:linear-gradient(90deg,#10b98147,#10b98114)}@keyframes quiz-reveal-bar-grow{0%{width:0!important}}.quiz-reveal-num{font-size:.75rem;font-weight:700;color:var(--text-primary);background:#0f172aa6;padding:2px 8px;border-radius:var(--radius-full);font-variant-numeric:tabular-nums;position:relative;z-index:2}.input{width:100%;padding:var(--sp-3) var(--sp-4);font-family:var(--font-sans);font-size:var(--text-sm);color:var(--text-primary);background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-md);transition:all var(--transition-fast)}.input:focus{outline:none;border-color:var(--amber-500);box-shadow:0 0 0 3px var(--accent-glow)}.input::placeholder{color:var(--text-muted)}textarea.input{min-height:100px;resize:vertical;line-height:1.6}.checklist{list-style:none}.checklist-item{display:flex;align-items:flex-start;gap:var(--sp-3);padding:var(--sp-3) 0;border-bottom:1px solid var(--border-subtle)}.checklist-item:last-child{border-bottom:none}.checklist-checkbox{width:20px;height:20px;border:2px solid var(--text-muted);border-radius:var(--radius-sm);flex-shrink:0;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast);margin-top:2px}.checklist-checkbox.checked{background:var(--emerald-500);border-color:var(--emerald-500)}.checklist-checkbox.checked:after{content:"✓";color:#fff;font-size:12px;font-weight:700}.checklist-text{font-size:var(--text-sm);color:var(--text-primary);line-height:1.5}.progress-bar{width:100%;height:6px;background:var(--border-subtle);border-radius:var(--radius-full);overflow:hidden}.progress-bar-fill{height:100%;background:linear-gradient(90deg,var(--amber-500),var(--emerald-400));border-radius:var(--radius-full);transition:width .6s ease}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:all var(--transition-base)}.modal-overlay.active{opacity:1;visibility:visible}.modal{background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-xl);width:90%;max-width:560px;max-height:85vh;overflow-y:auto;animation:scaleIn .3s ease}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--sp-5) var(--sp-6);border-bottom:1px solid var(--border-subtle)}.modal-title{font-size:var(--text-lg);font-weight:700}.modal-body{padding:var(--sp-6)}.modal-footer{display:flex;justify-content:flex-end;gap:var(--sp-3);padding:var(--sp-4) var(--sp-6);border-top:1px solid var(--border-subtle)}.toast-container{position:fixed;top:var(--sp-4);right:var(--sp-4);z-index:300;display:flex;flex-direction:column;gap:var(--sp-3)}.toast{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-3) var(--sp-5);background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);animation:slideInLeft .3s ease;min-width:280px}.toast-success{border-left:3px solid var(--emerald-500)}.toast-error{border-left:3px solid var(--rose-500)}.toast-info{border-left:3px solid var(--amber-500)}.toast-message{font-size:var(--text-sm);color:var(--text-primary);flex:1}.module-hero{padding:var(--sp-8) 0 var(--sp-6);animation:fadeIn .5s ease}.module-hero .module-badge{margin-bottom:var(--sp-3)}.module-hero h1{font-size:var(--text-3xl);margin-bottom:var(--sp-2);line-height:1.2}.module-hero .subtitle{font-size:var(--text-lg);color:var(--text-secondary);font-family:var(--font-serif)}.welcome-hero{position:relative;padding:0!important;border-radius:var(--radius-xl);overflow:hidden;margin-bottom:var(--sp-8);min-height:280px}.hero-banner-wrap{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0}.hero-banner-img{width:100%;height:100%;object-fit:cover;object-position:center 40%;opacity:.55;transition:opacity .6s ease}.welcome-hero:hover .hero-banner-img{opacity:.7}.hero-banner-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,#0f172a33,#0f172a99,#0f172af2)}.hero-text-content{position:relative;z-index:1;padding:var(--sp-12) var(--sp-8) var(--sp-8);display:flex;flex-direction:column;justify-content:flex-end;min-height:280px}.hero-text-content h1{text-shadow:0 2px 12px rgba(0,0,0,.5)}.hero-text-content .subtitle{text-shadow:0 1px 6px rgba(0,0,0,.4)}@media(max-width:768px){.welcome-hero{min-height:200px;border-radius:var(--radius-lg)}.hero-text-content{min-height:200px;padding:var(--sp-8) var(--sp-5) var(--sp-5)}}.module-hero-img{position:relative;padding:0!important;border-radius:var(--radius-xl);overflow:hidden;margin-bottom:var(--sp-6);min-height:220px}.module-hero-img .hero-banner-img{opacity:.4;object-position:center 35%}.module-hero-img:hover .hero-banner-img{opacity:.55}.module-hero-img .hero-text-content{min-height:220px;padding:var(--sp-8) var(--sp-8) var(--sp-6)}.module-hero-img .module-badge{margin-bottom:var(--sp-2)}@media(max-width:768px){.module-hero-img{min-height:180px;border-radius:var(--radius-lg)}.module-hero-img .hero-text-content{min-height:180px;padding:var(--sp-6) var(--sp-5) var(--sp-4)}}.bilingual{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-6);margin:var(--sp-4) 0}.bilingual .lang-en,.bilingual .lang-vn{padding:var(--sp-4);border-radius:var(--radius-md)}.bilingual .lang-en{background:#5c7cfa0d;border-left:3px solid var(--navy-500)}.bilingual .lang-vn{background:#f59e0b0d;border-left:3px solid var(--amber-500)}body[data-lang=en] .lang-vn,body[data-lang=vn] .lang-en{display:none}body[data-lang=en] .bilingual,body[data-lang=vn] .bilingual{grid-template-columns:1fr}body[data-lang=zh] [class*=lang-]:not(.lang-zh):not(.lang-bil-sep):not(.lang-indicator):not(.lang-btn){display:none}body[data-lang=ja] [class*=lang-]:not(.lang-ja):not(.lang-bil-sep):not(.lang-indicator):not(.lang-btn){display:none}body[data-lang=ko] [class*=lang-]:not(.lang-ko):not(.lang-bil-sep):not(.lang-indicator):not(.lang-btn){display:none}body[data-lang=es] [class*=lang-]:not(.lang-es):not(.lang-bil-sep):not(.lang-indicator):not(.lang-btn){display:none}body[data-lang=fr] [class*=lang-]:not(.lang-fr):not(.lang-bil-sep):not(.lang-indicator):not(.lang-btn){display:none}body[data-lang=de] [class*=lang-]:not(.lang-de):not(.lang-bil-sep):not(.lang-indicator):not(.lang-btn){display:none}body[data-lang=ru] [class*=lang-]:not(.lang-ru):not(.lang-bil-sep):not(.lang-indicator):not(.lang-btn){display:none}body[data-lang=ar] [class*=lang-]:not(.lang-ar):not(.lang-bil-sep):not(.lang-indicator):not(.lang-btn){display:none}body[data-lang=zh] .bilingual,body[data-lang=ja] .bilingual,body[data-lang=ko] .bilingual,body[data-lang=es] .bilingual,body[data-lang=fr] .bilingual,body[data-lang=de] .bilingual,body[data-lang=ru] .bilingual,body[data-lang=ar] .bilingual{grid-template-columns:1fr}body[data-lang=zh] .lang-bil-sep,body[data-lang=ja] .lang-bil-sep,body[data-lang=ko] .lang-bil-sep,body[data-lang=es] .lang-bil-sep,body[data-lang=fr] .lang-bil-sep,body[data-lang=de] .lang-bil-sep,body[data-lang=ru] .lang-bil-sep,body[data-lang=ar] .lang-bil-sep{display:none}.lang-bil-sep{display:inline}body[data-lang=en] .lang-bil-sep,body[data-lang=vn] .lang-bil-sep{display:none}body[data-lang=both] .lang-vn,body[data-lang=both] .lang-vn .text-muted,body[data-lang=both] .lang-vn .lang-bil-sep{color:var(--amber-300)}.fill-blank{display:inline-block;border:none;border-bottom:1px dashed currentColor;background:transparent;color:var(--amber-400, #fbbf24);font:inherit;padding:0 .25em;outline:none;vertical-align:baseline;min-width:5ch;max-width:100%;margin:0 .1em}.fill-blank::placeholder{color:var(--text-muted, #94a3b8);opacity:.5}.fill-blank:focus{border-bottom-color:var(--amber-400, #fbbf24);border-bottom-style:solid;background:#fbbf240f}.fill-blank-wide{width:100%!important}.fillin-actions{display:flex;justify-content:flex-end;align-items:center;gap:.75rem;margin:1rem 0 .5rem;padding-top:.75rem;border-top:1px dashed rgba(255,255,255,.06)}.fillin-status{font-size:.8125rem;min-width:6ch;text-align:right}.fillin-status.saving{color:var(--amber-400, #fbbf24)}.fillin-status.ok{color:#10b981}.fillin-status.error{color:#f87171}.fillin-submit{white-space:nowrap}.fillin-submit:disabled{opacity:.6;cursor:wait}.content-section{margin:var(--sp-8) 0;animation:fadeIn .4s ease forwards}.content-section h2{font-size:var(--text-2xl);margin-bottom:var(--sp-4);padding-bottom:var(--sp-3);border-bottom:1px solid var(--border-subtle)}.content-section h3{font-size:var(--text-xl);margin:var(--sp-6) 0 var(--sp-3);color:var(--amber-300)}.content-section h4{font-size:var(--text-lg);margin:var(--sp-4) 0 var(--sp-2)}.content-section ul,.content-section ol{padding-left:var(--sp-6);margin:var(--sp-3) 0}.content-section li{margin-bottom:var(--sp-2);font-family:var(--font-serif);color:var(--text-primary);line-height:1.7}.content-section li::marker{color:var(--amber-500)}.key-points{background:linear-gradient(135deg,#f59e0b0f,#10b9810a);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--sp-5);margin:var(--sp-6) 0}.key-points-title{display:flex;align-items:center;gap:var(--sp-2);font-size:var(--text-md);font-weight:700;margin-bottom:var(--sp-3);color:var(--amber-400)}.content-section blockquote{border-left:3px solid var(--amber-500);padding:var(--sp-4) var(--sp-5);margin:var(--sp-4) 0;background:var(--accent-glow);border-radius:0 var(--radius-md) var(--radius-md) 0;font-style:italic}.content-table{width:100%;border-collapse:collapse;margin:var(--sp-4) 0;font-size:var(--text-sm)}.content-table th{background:var(--bg-elevated);color:var(--text-heading);font-weight:600;text-align:left;padding:var(--sp-3) var(--sp-4);border:1px solid var(--border-default)}.content-table td{padding:var(--sp-3) var(--sp-4);border:1px solid var(--border-subtle);color:var(--text-primary)}.content-table tr:hover td{background:var(--bg-card)}.diagram-container{background:linear-gradient(135deg,var(--bg-card),rgba(30,58,95,.3));border:1px solid var(--border-subtle);border-radius:var(--radius-lg);margin:var(--sp-6) 0;overflow:hidden;transition:all .3s ease}.diagram-container:hover{border-color:var(--amber-500);box-shadow:0 0 20px #f59e0b1a}.diagram-header{display:flex;align-items:center;gap:var(--sp-2);padding:var(--sp-3) var(--sp-5);background:#f59e0b14;border-bottom:1px solid var(--border-subtle)}.diagram-icon{font-size:1.2em}.diagram-label{font-size:var(--text-sm);font-weight:600;color:var(--amber-400);flex:1}.diagram-zoom-btn{background:none;border:1px solid var(--border-subtle);border-radius:var(--radius-sm);color:var(--text-secondary);padding:4px 8px;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:4px}.diagram-zoom-btn:hover{color:var(--amber-400);border-color:var(--amber-500);background:#f59e0b1a}.diagram-svg-wrap{padding:var(--sp-6);text-align:center;min-height:200px;display:flex;align-items:center;justify-content:center}.diagram-svg-wrap svg{max-width:100%;height:auto;max-height:500px;transition:all .3s}.diagram-loading{display:flex;flex-direction:column;align-items:center;gap:var(--sp-3);color:var(--text-muted)}.diagram-loading .spinner{width:32px;height:32px;border:3px solid var(--border-subtle);border-top-color:var(--amber-500);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.diagram-error{color:var(--amber-400);padding:var(--sp-4)}.diagram-caption{padding:0 var(--sp-5) var(--sp-4)}.diagram-caption .bilingual{margin:0}.illustration-wrap{width:100%}.image-fallback-note{margin:var(--sp-3) 0;padding:var(--sp-3) var(--sp-4);background:#f59e0b0d;border-left:3px solid rgba(245,158,11,.4);border-radius:var(--radius-sm, 6px);font-size:.9rem;color:var(--text-secondary, #94a3b8)}.image-fallback-note p{margin:.15rem 0}.image-fallback-note:before{content:"📷";margin-right:.5rem;opacity:.6}.code-wrap{margin:var(--sp-3) 0}pre.code-block{margin:0;padding:var(--sp-3) var(--sp-4);background:#1e1e2e;border:1px solid rgba(255,255,255,.08);border-radius:var(--radius-md);overflow-x:auto;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:.86rem;line-height:1.5;color:#f8f8f2}pre.code-block code{background:transparent;padding:0;color:inherit;font:inherit;text-shadow:none}.code-wrap .diagram-caption{padding:var(--sp-2) var(--sp-4);font-size:.8rem}.mermaid-wrap{margin:var(--sp-3) 0;padding:var(--sp-3);background:#ffffff08;border:1px solid var(--border-subtle, rgba(255,255,255,.08));border-radius:var(--radius-md);display:flex;flex-direction:column;align-items:center}.mermaid-block{width:100%;display:flex;justify-content:center;min-height:60px}.mermaid-block svg{max-width:100%;height:auto}.mermaid-error{color:var(--rose-400, #fb7185);background:#f43f5e14;border-radius:var(--radius-sm);padding:var(--sp-2) var(--sp-3);font-size:.82rem;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;white-space:pre-wrap;margin:0}.mermaid-wrap .diagram-caption{padding-top:var(--sp-2);font-size:.8rem}.ext-lesson-block{margin:1.4rem 0;background:#ffffff0a;border:1px solid var(--border-subtle, rgba(255,255,255,.1));border-radius:12px;overflow:hidden}.ext-lesson-head{display:flex;align-items:center;justify-content:space-between;gap:.8rem;padding:.6rem .9rem;background:#ffffff0a;border-bottom:1px solid var(--border-subtle, rgba(255,255,255,.08));font-size:.88rem}.ext-lesson-title{display:inline-flex;align-items:center;gap:.4rem;font-weight:600;color:var(--text-primary, #f1f5f9)}.ext-lesson-fs{background:#ffffff0f;border:1px solid var(--border-subtle, rgba(255,255,255,.12));color:var(--text-secondary, #cbd5e1);border-radius:999px;padding:.3rem .8rem;font-size:.78rem;cursor:pointer;transition:background .15s,color .15s}.ext-lesson-fs:hover{background:#f59e0b29;color:var(--amber-400, #fbbf24)}.ext-lesson-frame{display:block}body.ext-lesson-open{overflow:hidden}.ext-lesson-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1080;background:#000000e0;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);display:flex;align-items:stretch;justify-content:center;padding:0}.ext-lesson-fs-frame{width:100%;height:100%;display:grid;grid-template-rows:auto 1fr;background:#fff}.ext-lesson-fs-head{display:flex;align-items:center;justify-content:space-between;gap:.8rem;padding:.5rem .9rem;background:var(--bg-elev-1, #0f172a);color:var(--text-primary, #f1f5f9);border-bottom:1px solid var(--border-subtle, rgba(255,255,255,.1))}.callout-block{display:grid;grid-template-columns:auto 1fr;gap:.9rem;padding:1rem 1.2rem;border-radius:10px;margin:1.2rem 0;border:1px solid;align-items:start}.callout-block .callout-icon{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.95rem;flex-shrink:0}.callout-block .callout-body{font-size:.95rem;line-height:1.55}.callout-block .callout-title{display:block;font-weight:600;font-size:1rem;margin-bottom:.2rem}.callout-block .callout-body p{margin:.2rem 0;color:inherit}.callout-note{background:#3b82f614;border-color:#3b82f64d;color:var(--text-primary, inherit)}.callout-note .callout-icon{background:#3b82f6;color:#fff}.callout-tip{background:#22c55e14;border-color:#22c55e4d;color:var(--text-primary, inherit)}.callout-tip .callout-icon{background:#22c55e;color:#fff}.callout-warn{background:#f43f5e14;border-color:#f43f5e52;color:var(--text-primary, inherit)}.callout-warn .callout-icon{background:#f43f5e;color:#fff}.callout-key{background:#f59e0b14;border-color:#f59e0b57;color:var(--text-primary, inherit)}.callout-key .callout-icon{background:var(--amber-500, #f59e0b);color:#1f1300}.tabs-block{margin:1.5rem 0}.tabs-block .tab-buttons{display:flex;flex-wrap:wrap;gap:4px;border-bottom:1px solid var(--border-subtle, rgba(255,255,255,.1));margin-bottom:1rem}.tabs-block .tab-btn{background:transparent;border:none;border-bottom:2px solid transparent;padding:.55rem 1rem;font-size:.92rem;font-weight:500;color:var(--text-secondary, #94a3b8);cursor:pointer;margin-bottom:-1px;transition:color .15s,border-color .15s}.tabs-block .tab-btn:hover{color:var(--text-primary, #f1f5f9)}.tabs-block .tab-btn.active{color:var(--amber-400, #fbbf24);border-bottom-color:var(--amber-500, #f59e0b);font-weight:600}.tabs-block .tab-panel{display:none}.tabs-block .tab-panel.active{display:block}.tabs-block .tab-panel>h4{margin:.3rem 0 .6rem}.tabs-block .tab-points{list-style:none;padding:0;margin:.6rem 0 0;display:grid;gap:.35rem}.tabs-block .tab-points li{padding-left:1.2rem;position:relative}.tabs-block .tab-points li:before{content:"•";position:absolute;left:.4rem;color:var(--amber-500, #f59e0b);font-weight:700}.compare-block{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin:1.5rem 0}.compare-block .cmp-card{padding:1.2rem 1.4rem;border-radius:12px;border:1px solid var(--border-subtle, rgba(255,255,255,.1));background:#ffffff08}.compare-block .cmp-card-highlight{background:#f59e0b0f;border-color:#f59e0b4d}.compare-block .cmp-title{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;margin:0 0 .5rem;font-size:1.05rem}.compare-block .cmp-badge{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.68rem;letter-spacing:.08em;text-transform:uppercase;background:#ffffff14;color:var(--text-secondary, #94a3b8);padding:.18rem .5rem;border-radius:4px;font-weight:600}.compare-block .cmp-card-highlight .cmp-badge{background:var(--amber-500, #f59e0b);color:#1f1300}.compare-block .cmp-items{list-style:none;padding:0;margin:.5rem 0 0;display:grid;gap:.35rem;font-size:.92rem}.compare-block .cmp-items li{padding-left:1.2rem;position:relative;line-height:1.5}.compare-block .cmp-items li:before{content:"›";position:absolute;left:.4rem;color:var(--amber-500, #f59e0b);font-weight:700}@media(max-width:640px){.compare-block{grid-template-columns:1fr}}.grid-block{display:grid;gap:.8rem;margin:1.4rem 0}.grid-block .grid-card{display:block;text-decoration:none;color:inherit;background:#ffffff0a;border:1px solid var(--border-subtle, rgba(255,255,255,.1));border-radius:12px;padding:1rem 1.1rem;transition:transform .15s,border-color .15s,background .15s}.grid-block .grid-card-linked:hover{transform:translateY(-2px);border-color:#f59e0b80;background:#f59e0b0f}.grid-block .grid-card-icon{width:36px;height:36px;border-radius:50%;background:#f59e0b1f;color:var(--amber-400, #fbbf24);display:flex;align-items:center;justify-content:center;font-size:1.05rem;font-weight:600;margin-bottom:.6rem}.grid-block .grid-card-title{font-weight:600;font-size:.98rem;margin-bottom:.25rem;line-height:1.35}.grid-block .grid-card-desc{font-size:.86rem;color:var(--text-secondary, #94a3b8);line-height:1.5}body.lb-open{overflow:hidden}.lb-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1050;background:#000000db;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:1.5rem;animation:lb-in .15s ease-out}@keyframes lb-in{0%{opacity:0}to{opacity:1}}.lb-stage{flex:1 1 auto;width:100%;display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative;min-height:0}.lb-img{max-width:95%;max-height:100%;object-fit:contain;transform-origin:center center;transition:transform .05s ease-out;-webkit-user-select:none;user-select:none;-webkit-user-drag:none;touch-action:none;background:#ffffff0a;border-radius:4px}.lb-caption{max-width:90%;margin-top:1rem;padding:.6rem 1rem;background:#ffffff0f;border-radius:6px;color:#cbd5e1;font-size:.88rem;text-align:center}.lb-caption p{margin:.2rem 0}.lb-controls{position:fixed;bottom:1.2rem;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:6px;padding:6px 10px;background:#141923d9;border:1px solid rgba(255,255,255,.1);border-radius:999px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.lb-btn{width:36px;height:36px;border-radius:50%;border:none;background:#ffffff14;color:#fff;font-size:1.1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s}.lb-btn:hover{background:#ffffff29}.lb-btn-close{background:#f43f5e33}.lb-btn-close:hover{background:#f43f5e66}.lb-zoom-val{min-width:52px;text-align:center;font-size:.82rem;color:#cbd5e1;font-variant-numeric:tabular-nums}@media(max-width:480px){.lb-overlay{padding:.5rem}.lb-caption{font-size:.78rem}}.diagram-zoomed{position:fixed;top:var(--sp-4);left:var(--sp-4);right:var(--sp-4);bottom:var(--sp-4);z-index:1000;margin:0;background:var(--bg-base);border:2px solid var(--amber-500);box-shadow:0 0 60px #000c;display:flex;flex-direction:column}.diagram-zoomed .diagram-svg-wrap{flex:1;padding:var(--sp-4);overflow:auto}.diagram-zoomed .diagram-svg-wrap svg{max-height:none;max-width:100%;height:100%}.diagram-zoomed .diagram-caption{display:none}.diagram-actions{display:flex;align-items:center;gap:var(--sp-2)}.diagram-edit-btn{background:none;border:1px solid var(--border-subtle);border-radius:var(--radius-sm);color:var(--text-secondary);padding:4px 8px;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:4px;position:relative}.diagram-edit-btn:hover{color:#10b981;border-color:#10b981;background:#10b9811a}.diagram-edit-btn.diagram-btn-loading{pointer-events:none}.diagram-edit-btn.diagram-btn-loading:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;border:2px solid transparent;border-top-color:#10b981;animation:spin .8s linear infinite}.diagram-refreshing{animation:diagramPulse 1.5s ease}.diagram-exporting .diagram-svg-wrap{opacity:.4;filter:blur(2px);transition:all .3s}@keyframes diagramPulse{0%{box-shadow:0 0 #10b98100}50%{box-shadow:0 0 30px #10b9814d;border-color:#10b981}to{box-shadow:0 0 #10b98100}}.diagram-notification{position:fixed;top:16px;right:16px;z-index:9999;padding:12px 20px;border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:500;transform:translate(120%);transition:transform .3s ease;box-shadow:0 8px 32px #0006;max-width:400px}.diagram-notification-show{transform:translate(0)}.diagram-notification-info{background:#1e3a5f;color:#7dd3fc;border:1px solid #0ea5e9}.diagram-notification-success{background:#14532d;color:#86efac;border:1px solid #10b981}.diagram-notification-warning{background:#78350f;color:#fcd34d;border:1px solid #f59e0b}.diagram-notification-error{background:#7f1d1d;color:#fca5a5;border:1px solid #ef4444}.welcome-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:var(--sp-4);margin:var(--sp-6) 0}.welcome-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--sp-5);transition:all var(--transition-base);cursor:pointer;text-decoration:none}.welcome-card:hover{border-color:var(--amber-500);transform:translateY(-2px);box-shadow:var(--shadow-glow)}.welcome-card .card-num{font-size:var(--text-3xl);font-weight:800;color:var(--amber-500);opacity:.3;line-height:1}.welcome-card h3{font-size:var(--text-md);margin:var(--sp-2) 0 var(--sp-1)}.welcome-card p{font-size:var(--text-sm);color:var(--text-secondary);line-height:1.5}.welcome-cta{display:flex;align-items:center;gap:var(--sp-4);padding:var(--sp-5) var(--sp-6);background:linear-gradient(135deg,#f59e0b2e,#5c7cfa1a);border:2px solid var(--amber-500);border-radius:var(--radius-lg);text-decoration:none;color:var(--text-primary);font-size:var(--text-lg);font-weight:600;box-shadow:0 4px 16px #f59e0b26;transition:all var(--transition-base)}.welcome-cta:hover{transform:translateY(-2px);box-shadow:0 8px 24px #f59e0b4d;border-color:var(--amber-400);background:linear-gradient(135deg,#f59e0b47,#5c7cfa29)}.welcome-cta .cta-icon{font-size:2.4em;line-height:1;flex-shrink:0;filter:drop-shadow(0 2px 6px rgba(245,158,11,.4))}.welcome-cta .cta-text{display:flex;flex-direction:column;gap:2px;flex:1}.welcome-cta .cta-title{font-size:var(--text-xl);font-weight:700;color:var(--amber-400)}.welcome-cta .cta-sub{font-size:var(--text-sm);color:var(--text-secondary);font-weight:400}.welcome-cta .cta-arrow{font-size:1.6em;color:var(--amber-500);transition:transform var(--transition-base)}.welcome-cta:hover .cta-arrow{transform:translate(4px)}body[data-lang=both] .welcome-card h3 .lang-en,body[data-lang=both] .welcome-card h3 .lang-vn,body[data-lang=both] .welcome-card p .lang-en,body[data-lang=both] .welcome-card p .lang-vn,body[data-lang=both] .welcome-cta .cta-title .lang-en,body[data-lang=both] .welcome-cta .cta-title .lang-vn,body[data-lang=both] .welcome-cta .cta-sub .lang-en,body[data-lang=both] .welcome-cta .cta-sub .lang-vn{display:block}body[data-lang=both] .welcome-card h3 .lang-vn{color:var(--amber-400);font-weight:500;font-size:.92em;margin-top:2px}body[data-lang=both] .welcome-card p .lang-vn{font-style:italic;opacity:.85}body[data-lang=both] .welcome-cta .cta-title .lang-vn{color:var(--amber-300);font-size:.9em;margin-top:2px}body[data-lang=both] .welcome-cta .cta-sub .lang-vn{font-style:italic;opacity:.85}.module-nav-btns{display:flex;justify-content:space-between;margin-top:var(--sp-10);padding-top:var(--sp-6);border-top:1px solid var(--border-subtle)}@media(max-width:768px){.bilingual{grid-template-columns:1fr}.module-hero h1{font-size:var(--text-2xl)}.welcome-grid{grid-template-columns:1fr}}.module-hero-logo{display:block;max-width:56px;max-height:56px;margin-bottom:var(--sp-2);border-radius:var(--radius-sm);background:#ffffff0f;padding:4px;object-fit:contain}.media-block{max-width:100%}.media-block .media-frame{width:100%;border-radius:var(--radius-md, 10px);overflow:hidden;background:#000;border:1px solid var(--border-color, rgba(255,255,255,.08));box-shadow:0 6px 20px #00000040}.media-block .media-frame>iframe{width:100%;height:100%;border:0;display:block}.media-block-video .media-frame{background:#000}.media-block-embed .media-frame{background:#1c2230}.media-block-pdf .media-frame{background:#fff}.media-block .diagram-caption{margin-top:.5rem;text-align:center;font-size:.85rem;color:var(--text-secondary, rgba(255,255,255,.7))}.media-block .diagram-caption p{margin:.15rem 0}.media-pdf-toolbar,.media-embed-toolbar{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;padding:.5rem .625rem;margin-bottom:.5rem;background:#ffffff0a;border:1px solid var(--border-color, rgba(255,255,255,.08));border-radius:var(--radius-md, 10px)}.media-pdf-label,.media-embed-label{font-weight:600;font-size:.85rem;margin-right:auto;color:var(--amber-400, #fbbf24)}.media-embed-fallback{margin-top:.5rem;padding:.6rem .75rem;background:#f59e0b14;border:1px solid rgba(245,158,11,.25);border-radius:var(--radius-md, 10px);font-size:.8rem;line-height:1.5;color:var(--text-secondary, #cbd5e1)}.media-embed-fallback strong{color:var(--amber-400, #fbbf24);display:block;margin-bottom:.25rem}.media-embed-fallback em{font-style:normal;font-weight:600;color:var(--text-primary, #f1f5f9)}.media-block-error{margin:1rem auto;padding:.875rem 1rem;background:#f43f5e14;border:1px solid rgba(244,63,94,.35);border-radius:var(--radius-md, 10px);color:var(--rose-400, #fb7185);font-size:.875rem}.media-block-error code{background:#0000004d;padding:1px 6px;border-radius:4px;font-size:.8rem}@media(max-width:640px){.media-block{width:100%!important}.media-block .media-frame{max-height:60vh}.media-pdf-toolbar{flex-wrap:wrap}}.media-frame-pdf{background:#525659;overflow:hidden}.pdfjs-shell{display:flex;flex-direction:column;height:100%;background:#525659}.pdfjs-toolbar{flex:0 0 auto;display:flex;align-items:center;gap:.5rem;padding:.4rem .625rem;background:#00000059;border-bottom:1px solid rgba(255,255,255,.08);color:#eee;font-size:.8rem}.pdfjs-page-info{margin-right:auto;opacity:.9}.pdfjs-zoom-val{min-width:3.5em;text-align:center;font-variant-numeric:tabular-nums}.pdfjs-btn{background:#ffffff14;border:1px solid rgba(255,255,255,.15);color:#eee;border-radius:4px;padding:.25rem .55rem;font-size:.85rem;cursor:pointer;line-height:1}.pdfjs-btn:hover{background:#ffffff2e}.pdfjs-pages{flex:1 1 auto;overflow:auto;padding:.75rem 0;display:flex;flex-direction:column;align-items:center;gap:.75rem;scrollbar-width:thin;outline:none}.pdfjs-page-wrap{background:#fff;box-shadow:0 4px 12px #0006}.pdfjs-canvas{display:block;max-width:100%;height:auto!important}.pdfjs-loading{display:flex;align-items:center;justify-content:center;height:100%;color:#eee;font-size:.875rem;background:#525659}.pdfjs-error{padding:1.5rem;text-align:center;color:#ffd7d7}.pdfjs-error a{color:#ffd7d7;text-decoration:underline}.search-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:2000;background:#000000b3;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:flex-start;justify-content:center;padding-top:12vh;opacity:0;visibility:hidden;transition:opacity .2s ease,visibility .2s ease}.search-overlay.active{opacity:1;visibility:visible}.search-dialog{width:680px;max-width:calc(100vw - 2rem);max-height:72vh;background:var(--bg-surface);border:1px solid var(--border-strong);border-radius:var(--radius-xl);box-shadow:0 24px 80px #0009,0 0 40px #f59e0b14;display:flex;flex-direction:column;overflow:hidden;transform:scale(.96) translateY(-10px);transition:transform .25s cubic-bezier(.16,1,.3,1)}.search-overlay.active .search-dialog{transform:scale(1) translateY(0)}.search-input-wrap{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-4) var(--sp-5);border-bottom:1px solid var(--border-subtle)}.search-input-icon{flex-shrink:0;color:var(--text-muted)}.search-input{flex:1;background:none;border:none;outline:none;font-family:var(--font-sans);font-size:var(--text-lg);color:var(--text-heading);caret-color:var(--amber-400)}.search-input::placeholder{color:var(--text-muted)}.search-kbd{font-family:var(--font-sans);font-size:var(--text-xs);background:var(--bg-elevated);color:var(--text-muted);padding:2px 8px;border-radius:var(--radius-sm);border:1px solid var(--border-default);line-height:1.6}.search-results{flex:1;overflow-y:auto;padding:var(--sp-2) 0}.search-empty-state{text-align:center;padding:var(--sp-10) var(--sp-6)}.search-empty-icon{font-size:2.5rem;margin-bottom:var(--sp-3)}.search-empty-state p{font-family:var(--font-sans);color:var(--text-secondary);font-size:var(--text-md);line-height:1.6}.search-tips{margin-top:var(--sp-4)}.search-tip-item{display:inline-block;font-family:var(--font-sans);font-size:var(--text-sm);color:var(--text-muted);background:var(--bg-elevated);padding:var(--sp-2) var(--sp-4);border-radius:var(--radius-full)}.search-result-group{padding:var(--sp-1) 0}.search-group-header{display:flex;align-items:center;gap:var(--sp-2);padding:var(--sp-2) var(--sp-5);position:sticky;top:0;background:var(--bg-surface);z-index:1}.search-group-badge{font-family:var(--font-sans);font-size:var(--text-xs);font-weight:800;width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm)}.badge-part1{background:#5c7cfa26;color:var(--navy-400)}.badge-part2{background:#10b98126;color:var(--emerald-400)}.search-group-title{font-family:var(--font-sans);font-size:var(--text-sm);font-weight:600;color:var(--text-heading);flex:1}.search-group-part{font-family:var(--font-sans);font-size:var(--text-xs);color:var(--text-muted)}.search-result-item{display:block;padding:var(--sp-3) var(--sp-5) var(--sp-3) calc(var(--sp-5) + 36px);cursor:pointer;text-decoration:none;border-left:3px solid transparent;transition:all var(--transition-fast)}.search-result-item:hover,.search-result-item.selected{background:#f59e0b0f;border-left-color:var(--amber-500)}.search-result-heading{font-family:var(--font-sans);font-size:var(--text-sm);font-weight:600;color:var(--text-heading);margin-bottom:2px;line-height:1.4}.search-result-snippet{font-family:var(--font-serif);font-size:var(--text-sm);color:var(--text-secondary);line-height:1.6;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.search-highlight{background:#f59e0b40;color:var(--amber-300);border-radius:2px;padding:0 2px}mark.search-hit{background:#f59e0b52;color:var(--amber-300);border-radius:3px;padding:0 3px;font-weight:700;box-shadow:0 0 0 1px #f59e0b66}.content-section.search-target-flash{animation:search-flash 2.2s ease-out}@keyframes search-flash{0%{background:#f59e0b2e;box-shadow:0 0 0 4px #f59e0b2e}to{background:transparent;box-shadow:0 0 0 0 transparent}}.search-footer{display:flex;align-items:center;justify-content:space-between;padding:var(--sp-3) var(--sp-5);border-top:1px solid var(--border-subtle);background:var(--bg-elevated)}.search-footer-hint{font-family:var(--font-sans);font-size:var(--text-xs);color:var(--text-muted)}.search-footer-hint kbd{font-family:var(--font-sans);font-size:10px;background:var(--bg-card);color:var(--text-secondary);padding:1px 6px;border-radius:3px;border:1px solid var(--border-default)}.search-footer-count{font-family:var(--font-sans);font-size:var(--text-xs);color:var(--amber-400);font-weight:600}@media(max-width:768px){.search-overlay{padding-top:var(--sp-4)}.search-dialog{max-height:90vh;border-radius:var(--radius-lg)}.search-result-item{padding-left:var(--sp-5)}}@media print{.search-overlay{display:none}}.print-modal{max-width:640px}.print-modal-desc{font-family:var(--font-sans);font-size:var(--text-sm);color:var(--text-secondary);margin-bottom:var(--sp-5);line-height:1.6}.print-mode-cards{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-4);margin-bottom:var(--sp-5)}.print-mode-card{display:flex;flex-direction:column;align-items:flex-start;gap:var(--sp-3);padding:var(--sp-5);background:var(--bg-surface);border:2px solid var(--border-subtle);border-radius:var(--radius-lg);text-align:left;cursor:pointer;transition:all var(--transition-fast)}.print-mode-card:hover{border-color:var(--amber-500);background:#f59e0b0d;transform:translateY(-2px);box-shadow:var(--shadow-md)}.print-mode-icon{font-size:2rem}.print-mode-info h4{font-family:var(--font-sans);font-size:var(--text-md);font-weight:700;color:var(--text-heading);margin-bottom:2px}.print-mode-info>.text-muted{font-family:var(--font-sans);font-size:var(--text-xs);display:block;margin-bottom:var(--sp-3)}.print-mode-features{list-style:none;padding:0;margin:0}.print-mode-features li{font-family:var(--font-sans);font-size:var(--text-xs);color:var(--text-secondary);line-height:1.8}.print-mode-features strong{color:var(--amber-400)}.print-options{padding:var(--sp-3) var(--sp-4);background:var(--bg-elevated);border-radius:var(--radius-md)}.print-option-check{display:flex;align-items:center;gap:var(--sp-3);font-family:var(--font-sans);font-size:var(--text-sm);color:var(--text-secondary);cursor:pointer}.print-option-check input[type=checkbox]{accent-color:var(--amber-500);width:16px;height:16px}.btn-close-modal{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);color:var(--text-muted);font-size:var(--text-lg);transition:all var(--transition-fast)}.btn-close-modal:hover{color:var(--text-primary);background:var(--bg-elevated)}@media(max-width:640px){.print-mode-cards{grid-template-columns:1fr}}.module-print-actions{display:flex;justify-content:flex-end;margin:var(--sp-2) 0 var(--sp-4)}@media print{.module-print-actions{display:none!important}*{-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important}body{background:#fff!important;color:#1a1a2e!important;font-size:10.5pt!important;line-height:1.6!important}.sidebar,.topbar,.mobile-menu-toggle,.sidebar-overlay,.exercise-footer,.toast-container,.module-nav-btns,.btn-search,.search-overlay,#print-modal,.loading-screen,.diagram-zoom-btn{display:none!important}.main-content{margin-left:0!important;width:100%!important}.content-area{max-width:100%!important;padding:0!important}#app{display:block!important}h1,h2,h3,h4,h5,h6{color:#1a1a2e!important;break-after:avoid;font-family:Inter,-apple-system,sans-serif!important}h1{font-size:18pt!important;margin-bottom:6pt!important}h2{font-size:14pt!important;margin-top:16pt!important;margin-bottom:6pt!important;border-bottom:1.5pt solid #333!important;padding-bottom:4pt!important}h3{font-size:12pt!important}p,li,span,.quiz-label,.checklist-text{color:#1a1a2e!important;font-size:10.5pt!important}a{color:#1a1a2e!important;text-decoration:none!important}.module-hero{border-bottom:2.5pt solid #1a1a2e!important;padding-bottom:12pt!important;margin-bottom:16pt!important;background:none!important;animation:none!important}.module-hero .subtitle{color:#555!important;font-style:italic!important}.module-badge{background:#eee!important;color:#333!important;border:1pt solid #ccc!important}.content-section{break-inside:avoid;margin-bottom:12pt!important;animation:none!important;padding:0!important;border:none!important;background:none!important}.bilingual{display:grid!important;grid-template-columns:1fr 1fr!important;gap:12pt!important;margin:8pt 0!important}.bilingual .lang-en{border-left:2pt solid #1a1a2e!important;padding-left:10pt!important}.bilingual .lang-vn{border-left:2pt solid #999!important;padding-left:10pt!important}body[data-lang=both] .lang-vn,body[data-lang=both] .lang-vn .text-muted,body[data-lang=both] .lang-vn .lang-bil-sep{color:#000!important}.key-points{border:1pt solid #ccc!important;border-radius:4pt!important;padding:10pt 14pt!important;background:#f9f9f9!important;break-inside:avoid;margin:10pt 0!important}.key-points-title{font-weight:700!important;font-size:10pt!important;color:#333!important;margin-bottom:6pt!important}.content-table{border-collapse:collapse!important;width:100%!important;margin:8pt 0!important;font-size:9.5pt!important}.content-table th{background:#e8e8e8!important;color:#1a1a2e!important;font-weight:700!important;padding:6pt 8pt!important;border:1pt solid #bbb!important;text-align:left!important}.content-table td{padding:5pt 8pt!important;border:1pt solid #ccc!important}.card{border:1pt solid #ddd!important;box-shadow:none!important;background:#fff!important;break-inside:avoid;-webkit-backdrop-filter:none!important;backdrop-filter:none!important}.diagram-container{break-inside:avoid;border:1pt solid #ddd!important;border-radius:4pt!important;padding:8pt!important;background:#fff!important;margin:10pt 0!important}.diagram-header{color:#333!important;background:none!important}.diagram-caption{color:#666!important;font-size:9pt!important}.diagram-zoom-overlay,.print-hide-diagrams .diagram-container{display:none!important}.exercise-container{border:1.5pt solid #333!important;border-radius:6pt!important;break-inside:avoid;background:#fff!important;margin:14pt 0!important;page-break-inside:avoid}.exercise-header{background:#f0f0f0!important;border-bottom:1pt solid #ccc!important;padding:8pt 12pt!important}.exercise-type-icon{background:#e0e0e0!important}.exercise-title{color:#1a1a2e!important;font-size:11pt!important}.exercise-body{padding:12pt 14pt!important}.quiz-option{border:1pt solid #ccc!important;background:#fff!important;padding:6pt 10pt!important;margin-bottom:4pt!important;border-radius:4pt!important}.quiz-radio{border:1.5pt solid #999!important;width:14pt!important;height:14pt!important}.quiz-radio:after{display:none!important}.quiz-feedback,.exercise-score{display:none!important}.print-worksheet .quiz-option{background:#fff!important;border-color:#ccc!important}.print-worksheet .quiz-option.selected,.print-worksheet .quiz-option.correct,.print-worksheet .quiz-option.incorrect{border-color:#ccc!important;background:#fff!important}.print-worksheet .quiz-radio{border-color:#999!important;background:#fff!important}.print-worksheet .quiz-option.correct .quiz-radio{background:#fff!important;border-color:#999!important}.print-worksheet .input,.print-worksheet textarea.input{border:none!important;border-bottom:1pt solid #999!important;border-radius:0!important;background:transparent!important;color:transparent!important;min-height:40pt!important;padding:4pt 0!important;box-shadow:none!important}.print-worksheet textarea.input{min-height:60pt!important;background:repeating-linear-gradient(transparent,transparent 18pt,#ccc 18pt,#ccc 18.5pt)!important}.print-worksheet .print-blank-field{min-height:50pt!important}.print-worksheet .checklist-checkbox{border:1.5pt solid #333!important;background:#fff!important;width:12pt!important;height:12pt!important}.print-worksheet .checklist-checkbox:after{display:none!important}.print-worksheet .module-hero:after{content:"📋 WORKSHEET / BÀI TẬP";display:block;font-size:9pt;font-weight:700;color:#888;letter-spacing:.1em;margin-top:6pt;border:1pt dashed #bbb;padding:3pt 8pt;display:inline-block;border-radius:3pt}.print-worksheet .simulator-steps .input{border-bottom:1pt solid #999!important;min-height:36pt!important;background:transparent!important;color:transparent!important}.print-answer-key .quiz-option[data-correct=true],.print-answer-key .quiz-option.print-correct-answer{border-left:3pt solid #059669!important;background:#ecfdf5!important}.print-answer-key .quiz-option[data-correct=true] .quiz-radio,.print-answer-key .quiz-option.print-correct-answer .quiz-radio{border-color:#059669!important;background:#059669!important;position:relative}.print-answer-key .quiz-option[data-correct=true] .quiz-radio:after,.print-answer-key .quiz-option.print-correct-answer .quiz-radio:after{content:"✓"!important;display:flex!important;align-items:center;justify-content:center;color:#fff!important;font-size:8pt!important;font-weight:700!important}.print-answer-key .quiz-option:not([data-correct=true]){opacity:.5}.print-answer-key .input,.print-answer-key textarea.input{border:1pt solid #ccc!important;border-radius:3pt!important;background:#fafafa!important;color:#1a1a2e!important;min-height:auto!important;padding:4pt 8pt!important}.print-answer-key .checklist-checkbox.checked{background:#059669!important;border-color:#059669!important}.print-answer-key .checklist-checkbox.checked:after{content:"✓"!important;display:flex!important;color:#fff!important;font-size:8pt!important;font-weight:700!important}.print-answer-key .module-hero:after{content:"✅ ANSWER KEY / ĐÁP ÁN";display:block;font-size:9pt;font-weight:700;color:#059669;letter-spacing:.1em;margin-top:6pt;border:1pt solid #059669;padding:3pt 8pt;display:inline-block;border-radius:3pt}@page{size:A4;margin:18mm 15mm}@page :first{margin-top:12mm}.page-break{break-before:page}.no-break{break-inside:avoid}.module-hero:before{content:"PMF Training Programme — Professional Master Facilitator";display:block;font-size:7.5pt;color:#aaa;margin-bottom:8pt;letter-spacing:.03em}}.hidden{display:none!important}.sidebar-classroom{padding:.75rem 1rem;border-top:1px solid var(--border-color, rgba(255,255,255,.06))}.classroom-link{display:flex;align-items:center;gap:.625rem;padding:.625rem .875rem;background:linear-gradient(135deg,#fbbf241a,#fbbf240d);border:1px solid rgba(251,191,36,.3);border-radius:8px;color:var(--amber-400, #fbbf24);text-decoration:none;font-weight:600;font-size:.875rem;transition:background .15s,transform .15s}.classroom-link:hover{background:linear-gradient(135deg,#fbbf2433,#fbbf241a);transform:translateY(-1px)}.classroom-icon{font-size:1.125rem}.auth-wrap{display:flex;align-items:center;justify-content:center;min-height:60vh;padding:2rem 1rem}.auth-card{width:100%;max-width:420px;background:var(--bg-elev, #1a1a2e);border:1px solid var(--border-color, rgba(255,255,255,.08));border-radius:12px;padding:2rem;box-shadow:0 20px 60px #0006}.auth-tabs{display:flex;gap:0;border-bottom:1px solid var(--border-color, rgba(255,255,255,.08));margin-bottom:1.5rem}.auth-tab{flex:1;background:transparent;border:0;padding:.75rem 1rem;color:var(--text-muted, #94a3b8);cursor:pointer;font:inherit;border-bottom:2px solid transparent}.auth-tab.active{color:var(--text, #fff);border-bottom-color:var(--amber-400, #fbbf24)}.auth-form{display:flex;flex-direction:column;gap:.875rem}.auth-form label{display:flex;flex-direction:column;gap:.375rem;font-size:.875rem;color:var(--text-muted, #94a3b8)}.auth-form input[type=text],.auth-form input[type=email],.auth-form input[type=password]{background:var(--bg-base, #0f0f23);color:var(--text, #fff);border:1px solid var(--border-color, rgba(255,255,255,.12));border-radius:8px;padding:.625rem .75rem;font:inherit}.auth-form input:focus{outline:none;border-color:var(--amber-400, #fbbf24)}.auth-role{display:flex;gap:1rem;border:0;padding:0;margin:0}.auth-role label{flex-direction:row;align-items:center;gap:.375rem;color:var(--text, #fff)}.auth-error{color:#f87171;font-size:.875rem;min-height:1.2em}.dash-wrap{padding:1rem 0}.dash-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem}.dash-sessions{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}.dash-session-card-wrap{position:relative}.dash-session-card{display:block;background:var(--bg-elev, #1a1a2e);border:1px solid var(--border-color, rgba(255,255,255,.08));border-radius:10px;padding:1rem;text-decoration:none;color:inherit;transition:transform .15s ease,border-color .15s ease}.dash-session-card:hover{transform:translateY(-2px);border-color:var(--amber-400, #fbbf24)}.dash-session-card-disabled{opacity:.6;cursor:default}.dash-session-delete{position:absolute;top:.5rem;right:.5rem;width:28px;height:28px;background:#f8717126;color:#f87171;border:1px solid rgba(248,113,113,.35);border-radius:6px;font-size:.875rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,transform .15s;z-index:2}.dash-session-delete:hover{background:#f871714d;transform:scale(1.05)}.dash-session-delete:disabled{cursor:wait;opacity:.6}.dash-session-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem;padding-right:2.25rem}.dash-session-code{font-family:monospace;font-size:1.25rem;letter-spacing:.15em;color:var(--amber-400, #fbbf24)}.badge{padding:.25rem .625rem;border-radius:999px;font-size:.75rem;font-weight:600}.badge-default{background:#94a3b826;color:#94a3b8}.badge-live{background:#10b98133;color:#10b981;animation:pulse 2s infinite}.badge-ended{background:#f8717126;color:#f87171}.modal-card{background:var(--bg-elev, #1a1a2e);border-radius:12px;padding:2rem;width:100%;max-width:480px;border:1px solid var(--border-color, rgba(255,255,255,.08));margin:1rem}.modal-actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:1.5rem}.classroom-page{padding-bottom:6rem}.instructor-section{border:2px solid transparent;border-radius:12px;margin:.5rem 0;padding:.5rem;position:relative;transition:border-color .3s,background .3s}.instructor-section.current{border-color:var(--amber-400, #fbbf24);background:#fbbf240d}.section-marker{position:absolute;top:-.75rem;left:1rem;background:var(--bg-base, #0f0f23);padding:.125rem .625rem;font-size:.75rem;color:var(--text-muted, #94a3b8);border-radius:4px}.instructor-section.current .section-marker{color:var(--amber-400, #fbbf24);font-weight:600}.instructor-bar{position:fixed;left:0;right:0;bottom:0;background:var(--bg-elev, #1a1a2e);border-top:1px solid var(--border-color, rgba(255,255,255,.12));padding:.875rem 1.25rem;display:flex;align-items:center;justify-content:space-between;z-index:100;flex-wrap:wrap;gap:.75rem}.ibar-left,.ibar-right{display:flex;align-items:center;gap:.875rem}.ibar-code{font-size:.875rem}.ibar-code strong{color:var(--amber-400, #fbbf24);font-family:monospace;letter-spacing:.1em}.ibar-counter{color:var(--text-muted, #94a3b8);font-size:.875rem}.ibar-online{font-size:.875rem;color:var(--text-muted, #94a3b8)}.join-slide-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172af2;z-index:1000;display:flex;align-items:center;justify-content:center;padding:2rem}.join-slide-close{position:absolute;top:1.25rem;right:1.25rem;background:transparent;border:none;color:#fff;font-size:1.75rem;cursor:pointer;line-height:1;padding:.5rem .75rem;border-radius:8px}.join-slide-close:hover{background:#ffffff1a}.join-slide-card{background:#fff;color:#0f172a;border-radius:16px;padding:3rem;max-width:1100px;width:100%;box-shadow:0 24px 60px #00000080}.join-slide-title{margin:0 0 2rem;font-size:2.25rem;font-weight:700;text-align:center}.join-slide-grid{display:grid;grid-template-columns:1fr auto;gap:3rem;align-items:center}@media(max-width:720px){.join-slide-grid{grid-template-columns:1fr}}.join-slide-step{margin-bottom:1.5rem}.join-slide-label{display:block;font-size:.875rem;color:#64748b;margin-bottom:.25rem}.join-slide-url{display:block;font-size:1.5rem;font-weight:600;font-family:ui-monospace,Menlo,monospace}.join-slide-code{display:block;font-size:3rem;font-weight:800;font-family:ui-monospace,Menlo,monospace;letter-spacing:.15em;color:#f59e0b}.join-slide-qr{display:flex;flex-direction:column;align-items:center;gap:.5rem}.join-slide-qr canvas{border-radius:8px}.join-slide-qr-label{font-size:.875rem;color:#64748b}.btn-danger{background:#f8717133;color:#f87171;border:1px solid rgba(248,113,113,.4)}.btn-danger:hover{background:#f871714d}.results-panel{position:fixed;top:80px;right:1rem;bottom:80px;width:340px;background:var(--bg-elev, #1a1a2e);border:1px solid var(--border-color, rgba(255,255,255,.12));border-radius:12px;padding:1rem;overflow-y:auto;z-index:90;display:flex;flex-direction:column;gap:.75rem;transition:transform .25s ease,box-shadow .25s ease}.results-panel.collapsed{transform:translate(calc(100% - 60px));cursor:pointer}.results-panel.collapsed:hover{box-shadow:-2px 0 12px #fbbf244d}.results-panel.flash{box-shadow:0 0 0 3px var(--amber-400, #fbbf24)}.results-header{display:flex;justify-content:space-between;align-items:center;font-size:.875rem;position:sticky;top:0;background:var(--bg-elev, #1a1a2e)}.results-header h3{margin:0;font-size:1rem}.results-open-fullpage{display:flex;align-items:center;justify-content:center;gap:.375rem;padding:.625rem .875rem;margin-bottom:.75rem;background:linear-gradient(135deg,#fbbf2433,#fbbf2414);border:1px solid rgba(251,191,36,.4);border-radius:8px;color:var(--amber-400, #fbbf24);text-decoration:none;font-weight:600;font-size:.8125rem;text-align:center;transition:background .15s,transform .15s}.results-open-fullpage:hover{background:linear-gradient(135deg,#fbbf244d,#fbbf2426);transform:translateY(-1px)}.results-open-arrow{font-size:.875rem}.results-toggle{background:transparent;border:1px solid var(--border-color, rgba(255,255,255,.2));color:var(--text, #fff);border-radius:4px;width:28px;height:28px;cursor:pointer;font-size:1rem}.results-body{font-size:.875rem}.ex-block{padding:.5rem 0;border-bottom:1px solid var(--border-color, rgba(255,255,255,.06))}.ex-block-header{margin-bottom:.5rem;font-size:.875rem}.quiz-aggr{display:flex;flex-direction:column;gap:.25rem}.quiz-aggr-row{display:flex;align-items:center;gap:.5rem;font-size:.8125rem}.quiz-aggr-label{width:2.5em;color:var(--text-muted, #94a3b8)}.quiz-aggr-bar{flex:1;height:8px;background:#94a3b826;border-radius:4px;overflow:hidden}.quiz-aggr-fill{height:100%;background:var(--amber-400, #fbbf24);transition:width .4s ease}.quiz-aggr-count{width:3.5em;text-align:right;color:var(--text-muted, #94a3b8);font-size:.75rem}.submissions-list{padding:0;margin:0;list-style:none;max-height:200px;overflow-y:auto}.submissions-list li{padding:.25rem 0;border-bottom:1px dashed rgba(255,255,255,.05);font-size:.8125rem}@media(max-width:1100px){.results-panel{top:auto;left:1rem;right:1rem;bottom:80px;width:auto;max-height:40vh}.results-panel.collapsed{transform:translateY(calc(100% - 50px))}}.student-page{padding-bottom:4rem}.student-section{animation:fadeInUp .6s ease-out}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.student-status .waiting{text-align:center;padding:3rem 2rem;margin:1.5rem 0}.student-status .waiting h2{margin-bottom:.5rem}.student-bar{position:fixed;left:0;right:0;bottom:0;background:var(--bg-elev, #1a1a2e);border-top:1px solid var(--border-color, rgba(255,255,255,.12));padding:.625rem 1.25rem;display:flex;align-items:center;gap:.875rem;font-size:.875rem}.student-bar strong{color:var(--amber-400, #fbbf24)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.nav-item-locked{opacity:.55}.nav-item-locked .nav-item-title{color:var(--text-muted, #94a3b8)}.nav-item-lock{margin-left:auto;padding-left:.4rem;font-size:.85rem;flex-shrink:0}.assignments-page{padding:1rem 0}.assignments-toolbar{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1rem;flex-wrap:wrap}.assignments-toolbar .text-muted{font-size:.875rem}.assignments-toggle{display:inline-flex;align-items:center;gap:.4rem;font-size:.875rem;cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap}.assignments-toggle input{width:16px;height:16px;accent-color:var(--amber-400, #fbbf24)}.assignments-table-wrap{overflow-x:auto;border:1px solid var(--border-color, rgba(255,255,255,.08));border-radius:10px;background:var(--bg-elev, #1a1a2e);background-image:linear-gradient(to right,transparent calc(100% - 36px),rgba(15,23,42,.55) 100%);background-attachment:local;-webkit-overflow-scrolling:touch}.assignments-table{border-collapse:collapse;min-width:100%;font-size:.875rem}.assignments-table th,.assignments-table td{padding:.55rem;border-bottom:1px solid var(--border-color, rgba(255,255,255,.06));text-align:center;white-space:nowrap}.assignments-table th[data-col-key],.assignments-table td[data-col-key]{min-width:40px;width:40px;padding:.55rem .25rem}.assignments-table th.col-student,.assignments-table td.col-student{text-align:left;position:sticky;left:0;background:var(--bg-elev, #1a1a2e);z-index:1;min-width:200px}.assignments-table th.col-action,.assignments-table td.col-action{position:sticky;right:0;background:var(--bg-elev, #1a1a2e);z-index:1;min-width:96px}.assignments-table td.cell-always-open{background:#f59e0b14;position:relative}.assignments-table td.cell-always-open input[type=checkbox]{cursor:not-allowed;accent-color:var(--amber-500);opacity:.7}.assignments-table td.cell-always-open:after{content:"🔓";position:absolute;top:2px;right:4px;font-size:9px;opacity:.6;pointer-events:none}.assignments-table thead th{background:#ffffff0a;font-weight:600;color:var(--text-secondary, #cbd5e1);font-size:.75rem;letter-spacing:.05em;text-transform:uppercase}.assignments-table th.col-action{text-transform:none;letter-spacing:0;font-weight:500;color:var(--amber-400, #fbbf24)}.assignments-table tbody tr:hover{background:#fbbf240a}.assignments-table .student-name{font-weight:500}.assignments-table .student-email{color:var(--text-muted, #94a3b8);font-size:.75rem}.assignments-table .student-expiry{font-size:.7rem;color:var(--text-muted, #94a3b8);margin-top:.15rem}.assignments-table input[type=checkbox]{width:18px;height:18px;accent-color:var(--amber-400, #fbbf24);cursor:pointer}.assignments-table .btn-row{font-size:.75rem;padding:.25rem .5rem}.assignments-row-status{font-size:.75rem;margin-left:.5rem}.assignments-row-status.saving{color:var(--amber-400, #fbbf24)}.assignments-row-status.ok{color:#10b981}.assignments-row-status.error{color:#f87171}.assignments-empty{padding:2.5rem 1rem;text-align:center;color:var(--text-muted, #94a3b8)}.assignments-scroll-hint{display:none;font-size:.75rem;color:var(--text-muted, #94a3b8);margin:0 0 .4rem;text-align:right}.assignments-scroll-hint:before{content:"↔ ";opacity:.7}@media(max-width:900px){.assignments-scroll-hint{display:block}.assignments-table th,.assignments-table td{padding:.4rem .3rem}.assignments-table th[data-col-key],.assignments-table td[data-col-key]{min-width:36px;width:36px}.assignments-table th.col-student,.assignments-table td.col-student{min-width:160px}.assignments-table th.col-action,.assignments-table td.col-action{min-width:70px}.assignments-table .btn-row{padding:.2rem .35rem;font-size:.7rem}.assignments-table input[type=checkbox]{width:16px;height:16px}}.coinst-list{list-style:none;padding:0;display:grid;gap:var(--sp-2)}.coinst-row{display:grid;grid-template-columns:1fr 1fr auto auto;align-items:center;gap:var(--sp-3);padding:8px 12px;background:#ffffff08;border:1px solid var(--border-subtle);border-radius:var(--radius-sm);font-size:var(--text-sm)}.coinst-name{font-weight:600}.coinst-email{font-size:.78rem}@media(max-width:720px){.coinst-row{grid-template-columns:1fr}}.replay-page{max-width:980px;margin:0 auto;padding:var(--sp-4)}.replay-section{margin-bottom:var(--sp-4);padding:var(--sp-3);background:#ffffff05;border-radius:var(--radius-md);pointer-events:none}.replay-section .exercise-footer{display:none}.replay-content,.replay-results,.replay-leaderboard,.replay-qa{margin-top:var(--sp-6)}.replay-content h2,.replay-results h2{margin-top:0;margin-bottom:var(--sp-3)}.replay-ex{margin-bottom:var(--sp-4)}.replay-mine{margin-top:var(--sp-2);padding:var(--sp-3);background:#f59e0b0f;border-left:3px solid var(--amber-500);border-radius:var(--radius-sm)}.replay-mine-empty{background:#ffffff08;border-left-color:var(--border-subtle);color:var(--text-muted)}.replay-myq{margin-top:var(--sp-2);padding:6px 10px;background:#ffffff08;border-radius:var(--radius-sm)}.replay-score-line{font-size:1.05rem;margin-bottom:var(--sp-2)}.replay-leaderboard{padding:var(--sp-4)}.replay-myrank{color:var(--amber-300);margin-bottom:var(--sp-2)}.replay-board{list-style:none;padding:0;display:grid;gap:4px}.replay-board li{display:grid;grid-template-columns:60px 1fr auto;padding:4px 12px;background:#ffffff08;border-radius:var(--radius-sm)}.replay-board li.is-me{background:#f59e0b1a;font-weight:700}.replay-rank{color:var(--text-muted)}.replay-name{color:var(--text-primary)}.replay-score{color:var(--amber-300);font-variant-numeric:tabular-nums}.replay-qa{padding:var(--sp-4)}.replay-qa-list{list-style:none;padding:0;display:grid;gap:var(--sp-3)}.replay-qa-item{padding:var(--sp-3);background:#ffffff08;border-radius:var(--radius-md)}.replay-qa-head{display:flex;align-items:center;gap:var(--sp-2);margin-bottom:4px;flex-wrap:wrap}.replay-qa-text{margin:4px 0;white-space:pre-wrap}.replay-qa-replies{list-style:none;margin:var(--sp-2) 0 0;padding-left:var(--sp-4);border-left:2px solid var(--border-subtle);display:grid;gap:var(--sp-2)}.replay-qa-replies p{margin:2px 0 0}.dash-session-replay{display:inline-block;margin-top:4px;padding:4px 10px;font-size:.75rem;color:var(--text-muted);background:#ffffff0a;border:1px solid var(--border-subtle);border-radius:var(--radius-sm);text-decoration:none}.dash-session-replay:hover{color:var(--text-primary);background:#ffffff14}.bk-toolbar{display:flex;align-items:center;gap:var(--sp-2);flex-wrap:wrap;margin-bottom:var(--sp-3)}.bk-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:var(--sp-3)}.bk-banner{margin-top:var(--sp-4)}.bk-banner .bk-card{border-color:#f59e0b66;background:#f59e0b0f}.bk-card{padding:var(--sp-3);background:#ffffff08;border:1px solid var(--border-subtle);border-radius:var(--radius-md);display:grid;gap:var(--sp-2)}.bk-card-head{display:flex;justify-content:space-between;align-items:center}.bk-members{list-style:none;padding:0;margin:0;display:grid;gap:2px;font-size:var(--text-sm);color:var(--text-secondary)}.bk-notes-label{display:grid;gap:4px}.bk-notes{font-size:var(--text-sm);resize:vertical;min-height:80px}.bk-notes-meta{font-size:.7rem}.bk-toolbar-field{display:inline-flex;align-items:center;gap:6px;font-size:.85rem}.bk-toolbar-field input,.bk-toolbar-field select{display:inline-block;margin:0}.bk-toolbar-field input[type=number]{width:64px}.bk-toolbar-field select{min-width:180px}.bk-summary{font-size:.85rem}.bk-unassigned{margin-bottom:var(--sp-3);padding:var(--sp-2) var(--sp-3);background:#f59e0b0f;border:1px solid rgba(245,158,11,.3);border-radius:var(--radius-md)}.bk-unassigned-list{list-style:none;padding:0;margin:var(--sp-2) 0 0;display:grid;gap:6px}.bk-unassigned-list li{display:flex;align-items:center;justify-content:space-between;gap:var(--sp-2);font-size:.88rem}.bk-unassigned-list select{min-width:180px}.bk-member-row{display:flex;align-items:center;justify-content:space-between;gap:var(--sp-2)}.bk-reassign-select{font-size:.75rem;padding:2px 4px;max-width:130px}.bk-chat-privacy{font-size:.72rem;margin:0}.bk-chat{display:grid;gap:6px;padding:var(--sp-2);background:#ffffff0a;border:1px solid var(--border-subtle);border-radius:var(--radius-md)}.bk-chat-head{display:flex;align-items:center;justify-content:space-between;font-size:.82rem;font-weight:600;gap:var(--sp-2)}.bk-chat-head .bk-chat-privacy{font-weight:400;color:var(--text-secondary)}.bk-chat-log{max-height:240px;min-height:80px;overflow-y:auto;display:grid;gap:6px;padding-right:4px}.bk-chat-empty{margin:0;font-size:.82rem;text-align:center;padding:var(--sp-3) 0}.bk-chat-msg{background:#ffffff0d;border-radius:var(--radius-sm);padding:6px 8px}.bk-chat-msg-head{display:flex;align-items:baseline;justify-content:space-between;gap:8px;margin-bottom:2px}.bk-chat-sender{font-size:.78rem;color:var(--amber-400, #fbbf24)}.bk-chat-time{font-size:.7rem}.bk-chat-msg-body{font-size:.88rem;white-space:pre-wrap;word-break:break-word}.bk-chat-form{display:flex;gap:var(--sp-2)}.bk-chat-form .bk-chat-input{flex:1}.bk-countdown{display:inline-flex;align-items:center;gap:4px;font-variant-numeric:tabular-nums;font-weight:600;font-size:.85rem;padding:2px 8px;border-radius:var(--radius-pill, 999px);background:#f59e0b26;color:var(--amber-400, #fbbf24);border:1px solid rgba(245,158,11,.4)}.bk-countdown-instructor{margin-left:auto}body.bk-overlay-open{overflow:hidden}.bk-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:radial-gradient(circle at top,#f59e0b1f,#0f172af5 70%);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);display:flex;align-items:stretch;justify-content:center;padding:var(--sp-3);animation:bk-overlay-in .18s ease-out}@keyframes bk-overlay-in{0%{opacity:0;transform:scale(.98)}to{opacity:1;transform:scale(1)}}.bk-overlay-frame{width:100%;max-width:720px;display:grid;grid-template-rows:auto 1fr;gap:var(--sp-3);align-self:center;max-height:95vh}.bk-overlay-head{display:flex;align-items:center;gap:var(--sp-2);padding:var(--sp-2) var(--sp-3);background:#ffffff0f;border:1px solid var(--border-subtle);border-radius:var(--radius-md)}.bk-overlay-title{display:flex;align-items:center;gap:var(--sp-2);flex:1;min-width:0;font-size:1.05rem}.bk-overlay-title strong{font-size:1.15rem}.bk-overlay-sub{font-size:.78rem;margin-left:var(--sp-2)}.bk-overlay-actions{display:flex;align-items:center;gap:var(--sp-2)}.bk-overlay-body{overflow-y:auto;padding-right:2px}.bk-overlay-body .bk-card{background:#ffffff0d;border-color:#f59e0b4d}.bk-overlay-body .bk-chat-log{max-height:42vh}.bk-rejoin-pill{position:fixed;bottom:16px;right:16px;z-index:999;display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border-radius:var(--radius-pill, 999px);background:var(--amber-500, #f59e0b);color:#1f1300;font-weight:600;font-size:.88rem;border:none;cursor:pointer;box-shadow:0 6px 20px #f59e0b66;font-variant-numeric:tabular-nums}.bk-rejoin-pill:hover{background:var(--amber-400, #fbbf24)}.bk-rejoin-pill [data-countdown]{background:#0003;border-radius:var(--radius-pill, 999px);padding:1px 8px}@media(max-width:480px){.bk-overlay{padding:0}.bk-overlay-frame{max-height:100vh;border-radius:0;padding:var(--sp-2)}.bk-overlay-head{flex-wrap:wrap}.bk-overlay-actions{width:100%;justify-content:space-between}}.bk-files{display:grid;gap:6px;padding:var(--sp-2);background:#ffffff0a;border:1px solid var(--border-subtle);border-radius:var(--radius-md)}.bk-files-head{display:flex;align-items:baseline;justify-content:space-between;gap:var(--sp-2);font-size:.82rem;font-weight:600}.bk-files-hint{font-weight:400;font-size:.7rem}.bk-files-empty{margin:0;font-size:.82rem;padding:8px 0;text-align:center}.bk-files-list{list-style:none;padding:0;margin:0;display:grid;gap:4px}.bk-file-item{display:flex;align-items:center;gap:6px;background:#ffffff0d;border-radius:var(--radius-sm);padding:4px 8px}.bk-file-open{flex:1;display:flex;align-items:center;gap:8px;background:transparent;border:none;cursor:pointer;color:var(--text-primary);padding:4px 0;text-align:left;min-width:0}.bk-file-open:hover .bk-file-name{text-decoration:underline}.bk-file-icon{font-size:1.2rem;flex-shrink:0}.bk-file-meta{display:grid;gap:1px;min-width:0}.bk-file-name{font-size:.86rem;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.bk-file-del{background:transparent;border:none;color:var(--rose-400, #fb7185);cursor:pointer;font-size:.85rem;padding:2px 6px;border-radius:var(--radius-sm)}.bk-file-del:hover{background:#f43f5e26}.bk-files-add{width:max-content;cursor:pointer}.bk-files-status{font-size:.74rem;min-height:1em}body.bk-viewer-open{overflow:hidden}.bk-viewer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1100;background:#0f172ad9;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:stretch;justify-content:center;padding:var(--sp-3);animation:bk-overlay-in .18s ease-out}.bk-viewer-frame{width:100%;max-width:1000px;align-self:center;display:grid;grid-template-rows:auto 1fr;gap:var(--sp-2);max-height:95vh;background:var(--bg-elev-1, #111827);border:1px solid var(--border-subtle);border-radius:var(--radius-lg, 12px);padding:var(--sp-3)}.bk-viewer-head{display:flex;align-items:center;gap:var(--sp-2);border-bottom:1px solid var(--border-subtle);padding-bottom:var(--sp-2)}.bk-viewer-title{display:flex;align-items:center;gap:8px;flex:1;min-width:0}.bk-viewer-title strong{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.bk-viewer-body{overflow:auto;padding:4px}.bk-viewer-loading,.bk-viewer-error,.bk-viewer-note{text-align:center;padding:1.5rem;font-size:.9rem}.bk-viewer-error{color:var(--rose-400, #fb7185)}.bk-viewer-pdf-host{width:100%;min-height:80vh;background:#1f2937;border-radius:var(--radius-md);overflow:hidden}.bk-viewer-pdf-host .pdfjs-pages{max-height:80vh;overflow-y:auto}.bk-viewer-txt{white-space:pre-wrap;word-break:break-word;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.85rem;background:#ffffff0a;padding:var(--sp-3);border-radius:var(--radius-md);margin:0}.bk-viewer-md,.bk-viewer-docx{font-size:.92rem;line-height:1.55;background:#fff;color:#0f172a;padding:var(--sp-4);border-radius:var(--radius-md);max-width:none}.bk-viewer-md *,.bk-viewer-docx *{color:#0f172a;background-color:transparent}.bk-viewer-md a,.bk-viewer-docx a{color:#1d4ed8;text-decoration:underline}.bk-viewer-md h1,.bk-viewer-md h2,.bk-viewer-md h3,.bk-viewer-docx h1,.bk-viewer-docx h2,.bk-viewer-docx h3{margin-top:1.2em;margin-bottom:.5em}.bk-viewer-md table,.bk-viewer-docx table{border-collapse:collapse;margin:.5em 0}.bk-viewer-md table td,.bk-viewer-md table th,.bk-viewer-docx table td,.bk-viewer-docx table th{border:1px solid #cbd5e1;padding:4px 8px}.bk-viewer-md table th,.bk-viewer-docx table th{background:#f1f5f9;font-weight:600}.bk-viewer-md code,.bk-viewer-docx code{background:#f1f5f9;padding:1px 4px;border-radius:3px;font-size:.85em}.bk-viewer-md pre,.bk-viewer-md pre code{background:#f1f5f9;padding:.6em;border-radius:6px;overflow-x:auto}.bk-viewer-md blockquote,.bk-viewer-docx blockquote{border-left:3px solid #cbd5e1;padding-left:.8em;margin-left:0;color:#475569}.bk-viewer-xlsx{background:#fff;color:#0f172a;padding:var(--sp-3);border-radius:var(--radius-md)}.bk-viewer-xlsx *{color:#0f172a}.bk-viewer-xlsx .bk-xlsx-tab{color:#475569}.bk-viewer-xlsx .bk-xlsx-tab.active{color:#0f172a}.bk-xlsx-tabs{display:flex;flex-wrap:wrap;gap:4px;border-bottom:1px solid #cbd5e1;margin-bottom:var(--sp-2)}.bk-xlsx-tab{background:transparent;border:none;border-bottom:2px solid transparent;padding:6px 10px;cursor:pointer;font-size:.85rem;color:#475569}.bk-xlsx-tab.active{color:#0f172a;border-bottom-color:var(--amber-500, #f59e0b);font-weight:600}.bk-xlsx-panel{display:none;overflow-x:auto}.bk-xlsx-panel.active{display:block}.bk-xlsx-panel table{border-collapse:collapse;font-size:.82rem}.bk-xlsx-panel td,.bk-xlsx-panel th{border:1px solid #e2e8f0;padding:3px 6px;white-space:nowrap}.bk-viewer-pptx{padding:var(--sp-2)}.bk-pptx-slides{list-style:none;padding:0;margin:0;display:grid;gap:var(--sp-3)}.bk-pptx-slide{background:#fff;color:#0f172a;border-radius:var(--radius-md);padding:var(--sp-3);box-shadow:0 1px 3px #0003}.bk-pptx-slide *{color:#0f172a}.bk-pptx-slide .text-muted{color:#64748b}.bk-pptx-slide strong.bk-pptx-slide-label{display:inline-block;background:var(--amber-500, #f59e0b);color:#1f1300;padding:2px 10px;border-radius:var(--radius-pill, 999px);font-size:.78rem;margin-bottom:8px}.bk-pptx-slide p{margin:4px 0;line-height:1.45;font-size:.92rem}.bk-pptx-images{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:8px;margin:10px 0 14px}.bk-pptx-images img{width:100%;height:auto;max-height:260px;object-fit:contain;background:#f8fafc;border:1px solid #e2e8f0;border-radius:var(--radius-sm);cursor:zoom-in}.bk-pptx-images img:hover{border-color:var(--amber-500, #f59e0b)}.bk-pptx-images img:only-child{max-height:420px;grid-column:1 / -1}.bk-viewer-pptx .bk-viewer-note{background:#f59e0b14;border:1px solid rgba(245,158,11,.3);border-radius:var(--radius-md);color:var(--text-primary);margin-bottom:var(--sp-3)}@media(max-width:480px){.bk-viewer-overlay{padding:0}.bk-viewer-frame{border-radius:0;max-height:100vh}.bk-viewer-pdf{height:76vh}}.r-page{padding:1rem 0 2rem;max-width:1200px;margin:0 auto}.r-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;flex-wrap:wrap;padding-bottom:1rem;border-bottom:1px solid var(--border-color, rgba(255,255,255,.08));margin-bottom:1.5rem}.r-header-info h1{margin:0 0 .25rem}.r-header-info p{margin:0}.r-code{font-family:ui-monospace,monospace;letter-spacing:.15em;color:var(--amber-400, #fbbf24);font-weight:700}.r-status{text-transform:uppercase;font-size:.75rem;font-weight:700;padding:.125rem .5rem;border-radius:999px}.r-status-live{background:#10b9812e;color:#10b981;animation:pulse 2s infinite}.r-status-ended{background:#f8717126;color:#f87171}.r-status-draft{background:#94a3b826;color:#94a3b8}.r-header-actions{display:flex;gap:.5rem;flex-wrap:wrap}.r-empty{text-align:center;padding:4rem 2rem;color:var(--text-muted, #94a3b8)}.r-empty h2{margin-bottom:.5rem}.r-grid{display:flex;flex-direction:column;gap:1.5rem}.r-ex-card{background:var(--bg-elev, #1a1a2e);border:1px solid var(--border-color, rgba(255,255,255,.08));border-radius:12px;overflow:hidden;transition:box-shadow .3s ease,transform .3s ease}.r-ex-card.r-flash{box-shadow:0 0 0 3px var(--amber-400, #fbbf24)}.r-ex-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border-color, rgba(255,255,255,.06));flex-wrap:wrap}.r-ex-header h2{margin:0;font-size:1.125rem;display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.r-ex-type{font-size:.6875rem;font-weight:600;padding:.125rem .5rem;border-radius:999px;background:#94a3b826;color:var(--text-muted, #94a3b8);text-transform:uppercase;letter-spacing:.05em}.r-ex-type.badge-amber{background:#fbbf242e;color:var(--amber-400, #fbbf24)}.r-ex-meta{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.r-ex-count{color:var(--text-muted, #94a3b8);font-size:.875rem}.btn-sm{padding:.375rem .75rem;font-size:.8125rem}.r-ex-body{padding:1.25rem 1.5rem}.r-q-block{margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border-color, rgba(255,255,255,.05))}.r-q-block:last-child{margin-bottom:0;padding-bottom:0;border-bottom:none}.r-q-text{margin:0 0 .75rem;font-weight:600;font-size:.9375rem;line-height:1.45}.r-q-num{display:inline-block;background:var(--amber-500, #f59e0b);color:#1a1a2e;border-radius:4px;padding:0 .4rem;margin-right:.5rem;font-size:.75rem;font-weight:700;letter-spacing:.05em}.r-q-acc{display:inline-block;margin-left:.5rem;padding:.1rem .5rem;border-radius:999px;background:#10b9811f;color:#10b981;font-size:.75rem;font-weight:600;vertical-align:middle}.r-q-acc-empty{background:transparent;color:var(--text-muted, #94a3b8);font-style:italic;font-weight:400}.r-pres-acc{margin:.5rem 0 1.25rem;font-size:1.125rem;color:#10b981;font-weight:600}.r-pres-join{position:absolute;top:64px;right:16px;width:min(240px,22vw);background:#fffffff2;color:#0f172a;border-radius:12px;padding:12px;z-index:6;display:flex;flex-direction:column;align-items:center;gap:8px;box-shadow:0 4px 16px #0000004d}.r-pres-join-qr{background:#fff;border-radius:8px;padding:6px;line-height:0}.r-pres-join-qr canvas{display:block;max-width:100%;height:auto}.r-pres-join-text{text-align:center;line-height:1.2}.r-pres-join-host{font-size:.85rem;color:#475569;font-weight:500}.r-pres-join-code{font-size:1.4rem;font-weight:700;letter-spacing:.1em;color:#0f172a;font-variant-numeric:tabular-nums;margin-top:2px}.r-pres-join-counter{margin-top:4px;padding:6px 10px;background:#0f172a0f;border-radius:6px;font-size:.85rem;display:flex;align-items:baseline;gap:.3rem;width:100%;justify-content:center}.r-pres-join-counter strong{font-size:1rem;font-variant-numeric:tabular-nums;color:#0f172a}.r-pres-join-counter .text-muted{color:#64748b}.r-pres-leaderboard[hidden]{display:none}.r-pres-leaderboard{position:absolute;top:380px;right:16px;bottom:80px;width:min(320px,28vw);background:#0f172ad9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(245,158,11,.25);border-radius:12px;padding:14px 16px;overflow-y:auto;z-index:5;display:flex;flex-direction:column}.r-pres-leaderboard .lb-header{display:flex;justify-content:space-between;align-items:baseline;font-weight:700;font-size:.95rem;margin-bottom:.5rem;padding-bottom:.4rem;border-bottom:1px solid rgba(255,255,255,.08)}.r-pres-leaderboard .lb-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.3rem}.r-pres-leaderboard .lb-row{display:grid;grid-template-columns:28px 1fr auto;grid-template-areas:"rank name score" "rank acc acc";gap:.1rem .5rem;align-items:center;padding:.35rem .5rem;border-radius:6px;background:#ffffff08;font-size:.875rem;transition:background .2s}.r-pres-leaderboard .lb-row:nth-child(1){background:#f59e0b1f}.r-pres-leaderboard .lb-row:nth-child(2){background:#ffffff0f}.r-pres-leaderboard .lb-row:nth-child(3){background:#b453091f}.r-pres-leaderboard .lb-rank{grid-area:rank;font-size:1.1rem;text-align:center;font-variant-numeric:tabular-nums}.r-pres-leaderboard .lb-rank-num{display:inline-block;font-size:.85rem;color:var(--text-muted)}.r-pres-leaderboard .lb-name{grid-area:name;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.r-pres-leaderboard .lb-score{grid-area:score;font-weight:700;color:var(--amber-300, #fcd34d);font-variant-numeric:tabular-nums}.r-pres-leaderboard .lb-acc{grid-area:acc;font-size:.7rem}@media(max-width:720px){.r-pres-leaderboard{position:static;width:auto;margin:.75rem;max-height:40vh}}.r-text-vn{color:var(--text-muted, #94a3b8);font-weight:400;font-size:.875rem}.r-opt-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.4rem}.r-opt{display:grid;grid-template-columns:1fr auto;align-items:center;gap:.75rem;padding:.5rem .75rem;border-radius:6px;background:#ffffff05;position:relative;overflow:hidden}.r-opt-correct{background:#10b98114;outline:1px solid rgba(16,185,129,.3)}.r-opt-bar{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0;pointer-events:none;border-radius:6px;overflow:hidden}.r-opt-fill{display:block;height:100%;background:#fbbf2429;transition:width .45s cubic-bezier(.22,1,.36,1)}.r-opt-correct .r-opt-fill{background:#10b9812e}.r-opt-label{position:relative;z-index:1;font-size:.875rem;line-height:1.35}.r-opt-count{position:relative;z-index:1;font-size:.875rem;color:var(--text-muted, #94a3b8);font-variant-numeric:tabular-nums;white-space:nowrap}.r-opt-correct .r-opt-count{color:#10b981;font-weight:600}.r-count-pct,.r-show-pct .r-count-num{display:none}.r-show-pct .r-count-pct{display:inline}.r-answer-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.625rem}.r-answer-list li{background:#ffffff06;border-left:3px solid var(--amber-400, #fbbf24);padding:.625rem .875rem;border-radius:4px;font-size:.875rem;line-height:1.5}.r-ans-name{color:var(--amber-400, #fbbf24);font-weight:600;margin-right:.4rem}.r-ans-text{white-space:pre-wrap;word-break:break-word}.r-heatmap{border-collapse:separate;border-spacing:2px;width:100%;font-size:.8125rem}.r-heatmap th,.r-heatmap td{padding:.4rem .5rem;text-align:center}.r-heatmap thead th{font-size:.75rem;color:var(--text-muted, #94a3b8);font-weight:500;border-bottom:1px solid var(--border-color, rgba(255,255,255,.08))}.r-row-head{text-align:left!important;font-weight:500;max-width:320px;white-space:normal}.r-cell-hit{background:#10b98140;color:#10b981;font-weight:700;border-radius:4px}.r-cell-miss{color:#ffffff2e}.r-cell-pct{font-variant-numeric:tabular-nums;color:var(--text-muted, #94a3b8);font-weight:600}.r-group-row th{text-align:left!important;padding:.625rem .5rem .4rem!important;color:var(--amber-400, #fbbf24)!important;font-weight:700!important;font-size:.8125rem!important;border-bottom:1px solid rgba(251,191,36,.2);background:#fbbf240a}body.r-presenter-open{overflow:hidden}.r-pres-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--bg-base, #0f0f23);z-index:10000;display:flex;flex-direction:column;animation:r-pres-fade .2s ease}@keyframes r-pres-fade{0%{opacity:0}to{opacity:1}}.r-pres-topbar{display:flex;align-items:center;gap:1.5rem;padding:1rem 2rem;border-bottom:1px solid var(--border-color, rgba(255,255,255,.08));font-size:.875rem;color:var(--text-muted, #94a3b8)}.r-pres-id{font-family:ui-monospace,monospace;color:var(--amber-400, #fbbf24)}.r-pres-progress{font-weight:700;font-size:1rem;color:var(--text, #fff)}.r-pres-count{margin-left:auto}.r-pres-close{background:transparent;border:1px solid var(--border-color, rgba(255,255,255,.2));color:var(--text, #fff);border-radius:6px;width:36px;height:36px;font-size:1rem;cursor:pointer}.r-pres-close:hover{background:#ffffff0d}.r-pres-stage{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem 280px 2rem 4vw;overflow:hidden;position:relative}@media(max-width:800px){.r-pres-stage{padding:2rem 4vw}.r-pres-join{position:static;width:auto;margin:0 auto 1rem;max-width:320px}.r-pres-leaderboard{position:static;width:100%;margin-top:1rem}}.r-pres-slide{width:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;transition:transform .32s cubic-bezier(.22,1,.36,1),opacity .28s ease;will-change:transform,opacity}.r-pres-stage>.r-pres-slide:not(:only-child){position:absolute;top:2rem;right:4vw;bottom:2rem;left:4vw;margin:auto}.r-pres-slide-from-right{transform:translate(28px);opacity:0}.r-pres-slide-from-left{transform:translate(-28px);opacity:0}.r-pres-slide-active{transform:translate(0);opacity:1}.r-pres-slide-to-left{transform:translate(-28px);opacity:0}.r-pres-slide-to-right{transform:translate(28px);opacity:0}.r-pres-q{font-size:clamp(1.75rem,4vw,3rem);text-align:center;margin:0 0 .5rem;line-height:1.2;max-width:1100px}.r-pres-q-vn{font-size:clamp(1rem,2vw,1.25rem);color:var(--text-muted, #94a3b8);text-align:center;margin:0 0 2rem;max-width:1000px}.r-pres-bars{list-style:none;padding:0;margin:0;width:100%;max-width:900px;display:flex;flex-direction:column;gap:.875rem}.r-pres-bar{display:grid;grid-template-columns:1fr auto;align-items:center;gap:1rem;padding:1rem 1.25rem;border-radius:10px;background:#ffffff08;border:1px solid var(--border-color, rgba(255,255,255,.06));position:relative;overflow:hidden;font-size:1.125rem}.r-pres-bar-correct{border-color:#10b98166;background:#10b9810f}.r-pres-fill{position:absolute;top:0;right:0;bottom:0;left:0;background:#fbbf242e;z-index:0;transition:width .5s cubic-bezier(.22,1,.36,1);border-radius:10px}.r-pres-bar-correct .r-pres-fill{background:#10b9812e}.r-pres-label{position:relative;z-index:1;font-weight:500;line-height:1.4}.r-pres-num{position:relative;z-index:1;font-size:1.75rem;font-weight:700;font-variant-numeric:tabular-nums;color:var(--amber-400, #fbbf24)}.r-pres-bar-correct .r-pres-num{color:#10b981}.r-pres-pie-wrap{display:flex;align-items:center;gap:2.5rem;margin-top:1.5rem;width:100%;max-width:720px;flex-wrap:wrap;justify-content:center}.r-pres-pie{width:clamp(220px,32vw,360px);height:auto;flex-shrink:0;filter:drop-shadow(0 4px 12px rgba(0,0,0,.15))}.r-pres-legend{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.6rem;min-width:200px}.r-pres-legend li{display:grid;grid-template-columns:18px auto auto 1fr;align-items:center;gap:.5rem .75rem;font-size:1.1rem;color:#1e293b}.r-pres-legend-correct{font-weight:600}.r-pres-legend-correct .r-pres-num{color:#10b981}.r-pres-legend .r-pres-num{font-size:1.2rem;font-weight:700;font-variant-numeric:tabular-nums;color:#0f172a}.r-pres-swatch{width:14px;height:14px;border-radius:3px;display:inline-block}.r-pres-legend-label{color:#475569}.r-pres-dots{display:flex;gap:1.5rem;margin-top:1.5rem;align-items:flex-end;justify-content:center;flex-wrap:wrap;width:100%;max-width:900px}.r-pres-dots-col{display:flex;flex-direction:column;align-items:center;min-width:120px;flex:1 1 0;max-width:200px}.r-pres-dots-cluster{display:flex;flex-wrap:wrap;gap:4px;justify-content:center;align-items:center;margin-bottom:.8rem;min-height:60px;position:relative}.r-pres-dot{width:14px;height:14px;border-radius:50%;display:inline-block}.r-pres-dots-overflow{margin-left:4px;font-size:.85rem;color:#64748b;font-weight:600}.r-pres-dots-meta{text-align:center;line-height:1.3}.r-pres-dots-meta .r-pres-num{font-size:1.4rem;font-weight:700;color:#0f172a;font-variant-numeric:tabular-nums}.r-pres-dots-col-correct .r-pres-dots-meta .r-pres-num{color:#10b981}.r-pres-dots-label{display:block;font-size:.95rem;color:#475569;margin-top:4px}body:not(.r-mode-hidden) .r-pres-pie-wrap .r-count-pct,body:not(.r-mode-hidden) .r-pres-dots .r-count-pct{display:none}.r-pres-stage.r-show-pct .r-count-num{display:none}.r-pres-stage.r-show-pct .r-count-pct{display:inline}.r-pres-answer-list{list-style:none;padding:0;margin:0;width:100%;max-width:900px;max-height:60vh;overflow-y:auto;display:flex;flex-direction:column;gap:.75rem}.r-pres-answer-list li{background:#ffffff0a;padding:1rem 1.25rem;border-radius:10px;border-left:3px solid var(--amber-400, #fbbf24);font-size:1.0625rem;line-height:1.5}.r-pres-answer-list strong{color:var(--amber-400, #fbbf24);margin-right:.5rem}.r-pres-nav{display:flex;justify-content:center;gap:1rem;padding:1rem 2rem 2rem}.r-fillin-student{padding:.25rem 0 .5rem}.r-fillin-list{list-style:none;padding:0 0 0 .5rem;margin:.25rem 0 0;display:flex;flex-direction:column;gap:.35rem}.r-fillin-list li{font-size:1rem;line-height:1.45;padding:.45rem .7rem;background:#ffffff06;border-left:3px solid var(--amber-400, #fbbf24);border-radius:4px}.r-fillin-list li.lang-vn{border-left-color:var(--navy-500, #5c7cfa)}@media(max-width:720px){.r-header{flex-direction:column;align-items:stretch}.r-ex-header{flex-direction:column;align-items:flex-start}.r-pres-bar{font-size:1rem}.r-pres-num{font-size:1.25rem}}body.r-mode-numbers .r-opt-bar,body.r-mode-numbers .r-opt-fill,body.r-mode-numbers .r-pres-fill{background:transparent!important}body.r-mode-numbers .r-opt-bar{background:#ffffff0a!important}body.r-mode-hidden .r-opt-bar,body.r-mode-hidden .r-opt-fill,body.r-mode-hidden .r-pres-fill{background:transparent!important}body.r-mode-hidden .r-opt-bar{background:#ffffff0a!important}body.r-mode-hidden .r-opt-count,body.r-mode-hidden .r-pres-num,body.r-mode-hidden .r-q-acc,body.r-mode-hidden .r-pres-acc,body.r-mode-hidden .r-ex-count,body.r-mode-hidden .r-pres-count,body.r-mode-hidden .quiz-podium-score,body.r-mode-hidden .guessnum-pres-stats,body.r-mode-hidden .guessnum-summary-line,body.r-mode-hidden .guessnum-value,body.r-mode-hidden .guessnum-dist{visibility:hidden}.qa-summary{display:flex;gap:var(--sp-4);flex-wrap:wrap;margin-bottom:var(--sp-4)}.qa-summary-stat{flex:1;min-width:140px;padding:var(--sp-3) var(--sp-4);background:#ffffff0a;border:1px solid var(--border-subtle);border-radius:var(--radius-md);text-align:center}.qa-summary-num{display:block;font-size:1.6rem;font-weight:800;color:var(--amber-300, #fcd34d);font-variant-numeric:tabular-nums}.qa-summary-label{display:block;font-size:.78rem;color:var(--text-muted);margin-top:4px}.qa-table-wrap{overflow-x:auto;border-radius:var(--radius-md);border:1px solid var(--border-subtle)}.qa-table{width:100%;border-collapse:collapse;font-size:var(--text-sm)}.qa-table th,.qa-table td{padding:8px 12px;text-align:left;border-bottom:1px solid var(--border-subtle);vertical-align:top}.qa-table th{background:#ffffff0a;color:var(--text-muted);font-weight:600;font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}.qa-table tbody tr:hover{background:#ffffff08}.qa-table .qa-num{text-align:right;font-variant-numeric:tabular-nums;white-space:nowrap}.qa-rank{color:var(--text-muted);font-weight:700}.qa-module{color:var(--text-secondary);white-space:nowrap}.qa-text-vn{font-size:.78rem;margin-top:2px}.qa-acc-cell{min-width:160px}.qa-acc-bar{display:inline-block;vertical-align:middle;width:100px;height:6px;background:#ffffff14;border-radius:3px;overflow:hidden;margin-right:8px}.qa-acc-fill{display:block;height:100%;background:var(--amber-400);transition:width .3s}.qa-acc-pct{font-weight:700}.r-acc-band-hard .qa-acc-fill{background:var(--rose-500, #f43f5e)}.r-acc-band-hard .qa-acc-pct{color:var(--rose-300, #fda4af)}.r-acc-band-mid .qa-acc-fill{background:var(--amber-400, #fbbf24)}.r-acc-band-mid .qa-acc-pct{color:var(--amber-300, #fcd34d)}.r-acc-band-easy .qa-acc-fill{background:var(--emerald-400, #34d399)}.r-acc-band-easy .qa-acc-pct{color:var(--emerald-300, #6ee7b7)}.r-acc-band-none .qa-acc-pct{color:var(--text-muted)}.hist-summary{display:flex;gap:var(--sp-3);flex-wrap:wrap;margin-top:var(--sp-2)}.hist-summary>.qa-summary-stat{min-width:120px}.hist-timeline{list-style:none;padding:0;display:grid;gap:var(--sp-2)}.hist-row{display:grid;grid-template-columns:160px 28px 1fr auto auto;align-items:center;gap:var(--sp-3);padding:8px 12px;background:#ffffff08;border-left:3px solid var(--border-subtle);border-radius:var(--radius-sm);font-size:var(--text-sm)}.hist-row.r-acc-band-hard{border-left-color:var(--rose-500)}.hist-row.r-acc-band-mid{border-left-color:var(--amber-400)}.hist-row.r-acc-band-easy{border-left-color:var(--emerald-500)}.hist-when{color:var(--text-muted);font-size:.78rem;white-space:nowrap}.hist-kind{text-align:center}.hist-title{font-weight:600}.hist-detail{color:var(--text-secondary);font-size:.85rem}.hist-dur{color:var(--text-muted);font-size:.78rem;font-variant-numeric:tabular-nums}@media(max-width:720px){.hist-row{grid-template-columns:1fr auto}.hist-row>.hist-when{grid-column:1 / -1;order:1}.hist-row>.hist-kind{order:2}.hist-row>.hist-title{order:3}.hist-row>.hist-detail{grid-column:1 / -1;order:4}.hist-row>.hist-dur{grid-column:1 / -1;order:5;text-align:right}}.quiz-attempt-info{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:var(--sp-4);padding-bottom:var(--sp-3);border-bottom:1px solid var(--border-subtle, rgba(255, 255, 255, .08))}.quiz-pass-card{display:flex;align-items:flex-start;gap:14px;padding:16px 20px;margin-bottom:var(--sp-4);background:linear-gradient(135deg,#22c55e2e,#22c55e0f);border:1px solid rgba(74,222,128,.4);border-radius:10px}.quiz-pass-icon{width:44px;height:44px;border-radius:50%;background:#4ade80;color:#0f2417;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:22px;flex-shrink:0}.quiz-pass-text strong{display:block;color:#86efac;font-size:16px;margin-bottom:4px}.quiz-pass-text p{margin:0;font-size:13px;line-height:1.5}.wc-input-row{display:flex;gap:var(--sp-2);align-items:center}.wc-input{flex:1}.wc-list{list-style:none;padding:0;margin:var(--sp-3) 0 0;display:flex;flex-wrap:wrap;gap:var(--sp-2)}.wc-tag{display:inline-flex;align-items:center;gap:4px;background:#f59e0b1f;border:1px solid rgba(245,158,11,.4);color:var(--amber-300);padding:4px 6px 4px 12px;border-radius:999px;font-size:var(--text-sm)}.wc-tag-x{background:transparent;border:0;color:inherit;cursor:pointer;font-size:16px;line-height:1;padding:0 6px;border-radius:50%;opacity:.7}.wc-tag-x:hover{opacity:1;background:#f59e0b33}.wc-cloud-mount{width:100%;min-height:220px;display:flex;align-items:center;justify-content:center;padding:8px}.wc-cloud-loading{font-size:28px;letter-spacing:4px;opacity:.5}.wc-svg{display:block;max-width:100%;max-height:100%;width:100%;height:100%}.wc-svg text{cursor:default;transition:font-size .35s ease-in-out,opacity .28s ease-in-out}.wc-svg:hover text{opacity:.5}.wc-svg text:hover{opacity:1}.r-pres-slide .wc-cloud-mount{min-height:360px;height:calc(100vh - 280px);max-height:calc(100vh - 280px)}.scale-axis-labels{display:flex;justify-content:space-between;font-size:var(--text-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--sp-3)}.scale-row{display:grid;grid-template-columns:1fr auto;gap:var(--sp-3);align-items:center;padding:var(--sp-3) 0;border-bottom:1px solid var(--border-subtle)}.scale-row:last-child{border-bottom:0}.scale-label{font-weight:500;font-size:var(--text-sm)}.scale-options{display:flex;gap:6px}.scale-opt{min-width:36px;min-height:36px;padding:4px 8px;border-radius:18px;border:1.5px solid var(--border-subtle);background:transparent;color:var(--text-secondary);font-weight:600;cursor:pointer;transition:all .15s;display:inline-flex;flex-direction:column;align-items:center;justify-content:center;line-height:1.1}.scale-opt:hover{border-color:var(--amber-400);color:var(--amber-300)}.scale-opt.selected{background:var(--amber-500);border-color:var(--amber-500);color:#0f0f23}.scale-opt-num{font-size:.95rem;font-weight:700}.scale-opt-hint{font-size:.65rem;font-weight:500;margin-top:2px;opacity:.75;max-width:80px;white-space:normal;text-align:center;line-height:1.1}.r-scale-row{margin-bottom:var(--sp-4)}.r-scale-avg{font-size:var(--text-sm);color:var(--text-muted);margin-left:var(--sp-3);font-weight:400}.r-scale-avg strong{color:var(--amber-400);font-weight:700}.r-scale-bars{display:flex;align-items:flex-end;gap:var(--sp-2);margin-top:var(--sp-2);min-height:100px}.r-scale-bucket{display:flex;flex-direction:column;align-items:center;flex:1;font-size:var(--text-xs)}.r-scale-bar{width:100%;height:80px;display:flex;align-items:flex-end;background:#f59e0b0f;border-radius:4px 4px 0 0;overflow:hidden}.r-scale-fill{width:100%;background:linear-gradient(180deg,var(--amber-400),var(--amber-500));transition:height .4s ease}.r-scale-num{font-weight:700;margin-top:4px;color:var(--text-secondary)}.r-scale-cnt{color:var(--text-muted);font-size:var(--text-xs)}.rank-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--sp-2)}.rank-item{display:grid;grid-template-columns:32px 24px 1fr auto;align-items:center;gap:var(--sp-3);padding:12px 14px;background:#ffffff08;border:1px solid var(--border-subtle, rgba(255, 255, 255, .08));border-radius:8px;cursor:grab;transition:background .15s,border-color .15s,transform .15s}.rank-item:hover{background:#f59e0b0f;border-color:#f59e0b4d}.rank-item.rank-dragging{opacity:.4;cursor:grabbing}.rank-item.rank-drop-target{border-color:var(--amber-500);background:#f59e0b1f;transform:scale(1.01)}.rank-num{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;background:var(--amber-500);color:#0f0f23;font-weight:700;font-size:14px}.rank-handle{color:var(--text-muted);font-size:18px;cursor:grab;-webkit-user-select:none;user-select:none}.rank-label{font-weight:500;font-size:var(--text-sm)}.rank-arrows{display:flex;flex-direction:column;gap:2px}.rank-up,.rank-down{background:transparent;border:1px solid var(--border-subtle, rgba(255, 255, 255, .1));color:var(--text-muted);width:24px;height:18px;font-size:9px;cursor:pointer;border-radius:3px;padding:0;display:inline-flex;align-items:center;justify-content:center}.rank-up:hover,.rank-down:hover{border-color:var(--amber-500);color:var(--amber-300)}.r-rank-bars{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px;counter-reset:rank-counter}.r-rank-bar{display:grid;grid-template-columns:32px 1fr;gap:var(--sp-3);align-items:center;position:relative;padding:8px 0}.r-rank-pos{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;background:#f59e0b2e;color:var(--amber-300);font-weight:700;font-size:14px}.r-rank-bar:first-child .r-rank-pos{background:var(--amber-500);color:#0f0f23}.r-rank-bar-fill{position:absolute;left:44px;right:0;height:100%;border-radius:6px;background:linear-gradient(90deg,#f59e0b2e,#f59e0b0d);z-index:0;transition:width .4s ease}.r-rank-meta{position:relative;z-index:1;display:flex;align-items:center;justify-content:space-between;padding:0 12px;gap:var(--sp-3);flex-wrap:wrap}.r-rank-label{font-weight:500}.r-rank-stats{font-size:var(--text-xs);color:var(--text-muted)}.r-rank-stats strong{color:var(--amber-300)}.matrix-axes-wrap{display:flex;align-items:stretch;gap:10px;max-width:600px;margin:0 auto}.matrix-axes-main{flex:1;min-width:0}.matrix-y-axis-title{writing-mode:vertical-rl;transform:rotate(180deg);font-size:.875rem;font-weight:700;color:var(--amber-300);align-self:center;letter-spacing:.02em;flex-shrink:0;padding:0 4px}.matrix-x-axis-title{text-align:center;font-size:.875rem;font-weight:700;color:var(--amber-300);margin-top:6px;letter-spacing:.02em}.matrix-wrap{display:grid;grid-template-columns:auto 1fr auto;grid-template-rows:auto 1fr auto;gap:8px;align-items:center;max-width:540px;margin:0 auto}.matrix-y-high{grid-column:1;grid-row:1;padding:0 6px;font-size:var(--text-xs);color:var(--text-muted);writing-mode:vertical-rl;transform:rotate(180deg);justify-self:end;align-self:start;font-weight:600}.matrix-y-low{grid-column:1;grid-row:3;padding:0 6px;font-size:var(--text-xs);color:var(--text-muted);writing-mode:vertical-rl;transform:rotate(180deg);justify-self:end;align-self:end;font-weight:600}.matrix-x-low{grid-column:1 / 2;grid-row:4;padding:4px 0 0;font-size:var(--text-xs);color:var(--text-muted);justify-self:start;font-weight:600}.matrix-x-high{grid-column:2 / 4;grid-row:4;padding:4px 0 0;font-size:var(--text-xs);color:var(--text-muted);justify-self:end;font-weight:600}.matrix-canvas{grid-column:2 / 4;grid-row:1 / 4;position:relative;aspect-ratio:1 / 1;background:#ffffff05;border:1px solid var(--border-subtle, rgba(255, 255, 255, .1));border-radius:8px;cursor:crosshair;overflow:hidden;-webkit-user-select:none;user-select:none}.matrix-canvas-readonly{cursor:default}.matrix-grid{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr}.matrix-quad{border:1px dashed rgba(255,255,255,.04)}.q-tl{background:#f59e0b0a}.q-tr{background:#22c55e0a}.q-bl{background:#f871710a}.q-br{background:#6366f10a}.matrix-axis-x,.matrix-axis-y{position:absolute;background:#ffffff26;pointer-events:none}.matrix-axis-x{left:0;right:0;top:50%;height:1px}.matrix-axis-y{top:0;bottom:0;left:50%;width:1px}.matrix-dot{position:absolute;width:18px;height:18px;margin-left:-9px;margin-top:-9px;border-radius:50%;background:var(--amber-500);box-shadow:0 0 0 4px #f59e0b40,0 2px 8px #0006;pointer-events:none;transition:left .2s,top .2s}.matrix-result-dot{position:absolute;width:12px;height:12px;margin-left:-6px;margin-top:-6px;border-radius:50%;background:#f59e0bcc;box-shadow:0 0 0 2px #0f0f2399;cursor:pointer;transition:transform .15s}.matrix-result-dot:hover{transform:scale(1.4);z-index:5}.matrix-dot-labelled{background:var(--dot-color, var(--amber-500));box-shadow:0 0 0 4px color-mix(in srgb,var(--dot-color, var(--amber-500)) 30%,transparent),0 2px 8px #0006}.matrix-dot-labelled .matrix-dot-label{position:absolute;top:-1.6em;left:50%;transform:translate(-50%);font-size:.7rem;font-weight:600;background:var(--dot-color, var(--amber-500));color:#1a1a1a;padding:1px 6px;border-radius:4px;white-space:nowrap;box-shadow:0 1px 4px #0000004d;pointer-events:none}.matrix-result-dot-labelled{background:var(--dot-color, rgba(245, 158, 11, .8))}.matrix-result-dot-labelled .matrix-result-dot-label{position:absolute;top:-1.6em;left:50%;transform:translate(-50%);font-size:.65rem;color:#1a1a1a;padding:1px 5px;border-radius:3px;white-space:nowrap}.matrix-items-panel{margin-top:.75rem;padding:.75rem;background:#ffffff08;border-radius:8px;border:1px solid rgba(255,255,255,.06)}.matrix-items-hint{font-size:.75rem;color:var(--text-muted);margin-bottom:.5rem}.matrix-items-chips{display:flex;gap:.4rem;flex-wrap:wrap}.matrix-item-chip{display:inline-flex;align-items:center;gap:.4rem;padding:.35rem .75rem;font-size:.875rem;border:1px solid rgba(255,255,255,.15);border-radius:999px;background:transparent;color:var(--text);cursor:pointer;transition:all .15s}.matrix-chip-swatch{display:inline-block;width:10px;height:10px;border-radius:50%;flex-shrink:0}.matrix-item-chip:hover{border-color:var(--chip-color, rgba(245, 158, 11, .5))}.matrix-item-chip.active{border-color:var(--chip-color, var(--amber-500));background:color-mix(in srgb,var(--chip-color, var(--amber-500)) 18%,transparent);color:var(--text);box-shadow:0 0 0 3px color-mix(in srgb,var(--chip-color, var(--amber-500)) 25%,transparent)}.matrix-item-chip.placed:before{content:"✓ ";color:var(--emerald-400)}.matrix-item-chip.placed{opacity:.75}.matrix-item-chip.placed.active{opacity:1}.matrix-result.matrix-large{max-width:720px}.matrix-large .matrix-result-dot{width:16px;height:16px;margin-left:-8px;margin-top:-8px}.matrix-quad-table{width:100%;margin-top:var(--sp-3);border-collapse:collapse;font-size:var(--text-sm)}.matrix-quad-table th,.matrix-quad-table td{padding:6px 10px;border:1px solid var(--border-subtle, rgba(255, 255, 255, .08));text-align:center}.matrix-quad-table th{color:var(--text-muted);font-weight:600;font-size:var(--text-xs)}.matrix-quad-table td{font-weight:700;color:var(--amber-300)}.r-pres-scale-avg{font-size:1.4em;color:var(--amber-300);margin-bottom:var(--sp-4)}.r-pres-scale-avg strong{font-size:1.5em}.r-pres-scale-bars{display:flex;align-items:flex-end;gap:var(--sp-3);min-height:240px}.r-pres-scale-bars .r-scale-bar{height:200px}.r-pres-scale-bars .r-scale-num{font-size:1.4em}.r-pres-scale-bars .r-scale-cnt{font-size:1em}.pinimage-canvas{position:relative;display:inline-block;cursor:crosshair;border:1px solid var(--border-subtle, rgba(255,255,255,.08));border-radius:var(--radius-md);overflow:hidden;max-width:100%;-webkit-user-select:none;user-select:none}.pinimage-img{display:block;max-width:100%;height:auto;pointer-events:none;-webkit-user-drag:none}.pinimage-dot{position:absolute;width:18px;height:18px;margin-left:-9px;margin-top:-9px;border-radius:50%;background:var(--amber-500);border:2px solid white;box-shadow:0 0 0 2px #f59e0b4d,0 2px 6px #0006;pointer-events:none;animation:pinimage-pop .25s ease-out}@keyframes pinimage-pop{0%{transform:scale(0);opacity:0}70%{transform:scale(1.25);opacity:1}to{transform:scale(1)}}.pinimage-canvas-result,.pinimage-canvas-presenter{cursor:default}.pinimage-canvas-result{max-width:720px}.pinimage-canvas-presenter{max-width:100%}.pinimage-result-dot{position:absolute;width:14px;height:14px;margin-left:-7px;margin-top:-7px;border-radius:50%;background:var(--amber-500);border:2px solid rgba(255,255,255,.85);box-shadow:0 1px 3px #00000080;pointer-events:none}.pinimage-canvas-presenter .pinimage-result-dot{width:18px;height:18px;margin-left:-9px;margin-top:-9px}.guessnum-row{display:inline-flex;align-items:center;gap:var(--sp-3)}.guessnum-input{width:200px;font-size:1.25rem;font-variant-numeric:tabular-nums}.guessnum-unit{font-size:.95rem;color:var(--text-muted)}.guessnum-summary-line{font-size:var(--text-sm);color:var(--text-muted);margin-bottom:var(--sp-1)}.guessnum-summary-line strong{color:var(--text-primary)}.guessnum-list{list-style:none;margin-top:var(--sp-3);padding:0;display:grid;gap:var(--sp-1)}.guessnum-row-item{display:grid;grid-template-columns:1fr auto auto;gap:var(--sp-3);align-items:center;padding:6px 10px;background:#ffffff08;border-radius:var(--radius-sm);font-size:var(--text-sm)}.guessnum-name{color:var(--text-primary)}.guessnum-value{font-weight:700;font-variant-numeric:tabular-nums;color:var(--amber-300)}.guessnum-dist{font-size:.8rem;color:var(--text-muted);font-variant-numeric:tabular-nums}.guessnum-pres{text-align:center;margin-top:var(--sp-4)}.guessnum-pres-correct{font-size:2rem;margin-bottom:var(--sp-3);color:var(--amber-300)}.guessnum-pres-correct strong{font-size:2.5rem}.guessnum-pres-stats{font-size:1.1rem;color:var(--text-muted);margin-bottom:var(--sp-3)}.guessnum-pres-stats strong{color:var(--text-primary)}.guessnum-pres-closest{font-size:1.2rem;color:var(--emerald-400);font-weight:600}.quickform-fields{display:grid;gap:var(--sp-4)}.quickform-field{display:grid;gap:var(--sp-2)}.quickform-label{font-size:var(--text-sm);font-weight:600;color:var(--text-primary)}.quickform-required{color:var(--rose-400)}.quickform-choices{display:grid;gap:var(--sp-2)}.quickform-choice{display:flex;align-items:center;gap:var(--sp-2);padding:6px 10px;background:#ffffff08;border:1px solid var(--border-subtle);border-radius:var(--radius-sm);cursor:pointer;font-size:var(--text-sm)}.quickform-choice:hover{background:#ffffff0f}.quickform-choice input{margin:0}.openended-input{min-height:80px;resize:vertical;line-height:1.6}.openended-list{list-style:none;padding:0;display:grid;gap:var(--sp-2)}.openended-row{display:grid;grid-template-columns:28px 1fr;align-items:start;gap:var(--sp-3);padding:var(--sp-3);border-left:3px solid var(--border-subtle);background:#ffffff08;border-radius:var(--radius-sm)}.openended-row-pass{border-left-color:var(--emerald-500)}.openended-row-fail{border-left-color:var(--rose-500)}.openended-row-body strong{font-size:var(--text-sm);color:var(--text-primary)}.openended-text{margin:4px 0 0;font-size:.85rem;color:var(--text-secondary);white-space:pre-wrap;line-height:1.5}.openended-matched{margin-top:6px;font-size:.72rem;color:var(--text-muted)}.openended-matched code{background:#10b9811a;color:var(--emerald-300);padding:1px 6px;border-radius:4px;font-size:.72rem;margin-left:4px}.openended-badge{width:22px;height:22px;display:inline-flex;align-items:center;justify-content:center;border-radius:50%;font-weight:800;font-size:.78rem}.openended-badge-pass{background:var(--emerald-500);color:#fff}.openended-badge-fail{background:#f43f5e26;color:var(--rose-300)}.openended-pres-list{list-style:none;padding:0;max-width:900px;margin:0 auto;display:grid;gap:var(--sp-2)}.openended-pres-row{padding:var(--sp-2) var(--sp-3);border-left:3px solid var(--border-subtle);background:#ffffff0a;border-radius:var(--radius-sm);font-size:1rem}.openended-pres-row.openended-row-pass{border-left-color:var(--emerald-500)}.openended-pres-row.openended-row-fail{border-left-color:var(--rose-500)}.wc-sentiment-legend{display:flex;gap:var(--sp-2);flex-wrap:wrap;justify-content:center;margin-top:var(--sp-3)}.wc-sent-pill{display:inline-flex;align-items:center;gap:4px;padding:4px 12px;border-radius:var(--radius-full);font-size:.78rem;font-weight:600;background:#ffffff0a;border:1px solid var(--border-subtle)}.wc-sent-positive{color:var(--emerald-300);border-color:#10b9814d;background:#10b98114}.wc-sent-neutral{color:var(--text-muted)}.wc-sent-negative{color:var(--rose-300);border-color:#f43f5e4d;background:#f43f5e14}.wc-views>.wc-view-counts,.wc-views>.wc-view-hidden{display:none}body.r-mode-numbers .wc-views>.wc-view-cloud{display:none}body.r-mode-numbers .wc-views>.wc-view-counts{display:block}body.r-mode-numbers .wc-views>.wc-view-hidden{display:none}body.r-mode-hidden .wc-views>.wc-view-cloud{display:none}body.r-mode-hidden .wc-views>.wc-view-counts{display:none}body.r-mode-hidden .wc-views>.wc-view-hidden{display:flex}.wc-counts-list{list-style:none;padding:0;display:grid;gap:var(--sp-2);max-width:720px;margin:0 auto}.wc-counts-row{display:grid;grid-template-columns:200px 1fr 60px;align-items:center;gap:var(--sp-3);padding:6px 12px;background:#ffffff08;border-radius:var(--radius-sm);font-size:var(--text-sm)}.wc-counts-word{font-weight:600;color:var(--text-primary)}.wc-counts-bar{height:8px;background:#ffffff0f;border-radius:4px;overflow:hidden}.wc-counts-fill{display:block;height:100%;background:linear-gradient(90deg,var(--amber-400, #fbbf24),var(--amber-500, #f59e0b))}.wc-counts-num{text-align:right;font-weight:700;font-variant-numeric:tabular-nums;color:var(--amber-300, #fcd34d)}.wc-view-hidden{align-items:center;justify-content:center;min-height:240px}.wc-hidden-card{text-align:center;padding:var(--sp-6);background:#ffffff08;border:1px dashed var(--border-subtle);border-radius:var(--radius-lg);max-width:420px}.wc-hidden-icon{font-size:3rem;margin-bottom:var(--sp-3);opacity:.9}.wc-hidden-card p{margin:4px 0}body.r-mode-numbers .wc-sentiment-btn,body.r-mode-hidden .wc-sentiment-btn{display:none}.snd-list{list-style:none;padding:0;display:grid;gap:var(--sp-2)}.snd-row{display:grid;grid-template-columns:1fr auto auto auto;align-items:center;gap:var(--sp-3);padding:8px 12px;background:#ffffff08;border:1px solid var(--border-subtle);border-radius:var(--radius-md);font-size:var(--text-sm)}.snd-name{font-weight:600}.snd-meta{font-size:.72rem;color:var(--text-muted);white-space:nowrap}.snd-player{height:32px}@media(max-width:720px){.snd-row{grid-template-columns:1fr auto}.snd-row .snd-meta{grid-column:1 / -1;order:1}.snd-row .snd-player{grid-column:1 / -1;order:2;width:100%}.snd-row .snd-del{order:3}}.snd-picker{padding:8px 10px;background:#ffffff05;border:1px dashed var(--border-subtle);border-radius:var(--radius-sm)}.snd-picker label{color:var(--text-muted)}.snd-picker audio{max-width:220px}.ach-page{max-width:1100px;margin:0 auto;padding:24px}.ach-header{margin-bottom:32px}.ach-header h1{margin:0 0 4px}.ach-summary{display:flex;gap:16px;margin-top:20px;flex-wrap:wrap}.ach-stat{flex:1;min-width:140px;padding:16px 20px;background:#ffffff0a;border:1px solid var(--border-subtle, rgba(255, 255, 255, .08));border-radius:10px;text-align:center}.ach-stat-num{font-size:32px;font-weight:800;color:var(--amber-400);line-height:1;margin-bottom:4px}.ach-stat-label{font-size:12px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;font-weight:600}.ach-section{margin-bottom:32px}.ach-section h2{margin-bottom:16px;font-size:18px}.ach-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}.ach-card{background:#ffffff0a;border:1px solid var(--border-subtle, rgba(255, 255, 255, .08));border-radius:10px;padding:16px;display:flex;flex-direction:column}.ach-card-pass{border-left:3px solid rgb(74,222,128);background:#22c55e0d}.ach-card-progress{border-left:3px solid var(--amber-500);background:#f59e0b0a}.ach-card-head{margin-bottom:12px}.ach-card-part{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-weight:600}.ach-card-head h3{margin:4px 0 0;font-size:16px}.ach-card-body{flex:1;display:flex;flex-direction:column;gap:6px;margin-bottom:12px}.ach-row{display:flex;justify-content:space-between;font-size:13px}.ach-row-label{color:var(--text-muted)}.ach-row-value{font-weight:600;color:var(--text-primary)}.ach-row-value.ach-pass{color:#86efac}.ach-card-foot{display:flex;gap:8px}.ach-detail{margin-top:32px;padding:20px;background:#0003;border-radius:10px;border:1px solid var(--border-subtle, rgba(255, 255, 255, .08))}.ach-history h3{margin:0 0 16px;font-size:16px;color:var(--amber-400)}.ach-history-table{width:100%;border-collapse:collapse;font-size:13px;margin-bottom:12px}.ach-history-table th,.ach-history-table td{padding:8px 10px;text-align:left;border-bottom:1px solid rgba(255,255,255,.05)}.ach-history-table th{color:var(--text-muted);font-weight:600;text-transform:uppercase;font-size:11px;letter-spacing:.04em}.ach-history-table tr.row-pass{background:#22c55e0f}.ach-history-table tr.row-fail{background:#f871710a}.ach-pass-tag{display:inline-block;padding:1px 7px;border-radius:4px;background:#22c55e38;color:#86efac;font-weight:600;font-size:11px}.ach-fail-tag{display:inline-block;padding:1px 7px;border-radius:4px;background:#f871712e;color:#fca5a5;font-weight:600;font-size:11px}.badge-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:var(--sp-3)}.badge-tile{padding:var(--sp-4);border-radius:var(--radius-lg);text-align:center;border:1px solid var(--border-subtle);background:#ffffff05;display:grid;gap:4px;transition:transform .15s,box-shadow .15s}.badge-earned{background:linear-gradient(160deg,#f59e0b29,#f59e0b0a);border-color:#f59e0b6b;box-shadow:0 4px 14px #f59e0b1a}.badge-earned:hover{transform:translateY(-2px);box-shadow:0 8px 22px #f59e0b2e}.badge-locked .badge-icon{filter:grayscale(1) opacity(.55)}.badge-icon{font-size:2.2rem;line-height:1;margin-bottom:4px}.badge-name{font-weight:700}.badge-desc{font-size:.78rem;line-height:1.35}.badge-meta{font-size:.7rem;color:var(--text-muted);margin-top:4px}.badge-progress{display:grid;gap:4px;margin-top:6px}.badge-progress-bar{height:4px;background:#ffffff14;border-radius:2px;overflow:hidden}.badge-progress-bar>span{display:block;height:100%;background:linear-gradient(90deg,var(--amber-400),var(--amber-500));transition:width .6s ease}#qa-host{position:fixed;z-index:9500}.qa-fab{position:fixed;right:20px;bottom:20px;display:inline-flex;align-items:center;gap:8px;padding:10px 18px;border-radius:999px;background:linear-gradient(135deg,var(--amber-500),#f97316);color:#0f0f23;border:0;cursor:grab;font-weight:700;font-size:14px;box-shadow:0 8px 24px #f59e0b59;transition:transform .15s,box-shadow .15s;z-index:9501;touch-action:none;-webkit-user-select:none;user-select:none}.qa-fab:active{cursor:grabbing}.qa-fab:hover{transform:translateY(-1px);box-shadow:0 10px 28px #f59e0b73}.qa-fab:active{transform:translateY(0)}.qa-fab-icon{font-size:18px}.qa-fab-badge{display:inline-flex;align-items:center;justify-content:center;min-width:22px;height:22px;padding:0 6px;border-radius:11px;background:#0f0f23;color:var(--amber-300);font-size:12px;font-weight:700;margin-left:4px}.qa-panel{position:fixed;right:0;top:0;bottom:0;width:min(440px,100vw);background:#16162a;border-left:1px solid rgba(255,255,255,.16);box-shadow:-16px 0 40px #0000008c;display:flex;flex-direction:column;transform:translate(100%);transition:transform .3s ease;z-index:9502}.qa-panel.qa-panel-open{transform:translate(0)}.qa-panel-instructor{background:#1c1c33;border-left:1px solid rgba(245,158,11,.22)}.qa-panel-header{display:flex;align-items:center;justify-content:space-between;padding:16px 18px;border-bottom:1px solid rgba(255,255,255,.12);background:#0000002e}.qa-panel-header h3{margin:0;font-size:16px;color:var(--text-primary)}.qa-panel-close{background:transparent;border:0;color:var(--text-secondary);font-size:18px;cursor:pointer;padding:4px 8px;border-radius:4px}.qa-panel-close:hover{background:#ffffff14;color:var(--text-primary)}.qa-panel-body{flex:1;overflow-y:auto;padding:14px;display:flex;flex-direction:column;gap:12px}.qa-empty{text-align:center;padding:32px 16px;color:var(--text-muted)}.qa-item{display:grid;grid-template-columns:50px 1fr auto;gap:12px;align-items:flex-start;padding:14px;background:#ffffff0f;border:1px solid rgba(255,255,255,.1);border-radius:10px;transition:background .15s,border-color .15s,opacity .15s}.qa-panel-instructor .qa-item{background:#ffffff14;border-color:#ffffff24}.qa-item:hover{background:#ffffff17;border-color:#f59e0b47}.qa-item-answered{opacity:.6}.qa-item-answered .qa-q{text-decoration:line-through}.qa-item-private{border-left:3px solid var(--amber-500);background:#f59e0b0f}.qa-panel-instructor .qa-item-private{background:#f59e0b1a}.qa-vote{display:flex;flex-direction:column;align-items:center;gap:2px;padding:8px 6px;background:#00000040;border:1px solid rgba(255,255,255,.16);border-radius:6px;color:var(--text-primary);cursor:pointer;transition:all .15s}.qa-vote:hover{border-color:var(--amber-400);color:var(--amber-300);background:#f59e0b1a}.qa-vote-on{background:#f59e0b33;border-color:var(--amber-500);color:var(--amber-300)}.qa-vote-arrow{font-size:12px;line-height:1}.qa-vote-count{font-weight:700;font-size:14px}.qa-text{min-width:0}.qa-q{margin:0 0 6px;font-size:14px;line-height:1.5;word-wrap:break-word;color:var(--text-primary);font-weight:500}.qa-meta{margin:0;font-size:11px;color:var(--text-secondary);display:flex;align-items:center;gap:8px;flex-wrap:wrap}.qa-author{font-weight:600;color:var(--text-primary)}.qa-tag-answered{display:inline-block;padding:1px 7px;border-radius:4px;background:#22c55e38;color:#86efac;font-weight:600}.qa-tag-private{display:inline-block;padding:1px 7px;border-radius:4px;background:#f59e0b38;color:var(--amber-300);font-weight:600}.qa-thread{list-style:none;margin:10px 0 8px;display:flex;flex-direction:column;gap:6px;border-left:2px solid rgba(255,255,255,.1);padding:0 0 0 10px}.qa-reply{padding:8px 10px;border-radius:6px;background:#ffffff0a;position:relative}.qa-reply-instructor{background:#22c55e1f;border-left:3px solid rgb(74,222,128)}.qa-reply-peer{background:#60a5fa14;border-left:3px solid rgba(96,165,250,.5)}.qa-reply-head{display:flex;align-items:center;gap:6px;font-size:11px;margin-bottom:3px}.qa-reply-author{font-weight:700;color:var(--text-primary)}.qa-reply-instructor .qa-reply-author{color:#86efac}.qa-reply-peer .qa-reply-author{color:#93c5fd}.qa-reply-age{color:var(--text-muted);font-size:10px}.qa-reply-x{margin-left:auto;background:transparent;border:0;color:var(--text-muted);cursor:pointer;font-size:10px;padding:2px 5px;border-radius:3px}.qa-reply-x:hover{background:#f871712e;color:#f87171}.qa-reply-text{font-size:13px;line-height:1.45;color:var(--text-primary);white-space:pre-wrap;word-wrap:break-word}.qa-reply-form{margin-top:8px;display:flex;gap:6px;align-items:center}.qa-reply-input{flex:1;padding:7px 10px;border-radius:999px;border:1px solid rgba(255,255,255,.15);background:#0000004d;color:var(--text-primary);font-family:inherit;font-size:13px}.qa-reply-input:focus{outline:none;border-color:var(--amber-500);background:#00000073}.qa-reply-input:disabled{opacity:.5}.qa-reply-send{background:var(--amber-500);color:#0f0f23;border:0;width:32px;height:32px;border-radius:50%;font-weight:700;cursor:pointer;font-size:14px;flex-shrink:0;transition:transform .1s,background .15s}.qa-reply-send:hover{background:#f97316}.qa-reply-send:active{transform:scale(.95)}.qa-thread-count{display:inline-block;padding:1px 7px;border-radius:4px;background:#60a5fa2e;color:#93c5fd;font-weight:600}.qa-actions{display:flex;gap:4px;flex-direction:column}.qa-act{background:#ffffff0a;border:1px solid rgba(255,255,255,.08);color:var(--text-secondary);cursor:pointer;font-size:14px;padding:6px 8px;border-radius:6px;transition:all .15s;min-width:30px;text-align:center}.qa-act:hover{background:#ffffff1a;color:var(--text-primary);border-color:#fff3}.qa-act-reply:hover,.qa-act-answered:hover{color:#4ade80;border-color:#4ade80}.qa-act-delete:hover{color:#f87171;border-color:#f87171}.qa-panel-form{padding:12px 14px 14px;border-top:1px solid rgba(255,255,255,.12);background:#0003;display:flex;flex-direction:column;gap:8px}.qa-panel-form textarea{width:100%;padding:10px 12px;border-radius:6px;border:1px solid rgba(255,255,255,.18);background:#0000004d;color:var(--text-primary);font-family:inherit;font-size:14px;resize:vertical;min-height:60px}.qa-panel-form textarea:focus{outline:none;border-color:var(--amber-500)}.qa-form-row{display:flex;align-items:center;justify-content:space-between;gap:8px;flex-wrap:wrap}.qa-private-toggle{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--text-secondary);cursor:pointer;-webkit-user-select:none;user-select:none}.qa-private-toggle input{accent-color:var(--amber-500)}.qa-private-toggle:hover{color:var(--text-primary)}@media(max-width:600px){.qa-panel{width:100vw}.qa-fab-label{display:none}}#rx-host{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:9499}.rx-bar{position:fixed;right:24px;bottom:80px;display:flex;flex-direction:column;gap:6px;padding:14px 6px 6px;background:#0f0f23c7;border:1px solid var(--border-subtle, rgba(255, 255, 255, .08));border-radius:999px;pointer-events:auto;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);cursor:grab;touch-action:none;-webkit-user-select:none;user-select:none}.rx-bar:before{content:"";display:block;width:22px;height:3px;margin:0 auto 4px;border-radius:2px;background:#ffffff59}.rx-bar:active{cursor:grabbing}.rx-btn{width:36px;height:36px;border-radius:50%;border:0;background:transparent;font-size:20px;cursor:pointer;transition:transform .15s,background .15s;line-height:1}.rx-btn:hover{background:#f59e0b2e;transform:scale(1.15)}.rx-btn:active{transform:scale(.95)}.rx-stage{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;overflow:hidden}.rx-floater{position:absolute;bottom:0;font-size:32px;opacity:0;pointer-events:none;animation:rx-float 2.4s ease-out forwards;text-shadow:0 2px 8px rgba(0,0,0,.5);will-change:transform,opacity}@keyframes rx-float{0%{transform:translateY(0) scale(.6);opacity:0}10%{transform:translateY(-30px) scale(1);opacity:1}60%{transform:translateY(-65vh) translate(-30px) scale(1.1);opacity:1}to{transform:translateY(-90vh) translate(40px) scale(.7);opacity:0}}@media(max-width:600px){.rx-bar{right:12px;bottom:76px;flex-direction:row;flex-wrap:wrap;max-width:220px}.rx-btn{width:32px;height:32px;font-size:18px}}.budget-total{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;margin-bottom:var(--sp-3);border-radius:8px;background:#ffffff08;border:1px solid var(--border-subtle, rgba(255, 255, 255, .08));font-weight:600}.budget-total-num{font-size:28px;font-weight:800}.budget-total.over .budget-total-num{color:#f87171}.budget-total.exact .budget-total-num{color:#4ade80}.budget-total-status{font-size:var(--text-xs);color:var(--text-muted)}.budget-row{display:grid;grid-template-columns:1fr 80px 100px;gap:var(--sp-3);align-items:center;padding:10px 0;border-bottom:1px solid var(--border-subtle, rgba(255, 255, 255, .05))}.budget-row:last-child{border-bottom:0}.budget-label{font-weight:500;font-size:var(--text-sm)}.budget-input{width:80px;padding:6px 10px;border-radius:6px;border:1px solid var(--border-subtle, rgba(255, 255, 255, .1));background:#0003;color:var(--text-primary);text-align:right;font-weight:700;font-family:inherit}.budget-input:focus{outline:none;border-color:var(--amber-500)}.budget-slider{width:100px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent}.budget-slider::-webkit-slider-runnable-track{height:4px;background:#ffffff1a;border-radius:2px}.budget-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:14px;height:14px;background:var(--amber-500);border-radius:50%;margin-top:-5px;cursor:pointer}.r-budget-bars{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--sp-2)}.r-budget-row{display:grid;grid-template-columns:1fr auto;gap:var(--sp-3);align-items:center}.r-budget-bar-wrap{height:28px;background:#ffffff0a;border-radius:6px;overflow:hidden;position:relative}.r-budget-fill{height:100%;background:linear-gradient(90deg,var(--amber-500),#f97316);transition:width .4s ease}.r-budget-text{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;padding:0 10px;font-size:13px;font-weight:600}.r-budget-avg{font-weight:700;color:var(--amber-300);white-space:nowrap}body[data-protect="1"]{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;-webkit-touch-callout:none}body[data-protect="1"] input,body[data-protect="1"] textarea,body[data-protect="1"] select,body[data-protect="1"] [contenteditable=true]{-webkit-user-select:text;-moz-user-select:text;-ms-user-select:text;user-select:text}body[data-protect="1"] img{-webkit-user-drag:none;user-drag:none}body[data-protect="1"] #btn-print{display:none}.copy-watermark{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:9990;background-repeat:repeat;background-position:0 0;opacity:.13;mix-blend-mode:lighten}.copy-toast{position:fixed;bottom:24px;left:50%;transform:translate(-50%,16px);background:#0f0f23f0;color:#fde68a;padding:10px 18px;border-radius:8px;font-size:13px;font-weight:500;border:1px solid rgba(245,158,11,.4);box-shadow:0 6px 24px #00000073;opacity:0;transition:opacity .25s ease,transform .25s ease;pointer-events:none;z-index:100000;white-space:nowrap;max-width:calc(100vw - 48px)}.copy-toast.show{opacity:1;transform:translate(-50%)}@media print{body[data-protect="1"] *{visibility:hidden!important}body[data-protect="1"] .copy-watermark{visibility:visible!important;opacity:.25!important}body[data-protect="1"]:after{content:"Nội dung được bảo vệ bản quyền — không thể in. Content is copyright-protected.";visibility:visible!important;position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;padding:32px;text-align:center;font-family:Inter,system-ui,sans-serif;font-size:22px;color:#0f0f23;background:#fff}}.homework-page h1{font-size:1.5rem;margin:0}.hw-list-table{width:100%;border-collapse:collapse;background:var(--bg-card);border-radius:8px;overflow:hidden}.hw-list-table th,.hw-list-table td{padding:.75rem 1rem;border-bottom:1px solid var(--border-default);text-align:left;color:var(--text-primary)}.hw-list-table th{background:var(--bg-elevated);font-weight:600;font-size:.875rem;color:var(--text-primary)}.hw-list-table tbody tr:hover{background:var(--bg-elevated)}.hw-list-table .hw-actions{display:flex;gap:.4rem;justify-content:flex-end}.hw-flag{display:inline-block;margin-left:.4rem;padding:.125rem .5rem;background:var(--bg-elevated);color:var(--text-muted);border-radius:999px;font-size:.7rem;font-weight:500}.hw-list-toolbar{display:flex;gap:1rem;align-items:center;flex-wrap:wrap;padding:.5rem 0 .75rem}.hw-list-toolbar label{display:flex;gap:.4rem;align-items:center;font-size:.875rem}.hw-list-toolbar .input{padding:.3rem .5rem}.hw-progress{margin-top:.25rem;height:4px;background:var(--bg-elevated);border-radius:2px;overflow:hidden;max-width:120px}.hw-progress-bar{height:100%;background:linear-gradient(90deg,#2563eb,#10b981);transition:width .2s}.hw-badge-late{display:inline-block;min-width:1.5rem;padding:.125rem .5rem;background:#fed7aa;color:#c2410c;border-radius:999px;font-weight:600;font-size:.875rem;text-align:center}.hw-cohort-bar{display:flex;gap:.4rem;align-items:flex-start;flex-wrap:wrap;padding:.75rem;margin-bottom:.75rem;background:var(--bg-elevated);border-radius:8px;flex-direction:column}.hw-cohort-bar .btn{padding:.25rem .6rem}.hw-cohort-pill{display:inline-flex;align-items:center;gap:.4rem;padding:.3rem .7rem;border:1px solid var(--border-default);border-radius:999px;cursor:pointer;background:var(--bg-card);font-size:.875rem;-webkit-user-select:none;user-select:none;transition:background .12s,border-color .12s}.hw-cohort-pill input{margin:0}.hw-cohort-pill.on,.hw-cohort-pill:has(input:checked){background:#eff6ff;border-color:#2563eb;color:#1e3a8a;font-weight:500}.hw-via-cohort-pill{display:inline-block;padding:.1rem .5rem;background:#ecfdf5;color:#047857;border-radius:999px;font-size:.75rem;font-weight:500}.hw-cohort-member-row{display:flex;gap:.5rem;align-items:center;padding:.25rem .4rem;border-radius:4px;cursor:pointer}.hw-cohort-member-row:hover{background:var(--bg-elevated)}.hw-ai-suggest{margin:.75rem 0;padding:.5rem .75rem;background:#eff6ff;border-left:3px solid #2563eb;border-radius:6px;font-size:.875rem}.hw-ai-rationale{margin-top:.4rem;color:var(--text-secondary);font-style:italic}.hw-comments-block{margin-top:.75rem;padding-top:.5rem;border-top:1px dashed var(--border-default)}.hw-comments-block summary{cursor:pointer;font-weight:500;color:var(--text-muted)}.hw-comments-count{color:var(--text-muted);font-weight:400}.hw-comments-list{padding:.5rem 0;display:flex;flex-direction:column;gap:.5rem}.hw-comment{background:var(--bg-elevated);border-radius:6px;padding:.5rem .75rem;font-size:.875rem}.hw-comment-head{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap;margin-bottom:.25rem}.hw-comment-head .btn{margin-left:auto;padding:0 .4rem}.hw-comment-role{font-size:.7rem;text-transform:uppercase;padding:.1rem .4rem;background:var(--bg-card);border-radius:4px;color:var(--text-muted)}.hw-comment-text{white-space:pre-wrap}.hw-comments-add{display:flex;gap:.5rem;align-items:flex-end;margin-top:.5rem}.hw-comments-add textarea{flex:1}.hw-resubmit-banner{margin:.75rem 0;padding:.6rem .9rem;background:#ecfdf5;color:#047857;border-radius:6px;font-weight:500}.hw-rev-badge{display:inline-block;padding:.125rem .5rem;background:#ede9fe;color:#6d28d9;border-radius:999px;font-size:.75rem;font-weight:600}.hw-revisions-block{margin-top:.75rem;padding-top:.5rem;border-top:1px dashed var(--border-default)}.hw-revisions-block summary{cursor:pointer;font-weight:500;color:var(--text-muted)}.hw-revisions-list{display:flex;flex-direction:column;gap:.5rem;padding:.5rem 0}.hw-revision{border:1px solid var(--border-default);border-left:3px solid #8b5cf6;border-radius:6px;padding:.6rem .8rem;background:var(--bg-elevated);font-size:.875rem}.hw-revision-head{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap;margin-bottom:.4rem}.hw-revision-text{white-space:pre-wrap;background:var(--bg-card);padding:.4rem .6rem;border-radius:4px;margin:.4rem 0}.hw-revision-attachments{display:flex;gap:.4rem;flex-wrap:wrap;margin:.4rem 0}.hw-revision-feedback{margin-top:.4rem;padding:.4rem .6rem;background:#fffbeb;border-left:3px solid #f59e0b;border-radius:4px}.hw-deadline-tag{display:inline-block;margin-left:.5rem;padding:.125rem .5rem;background:#ecfdf5;color:#047857;border-radius:999px;font-size:.75rem;font-weight:500}.hw-deadline-tag.overdue{background:#fef2f2;color:#b91c1c}.hw-deadline-tag.urgent{background:#fffbeb;color:#b45309}.hw-form label{display:flex;flex-direction:column;gap:.25rem;font-weight:500}.hw-form label>span{color:var(--text-muted);font-size:.875rem;font-weight:500}.hw-limits{border:1px solid var(--border-default);border-radius:8px;padding:.75rem 1rem;display:flex;gap:1rem;flex-wrap:wrap}.hw-limits legend{padding:0 .4rem;font-weight:600}.hw-limits label{flex-direction:row;align-items:center;gap:.4rem}.hw-limits input{width:5rem}.hw-block{border:1px solid var(--border-default);border-radius:8px;padding:.75rem;margin-bottom:.5rem;display:grid;gap:.5rem;background:var(--bg-card)}.hw-block-head{display:flex;justify-content:space-between;align-items:center}.hw-reminders{border:1px solid var(--border-default);border-radius:8px;padding:1rem}.hw-reminders legend{padding:0 .4rem;font-weight:600}.hw-reminders h4{font-size:.95rem;color:var(--text-muted)}.hw-offset-row{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap;padding:.4rem 0;border-bottom:1px dashed var(--border-default)}.hw-offset-row:last-child{border-bottom:0}.hw-offset-row .input{width:auto}.hw-matrix-table{width:100%;border-collapse:collapse;margin-top:.5rem}.hw-matrix-table th,.hw-matrix-table td{padding:.5rem .75rem;border-bottom:1px solid var(--border-default);text-align:left;color:var(--text-primary)}.hw-matrix-table th{background:var(--bg-elevated);font-size:.875rem;color:var(--text-primary)}.hw-status{display:inline-block;padding:.125rem .5rem;background:#f3f4f6;color:#374151;border-radius:999px;font-size:.75rem;font-weight:500}.hw-status-draft{background:#fef3c7;color:#92400e}.hw-status-submitted{background:#dbeafe;color:#1e40af}.hw-status-late{background:#fed7aa;color:#c2410c}.hw-status-graded{background:#d1fae5;color:#065f46}.hw-status-none{background:#f3f4f6;color:#6b7280}.hw-sub-card{margin-bottom:.75rem}.hw-sub-head{display:flex;gap:.75rem;align-items:center;flex-wrap:wrap;margin-bottom:.5rem}.hw-sub-text{background:var(--bg-elevated);border-radius:6px;padding:.75rem;margin:.5rem 0;white-space:pre-wrap}.hw-attachments{display:flex;gap:.5rem;flex-wrap:wrap;margin:.5rem 0}.hw-attachments img{max-width:160px;max-height:120px;border-radius:6px}.hw-attachments audio{max-width:280px}.hw-attachments video{max-width:280px;max-height:180px;border-radius:6px}.hw-doc{display:inline-block;padding:.4rem .75rem;background:var(--bg-elevated);border-radius:6px;text-decoration:none;color:var(--text, #1f2937)}.hw-grade-row{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap;margin-top:.5rem}.hw-grade-row .input{flex:1 1 auto;min-width:120px}.hw-student-list{display:grid;gap:.75rem}.hw-student-card{display:block;padding:1rem 1.25rem;text-decoration:none;color:var(--text-primary);background:var(--bg-card);border:1px solid var(--border-default);border-radius:8px;transition:box-shadow .12s ease}.hw-student-card:hover{box-shadow:0 4px 12px #00000014;border-color:var(--accent, #2563eb)}.hw-student-card-head{display:flex;gap:.75rem;justify-content:space-between;align-items:baseline;margin-bottom:.25rem}.hw-student-card-meta{color:var(--text-muted);font-size:.875rem}.hw-grade-pill{display:inline-block;margin-top:.4rem;padding:.25rem .6rem;background:#d1fae5;color:#065f46;border-radius:999px;font-size:.875rem}.hw-instructions{background:#f0f9ff}.hw-do-block{padding:.75rem;margin-bottom:.5rem;border-radius:6px;background:var(--bg-elevated)}.hw-do-prompt{border-left:3px solid var(--accent, #2563eb);background:#eff6ff}.hw-upload-row{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap;margin-top:.75rem}.hw-upload-row .input[type=file]{padding:.25rem}.hw-att-row{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap;padding:.5rem;border-radius:6px;background:var(--bg-elevated);margin-bottom:.4rem}.hw-att-row img{max-width:100px;max-height:80px;border-radius:4px}.hw-att-row audio{max-width:220px}.hw-att-row video{max-width:220px;max-height:140px;border-radius:4px}.hw-att-kind{font-size:.7rem;font-weight:600;text-transform:uppercase;padding:.1rem .4rem;background:var(--bg-card);border-radius:4px}.hw-deadline-banner{margin-top:.5rem;padding:.6rem .9rem;border-radius:8px;font-weight:500}.hw-deadline-banner.warn{background:#fef3c7;color:#92400e}.hw-deadline-banner.over{background:#fef2f2;color:#b91c1c}.hw-submit-row{display:flex;gap:.5rem;justify-content:flex-end;align-items:center;margin-top:1rem}@media(max-width:720px){.hw-list-table,.hw-matrix-table{display:block;overflow-x:auto;white-space:nowrap}.hw-grade-row,.hw-upload-row{flex-direction:column;align-items:stretch}.hw-grade-row .input,.hw-upload-row .input{width:100%}}
