:root{--primary:#00a651;--primary-dark:#007a3d;--primary-darker:#005c2d;--primary-light:#e6f6ee;--accent-blue:#007bff;--warning:#ffb300;--error:#e53935;--bg:#f0f2f5;--bg-chat:#efeae2;--surface:#fff;--surface-alt:#f7faf8;--text:#111b21;--text-muted:#667781;--text-light:#8696a0;--divider:#e9edef;--border:#e3ebe6;--shadow-sm:0 1px 1px #0b141a0f;--shadow-md:0 4px 12px #0b141a1a;--shadow-fab:0 4px 12px #007a3d52;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:20px;--header-h:56px;--bottom-nav-h:60px;--sans:system-ui, "Segoe UI", Roboto, -apple-system, sans-serif;font-family:var(--sans);color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:15px;line-height:1.45}*{box-sizing:border-box}html,body,#root{min-height:100vh;margin:0;padding:0}body{background:var(--bg)}h1,h2,h3,h4{color:var(--text);letter-spacing:-.01em;margin:0;font-weight:600}h1{font-size:24px}h2{font-size:20px}h3{font-size:17px}h4{font-size:15px}p{margin:0}a{color:var(--primary-dark);text-decoration:none}a:hover{color:var(--primary-darker)}button{cursor:pointer;font-family:inherit}input,select,textarea{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--surface);width:100%;color:var(--text);outline:none;padding:12px 14px;font-family:inherit;font-size:15px;transition:border-color .15s,box-shadow .15s}input:focus,select:focus,textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px #00a65126}textarea{resize:vertical;min-height:100px}label{color:var(--text-muted);margin-bottom:6px;font-size:13px;font-weight:500;display:block}.form-group{margin-bottom:16px}.form-group.checkbox-row{align-items:center;gap:10px;margin-bottom:12px;display:flex}.form-group.checkbox-row input[type=checkbox]{width:18px;height:18px;accent-color:var(--primary);cursor:pointer;flex-shrink:0}.form-group.checkbox-row label{color:var(--text);cursor:pointer;margin:0;font-size:14px}.badge{letter-spacing:.02em;text-transform:capitalize;border-radius:999px;align-items:center;padding:3px 10px;font-size:11px;font-weight:600;display:inline-flex}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.spin{animation:.9s linear infinite spin}.error-banner{color:#a22622;border-radius:var(--radius-md);background:#ffe2e1;border:1px solid #ffb9b7;justify-content:space-between;align-items:center;gap:10px;margin-bottom:16px;padding:12px 14px;font-size:14px;display:flex}.page-loading{color:var(--primary-dark);justify-content:center;align-items:center;padding:48px 16px;display:flex}.badge-success{background:var(--primary-light);color:var(--primary-dark)}.badge-warning{color:#8a5a00;background:#fff3d6}.badge-error{color:#a22622;background:#ffe2e1}.badge-muted{color:var(--text-muted);background:#eef2ef}.badge-info{color:#0056b3;background:#e0efff}.wa-list{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden}.wa-row{cursor:pointer;border-bottom:1px solid var(--divider);align-items:center;gap:14px;padding:12px 16px;transition:background .12s;display:flex}.wa-row:last-child{border-bottom:none}.wa-row:hover{background:var(--surface-alt)}.wa-row:active{background:var(--divider)}.wa-row-body{flex:1;min-width:0}.wa-row-top{justify-content:space-between;align-items:baseline;gap:8px;margin-bottom:2px;display:flex}.wa-row-name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:16px;font-weight:600;overflow:hidden}.wa-row-time{color:var(--text-muted);flex-shrink:0;font-size:12px}.wa-row-bottom{justify-content:space-between;align-items:center;gap:8px;display:flex}.wa-row-sub{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;flex:1;min-width:0;font-size:14px;overflow:hidden}.wa-row-trail{color:var(--text-muted);flex-shrink:0;font-size:12px}.wa-section-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;padding:16px 4px 8px;font-size:13px;font-weight:600}.avatar{color:#fff;border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;font-weight:600;display:inline-flex}.avatar-sm{width:32px;height:32px;font-size:12px}.avatar-md{width:42px;height:42px;font-size:14px}.avatar-lg{width:64px;height:64px;font-size:22px}.layout{background:var(--bg);min-height:100vh;display:flex}.sidebar{background:var(--surface);border-right:1px solid var(--border);flex-direction:column;width:240px;height:100vh;padding:20px 14px;display:flex;position:sticky;top:0}.sidebar-brand{cursor:pointer;border-bottom:1px solid var(--border);align-items:center;gap:10px;margin-bottom:16px;padding:4px 8px 20px;display:flex}.brand-mark{border-radius:var(--radius-md);background:var(--primary);color:#fff;justify-content:center;align-items:center;width:36px;height:36px;font-size:18px;font-weight:700;display:flex}.brand-mark-sm{width:28px;height:28px;font-size:14px}.brand-name{color:var(--text);font-size:16px;font-weight:700}.brand-sub{color:var(--text-muted);font-size:11px}.sidebar-nav{flex-direction:column;flex:1;gap:2px;display:flex;overflow-y:auto}.nav-item{border-radius:var(--radius-md);color:var(--text-muted);align-items:center;gap:12px;padding:10px 12px;font-size:14px;font-weight:500;transition:background .15s,color .15s;display:flex}.nav-item:hover{background:var(--bg);color:var(--text)}.nav-item-active{background:var(--primary-light);color:var(--primary-dark)}.sidebar-footer{border-top:1px solid var(--border);align-items:center;gap:10px;margin-top:12px;padding:12px 10px;display:flex}.sidebar-user{min-width:0}.sidebar-user-name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.sidebar-user-role{color:var(--text-muted);font-size:11px}.sidebar-logout{border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:6px;transition:background .15s,color .15s;display:inline-flex}.sidebar-logout:hover{background:var(--bg);color:var(--error)}.main-wrap{flex-direction:column;flex:1;min-width:0;display:flex}.topbar{height:var(--header-h);background:var(--primary-dark);color:#fff;z-index:20;justify-content:space-between;align-items:center;padding:0 6px 0 16px;display:none;position:sticky;top:0;box-shadow:0 1px 3px #00000026}.topbar-title{letter-spacing:.01em;font-size:19px;font-weight:600}.topbar-actions{align-items:center;display:flex}.topbar-icon-btn{color:#fff;cursor:pointer;background:0 0;border:none;border-radius:999px;justify-content:center;align-items:center;width:40px;height:40px;transition:background .15s;display:inline-flex}.topbar-icon-btn:hover{background:#ffffff1f}.topbar-icon-btn:active{background:#fff3}.topbar-menu{background:var(--surface);border-radius:var(--radius-md);box-shadow:var(--shadow-md);z-index:30;flex-direction:column;min-width:160px;padding:6px;display:flex;position:absolute;top:48px;right:8px}.topbar-menu button{text-align:left;color:var(--text);border-radius:var(--radius-sm);cursor:pointer;background:0 0;border:none;padding:10px 14px;font-size:14px}.topbar-menu button:hover{background:var(--surface-alt)}.topbar-menu-backdrop{z-index:25;position:fixed;inset:0}.content{flex:1;width:100%;max-width:1200px;margin:0 auto;padding:28px 32px 40px}.bottom-nav{background:var(--surface);border-top:1px solid var(--border);z-index:10;height:var(--bottom-nav-h);display:none;position:sticky;bottom:0;box-shadow:0 -1px 3px #0000000a}.bottom-nav-item{color:var(--text-muted);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:3px;padding:6px 4px;transition:color .15s;display:flex}.bottom-nav-item-active{color:var(--primary-dark)}.bottom-nav-item-active svg{stroke-width:2.4px}.bottom-nav-label{font-size:11px;font-weight:500}@media (width<=860px){.sidebar{display:none}.topbar,.bottom-nav{display:flex}.content{padding:14px 14px 80px}}.pwa-prompt{left:50%;bottom:calc(var(--bottom-nav-h,60px) + 16px);z-index:50;background:var(--surface);border:1px solid var(--divider);border-radius:var(--radius-lg);align-items:center;gap:12px;min-width:300px;max-width:calc(100vw - 32px);padding:12px 14px;animation:.25s ease-out pwa-slide-in;display:flex;position:fixed;transform:translate(-50%);box-shadow:0 10px 30px #0b141a26}@keyframes pwa-slide-in{0%{opacity:0;transform:translate(-50%,16px)}to{opacity:1;transform:translate(-50%)}}.pwa-prompt-icon{background:var(--primary-light);width:36px;height:36px;color:var(--primary-dark);border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;display:inline-flex}.pwa-prompt-update .pwa-prompt-icon{color:#0056b3;background:#e0efff}.pwa-prompt-body{flex:1;min-width:0}.pwa-prompt-title{color:var(--text);font-size:14px;font-weight:600}.pwa-prompt-desc{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;margin-top:2px;font-size:12px;overflow:hidden}.pwa-prompt-primary{background:var(--primary);color:#fff;border-radius:var(--radius-md);cursor:pointer;border:none;flex-shrink:0;padding:8px 14px;font-size:13px;font-weight:600;transition:background .15s}.pwa-prompt-primary:hover{background:var(--primary-dark)}.pwa-prompt-dismiss{color:var(--text-muted);cursor:pointer;border-radius:var(--radius-sm);background:0 0;border:none;flex-shrink:0;padding:6px;transition:background .15s;display:inline-flex}.pwa-prompt-dismiss:hover{background:var(--bg);color:var(--text)}@media (width>=861px){.pwa-prompt{bottom:24px;left:auto;right:24px;transform:none}@keyframes pwa-slide-in{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}}.btn{border-radius:var(--radius-md);cursor:pointer;white-space:nowrap;border:1px solid #0000;justify-content:center;align-items:center;gap:8px;font-weight:500;line-height:1;transition:background .15s,transform 50ms,box-shadow .15s;display:inline-flex}.btn:active{transform:translateY(1px)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-sm{padding:8px 12px;font-size:13px}.btn-md{padding:12px 18px;font-size:14px}.btn-lg{padding:14px 22px;font-size:16px}.btn-full{width:100%}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-dark)}.btn-secondary{background:var(--primary-light);color:var(--primary-dark)}.btn-secondary:hover{background:#d4eedf}.btn-ghost{color:var(--text);border-color:var(--border);background:0 0}.btn-ghost:hover{background:var(--bg)}.btn-danger{background:var(--error);color:#fff}.btn-danger:hover{background:#c32b27}.btn-icon{align-items:center;font-size:16px;display:inline-flex}.landing{background:var(--bg);min-height:100vh;color:var(--text);flex-direction:column;display:flex}.landing-nav-wrap{z-index:50;-webkit-backdrop-filter:saturate(180%)blur(12px);background:#ffffffd9;border-bottom:1px solid #0000000f;position:sticky;top:0}.landing-nav{box-sizing:border-box;justify-content:space-between;align-items:center;width:100%;max-width:1180px;margin:0 auto;padding:14px 20px;display:flex}.landing-brand{align-items:center;gap:10px;font-size:17px;font-weight:700;display:flex}.landing-nav-actions{align-items:center;gap:12px;display:flex}.landing-nav-link{color:var(--text);cursor:pointer;background:0 0;border:none;padding:6px 4px;font-size:14px;font-weight:600}.landing-nav-link:hover{color:var(--primary-dark)}.landing-hero{box-sizing:border-box;grid-template-columns:1fr;align-items:center;gap:28px;width:100%;max-width:1180px;margin:0 auto;padding:28px 20px 12px;display:grid}.landing-pill{background:var(--primary-light);color:var(--primary-dark);letter-spacing:.04em;text-transform:uppercase;border-radius:999px;align-items:center;gap:6px;margin-bottom:18px;padding:6px 12px;font-size:11px;font-weight:700;display:inline-flex}.landing-hero h1{letter-spacing:-.02em;color:var(--text);margin:0 0 14px;font-size:32px;line-height:1.08}.landing-hero p{color:var(--text-muted);max-width:520px;margin:0 0 28px;font-size:15px;line-height:1.55}.landing-cta{flex-direction:column;align-items:flex-start;gap:12px;display:flex}.landing-cta-link{color:var(--primary-dark);cursor:pointer;background:0 0;border:none;padding:4px 2px;font-size:14px;font-weight:600}.landing-cta-link:hover{text-decoration:underline}.landing-hero-visual{display:none;position:relative}.hero-card{background:var(--surface);border:1px solid var(--divider);border-radius:var(--radius-xl);padding:18px 18px 16px;box-shadow:0 24px 60px #0050281a}.hero-card-front{z-index:2;position:relative}.hero-card-back{z-index:1;background:var(--primary-light);border-color:#00502814;width:92%;position:absolute;bottom:-32px;right:-8px;box-shadow:0 18px 40px #0050281a}.hero-card-eyebrow{letter-spacing:.04em;text-transform:uppercase;color:var(--primary-dark);background:var(--primary-light);border-radius:999px;align-items:center;gap:6px;margin-bottom:12px;padding:4px 10px;font-size:11px;font-weight:700;display:inline-flex}.hero-card-name{margin-bottom:12px;font-size:15px;font-weight:700}.hero-card-row{grid-template-columns:88px 1fr;align-items:center;margin-bottom:6px;font-size:13px;display:grid}.hero-card-label{color:var(--text-muted)}.hero-card-value{font-weight:600}.hero-card-pill{color:#8a5a00;background:#fff3d6;border-radius:999px;padding:2px 10px;font-size:12px;font-weight:700;display:inline-block}.hero-card-pill.warn{color:#8a5a00;background:#fff3d6}.hero-card-divider{background:var(--divider);height:1px;margin:12px 0}.hero-card-section-label{text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin-bottom:8px;font-size:11px;font-weight:700}.hero-card-list{color:var(--text);flex-direction:column;gap:8px;margin:0 0 12px;padding:0;font-size:13px;list-style:none;display:flex}.hero-card-list li{align-items:flex-start;gap:10px;line-height:1.4;display:flex}.dot{border-radius:999px;flex-shrink:0;width:8px;height:8px;margin-top:6px;display:inline-block}.dot-red{background:#d6443a}.hero-card-foot{color:var(--text-muted);border-top:1px dashed var(--divider);padding-top:10px;font-size:12px;font-style:italic}.hero-card-mini{color:var(--primary-dark);font-size:13px;line-height:1.5}.landing-section{box-sizing:border-box;width:100%;max-width:1180px;margin:0 auto;padding:48px 20px 16px}.landing-section-head{text-align:center;margin-bottom:28px}.landing-eyebrow{letter-spacing:.08em;text-transform:uppercase;color:var(--primary-dark);margin-bottom:10px;font-size:11px;font-weight:700;display:inline-block}.landing-eyebrow.on-dark{color:#ffffffd9}.landing-section-title{letter-spacing:-.015em;margin:0 0 8px;font-size:24px;line-height:1.15}.landing-section-sub{color:var(--text-muted);max-width:560px;margin:0 auto;font-size:14px;line-height:1.5}.landing-features{grid-template-columns:1fr;gap:14px;margin-top:28px;display:grid}.landing-feature{background:var(--surface);border:1px solid var(--divider);border-radius:18px;flex-direction:column;gap:14px;padding:22px 22px 24px;transition:transform .16s,border-color .16s,box-shadow .16s;display:flex;position:relative;overflow:hidden}.landing-feature:before{content:"";background:linear-gradient(90deg, var(--primary-dark) 0%, #00502840 100%);opacity:0;height:3px;transition:opacity .16s;position:absolute;inset:0 0 auto}.landing-feature:hover{border-color:#00502833;transform:translateY(-2px);box-shadow:0 14px 28px #00502814}.landing-feature:hover:before{opacity:1}.landing-feature-icon{background:linear-gradient(135deg, var(--primary-light) 0%, #0050281a 100%);width:44px;height:44px;color:var(--primary-dark);border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;display:flex;box-shadow:inset 0 0 0 1px #00502814}.landing-feature h3{letter-spacing:-.015em;color:var(--text);margin:0;font-size:16px;line-height:1.25}.landing-feature p{color:var(--text-muted);margin:0;font-size:13.5px;line-height:1.6}.landing-centre{box-sizing:border-box;width:100%;max-width:1180px;margin:32px auto 0;padding:0 20px}.landing-centre-inner{background:linear-gradient(135deg, var(--primary-dark) 0%, #0d6a3a 100%);border-radius:var(--radius-xl);color:#fff;grid-template-columns:1fr;gap:24px;padding:28px 24px;display:grid}.landing-centre-text h2{letter-spacing:-.015em;color:#fff;margin:0 0 12px;font-size:22px;line-height:1.2}.landing-centre-text p{color:#ffffffd9;margin:0 0 22px;font-size:14px;line-height:1.55}.landing-centre-stats{grid-template-columns:1fr;gap:10px;display:grid}.landing-stat{border-radius:var(--radius-lg);background:#ffffff1a;border:1px solid #ffffff26;padding:16px 18px}.landing-stat-value{color:#fff;letter-spacing:-.01em;font-size:22px;font-weight:800}.landing-stat-label{color:#ffffffbf;margin-top:2px;font-size:12px}.landing-footer{text-align:center;color:var(--text-muted);margin-top:auto;padding:36px 20px;font-size:12px}@media (width>=640px){.landing-hero{padding:40px 24px 24px}.landing-hero h1{font-size:38px}.landing-cta{flex-direction:row;align-items:center}.landing-features{grid-template-columns:1fr 1fr;gap:16px}.landing-section-title{font-size:28px}.landing-centre-inner{padding:36px 32px}.landing-centre-stats{grid-template-columns:repeat(3,1fr)}}@media (width>=860px){.landing-hero{grid-template-columns:1.05fr .95fr;gap:48px;padding:56px 32px 40px}.landing-hero h1{font-size:46px}.landing-hero-visual{display:block}.landing-centre-inner{grid-template-columns:1.1fr 1fr;align-items:center;gap:36px;padding:44px 40px}.landing-centre-stats{grid-template-columns:1fr;gap:12px}}@media (width>=1100px){.landing-nav{padding:22px 32px}.landing-hero{gap:64px;padding:72px 32px 56px}.landing-hero h1{font-size:56px;line-height:1.02}.landing-hero p{max-width:540px;font-size:16px}.landing-section{padding:80px 32px 24px}.landing-section-title{font-size:36px}.landing-section-sub{font-size:15px}.landing-features{grid-template-columns:repeat(3,1fr);gap:18px;margin-top:32px}.landing-feature{padding:22px}.landing-feature h3{font-size:16px}.landing-feature p{font-size:14px}.landing-centre{margin:64px auto 24px}.landing-centre-inner{padding:56px 48px}.landing-centre-text h2{font-size:30px;line-height:1.15}.landing-centre-text p{font-size:15px}}.auth-screen{background:linear-gradient(135deg, var(--primary-light) 0%, var(--bg) 60%);justify-content:center;align-items:center;min-height:100vh;padding:24px 16px;display:flex}.auth-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);width:100%;max-width:520px;box-shadow:var(--shadow-md);padding:32px}.auth-brand{align-items:center;gap:10px;margin-bottom:20px;font-weight:700;display:flex}.auth-card h1{margin-bottom:4px;font-size:24px}.auth-sub{color:var(--text-muted);margin-bottom:24px;font-size:14px}.auth-row{grid-template-columns:1fr 1fr;gap:12px;display:grid}.auth-footer{text-align:center;color:var(--text-muted);margin-top:20px;font-size:14px}.chip-group{flex-wrap:wrap;gap:8px;display:flex}.chip{background:var(--bg);border:1px solid var(--border);color:var(--text);cursor:pointer;border-radius:999px;padding:8px 14px;font-size:13px;font-weight:500;transition:all .15s}.chip:hover{border-color:var(--primary)}.chip-active{background:var(--primary);color:#fff;border-color:var(--primary)}.auth-toggle{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-md);margin-bottom:20px;padding:4px;display:flex}.auth-toggle button{border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;background:0 0;border:none;flex:1;padding:8px;font-size:13px;font-weight:500}.auth-toggle-active{box-shadow:var(--shadow-sm);background:var(--surface)!important;color:var(--primary-dark)!important}@media (width<=500px){.auth-row{grid-template-columns:1fr}.auth-card{padding:24px 20px}}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:box-shadow .15s,transform .15s}.card-pad-sm{padding:12px}.card-pad-md{padding:18px}.card-pad-lg{padding:24px}.card-clickable{cursor:pointer}.card-clickable:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.card-header{justify-content:space-between;align-items:center;margin-bottom:14px;display:flex}.card-header h3{font-size:16px;font-weight:600}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);align-items:flex-start;gap:14px;padding:18px;display:flex}.stat-icon{border-radius:var(--radius-md);flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:20px;display:flex}.stat-primary .stat-icon{background:var(--primary-light);color:var(--primary-dark)}.stat-blue .stat-icon{color:#0056b3;background:#e0efff}.stat-warning .stat-icon{color:#8a5a00;background:#fff3d6}.stat-error .stat-icon{color:#a22622;background:#ffe2e1}.stat-body{min-width:0}.stat-value{color:var(--text);font-size:26px;font-weight:700;line-height:1.1}.stat-label{color:var(--text-muted);margin-top:2px;font-size:13px}.stat-hint{color:var(--primary-dark);margin-top:6px;font-size:12px}.dashboard-stats{grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:20px;display:grid}@media (width>=700px){.dashboard-stats{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:14px}}.dashboard-grid{grid-template-columns:1fr;gap:14px;display:grid}@media (width>=860px){.dashboard-grid{grid-template-columns:1fr 1fr;gap:18px}}.quick-actions{grid-template-columns:1fr 1fr;gap:10px;display:grid}.qa-tile{background:var(--primary-light);color:var(--primary-dark);border-radius:var(--radius-md);cursor:pointer;border:1px solid #0000;flex-direction:column;justify-content:center;align-items:center;gap:8px;padding:18px 12px;font-size:13px;font-weight:600;transition:transform .1s,background .15s;display:flex}.qa-tile:hover{background:#d4eedf}.qa-tile:active{transform:scale(.98)}.qa-tile.qa-primary{background:var(--primary);color:#fff}.qa-tile.qa-primary:hover{background:var(--primary-dark)}.activity-list{flex-direction:column;display:flex}.activity-item{border-bottom:1px solid var(--divider);align-items:center;gap:12px;padding:10px 6px;display:flex}.activity-item:last-child{border-bottom:none}.activity-icon{border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.activity-student_added{background:var(--primary-light);color:var(--primary-dark)}.activity-quiz_completed{color:#0056b3;background:#e0efff}.activity-note_added{color:#6f42c1;background:#f1e8ff}.activity-alert{color:#a22622;background:#ffe2e1}.activity-body{flex:1;min-width:0}.activity-title{color:var(--text);font-size:14px;font-weight:500;line-height:1.35}.activity-meta{color:var(--text-muted);margin-top:2px;font-size:12px}.mini-student-list{flex-direction:column;display:flex}.mini-student{border-bottom:1px solid var(--divider);cursor:pointer;align-items:center;gap:12px;padding:10px 6px;transition:background .12s;display:flex}.mini-student:last-child{border-bottom:none}.mini-student:hover{background:var(--surface-alt)}.mini-student-body{flex:1;min-width:0}.mini-student-name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:15px;font-weight:600;overflow:hidden}.mini-student-meta{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;font-size:13px;overflow:hidden}.alert-list{flex-direction:column;gap:10px;display:flex}.alert-item{background:var(--surface-alt);border-radius:var(--radius-md);gap:12px;padding:12px;display:flex}.alert-stripe{border-radius:2px;flex-shrink:0;width:4px}.alert-high{background:var(--error)}.alert-medium{background:var(--warning)}.alert-low{background:var(--accent-blue)}.alert-body{flex:1}.alert-title{color:var(--text);font-size:14px;font-weight:600}.alert-desc{color:var(--text-muted);margin-top:2px;font-size:12px;line-height:1.45}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:18px;display:flex}.page-header h1{margin-bottom:2px;font-size:22px;font-weight:700}.page-header-sub{color:var(--text-muted);font-size:13px}.page-header-action{gap:8px;display:flex}@media (width<=860px){.page-header-action{display:none}.page-header h1{font-size:20px}.page-header{margin-bottom:14px}}@media (width>=860px){.page-header h1{font-size:26px}.page-header{margin-bottom:24px}}.fab{right:20px;bottom:calc(var(--bottom-nav-h) + 16px);background:var(--primary);color:#fff;width:56px;height:56px;box-shadow:var(--shadow-fab);cursor:pointer;z-index:15;border:none;border-radius:999px;justify-content:center;align-items:center;gap:8px;transition:transform .15s,background .15s,box-shadow .15s;display:inline-flex;position:fixed}.fab:hover{background:var(--primary-dark);transform:translateY(-1px)}.fab:active{transform:translateY(0)}.fab-extended{width:auto;height:52px;padding:0 22px 0 18px}.fab-icon{align-items:center;display:inline-flex}.fab-label{font-size:14px;font-weight:600}@media (width>=861px){.fab{bottom:28px;right:28px}}.students-toolbar{flex-direction:column;gap:10px;margin-bottom:16px;display:flex}@media (width>=700px){.students-toolbar{flex-direction:row;align-items:center}}.search-input{flex:1;align-items:center;display:flex;position:relative}.search-input svg{color:var(--text-muted);pointer-events:none;position:absolute;left:14px}.search-input input{background:var(--surface);border-color:var(--divider);border-radius:999px;padding-left:42px}.filter-tabs{background:var(--surface);border:1px solid var(--divider);border-radius:999px;padding:4px;display:flex;overflow-x:auto}.filter-tab{color:var(--text-muted);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-radius:999px;padding:8px 16px;font-size:13px;font-weight:600;transition:all .15s}.filter-tab-active{background:var(--primary-light);color:var(--primary-dark)}.performance-pill{border-radius:999px;flex-shrink:0;padding:3px 10px;font-size:12px;font-weight:600}.perf-high{background:var(--primary-light);color:var(--primary-dark)}.perf-med{color:#8a5a00;background:#fff3d6}.perf-low{color:#a22622;background:#ffe2e1}.profile-back{color:var(--primary-dark);cursor:pointer;background:0 0;border:none;align-items:center;gap:4px;margin-bottom:12px;padding:4px 8px 4px 0;font-size:14px;font-weight:500;display:inline-flex}.profile-hero{background:linear-gradient(135deg, var(--primary-light), var(--surface));border:1px solid var(--divider);border-radius:var(--radius-lg);align-items:center;gap:16px;margin-bottom:14px;padding:20px;display:flex}.profile-hero-body{flex:1;min-width:0}.profile-hero h1{margin-bottom:4px;font-size:22px}.profile-hero-grade{color:var(--text-muted);margin-bottom:8px;font-size:13px}.profile-hero-contacts{flex-direction:column;gap:4px;margin-bottom:10px;display:flex}.profile-hero-contacts a{color:var(--text-muted);align-items:center;gap:6px;font-size:13px;display:inline-flex}.profile-hero-contacts a:hover{color:var(--primary-dark)}.profile-hero-subjects{flex-wrap:wrap;gap:6px;display:flex}.profile-quick{grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:14px;display:grid}.profile-quick-btn{background:var(--surface);border:1px solid var(--divider);border-radius:var(--radius-md);color:var(--text);cursor:pointer;flex-direction:column;justify-content:center;align-items:center;gap:6px;padding:12px 6px;font-size:12px;font-weight:600;transition:all .15s;display:flex}.profile-quick-btn:hover{background:var(--surface-alt);border-color:var(--primary);color:var(--primary-dark)}.profile-quick-btn.primary{background:var(--primary);color:#fff;border-color:var(--primary)}.profile-quick-btn.primary:hover{background:var(--primary-dark);color:#fff}.profile-stats{grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:16px;display:grid}.profile-stat{background:var(--surface);border:1px solid var(--divider);border-radius:var(--radius-lg);text-align:center;padding:12px 6px}.profile-stat-value{color:var(--primary-dark);font-size:20px;font-weight:700}.profile-stat-label{color:var(--text-muted);margin-top:2px;font-size:11px}.profile-grid{grid-template-columns:1fr;gap:14px;display:grid}@media (width>=860px){.profile-grid{grid-template-columns:1fr 1fr;gap:18px}}.profile-empty{color:var(--text-muted);flex-direction:column;align-items:center;gap:8px;padding:24px 12px;font-size:14px;display:flex}.profile-muted{color:var(--text-muted);font-size:14px}.weak-topic-list,.profile-items,.profile-notes{flex-direction:column;gap:10px;display:flex}.weak-topic{background:var(--surface-alt);border-radius:var(--radius-md);justify-content:space-between;align-items:center;padding:12px;font-size:14px;display:flex}.profile-note{background:var(--surface-alt);border-radius:var(--radius-md);padding:12px}.profile-note-head{justify-content:space-between;align-items:center;margin-bottom:6px;display:flex}.profile-note-date{color:var(--text-muted);font-size:12px}.profile-note-topic{margin-bottom:4px;font-size:14px;font-weight:600}.profile-note-body{color:var(--text-muted);font-size:13px;line-height:1.5}.profile-item{background:var(--surface-alt);border-radius:var(--radius-md);justify-content:space-between;align-items:center;gap:12px;padding:12px;display:flex}.profile-item-title{color:var(--text);font-size:14px;font-weight:600}.profile-item-meta{color:var(--text-muted);margin-top:2px;font-size:12px}@media (width<=500px){.profile-hero{text-align:center;flex-direction:column;align-items:center}.profile-hero-contacts{align-items:center}.profile-hero-subjects{justify-content:center}}.profile-schedule{margin-top:18px}.profile-danger{border-radius:var(--radius-lg);color:#7a1f1d;background:#fff5f5;border:1px solid #ffd1d0;margin-top:24px;padding:18px}.profile-danger-head{align-items:flex-start;gap:12px;margin-bottom:14px;display:flex}.profile-danger-head>svg{color:var(--error);flex-shrink:0;margin-top:2px}.profile-danger-title{color:#7a1f1d;font-size:15px;font-weight:600}.profile-danger-desc{color:#7a1f1d;opacity:.85;margin-top:2px;font-size:13px;line-height:1.5}.profile-danger-confirm{color:#7a1f1d;flex-direction:column;gap:10px;font-size:14px;display:flex}.profile-danger-confirm-actions{justify-content:flex-end;gap:8px;display:flex}@media (width>=600px){.profile-danger-confirm{flex-direction:row;justify-content:space-between;align-items:center}}.notes-filters{flex-wrap:wrap;gap:10px;margin-bottom:16px;display:flex}.notes-filters select{background:var(--surface);border-radius:999px;min-width:160px;max-width:220px}.notes-timeline{flex-direction:column;gap:6px;display:flex}.note-item{gap:10px;display:flex}.note-side{flex-direction:column;flex-shrink:0;align-items:center;width:48px;display:flex}.note-date{color:var(--primary-dark);background:var(--primary-light);white-space:nowrap;border-radius:999px;padding:2px 6px;font-size:11px;font-weight:600}.note-line{background:var(--divider);flex:1;width:2px;min-height:20px;margin-top:4px}.note-item:last-child .note-line{display:none}.note-card{background:var(--surface);border:1px solid var(--divider);border-radius:var(--radius-lg);cursor:pointer;flex:1;margin-bottom:12px;padding:14px;transition:box-shadow .15s,transform .15s}.note-card:hover{box-shadow:var(--shadow-sm)}.note-card-head{flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:6px;display:flex}.note-topic{color:var(--text);font-size:15px;font-weight:600}.note-body{color:var(--text);margin-bottom:10px;font-size:14px;line-height:1.5}.note-footer{color:var(--text-muted);font-size:12px}.quiz-list{flex-direction:column;gap:10px;display:flex}.quiz-card{background:var(--surface);border:1px solid var(--divider);border-radius:var(--radius-lg);gap:14px;padding:14px;transition:box-shadow .15s,transform .15s;display:flex}.quiz-card:hover{box-shadow:var(--shadow-sm)}.quiz-icon{border-radius:var(--radius-md);flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.q-info{color:#0056b3;background:#e0efff}.q-success{background:var(--primary-light);color:var(--primary-dark)}.q-warn{color:#8a5a00;background:#fff3d6}.quiz-body{flex:1;min-width:0}.quiz-head{justify-content:space-between;align-items:flex-start;gap:8px;margin-bottom:8px;display:flex}.quiz-title{color:var(--text);font-size:15px;font-weight:600}.quiz-sub{color:var(--text-muted);margin-top:2px;font-size:13px}.quiz-score{text-align:right;flex-shrink:0}.quiz-score-v{color:var(--primary-dark);font-size:18px;font-weight:700}.quiz-score-l{color:var(--text-muted);font-size:10px}.quiz-meta{flex-wrap:wrap;align-items:center;gap:6px;margin-bottom:6px;display:flex}.quiz-qcount{color:var(--text-muted);font-size:12px}.quiz-assigned{color:var(--text-muted);border-top:1px dashed var(--divider);margin-top:6px;padding-top:6px;font-size:12px}.assign-list{flex-direction:column;gap:12px;display:flex}.assign-card{background:var(--surface);border:1px solid var(--divider);border-radius:var(--radius-lg);padding:14px;transition:box-shadow .15s}.assign-card:hover{box-shadow:var(--shadow-sm)}.assign-head{align-items:flex-start;gap:12px;margin-bottom:10px;display:flex}.assign-icon{border-radius:var(--radius-md);flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.a-warn{color:#8a5a00;background:#fff3d6}.a-success{background:var(--primary-light);color:var(--primary-dark)}.a-error{color:#a22622;background:#ffe2e1}.assign-body{flex:1;min-width:0}.assign-top{justify-content:space-between;align-items:flex-start;gap:8px;margin-bottom:4px;display:flex}.assign-title{color:var(--text);font-size:15px;font-weight:600;line-height:1.3}.assign-sub{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.assign-due{color:var(--text-muted);align-items:center;gap:4px;font-size:12px;display:inline-flex}.assign-instructions{color:var(--text-muted);margin-bottom:12px;font-size:14px;line-height:1.5}.assign-progress-row{color:var(--text-muted);justify-content:space-between;margin-bottom:4px;font-size:12px;display:flex}.assign-progress{background:var(--divider);border-radius:999px;height:6px;margin-bottom:12px;overflow:hidden}.assign-progress-fill{background:var(--primary);height:100%;transition:width .3s}.assign-students{flex-wrap:wrap;gap:4px;display:flex}.assign-chip{color:#fff;border:2px solid var(--surface);border-radius:999px;justify-content:center;align-items:center;width:28px;height:28px;font-size:11px;font-weight:700;display:inline-flex}.assign-chip-more{color:var(--text-muted);background:var(--bg)!important}.challenge-summary{grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:18px;display:grid}.challenge-summary-item{border-radius:var(--radius-lg);text-align:center;border:1px solid #0000;flex-direction:column;align-items:center;gap:2px;padding:14px 12px;display:flex}.challenge-summary-item.severity-high{color:#a22622;background:#ffe2e1;border-color:#ffb9b7}.challenge-summary-item.severity-medium{color:#8a5a00;background:#fff3d6;border-color:#f5dca1}.challenge-summary-item.severity-low{color:#0056b3;background:#e0efff;border-color:#b9d7ff}.challenge-summary-value{font-size:22px;font-weight:700}.challenge-summary-label{font-size:12px;font-weight:500}.challenge-list{flex-direction:column;gap:12px;display:flex}.challenge-card{background:var(--surface);border:1px solid var(--divider);border-radius:var(--radius-lg);gap:12px;padding:14px;transition:box-shadow .15s;display:flex}.challenge-card:hover{box-shadow:var(--shadow-sm)}.challenge-stripe{border-radius:2px;flex-shrink:0;width:4px}.challenge-card.severity-high .challenge-stripe{background:var(--error)}.challenge-card.severity-medium .challenge-stripe{background:var(--warning)}.challenge-card.severity-low .challenge-stripe{background:var(--accent-blue)}.challenge-body{flex:1;min-width:0}.challenge-head{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;margin-bottom:10px;display:flex}.challenge-student{align-items:center;gap:10px;display:flex}.challenge-student-name{font-size:14px;font-weight:600}.challenge-student-grade{color:var(--text-muted);font-size:12px}.severity-badge{border-radius:999px;align-items:center;gap:4px;padding:4px 10px;font-size:11px;font-weight:600;display:inline-flex}.severity-badge-high{color:#a22622;background:#ffe2e1}.severity-badge-medium{color:#8a5a00;background:#fff3d6}.severity-badge-low{color:#0056b3;background:#e0efff}.challenge-topic{flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:6px;display:flex}.challenge-desc{color:var(--text-muted);font-size:13px;line-height:1.5}.challenge-footer{border-top:1px solid var(--divider);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;margin-top:10px;padding-top:10px;display:flex}.challenge-date{color:var(--text-muted);font-size:12px}.challenge-actions{gap:6px;display:flex}@media (width<=600px){.challenge-head{flex-direction:column;align-items:flex-start}.challenge-footer{flex-direction:column;align-items:stretch}.challenge-actions{width:100%}.challenge-actions button{flex:1}}.analytics-stats{grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:18px;display:grid}@media (width>=700px){.analytics-stats{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px}}.analytics-stat{background:var(--surface);border:1px solid var(--divider);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:14px;position:relative}.analytics-stat-icon{border-radius:var(--radius-sm);background:var(--primary-light);width:30px;height:30px;color:var(--primary-dark);justify-content:center;align-items:center;margin-bottom:8px;display:inline-flex}.analytics-stat-value{color:var(--primary-dark);font-size:24px;font-weight:700;line-height:1.1}.analytics-stat-label{color:var(--text-muted);margin-top:2px;font-size:12px}.analytics-grid{grid-template-columns:1fr 1fr;gap:18px;display:grid}@media (width<=860px){.analytics-grid{grid-template-columns:1fr}}.chart{padding:10px 0}.chart-bars{justify-content:space-between;align-items:flex-end;gap:10px;height:200px;padding-top:20px;display:flex}.chart-bar-wrap{flex-direction:column;flex:1;align-items:center;gap:6px;height:100%;display:flex}.chart-bar{background:linear-gradient(180deg, var(--primary) 0%, var(--primary-dark) 100%);border-radius:var(--radius-sm) var(--radius-sm) 0 0;justify-content:center;align-items:flex-start;width:100%;max-width:40px;padding-top:4px;transition:height .4s;display:flex;position:relative}.chart-bar-value{color:#fff;font-size:10px;font-weight:600}.chart-bar-label{color:var(--text-muted);font-size:11px}.topic-list{flex-direction:column;gap:12px;display:flex}.topic-row-head{justify-content:space-between;align-items:center;margin-bottom:6px;font-size:13px;display:flex}.topic-bar{background:var(--bg);border-radius:999px;height:8px;overflow:hidden}.topic-bar-fill{background:var(--warning);height:100%}.performer-list{flex-direction:column;gap:10px;display:flex}.performer{background:var(--bg);border-radius:var(--radius-md);align-items:center;gap:12px;padding:10px;display:flex}.performer-rank{background:var(--primary);color:#fff;border-radius:999px;justify-content:center;align-items:center;width:28px;height:28px;font-size:12px;font-weight:700;display:flex}.performer-body{flex:1}.performer-name{font-size:14px;font-weight:600}.performer-meta{color:var(--text-muted);font-size:12px}.performer-score{color:var(--primary-dark);font-size:16px;font-weight:700}.completion-list{flex-direction:column;gap:12px;display:flex}.completion-row{background:var(--bg);border-radius:var(--radius-md);justify-content:space-between;align-items:center;padding:10px 12px;font-size:14px;display:flex}
