html,body{width:100%;height:100%}input::-ms-clear,input::-ms-reveal{display:none}*,*:before,*:after{box-sizing:border-box}html{font-family:sans-serif;line-height:1.15;-webkit-text-size-adjust:100%;-ms-text-size-adjust:100%;-ms-overflow-style:scrollbar;-webkit-tap-highlight-color:rgba(0,0,0,0)}@-ms-viewport{width:device-width}body{margin:0}[tabindex="-1"]:focus{outline:none}hr{box-sizing:content-box;height:0;overflow:visible}h1,h2,h3,h4,h5,h6{margin-top:0;margin-bottom:.5em;font-weight:500}p{margin-top:0;margin-bottom:1em}abbr[title],abbr[data-original-title]{-webkit-text-decoration:underline dotted;text-decoration:underline dotted;border-bottom:0;cursor:help}address{margin-bottom:1em;font-style:normal;line-height:inherit}input[type=text],input[type=password],input[type=number],textarea{-webkit-appearance:none}ol,ul,dl{margin-top:0;margin-bottom:1em}ol ol,ul ul,ol ul,ul ol{margin-bottom:0}dt{font-weight:500}dd{margin-bottom:.5em;margin-left:0}blockquote{margin:0 0 1em}dfn{font-style:italic}b,strong{font-weight:bolder}small{font-size:80%}sub,sup{position:relative;font-size:75%;line-height:0;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}pre,code,kbd,samp{font-size:1em;font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,Courier,monospace}pre{margin-top:0;margin-bottom:1em;overflow:auto}figure{margin:0 0 1em}img{vertical-align:middle;border-style:none}a,area,button,[role=button],input:not([type=range]),label,select,summary,textarea{touch-action:manipulation}table{border-collapse:collapse}caption{padding-top:.75em;padding-bottom:.3em;text-align:left;caption-side:bottom}input,button,select,optgroup,textarea{margin:0;color:inherit;font-size:inherit;font-family:inherit;line-height:inherit}button,input{overflow:visible}button,select{text-transform:none}button,html [type=button],[type=reset],[type=submit]{-webkit-appearance:button}button::-moz-focus-inner,[type=button]::-moz-focus-inner,[type=reset]::-moz-focus-inner,[type=submit]::-moz-focus-inner{padding:0;border-style:none}input[type=radio],input[type=checkbox]{box-sizing:border-box;padding:0}input[type=date],input[type=time],input[type=datetime-local],input[type=month]{-webkit-appearance:listbox}textarea{overflow:auto;resize:vertical}fieldset{min-width:0;margin:0;padding:0;border:0}legend{display:block;width:100%;max-width:100%;margin-bottom:.5em;padding:0;color:inherit;font-size:1.5em;line-height:inherit;white-space:normal}progress{vertical-align:baseline}[type=number]::-webkit-inner-spin-button,[type=number]::-webkit-outer-spin-button{height:auto}[type=search]{outline-offset:-2px;-webkit-appearance:none}[type=search]::-webkit-search-cancel-button,[type=search]::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{font:inherit;-webkit-appearance:button}output{display:inline-block}summary{display:list-item}template{display:none}[hidden]{display:none!important}mark{padding:.2em;background-color:#feffe6}:root{font-family:Plus Jakarta Sans,PingFang SC,Microsoft YaHei,sans-serif;--color-primary: #2563eb;--color-success: #16a34a;--color-warning: #d97706;--color-danger: #dc2626;--color-bg: #f4f7fb;--color-surface: #ffffff;--color-surface-muted: #eef4ff;--color-text-primary: #0f172a;--color-text-secondary: #475569;--color-border: #d9e2f0;--color-code-bg: #0f172a;--color-code-text: #e2e8f0;--shadow-card: 0 16px 32px rgba(15, 23, 42, .1);color:var(--color-text-primary);background:var(--color-bg);color-scheme:light}*{box-sizing:border-box}html,body,#root{margin:0;min-height:100%}body{background:var(--color-bg);color:var(--color-text-primary)}a{color:inherit;text-decoration:none}.app-shell{min-height:100vh;background:var(--color-bg)}.app-main-layout,.app-shell .ant-layout{background:transparent!important}.app-sider.ant-layout-sider{background:transparent!important;flex:0 0 240px!important;max-width:240px!important;min-width:240px!important;width:240px!important}.app-sider .ant-layout-sider-children{display:flex;flex-direction:column;justify-content:space-between;gap:24px;padding:24px 16px 24px 24px;background:var(--color-code-bg)}.app-sider__section{display:flex;flex-direction:column;gap:20px;min-height:0}.app-brand{display:flex;flex-direction:column;gap:4px}.app-brand__title.ant-typography{margin:0!important;color:#fff!important;font-size:28px!important;font-weight:700!important;letter-spacing:-.02em}.app-brand__subtitle{color:#cbd5e1!important;font-size:14px}.app-nav-menu.ant-menu{background:transparent!important;border-inline-end:none!important}.app-nav-menu.ant-menu .ant-menu-item{height:44px;margin:0 0 8px!important;border-radius:12px;color:#cbd5e1!important;display:flex;align-items:center;font-size:15px;font-weight:500}.app-nav-menu.ant-menu .ant-menu-item .ant-menu-item-icon{color:inherit!important;font-size:16px}.app-nav-menu.ant-menu .ant-menu-item-selected{background:#1e293b!important;color:#fff!important}.app-nav-menu.ant-menu .ant-menu-item-selected:after{display:none}.app-sider__footer{display:flex;flex-direction:column;gap:8px}.app-sider__footer-label,.app-mobile-drawer__label{color:#94a3b8!important;font-size:12px;font-weight:600}.app-topbar.ant-layout-header{height:72px;line-height:normal;display:flex;justify-content:space-between;align-items:center;margin:28px 28px 0;padding:0 24px!important;background:var(--color-surface)!important;border:1px solid #e2e8f0;border-radius:16px}.app-topbar__left{display:flex;align-items:center;gap:12px}.app-topbar__note{color:var(--color-text-secondary)!important;font-size:15px}.language-switcher{display:inline-flex;align-items:center;justify-content:space-between;gap:8px}.language-switcher.ant-btn{box-shadow:none}.language-switcher--sidebar.ant-btn{width:100%;height:44px;color:#fff;background:#1e293b!important;border-color:#1e293b!important;justify-content:space-between}.language-switcher--sidebar.ant-btn:hover,.language-switcher--sidebar.ant-btn:focus{color:#fff!important;background:#334155!important;border-color:#334155!important}.language-switcher--drawer.ant-btn,.language-switcher--floating.ant-btn{height:40px;color:var(--color-text-primary);background:#fff!important;border:1px solid #e2e8f0!important}.language-switcher--drawer.ant-btn{width:100%;justify-content:space-between}.app-user-avatar{background:#dbeafe!important;color:var(--color-primary)!important}.app-user-name{font-weight:600}.app-shell-content{padding:24px 28px 28px}.page-section{display:flex;flex-direction:column;gap:24px}.page-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px;min-height:72px;padding:16px 24px;background:var(--color-surface);border-radius:16px;border:1px solid #e2e8f0}.page-title{margin:0;font-size:28px;font-weight:700;line-height:1.1}.page-subtitle{margin:8px 0 0;color:#475569;font-size:14px}.stats-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px}.chart-grid{display:grid;grid-template-columns:2fr 1fr;gap:16px}.card-shadow{box-shadow:var(--shadow-card)}.card-shadow.ant-card,.ant-card.card-shadow{border-radius:16px;border:none;background:var(--color-surface)}.ant-card.card-shadow .ant-card-body,.card-shadow.ant-card .ant-card-body{padding:20px}.ant-table-wrapper .ant-table{border-radius:16px}.ant-table-wrapper .ant-table-thead>tr>th{background:#f8fafc;color:var(--color-text-secondary);font-size:13px;font-weight:600;border-bottom:1px solid #e2e8f0}.ant-table-wrapper .ant-table-tbody>tr>td{border-bottom:1px solid #eef2f7}.ant-input,.ant-input-affix-wrapper,.ant-select-selector,.ant-picker,.ant-input-number,.ant-input-number-input-wrap{border-radius:12px!important}.ant-btn{border-radius:12px;height:42px;font-weight:600}.ant-btn-primary{box-shadow:none}.stat-card{display:flex;flex-direction:column;gap:12px;min-height:132px;padding:20px;background:var(--color-surface);border-radius:16px}.stat-card__title{color:var(--color-text-secondary);font-size:14px}.stat-card__value{color:var(--color-text-primary);font-size:34px;font-weight:700;line-height:1;letter-spacing:-.03em}.stat-card__suffix{margin-left:4px;font-size:18px}.stat-card__hint{color:var(--color-text-secondary);font-size:13px;line-height:1.5}.status-tag{display:inline-flex;align-items:center;justify-content:center;min-height:32px;padding:6px 12px;border-radius:12px;font-size:13px;font-weight:600;white-space:nowrap}.status-tag--success{color:var(--color-success);background:#e8f7ed}.status-tag--warning{color:var(--color-warning);background:#fef3c7}.status-tag--danger{color:var(--color-danger);background:#fee2e2}.status-tag--info{color:var(--color-primary);background:#dbeafe}.status-tag--neutral{color:var(--color-text-secondary);background:#e2e8f0}.state-panel{display:flex;flex-direction:column;align-items:flex-start;gap:12px;padding:24px;background:var(--color-surface);border-radius:16px;border:1px solid #e2e8f0;box-shadow:var(--shadow-card)}.state-panel__badge{padding:6px 12px;border-radius:999px;font-size:12px;font-weight:700}.state-panel--empty .state-panel__badge{background:#eef4ff;color:var(--color-primary)}.state-panel--error .state-panel__badge{background:#fee2e2;color:var(--color-danger)}.state-panel__title{font-size:24px;font-weight:700;color:var(--color-text-primary)}.state-panel__description{max-width:560px;color:var(--color-text-secondary);line-height:1.6}.editor-shell{display:flex;flex-direction:column;height:clamp(420px,calc(100vh - 320px),720px);min-height:560px;border-radius:16px;overflow:hidden;background:#fff;box-shadow:0 12px 30px #0f172a14}.editor-shell .editor-toolbar{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid #e2e8f0}.editor-stage{flex:1;min-height:0}.editor-stage>div{height:100%;min-height:0}.result-panel{background:#e2e8f0;border-top:1px solid #cbd5e1;min-height:220px}.teacher-header-actions,.student-header-actions{display:flex;gap:12px;align-items:center}.login-page{position:relative;min-height:100vh;display:grid;grid-template-columns:1.1fr .9fr;background:radial-gradient(circle at top left,rgba(37,99,235,.18),transparent 36%),linear-gradient(180deg,#f8fbff,#eef4fb)}.login-page__actions{position:absolute;top:24px;right:24px;z-index:2}.login-brand .ant-typography{color:var(--color-text-primary)}.login-brand{padding:72px;display:flex;flex-direction:column;justify-content:center;gap:24px}.login-card-wrap{display:flex;align-items:center;justify-content:center;padding:48px}.three-column-grid{display:grid;grid-template-columns:280px minmax(0,1fr) 360px;gap:16px}.student-class-card{display:grid;grid-template-columns:minmax(0,1.6fr) minmax(280px,.8fr);gap:16px;align-items:start}.student-class-card__main{display:flex;flex-direction:column;gap:8px}.student-class-card__note{display:flex;flex-direction:column;gap:8px;padding:16px 18px;border-radius:12px;background:var(--color-surface-muted);color:var(--color-text-primary)}.student-stats-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}.student-filter-card{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}.student-question-layout{display:grid;grid-template-columns:minmax(320px,40%) minmax(0,60%);gap:16px;align-items:start}.student-right-stack{display:grid;grid-template-rows:minmax(0,1fr) minmax(220px,auto);gap:16px;min-height:0}.student-question-layout>*,.student-right-stack>*{min-height:0}.code-font{font-family:JetBrains Mono,Fira Code,monospace}.app-mobile-nav-trigger{display:none}.app-mobile-drawer{display:flex;flex-direction:column;justify-content:space-between;gap:24px;min-height:100%}.app-mobile-drawer__footer{display:flex;flex-direction:column;gap:8px}@media(max-width:1200px){.app-sider.ant-layout-sider{display:none}.app-topbar.ant-layout-header{margin-left:20px;margin-right:20px}.app-shell-content{padding:20px}.app-mobile-nav-trigger{display:inline-flex;align-items:center}.stats-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.chart-grid,.three-column-grid,.student-class-card,.student-question-layout{grid-template-columns:1fr}.student-stats-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.student-right-stack{grid-template-rows:auto auto}.editor-shell{height:520px;min-height:520px}}@media(max-width:768px){.student-stats-grid{grid-template-columns:1fr}}
