:root{color:#18212f;background:#eef3f6;font-family:Inter,Microsoft YaHei,PingFang SC,system-ui,sans-serif}*{box-sizing:border-box}html{min-width:320px;background:#eef3f6}body{margin:0;min-width:320px;overflow-x:hidden;background:#eef3f6;-webkit-text-size-adjust:100%;text-size-adjust:100%}button,input,select,textarea{font:inherit}button{cursor:pointer;-webkit-tap-highlight-color:transparent}.app-shell{width:min(100%,1120px);min-height:100vh;min-height:100dvh;margin:0 auto;padding:18px;padding-bottom:calc(92px + env(safe-area-inset-bottom))}.auth-layout{display:grid;grid-template-columns:minmax(0,1.04fr) minmax(360px,.96fr);gap:22px;align-items:stretch;min-height:calc(100vh - 36px)}.brand-panel{position:relative;display:grid;grid-template-rows:auto minmax(0,1fr) auto;align-content:stretch;gap:26px;min-height:520px;padding:34px;overflow:hidden;color:#fff;background:linear-gradient(145deg,#112637,#184f55);border-radius:8px}.brand-panel:before{content:"";position:absolute;inset:0;background:linear-gradient(rgba(255,255,255,.055) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.045) 1px,transparent 1px);background-size:28px 28px;opacity:.28}.brand-panel:after{display:none}.brand-content,.brand-visual,.brand-summary{position:relative;z-index:1}.brand-content{display:grid;align-content:center;gap:13px;max-width:520px}.brand-visual{align-self:start;display:grid;gap:14px;width:min(100%,520px);padding:18px;background:#f7fbfcf0;border:1px solid rgba(255,255,255,.68);border-radius:8px;color:#173142}.brand-visual-header{display:flex;align-items:center;justify-content:space-between;gap:12px;color:#506979;font-size:13px;font-weight:800}.brand-visual-header span{display:inline-flex;align-items:center;min-height:26px;padding:0 9px;color:#0d6572;background:#e6f3f5;border:1px solid #c5dfe5;border-radius:999px;font-size:12px}.brand-visual-header b{font-weight:800}.brand-metric-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.brand-metric-grid div{display:grid;gap:5px;min-height:76px;padding:12px;background:#fff;border:1px solid #d8e5ea;border-radius:8px}.brand-metric-grid span{color:#5c7180;font-size:12px;font-weight:800}.brand-metric-grid strong{color:#102638;font-size:22px;font-weight:900;line-height:1.18}.brand-visual-note{display:flex;gap:8px;align-items:center;padding:10px 11px;color:#244250;background:#edf8f7;border:1px solid #cce6e3;border-radius:8px;font-size:13px;font-weight:800;line-height:1.45}.brand-visual-note svg{flex:0 0 auto;color:#168092}.brand-mark{display:grid;place-items:center;width:64px;height:64px;background:#ffffff21;border:1px solid rgba(255,255,255,.3);border-radius:8px}.brand-kicker{color:#ffffffc7;font-size:14px;font-weight:800}.brand-panel h1{margin:0;max-width:11em;font-size:34px;letter-spacing:0;line-height:1.22;text-wrap:balance}.brand-panel p{max-width:520px;margin:0;color:#ffffffe0;font-size:17px;line-height:1.68}.brand-summary{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.brand-summary div{display:grid;grid-template-columns:auto minmax(0,1fr);gap:5px 9px;min-height:78px;padding:13px;background:#ffffff1c;border:1px solid rgba(255,255,255,.24);border-radius:8px}.brand-summary svg{grid-row:span 2;color:#a9e7e4;margin-top:2px}.brand-summary strong{color:#fff;font-size:15px;line-height:1.25}.brand-summary span{color:#ffffffdb;font-size:12px;line-height:1.5}.auth-card,.panel{background:#fff;border:1px solid #dce5ea;border-radius:8px;box-shadow:0 16px 42px #23354614}.auth-card{display:flex;flex-direction:column;justify-content:center;gap:16px;padding:44px 30px;box-shadow:0 8px 14px #23354614}.auth-card-header{display:grid;gap:7px;margin-bottom:2px}.auth-card-header span{color:#0d6572;font-size:13px;font-weight:900}.auth-card-header h2{margin:0;color:#102638;font-size:28px;line-height:1.2}.auth-card-header p{max-width:34ch;margin:0;color:#52616f;font-size:14px;line-height:1.55}.segmented{display:grid;grid-template-columns:1fr 1fr;gap:4px;padding:4px;background:#edf3f5;border-radius:8px}.segmented button,.bottom-tabs button{border:0;background:transparent}.segmented button{min-height:42px;border-radius:6px;color:#50606d}.segmented .active{background:#fff;color:#0d5b67;box-shadow:0 6px 16px #1b36441f}.captcha-row{display:grid;grid-template-columns:minmax(82px,auto) minmax(0,1fr) auto;gap:8px;align-items:center}.captcha-row strong{display:grid;min-height:44px;padding:0 12px;place-items:center;color:#0d5b67;background:#eaf6f8;border:1px solid #c8e2e8;border-radius:8px;font-size:16px;white-space:nowrap}label{display:grid;gap:7px;color:#52616f;font-size:14px}input,select,textarea{width:100%;max-width:100%;min-height:44px;padding:10px 12px;color:#17212f;background:#f8fbfc;border:1px solid #cdd9df;border-radius:8px;outline:none}textarea{min-height:86px;resize:vertical}img,canvas,video{max-width:100%}input:focus,select:focus,textarea:focus{border-color:#197586;box-shadow:0 0 0 3px #1975861f}.primary{min-height:44px;padding:0 16px;color:#fff;background:#197586;border:0;border-radius:8px;font-weight:700}.topbar{position:sticky;top:0;z-index:3;display:flex;align-items:center;justify-content:space-between;margin-bottom:18px;padding:14px 16px;background:#ffffffe0;border:1px solid #dce5ea;border-radius:8px;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.topbar-user{display:grid;gap:3px;min-width:0}.topbar-user strong,.topbar-user span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.topbar .topbar-actions{display:flex;align-items:center;justify-content:flex-end;gap:8px;min-width:0;position:relative}.topbar .topbar-shortcut,.account-menu-button{display:inline-flex;align-items:center;justify-content:center;gap:5px;min-height:44px;padding:0 12px;color:#31414f;background:#eef4f6;border:1px solid #d8e3e8;border-radius:8px;font-size:13px;font-weight:800;white-space:nowrap}.topbar-shortcut:hover,.topbar-shortcut:focus-visible,.account-menu-button:hover,.account-menu-button:focus-visible,.icon-button:hover,.icon-button:focus-visible{color:#0d6572;background:#e7f4f6;border-color:#c7e1e7}.topbar-user span,.result-row span,.student-exam span,.mini-card span{color:#657483;font-size:13px}.topbar .topbar-shortcut span{color:inherit;font-size:inherit}.account-menu-badge{display:inline-grid;place-items:center;min-width:18px;height:18px;padding:0 5px;color:#fff;background:#c2410c;border-radius:999px;font-size:11px;font-weight:900}.account-menu{position:absolute;top:calc(100% + 8px);right:0;z-index:8;display:grid;gap:4px;width:220px;padding:6px;background:#fff;border:1px solid #d8e3e8;border-radius:8px;box-shadow:0 10px 24px #1c2c3824}.account-menu button{display:flex;align-items:center;gap:8px;width:100%;min-height:40px;padding:0 10px;color:#263746;background:transparent;border:0;border-radius:6px;font-size:14px;font-weight:800;text-align:left}.account-menu button:hover,.account-menu button:focus-visible{color:#0d6572;background:#edf7f8}.account-menu .danger-menu-item{color:#a32920}.account-menu-divider{display:block;height:1px;margin:3px 2px;background:#e4edf1}.icon-button{display:grid;place-items:center;width:42px;height:42px;color:#31414f;background:#eef4f6;border:1px solid #d8e3e8;border-radius:8px}.pwa-install-button{position:fixed;top:calc(14px + env(safe-area-inset-top));right:calc(14px + env(safe-area-inset-right));z-index:20;display:inline-flex;align-items:center;gap:6px;min-height:38px;padding:0 12px;color:#fff;background:#197586;border:0;border-radius:8px;box-shadow:0 12px 28px #1975863d;font-size:14px;font-weight:800}.danger-icon-button{display:grid;place-items:center;flex:0 0 auto;width:40px;height:40px;color:#b3261e;background:#fff1ef;border:1px solid #f3c7c2;border-radius:8px}.student-row,.exam-row{align-items:center}.student-actions{display:flex;align-items:center;gap:8px;flex:0 0 auto}.student-actions select{width:min(180px,34vw);min-height:40px;padding:8px 10px}.student-table{display:grid;overflow:hidden;border:1px solid #dce8ed;border-radius:8px;background:#fff}.student-bulk-toolbar{display:flex;align-items:center;justify-content:flex-end;gap:12px;flex-wrap:wrap;padding:10px 12px;margin:10px 0;background:#f6fafb;border:1px solid #dce8ed;border-radius:8px}.student-bulk-toolbar>span{color:#536879;font-size:13px;font-weight:800}.student-check-control,.student-name-check{display:flex;align-items:center;gap:10px}.student-name-check{min-width:0;flex-wrap:wrap}.student-check-control{margin-right:auto;color:#173242;font-weight:800}.student-check-control input,.student-name-check input{width:18px;height:18px;accent-color:#0d7a8a}.student-table-row{display:grid;grid-template-columns:64px minmax(150px,1fr) minmax(110px,.8fr) minmax(180px,240px) minmax(220px,auto);gap:12px;align-items:center;min-height:56px;padding:10px 12px;border-bottom:1px solid #e7eef2}.student-table-row:last-child{border-bottom:0}.student-table-head{min-height:44px;color:#607483;background:#f1f7f9;font-size:13px;font-weight:800}.student-table-row strong{color:#102532;overflow-wrap:anywhere}.student-name-check strong{line-height:1.35}.student-table-row span{color:#4f6371;overflow-wrap:anywhere}.student-index{color:#0d6977!important;font-weight:800}.student-approval-panel{display:grid;gap:12px;margin:12px 0;padding:14px;border:1px solid #b8dce0;border-radius:8px;background:#f0fbfb}.student-approval-panel .row-between{align-items:flex-start}.student-approval-panel strong{color:#102532}.student-approval-panel span{color:#587083;font-weight:700}.student-approval-list{display:grid;gap:10px}.student-approval-list article{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px;border:1px solid #d6e8ec;border-radius:8px;background:#fff}.student-approval-list article>div:first-child{display:grid;gap:4px;min-width:0}.student-approval-badge{display:inline-flex;align-items:center;width:fit-content;padding:3px 8px;border-radius:999px;color:#526876!important;background:#eef4f6;font-size:12px;font-weight:900;line-height:1.2;white-space:nowrap}.student-approval-badge.pending{color:#9a5a00!important;background:#fff4d8}.student-approval-badge.approved{color:#0f6c4c!important;background:#e2f6ec}.student-approval-badge.rejected{color:#9f2d2d!important;background:#fde7e7}.action-cell{justify-content:flex-end;flex-wrap:wrap}.content{display:grid;gap:16px}.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.stat,.mini-card,.student-exam{padding:16px;background:#fff;border:1px solid #dce5ea;border-radius:8px}.stat{display:grid;gap:10px}.stat span{color:#60717f}.stat strong{font-size:30px}.dashboard-page{gap:14px}.dashboard-hero{display:grid;grid-template-columns:minmax(0,1.3fr) minmax(220px,.7fr);gap:18px;align-items:center;padding:22px;color:#fff;background:linear-gradient(135deg,#174d59,#3e7658);border-radius:8px;box-shadow:0 18px 40px #1f4b5729}.dashboard-hero span{color:#ffffffc7;font-weight:700}.dashboard-hero h1{margin:8px 0;font-size:34px;line-height:1.15}.dashboard-hero p{max-width:560px;margin:0;color:#ffffffdb;line-height:1.65}.dashboard-hero-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px}.dashboard-hero-actions button{display:inline-flex;align-items:center;justify-content:center;gap:7px;min-height:46px;color:#fff;background:#ffffff21;border:1px solid rgba(255,255,255,.28);border-radius:8px;font-weight:700}.dashboard-stat-grid{display:grid;grid-template-columns:1.4fr repeat(3,1fr);gap:12px}.dashboard-stat{display:grid;gap:8px;min-height:130px;padding:16px;background:#fff;border:1px solid #dce5ea;border-radius:8px}.dashboard-stat span,.dashboard-stat small{color:#627383}.dashboard-stat strong{color:#102532;font-size:32px}.primary-stat{background:#f3faf8;border-color:#cce6df}.dashboard-progress{height:10px;overflow:hidden;background:#dcebe8;border-radius:999px}.dashboard-progress i{display:block;height:100%;background:linear-gradient(90deg,#18798a,#4f8f61);border-radius:inherit}.dashboard-columns{display:grid;grid-template-columns:minmax(0,1.2fr) minmax(260px,.8fr);gap:14px}.todo-list{display:grid;gap:10px}.todo-list button{display:grid;grid-template-columns:56px minmax(0,1fr);gap:12px;align-items:center;min-height:66px;padding:12px;text-align:left;background:#f8fbfc;border:1px solid #dce8ed;border-radius:8px}.todo-list b{color:#0d6977;font-size:28px;text-align:center}.todo-list span{color:#526675}.operation-dashboard{gap:14px}.operation-hero{background:linear-gradient(135deg,#22555f,#557a4c)}.operation-kpi-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.operation-kpi-card{display:grid;gap:8px;min-height:126px;padding:16px;background:#fff;border:1px solid #dce8ed;border-radius:8px}.operation-kpi-card.warning{background:#fff8ec;border-color:#efd397}.operation-kpi-card.danger{background:#fff5f3;border-color:#efc5bf}.operation-kpi-card span,.operation-kpi-card small{color:#607583}.operation-kpi-card span{font-size:13px;font-weight:800}.operation-kpi-card strong{color:#102532;font-size:32px}.operation-layout{display:grid;grid-template-columns:minmax(330px,.9fr) minmax(0,1.1fr);gap:14px;align-items:start}.operation-class-list,.operation-alert-stack,.operation-warning-list,.operation-event-list,.operation-quick-list{display:grid;gap:8px}.operation-class-list{max-height:570px;overflow:auto;padding-right:2px}.operation-class-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px 12px;width:100%;padding:12px;text-align:left;background:#f8fbfc;border:1px solid #dce8ed;border-left:5px solid #7aa7b2;border-radius:8px}.operation-class-row.active{border-color:#168092;border-left-color:#168092;box-shadow:0 0 0 2px #1680921f}.operation-class-row.warning{border-left-color:#c76a00}.operation-class-row.danger{background:#fff8f7;border-left-color:#b3261e}.operation-class-main{display:flex;gap:10px;align-items:center;min-width:0}.operation-class-main b{display:grid;flex:0 0 auto;place-items:center;width:34px;height:34px;color:#0d6977;background:#e7f5f7;border-radius:999px}.operation-class-main div{display:grid;gap:3px;min-width:0}.operation-class-main strong,.operation-event-row strong,.operation-warning-student strong,.operation-quick-list strong{color:#102532}.operation-event-row div,.operation-warning-student>div:first-child{display:grid;gap:3px;min-width:0}.operation-class-main span,.operation-class-tags span,.operation-class-metrics span,.operation-event-row span,.operation-warning-student span,.operation-quick-list small,.operation-alert-card span,.operation-detail-grid span,.operation-trend-card span,.operation-section-title span{color:#607583;font-size:13px}.operation-class-tags{display:flex;grid-column:1 / -1;gap:6px;flex-wrap:wrap}.operation-class-tags span{padding:4px 8px;background:#eef6f7;border:1px solid #d6e8ed;border-radius:999px;font-weight:800}.operation-class-metrics{display:grid;gap:4px;justify-items:end}.operation-class-metrics strong{color:#0d6977;font-size:20px}.operation-detail{display:grid;gap:12px}.operation-alert-card{display:grid;gap:5px;padding:11px;background:#fff8ec;border:1px solid #efd397;border-radius:8px}.operation-alert-card.danger{background:#fff5f3;border-color:#efc5bf}.operation-alert-card.normal{background:#f5fbf7;border-color:#cfe7d7}.operation-detail-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px}.operation-detail-grid article{display:grid;gap:5px;padding:11px;background:#f8fbfc;border:1px solid #dce8ed;border-radius:8px}.operation-detail-grid strong{color:#102532;font-size:24px}.operation-trend-card{display:grid;gap:10px;padding:12px;background:#fbfdfe;border:1px solid #dce8ed;border-radius:8px}.operation-trend-bars{display:grid;gap:8px}.operation-trend-bars div{display:grid;grid-template-columns:54px minmax(0,1fr) 52px;gap:8px;align-items:center}.operation-trend-bars i{display:block;height:9px;overflow:hidden;background:#e3edf1;border-radius:999px}.operation-trend-bars i:before{display:block;width:var(--value);height:100%;background:linear-gradient(90deg,#18798a,#4f8f61);border-radius:inherit;content:""}.operation-trend-bars b{color:#0d6977;text-align:right}.operation-section-title{display:flex;align-items:center;justify-content:space-between;gap:10px}.operation-warning-student{display:grid;gap:7px;padding:10px;background:#fff;border:1px solid #dce8ed;border-left:5px solid #c76a00;border-radius:8px}.operation-warning-student.danger{background:#fff8f7;border-left-color:#b3261e}.operation-risk-tags{display:flex;gap:6px;flex-wrap:wrap}.operation-risk-tags em{padding:3px 8px;color:#9a3412;background:#fff1df;border-radius:999px;font-size:12px;font-style:normal;font-weight:900}.operation-footer-grid{display:grid;grid-template-columns:minmax(0,1.15fr) minmax(280px,.85fr);gap:14px}.operation-event-row{display:grid;grid-template-columns:auto minmax(0,1fr) auto;gap:10px;align-items:center;padding:10px;background:#f8fbfc;border:1px solid #e1e9ed;border-radius:8px}.operation-event-row time{color:#6a7c87;font-size:12px}.operation-event-dot{display:block;width:10px;height:10px;background:#168092;border-radius:999px}.operation-event-row.warning .operation-event-dot{background:#c76a00}.operation-quick-list button{display:grid;grid-template-columns:auto minmax(0,1fr);gap:10px;align-items:center;padding:12px;text-align:left;background:#f8fbfc;border:1px solid #dce8ed;border-radius:8px}.operation-quick-list svg{color:#0d6977}.operation-quick-list span{display:grid;gap:3px}.operation-warning-types{display:grid;grid-template-columns:repeat(auto-fit,minmax(108px,1fr));gap:8px;margin-bottom:10px}.operation-warning-types article{display:grid;gap:4px;padding:10px;background:#fff8ec;border:1px solid #efd397;border-radius:8px}.operation-warning-types span,.operation-warning-types p{margin:0;color:#607583;font-size:13px}.operation-warning-types strong{color:#9a5400;font-size:22px}.warning-hero{background:linear-gradient(135deg,#24515b,#6d6041)}.warning-toolbar{display:grid;grid-template-columns:minmax(130px,.7fr) minmax(150px,.8fr) minmax(180px,1fr) auto;gap:10px;align-items:center}.warning-layout{display:grid;grid-template-columns:minmax(0,1.2fr) minmax(280px,.8fr);gap:14px;align-items:start}.warning-list,.warning-type-list{display:grid;gap:10px}.warning-card{display:grid;gap:10px;padding:12px;background:#fff;border:1px solid #dce8ed;border-left:5px solid #c76a00;border-radius:8px}.warning-card.danger{background:#fff8f7;border-left-color:#b3261e}.warning-card.overdue{border-color:#d58b88;border-left-color:#b3261e;box-shadow:0 10px 28px #b3261e14}.warning-card.resolved{opacity:.72}.warning-card-head{display:flex;justify-content:space-between;gap:12px;align-items:flex-start}.warning-card-head div,.warning-type-list div{display:grid;gap:4px;min-width:0}.warning-card-head strong,.warning-type-list strong{color:#102532}.warning-card-head span,.warning-card p,.warning-evidence span,.warning-type-list span{color:#607583;font-size:13px;line-height:1.45}.warning-card-head b{flex:0 0 auto;padding:5px 8px;color:#9a5400;background:#fff1d8;border-radius:999px;font-size:12px}.warning-card.danger .warning-card-head b{color:#b3261e;background:#ffe7e3}.warning-card p{margin:0}.warning-evidence{display:flex;gap:8px;flex-wrap:wrap}.warning-evidence span{padding:4px 8px;background:#f3f7f9;border:1px solid #dfe9ed;border-radius:999px}.warning-card textarea{min-height:72px}.warning-follow-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:9px}.warning-follow-grid label{display:grid;gap:5px;color:#4d6270;font-size:13px;font-weight:800}.warning-card-actions{display:flex;justify-content:flex-end;gap:8px;flex-wrap:wrap}.warning-timeline{display:grid;gap:8px;padding:10px;border:1px solid #dce8ed;border-radius:8px;background:#f8fbfc}.warning-timeline article{display:grid;gap:5px;padding:9px;border:1px solid #e2edf1;border-radius:8px;background:#fff}.warning-timeline article div{display:flex;justify-content:space-between;gap:8px;flex-wrap:wrap}.warning-timeline span,.warning-timeline p,.warning-timeline small{margin:0;color:#607583;font-size:13px;line-height:1.45}.warning-type-list article{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px;align-items:center;padding:11px;background:#f8fbfc;border:1px solid #dce8ed;border-radius:8px}.warning-type-list b{color:#0d6977;font-size:24px}.warning-settings-panel{display:grid;gap:10px}.warning-settings-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:8px}.warning-settings-grid label{display:grid;gap:5px;color:#4d6270;font-size:13px;font-weight:800}.reports-hero{background:linear-gradient(135deg,#24515b,#4f6d83)}.reports-layout{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;align-items:start}.report-mode-grid{display:grid;gap:10px}.report-mode-card{width:100%;display:grid;grid-template-columns:auto minmax(0,1fr) auto;gap:10px;align-items:center;padding:12px;text-align:left;color:#18323d;background:#f7fbfc;border:1px solid #dce8ed;border-radius:8px}.report-mode-card.active{border-color:#0d6977;background:#eaf7f9;box-shadow:0 0 0 3px #0d697717}.report-mode-card span{display:grid;gap:3px}.report-mode-card small{color:#607583;line-height:1.4}.report-mode-card b{padding:4px 8px;color:#0d6977;background:#fff;border:1px solid #cfe5eb;border-radius:999px;font-size:12px;white-space:nowrap}.report-panel-wide{grid-column:1 / -1}.report-toolbar{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px;margin-bottom:12px}.report-config-card{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px;align-items:end}.report-config-card label{display:grid;gap:6px;color:#4d6270;font-size:13px;font-weight:800}.report-config-card .primary,.report-history-toolbar .ghost-button,.report-action-bar .ghost-button{display:inline-flex;align-items:center;justify-content:center;gap:6px}.report-scope-hint{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin-top:10px;padding:10px 12px;color:#607583;background:#f8fbfc;border:1px solid #dce8ed;border-radius:8px}.report-scope-hint strong{color:#0f2a3a}.report-view{display:grid;gap:12px}.report-document-head{display:flex;flex-wrap:wrap;justify-content:space-between;gap:12px;padding:14px;background:#f7fbfc;border:1px solid #dce8ed;border-radius:8px}.report-document-head div{display:grid;gap:4px}.report-document-head span{color:#607583;font-size:13px}.report-document-head strong{color:#0f2a3a;font-size:18px}.report-document-head b{align-self:start;padding:5px 10px;color:#0d6977;background:#e8f6f8;border-radius:999px;font-size:13px}.report-action-bar{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end}.report-card-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.report-view textarea{min-height:260px;line-height:1.65}.report-readable{display:grid;gap:8px;padding:16px;color:#24414c;background:#fff;border:1px solid #dce8ed;border-radius:8px;line-height:1.75}.report-readable p{margin:0}.report-line-lead{color:#0f2a3a;font-size:16px;font-weight:800}.report-line-bullet{position:relative;padding-left:18px;color:#4d6270}.report-line-bullet:before{content:"";position:absolute;left:3px;top:.78em;width:6px;height:6px;background:#197586;border-radius:999px}.report-warning-linkage{display:grid;gap:12px;padding:14px;background:#fffaf1;border:1px solid #eed6a5;border-radius:8px}.report-section-head{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;flex-wrap:wrap}.report-section-head div{display:grid;gap:4px}.report-section-head strong{color:#0f2a3a}.report-section-head span{color:#607583;font-size:13px}.report-section-head b{padding:5px 9px;color:#9a5400;background:#fff1d8;border:1px solid #efd397;border-radius:999px;font-size:12px}.report-warning-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:10px}.report-warning-item{display:grid;gap:7px;padding:11px;background:#fff;border:1px solid #e7d3aa;border-left:4px solid #c76a00;border-radius:8px}.report-warning-item.danger{border-left-color:#b3261e;background:#fff8f7}.report-warning-item.resolved{opacity:.74}.report-warning-item div{display:flex;gap:7px;align-items:center;min-width:0}.report-warning-item strong{color:#0f2a3a}.report-warning-item p,.report-warning-item span,.report-warning-item small,.report-warning-item em{margin:0;color:#607583;font-size:13px;line-height:1.45}.report-warning-item em{font-style:normal;padding:6px 8px;background:#f8fbfc;border:1px solid #e2edf1;border-radius:7px}.report-intervention-list{display:grid;gap:8px}.report-intervention-list article{display:grid;gap:5px;padding:10px;background:#f8fbfc;border:1px solid #dce8ed;border-radius:8px}.report-intervention-list span{color:#607583;font-size:13px;line-height:1.45}.report-detail-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.report-detail-list{display:grid;gap:8px;padding:12px;border:1px solid #dce8ed;border-radius:8px;background:#f8fbfc}.report-detail-list>strong{color:#0f2a3a}.report-detail-list article{display:grid;gap:4px;padding:9px;border:1px solid #e2edf1;border-radius:8px;background:#fff}.report-detail-list span,.report-detail-list small{color:#607583;font-size:13px;line-height:1.45}.report-history-list{display:grid;gap:9px}.report-history-toolbar{display:flex;flex-wrap:wrap;justify-content:space-between;gap:10px;margin-bottom:12px}.report-history-tabs{display:flex;flex-wrap:wrap;gap:8px}.report-history-tabs button{min-height:36px;padding:0 12px;color:#24414c;background:#f7fbfc;border:1px solid #dce8ed;border-radius:8px;font-weight:800}.report-history-tabs button.active{color:#0d6977;background:#eaf7f9;border-color:#7eb6c6}.report-history-list article button{width:100%;display:grid;gap:5px;text-align:left;padding:12px;border:1px solid #dce8ed;border-radius:8px;background:#f8fbfc;color:#0f2a3a}.report-history-list b{justify-self:start;padding:3px 8px;color:#0d6977;background:#e8f6f8;border-radius:999px;font-size:12px}.report-history-list article button:hover{border-color:#7eb6c6;background:#eef8fa}.report-history-list span{color:#607583;font-size:13px;line-height:1.45}.student-report-layout{display:grid;grid-template-columns:minmax(240px,.75fr) minmax(0,1.25fr);gap:14px;align-items:start}.student-report-list{display:grid;gap:9px}.student-report-list button{width:100%;display:grid;grid-template-columns:auto minmax(0,1fr) auto;gap:10px;align-items:center;padding:12px;text-align:left;color:#0f2a3a;background:#f8fbfc;border:1px solid #dce8ed;border-radius:8px}.student-report-list button.active{border-color:#0d6977;background:#eaf7f9;box-shadow:0 0 0 3px #0d697717}.student-report-list button.unread{border-color:#f0b35b;background:#fff8ed}.student-report-list span{display:grid;gap:4px}.student-report-list small{color:#607583;line-height:1.4}.report-unread-pill{display:inline-grid;place-items:center;width:26px;height:26px;color:#fff;background:#c2410c;border-radius:999px;font-size:12px}.panel{padding:16px}.panel h2{margin:0 0 14px;font-size:18px}.list,.table-list,.card-grid,.feedback-list{display:grid;gap:10px}.card-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.mini-card{display:grid;gap:8px}.mini-card b{font-size:24px}.class-card{align-content:start}.clickable-card{cursor:pointer}.clickable-card:hover{border-color:#8fc7d0;background:#f3fbfc}.class-card div{display:grid;gap:4px}.danger-outline-button{display:inline-flex;align-items:center;justify-content:center;gap:6px;min-height:38px;padding:0 12px;color:#b3261e;background:#fff7f6;border:1px solid #f0c6c0;border-radius:8px;font-weight:700}.result-row,.row-between{display:flex;align-items:center;justify-content:space-between;gap:14px;min-width:0}.result-row{padding:12px;background:#f8fbfc;border:1px solid #e1e9ed;border-radius:8px}.result-row-button{width:100%;color:inherit;font:inherit;text-align:left;cursor:pointer}.result-row-button:hover,.result-row-button:focus-visible{border-color:#6bb7c2;background:#eef9fb}.result-row div,.row-between div{display:grid;gap:4px;min-width:0}.result-row strong,.result-row span,.row-between strong,.row-between span{overflow-wrap:anywhere}.result-row b,.row-between b{flex:0 0 auto;color:#0d6977}.inline-form,.exam-form{display:grid;gap:10px}.inline-form{grid-template-columns:1fr 1fr auto;align-items:end}.compact-inline-form{grid-template-columns:1fr auto}.teacher-create-form,.teacher-create-fields,.teacher-create-binding{display:grid;gap:10px}.teacher-create-fields{grid-template-columns:repeat(4,minmax(170px,1fr));align-items:center}.teacher-create-binding{grid-template-columns:minmax(180px,.8fr) minmax(260px,1.4fr) auto;align-items:center;padding:10px;background:#f4fafb;border:1px solid #d8e7ec;border-radius:8px}.teacher-create-note{padding:12px 14px;color:#4f6370;background:#f4fafb;border:1px solid #d8e7ec;border-radius:8px;font-size:14px;font-weight:800}.teacher-binding-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:8px;padding:10px;background:#f4fafb;border:1px solid #d8e7ec;border-radius:8px}.teacher-binding-grid.compact{grid-template-columns:repeat(auto-fit,minmax(140px,1fr));padding:8px}.teacher-binding-option{display:flex;align-items:center;gap:8px;min-height:38px;padding:8px 10px;background:#fff;border:1px solid #dce8ec;border-radius:8px;color:#183243;font-weight:800}.teacher-binding-option input{width:16px;height:16px}.teacher-binding-editor{display:grid;gap:8px;min-width:min(100%,420px)}.teacher-account-actions{display:grid;grid-template-columns:minmax(280px,1fr) auto;gap:10px;align-items:start;width:min(100%,720px)}.teacher-binding-picker{display:grid;grid-template-columns:minmax(120px,1fr) minmax(160px,1.4fr) auto;gap:8px;align-items:center}.teacher-binding-tags{display:flex;flex-wrap:wrap;gap:8px;min-height:42px;padding:10px;background:#f4fafb;border:1px solid #d8e7ec;border-radius:8px}.teacher-binding-tags.compact{max-width:min(100%,560px);max-height:116px;overflow:auto}.teacher-binding-tag{display:inline-flex;align-items:center;gap:6px;max-width:100%;padding:7px 9px;color:#0d4f5b;background:#e7f4f6;border:1px solid #c7e1e7;border-radius:999px;font-size:13px;font-weight:800;line-height:1.2}.teacher-binding-tag button{display:inline-grid;place-items:center;width:18px;height:18px;padding:0;color:#0d6977;background:#fff;border:1px solid #c7e1e7;border-radius:999px;font-size:13px;font-weight:900;cursor:pointer}.teacher-binding-tag button:hover{color:#b42318;border-color:#f2b8b5}.danger-button{display:inline-flex;align-items:center;justify-content:center;gap:6px;min-height:40px;color:#b42318;background:#fff7f6;border:1px solid #f0c6c0;border-radius:8px;font-weight:900;cursor:pointer}.danger-button:hover:not(:disabled){background:#ffecea;border-color:#ef9a92}.danger-button:disabled{opacity:.6;cursor:not-allowed}.teacher-delete-button{min-width:104px}.muted{margin:0;color:#6a7d8b;font-size:13px;font-weight:700;line-height:1.5}.compact-field{display:grid;gap:4px}.compact-field span{color:#5e7280;font-size:12px;font-weight:800}.course-tree{display:grid;gap:8px;margin-top:8px}.course-class-panel{display:grid;gap:10px;margin-top:10px;padding:10px;background:#f4fafb;border:1px solid #d7e9ee;border-radius:8px}.course-class-head{display:flex;align-items:center;justify-content:space-between;gap:10px}.course-class-head b{color:#173142}.course-class-head small,.course-class-list small{color:#6b7f8c;font-weight:800}.course-class-list{display:flex;flex-wrap:wrap;gap:8px}.course-class-list span{display:inline-flex;max-width:100%;padding:6px 9px;color:#0d6170;background:#fff;border:1px solid #d7e9ee;border-radius:999px;font-size:13px;font-weight:800;overflow-wrap:anywhere}.course-class-form{grid-template-columns:minmax(0,1fr) auto}.course-catalog-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;align-items:start}.course-catalog-card{align-items:stretch;min-width:0}.course-catalog-card>div{width:100%}.course-edit-row{display:grid;grid-template-columns:1fr auto auto;gap:8px;align-items:center}.course-node-title{display:grid;grid-template-columns:minmax(0,1fr) auto auto;align-items:center;gap:8px;min-width:0;position:relative}.course-node-title b,.course-node-title span,.course-node-title strong{min-width:0;overflow-wrap:anywhere}.course-tree>section>.course-node-title>b{min-width:0}.chapter-toggle-button{width:26px;height:26px;min-height:26px;padding:0;color:#5f7381;background:transparent;border:0;border-radius:7px;font-size:16px;line-height:1;transform:rotate(-90deg);transition:transform .15s ease,background .15s ease}.chapter-toggle-button.expanded{transform:rotate(0)}.chapter-toggle-button:hover,.chapter-toggle-button:focus{background:#eaf2ff}.course-title-row{grid-template-columns:minmax(0,1fr) auto auto;max-width:100%}.course-node-edit{margin-bottom:2px}.mini-icon-button{width:34px;height:34px;min-height:34px}.node-menu-wrap{position:relative;flex:0 0 auto}.node-menu-trigger{width:34px;height:34px;color:#6a8fe8;background:#edf5ff;border:0;border-radius:9px;font-size:24px;line-height:1;opacity:1}.node-menu-trigger:focus,.node-menu-trigger[aria-expanded=true],.node-menu-wrap:focus-within .node-menu-trigger{opacity:1}.node-menu-trigger:hover,.node-menu-trigger[aria-expanded=true]{background:#eaf2ff}.node-menu{position:absolute;right:0;top:100%;z-index:20;display:grid;min-width:132px;padding:6px;background:#fff;border:1px solid #d9e4ea;border-radius:8px;box-shadow:0 12px 30px #152d4029}.node-menu button{min-height:44px;padding:0 16px;color:#4d5f6f;text-align:left;background:transparent;border:0;border-radius:7px;font-weight:800}.node-menu button:hover{background:#f1f6f8}.node-menu .danger-menu-item{color:#b42318}.move-node-row{display:grid;grid-template-columns:minmax(0,1fr) auto auto;gap:8px}.course-tree section{display:grid;gap:6px;padding:10px;background:#f8fbfc;border:1px solid #dce8ed;border-radius:8px}.course-tree>section>span,.section-node>span{padding-left:12px;color:#4d6170}.section-title-row{grid-template-columns:minmax(0,1fr) auto;padding-left:12px}.section-title-button{display:flex;align-items:center;justify-content:space-between;gap:10px;min-height:38px;padding:0 10px;color:#526776;text-align:left;background:transparent;border:0;border-radius:8px;font-weight:800}.section-title-button:hover,.section-title-button:focus-visible{color:#0a6f7e;background:#eef7f9}.section-title-button span{min-width:0;overflow-wrap:anywhere}.section-title-button small{flex:0 0 auto;padding:3px 7px;color:#0e6674;background:#e7f4f6;border:1px solid #c4e0e6;border-radius:999px;font-size:12px}.section-node{display:grid;gap:5px;padding-left:10px;border-left:2px solid #dce8ed}.section-node small{padding-left:24px;color:#687987}.structure-select{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;grid-column:1 / -1}.section-resource-upload{display:grid;grid-template-columns:minmax(180px,1fr) minmax(220px,320px) auto;gap:10px;align-items:center;margin-top:12px}.section-resource-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.section-resource-card{display:grid;gap:10px;padding:12px;background:#fff;border:1px solid #dce8ed;border-radius:8px}.section-resource-card b{display:inline-flex;width:fit-content;padding:3px 7px;color:#0e6674;background:#e7f4f6;border-radius:999px;font-size:12px}.section-resource-card strong{color:#102532}.section-resource-card span{color:#687987;font-size:13px}.section-resource-card video,.section-resource-card iframe{width:100%;min-height:220px;background:#f6fafb;border:1px solid #dce8ed;border-radius:8px}.section-resource-actions{display:flex;align-items:center;justify-content:space-between;gap:8px}.student-resource-list{display:grid;gap:12px}.student-resource-chapter{display:grid;gap:10px;padding:12px;background:#fbfdfe;border:1px solid #dce8ed;border-radius:8px}.student-resource-chapter h3{margin:0;color:#102532;font-size:16px}.exam-form{grid-template-columns:repeat(2,1fr)}.exam-form textarea,.exam-form .rubric-file-button,.exam-form .question-picker,.exam-form .field-hint,.exam-form .primary,.exam-form .success{grid-column:1 / -1}.question-picker{display:grid;gap:10px;padding:12px;background:#f8fbfc;border:1px solid #dce8ed;border-radius:8px}.question-picker-list{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;max-height:340px;overflow:auto}.question-picker-chapters{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px}.question-picker-chapter-card{display:grid;gap:8px;min-height:82px;padding:12px;text-align:left;background:#fff;border:1px solid #dce5ea;border-radius:8px;cursor:pointer}.question-picker-chapter-card:hover{border-color:#168494;background:#edf8fa}.question-picker-chapter-card strong{color:#102532;font-size:16px}.question-picker-chapter-card span{color:#687987;font-size:13px}.question-picker-subheader{display:flex;align-items:center;justify-content:space-between;gap:10px}.question-picker-item{display:grid;grid-template-columns:24px minmax(0,1fr);gap:12px;min-height:116px;padding:12px;background:#fff;border:1px solid #dce5ea;border-radius:8px;cursor:pointer}.question-picker-item input{width:18px;height:18px;margin-top:4px}.question-picker-item.selected{background:#e9f6f8;border-color:#168494}.question-picker-item.classroom-picker-item{grid-template-columns:minmax(0,1fr) auto;align-items:start;text-align:left;font:inherit}.question-picker-item.classroom-picker-item>span:last-child{align-self:start;color:#0b7180;font-weight:800}.question-picker-content{display:grid;gap:5px;min-width:0}.question-picker-content b{color:#0f2438;font-size:16px}.question-picker-content small{color:#687987;line-height:1.35}.question-picker-content em{display:-webkit-box;min-height:44px;max-height:48px;overflow:hidden;color:#24384a;font-style:normal;line-height:1.45;-webkit-line-clamp:2;-webkit-box-orient:vertical}.paper-library-list{display:grid;gap:10px;margin-top:12px}.paper-library-item{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px;background:#f8fbfc;border:1px solid #dce8ed;border-radius:8px}.paper-library-item div{display:grid;gap:4px}.paper-library-item span{color:#687987;font-size:13px}.case-library-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-top:12px}.case-library-card{display:grid;gap:10px;padding:10px;background:#f8fbfc;border:1px solid #dce8ed;border-radius:8px}.case-library-card-body{display:grid;gap:3px;min-width:0}.case-library-card-body strong{color:#102532;overflow-wrap:anywhere}.case-library-card-body span,.case-library-card-body small{color:#687987;font-size:13px;overflow-wrap:anywhere}.case-thumbnail{position:relative;width:100%;height:118px;overflow:hidden;padding:0;background:#fff;border:1px solid #bddae2;border-radius:8px}.case-thumbnail iframe{width:640px;height:380px;border:0;pointer-events:none;transform:scale(.3);transform-origin:top left}.case-preview-button{justify-self:start;min-height:32px;padding:0 10px;color:#fff;background:#1f8290;border:0;border-radius:6px;font-size:12px;font-weight:800}.case-preview-overlay{position:fixed;inset:0;z-index:20;display:grid;place-items:center;padding:18px;background:#0e1b2594}.case-preview-modal{display:grid;gap:12px;width:min(100%,1040px);max-height:calc(100dvh - 36px);padding:14px;background:#fff;border:1px solid #dce8ed;border-radius:8px;box-shadow:0 22px 70px #0d1b2747}.case-preview-modal iframe{width:100%;height:min(72dvh,720px);background:#fff;border:1px solid #d8e6ea;border-radius:8px}.password-prompt-overlay{position:fixed;inset:0;z-index:30;display:grid;place-items:center;padding:18px;background:#0e1b2585}.password-prompt-card{display:grid;gap:14px;width:min(100%,420px);padding:20px;background:#fff;border:1px solid #d8e6ea;border-radius:8px;box-shadow:0 22px 70px #0d1b2742}.password-prompt-title{display:grid;grid-template-columns:auto 1fr;gap:12px;align-items:start;color:#12313c}.password-prompt-title svg{margin-top:2px;color:#197586}.password-prompt-title strong,.password-prompt-title span{display:block}.password-prompt-title strong{font-size:20px}.password-prompt-title span{margin-top:4px;color:#667784;font-size:13px;line-height:1.55}.password-prompt-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px}.profile-grid{display:grid;grid-template-columns:minmax(260px,.85fr) minmax(320px,1.15fr);gap:16px;align-items:start}.profile-section-tabs,.teacher-combo-tabs{display:flex;gap:8px;margin-bottom:16px;padding:8px;overflow-x:auto;background:#fff;border:1px solid #dce8ed;border-radius:8px;scrollbar-width:none}.profile-section-tabs::-webkit-scrollbar,.teacher-combo-tabs::-webkit-scrollbar{display:none}.profile-section-tabs button,.teacher-combo-tabs button{position:relative;display:inline-flex;flex:1 0 118px;align-items:center;justify-content:center;gap:6px;min-height:42px;padding:0 12px;color:#526776;background:#f7fbfc;border:1px solid transparent;border-radius:8px;font-weight:800;white-space:nowrap}.profile-section-tabs button.active,.teacher-combo-tabs button.active{color:#0d6572;background:#e9f4f5;border-color:#c4e0e6}.teacher-combo-tabs{position:sticky;top:82px;z-index:2;width:min(100%,520px)}.inline-badge{display:inline-grid;place-items:center;min-width:20px;height:20px;padding:0 6px;color:#fff;background:#c2410c;border-radius:999px;font-size:12px;line-height:1}.profile-embedded-section{display:grid;gap:16px}.profile-info-list,.profile-password-form{display:grid;gap:12px}.profile-avatar-form{display:grid;grid-template-columns:auto minmax(0,1fr) auto;gap:10px;align-items:center;margin-bottom:14px;padding:12px;background:#f7fbfc;border:1px solid #dce8ed;border-radius:8px}.profile-avatar-preview{display:grid;place-items:center;width:72px;height:72px;color:#0d6572;background:#e9f4f5;border:1px solid #c4e0e6;border-radius:50%;overflow:hidden;font-weight:900}.profile-avatar-preview img{width:100%;height:100%;object-fit:cover}.profile-avatar-picker{display:grid;gap:6px;min-width:0;color:#526776;font-weight:800}.profile-avatar-picker input{min-width:0}.profile-info-row{display:grid;grid-template-columns:90px minmax(0,1fr);gap:12px;align-items:center;padding:12px;background:#f7fbfc;border:1px solid #dce8ed;border-radius:8px}.profile-info-row span{color:#687987;font-size:13px}.profile-info-row strong{min-width:0;color:#102532;overflow-wrap:anywhere}.choice-options-preview,.student-choice-sheet,.student-choice-question{display:grid;gap:10px}.choice-options-preview{grid-template-columns:repeat(2,minmax(0,1fr));margin:10px 0}.choice-options-preview span{display:flex;align-items:center;gap:8px;padding:10px 12px;background:#f5fafb;border:1px solid #d6e5eb;border-radius:8px;color:#24384a}.choice-options-preview b,.choice-answer-grid b{flex:0 0 auto;color:#0e7885}.student-choice-sheet{margin-top:12px;padding:12px;background:#f8fbfc;border:1px solid #dce8ed;border-radius:8px}.choice-answer-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.choice-answer-grid button{display:flex;align-items:center;gap:6px;min-width:0;min-height:44px;padding:9px 11px;text-align:left;color:#253b4d;background:#fff;border:1px solid #d3e2e8;border-radius:8px;font-weight:800;overflow-wrap:anywhere}.choice-answer-grid button span{min-width:0}.choice-answer-grid button.active{color:#075f69;background:#e7f6f8;border-color:#16818f;box-shadow:inset 0 0 0 1px #16818f}.submitted-choice-answer{display:flex;align-items:center;gap:12px;margin:12px 0;padding:12px 14px;border:1px solid #cfe0e7;border-radius:8px;background:#f5fbfc}.submitted-choice-answer span{font-size:22px;font-weight:800;color:#0e7c86}.student-upload-panel{display:grid;gap:8px;margin:12px 0}.student-upload-panel span{color:#687987;font-size:13px}.submitted-pages{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:10px;margin-top:12px}.submitted-page-card{display:grid;gap:8px;padding:10px;color:#21404c;text-decoration:none;background:#f7fbfc;border:1px solid #d6e5eb;border-radius:8px}.submitted-page-card img{width:100%;max-height:220px;object-fit:contain;background:#fff;border-radius:6px}.submitted-page-card span{font-size:13px;font-weight:800}.exam-template-flow{grid-column:1 / -1;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px}.exam-template-flow span{padding:9px 10px;color:#0e6674;text-align:center;background:#eef8f9;border:1px solid #cce4e8;border-radius:8px;font-size:13px;font-weight:900}.exam-template-editor{grid-column:1 / -1;display:grid;grid-template-columns:120px repeat(2,minmax(0,1fr));gap:10px;padding:12px;background:#f8fbfc;border:1px solid #dce8ed;border-radius:8px}.exam-template-editor label{display:grid;gap:6px;min-width:0}.exam-template-editor label:first-child{align-self:start}.exam-template-editor label span{color:#526675;font-size:13px;font-weight:800}.exam-template-editor textarea{min-height:98px}.exam-template-actions{grid-column:1 / -1;display:flex;justify-content:flex-end;gap:8px;flex-wrap:wrap}.exam-grade-summary{display:grid;gap:14px}.exam-summary-header{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;flex-wrap:wrap;padding:12px;background:#f7fbfc;border:1px solid #dce8ed;border-radius:8px}.exam-summary-header>div:first-child{display:grid;gap:4px}.exam-summary-header strong{color:#102532;font-size:18px}.exam-summary-header span,.exam-summary-report span,.exam-summary-report small{color:#607583;font-size:13px}.exam-summary-actions{display:flex;gap:8px;flex-wrap:wrap}.exam-summary-actions button{display:inline-flex;align-items:center;gap:6px;justify-content:center}.exam-summary-kpis{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}.exam-summary-table-wrap{width:100%;overflow:auto;border:1px solid #dce8ed;border-radius:8px;background:#fff}.exam-summary-table{width:100%;min-width:980px;border-collapse:collapse;color:#18323d}.exam-summary-table th,.exam-summary-table td{padding:9px 10px;border-bottom:1px solid #e4eef2;text-align:left;white-space:nowrap;vertical-align:top;font-size:13px}.exam-summary-table th{position:sticky;top:0;z-index:1;background:#eef8fa;color:#0f2a3a;font-weight:900}.exam-summary-table th small,.exam-summary-table td small{display:block;margin-top:2px;color:#607583;font-size:11px;max-width:160px;overflow:hidden;text-overflow:ellipsis}.exam-summary-card-list{display:none}.exam-summary-card{display:grid;gap:12px;padding:12px;background:#fff;border:1px solid #dce8ed;border-radius:8px}.exam-summary-card-head,.exam-summary-card-score{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.exam-summary-card-head>div{display:grid;gap:3px;min-width:0}.exam-summary-card-head strong{color:#132638;font-size:16px}.exam-summary-card-head span:not(.exam-status-pill),.exam-summary-card-score span{color:#607583;font-size:12px}.exam-summary-card-score{align-items:stretch}.exam-summary-card-score span{display:grid;flex:1;gap:2px;min-width:0;padding:8px;background:#f6fbfc;border:1px solid #e0edf2;border-radius:8px}.exam-summary-card-score strong{color:#102638;font-size:17px}.exam-summary-score-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(86px,1fr));gap:8px}.exam-summary-score-cell{display:grid;gap:3px;min-width:0;padding:8px;background:#f8fbfc;border:1px solid #e0edf2;border-radius:8px}.exam-summary-score-cell span,.exam-summary-score-cell small{overflow:hidden;color:#61717d;font-size:11px;text-overflow:ellipsis;white-space:nowrap}.exam-summary-score-cell strong{color:#0d6572;font-size:16px}.exam-status-pill{display:inline-flex;padding:4px 8px;border-radius:999px;color:#0d6977;background:#e8f6f8;border:1px solid #cfe5eb;font-size:12px;font-weight:900}.exam-status-pill.done{color:#276749;background:#e9f8ee;border-color:#b9dfc6}.exam-status-pill.pending{color:#9a5400;background:#fff1d8;border-color:#efd397}.exam-status-pill.missing{color:#9b2c2c;background:#ffe7e3;border-color:#e9b4ad}.exam-question-stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:10px}.exam-question-stat-grid article{display:grid;gap:5px;padding:10px;background:#f8fbfc;border:1px solid #dce8ed;border-radius:8px}.exam-question-stat-grid strong{color:#102532}.exam-question-stat-grid span,.exam-question-stat-grid small{color:#607583;font-size:13px;line-height:1.45}.exam-summary-report{display:grid;gap:8px;padding:12px;border:1px solid #dce8ed;border-radius:8px;background:#fff}.exam-summary-report pre{margin:0;padding:12px;max-height:420px;overflow:auto;white-space:pre-wrap;color:#243f4c;background:#f8fbfc;border:1px solid #e4eef2;border-radius:8px;font-family:inherit;line-height:1.7}.homework-page-upload-panel.exam-file-slot-panel{grid-column:1 / -1;gap:12px;padding:12px;background:#f6fbfc;border-color:#bfdde5}.exam-file-slot-header{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:12px;align-items:center}.exam-file-slot-title{display:flex;align-items:center;gap:10px;min-width:0}.exam-file-slot-title div{display:grid;gap:2px;min-width:0}.exam-file-slot-title strong{color:#102532;font-size:16px}.exam-file-slot-title span:not(.exam-file-slot-icon){color:#607583;font-size:13px;font-weight:700}.exam-file-slot-icon{display:grid;place-items:center;flex:0 0 auto;width:38px;height:38px;color:#0f6d7a;background:#e7f5f7;border:1px solid #c8e5eb;border-radius:8px}.exam-file-slot-actions{display:flex;align-items:center;justify-content:flex-end;gap:8px;flex-wrap:wrap}.exam-file-count-pill{display:inline-flex;align-items:center;min-height:34px;padding:0 10px;color:#4d6573;background:#fff;border:1px solid #d4e5ea;border-radius:999px;font-size:13px;font-weight:800}.homework-page-upload-grid.exam-file-upload-grid{grid-template-columns:repeat(auto-fit,minmax(176px,1fr))}.homework-page-upload-slot.exam-file-upload-slot{position:relative;gap:10px;padding:12px;background:#fff;border-color:#d7e8ed}.exam-file-upload-slot:after{content:"";position:absolute;inset:0;pointer-events:none;border-radius:8px;box-shadow:inset 0 1px #ffffffbf}.homework-page-upload-slot.exam-file-upload-slot.filled{background:#f2fbf7;border-color:#87c8a8;box-shadow:0 0 0 2px #1f87601a}.exam-file-upload-card-head{display:flex;align-items:center;gap:9px;min-width:0}.exam-file-upload-card-head div{display:grid;gap:2px;min-width:0}.exam-file-upload-slot .exam-file-page-badge{display:grid;place-items:center;flex:0 0 auto;width:30px;height:30px;color:#0f6d7a;background:#e7f5f7;border:1px solid #c8e5eb;border-radius:999px;font-size:13px;font-weight:900}.exam-file-upload-slot.filled .exam-file-page-badge{color:#fff;background:#198060;border-color:#198060}.exam-file-upload-slot .compact-file-button,.exam-file-clear-button{width:100%}.grading-report{display:grid;gap:12px;margin-top:10px;padding:12px;background:#fbfdfe;border:1px solid #d8e7ec;border-radius:8px}.grading-report.compact{gap:10px;padding:10px}.grading-report-header{display:flex;justify-content:space-between;gap:12px;align-items:center}.grading-report-header div{display:grid;gap:4px;min-width:0}.grading-report-header span{color:#5e7280;font-size:13px;font-weight:800}.grading-report-header strong{color:#102532;font-size:20px}.grading-report-header b{min-width:58px;padding:8px 10px;color:#0d6977;text-align:center;background:#e8f6f8;border:1px solid #c7e3e9;border-radius:8px}.grading-report h5{margin:0;color:#102532;font-size:14px}.grading-report-section,.grading-point-list{display:grid;gap:8px}.grading-point-list article{display:grid;gap:7px;padding:10px;background:#fff;border:1px solid #dfe9ed;border-radius:8px}.grading-point-list article.earned{background:#f5fbf7;border-color:#cfe7d7}.grading-point-list article.lost{background:#fff8f6;border-color:#efd3cc}.grading-point-main{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px;align-items:start}.grading-point-main div{display:grid;gap:3px;min-width:0}.grading-point-main span,.grading-point-list p,.grading-report-grid p{color:#455b69;font-size:13px;line-height:1.5}.grading-point-main b{color:#0d6977;white-space:nowrap}.grading-point-list em{justify-self:start;padding:4px 8px;color:#a83322;background:#fff0ed;border:1px solid #f0c7bf;border-radius:999px;font-style:normal;font-size:12px;font-weight:900}.grading-point-list p,.grading-report-grid p{margin:0}.grading-report-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.grading-report-grid article{display:grid;align-content:start;gap:8px;padding:10px;background:#fff;border:1px solid #dfe9ed;border-radius:8px}.grading-report-images{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:10px}.grading-report-images a{display:grid;gap:7px;min-width:0;padding:8px;color:#21404c;text-decoration:none;background:#fff;border:1px solid #dfe9ed;border-radius:8px}.grading-report-images img{width:100%;height:180px;object-fit:contain;background:#f8fbfc;border-radius:6px}.grading-report-images span{color:#526b78;font-size:13px;font-weight:800}.grading-report.compact .grading-report-grid{grid-template-columns:1fr}.grading-report.compact .grading-report-images img{height:120px}.live-choice-grid{margin:12px 0}.grading-editor{display:grid;gap:12px}.grading-toolbar{display:grid;grid-template-columns:minmax(110px,150px) minmax(120px,180px) minmax(120px,180px) minmax(100px,130px) auto;gap:10px;align-items:center}.grading-count-control{display:grid;grid-template-columns:auto minmax(56px,1fr);gap:8px;align-items:center;min-height:45px;padding:0 10px;color:#526675;background:#f7fbfc;border:1px solid #d2e1e7;border-radius:8px;font-weight:900}.grading-count-control input{min-width:0;height:32px;padding:4px 6px;border:1px solid #cddce3;border-radius:6px;font:inherit}.grading-page-tabs{display:flex;gap:8px;overflow-x:auto;padding-bottom:2px}.grading-page-tabs button{display:grid;gap:2px;min-width:112px;padding:9px 12px;color:#526675;background:#f7fbfc;border:1px solid #d2e1e7;border-radius:8px;font-weight:800;text-align:left}.grading-page-tabs button.active{color:#0e6674;background:#e7f4f6;border-color:#168494}.grading-page-tabs span{color:#6d7e8b;font-size:12px;font-weight:700}.grading-canvas{position:relative;width:min(100%,760px);max-height:78vh;overflow:auto;background:#f8fbfc;border:1px solid #dce8ed;border-radius:8px;cursor:crosshair!important;touch-action:none;-webkit-user-select:none;user-select:none}.grading-image-layer{position:relative;width:100%;min-height:180px;cursor:crosshair!important;touch-action:none;user-select:none;-webkit-user-select:none}.grading-image-layer *{cursor:crosshair!important}.grading-canvas img{display:block;width:100%;height:auto;-webkit-user-select:none;user-select:none;pointer-events:none;-webkit-user-drag:none;-webkit-touch-callout:none}.grading-box{position:absolute;display:grid;place-items:start;padding:3px 5px;color:#fff;background:#0e667433;border:2px solid #0e6674;border-radius:5px;font-size:12px;font-weight:800;pointer-events:none}.grading-box.deduction{background:#d11d1324;border-color:#d11d13}.grading-box.answer{color:#0b4c5a;background:#1884941f;border-color:#21a4b5;border-style:dashed}.grading-box.total{background:#277a4a29;border-color:#277a4a}.grading-box.preview{background:#ffc10733;border-color:#b77900}.grading-box.selected{border-width:3px;box-shadow:0 0 0 3px #0e66742e}.grading-cursor-guide{position:absolute;z-index:3;width:34px;height:34px;pointer-events:none;transform:translate(-50%,-50%)}.grading-cursor-guide:before,.grading-cursor-guide:after{content:"";position:absolute;background:#d11d13d9;border-radius:999px;box-shadow:0 0 0 1px #ffffffc7}.grading-cursor-guide:before{left:50%;top:0;width:2px;height:100%;transform:translate(-50%)}.grading-cursor-guide:after{left:0;top:50%;width:100%;height:2px;transform:translateY(-50%)}.grading-region-list{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.grading-region-item{display:inline-flex;gap:6px;align-items:center;padding:4px;border:1px solid transparent;border-radius:8px}.grading-region-item.selected{background:#e7f5f3;border-color:#9bd0ca}.grading-region-list span{color:#687987;font-size:13px}.upload-form{grid-template-columns:1fr 1fr auto auto}.file-button{display:inline-flex;align-items:center;justify-content:center;gap:7px;min-height:44px;padding:0 14px;color:#21404c;background:#edf4f6;border:1px solid #d3e0e5;border-radius:8px;cursor:pointer}.file-button input{display:none}.native-file-input{position:absolute;left:-10000px;width:1px;height:1px;opacity:0}.image-source-actions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;width:100%}.image-source-actions .file-button{width:100%;min-width:0;padding:0 10px}.image-source-actions .is-processing{color:#6d7c86;cursor:wait;opacity:.82}.camera-file-button{color:#0b6470;background:#e9f7f8;border-color:#bfe0e6}.image-process-row{grid-column:1 / -1;display:grid;grid-template-columns:auto minmax(0,1fr);align-items:center;gap:8px;min-height:34px;padding:0 10px;color:#607483;background:#f8fbfc;border:1px solid #dce8ed;border-radius:8px;font-size:12px;font-weight:800}.image-process-row select{min-height:28px;padding:0 8px;color:#21404c;background:#fff;border:1px solid #d3e0e5;border-radius:7px;font-weight:800}.image-process-notice{grid-column:1 / -1;color:#0d7a8a;font-size:12px;font-weight:800}.rubric-file-button{justify-self:stretch}.field-hint{margin:-2px 0 2px;color:#687987;font-size:13px;line-height:1.5}.checkbox-row{display:flex;align-items:center;gap:10px;min-height:46px;padding:10px 12px;color:#183241;background:#f5f9fa;border:1px solid #d3e0e5;border-radius:8px;font-weight:700}.checkbox-row input{width:18px;height:18px;accent-color:#0b7d8c}.correction-row{align-items:stretch;gap:16px}.correction-editor{display:grid;grid-template-columns:90px minmax(96px,130px) minmax(180px,1fr) auto;gap:8px;align-items:center;min-width:min(100%,560px)}.correction-editor b{color:#0b6b78;text-align:right}.small-button{padding:10px 14px;min-height:42px}.compact-button{min-height:40px;padding:0 12px;white-space:nowrap}.mini-feedback{margin-top:8px;display:grid;gap:4px}.mini-feedback p,.rule-row p{margin:0;color:#5f6f7c;font-size:13px;line-height:1.45}.attachment-list{display:grid;gap:8px}.file-chip-list{display:flex;flex-wrap:wrap;gap:8px}.file-chip-list span{max-width:100%;padding:7px 10px;color:#0e6674;background:#eef7f8;border:1px solid #cae3e7;border-radius:8px;font-size:13px;font-weight:700;word-break:break-word}.attachment-link{display:grid;grid-template-columns:auto 1fr;align-items:center;gap:10px;min-height:42px;padding:8px 10px;color:#0e6674;background:#eef7f8;border:1px solid #cae3e7;border-radius:8px;font-size:13px;font-weight:700;text-decoration:none}.attachment-link img{width:46px;height:46px;object-fit:cover;border-radius:6px;border:1px solid #c2dce0}.attachment-preview{display:grid;gap:8px;padding:10px;color:#0e6674;background:#fff;border:1px solid #cae3e7;border-radius:8px;font-size:13px;font-weight:700;text-decoration:none}.attachment-preview img{display:block;width:100%;max-height:520px;object-fit:contain;background:#fff;border:1px solid #d8e6ea;border-radius:8px}.html-preview-card{gap:10px}.html-preview-card iframe{width:100%;min-height:320px;background:#fff;border:1px solid #d8e6ea;border-radius:8px}.question-card .attachment-link{color:#fff;background:#ffffff24;border-color:#ffffff3d}.question-card .attachment-link img{border-color:#ffffff5c}.student-hero{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:26px;color:#fff;background:linear-gradient(135deg,#174d56,#28746f);border-radius:8px}.student-hero h1{margin:5px 0 0;font-size:30px}.student-hero span{color:#ffffffc7}.student-participation-hero{align-items:stretch}.student-live-metrics{display:grid;grid-template-columns:repeat(3,minmax(94px,1fr));gap:10px;width:min(520px,58%)}.student-live-metrics article{display:grid;align-content:center;gap:4px;min-height:86px;padding:12px;background:#ffffff1f;border:1px solid rgba(255,255,255,.22);border-radius:8px}.student-live-metrics strong{color:#fff;font-size:22px;line-height:1}.student-live-metrics span{color:#ffffffc7;font-size:12px;font-weight:800}.student-activity-list{display:grid;gap:12px}.student-activity-card{display:grid;gap:12px;padding:14px;background:#f8fbfc;border:1px solid #dce8ed;border-radius:8px}.student-activity-card-head,.student-activity-entry{display:flex;align-items:center;justify-content:space-between;gap:12px}.student-activity-card-head>div,.student-activity-entry>div:first-child{display:grid;gap:4px;min-width:0}.student-activity-card-head strong,.student-activity-entry strong{color:#102638}.student-activity-card-head span,.student-activity-entry span{color:#657684;font-size:13px}.student-activity-status,.student-activity-entry-side b{display:inline-flex;align-items:center;justify-content:center;min-height:28px;padding:0 9px;color:#0d6572;background:#e7f6f8;border:1px solid #bddfe6;border-radius:999px;font-size:12px;font-weight:900;white-space:nowrap}.student-activity-status.ended{color:#516575;background:#eef3f6;border-color:#d8e3e8}.student-activity-entry-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:10px}.student-activity-entry{min-height:88px;padding:12px;background:#fff;border:1px solid #dce8ed;border-radius:8px}.student-activity-entry.signed,.student-activity-entry.completed{background:#f0faf5;border-color:#bee6d2}.student-activity-entry.late,.student-activity-entry.pending,.student-activity-entry.partial{background:#fff8ec;border-color:#f1d8ad}.student-activity-entry.open{background:#edf8fb;border-color:#bddfe6}.student-activity-entry-side{display:grid;justify-items:end;gap:5px;min-width:112px}.student-activity-entry-side .ghost-button{display:inline-flex;align-items:center;justify-content:center;min-height:34px;text-decoration:none}.student-exam{display:grid;gap:12px}.feedback-list p{margin:0;padding:10px;color:#5b331b;background:#fff4e8;border:1px solid #f2d7bb;border-radius:8px;line-height:1.5}.answer-preview{position:relative;overflow:hidden;border:2px solid #d8e3e8;border-radius:8px;background:#fff}.answer-preview img{display:block;width:100%;max-height:420px;object-fit:contain;background:#fff}.answer-preview.passed,.answer-preview.needs-work{border-color:#d7352a}.answer-mark{position:absolute;right:12px;top:12px;display:grid;place-items:center;width:72px;height:72px;color:#d11d13;background:#ffffffdb;border:3px solid #d11d13;border-radius:50%;transform:rotate(-8deg)}.answer-mark span{color:#d11d13;font-size:42px;font-weight:900;line-height:.8}.answer-mark b{color:#d11d13;font-size:13px}.correct-answer{display:grid;gap:8px;padding:12px;background:#f0f8f6;border:1px solid #cce6df;border-radius:8px}.correct-answer strong{color:#185c50}.correct-answer p{margin:0;color:#31524c;line-height:1.55}.paper-link{color:#0e6674;font-weight:700;text-decoration:none}.inline-link-button{display:inline;width:auto;min-height:0;padding:0;background:transparent;border:0;cursor:pointer}.image-preview-overlay{position:fixed;inset:0;z-index:80;display:grid;place-items:center;padding:18px;background:#0f1f279e}.image-preview-panel{display:grid;gap:12px;max-width:min(920px,96vw);max-height:92vh;padding:14px;background:#fff;border-radius:8px;box-shadow:0 22px 60px #10253247}.image-preview-header{display:flex;gap:10px;align-items:center;justify-content:space-between}.image-preview-header strong{min-width:0;overflow:hidden;color:#102532;text-overflow:ellipsis;white-space:nowrap}.image-preview-panel img{display:block;max-width:100%;max-height:calc(92vh - 112px);object-fit:contain;border:1px solid #dce8ed;border-radius:8px;background:#f6fafb}.answer-download{display:block;padding:10px 12px;background:#fff7f6;border-top:1px solid #f0c6c0}.analytics-hero{background:linear-gradient(135deg,#19545d,#3f7554)}.wrongbook-hero{background:linear-gradient(135deg,#2b5b5f,#7a6140)}.common-hero{background:linear-gradient(135deg,#244f63,#6b7043)}.questionbank-hero{background:linear-gradient(135deg,#1c5963,#4d6f82)}.questionbank-mode-tabs,.questionbank-resource-tabs{display:grid;gap:8px;padding:8px;background:#fff;border:1px solid #dce8ed;border-radius:8px}.questionbank-mode-tabs{grid-template-columns:repeat(3,minmax(0,1fr))}.questionbank-resource-tabs{grid-template-columns:repeat(4,minmax(0,1fr))}.questionbank-mode-tabs button,.questionbank-resource-tabs button{display:grid;gap:4px;align-content:center;min-height:58px;padding:10px 12px;color:#536979;background:#f6fafb;border:1px solid transparent;border-radius:8px}.questionbank-mode-tabs button.active,.questionbank-resource-tabs button.active{color:#0d6a75;background:#eaf7f8;border-color:#b8dfe6}.questionbank-mode-tabs strong,.questionbank-resource-tabs span{color:inherit;font-weight:900}.questionbank-mode-tabs span,.questionbank-resource-tabs b{color:#6a7b87;font-size:12px;font-weight:800}.discussion-hero{background:linear-gradient(135deg,#245664,#4f7658)}.homework-hero{background:linear-gradient(135deg,#245260,#6f7441)}.student-stat-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.score-trend,.mastery-list,.advice-list{display:grid;gap:10px}.trend-item,.mastery-row{display:grid;grid-template-columns:minmax(0,1.2fr) minmax(120px,1fr) 54px;gap:12px;align-items:center;padding:12px;background:#f8fbfc;border:1px solid #dce8ed;border-radius:8px}.trend-item strong,.mastery-row strong{display:block;color:#102532}.trend-item span,.mastery-row span,.weak-card span{color:#687987;font-size:13px}.trend-item b,.mastery-row b{color:#0b6b78;text-align:right}.trend-bar,.mastery-meter{height:10px;overflow:hidden;background:#e5eef2;border-radius:999px}.trend-bar i,.mastery-meter i{display:block;height:100%;background:linear-gradient(90deg,#1a808d,#4e8b62);border-radius:inherit}.weak-card{display:grid;gap:8px;padding:12px;background:#fff9f2;border:1px solid #efd8bd;border-radius:8px}.weak-card b{color:#bd3d27}.weak-card p,.advice-list p{margin:0;color:#4d6170;line-height:1.5}.advice-list p{padding:12px;background:#f0f8f6;border:1px solid #cce6df;border-radius:8px}.wrongbook-card{display:grid;gap:10px;padding:14px;background:#fff;border:1px solid #dce5ea;border-radius:8px}.wrongbook-card strong{display:block;color:#102532}.wrongbook-card span{color:#687987;font-size:13px}.wrongbook-card b{color:#bd3d27}.wrongbook-card p{margin:0;color:#4d6170;line-height:1.5}.wrongbook-toolbar{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}.wrongbook-mode-tabs{margin-bottom:12px}.student-ai-form{gap:14px}.ai-mode-switch{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;padding:6px;background:#edf4f6;border:1px solid #dce8ed;border-radius:8px}.ai-mode-switch button{min-height:42px;color:#506574;background:transparent;border:0;border-radius:7px;font-weight:900}.ai-mode-switch button.active{color:#0e6674;background:#fff;box-shadow:0 8px 18px #172f3d14}.ai-upload-zone{display:grid;place-items:center;gap:8px;min-height:160px;padding:20px;text-align:center;color:#5f7280;background:#fbfdfe;border:2px dashed #d5e2e8;border-radius:8px;cursor:pointer}.ai-upload-zone input{display:none}.ai-upload-zone svg{color:#0e6674}.ai-upload-zone strong{color:#17212f;font-size:17px}.ai-upload-zone span{font-size:13px}.ai-solution-card,.ai-practice-card{display:grid;gap:12px;margin-top:14px;padding:14px;background:#f8fbfc;border:1px solid #dce8ed;border-radius:8px}.ai-solution-card img{width:min(100%,360px);max-height:240px;object-fit:contain;background:#fff;border:1px solid #dce8ed;border-radius:8px}.ai-solution-card h3,.ai-practice-card h3{margin:0}.ai-solution-card p,.ai-practice-item p{margin:0;color:#405565;line-height:1.65}.ai-keypoints{display:flex;flex-wrap:wrap;gap:8px}.ai-keypoints span{padding:7px 10px;color:#0e6674;background:#eaf7f4;border:1px solid #c8e4dc;border-radius:999px;font-size:13px;font-weight:800}.ai-practice-item{display:grid;gap:8px;padding:12px;background:#fff;border:1px solid #dce8ed;border-radius:8px}.selectable-wrong{position:relative}.selectable-wrong.selected{border-color:#1f8290;box-shadow:0 0 0 3px #1f82901f}.wrongbook-select{display:inline-flex;grid-template-columns:none;align-items:center;justify-self:start;gap:7px;width:auto;min-height:34px;padding:5px 9px;color:#0e6674;background:#eef8fa;border:1px solid #cae3e7;border-radius:8px;font-size:13px;font-weight:800}.wrongbook-select input{width:16px;height:16px;min-height:0;padding:0;accent-color:#197586}.wrong-reason{padding:10px;background:#fff4e8;border:1px solid #f0d6ba;border-radius:8px}.practice-list,.reason-list{display:grid;gap:8px}.practice-list p{padding:10px;background:#f0f8f6;border:1px solid #cce6df;border-radius:8px}.reason-list p{padding:10px;background:#fff9f2;border:1px solid #efd8bd;border-radius:8px}.discussion-meta-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.discussion-list,.discussion-replies{display:grid;gap:12px}.discussion-thread{display:grid;gap:12px;padding:14px;background:#fff;border:1px solid #dce5ea;border-radius:8px}.discussion-thread-target{border-color:#1f8290;box-shadow:0 0 0 3px #1f829024}.discussion-thread>.row-between{align-items:start}.discussion-thread strong{display:block;color:#102532}.discussion-thread span,.discussion-thread small,.discussion-thread b{color:#687987;font-size:13px}.discussion-content{margin:0;padding:12px;color:#263846;line-height:1.6;background:#f8fbfc;border:1px solid #dce8ed;border-radius:8px}.discussion-reply{display:grid;gap:8px;padding:12px;background:#f5faf9;border:1px solid #d2e8e4;border-radius:8px}.discussion-reply p{margin:0;color:#263846;line-height:1.6}.discussion-reply-form{display:grid;grid-template-columns:minmax(0,1fr) 120px 90px;gap:10px;align-items:stretch}.discussion-reply-form textarea{min-height:54px}.compact-file-button{min-height:44px;padding:0 10px}.homework-list,.homework-question-list,.homework-submission-list{display:grid;gap:12px}.homework-card{display:grid;gap:14px;padding:14px;background:#fff;border:1px solid #dce5ea;border-radius:8px}.homework-card>.row-between{align-items:start}.homework-detail-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 12px;background:#f7fbfc;border:1px solid #dce8ed;border-radius:8px}.homework-detail-toolbar.editing{display:block;padding:0;background:transparent;border:0}.homework-detail-meta{display:flex;align-items:center;min-height:36px}.homework-card-actions{display:flex;align-items:center;justify-content:flex-end;gap:8px;flex-wrap:wrap}.homework-date-pill{display:inline-flex;align-items:center;min-height:34px;padding:0 10px;color:#536879!important;background:#fff;border:1px solid #dce8ed;border-radius:999px;font-size:13px}.homework-action-button{display:inline-flex;align-items:center;justify-content:center;gap:6px;min-height:36px;padding:0 12px;color:#174555;background:#fff;border:1px solid #c9dde4;border-radius:8px;font-weight:800;white-space:nowrap}.homework-action-button:hover:not(:disabled),.homework-action-button:focus-visible{color:#0c6f7d;border-color:#8fc8d2;background:#eef9fb}.homework-action-button.danger{color:#b3261e;border-color:#f0c8c2;background:#fff8f7}.homework-action-button.danger:hover,.homework-action-button.danger:focus-visible{color:#9f1d17;background:#fff1ef;border-color:#eaa8a0}.homework-edit-row{display:grid;grid-template-columns:minmax(180px,1fr) minmax(140px,180px) minmax(160px,220px) auto auto;gap:8px;align-items:center}.homework-card strong{display:block;color:#102532}.homework-card span,.homework-card b{color:#687987;font-size:13px}.homework-course-card,.homework-title-card,.homework-question-title-card{width:100%;text-align:left;cursor:pointer}.homework-course-card{grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:14px}.homework-course-card-main{display:grid;gap:8px;min-width:0}.homework-submit-pill{justify-self:end;min-width:106px;padding:9px 12px;color:#fff;background:#197586;border-radius:8px;font-size:15px;font-weight:900;text-align:center;white-space:nowrap}.student-homework-status{display:grid;justify-items:center;gap:4px;min-width:104px;padding:10px 12px;color:#526776!important;background:#f5fafb;border:1px solid #d5e4ea;border-radius:8px;font-size:16px!important;line-height:1.1;font-weight:900;text-align:center;white-space:nowrap}.student-homework-status span{color:#1f3745!important;font-size:14px;line-height:1.1;font-weight:900}.student-homework-status.done{color:#fff!important;background:#0f7a8a;border-color:#0f7a8a;box-shadow:0 8px 18px #0f7a8a2e}.student-homework-status.done span{color:#fff!important}.student-homework-status.returned{color:#9f1d17!important;background:#fff1ef;border-color:#eab0a8}.homework-title-card{display:grid;gap:6px}.homework-question-title-list{display:grid;gap:10px}.homework-question-title-card{display:grid;gap:6px;padding:12px;background:#f8fbfc;border:1px solid #dce8ed;border-radius:8px}.homework-question-title-card:hover,.homework-title-card:hover,.homework-course-card:hover{border-color:#85b7c1;background:#eef8fa}.homework-question-title-card span{color:#4d6170;line-height:1.55}.homework-question-title-card small{color:#687987;font-weight:800}.homework-question{display:grid;gap:10px;padding:12px;background:#f8fbfc;border:1px solid #dce8ed;border-radius:8px}.homework-question p,.homework-result p,.homework-submission-row p{margin:0;color:#4d6170;line-height:1.55}.homework-region-actions{display:flex;align-items:center;flex-wrap:wrap;gap:10px}.homework-count-field{display:grid;gap:6px;color:#536776;font-size:13px;font-weight:900}.homework-subquestion-grid{display:flex;flex-wrap:wrap;gap:6px}.homework-subquestion-grid span{display:inline-flex;align-items:center;gap:4px;padding:5px 8px;color:#0e6674;background:#e7f4f6;border:1px solid #c4e0e6;border-radius:6px;font-weight:800}.homework-standard-preview{display:grid;gap:10px}.homework-standard-card,.homework-question-edit{padding:10px;background:#fff;border:1px solid #dce8ed;border-radius:8px}.homework-standard-preview b{color:#102532}.homework-standard-header{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:6px}.homework-question-edit{display:grid;gap:8px}.homework-question-edit textarea{min-height:82px;resize:vertical}.homework-subquestion-editor{display:grid;gap:6px}.homework-subquestion-editor span{color:#315161;font-size:13px;font-weight:800}.homework-subquestion-editor textarea{min-height:130px;font-family:inherit}.scroll-anchor-panel{scroll-margin-top:18px;scroll-margin-bottom:120px}.grading-panel-heading{align-items:flex-start;margin-bottom:12px}.grading-panel-heading span{display:block;margin-top:4px;color:#687987;font-size:13px;line-height:1.5}.homework-submit-box{display:grid;gap:10px}.homework-answer-input{min-height:82px;resize:vertical}.homework-text-submit{width:100%}.homework-page-upload-panel{display:grid;gap:10px;padding:10px;background:#f4fbfc;border:1px solid #c8e5eb;border-radius:8px}.homework-page-hint{margin:0;color:#305968;font-weight:700}.homework-page-upload-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:10px}.homework-page-upload-slot{display:grid;gap:8px;padding:10px;background:#fff;border:1px solid #d6e4ea;border-radius:8px}.homework-page-upload-slot.filled{border-color:#1f8796;box-shadow:0 0 0 2px #1f87961f}.homework-page-upload-slot b{display:block;color:#123846;font-size:15px}.homework-page-upload-slot span{color:#607483;font-size:12px}.homework-page-submit{width:100%}.homework-text-answer{padding:8px 10px;background:#eef8f6;border:1px solid #c9e3df;border-radius:8px}.homework-result{display:grid;gap:8px;padding:10px;background:#fff9f2;border:1px solid #efd8bd;border-radius:8px}.homework-result b{color:#bd3d27;font-size:18px}.homework-link-list{display:flex;flex-wrap:wrap;gap:8px}.homework-submission-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px;align-items:center}.homework-submission-row.expanded{align-items:start}.homework-submission-summary{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:12px;align-items:center;min-width:0;padding:0;color:inherit;text-align:left;background:transparent;border:0;cursor:pointer}.homework-submission-summary span{display:grid;gap:5px;min-width:0}.homework-submission-summary small{color:#687987;font-size:13px;font-weight:700}.homework-submission-summary b{padding:8px 10px;color:#0d6977;background:#eaf7f8;border:1px solid #c5e5ea;border-radius:8px;font-size:14px}.homework-submission-detail{grid-column:1 / -1;display:grid;gap:12px;padding:12px;background:#fff;border:1px solid #dce8ed;border-radius:8px}.homework-submission-detail section{display:grid;gap:8px}.homework-submission-detail h4{margin:0;color:#102532;font-size:15px}.homework-feedback-list{display:grid;gap:6px}.homework-feedback-list p,.homework-submission-detail .homework-text-answer{margin:0;padding:8px 10px;color:#435767;background:#f7fbfc;border:1px solid #e2edf1;border-radius:8px;line-height:1.55}.homework-correction-panel{grid-template-columns:minmax(90px,120px) minmax(160px,1fr) repeat(3,auto);align-items:center}.homework-submission-notice{justify-self:start;padding:8px 10px;background:#edf8f1;border:1px solid #ccebd6;border-radius:8px}.classroom-correction-row{display:grid;grid-template-columns:82px minmax(0,1fr) auto;gap:8px;align-items:center;margin-top:10px}.learning-row{align-items:center}.learning-row-button{width:100%;text-align:left;cursor:pointer}.learning-row-button.active{border-color:#168092;box-shadow:0 0 0 2px #1680921f}.learning-metrics{display:flex;align-items:center;justify-content:flex-end;gap:10px;flex-wrap:wrap}.learning-metrics b{color:#0d6977}.student-detail-advice{margin-top:12px}.student-detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:12px;margin-top:12px}.student-detail-card{display:grid;gap:8px;padding:12px;background:#fbfdfe;border:1px solid #dce8ed;border-radius:8px}.student-detail-card h3{margin:0;color:#102532;font-size:16px}.student-detail-record{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px;align-items:center;padding:9px;background:#f5fafb;border:1px solid #e0edf1;border-radius:8px}.student-detail-record strong{display:block;color:#173241}.student-detail-record span{display:block;margin-top:3px;color:#687987;font-size:12px;line-height:1.45}.student-detail-record b,.student-discussion-summary b{color:#0d6977}.student-discussion-summary{display:flex;gap:8px;flex-wrap:wrap}.student-discussion-summary b{padding:6px 9px;background:#e8f5f7;border-radius:999px}.common-card{background:#fbfdfe}.question-bank-card{display:grid;gap:12px;padding:14px;background:#fff;border:1px solid #dce5ea;border-radius:8px}.question-bank-card strong{color:#102532}.question-bank-card span,.question-bank-card b{color:#687987;font-size:13px}.question-bank-card p{margin:0;color:#4d6170;line-height:1.5}.question-bank-group{display:grid;gap:10px;padding:14px;background:#fbfdfe;border:1px solid #dce5ea;border-radius:8px}.question-bank-group h3{margin:0;color:#102532;font-size:16px}.question-bank-compact-list{display:grid;gap:10px}.question-bank-compact-card{width:100%;text-align:left;cursor:pointer}.question-bank-compact-card:hover{border-color:#1f7f8c;background:#f5fbfc}.question-bank-stem{display:-webkit-box;overflow:hidden;-webkit-box-orient:vertical;-webkit-line-clamp:2}.question-bank-card-hint{justify-self:start;color:#1f7f8c!important;font-size:13px}.course-resource-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}.course-resource-card{display:grid;gap:8px;width:100%;min-height:92px;padding:16px;text-align:left;background:#fbfdfe;border:1px solid #d6e5ea;border-radius:8px;cursor:pointer}.course-resource-card:hover{border-color:#1f7f8c;background:#eef8fa}.course-resource-card strong,.course-resource-header strong{color:#102532;font-size:18px}.course-resource-card span,.course-resource-header span,.resource-mini-card span{color:#687987;font-size:13px}.course-resource-header{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px;background:#eef8fa;border:1px solid #d6e5ea;border-radius:8px}.course-resource-header div{display:grid;gap:6px}.question-category-manager{display:grid;gap:12px;padding:14px;background:#fbfdfe;border:1px solid #dce5ea;border-radius:8px}.question-category-scope{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.question-category-head{display:flex;align-items:end;justify-content:space-between;gap:12px}.question-category-head>div{display:grid;gap:4px}.question-category-head strong{color:#102532;font-size:16px}.question-category-head span,.question-category-row span{color:#687987;font-size:13px}.question-category-create{display:flex;gap:8px;min-width:min(100%,320px)}.question-category-create input{min-width:0}.question-category-list{display:grid;gap:8px}.question-category-row{display:grid;grid-template-columns:minmax(0,1fr) auto auto auto;gap:8px;align-items:center;min-height:48px;padding:8px 10px;background:#fff;border:1px solid #e1e9ed;border-radius:8px}.question-category-row strong{min-width:0;overflow:hidden;color:#102532;text-overflow:ellipsis;white-space:nowrap}.course-resource-section{display:grid;gap:10px;padding:14px;background:#fbfdfe;border:1px solid #dce5ea;border-radius:8px}.course-resource-section h3{margin:0;font-size:16px}.resource-mini-card{display:grid;gap:6px;padding:12px;background:#fff;border:1px solid #e1e9ed;border-radius:8px}.resource-mini-button{width:100%;text-align:left;cursor:pointer}.resource-mini-button:hover,.resource-mini-row:hover{border-color:#1f7f8c;background:#f1fbfc}.resource-mini-row{position:relative;grid-template-columns:1fr auto;align-items:center;gap:10px}.homework-list-row .resource-card-menu-button{opacity:1;transform:translateY(0)}.resource-mini-main{display:grid;gap:6px;min-width:0;padding:0;color:inherit;text-align:left;background:transparent;border:0;cursor:pointer}.resource-mini-main strong,.resource-mini-main span{overflow:hidden;text-overflow:ellipsis}.resource-card-menu{position:relative;justify-self:end}.resource-card-menu-button{display:grid;place-items:center;width:34px;height:34px;padding:0;color:#5c7080;font-size:24px;line-height:1;background:#eef6f8;border:1px solid #d6e5ea;border-radius:8px;cursor:pointer;opacity:0;transform:translateY(2px);transition:opacity .16s ease,transform .16s ease,border-color .16s ease}.resource-mini-row:hover .resource-card-menu-button,.resource-mini-row:focus-within .resource-card-menu-button{opacity:1;transform:translateY(0)}.resource-card-menu-button:hover,.resource-card-menu-button:focus-visible{color:#0f6670;border-color:#1f7f8c;outline:none}.resource-card-popover{position:absolute;top:calc(100% + 6px);right:0;z-index:20;display:none;min-width:142px;padding:8px;background:#fff;border:1px solid #dbe7ec;border-radius:8px;box-shadow:0 16px 36px #0f263429}.resource-card-menu:hover .resource-card-popover,.resource-card-menu:focus-within .resource-card-popover{display:grid;gap:4px}.resource-card-popover button{width:100%;padding:10px 12px;color:#213746;text-align:left;background:transparent;border:0;border-radius:6px;cursor:pointer}.resource-card-popover button:hover,.resource-card-popover button:focus-visible{background:#eef8fa;outline:none}.resource-card-popover .danger-menu-item{color:#c02b21}.resource-homework-edit{padding:12px;background:#f5fbfc;border:1px solid #d6e5ea;border-radius:8px}@media(hover:none){.resource-card-menu-button{opacity:1;transform:none}.node-menu-trigger{width:38px;height:38px;font-size:26px}.node-menu{min-width:148px}.node-menu button{min-height:48px;font-size:15px}}.course-resource-detail{display:grid;gap:12px;padding:14px;background:#fbfdfe;border:1px solid #dce5ea;border-radius:8px}.resource-detail-header{display:flex;align-items:center;justify-content:space-between;gap:12px;padding-bottom:12px;border-bottom:1px solid #e1e9ed}.resource-detail-header div{display:grid;gap:6px}.resource-detail-header-actions{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:8px}.resource-detail-header strong{color:#102532;font-size:18px}.resource-detail-header span,.resource-detail-card span{color:#687987;font-size:13px}.resource-detail-card{display:grid;gap:10px;padding:12px;background:#fff;border:1px solid #e1e9ed;border-radius:8px}.resource-detail-card p{margin:0;color:#4d6170;line-height:1.6}.resource-detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:10px}.resource-detail-grid section{display:grid;gap:6px;padding:10px;background:#f8fcfd;border:1px solid #e1e9ed;border-radius:8px}.ai-generate-form{margin-bottom:14px}.ai-auto-requirement{display:grid;grid-column:1 / -1;gap:6px;padding:12px 14px;color:#253746;background:#f4fafb;border:1px solid #cfe4ea;border-radius:8px}.ai-auto-requirement strong{color:#0d6572;font-size:14px}.ai-auto-requirement span{color:#425666;font-size:14px;font-weight:800;line-height:1.55}.ai-candidate-list{display:grid;gap:12px}.ai-job-status{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;margin-bottom:14px;background:#f5fbfc;border:1px solid #d6e5ea;border-radius:8px}.ai-job-status>div{display:grid;gap:4px}.ai-job-status strong{color:#102532}.ai-job-status span{color:#526777;font-size:13px}.ai-job-status.running,.ai-job-status.queued{background:#eaf7f9;border-color:#b9dfe6}.ai-job-status.done{background:#edf8f2;border-color:#c7e8d3}.ai-job-status.failed{background:#fff3f1;border-color:#f0c8c1}.ai-job-status.failed strong{color:#b02b20}.ai-candidate-card{display:grid;gap:12px;padding:14px;background:#fbfdfe;border:1px solid #d6e5ea;border-radius:8px}.ai-candidate-card>section{display:grid;gap:6px;padding:10px;background:#fff;border:1px solid #e1e9ed;border-radius:8px}.ai-candidate-card strong{color:#102532}.ai-candidate-card span{color:#687987;font-size:13px}.ai-candidate-card p{margin:0;color:#4d6170;line-height:1.55}.question-bank-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.question-bank-grid section{display:grid;gap:6px;padding:10px;background:#f8fbfc;border:1px solid #e1e9ed;border-radius:8px}.student-question-text{padding:12px;color:#102532;background:#f8fbfc;border:1px solid #dce8ed;border-radius:8px;line-height:1.75}.question-edit-form,.extracted-edit{display:grid;gap:10px}.question-edit-form textarea,.extracted-edit textarea{min-height:96px}.extracted-edit{grid-template-columns:repeat(4,1fr);padding:12px;background:#f8fbfc;border:1px solid #dce8ed;border-radius:8px}.extracted-edit textarea{grid-column:1 / -1}.question-actions{display:flex;flex-wrap:wrap;gap:8px}.extracted-question-list{display:grid;gap:10px}.extracted-question{display:grid;gap:8px;padding:12px;background:#f7fbf9;border:1px solid #cfe5dc;border-radius:8px}.extracted-question .answer-line{padding:8px 10px;background:#fff;border:1px solid #dce9e4;border-radius:8px}.latex-text{overflow-wrap:anywhere;word-break:break-word}.latex-text math{font-size:1.04em}.latex-text math[display=block]{display:block;overflow-x:auto;overflow-y:hidden;padding:4px 0}.activity-entry-page,.classroom-activity-page{display:grid;gap:16px}.activity-entry-hero,.classroom-activity-hero{align-items:center}.activity-entry-hero p,.classroom-activity-hero p{max-width:58ch}.activity-status{display:inline-flex;align-items:center;justify-content:center;min-height:30px;padding:0 10px;color:#526776;background:#f2f6f8;border:1px solid #dce8ed;border-radius:999px;font-size:12px;font-weight:900;white-space:nowrap}.activity-status.active{color:#0d6572;background:#e7f6f8;border-color:#bddfe6}.activity-status.ended{color:#5f6f7c;background:#eef2f5}.activity-page-header{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:16px;background:#fff;border:1px solid #dce5ea;border-radius:8px}.activity-page-header>div:first-child{display:grid;gap:4px;min-width:0}.activity-page-header span{color:#0d6572;font-size:13px;font-weight:900}.activity-page-header h1{margin:0;color:#102638;font-size:24px;line-height:1.18}.activity-page-header p{margin:0;color:#526776;font-size:14px}.activity-header-actions,.activity-current-actions{display:flex;gap:8px;justify-content:flex-end;flex-wrap:wrap}.activity-header-actions button{min-height:38px;padding:0 12px;color:#284150;background:#f3f8fa;border:1px solid #d5e3e9;border-radius:8px;font-weight:900}.activity-header-actions button:disabled{opacity:.48}.activity-overview-grid{display:grid;grid-template-columns:minmax(320px,.9fr) minmax(420px,1.1fr);gap:14px;align-items:start}.activity-current-panel{display:grid;gap:14px;padding:16px;background:#fff;border:1px solid #dce5ea;border-radius:8px}.activity-current-panel>div:first-child{display:grid;gap:5px}.activity-current-panel span{color:#0d6572;font-size:13px;font-weight:900}.activity-current-panel h2{margin:0;color:#102638;font-size:20px;line-height:1.25}.activity-current-panel p{margin:0;color:#526776;font-size:13px;line-height:1.5}.activity-current-metrics{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.activity-current-metrics .mini-card{min-height:86px;padding:10px}.activity-current-actions{justify-content:flex-start}.activity-lesson-panel{min-width:0}.activity-panel-title-row{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:12px}.activity-panel-title-row h2{flex:0 0 auto;min-width:max-content;margin:0;white-space:nowrap}.activity-create-popover{flex:0 0 auto;min-width:0;position:relative;z-index:2}.activity-create-popover summary{display:inline-flex;align-items:center;min-height:36px;padding:0 12px;color:#0d6572;background:#eaf6f8;border:1px solid #bfdfe6;border-radius:8px;font-size:13px;font-weight:900;cursor:pointer;list-style:none;white-space:nowrap}.activity-create-popover summary::-webkit-details-marker{display:none}.activity-create-popover[open]{flex:1 1 520px;width:auto;max-width:100%}.activity-create-popover[open] summary{margin-bottom:10px}.activity-create-popover .activity-create-form{padding:12px;background:#f8fbfc;border:1px solid #dce8ed;border-radius:8px}.activity-identify-form,.activity-create-form,.activity-bind-form{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:10px;align-items:end}.inline-check{display:inline-flex;align-items:center;min-height:44px;gap:7px;padding:0 10px;color:#425666;background:#f7fbfc;border:1px solid #dce8ed;border-radius:8px;font-size:13px;font-weight:800}.inline-check input{width:17px;height:17px;accent-color:#0d7a8a}.activity-phase-tabs{grid-column:1 / -1;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;padding:6px;background:#f3f8fa;border:1px solid #dce8ed;border-radius:8px}.activity-phase-tabs button{display:grid;place-items:center;min-height:54px;padding:9px 10px;color:#526776;background:transparent;border:1px solid transparent;border-radius:7px}.activity-phase-tabs button:hover{color:#0d6572;background:#fff;border-color:#cfe1e7}.activity-phase-tabs button.active{color:#0d6572;background:#fff;border-color:#9fcbd4;box-shadow:inset 0 0 0 1px #d8eef2}.activity-phase-tabs strong{font-size:14px}.activity-phase-tabs span{font-size:12px;font-weight:800}.activity-checkin-field{display:grid;gap:6px;color:#425666;font-size:12px;font-weight:900}.activity-checkin-field input{width:100%}.activity-checkin-field input:disabled{color:#8a98a5;background:#eef4f6}.activity-question-picker{grid-column:1 / -1;display:grid;gap:10px;padding:10px;background:#f8fbfc;border:1px solid #dce8ed;border-radius:8px}.activity-question-picker-head{display:flex;align-items:center;justify-content:space-between;gap:12px}.activity-question-picker-head>div:first-child{display:grid;gap:3px;min-width:0}.activity-question-picker-head strong{color:#102638;font-size:15px}.activity-question-picker-head span{color:#647684;font-size:12px;font-weight:800}.activity-question-picker-head>div:last-child{display:flex;gap:8px;flex-wrap:wrap}.activity-question-picker-list{display:grid;gap:8px;max-height:280px;overflow:auto;padding-right:4px}.activity-question-choice{display:grid;grid-template-columns:22px minmax(0,1fr);gap:10px;align-items:start;min-height:58px;padding:10px;color:#243746;background:#fff;border:1px solid #dde8ed;border-radius:8px}.activity-question-choice:hover{border-color:#b9dfe6}.activity-question-choice.active{background:#eaf7f8;border-color:#9fcfd8}.activity-question-choice input{width:18px;height:18px;margin-top:2px;accent-color:#0d7a8a}.activity-question-choice span{display:grid;gap:4px;min-width:0}.activity-question-choice strong{overflow:hidden;color:#102638;font-size:15px;text-overflow:ellipsis;white-space:nowrap}.activity-question-choice small{overflow:hidden;color:#647684;font-size:12px;text-overflow:ellipsis;white-space:nowrap}.activity-checkin-toggle{min-width:0}.activity-student-line,.activity-entry-hint{margin:0;padding:10px 12px;color:#425666;background:#f7fbfc;border:1px solid #dce8ed;border-radius:8px}.activity-student-line{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.activity-student-line span{color:#657483;font-size:13px}.activity-question-stack{display:grid;gap:12px}.activity-question-card{display:grid;gap:12px;padding:14px;background:#fff;border:1px solid #dce8ed;border-radius:8px}.activity-question-title{display:grid;gap:4px}.activity-question-title span,.activity-bound-list span,.activity-qr-card span,.activity-question-stat-head span{color:#0d6572;font-size:12px;font-weight:900}.activity-question-title strong{color:#102638;font-size:18px}.activity-question-stem{color:#223746;line-height:1.65}.activity-option-list{display:grid;gap:8px}.activity-option-list button{display:grid;grid-template-columns:36px minmax(0,1fr);gap:10px;align-items:center;min-height:54px;padding:9px 10px;color:#263746;background:#f8fbfc;border:1px solid #dce8ed;border-radius:8px;text-align:left}.activity-option-list button b{display:grid;place-items:center;width:32px;height:32px;color:#0d6572;background:#e9f4f5;border-radius:999px}.activity-option-list button.active{background:#e8f6f8;border-color:#9fcbd4}.activity-submit-button{min-height:52px}.activity-submit-success{display:grid;justify-items:center;gap:10px;padding:34px 18px;color:#0d6572;background:#fff;border:1px solid #dce8ed;border-radius:8px;text-align:center}.activity-submit-success h1{margin:0;color:#102638}.activity-submit-success p{margin:0;color:#526776}.activity-checkin-score{display:inline-flex;align-items:center;min-height:30px;padding:0 10px;color:#0d6572;background:#e8f6f8;border:1px solid #b9dfe6;border-radius:999px;font-size:13px;font-weight:900}.activity-answer-feedback,.activity-list,.activity-bound-list,.activity-phase-bound-list,.activity-question-stat-list{display:grid;gap:10px}.activity-answer-feedback article,.activity-list-item,.activity-bound-list article,.activity-question-stat-list>article{display:grid;gap:8px;padding:11px;background:#f8fbfc;border:1px solid #dce8ed;border-radius:8px}.activity-phase-bound-list{margin-top:12px}.activity-phase-group{display:grid;gap:10px;padding:12px;background:#fff;border:1px solid #dce8ed;border-radius:8px}.activity-phase-group.empty{background:#f8fbfc}.activity-entry-group-list{display:grid;gap:10px}.activity-entry-group-card{display:grid;gap:10px;padding:10px;background:#f8fbfc;border:1px solid #dce8ed;border-radius:8px}.activity-phase-group-head{display:flex;align-items:center;justify-content:space-between;gap:12px}.activity-phase-group-head>div{display:grid;gap:3px;min-width:0}.activity-phase-group-head strong{color:#102638;font-size:15px}.activity-phase-group-head span{color:#647684;font-size:12px;font-weight:800}.activity-phase-group-head b{padding:5px 9px;color:#0d6572;background:#e7f6f8;border:1px solid #bddfe6;border-radius:999px;font-size:12px;white-space:nowrap}.activity-entry-group-head{display:flex;align-items:center;justify-content:space-between;gap:10px}.activity-entry-group-head>div{display:grid;gap:3px;min-width:0}.activity-entry-group-head strong{color:#102638;font-size:14px}.activity-entry-group-head span{color:#647684;font-size:12px;font-weight:800}.activity-entry-group-head b{padding:5px 9px;color:#0d6572;background:#e7f6f8;border:1px solid #bddfe6;border-radius:999px;font-size:12px;white-space:nowrap}.classroom-activity-layout{display:grid;grid-template-columns:minmax(280px,.9fr) minmax(320px,1.1fr);gap:16px;align-items:start}.activity-list-item{grid-template-columns:minmax(0,1fr) auto;align-items:center;text-align:left}.activity-list-item.active{background:#eaf6f8;border-color:#b9dfe6}.activity-list-main,.activity-bound-list article div{display:grid;gap:4px;min-width:0}.activity-list-main{padding:0;color:inherit;background:transparent;border:0;text-align:left}.activity-list-actions{display:flex;gap:8px;align-items:center;justify-content:flex-end;flex-wrap:wrap}.activity-list-actions .compact-button{min-height:34px;padding:0 10px}.activity-list-item strong,.activity-bound-list strong,.activity-qr-card strong,.activity-question-stat-head strong{color:#102638;overflow:hidden;text-overflow:ellipsis}.activity-list-item span,.activity-bound-list small,.activity-qr-card small,.activity-stat-meta,.activity-phase-grid small{color:#657483;font-size:12px}.activity-qr-countdown{color:#0d6572!important;font-weight:900}.activity-qr-countdown.warning{color:#a15c00!important}.activity-bound-list article{grid-template-columns:minmax(0,1fr) auto;align-items:center}.activity-qr-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:10px}.activity-qr-card{display:grid;grid-template-columns:92px minmax(0,1fr);gap:10px;align-items:center;padding:10px;background:#f8fbfc;border:1px solid #dce8ed;border-radius:8px}.activity-qr-image{display:grid;place-items:center;width:92px;height:92px;background:#fff;border:1px solid #dce8ed;border-radius:8px}.activity-qr-image img{width:82px;height:82px}.activity-qr-actions{grid-column:1 / -1;display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:8px}.activity-stat-strip,.activity-phase-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:10px;margin-bottom:12px}.activity-phase-grid article{display:grid;gap:4px;padding:10px;background:#f8fbfc;border:1px solid #dce8ed;border-radius:8px}.activity-checkin-panel{display:grid;gap:12px;margin-bottom:12px;padding:12px;background:#f7fbfc;border:1px solid #dce8ed;border-radius:8px}.activity-checkin-head{display:flex;justify-content:space-between;gap:10px;align-items:center}.activity-checkin-head>div{display:grid;gap:4px}.activity-checkin-head strong{color:#102638}.activity-checkin-head span{color:#657483;font-size:12px;font-weight:800}.activity-checkin-head .activity-checkin-actions{display:flex;gap:8px;justify-content:flex-end;flex-wrap:wrap}.activity-checkin-actions .compact-button{min-height:36px}.activity-suspicious-list{display:grid;gap:6px;padding:10px;color:#804d00;background:#fff8eb;border:1px solid #f1d59c;border-radius:8px;font-size:13px}.activity-suspicious-list strong{display:inline-flex;gap:6px;align-items:center;color:#6d4300}.activity-question-stat-head{display:flex;justify-content:space-between;gap:12px;align-items:flex-start}.activity-question-stat-head>div{display:grid;gap:4px;min-width:0}.activity-question-stat-head b{color:#0d6572;white-space:nowrap}.activity-stat-meta{display:flex;gap:10px;flex-wrap:wrap}.activity-option-bars{display:grid;gap:7px}.activity-option-bars>div{display:grid;grid-template-columns:26px minmax(0,1fr) 48px;gap:8px;align-items:center;color:#526776;font-size:12px}.activity-option-bars div div{height:8px;overflow:hidden;background:#e4edf1;border-radius:999px}.activity-option-bars i{display:block;height:100%;background:#168092}.activity-wall-shell{min-width:320px;min-height:100vh;min-height:100dvh;padding:22px;color:#f8fbfc;background:#102638;font-family:Inter,Microsoft YaHei,PingFang SC,system-ui,sans-serif}.activity-wall-page{display:grid;gap:16px;width:min(100%,1580px);min-height:calc(100dvh - 44px);margin:0 auto}.activity-wall-hero{display:grid;grid-template-columns:minmax(0,1fr) 260px;gap:18px;align-items:stretch;padding:22px;background:linear-gradient(135deg,#12344a,#0f6872);border:1px solid rgba(210,231,237,.26);border-radius:12px}.activity-wall-hero>div:first-child{display:grid;align-content:center;gap:9px;min-width:0}.activity-wall-hero span{color:#f8fbfcc7;font-size:15px;font-weight:900}.activity-wall-hero h1{margin:0;color:#fff;font-size:42px;line-height:1.12;text-wrap:balance}.activity-wall-hero p{max-width:62ch;margin:0;color:#f8fbfcd6;font-size:17px;font-weight:700;line-height:1.5}.activity-wall-clock{display:grid;align-content:center;justify-items:center;gap:8px;min-height:132px;padding:16px;background:#f8fbfc1a;border:1px solid rgba(248,251,252,.22);border-radius:10px;text-align:center}.activity-wall-clock span{color:#f8fbfcc7}.activity-wall-clock strong{color:#fff;font-size:38px;line-height:1}.activity-wall-kpis{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.activity-wall-kpis article{display:grid;gap:8px;min-height:110px;padding:18px;color:#102638;background:#f8fbfc;border:1px solid rgba(210,231,237,.92);border-radius:10px}.activity-wall-kpis article.signed{background:#eaf7ef;border-color:#bfe4cd}.activity-wall-kpis article.waiting{background:#fff8eb;border-color:#efcf93}.activity-wall-kpis span{color:#5f7280;font-size:15px;font-weight:900}.activity-wall-kpis strong{color:#102638;font-size:42px;line-height:1}.activity-wall-live{display:grid;grid-template-columns:minmax(300px,.42fr) minmax(0,1fr);gap:14px;min-height:0}.activity-wall-qr-panel{display:grid;align-content:start;gap:14px;min-width:0;padding:18px;color:#102638;background:#f8fbfc;border:1px solid rgba(210,231,237,.92);border-radius:12px}.activity-wall-qr-panel>div:first-child{display:grid;gap:5px}.activity-wall-qr-panel strong{color:#102638;font-size:22px}.activity-wall-qr-panel span,.activity-wall-qr-panel small{color:#657483;font-size:14px;font-weight:800;line-height:1.45}.activity-wall-qr{display:grid;place-items:center;width:100%;aspect-ratio:1;background:#fff;border:1px solid #dce8ed;border-radius:10px}.activity-wall-qr img{width:min(100%,420px);aspect-ratio:1;background:#fff;border:12px solid #ffffff;border-radius:8px}.activity-wall-roster{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:14px;min-height:0}.activity-wall-roster>section{display:grid;grid-template-rows:auto minmax(0,1fr);gap:12px;min-width:0;min-height:0;padding:16px;background:#f8fbfc;border:1px solid rgba(210,231,237,.92);border-radius:12px}.activity-wall-section-title{display:flex;align-items:center;justify-content:space-between;gap:12px;min-width:0}.activity-wall-section-title strong{color:#102638;font-size:22px}.activity-wall-section-title span{color:#657483;font-size:16px;font-weight:900;white-space:nowrap}.activity-wall-name-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(148px,1fr));gap:8px;align-content:start;min-height:0;max-height:calc(100dvh - 330px);overflow:auto;padding-right:2px}.activity-wall-name-grid article{display:grid;gap:5px;min-width:0;min-height:62px;padding:10px 11px;background:#fff;border:1px solid #dce8ed;border-radius:8px}.activity-wall-name-grid.signed article{background:#effaf3;border-color:#ccebd6}.activity-wall-name-grid.waiting article{background:#fffaf0;border-color:#efd59e}.activity-wall-name-grid strong{overflow:hidden;color:#102638;font-size:18px;line-height:1.2;text-overflow:ellipsis;white-space:nowrap}.activity-wall-name-grid span{overflow:hidden;color:#657483;font-size:13px;font-weight:800;text-overflow:ellipsis;white-space:nowrap}.activity-wall-name-grid.signed span{color:#27734a}.activity-wall-name-grid.waiting span{color:#99650a}.activity-wall-empty{display:grid;place-items:center;grid-column:1 / -1;min-height:180px;color:#657483;background:#f2f6f8;border:1px dashed #cddde4;border-radius:8px;font-size:18px;font-weight:900;text-align:center}.activity-entry-wall-shell{min-width:320px;min-height:100vh;min-height:100dvh;padding:18px;color:#f8fbfc;background:#102638;font-family:Inter,Microsoft YaHei,PingFang SC,system-ui,sans-serif}.activity-entry-wall-page{width:min(100%,1680px);min-height:calc(100dvh - 36px);margin:0 auto}.activity-entry-wall-board{display:grid;grid-template-columns:minmax(320px,.36fr) minmax(0,1fr);gap:16px;min-height:calc(100dvh - 36px)}.activity-entry-wall-left,.activity-entry-wall-right{min-width:0;background:#f8fbfc;border:1px solid rgba(210,231,237,.9);border-radius:12px}.activity-entry-wall-left{display:grid;align-content:start;gap:16px;padding:18px;color:#102638}.activity-entry-wall-title{display:grid;gap:6px}.activity-entry-wall-title span{color:#0d6572;font-size:15px;font-weight:900}.activity-entry-wall-title h1{margin:0;color:#102638;font-size:30px;line-height:1.16;text-wrap:balance}.activity-entry-wall-title p{margin:0;color:#526776;font-size:16px;font-weight:800}.activity-entry-wall-qr{display:grid;place-items:center;width:100%;aspect-ratio:1;background:#fff;border:1px solid #dce8ed;border-radius:10px}.activity-entry-wall-qr img{width:min(100%,520px);aspect-ratio:1;background:#fff;border:12px solid #ffffff;border-radius:8px}.activity-entry-wall-code{display:grid;gap:5px;padding:12px;color:#102638;background:#eaf6f8;border:1px solid #bddfe6;border-radius:8px}.activity-entry-wall-code strong{color:#0d6572;font-size:26px;letter-spacing:0}.activity-entry-wall-code span{color:#526776;font-size:14px;font-weight:900}.activity-entry-wall-right{display:grid;gap:14px;align-content:start;padding:16px;color:#102638}.activity-entry-wall-kpis{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}.activity-entry-wall-kpis article{display:grid;gap:6px;min-height:94px;padding:14px;background:#fff;border:1px solid #dce8ed;border-radius:10px}.activity-entry-wall-kpis article.signed{background:#eaf7ef;border-color:#bfe4cd}.activity-entry-wall-kpis article.waiting{background:#fff8eb;border-color:#efcf93}.activity-entry-wall-kpis span{color:#5f7280;font-size:14px;font-weight:900}.activity-entry-wall-kpis strong{color:#102638;font-size:36px;line-height:1}.activity-entry-wall-rosters{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.activity-entry-wall-rosters>section,.activity-entry-wall-question-list{display:grid;gap:12px;min-width:0;padding:14px;background:#fff;border:1px solid #dce8ed;border-radius:10px}.activity-entry-wall-rosters .activity-wall-name-grid{max-height:34dvh}.activity-entry-wall-question-list article{display:grid;gap:10px;padding:11px;background:#f8fbfc;border:1px solid #dce8ed;border-radius:8px}.activity-entry-wall-question-list article>div:first-child{display:grid;gap:4px}.activity-entry-wall-question-list span{color:#0d6572;font-size:12px;font-weight:900}.activity-entry-wall-question-list strong{color:#102638;font-size:16px}.activity-entry-wall-question-list small{color:#657483;font-size:13px;font-weight:800}.activity-entry-wall-question-list .activity-wall-empty{min-height:120px}.bottom-tabs{position:fixed;left:50%;bottom:calc(14px + env(safe-area-inset-bottom));z-index:5;display:flex;gap:6px;width:min(calc(100% - 28px - env(safe-area-inset-left) - env(safe-area-inset-right)),720px);padding:8px;overflow:visible;background:#fffffff0;border:1px solid #d9e3e8;border-radius:8px;box-shadow:0 8px 18px #1c2c381f;transform:translate(-50%)}.bottom-tabs button{position:relative;display:grid;flex:1 1 0;place-items:center;gap:4px;min-height:52px;min-width:0;color:#61717d;border-radius:6px;font-size:12px}.student-tabs button{flex-basis:0}.bottom-tabs .active{color:#0d6572;background:#e9f4f5}.tab-badge{position:absolute;top:4px;right:8px;display:inline-grid;place-items:center;min-width:18px;height:18px;padding:0 5px;color:#fff;background:#c2410c;border:2px solid #ffffff;border-radius:999px;font-size:11px;font-weight:800;line-height:1}.roadmap{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:10px}.live-toolbar{display:grid;grid-template-columns:1fr auto;gap:10px;align-items:center}.filter-toolbar{grid-template-columns:minmax(150px,1fr) minmax(150px,1fr) auto}.learning-filter{grid-template-columns:minmax(130px,1fr) minmax(130px,1fr) minmax(160px,1.1fr) minmax(160px,1.1fr) auto}.learning-export-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:10px}.attendance-layout{display:grid;grid-template-columns:minmax(280px,.85fr) minmax(360px,1.15fr);gap:16px;align-items:start}.attendance-scope-note{margin:0 0 12px;padding:10px 12px;color:#425666;background:#f4fafb;border:1px solid #d2e7ed;border-radius:8px;font-size:13px;font-weight:800;line-height:1.5}.attendance-session-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px;align-items:stretch;padding:8px}.attendance-session-row.active{border-color:#168092;box-shadow:0 0 0 2px #1680921f}.attendance-session-open{display:flex;align-items:center;justify-content:space-between;gap:12px;min-width:0;padding:4px;color:inherit;text-align:left;background:transparent;border:0;cursor:pointer;font:inherit}.attendance-session-open:hover strong,.attendance-session-open:focus-visible strong{color:#0d6977}.attendance-delete-button{align-self:center}.attendance-live-layout{display:grid;grid-template-columns:minmax(320px,.9fr) minmax(420px,1.1fr);gap:16px;align-items:stretch}.attendance-live-qr,.attendance-live-roster{display:grid;gap:14px;align-content:start}.attendance-big-qr{display:grid;place-items:center;padding:18px;background:#f4fafb;border:1px solid #d2e7ed;border-radius:8px}.attendance-big-qr img,.attendance-big-qr .qr-placeholder{width:min(100%,360px);height:auto;aspect-ratio:1;border-radius:8px}.attendance-big-qr img{background:#fff;border:14px solid #ffffff;box-shadow:0 16px 38px #182c381f,inset 0 0 0 1px #dce8ed}.attendance-live-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:8px}.attendance-live-summary div{display:grid;gap:6px;min-height:74px;padding:12px;background:#f8fbfc;border:1px solid #dce8ed;border-radius:8px}.attendance-live-summary .present{background:#edf8f1;border-color:#ccebd6}.attendance-live-summary .waiting{background:#fff8eb;border-color:#f2d7a5}.attendance-live-summary .suspicious{background:#fff1f0;border-color:#f2c1bb}.attendance-live-summary span{color:#617482;font-size:13px;font-weight:800}.attendance-live-summary strong{color:#162233;font-size:26px;line-height:1}.attendance-live-list{display:grid;gap:10px;min-width:0}.attendance-live-list h3{margin:0;color:#1c2b3c;font-size:18px}.attendance-live-list .attendance-record{grid-template-columns:minmax(0,1fr) auto;gap:10px}.attendance-record-person{display:flex;align-items:center;gap:8px;min-width:0}.attendance-live-list .attendance-record strong,.attendance-live-list .attendance-record span{display:inline-block;margin-top:0;white-space:nowrap;word-break:keep-all}.attendance-live-list .attendance-status-buttons{flex-wrap:nowrap;justify-content:flex-end}.attendance-live-list .attendance-status-buttons .compact-button,.attendance-live-list .attendance-status-buttons .small-button{min-width:58px;padding:0 10px}.attendance-live-random{padding-top:2px}.attendance-avatar-wall{display:grid;grid-template-columns:repeat(auto-fill,minmax(82px,1fr));gap:16px 14px;align-content:start;min-height:280px;padding:18px;background:linear-gradient(135deg,#263142,#3d4858);border:1px solid #dce8ed;border-radius:8px}.attendance-avatar-tile{display:grid;justify-items:center;gap:8px;min-width:0;color:#fff;text-align:center}.attendance-avatar-tile strong{max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-shadow:0 1px 3px rgba(0,0,0,.35)}.attendance-avatar,.attendance-avatar-lg{display:grid;place-items:center;width:46px;height:46px;color:#0d6572;background:#e9f4f5;border:2px solid rgba(255,255,255,.85);border-radius:50%;overflow:hidden;font-weight:900}.attendance-avatar-lg{width:64px;height:64px;font-size:18px}.attendance-avatar img{width:100%;height:100%;object-fit:cover}.attendance-avatar-empty{display:grid;place-items:center;grid-column:1 / -1;min-height:220px;color:#ffffffc7;font-weight:800}.attendance-roster-tabs{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;padding:6px;background:#f4fafb;border:1px solid #dce8ed;border-radius:8px}.attendance-roster-tabs button{min-height:42px;color:#526776;background:transparent;border:1px solid transparent;border-radius:8px;font-weight:900}.attendance-roster-tabs button.active{color:#0d6572;background:#fff;border-color:#c4e0e6;box-shadow:0 8px 20px #143d4914}.attendance-live-management{max-height:340px;overflow:auto;padding-right:2px}.attendance-detail,.attendance-record-list{display:grid;gap:12px}.attendance-detail-title span{display:block;margin-top:4px;color:#667987}.attendance-stat-tabs{display:grid;grid-template-columns:repeat(auto-fit,minmax(110px,1fr));gap:8px}.attendance-stat-tabs button{display:grid;gap:6px;min-height:74px;padding:12px;text-align:left;background:#f8fbfc;border:1px solid #dce8ed;border-radius:8px}.attendance-stat-tabs button.active{color:#fff;background:#197586;border-color:#197586;box-shadow:0 10px 22px #1975862e}.attendance-stat-tabs span{color:#617482;font-size:13px;font-weight:800}.attendance-stat-tabs strong{color:#162233;font-size:25px;line-height:1}.attendance-stat-tabs button.active span,.attendance-stat-tabs button.active strong{color:#fff}.attendance-actions{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.attendance-actions input{width:78px;min-height:40px}.attendance-picks{display:flex;gap:8px;flex-wrap:wrap;align-items:center;padding:10px;background:#fff8eb;border:1px solid #f2d7a5;border-radius:8px}.attendance-picks span{padding:6px 10px;color:#8a4a08;background:#fff1d6;border-radius:999px;font-weight:800}.attendance-suspicious-panel{display:grid;gap:6px;padding:12px;color:#6f1d18;background:#fff7f6;border:1px solid #f0c8c3;border-radius:8px}.attendance-suspicious-panel strong,.attendance-suspicious-panel span,.attendance-suspicious-panel p{margin:0}.attendance-suspicious-panel span,.attendance-suspicious-panel p{color:#7a3a35;font-size:13px;font-weight:800;line-height:1.45}.attendance-suspicious-item{display:grid;gap:4px;padding:10px;background:#fff;border:1px solid #f0d3cf;border-radius:8px}.attendance-suspicious-item b,.attendance-suspicious-item span,.attendance-suspicious-item small{margin:0}.attendance-suspicious-item b{color:#6f1d18;font-size:13px}.attendance-suspicious-item span,.attendance-suspicious-item small{color:#7a3a35;font-size:13px;font-weight:800;line-height:1.45}.attendance-suspicious-item small{color:#9b4a42}.attendance-suspicious-badge,.attendance-session-alert{display:inline-flex;align-items:center;width:fit-content;margin-top:5px;padding:4px 8px;color:#9b1c16;background:#fff1f0;border:1px solid #f0c8c3;border-radius:999px;font-size:12px;font-style:normal;font-weight:900}.attendance-qr-panel{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:14px;align-items:center;padding:14px;background:#f4fafb;border:1px solid #d2e7ed;border-radius:8px}.attendance-qr-panel strong,.attendance-qr-panel span{display:block}.attendance-qr-panel span{margin:4px 0 10px;color:#5f7482;font-size:13px;line-height:1.45}.attendance-origin-warning{margin:0 0 10px;padding:8px 10px;color:#8a4a08;background:#fff4d9;border:1px solid #f4d08a;border-radius:8px;font-size:13px;font-weight:800;line-height:1.45}.attendance-qr-controls{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.attendance-qr-controls select{min-height:40px;max-width:140px}.attendance-qr-panel img,.qr-placeholder{width:220px;height:220px;border-radius:8px}.attendance-qr-panel img{background:#fff;border:10px solid #ffffff;box-shadow:inset 0 0 0 1px #dce8ed}.qr-placeholder{display:grid;place-items:center;color:#687987;background:#fff;border:1px dashed #cddde4}.attendance-scan-notice{margin-bottom:12px;padding:10px 12px;background:#fff;border:1px solid #dce8ed;border-radius:8px}.attendance-record{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:12px;align-items:center;padding:12px;background:#f8fbfc;border:1px solid #dce8ed;border-left:5px solid #c8d7df;border-radius:8px}.attendance-record strong,.attendance-record span{display:block}.attendance-record span{margin-top:3px;color:#647785;font-size:13px}.attendance-present{border-left-color:#237047}.attendance-absent{border-left-color:#b3261e}.attendance-late{border-left-color:#c76a00}.attendance-leave{border-left-color:#2563a8}.attendance-status-buttons{display:flex;gap:6px;flex-wrap:wrap;justify-content:flex-end}.detail-title{color:#687987;font-size:14px}.ghost-button{min-height:44px;padding:0 14px;color:#24414c;background:#edf4f6;border:1px solid #d3e0e5;border-radius:8px;font-weight:700}.ghost-button:disabled{cursor:not-allowed;opacity:.5}.classroom-list{display:grid;gap:10px}.classroom-list-item{display:grid;grid-template-columns:1fr auto;gap:10px;align-items:center;padding:10px;background:#f8fbfc;border:1px solid #e1e9ed;border-radius:8px}.classroom-list-item.active{border-color:#197586;box-shadow:0 0 0 3px #1975861a}.classroom-open{display:grid;gap:5px;width:100%;min-height:54px;padding:0;color:#17212f;text-align:left;background:transparent;border:0}.classroom-open strong{line-height:1.45}.classroom-open span{color:#657483;font-size:13px}.live-board{display:grid;gap:14px;margin-top:14px}.question-card{display:grid;gap:8px;padding:16px;color:#fff;background:linear-gradient(135deg,#223d4a,#1f766f);border-radius:8px}.question-card span{color:#ffffffc2;font-size:13px}.question-card strong{font-size:18px;line-height:1.5}.insight-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:14px}.insight-grid section{display:grid;align-content:start;gap:12px;padding:14px;background:#f8fbfc;border:1px solid #e1e9ed;border-radius:8px}.insight-grid h3{display:inline-flex;align-items:center;gap:7px;margin:0;font-size:16px}.error-bars{display:grid;gap:10px}.error-bars div{display:grid;grid-template-columns:minmax(86px,1fr) 2fr auto;gap:8px;align-items:center}.error-bars span{color:#52616f;font-size:13px}meter{width:100%;height:12px}.live-response{display:grid;gap:8px;padding:12px;background:#fff;border:1px solid #dce5ea;border-radius:8px}.live-response p{margin:0;color:#5f4738;font-size:14px;line-height:1.5}.live-hero{background:linear-gradient(135deg,#23515f,#4b7a4f)}.live-question{overflow:hidden}.answer-button{width:100%}.roadmap span{padding:12px;background:#f4f8fa;border:1px solid #dce7ec;border-radius:8px}.points-hero{background:linear-gradient(135deg,#24515b,#55733d)}.points-layout{display:grid;grid-template-columns:minmax(0,1.35fr) minmax(280px,.65fr);gap:14px;align-items:start}.points-layout.secondary{grid-template-columns:minmax(0,1fr) minmax(300px,.9fr)}.student-points-record-layout{grid-template-columns:minmax(0,1fr)}.points-filter-row,.points-action-row,.point-rule-form{display:grid;gap:10px}.point-auto-form{display:grid;grid-template-columns:repeat(auto-fit,minmax(135px,1fr));gap:10px}.point-auto-context{margin:0 0 12px;color:#4d6270;font-size:13px;font-weight:800}.point-auto-form label{display:grid;gap:6px;color:#41515d;font-size:13px;font-weight:800}.point-auto-form button{align-self:end}.points-filter-row{grid-template-columns:minmax(150px,.8fr) minmax(180px,1fr) auto}.points-action-row{grid-template-columns:minmax(0,1fr) auto;margin-top:10px}.point-component-strip{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:10px}.point-component-strip:empty{display:none}.point-component-strip article{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:4px 10px;align-items:center;padding:12px;background:#f8fbfc;border:1px solid #dfe8ec;border-radius:8px}.point-component-strip div{display:grid;gap:3px;min-width:0}.point-component-strip span,.point-component-strip small{color:#687987;font-size:12px}.point-component-strip b{color:#0d6977;font-size:21px}.point-component-strip small{grid-column:1 / -1}.point-rule-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(132px,1fr));gap:8px;margin-top:10px}.point-rule-button{display:grid;gap:5px;min-height:70px;padding:11px;text-align:left;background:#f7fbfa;border:1px solid #dce8ed;border-radius:8px}.point-rule-button span,.point-student-card span,.point-rank-row span,.point-record-row span,.point-rule-row span{color:#5f7280;font-size:13px;line-height:1.35}.point-rule-button.positive{border-color:#cfe6d9}.point-rule-button.negative{border-color:#efd2cf}.point-rule-button.active{background:#eaf7f3;border-color:#23906f;box-shadow:0 0 0 2px #23906f1f}.points-student-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(138px,1fr));gap:8px;margin-top:12px}.point-student-card{display:grid;gap:7px;justify-items:start;min-height:118px;padding:11px;color:inherit;text-align:left;background:#fff;border:1px solid #dce8ed;border-radius:8px}.point-student-card.selected{background:#eff8f4;border-color:#23906f}.points-leaderboard,.point-record-list,.point-rule-list{display:grid;gap:8px}.point-rank-row,.point-record-row,.point-rule-row{display:grid;grid-template-columns:auto minmax(0,1fr) auto;gap:10px;align-items:center;padding:11px;background:#f8fbfc;border:1px solid #e1e9ed;border-radius:8px}.point-rank-row b{display:grid;place-items:center;width:30px;height:30px;color:#0c5f6d;background:#e6f2f4;border-radius:999px}.point-rank-row.top b{color:#7b4e00;background:#fff0bf}.point-rank-row div,.point-record-row div,.point-rule-row div{display:grid;gap:4px;min-width:0}.point-rank-row em{color:#0d6977;font-style:normal;font-size:22px;font-weight:900}.point-record-row p{margin:0;color:#344657;font-size:13px;line-height:1.45}.point-rule-form{grid-template-columns:minmax(120px,.8fr) minmax(140px,1fr) 90px minmax(160px,1fr) auto;margin-bottom:12px}.point-rule-row.editing{grid-template-columns:minmax(0,1fr)}.point-rule-edit-form{display:grid;grid-template-columns:minmax(110px,.75fr) minmax(130px,1fr) 82px minmax(150px,1fr) auto;gap:8px;align-items:center}.point-rule-actions,.point-rule-edit-actions{display:flex;gap:8px;justify-content:flex-end;flex-wrap:wrap}.point-rule-row.disabled{opacity:.58}.positive-text{color:#16724f}.negative-text{color:#b3261e}.error{margin:0;color:#b3261e}.success{display:inline-flex;align-items:center;gap:6px;margin:0;color:#237047}.auth-success{padding:10px 12px;background:#edf8f1;border:1px solid #ccebd6;border-radius:8px;line-height:1.45}.empty,.loading{margin:0;padding:18px;color:#687987;text-align:center;min-width:0;white-space:normal;overflow-wrap:break-word}.case-library-grid>.empty{grid-column:1 / -1}@media(max-width:780px){.app-shell{padding:12px;padding-bottom:calc(96px + env(safe-area-inset-bottom))}.points-layout,.points-layout.secondary,.points-filter-row,.points-action-row,.grading-report-grid,.grading-point-main,.exam-template-flow,.exam-template-editor,.exam-file-slot-header,.point-rule-form,.point-rule-edit-form,.report-config-card{grid-template-columns:1fr}.exam-file-slot-actions{justify-content:flex-start}.auth-layout,.stat-grid,.dashboard-hero,.dashboard-stat-grid,.classroom-activity-layout,.dashboard-columns,.operation-kpi-grid,.operation-layout,.operation-footer-grid,.operation-detail-grid,.warning-toolbar,.warning-layout,.reports-layout,.report-toolbar,.report-config-card,.report-card-grid,.report-detail-grid,.report-document-head,.report-history-toolbar,.exam-summary-kpis,.student-report-layout,.attendance-layout,.attendance-live-layout,.activity-overview-grid,.insight-grid,.live-toolbar,.filter-toolbar,.discussion-meta-grid,.discussion-reply-form,.homework-submission-row,.homework-submission-summary,.homework-correction-panel,.homework-edit-row,.section-resource-upload,.section-resource-grid,.classroom-correction-row,.course-catalog-grid,.course-edit-row,.resource-detail-header,.inline-form,.compact-inline-form,.structure-select,.upload-form,.exam-form,.teacher-create-fields,.teacher-create-binding,.teacher-account-actions,.teacher-binding-picker,.correction-editor,.activity-create-form,.activity-bind-form,.activity-identify-form,.grading-toolbar{grid-template-columns:1fr}.auth-layout{min-height:auto;gap:12px}.auth-card{order:1}.brand-panel{order:2;min-height:auto;gap:18px;padding:18px}.brand-visual{display:none}.brand-content{gap:9px}.brand-mark{width:48px;height:48px}.brand-panel h1{max-width:none;font-size:24px;line-height:1.28}.brand-panel p{font-size:14px;line-height:1.6}.activity-page-header{display:grid}.activity-header-actions{justify-content:stretch}.activity-header-actions button{width:100%}.activity-current-metrics{grid-template-columns:1fr}.activity-panel-title-row{align-items:stretch;flex-direction:column}.activity-create-popover[open]{width:auto}.activity-list-item,.activity-bound-list article,.activity-qr-card{grid-template-columns:1fr}.activity-list-actions{justify-content:flex-start}.activity-phase-tabs{grid-template-columns:repeat(2,minmax(0,1fr))}.activity-phase-group-head,.activity-entry-group-head{display:grid}.activity-phase-group-head b,.activity-entry-group-head b{width:fit-content}.activity-question-picker-head{align-items:stretch;flex-direction:column}.activity-question-picker-head>div:last-child{display:grid;grid-template-columns:repeat(2,minmax(0,1fr))}.activity-qr-image{width:112px;height:112px}.activity-qr-image img{width:102px;height:102px}.activity-qr-actions{grid-template-columns:1fr}.activity-checkin-head{display:grid}.activity-checkin-head .activity-checkin-actions{justify-content:stretch}.activity-checkin-actions .compact-button{width:100%}.activity-question-stat-head{display:grid}.activity-wall-shell{padding:12px}.activity-wall-page{min-height:calc(100dvh - 24px)}.activity-wall-hero,.activity-wall-live,.activity-wall-roster{grid-template-columns:1fr}.activity-wall-hero{padding:16px}.activity-wall-hero h1{font-size:28px}.activity-wall-hero p{font-size:14px}.activity-wall-clock{min-height:92px}.activity-wall-clock strong{font-size:30px}.activity-wall-kpis{grid-template-columns:repeat(2,minmax(0,1fr))}.activity-wall-kpis article{min-height:88px;padding:14px}.activity-wall-kpis strong{font-size:30px}.activity-wall-name-grid{grid-template-columns:repeat(auto-fill,minmax(124px,1fr));max-height:none}.activity-wall-section-title strong{font-size:19px}.activity-entry-wall-shell{padding:10px}.activity-entry-wall-page{min-height:calc(100dvh - 20px)}.activity-entry-wall-board,.activity-entry-wall-rosters{grid-template-columns:1fr;min-height:auto}.activity-entry-wall-left,.activity-entry-wall-right{border-radius:10px}.activity-entry-wall-left,.activity-entry-wall-right,.activity-entry-wall-rosters>section,.activity-entry-wall-question-list{padding:12px}.activity-entry-wall-title h1{font-size:26px}.activity-entry-wall-title p{font-size:14px}.activity-entry-wall-qr{max-width:360px;margin:0 auto}.activity-entry-wall-kpis{grid-template-columns:repeat(2,minmax(0,1fr))}.activity-entry-wall-kpis article{min-height:80px;padding:12px}.activity-entry-wall-kpis strong{font-size:30px}.activity-entry-wall-rosters .activity-wall-name-grid{max-height:none}.question-category-head,.question-category-create,.question-category-scope{display:grid}.question-category-scope{grid-template-columns:1fr}.question-category-row{grid-template-columns:1fr;align-items:stretch}.ai-job-status{display:grid}.questionbank-mode-tabs,.questionbank-resource-tabs{gap:6px;padding:6px}.questionbank-mode-tabs{grid-template-columns:repeat(3,minmax(0,1fr))}.questionbank-resource-tabs{grid-template-columns:repeat(4,minmax(0,1fr))}.questionbank-mode-tabs button,.questionbank-resource-tabs button{min-height:50px;padding:8px 6px}.topbar{gap:10px}.topbar .topbar-actions{flex:0 0 auto}.attendance-record{grid-template-columns:1fr}.operation-class-list{max-height:none;padding-right:0}.operation-class-row,.operation-event-row{grid-template-columns:1fr}.operation-class-metrics{justify-items:start}.warning-follow-grid{grid-template-columns:1fr}.warning-card-head{align-items:stretch;flex-direction:column}.report-mode-card{grid-template-columns:auto minmax(0,1fr)}.report-mode-card b{grid-column:2;justify-self:start}.report-history-tabs{width:100%}.report-history-tabs button{flex:1 1 130px}.warning-card-actions{justify-content:flex-start}.attendance-live-summary{grid-template-columns:repeat(2,minmax(0,1fr))}.attendance-live-summary div{min-height:62px;padding:10px 8px}.attendance-live-summary span{font-size:12px}.attendance-live-summary strong{font-size:22px}.attendance-avatar-wall{grid-template-columns:repeat(auto-fill,minmax(68px,1fr));min-height:180px;padding:12px}.attendance-avatar-lg{width:54px;height:54px}.attendance-live-list .attendance-record{grid-template-columns:1fr}.attendance-stat-tabs{grid-template-columns:repeat(2,minmax(0,1fr));gap:6px}.attendance-stat-tabs button{min-height:62px;padding:10px 8px}.attendance-stat-tabs span{font-size:12px}.attendance-stat-tabs strong{font-size:21px}.attendance-qr-panel{grid-template-columns:1fr}.attendance-status-buttons{justify-content:flex-start}.correction-editor b{text-align:left}.brand-panel{grid-template-rows:auto auto auto;min-height:0;padding:26px;gap:18px}.brand-visual{min-height:148px;padding:14px}.brand-visual-body{min-height:104px}.brand-visual-paper{top:18px;min-height:88px;padding:14px}.brand-visual-panel{top:32px;min-height:82px;padding:12px}.visual-stat strong{font-size:22px}.visual-bars{height:30px;margin-top:10px}.brand-visual-chip{right:12px;bottom:-5px;padding:8px 10px;font-size:12px}.brand-panel h1{font-size:24px;line-height:1.28}.brand-summary{grid-template-columns:repeat(2,minmax(0,1fr))}.brand-summary div{min-height:84px;padding:13px}.brand-summary strong{font-size:15px}.brand-summary span{font-size:12px}.dashboard-hero{padding:18px}.dashboard-hero h1{font-size:28px}.case-library-grid{grid-template-columns:1fr}.dashboard-hero-actions{grid-template-columns:1fr 1fr}.student-row,.exam-row,.paper-library-item{align-items:stretch;flex-direction:column}.case-thumbnail{height:130px}.case-thumbnail iframe{width:640px;height:380px;transform:scale(.46)}.student-actions{justify-content:space-between}.student-actions select{width:100%}.student-approval-list article{align-items:stretch;flex-direction:column}.student-table{overflow:visible;border:0;background:transparent;gap:10px}.student-table-head{display:none}.student-table-row{grid-template-columns:48px minmax(0,1fr) auto;grid-template-areas:"index name action" "index number action" "class class class";gap:6px 10px;padding:12px;border:1px solid #dce8ed;border-radius:8px;background:#fff}.student-table-row .student-index{grid-area:index}.student-table-row strong,.student-table-row .student-name-check{grid-area:name}.student-table-row>span:not(.student-index){grid-area:number}.student-table-row .student-actions:first-of-type{grid-area:class}.student-table-row .action-cell{grid-area:action}.student-stat-grid{grid-template-columns:repeat(2,1fr)}.trend-item,.mastery-row,.question-bank-grid,.question-picker-list,.extracted-edit{grid-template-columns:1fr}.trend-item b,.mastery-row b{text-align:left}.classroom-list-item{grid-template-columns:1fr}.homework-detail-toolbar{align-items:stretch;flex-direction:column}.homework-card-actions{justify-content:flex-start}.auth-card,.panel{padding:14px}.auth-card{padding:18px}.auth-card-header h2{font-size:24px}.captcha-row{grid-template-columns:1fr}.captcha-row strong{justify-content:center}}@media(max-width:1100px)and (min-width:781px){.case-library-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.operation-kpi-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.operation-layout,.operation-footer-grid,.warning-layout,.reports-layout,.activity-entry-wall-board{grid-template-columns:1fr}.activity-entry-wall-left{grid-template-columns:minmax(240px,340px) minmax(0,1fr);align-items:start}.activity-entry-wall-title,.activity-entry-wall-code{grid-column:2}.activity-entry-wall-qr{grid-row:1 / span 2}}@media(max-width:520px){.row-between,.result-row{align-items:flex-start;flex-wrap:wrap}.dashboard-hero-actions,.choice-options-preview,.choice-answer-grid,.profile-grid{grid-template-columns:1fr}.profile-avatar-form{grid-template-columns:auto minmax(0,1fr)}.profile-avatar-form button{grid-column:1 / -1}.student-hero{padding:18px}.student-participation-hero{display:grid}.student-hero h1{font-size:24px}.student-live-metrics{width:100%;grid-template-columns:1fr}.student-live-metrics article{min-height:64px}.student-activity-card-head,.student-activity-entry{align-items:flex-start}.student-activity-entry{display:grid}.student-activity-entry-side{justify-items:start;min-width:0}.dashboard-hero{gap:14px;padding:16px}.dashboard-hero h1{margin:5px 0;font-size:25px}.dashboard-hero p{font-size:14px;line-height:1.55}.dashboard-hero .dashboard-hero-actions{grid-template-columns:repeat(2,minmax(0,1fr))}.dashboard-hero-actions button{min-height:42px;padding:0 8px}.homework-page-upload-panel.exam-file-slot-panel{gap:10px;padding:10px 8px}.exam-file-slot-title{gap:8px}.exam-file-slot-title strong{font-size:15px}.exam-file-slot-title span:not(.exam-file-slot-icon){font-size:12px}.exam-file-slot-icon{width:34px;height:34px}.exam-file-slot-actions{gap:6px}.exam-file-count-pill,.exam-file-slot-actions .compact-button{padding:0 9px;font-size:12px}.homework-page-upload-grid.exam-file-upload-grid{grid-template-columns:1fr;gap:8px}.homework-page-upload-slot.exam-file-upload-slot{gap:8px;padding:10px}.exam-file-upload-card-head{gap:8px}.exam-file-upload-slot .exam-file-page-badge{width:28px;height:28px;font-size:12px}.homework-page-upload-slot b{font-size:14px}.image-source-actions{gap:6px}.image-source-actions .file-button{padding:0 7px;gap:5px;font-size:14px;line-height:1.2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.image-source-actions .file-button svg{flex:0 0 auto;width:15px;height:15px}.image-process-row{padding:0 8px;gap:6px}.brand-visual{min-height:128px}.brand-visual-body{min-height:88px}.brand-visual-panel{width:47%}.brand-visual-chip{display:none}.brand-mark{width:54px;height:54px}.brand-panel h1{font-size:22px;line-height:1.3}.brand-panel p{font-size:15px}.bottom-tabs{bottom:calc(8px + env(safe-area-inset-bottom));width:min(calc(100% - 16px - env(safe-area-inset-left) - env(safe-area-inset-right)),960px);padding:6px}.bottom-tabs button{flex-basis:0;min-width:0}.compact-button,.small-button,.danger-button,.pwa-install-button,.image-source-actions .file-button,.image-process-row,.exam-file-count-pill,.exam-file-slot-actions .compact-button{min-height:44px}.icon-button,.danger-icon-button,.mini-icon-button,.node-menu-trigger,.point-rank-row b{width:44px;height:44px;min-height:44px}.exam-summary-header,.exam-summary-actions{display:grid;grid-template-columns:1fr;width:100%}.exam-summary-actions button{width:100%}.exam-summary-kpis{grid-template-columns:repeat(2,minmax(0,1fr))}.exam-summary-table-wrap{display:none}.exam-summary-card-list{display:grid;gap:10px}.exam-summary-card-score{flex-direction:column}.profile-info-row{grid-template-columns:1fr;gap:4px}.case-thumbnail iframe{transform:scale(calc((100vw - 52px) / 640))}}
