@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-space-y-reverse:0;--tw-border-style:solid;--tw-leading:initial;--tw-font-weight:initial;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial}}}@layer theme{:root,:host{--font-sans:ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--color-red-50:oklch(97.1% .013 17.38);--color-red-100:oklch(93.6% .032 17.717);--color-red-200:oklch(88.5% .062 18.334);--color-red-600:oklch(57.7% .245 27.325);--color-red-700:oklch(50.5% .213 27.518);--color-orange-50:oklch(98% .016 73.684);--color-orange-700:oklch(55.3% .195 38.402);--color-amber-100:oklch(96.2% .059 95.617);--color-amber-600:oklch(66.6% .179 58.318);--color-amber-700:oklch(55.5% .163 48.998);--color-emerald-50:oklch(97.9% .021 166.113);--color-emerald-100:oklch(95% .052 163.051);--color-emerald-600:oklch(59.6% .145 163.225);--color-emerald-700:oklch(50.8% .118 165.612);--color-sky-50:oklch(97.7% .013 236.62);--color-sky-100:oklch(95.1% .026 236.824);--color-sky-600:oklch(58.8% .158 241.966);--color-sky-700:oklch(50% .134 242.749);--color-blue-50:oklch(97% .014 254.604);--color-blue-100:oklch(93.2% .032 255.585);--color-blue-200:oklch(88.2% .059 254.128);--color-blue-600:oklch(54.6% .245 262.881);--color-blue-700:oklch(48.8% .243 264.376);--color-violet-100:oklch(94.3% .029 294.588);--color-violet-700:oklch(49.1% .27 292.581);--color-rose-50:oklch(96.9% .015 12.422);--color-rose-100:oklch(94.1% .03 12.58);--color-rose-600:oklch(58.6% .253 17.585);--color-rose-700:oklch(51.4% .222 16.935);--color-slate-50:oklch(98.4% .003 247.858);--color-slate-100:oklch(96.8% .007 247.896);--color-slate-200:oklch(92.9% .013 255.508);--color-slate-300:oklch(86.9% .022 252.894);--color-slate-400:oklch(70.4% .04 256.788);--color-slate-500:oklch(55.4% .046 257.417);--color-slate-600:oklch(44.6% .043 257.281);--color-slate-700:oklch(37.2% .044 257.287);--color-slate-900:oklch(20.8% .042 265.755);--color-white:#fff;--spacing:.25rem;--container-md:28rem;--text-xs:.75rem;--text-xs--line-height:calc(1 / .75);--text-sm:.875rem;--text-sm--line-height:calc(1.25 / .875);--text-base:1rem;--text-base--line-height: 1.5 ;--text-lg:1.125rem;--text-lg--line-height:calc(1.75 / 1.125);--text-xl:1.25rem;--text-xl--line-height:calc(1.75 / 1.25);--font-weight-medium:500;--font-weight-semibold:600;--leading-tight:1.25;--radius-lg:.5rem;--radius-xl:.75rem;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.fixed{position:fixed}.sticky{position:sticky}.\!start{inset-inline-start:var(--spacing)!important}.start{inset-inline-start:var(--spacing)}.end{inset-inline-end:var(--spacing)}.top-0{top:calc(var(--spacing) * 0)}.container{width:100%}@media(min-width:40rem){.container{max-width:40rem}}@media(min-width:48rem){.container{max-width:48rem}}@media(min-width:64rem){.container{max-width:64rem}}@media(min-width:80rem){.container{max-width:80rem}}@media(min-width:96rem){.container{max-width:96rem}}.mx-auto{margin-inline:auto}.mt-1{margin-top:calc(var(--spacing) * 1)}.mt-2{margin-top:calc(var(--spacing) * 2)}.mt-3{margin-top:calc(var(--spacing) * 3)}.mt-4{margin-top:calc(var(--spacing) * 4)}.mt-5{margin-top:calc(var(--spacing) * 5)}.mt-6{margin-top:calc(var(--spacing) * 6)}.mt-16{margin-top:calc(var(--spacing) * 16)}.mt-20{margin-top:calc(var(--spacing) * 20)}.mb-2{margin-bottom:calc(var(--spacing) * 2)}.mb-3{margin-bottom:calc(var(--spacing) * 3)}.ml-1{margin-left:calc(var(--spacing) * 1)}.ml-3{margin-left:calc(var(--spacing) * 3)}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline-flex{display:inline-flex}.table{display:table}.min-h-screen{min-height:100vh}.w-full{width:100%}.max-w-md{max-width:var(--container-md)}.min-w-0{min-width:calc(var(--spacing) * 0)}.min-w-\[360px\]{min-width:360px}.min-w-\[680px\]{min-width:680px}.min-w-\[760px\]{min-width:760px}.min-w-\[880px\]{min-width:880px}.min-w-\[900px\]{min-width:900px}.min-w-\[980px\]{min-width:980px}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.cursor-pointer{cursor:pointer}.list-disc{list-style-type:disc}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-cols-\[280px_minmax\(0\,1fr\)\]{grid-template-columns:280px minmax(0,1fr)}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.items-end{align-items:flex-end}.justify-between{justify-content:space-between}.justify-end{justify-content:flex-end}.gap-1{gap:calc(var(--spacing) * 1)}.gap-2{gap:calc(var(--spacing) * 2)}.gap-3{gap:calc(var(--spacing) * 3)}.gap-4{gap:calc(var(--spacing) * 4)}.gap-5{gap:calc(var(--spacing) * 5)}:where(.space-y-1>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 1) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 1) * calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-2>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 2) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 2) * calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-3>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 3) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 3) * calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-4>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 4) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 4) * calc(1 - var(--tw-space-y-reverse)))}.self-end{align-self:flex-end}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.rounded{border-radius:.25rem}.rounded-full{border-radius:3.40282e38px}.rounded-lg{border-radius:var(--radius-lg)}.rounded-xl{border-radius:var(--radius-xl)}.border{border-style:var(--tw-border-style);border-width:1px}.border-t{border-top-style:var(--tw-border-style);border-top-width:1px}.border-dashed{--tw-border-style:dashed;border-style:dashed}.border-blue-200{border-color:var(--color-blue-200)}.border-red-200{border-color:var(--color-red-200)}.border-slate-100{border-color:var(--color-slate-100)}.border-slate-200{border-color:var(--color-slate-200)}.border-slate-300{border-color:var(--color-slate-300)}.bg-amber-100{background-color:var(--color-amber-100)}.bg-blue-50{background-color:var(--color-blue-50)}.bg-blue-600{background-color:var(--color-blue-600)}.bg-emerald-50{background-color:var(--color-emerald-50)}.bg-emerald-100{background-color:var(--color-emerald-100)}.bg-emerald-600{background-color:var(--color-emerald-600)}.bg-orange-50{background-color:var(--color-orange-50)}.bg-red-50{background-color:var(--color-red-50)}.bg-rose-50{background-color:var(--color-rose-50)}.bg-rose-100{background-color:var(--color-rose-100)}.bg-sky-50{background-color:var(--color-sky-50)}.bg-sky-100{background-color:var(--color-sky-100)}.bg-sky-600{background-color:var(--color-sky-600)}.bg-slate-50{background-color:var(--color-slate-50)}.bg-violet-100{background-color:var(--color-violet-100)}.bg-white{background-color:var(--color-white)}.p-1\.5{padding:calc(var(--spacing) * 1.5)}.p-3{padding:calc(var(--spacing) * 3)}.p-4{padding:calc(var(--spacing) * 4)}.p-6{padding:calc(var(--spacing) * 6)}.p-8{padding:calc(var(--spacing) * 8)}.px-2{padding-inline:calc(var(--spacing) * 2)}.px-3{padding-inline:calc(var(--spacing) * 3)}.py-0\.5{padding-block:calc(var(--spacing) * .5)}.py-1{padding-block:calc(var(--spacing) * 1)}.py-1\.5{padding-block:calc(var(--spacing) * 1.5)}.py-2{padding-block:calc(var(--spacing) * 2)}.py-2\.5{padding-block:calc(var(--spacing) * 2.5)}.py-6{padding-block:calc(var(--spacing) * 6)}.pb-2{padding-bottom:calc(var(--spacing) * 2)}.pl-5{padding-left:calc(var(--spacing) * 5)}.text-center{text-align:center}.text-left{text-align:left}.text-base{font-size:var(--text-base);line-height:var(--tw-leading,var(--text-base--line-height))}.text-lg{font-size:var(--text-lg);line-height:var(--tw-leading,var(--text-lg--line-height))}.text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.text-xl{font-size:var(--text-xl);line-height:var(--tw-leading,var(--text-xl--line-height))}.text-xs{font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height))}.text-\[11px\]{font-size:11px}.leading-7{--tw-leading:calc(var(--spacing) * 7);line-height:calc(var(--spacing) * 7)}.leading-tight{--tw-leading:var(--leading-tight);line-height:var(--leading-tight)}.font-medium{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.font-semibold{--tw-font-weight:var(--font-weight-semibold);font-weight:var(--font-weight-semibold)}.text-amber-600{color:var(--color-amber-600)}.text-amber-700{color:var(--color-amber-700)}.text-blue-700{color:var(--color-blue-700)}.text-emerald-600{color:var(--color-emerald-600)}.text-emerald-700{color:var(--color-emerald-700)}.text-orange-700{color:var(--color-orange-700)}.text-red-600{color:var(--color-red-600)}.text-red-700{color:var(--color-red-700)}.text-rose-600{color:var(--color-rose-600)}.text-rose-700{color:var(--color-rose-700)}.text-sky-700{color:var(--color-sky-700)}.text-slate-300{color:var(--color-slate-300)}.text-slate-400{color:var(--color-slate-400)}.text-slate-500{color:var(--color-slate-500)}.text-slate-600{color:var(--color-slate-600)}.text-slate-700{color:var(--color-slate-700)}.text-slate-900{color:var(--color-slate-900)}.text-violet-700{color:var(--color-violet-700)}.text-white{color:var(--color-white)}.capitalize{text-transform:capitalize}.antialiased{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.filter{filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}@media(hover:hover){.hover\:bg-blue-100:hover{background-color:var(--color-blue-100)}.hover\:bg-red-50:hover{background-color:var(--color-red-50)}.hover\:bg-red-100:hover{background-color:var(--color-red-100)}.hover\:bg-slate-50:hover{background-color:var(--color-slate-50)}}.disabled\:bg-slate-100:disabled{background-color:var(--color-slate-100)}.disabled\:opacity-40:disabled{opacity:.4}.disabled\:opacity-50:disabled{opacity:.5}.disabled\:opacity-60:disabled{opacity:.6}@media(min-width:48rem){.md\:col-span-1{grid-column:span 1/span 1}.md\:col-span-2{grid-column:span 2/span 2}.md\:col-span-3{grid-column:span 3/span 3}.md\:col-span-4{grid-column:span 4/span 4}.md\:col-span-5{grid-column:span 5/span 5}.md\:col-span-6{grid-column:span 6/span 6}.md\:ml-5{margin-left:calc(var(--spacing) * 5)}.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.md\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.md\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.md\:grid-cols-5{grid-template-columns:repeat(5,minmax(0,1fr))}.md\:grid-cols-6{grid-template-columns:repeat(6,minmax(0,1fr))}.md\:p-5{padding:calc(var(--spacing) * 5)}}@media(min-width:64rem){.lg\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}}}:root{--bg:#f8fafc;--text:#0f172a;--muted:#94a3b8;--line:#0f172a14;--sidebar-width:clamp(268px, 16vw, 340px)}body{background:var(--bg);color:var(--text);font-family:Inter,PingFang SC,Microsoft YaHei,sans-serif;font-size:13px;line-height:1.6}h1,h2,h3,h4,h5,h6,.app-title,.font-bold,.font-semibold,.font-extrabold{font-weight:500!important}.helper-text,.text-slate-500,.text-slate-600,.text-slate-400{color:var(--muted)!important;font-size:11px!important}.glass-card{border:.5px solid var(--line);background:#fff;border-radius:12px}.app-container{max-width:min(2200px,100vw - 12px)}.app-shell{align-items:stretch;min-height:calc(100vh - 16px);grid-template-columns:var(--sidebar-width) minmax(0,1fr)!important}.sidebar{width:var(--sidebar-width);min-width:var(--sidebar-width);height:calc(100vh - 24px);min-height:calc(100vh - 24px);max-height:calc(100vh - 24px);position:sticky;top:12px;overflow:auto}.sidebar-top .meta-line{line-height:1.25}.action-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:6px;display:grid}.action-btn{color:#334155;text-align:center;background:#fff;border:1px solid #0f172a1a;border-radius:8px;padding:6px;font-size:11px;line-height:1.1}.action-btn-primary{color:#fff;background:#0284c7;border-color:#0284c7}.action-btn-danger{color:#dc2626;border-color:#dc262640}.nav-item{background:0 0;border:1px solid #0f172a0f;transition:all .2s}.nav-item:hover{background:#f8fafc;border-color:#0ea5e940;transform:translate(2px)}.nav-item .nav-dot{opacity:.4;background:currentColor;border-radius:50%;width:8px;height:8px;display:inline-block}.nav-item.active{background:#0ea5e9;border-color:#0ea5e9;box-shadow:0 8px 20px -14px #0284c7e6}.nav-item.active .nav-dot{opacity:1;background:#ffffffb3}.stats-bar{grid-template-columns:repeat(6,minmax(0,1fr));gap:10px;margin-bottom:12px;display:grid}.stat-card{border:.5px solid var(--line);background:#fff;border-radius:12px;padding:14px 16px}.stat-card-clickable{cursor:pointer;transition:transform .18s,box-shadow .18s,border-color .18s}.stat-card-clickable:hover{border-color:#0ea5e959;transform:translateY(-1px);box-shadow:0 8px 22px -18px #0284c7cc}.stat-label{color:#94a3b8;font-size:11px}.stat-value{color:#0f172a;margin-top:4px;font-size:22px;font-weight:500;line-height:1.2}.stat-dual{gap:4px;margin-top:4px;display:grid}.stat-dual-line{justify-content:space-between;align-items:center;display:flex}.stat-dual-divider{background:#0f172a14;height:1px}.stat-dual-k{color:#64748b;font-size:11px}.stat-dual-v{color:#0f172a;font-size:18px;font-weight:600}.stat-badge{border-radius:999px;margin-top:8px;padding:2px 8px;font-size:11px;display:inline-flex}.stat-badge.up{color:#065f46;background:#d1fae5}.stat-badge.down{color:#991b1b;background:#fee2e2}.stat-badge.flat{color:#475569;background:#e2e8f0}.detail-mask{z-index:10000;background:#0f172a59;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.detail-card{background:#fff;border:1px solid #0f172a14;border-radius:14px;width:min(720px,100%);max-height:min(78vh,680px);padding:14px 16px;overflow:auto;box-shadow:0 24px 48px -26px #0206178c}.detail-head{justify-content:space-between;align-items:center;gap:10px;margin-bottom:10px;display:flex}.detail-head h3{color:#0f172a;font-size:16px}.detail-close{color:#334155;background:#fff;border:1px solid #0f172a1f;border-radius:8px;padding:4px 10px;font-size:12px}.detail-list{gap:6px;display:grid}.detail-list p{color:#1e293b;background:#f8fafc;border:1px solid #0f172a0f;border-radius:8px;padding:6px 8px;font-size:13px}.table-scroll{background:#fff;border:.5px solid #0f172a14;border-radius:12px;max-height:calc(100vh - 320px);overflow:auto}.table-scroll table{min-width:max-content}.table-scroll thead th{z-index:3;background:#f8fafc;position:sticky;top:0}.table-scroll tbody tr:hover td{background:#f1f5f9}.table-scroll th,.table-scroll td{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.table-scroll td{max-width:320px}.student-grid{border:.5px solid #0f172a0f;border-radius:12px;overflow:hidden}.student-cards{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:10px;display:grid}.student-card{cursor:pointer;background:#fff;border:.5px solid #0f172a14;border-radius:12px;gap:8px;padding:10px;transition:transform .16s,box-shadow .16s,border-color .16s;display:grid}.student-card:hover{border-color:#0ea5e959;transform:translateY(-1px);box-shadow:0 10px 24px -20px #0284c7d9}.student-card-head{justify-content:space-between;align-items:center;gap:8px;display:flex}.student-card-name{align-items:center;gap:8px;min-width:0;display:flex}.student-card-title{color:#0f172a;text-overflow:ellipsis;white-space:nowrap;font-size:13px;font-weight:600;overflow:hidden}.student-card-index{color:#94a3b8;font-size:11px}.student-card-tags{flex-wrap:wrap;gap:4px;display:flex}.student-card-tag{border-radius:999px;padding:1px 7px;font-size:10px;display:inline-flex}.student-card-stats{grid-template-columns:1fr 1fr;gap:8px;display:grid}.student-card-stat{background:#f8fafc;border:1px solid #0f172a0f;border-radius:9px;padding:6px 8px}.student-card-stat label{color:#94a3b8;font-size:10px;display:block}.student-card-stat strong{color:#0f172a;font-size:15px}.student-row{border-bottom:.5px solid #0f172a0f;grid-template-columns:28px 1fr 70px 70px 80px;align-items:center;gap:8px;padding:8px 10px;display:grid}.student-row:last-child{border:none}.student-row-clickable{cursor:pointer;transition:background-color .2s}.student-row-clickable:hover{background:#eef6ff}.student-row:nth-child(odd){background:#f8fafc}.avatar-dot{color:#0f172a;border-radius:50%;justify-content:center;align-items:center;width:26px;height:26px;font-size:11px;display:inline-flex}.score-cell{text-align:right;font-weight:500}.progress-track{background:#e2e8f0;border-radius:2px;height:4px;overflow:hidden}.progress-fill{background:#0ea5e9;border-radius:2px;height:100%}.student-editor-card{width:min(980px,100%);max-height:min(86vh,860px)}.seat-mini-wrap{background:#fff;border:.5px solid #0f172a14;border-radius:12px;padding:8px}.seat-legend{color:#64748b;gap:10px;margin-bottom:8px;font-size:11px;display:flex}.seat-mini-grid{grid-template-columns:repeat(8,minmax(0,1fr));gap:5px;display:grid}.seat-mini-cell{aspect-ratio:1;border-radius:5px;justify-content:center;align-items:center;font-size:8px;display:flex}.seat-mini-cell.present{color:#0369a1;background:#e0f2fe}.seat-mini-cell.empty{color:#94a3b8;background:#f1f5f9}.seat-mini-cell.warn{color:#92400e;background:#fef3c7}@media(max-width:1100px){.app-shell{grid-template-columns:1fr!important}.sidebar{width:100%;min-width:0;height:auto;min-height:0;max-height:none;position:static;overflow:visible}.stats-bar{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:1280px){#app{padding:12px!important}.table-scroll{max-height:calc(100vh - 300px)}}@media(min-width:1680px){.app-container{max-width:min(2360px,100vw - 16px)}.table-scroll{max-height:calc(100vh - 260px)}.student-row{grid-template-columns:36px 1fr 88px 88px 110px;padding:9px 12px}}@media(max-width:1024px){.app-shell{min-height:auto;grid-template-columns:1fr!important}.sidebar{width:100%;min-width:0;max-height:none;position:static!important}.sidebar nav{grid-template-columns:repeat(2,minmax(0,1fr));gap:6px;display:grid}.stats-bar{grid-template-columns:repeat(2,minmax(0,1fr))}.table-scroll{max-height:calc(100vh - 340px)}.table-scroll td{max-width:220px}}@media(max-width:640px){#app{padding:8px!important}.app-container{max-width:100vw}.app-shell{gap:10px!important}.glass-card{border-radius:10px}.sidebar{padding:10px!important}.action-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.action-btn{padding:8px 6px;font-size:12px}.stats-bar,.sidebar nav{grid-template-columns:1fr}.table-scroll{border-radius:10px;max-height:calc(100vh - 300px)}.table-scroll td{max-width:160px}.student-row{grid-template-columns:24px 1fr 56px 56px 70px;gap:6px;padding:7px 8px}.student-cards{grid-template-columns:1fr}.seat-mini-grid{grid-template-columns:repeat(6,minmax(0,1fr))}}.screen-body{color:#e2e8f0;background:radial-gradient(circle at 20% 20%,#1e293b,#0b1220 55%,#060b14);min-height:100vh;margin:0;font-family:PingFang SC,Microsoft YaHei,-apple-system,BlinkMacSystemFont,sans-serif;overflow:hidden}.screen-body .bg-layer{pointer-events:none;position:fixed;inset:0}.screen-body .bg-grid{background-image:linear-gradient(#94a3b814 1px,#0000 1px),linear-gradient(90deg,#94a3b814 1px,#0000 1px);background-size:48px 48px}.screen-body .bg-glow{background:radial-gradient(circle at 80% 15%,#0ea5e929,#0000 35%),radial-gradient(circle at 10% 90%,#22c55e24,#0000 35%)}.screen-body .screen-wrap{z-index:2;box-sizing:border-box;gap:10px;height:100vh;padding:10px 14px;display:grid;position:relative}.screen-body .top-nav{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#0f172a99;border:1px solid #94a3b840;border-radius:12px;align-items:center;gap:8px;padding:8px;display:flex}.screen-body .top-nav.hidden{display:none}.screen-body .nav-btn,.screen-body .nav-dock-btn,.screen-body .dock-btn,.screen-body .mode-btn,.screen-body .secondary,.screen-body .primary{color:#e2e8f0;cursor:pointer;background:#1e293bb3;border:1px solid #94a3b859;border-radius:10px;padding:6px 10px}.screen-body .nav-btn.active,.screen-body .nav-dock-btn.active,.screen-body .dock-btn.active,.screen-body .mode-btn.active,.screen-body .primary{color:#fff;background:#0369a1;border-color:#0369a1}.screen-body .build-tag{color:#94a3b8;margin-left:auto;font-size:12px}.screen-body .main-view{min-height:0;display:none;overflow:hidden}.screen-body .main-view.active{display:block}.screen-body .screen-header{justify-content:space-between;align-items:center;gap:8px;margin-bottom:6px;display:flex}.screen-body .screen-header h1{margin:0;font-size:24px;line-height:1.15}.screen-body .screen-header p{color:#94a3b8;margin:2px 0 0;font-size:12px;line-height:1.2}.screen-body .server-time{color:#38bdf8;white-space:nowrap;font-size:18px;font-weight:700}.screen-body .grid{grid-template-rows:repeat(2,minmax(0,1fr));grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;height:calc(100vh - 112px);display:grid}.screen-body .panel{background:#0f172aa6;border:1px solid #94a3b840;border-radius:14px;flex-direction:column;min-height:0;padding:10px;display:flex;overflow:hidden}.screen-body .panel h2{color:#7dd3fc;margin:0 0 8px;font-size:17px}.screen-body .kpis{grid-template-columns:minmax(0,1.7fr) repeat(2,minmax(0,1fr));gap:6px;margin-bottom:6px;display:grid}.screen-body .kpi{background:#0f172a8c;border:1px solid #94a3b840;border-radius:10px;padding:6px}.screen-body .kpi label{color:#94a3b8;font-size:12px;display:block}.screen-body .kpi strong{font-size:18px}.screen-body .kpi-time-board{grid-column:span 1}.screen-body .mini-time-table{border-collapse:collapse;width:100%;margin-top:4px;font-size:12px}.screen-body .mini-time-table th,.screen-body .mini-time-table td{border:1px solid #94a3b833;padding:4px 6px}.screen-body .mini-time-table th{color:#94a3b8;text-align:left;background:#1e293b61;width:52px;font-weight:500}.screen-body .mini-time-table td{color:#e2e8f0;font-weight:600}.screen-body .data-list{gap:6px;margin:6px 0 0;padding:0;list-style:none;display:grid;overflow:auto}.screen-body .item{white-space:normal;word-break:break-word;background:#1e293ba6;border-radius:8px;padding:8px;font-size:12.5px;line-height:1.45}.screen-body .scroll-wrap{flex:1;min-height:0;overflow:hidden}.screen-body .scroll-strip{height:100%}.screen-body .data-list.auto-scroll{scrollbar-width:none}.screen-body .data-list.auto-scroll::-webkit-scrollbar{width:0;height:0}.screen-body .notice-columns{grid-template-columns:1fr 1fr;gap:10px;display:grid}.screen-body .notice-columns .data-list{margin-top:0}.screen-body .bulletin-col{flex-direction:column;min-width:0;display:flex}.screen-body .bulletin-col>label{color:#93c5fd;margin-bottom:6px;font-size:13px}.screen-body .countdown-main{color:#fcd34d;margin-bottom:10px;font-size:16px}.screen-body .timer{grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;display:grid}.screen-body .time-item{text-align:center;background:#0f172a8c;border:1px solid #94a3b840;border-radius:10px;padding:10px 6px}.screen-body .time-item strong{color:#f8fafc;font-size:26px;display:block}.screen-body .time-item span{color:#94a3b8;font-size:12px}.screen-body .grid.compact{gap:8px}.screen-body .grid.compact .panel{border-radius:12px;padding:8px}.screen-body .grid.compact .panel h2{margin-bottom:6px;font-size:16px}.screen-body .grid.compact .kpis{gap:4px;margin-bottom:4px}.screen-body .grid.compact .kpi{padding:4px}.screen-body .grid.compact .kpi label{font-size:11px}.screen-body .grid.compact .kpi strong{font-size:16px}.screen-body .grid.compact .mini-time-table{margin-top:2px;font-size:11px}.screen-body .grid.compact .mini-time-table th,.screen-body .grid.compact .mini-time-table td{padding:3px 4px}.screen-body .grid.compact .item{padding:6px;font-size:12px;line-height:1.35}.screen-body .grid.compact .countdown-main{margin-bottom:6px;font-size:14px}.screen-body .grid.compact .time-item{padding:6px 4px}.screen-body .grid.compact .time-item strong{font-size:20px}.screen-body .forest-layout{gap:12px;height:calc(100vh - 130px);display:grid}.screen-body .forest-layout.pos-left{grid-template-columns:330px 1fr}.screen-body .forest-layout.pos-right{grid-template-columns:1fr 330px}.screen-body .forest-layout.pos-right .control-panel{order:2}.screen-body .forest-layout.pos-bottom{grid-template-rows:1fr auto;grid-template-columns:1fr}.screen-body .control-panel{background:#0f172aad;border:1px solid #94a3b840;border-radius:14px;align-content:start;gap:10px;padding:12px;display:grid;overflow:auto}.screen-body .forest-title{justify-content:space-between;align-items:center;display:flex}.screen-body .forest-title h2{color:#86efac;margin:0;font-size:18px}.screen-body .forest-title span{color:#facc15;font-size:12px}.screen-body .dock-switch,.screen-body .session-box,.screen-body .mode-selector,.screen-body .forest-stats,.screen-body .forest-health,.screen-body .vol-box,.screen-body .slider-box,.screen-body .forest-actions{background:#02061766;border:1px solid #94a3b82e;border-radius:10px;padding:8px}.screen-body .dock-buttons,.screen-body .mode-selector,.screen-body .forest-actions,.screen-body .mic-row{flex-wrap:wrap;gap:6px;display:flex}.screen-body .session-box{grid-template-columns:1fr 1fr;gap:8px;display:grid}.screen-body .session-box div{background:#0f172aa6;border-radius:8px;padding:6px}.screen-body .session-box span{color:#94a3b8;font-size:12px;display:block}.screen-body .session-box strong{font-size:18px}.screen-body .forest-stats{grid-template-columns:1fr 1fr;gap:8px;display:grid}.screen-body .stat-item{background:#0f172aa6;border-radius:8px;padding:8px}.screen-body .stat-head{color:#cbd5e1;justify-content:space-between;font-size:12px;display:flex}.screen-body .stat-val{font-size:24px;font-weight:700}.screen-body .stat-val.withered{color:#fca5a5}.screen-body .health-row,.screen-body .vol-row{justify-content:space-between;font-size:12px;display:flex}.screen-body .health-track,.screen-body .vol-track{background:#94a3b833;border-radius:999px;height:8px;margin-top:6px;position:relative;overflow:hidden}.screen-body .health-bar{background:linear-gradient(90deg,#22c55e,#0ea5e9);width:100%;height:100%}.screen-body .vol-bar{background:linear-gradient(90deg,#38bdf8,#22c55e);width:0;height:100%}.screen-body .vol-line{background:#f97316;width:2px;position:absolute;top:-2px;bottom:-2px;left:20%}.screen-body .slider-box{gap:6px;font-size:12px;display:grid}.screen-body .slider-box input[type=range]{width:100%}.screen-body .forest-stage{background:#0f172aad;border:1px solid #94a3b840;border-radius:14px;grid-template-rows:auto auto 1fr;gap:8px;min-height:0;padding:12px;display:grid}.screen-body .land-tag{color:#86efac;font-size:16px}.screen-body .forest-legend{color:#cbd5e1;gap:14px;font-size:12px;display:flex}.screen-body .forest-land{border:1px dashed #94a3b84d;border-radius:10px;grid-template-columns:repeat(12,minmax(0,1fr));align-content:start;gap:6px;padding:8px;display:grid;overflow:auto}.screen-body .tree-cell{text-align:center;background:#1e293b80;border-radius:6px;padding:4px;font-size:20px}.screen-body .tree-cell.good{box-shadow:inset 0 0 0 1px #22c55e59}.screen-body .tree-cell.bad{box-shadow:inset 0 0 0 1px #f43f5e59}.screen-body .global-nav-toggle,.screen-body .global-nav-show{z-index:10;color:#e2e8f0;cursor:pointer;background:#0f172acc;border:1px solid #94a3b859;border-radius:10px;padding:6px 10px;position:fixed;top:10px;right:12px}.screen-body .global-nav-show{top:48px}.screen-body .hidden{display:none!important}.screen-body .top-nav.dock-left{justify-self:start}.screen-body .top-nav.dock-right{justify-self:end}.screen-body .top-nav.dock-bottom{z-index:20;position:fixed;bottom:10px;left:50%;transform:translate(-50%)}@media(max-width:1200px){.screen-body{overflow:auto}.screen-body .grid{grid-template-columns:1fr;height:auto}.screen-body .screen-wrap{height:auto;min-height:100vh}.screen-body .kpis,.screen-body .forest-layout.pos-left,.screen-body .forest-layout.pos-right{grid-template-columns:1fr}.screen-body .forest-layout.pos-right .control-panel{order:0}.screen-body .notice-columns{grid-template-columns:1fr}}@media(max-width:768px){.screen-body .screen-wrap{gap:10px;padding:10px}.screen-body .top-nav{flex-wrap:wrap;gap:6px}.screen-body .build-tag{width:100%;margin-left:0}.screen-body .screen-header{flex-direction:column;align-items:flex-start;gap:6px}.screen-body .screen-header h1{font-size:22px}.screen-body .server-time{font-size:18px}.screen-body .panel{padding:10px}.screen-body .panel h2{font-size:17px}.screen-body .timer{grid-template-columns:repeat(2,minmax(0,1fr))}.screen-body .time-item strong{font-size:22px}}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-space-y-reverse{syntax:"*";inherits:false;initial-value:0}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-leading{syntax:"*";inherits:false}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}
