@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-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;--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;-webkit-text-decoration:inherit;-webkit-text-decoration: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}.grid{display:grid}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.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,)}}:root{--ink:#172033;--muted:#667085;--line:#26365924;--paper:#ffffffe6;--blue:#2f6df6;--green:#10a86f;--yellow:#f4b740;--pink:#e9568f;--red:#e5484d;--cyan:#13a8b8;--shadow:0 18px 45px #1f2f541f}*{box-sizing:border-box;scrollbar-width:thin;scrollbar-color:#57709c7a #ebf2fcb8}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:#ebf2fcb8;border-radius:999px}::-webkit-scrollbar-thumb{background:linear-gradient(#7a91b8c7,#2f6df694);border:2px solid #ebf2fcb8;border-radius:999px}::-webkit-scrollbar-thumb:hover{background:linear-gradient(#5d7399db,#2f6df6b8)}html,body{min-height:100%;margin:0}body{color:var(--ink);background:radial-gradient(circle at 11% 12%,#2f6df629,#0000 28%),radial-gradient(circle at 82% 8%,#f4b7402e,#0000 24%),linear-gradient(135deg,#f7fbff 0%,#fff9ee 48%,#f6fff8 100%);font-family:Microsoft YaHei,PingFang SC,Noto Sans SC,Arial,sans-serif}button,input,select,textarea{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed;opacity:.52}input,select,textarea{width:100%;color:var(--ink);background:linear-gradient(#fffffffa,#f7fafff0),#fffffff0;border:1px solid #c5d3eadb;border-radius:8px;outline:none;transition:border-color .18s,box-shadow .18s,transform .18s,background .18s;box-shadow:inset 0 1px #ffffffdb,0 4px 12px #2b3d620f}input,select{height:40px;padding:0 12px}textarea{resize:vertical;min-height:142px;padding:12px}input::placeholder,textarea::placeholder{color:#667085ad}input:hover:not(:disabled),select:hover:not(:disabled),textarea:hover:not(:disabled){border-color:#2f6df65c;box-shadow:inset 0 1px #ffffffe6,0 7px 16px #2f6df617}input:focus,select:focus,textarea:focus{background:linear-gradient(#fff,#f4f9fffa),#fffffffa;border-color:#2f6df6b8;box-shadow:0 0 0 4px #2f6df61f,0 10px 22px #2f6df61f}.input-field{color:var(--muted);gap:7px;font-size:13px;font-weight:900;display:grid}.input-shell{width:100%;min-width:0;height:42px;color:var(--ink);background:linear-gradient(#fffffffa,#f7fafff0),linear-gradient(135deg,#2f6df617,#10a86f0d);border:1px solid #c5d3eadb;border-radius:8px;align-items:center;gap:9px;padding:0 11px;transition:border-color .18s,box-shadow .18s,background .18s,transform .18s;display:flex;box-shadow:inset 0 1px #ffffffdb,0 6px 14px #2b3d6212}.input-shell:hover{border-color:#2f6df661;box-shadow:inset 0 1px #ffffffe6,0 9px 20px #2f6df61a}.input-shell:focus-within{background:linear-gradient(#fff,#f2f8fffa),linear-gradient(135deg,#2f6df621,#10a86f12);border-color:#2f6df6b8;box-shadow:0 0 0 4px #2f6df61f,0 12px 24px #2f6df61f}.input-shell input{min-width:0;height:100%;box-shadow:none;background:0 0;border:0;border-radius:0;flex:auto;padding:0}.input-shell input:hover,.input-shell input:focus{box-shadow:none;background:0 0;border:0}.input-shell.with-action{padding-right:6px}.input-icon{color:#2f6df6c7;flex:none;width:18px;height:18px;position:relative}.search-icon:before{content:"";border:2px solid;border-radius:999px;width:10px;height:10px;position:absolute;top:2px;left:2px}.search-icon:after{content:"";background:currentColor;border-radius:999px;width:7px;height:2px;position:absolute;bottom:2px;right:1px;transform:rotate(45deg)}.mail-icon:before{content:"";border:2px solid;border-radius:4px;position:absolute;inset:3px 1px 4px}.mail-icon:after{content:"";transform-origin:50%;border-bottom:2px solid;border-right:2px solid;width:10px;height:8px;position:absolute;top:6px;left:4px;transform:rotate(45deg)skew(-10deg,-10deg)}.lock-icon:before{content:"";border:2px solid;border-bottom:0;border-radius:8px 8px 0 0;width:10px;height:9px;position:absolute;top:1px;left:4px}.lock-icon:after{content:"";background:currentColor;border-radius:5px;height:11px;position:absolute;bottom:2px;left:2px;right:2px;box-shadow:inset 0 3px #ffffffad}.key-icon:before{content:"";border:2px solid;border-radius:999px;width:8px;height:8px;position:absolute;top:4px;left:1px}.key-icon:after{content:"";background:currentColor;border-radius:999px;width:12px;height:2px;position:absolute;top:9px;left:10px;box-shadow:4px 4px 0 -1px,8px 4px 0 -1px}.input-action{color:#2f5fc9;background:#2f6df617;border:0;border-radius:8px;flex:none;place-items:center;width:30px;height:30px;padding:0;font-size:13px;font-weight:1000;line-height:1;transition:background .16s,color .16s,transform .16s,box-shadow .16s;display:grid}.input-action:hover:not(:disabled),.input-action:focus-visible{color:#1d4fb8;background:#2f6df629;outline:none;transform:translateY(-1px);box-shadow:0 5px 12px #2f6df624}.workbench{min-height:100vh;padding:16px}.topbar{z-index:10;box-shadow:var(--shadow);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#ffffffdb;border:1px solid #ffffffb3;border-radius:8px;grid-template-columns:minmax(0,1fr);grid-template-areas:"main""subscription";align-items:center;gap:8px;padding:8px;display:grid;position:sticky;top:12px}.topbar-main{grid-area:main;align-items:center;gap:7px;min-width:0;display:flex}.topbar-spacer{flex:12px;min-width:4px}.brand{grid-area:brand;align-items:center;gap:12px;min-width:0;display:flex}.account-chip{border:1px solid var(--line);background:#f7faffeb;border-radius:8px;grid-area:account;justify-self:end;align-items:center;gap:8px;padding:6px 8px;display:flex;box-shadow:inset 0 0 0 1px #ffffff80}.account-chip span{color:#2d3b59;font-weight:900}.account-chip .btn{height:32px;padding-left:9px;padding-right:9px}.brand h1{margin:0;font-size:clamp(17px,2.2vw,23px);line-height:1.1}.brand p,.muted{color:var(--muted);margin:3px 0 0;font-size:12px}.topbar-controls,.toolbar-actions,.view-tabs,.modal-actions,.form-row{align-items:center;gap:8px;display:flex}.topbar-controls{flex-wrap:nowrap;grid-area:controls;min-width:0}.topbar>.toolbar-actions{flex-wrap:wrap;grid-area:actions;justify-content:flex-end;min-width:0}.topbar .topbar-search{flex:0 0 166px;width:166px;min-width:166px}.topbar .topbar-search .search-shell{height:34px}.topbar .classroom-menu{flex:0 0 210px;min-width:210px}.topbar .classroom-menu-trigger{min-height:36px;padding:4px 9px 4px 10px}.topbar .view-tabs{flex:none;padding:3px}.topbar .view-tab,.topbar .btn,.topbar .data-menu-trigger,.topbar .account-menu-trigger{height:34px;padding-left:10px;padding-right:10px}.topbar .selection-actions{min-height:34px;padding:2px}.topbar .selection-actions button{height:26px;padding-left:7px;padding-right:7px}.topbar .sidebar-toggle-btn{flex-basis:34px;width:34px;height:34px}.subscription-banner{color:#7a4b08;background:linear-gradient(135deg,#fff8e1f5,#ffffffe0);border:1px solid #f4b74057;border-radius:8px;grid-area:subscription;align-items:center;gap:10px;min-height:38px;padding:7px 9px;display:flex}.subscription-banner.readonly,.subscription-banner.locked,.subscription-banner.deletionEligible{color:#9f1f2b;background:linear-gradient(135deg,#fff0f1f5,#ffffffe6);border-color:#e5484d42}.subscription-banner strong{background:#ffffffb8;border-radius:999px;flex:none;padding:4px 8px;font-size:12px;font-weight:1000}.subscription-banner span{flex:auto;min-width:0;font-size:13px;font-weight:850}.subscription-banner button{color:#1d4fb8;background:#2f6df61f;border:0;border-radius:8px;flex:none;height:28px;padding:0 10px;font-size:12px;font-weight:1000}.classroom-menu{flex:0 280px;width:min(280px,100%);min-width:240px;position:relative}.classroom-menu.open{z-index:32}.classroom-menu-trigger{color:#26334d;text-align:left;background:linear-gradient(#fffffffa,#f6fafff0),linear-gradient(135deg,#2f6df61a,#10a86f0f);border:1px solid #c5d3ead1;border-radius:8px;grid-template-columns:minmax(0,1fr) auto;grid-template-areas:"label arrow""name arrow";align-items:center;gap:2px 10px;width:100%;min-width:0;min-height:44px;padding:6px 11px 6px 12px;transition:border-color .16s,box-shadow .16s,background .16s,transform .16s;display:grid;box-shadow:0 6px 14px #2b3d6214}.classroom-menu-trigger span{min-width:0;color:var(--muted);text-overflow:ellipsis;white-space:nowrap;grid-area:label;font-size:11px;font-weight:900;overflow:hidden}.classroom-menu-trigger strong{min-width:0;color:var(--ink);text-overflow:ellipsis;white-space:nowrap;grid-area:name;font-size:14px;font-weight:1000;overflow:hidden}.classroom-menu-trigger:after{content:"";border-bottom:2px solid #495874b8;border-right:2px solid #495874b8;grid-area:arrow;width:8px;height:8px;transition:transform .16s,border-color .16s;transform:translateY(-2px)rotate(45deg)}.classroom-menu-trigger:hover,.classroom-menu.open .classroom-menu-trigger{background:linear-gradient(#fff,#ebf5fffa),linear-gradient(135deg,#2f6df626,#10a86f17);border-color:#2f6df670;box-shadow:0 10px 22px #2f6df621}.classroom-menu-trigger:focus-visible{outline-offset:2px;outline:3px solid #2f6df62e}.classroom-menu.open .classroom-menu-trigger:after{border-color:#2f6df6d1;transform:translateY(2px)rotate(225deg)}.classroom-menu-panel{z-index:60;background:#fffffffa;border:1px solid #c5d3eadb;border-radius:8px;width:min(340px,100vw - 24px);animation:.15s ease-out custom-select-in;position:absolute;top:calc(100% + 8px);left:0;overflow:hidden;box-shadow:0 22px 46px #1f2f542e,inset 0 1px #ffffffe6}.classroom-menu-panel:before{content:"";background:#fff;border-top:1px solid #c5d3eadb;border-left:1px solid #c5d3eadb;width:12px;height:12px;position:absolute;top:-6px;left:22px;transform:rotate(45deg)}.classroom-menu-list,.classroom-menu-actions{z-index:1;gap:6px;padding:7px;display:grid;position:relative}.classroom-menu-list{max-height:260px;overflow:auto}.classroom-menu-main,.classroom-menu-actions button{color:#34405a;text-align:left;background:0 0;border:0;border-radius:8px;align-items:center;min-height:36px;font-size:13px;font-weight:900;transition:background .14s,color .14s,transform .14s;display:grid}.classroom-menu-row{border-radius:8px;grid-template-columns:minmax(0,1fr) 30px 30px;align-items:center;gap:5px;transition:background .14s;display:grid}.classroom-menu-row.active{background:linear-gradient(135deg,#2f6df61f,#13a8b81a)}.classroom-menu-main{grid-template-columns:minmax(0,1fr) auto;gap:10px;padding:0 9px}.classroom-menu-main span,.classroom-menu-main em{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.classroom-menu-main em{color:var(--muted);font-size:12px;font-style:normal}.classroom-menu-main:hover,.classroom-menu-main:focus-visible,.classroom-menu-actions button:hover:not(:disabled),.classroom-menu-actions button:focus-visible{color:#1d4fb8;background:#2f6df614;outline:none;transform:translateY(-1px)}.classroom-menu-row.active .classroom-menu-main{color:#1d4fb8}.classroom-menu-icon{color:#4a5c78;background:radial-gradient(circle at 28% 18%,#fffffff5,#0000 32%),linear-gradient(#fffffff5,#eff6ffe0);border:1px solid #cbd9eeeb;border-radius:8px;place-items:center;width:30px;height:30px;padding:0;transition:border-color .16s,box-shadow .16s,background .16s,transform .16s,color .16s;display:grid;position:relative;box-shadow:0 3px 8px #30446e14}.classroom-menu-icon:hover:not(:disabled),.classroom-menu-icon:focus-visible{color:#1d4fb8;border-color:#2f6df657;outline:none;transform:translateY(-1px);box-shadow:0 7px 15px #2f6df621,0 0 0 3px #2f6df614}.classroom-menu-icon.delete{color:#9f1f2a}.classroom-menu-icon.delete:hover:not(:disabled),.classroom-menu-icon.delete:focus-visible{color:#9f1f2a;background:#fff0f1f5;border-color:#e5484d57;box-shadow:0 7px 15px #e5484d1f,0 0 0 3px #e5484d14}.classroom-menu-icon span,.classroom-menu-icon span:before,.classroom-menu-icon span:after{content:"";display:block;position:absolute}.classroom-menu-icon.edit span{background:currentColor;border-radius:999px;width:14px;height:3px;transform:rotate(-35deg)}.classroom-menu-icon.edit span:before{background:#f4b740;border-radius:1px;width:3px;height:3px;top:0;right:-3px}.classroom-menu-icon.edit span:after{background:0 0;border-top:2px solid #0000;border-bottom:2px solid #0000;border-right:4px solid;width:0;height:0;top:0;left:-4px}.classroom-menu-icon.delete span{border:2px solid;border-top:0;border-radius:0 0 3px 3px;width:11px;height:12px;transform:translateY(2px)}.classroom-menu-icon.delete span:before{background:currentColor;border-radius:999px;width:15px;height:2px;top:-5px;left:-4px}.classroom-menu-icon.delete span:after{background:currentColor;border-radius:999px;width:7px;height:2px;top:-8px;left:2px}.classroom-menu-actions{background:#f8fbffd1;border-top:1px solid #e2e8f0e0}.classroom-menu-actions button{grid-template-columns:minmax(0,1fr) auto;gap:10px;padding:0 9px}.classroom-menu-actions button em{color:var(--muted);font-size:12px;font-style:normal}.classroom-menu-actions button:disabled{cursor:not-allowed;opacity:.58;transform:none}.classroom-limit-note{color:var(--muted);margin:-1px 2px 0;font-size:11px;font-weight:800}.classroom-limit-note.reached{color:#b4232d}.classroom-empty-note{min-height:34px;color:var(--muted);background:#f8fcffb8;border:1px dashed #bfdbfeeb;border-radius:8px;place-items:center;margin:0;font-size:12px;font-weight:900;display:grid}.data-menu,.account-menu{flex:none;position:relative}.data-menu.open,.account-menu.open{z-index:34}.data-menu-trigger,.account-menu-trigger{color:#5c3b00;background:linear-gradient(135deg,#fff8dcfa,#ffd166f2),#ffd166;border:0;border-radius:8px;align-items:center;gap:7px;height:38px;padding:0 12px;font-weight:900;transition:transform .18s,box-shadow .18s,background .18s;display:flex;box-shadow:0 10px 20px #f4b7402b}.account-menu-trigger{color:#1d4fb8;background:linear-gradient(135deg,#eff6fffa,#dbeafef0),#eff8ff;box-shadow:0 9px 18px #2f6df621}.data-menu-trigger:hover,.data-menu-trigger:focus-visible,.data-menu.open .data-menu-trigger,.account-menu-trigger:hover,.account-menu-trigger:focus-visible,.account-menu.open .account-menu-trigger{outline:none;transform:translateY(-2px);box-shadow:0 14px 26px #f4b74038,0 0 0 3px #ffd1662e}.account-menu-trigger:hover,.account-menu-trigger:focus-visible,.account-menu.open .account-menu-trigger{box-shadow:0 13px 24px #2f6df62e,0 0 0 3px #2f6df621}.data-menu-trigger-icon{border:2px solid;border-radius:4px;width:15px;height:15px;position:relative}.data-menu-trigger-icon:before,.data-menu-trigger-icon:after{content:"";background:currentColor;border-radius:999px;height:2px;position:absolute;left:3px;right:3px}.data-menu-trigger-icon:before{top:4px}.data-menu-trigger-icon:after{bottom:3px}.data-menu-panel,.account-menu-panel{z-index:60;background:#fffffffa;border:1px solid #c5d3eadb;border-radius:8px;gap:6px;width:min(286px,100vw - 24px);padding:7px;animation:.15s ease-out custom-select-in;display:grid;position:absolute;top:calc(100% + 8px);right:0;box-shadow:0 22px 46px #1f2f542e,inset 0 1px #ffffffe6}.account-menu-panel{gap:5px;width:min(174px,100vw - 24px);padding:6px}.data-menu-panel:before,.account-menu-panel:before{content:"";background:#fff;border-top:1px solid #c5d3eadb;border-left:1px solid #c5d3eadb;width:12px;height:12px;position:absolute;top:-6px;right:24px;transform:rotate(45deg)}.data-menu-panel button,.account-menu-panel button{z-index:1;color:#34405a;text-align:left;background:0 0;border:0;border-radius:8px;grid-template-columns:34px minmax(0,1fr);align-items:center;gap:9px;min-height:54px;padding:7px 9px;transition:background .14s,color .14s,transform .14s;display:grid;position:relative}.account-menu-panel button{border-radius:7px;grid-template-columns:minmax(0,1fr);min-height:38px;padding:0 10px;font-size:13px;font-weight:900}.data-menu-panel button:hover:not(:disabled),.data-menu-panel button:focus-visible,.account-menu-panel button:hover,.account-menu-panel button:focus-visible{color:#1d4fb8;background:#2f6df614;outline:none;transform:translateY(-1px)}.data-menu-panel button:disabled{cursor:wait;opacity:.62}.data-menu-panel button>span:last-child{gap:2px;min-width:0;display:grid}.data-menu-panel strong{font-size:13px;font-weight:1000}.data-menu-panel em{color:var(--muted);text-overflow:ellipsis;white-space:nowrap;font-size:12px;font-style:normal;font-weight:800;overflow:hidden}.data-menu-icon{color:currentColor;background:linear-gradient(#fffffff5,#eff6ffe0);border:1px solid #cbd9eeeb;border-radius:8px;place-items:center;width:32px;height:32px;display:grid;position:relative;box-shadow:0 3px 8px #30446e14}.data-menu-icon:before,.data-menu-icon:after{content:"";position:absolute}.data-menu-icon.export:before{border:2px solid;border-top:0;border-radius:0 0 3px 3px;width:13px;height:10px;bottom:7px}.data-menu-icon.export:after{border-bottom:2px solid;border-right:2px solid;width:7px;height:10px;top:7px;transform:rotate(45deg)}.data-menu-icon.import:before{border:2px solid;border-radius:4px;width:14px;height:14px}.data-menu-icon.import:after{border-bottom:2px solid;border-left:2px solid;width:12px;height:7px;transform:rotate(-45deg)}.selection-actions{background:#f7faffe6;border:1px solid #c5d3ead1;border-radius:8px;align-items:center;gap:4px;min-height:38px;padding:3px;display:flex;box-shadow:inset 0 1px #ffffffd1}.selection-actions>span{color:#4d5d79;text-align:center;white-space:nowrap;min-width:66px;padding:0 8px;font-size:12px;font-weight:1000}.selection-actions.active>span{color:#1d4fb8}.selection-actions button{color:#34405a;white-space:nowrap;background:#ffffffd1;border:0;border-radius:7px;height:30px;padding:0 9px;font-size:12px;font-weight:900;transition:background .14s,color .14s,transform .14s,box-shadow .14s}.selection-actions button:hover:not(:disabled),.selection-actions button:focus-visible{color:#1d4fb8;background:#2f6df61a;outline:none;transform:translateY(-1px)}.selection-actions button:disabled{cursor:not-allowed;opacity:.48}.undo-icon-btn{color:#1d4fb8;background:radial-gradient(circle at 24% 18%,#fffffffa,#0000 34%),linear-gradient(#fffffff0,#eff6ffe6);border:1px solid #2f6df633;border-radius:8px;flex:none;justify-content:center;align-items:center;gap:5px;width:auto;min-width:66px;height:34px;padding:0 10px;font-size:13px;font-weight:950;transition:transform .16s,box-shadow .16s,border-color .16s,background .16s;display:inline-flex;position:relative;box-shadow:0 8px 16px #2f6df61c}.undo-icon-btn span{background:#ffffffad;border:1px solid #2f6df638;border-radius:999px;place-items:center;width:18px;height:18px;font-size:17px;font-weight:950;line-height:1;display:inline-grid}.undo-icon-btn strong{font-size:13px;font-weight:950;line-height:1}.undo-icon-btn:hover:not(:disabled),.undo-icon-btn:focus-visible{background:linear-gradient(135deg,#eff8ff,#dbeafe);border-color:#2f6df661;outline:none;transform:translateY(-1px);box-shadow:0 12px 22px #2f6df629,0 0 0 3px #2f6df61a}.undo-icon-btn:disabled{cursor:not-allowed;opacity:.5;transform:none}.sidebar-toggle-btn{color:#34405a;background:#ffffffe0;border:1px solid #c5d3ead1;border-radius:8px;flex:0 0 38px;place-items:center;width:38px;height:38px;padding:0;transition:border-color .16s,box-shadow .16s,color .16s,transform .16s;display:grid;position:relative;box-shadow:0 6px 14px #2b3d6214}.sidebar-toggle-btn:hover:not(:disabled),.sidebar-toggle-btn:focus-visible{color:#1d4fb8;border-color:#2f6df657;outline:none;transform:translateY(-1px);box-shadow:0 8px 18px #2f6df624,0 0 0 3px #2f6df614}.sidebar-toggle-btn:disabled{cursor:not-allowed;opacity:.46}.sidebar-toggle-btn span{border:2px solid;border-radius:4px;width:18px;height:15px;position:relative}.sidebar-toggle-btn span:before,.sidebar-toggle-btn span:after{content:"";position:absolute}.sidebar-toggle-btn span:before{background:currentColor;width:2px;top:-2px;bottom:-2px;right:4px}.sidebar-toggle-btn span:after{border-bottom:2px solid;border-left:2px solid;width:5px;height:5px;top:4px;left:3px;transform:rotate(45deg)}.sidebar-toggle-btn.collapsed span:before{left:4px;right:auto}.sidebar-toggle-btn.collapsed span:after{left:auto;right:3px;transform:rotate(-135deg)}.custom-select{width:100%;min-width:0;position:relative}.custom-select.open{z-index:28}.custom-select-trigger{color:#26334d;background:linear-gradient(#fffffffa,#f6fafff0),linear-gradient(135deg,#2f6df61a,#10a86f0f);border:1px solid #c5d3ead1;border-radius:8px;justify-content:space-between;align-items:center;gap:10px;width:100%;min-width:0;height:40px;padding:0 11px 0 12px;font-weight:900;line-height:1.2;transition:border-color .16s,box-shadow .16s,background .16s,transform .16s;display:flex;box-shadow:0 6px 14px #2b3d6214}.custom-select-trigger span{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.custom-select-trigger:after{content:"";border-bottom:2px solid #495874b8;border-right:2px solid #495874b8;flex:none;width:7px;height:7px;margin-right:1px;transition:transform .16s,border-color .16s;transform:translateY(-2px)rotate(45deg)}.custom-select-trigger:hover,.custom-select.open .custom-select-trigger{background:linear-gradient(#fff,#ebf5fffa),linear-gradient(135deg,#2f6df626,#10a86f17);border-color:#2f6df670;box-shadow:0 10px 22px #2f6df621}.custom-select-trigger:focus-visible{outline-offset:2px;outline:3px solid #2f6df62e}.custom-select.open .custom-select-trigger:after{border-color:#2f6df6e6;transform:translateY(2px)rotate(225deg)}.custom-select.disabled .custom-select-trigger{cursor:not-allowed}.custom-select-panel{z-index:32;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transform-origin:0 0;background:#fffffff7;border:1px solid #c6d3e8eb;border-radius:8px;width:max(100%,152px);max-height:min(320px,54vh);animation:.15s ease-out custom-select-in;display:grid;position:absolute;top:calc(100% + 8px);left:0;overflow:visible;box-shadow:0 18px 38px #212d4638,inset 0 1px #fffffff5}.custom-select-panel:before{content:"";background:#fffffff7;border-top:1px solid #c6d3e8eb;border-left:1px solid #c6d3e8eb;width:9px;height:9px;position:absolute;top:-5px;left:22px;transform:rotate(45deg)}.custom-select-option{color:#26334d;text-align:left;background:0 0;border:0;border-radius:0;align-items:center;min-height:38px;padding:0 34px 0 12px;font-size:12px;font-weight:900;transition:background .14s,color .14s;display:flex;position:relative}.custom-select-option:first-child{border-radius:8px 8px 0 0}.custom-select-option:last-child{border-radius:0 0 8px 8px}.custom-select-option+.custom-select-option{border-top:1px solid #e2e8f0d1}.custom-select-option span{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.custom-select-option.active{color:#1d4fb8;background:#2f6df614}.custom-select-option.active:after{content:"";border-left:2px solid var(--blue);border-bottom:2px solid var(--blue);width:10px;height:6px;position:absolute;top:50%;right:13px;transform:translateY(-65%)rotate(-45deg)}.custom-select-option:hover,.custom-select-option:focus-visible{color:#1d4fb8;background:#2f6df61a;outline:none}@keyframes custom-select-in{0%{opacity:0;transform:translateY(-4px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}.view-tabs{border:1px solid var(--line);background:#f7faffeb;border-radius:8px;grid-area:tabs;justify-content:center;place-self:center;padding:4px}.view-tab,.btn{white-space:nowrap;border:0;border-radius:8px;height:38px;padding:0 13px;font-weight:800;transition:transform .18s,box-shadow .18s,background .18s}.view-tab{color:#4c5b76;background:0 0}.view-tab.active{background:linear-gradient(135deg, var(--blue), #19a7c5);color:#fff;box-shadow:0 10px 20px #2f6df638}.classroom-dropdown .custom-select-trigger,.rule-category-select .custom-select-trigger,.record-filter-select .custom-select-trigger,.pet-batch-select .custom-select-trigger{color:var(--ink)}.rule-category-select{flex:1 1 0}.form-row>input{flex:0 0 88px}.record-filter-select .custom-select-panel,.rule-category-select .custom-select-panel,.pet-batch-select .custom-select-panel{width:max(100%,168px)}.field:has(.pet-batch-select.open){z-index:70;position:relative}.pet-batch-select .custom-select-panel{scrollbar-gutter:stable;transform-origin:0 100%;max-height:min(264px,42vh);padding:4px;top:auto;bottom:calc(100% + 8px);overflow:hidden auto}.pet-batch-select .custom-select-panel:before{display:none}.pet-batch-select .custom-select-option{border-radius:7px}.pet-batch-select .custom-select-option+.custom-select-option{border-top:0;margin-top:2px}.btn.primary{background:linear-gradient(135deg, var(--blue), #14a3c7);color:#fff;box-shadow:0 12px 24px #2f6df638}.btn.secondary{color:#5c3b00;background:linear-gradient(135deg,#fff2bf,#ffd166);box-shadow:0 10px 20px #f4b7402e}.btn.ghost{border:1px solid var(--line);color:#34405a;background:#ffffffdb}.btn.danger,.btn.danger-soft{color:#b4232d;background:#fff0f1}.btn.danger{color:#fff;background:linear-gradient(135deg,#ff5c6c,#d7263d)}.btn.full{width:100%}.btn:hover:not(:disabled),.view-tab:hover:not(:disabled),.pet-card:hover{transform:translateY(-2px)}.toolbar{justify-content:space-between;align-items:center;gap:12px;margin:14px 0;display:flex}.search-box{gap:8px;width:min(460px,100%);display:flex}.search-box>button{border:1px solid var(--line);width:auto;color:var(--muted);background:#fff;border-radius:8px;padding:0 12px}.search-shell{height:44px}.search-shell .input-action{color:#667085;font-size:18px}.record-search-shell{height:40px}.app-layout{grid-template-columns:minmax(0,1fr) 330px;align-items:start;gap:14px;display:grid}.app-layout.side-collapsed{grid-template-columns:minmax(0,1fr)}.main-panel,.side-card,.modal,.empty-state,.loading-card{background:var(--paper);box-shadow:var(--shadow);border:1px solid #ffffffb8;border-radius:8px}.main-panel{min-height:62vh;padding:14px}.view-head{background:radial-gradient(circle at 96% 0,#2f6df61f,#0000 32%),linear-gradient(#fffffff0,#f8fbffe0);border:1px solid #dae4f2db;border-radius:8px;justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px;padding:10px 11px;display:flex;box-shadow:inset 0 1px #ffffffbd}.view-head div{gap:3px;min-width:0;display:grid}.view-head h2{color:#1f2a44;margin:0;font-size:17px;line-height:1.2}.view-head span{color:var(--muted);font-size:12px;font-weight:800}.side-panel{overscroll-behavior:contain;scrollbar-gutter:stable;gap:12px;max-height:calc(100vh - 142px);padding-right:2px;display:grid;position:sticky;top:126px;overflow-y:auto}.side-card{padding:12px}.side-head,.performance-head,.leaderboard-head,.student-line,.card-stats,.record-row,.record-summary,.record-more,.modal-head{justify-content:space-between;align-items:center;gap:10px;display:flex}.side-head h2,.leaderboard-head h2,.modal-head h2{margin:0;font-size:17px}.side-head span,.leaderboard-head span,.card-stats,.record-row span,.record-summary span{color:var(--muted);font-size:12px}.pet-level-badge{z-index:8;color:#1d4ed8;white-space:nowrap;background:linear-gradient(135deg,#eff8fff5,#dbeafef0);border:1px solid #2f6df657;border-radius:999px;align-items:center;min-height:26px;padding:4px 9px;font-size:12px;font-weight:950;line-height:1;display:inline-flex;position:absolute;top:8px;left:2px;box-shadow:0 7px 15px #2f6df61f}.side-link{color:#1d4fb8;background:#eff6ffdb;border:1px solid #2f6df62e;border-radius:8px;height:30px;padding:0 10px;font-size:12px;font-weight:900;transition:background .16s,border-color .16s,box-shadow .16s,transform .16s}.side-link:hover:not(:disabled),.side-link:focus-visible{background:#e1effff0;border-color:#2f6df65c;outline:none;transform:translateY(-1px);box-shadow:0 7px 15px #2f6df61f}.recent-record-card{background:radial-gradient(circle at 94% 0,#f4b74029,#0000 35%),#ffffffe6}.rule-manager-card{background:radial-gradient(circle at 96% 0,#10a86f1f,#0000 34%),#ffffffe6}.rule-manager-card:not(.open){cursor:pointer}.rule-manager-head{width:100%;min-height:46px;color:inherit;text-align:left;cursor:pointer;background:0 0;border:0;border-radius:8px;align-items:center;padding:4px;transition:background .16s,box-shadow .16s,transform .16s}.rule-manager-title{gap:3px;min-width:0;display:grid}.rule-manager-title strong{color:var(--ink);font-size:17px}.rule-manager-title span{color:var(--muted);font-size:12px;font-weight:800}.rule-manager-cue{color:#1d4fb8;flex:none;align-items:center;gap:7px;font-size:12px;font-weight:900;display:inline-flex}.rule-manager-cue:after{content:"";border-bottom:2px solid;border-right:2px solid;width:7px;height:7px;transition:transform .16s;transform:translateY(-2px)rotate(45deg)}.rule-manager-card.open .rule-manager-cue:after{transform:translateY(2px)rotate(225deg)}.rule-manager-head:hover,.rule-manager-head:focus-visible,.rule-manager-card:not(.open):hover .rule-manager-head{background:#e1effff5;outline:none;transform:translateY(-1px);box-shadow:0 7px 15px #2f6df61f}.rule-manager-body{gap:10px;margin-top:11px;animation:.16s ease-out rule-manager-in;display:grid}@keyframes rule-manager-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.recent-record-list{gap:7px;margin-top:10px;display:grid}.recent-record-item{color:#26334d;text-align:left;background:linear-gradient(#fffffff5,#f8fbffe6),#ffffffeb;border:1px solid #dae4f2eb;border-radius:8px;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:8px;min-height:48px;padding:8px;transition:border-color .16s,box-shadow .16s,transform .16s,background .16s;display:grid;box-shadow:0 5px 12px #2b3d620f}.recent-record-item:hover,.recent-record-item:focus-visible{background:linear-gradient(#fff,#f0f7fff5),#fffffff5;border-color:#2f6df657;outline:none;transform:translateY(-1px);box-shadow:0 9px 19px #2f6df61f}.recent-record-main{gap:3px;min-width:0;display:grid}.recent-record-main strong,.recent-record-main span{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.recent-record-main strong{color:#1f2a44;font-size:12px;font-weight:1000}.recent-record-main span{color:var(--muted);font-size:11px;font-weight:800}.recent-record-tags{flex-wrap:wrap;justify-content:flex-end;gap:4px;max-width:112px;display:flex}.recent-record-tags em,.recent-record-tags i{color:#38517a;background:#eff6fff0;border-radius:8px;padding:3px 6px;font-size:11px;font-style:normal;font-weight:1000;line-height:1.1}.recent-record-tags em.plus{color:#067647;background:#10a86f1f}.recent-record-tags em.minus{color:#b4232d;background:#e5484d1f}.recent-record-empty{text-align:center;background:#f8fcffb8;border:1px dashed #bfdbfeeb;border-radius:8px;align-content:center;place-items:center;gap:5px;min-height:86px;margin-top:10px;display:grid}.recent-record-empty strong{color:#253149;font-size:13px}.recent-record-empty span{max-width:210px;color:var(--muted);font-size:12px;line-height:1.6}.pet-grid{grid-template-columns:repeat(auto-fill,minmax(218px,1fr));align-items:stretch;gap:12px;display:grid}.side-collapsed .pet-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.pet-card{border:1px solid var(--line);background:linear-gradient(#fffffff2,#f7fbfff5),radial-gradient(circle at 100% 0,#f4b7402e,#0000 34%);border-radius:8px;grid-template-rows:30px 56px 202px 18px 24px;align-content:start;padding:14px 12px;transition:transform .18s,box-shadow .18s,border-color .18s,background .18s;display:grid;position:relative;overflow:visible;box-shadow:0 10px 26px #2b3d621a}.pet-card.selected{background:linear-gradient(#eff6fffa,#fffffff5),radial-gradient(circle at 88% 12%,#2f6df63d,#0000 34%),radial-gradient(circle at 14% 18%,#10a86f1f,#0000 30%);border-color:#2f6df6eb;transform:translateY(-1px);box-shadow:inset 4px 0 #2f6df6db,0 0 0 3px #2f6df629,0 20px 40px #2f6df633}.pet-card-draggable{cursor:grab}.pet-card-draggable:active{cursor:grabbing}:is(.pet-card:has(.student-menu.open),.pet-card:has(.custom-select.open)){z-index:8}.student-drag-placeholder{background:linear-gradient(135deg,#eff6ffc2,#fff7df9e);border:2px dashed #2f6df657;border-radius:8px;min-height:390px;box-shadow:inset 0 1px #ffffffd1}.student-drag-float{z-index:1000;pointer-events:none;opacity:.98;filter:drop-shadow(0 24px 30px #0f172a47);will-change:transform;position:fixed;top:0;left:0}.student-drag-card{height:100%;min-height:inherit;color:#172033;text-align:center;background:radial-gradient(circle at 100% 0,#f4b74038,#0000 36%),linear-gradient(#fffffffa,#f4f9fff5);border:1px solid #2f6df657;border-radius:8px;align-content:center;place-items:center;gap:9px;padding:14px;display:grid}.student-drag-card strong{color:#172033;text-overflow:ellipsis;white-space:nowrap;max-width:100%;font-size:16px;font-weight:1000;overflow:hidden}.student-drag-card img{object-fit:contain;filter:drop-shadow(0 16px 18px #202d4c3d);width:min(160px,80%);height:160px}.student-drag-card span{color:var(--muted);font-size:12px;font-weight:900}body.student-dragging{cursor:grabbing;-webkit-user-select:none;user-select:none}.student-line .pet-archive-select{flex:none;width:128px;max-width:128px}.student-line{align-items:flex-start}.pet-archive-select .custom-select-trigger{height:32px;padding:0 8px 0 9px;font-size:12px;font-weight:700;box-shadow:0 5px 12px #2b3d6212}.pet-archive-select .custom-select-panel{width:164px;left:auto;right:0}.pet-archive-select .custom-select-panel:before{left:auto;right:22px}.student-menu{flex:auto;min-width:0;position:relative}.student-name{color:#172033;width:100%;min-width:0;max-width:100%;box-shadow:none;cursor:pointer;text-align:left;background:0 0;border:0;border-radius:6px;justify-content:flex-start;align-items:center;padding:2px 0;font-size:15px;font-weight:900;line-height:1.24;list-style:none;transition:color .16s,transform .16s;display:flex}.student-name:after{display:none}.student-name span{overflow-wrap:anywhere;text-overflow:clip;white-space:normal;min-width:0;overflow:visible}.student-name:hover,.student-menu.open .student-name{color:#1d4fb8;transform:translateY(-1px)}.student-name:focus-visible{outline-offset:2px;outline:3px solid #2f6df62e}.student-menu-panel{z-index:20;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transform-origin:0 0;background:#fffffff5;border:1px solid #c6d3e8eb;border-radius:8px;width:156px;animation:.15s ease-out student-menu-in;display:grid;position:absolute;top:calc(100% + 9px);left:0;overflow:visible;box-shadow:0 18px 38px #212d4638,inset 0 1px #fffffff5}.student-menu-panel:before{content:"";background:#fffffff5;border-top:1px solid #c6d3e8eb;border-left:1px solid #c6d3e8eb;width:9px;height:9px;position:absolute;top:-5px;left:22px;transform:rotate(45deg)}@keyframes student-menu-in{0%{opacity:0;transform:translateY(-4px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}.student-menu-panel button{color:#26334d;text-align:left;background:0 0;border:0;border-radius:0;align-items:center;gap:9px;min-height:38px;padding:0 13px 0 12px;font-size:12px;font-weight:900;transition:background .14s,color .14s;display:flex;position:relative}.student-menu-panel button:first-child{border-radius:8px 8px 0 0}.student-menu-panel button:last-child{border-radius:0 0 8px 8px}.student-menu-panel button:before{content:"";background:#2f6df61a;border-radius:7px;flex:none;place-items:center;width:20px;height:20px;display:grid}.student-menu-panel button:after{content:"";background:#2f6df6;border-radius:2px;width:10px;height:2px;position:absolute;top:50%;left:18px;transform:translateY(-50%)rotate(-35deg)}.student-menu-panel button+button{border-top:1px solid #e2e8f0d1}.student-menu-panel .danger-text:before{background:#e5484d1c}.student-menu-panel .danger-text:after{background:0 0;border:2px solid #b4232d;border-top:0;border-radius:0 0 3px 3px;width:9px;height:10px;left:18px;transform:translateY(-38%)}.student-menu-panel button:hover,.student-menu-panel button:focus-visible{color:#1d4fb8;background:#2f6df614;outline:none}.student-menu-panel .danger-text:hover,.student-menu-panel .danger-text:focus-visible{background:#e5484d17;color:#9f1f2a!important}.honor-row{flex-wrap:wrap;gap:5px;min-height:23px;margin:8px 0 4px;display:flex}.honor-slot{box-sizing:border-box;background:linear-gradient(#ffffffa3,#f7faffc7),radial-gradient(circle at 18% 12%,#ffe08a29,#0000 34%),radial-gradient(circle at 84% 28%,#2f6df61a,#0000 34%);border:1px solid #e2e8f0b8;border-radius:8px;height:56px;padding:0 6px;overflow:hidden;box-shadow:inset 0 1px #ffffffd1}.honor-slot .honor-row{max-height:48px;margin:4px 0 0}.honor-badge{--honor-bg-start:#fff5ca;--honor-bg-end:#ffe08a;--honor-border:#f4b74094;--honor-text:#754400;--honor-shadow:#f4b7402e;--honor-sweep:#ffffffb8;border:1px solid var(--honor-border);background:linear-gradient(135deg, var(--honor-bg-start), var(--honor-bg-end));color:var(--honor-text);box-shadow:0 7px 16px var(--honor-shadow);border-radius:8px;padding:3px 6px;font-size:11px;font-weight:900;line-height:1;position:relative;overflow:hidden}.honor-badge:after{content:"";background:linear-gradient(90deg, transparent, var(--honor-sweep), transparent);opacity:0;pointer-events:none;border-radius:999px;width:28px;height:190%;animation:4.8s ease-in-out infinite honorBadgeSweep;position:absolute;top:-45%;left:-42%;transform:translate(-18px)rotate(18deg)}.category-tone-speech{--honor-bg-start:#eff8ff;--honor-bg-end:#dbeafe;--honor-border:#3b82f673;--honor-text:#1d4ed8;--honor-shadow:#3b82f626}.category-tone-homework{--honor-bg-start:#fff5ca;--honor-bg-end:#ffe08a;--honor-border:#f4b74094;--honor-text:#754400;--honor-shadow:#f4b7402e}.category-tone-progress{--honor-bg-start:#fff4e8;--honor-bg-end:#fed7aa;--honor-border:#f9731666;--honor-text:#c2410c;--honor-shadow:#f9731624}.category-tone-discipline{--honor-bg-start:#f3f0ff;--honor-bg-end:#ddd6fe;--honor-border:#7c3aed66;--honor-text:#5b21b6;--honor-shadow:#7c3aed24}.category-tone-duty{--honor-bg-start:#e6fffb;--honor-bg-end:#bff4ec;--honor-border:#14b8a66b;--honor-text:#0f766e;--honor-shadow:#14b8a624}.category-tone-virtue{--honor-bg-start:#fff1f2;--honor-bg-end:#ffe4e6;--honor-border:#f43f5e5c;--honor-text:#be123c;--honor-shadow:#f43f5e21}.pet-stage{isolation:isolate;background:0 0;border-radius:8px;place-items:center;height:192px;margin:4px 0 6px;display:grid;position:relative;overflow:visible}.pet-light-sweep{z-index:4;mix-blend-mode:screen;opacity:0;pointer-events:none;background:linear-gradient(90deg,#0000,#ffffff7a,#0000);border-radius:999px;width:24px;height:118px;animation:5.6s ease-in-out infinite petLightSweep;position:absolute;top:14px;left:12%;transform:rotate(16deg)}.pet-stage img{z-index:2;object-fit:contain;transform-origin:bottom;will-change:transform;width:auto;max-width:112%;max-height:190px;animation:4.4s ease-in-out infinite petCardFloat;position:relative}.pet-stage.egg-stage img{animation:3.4s ease-in-out infinite petEggBreathe}.pet-stage.maxed-stage img{animation-duration:3.6s}.pet-stage.score-plus img{animation:.9s cubic-bezier(.18,1.2,.22,1) both petScoreHop}.pet-stage.score-minus img{animation:.82s ease-in-out both petScoreDip}.pet-stage-sparks{z-index:5;pointer-events:none;position:absolute;inset:0}.pet-stage-sparks i{background:var(--spark-color,#facc15);width:7px;height:7px;box-shadow:0 0 12px var(--spark-color,#facc15);opacity:0;border-radius:50%;animation:2.8s ease-in-out infinite petSparkFloat;position:absolute}.pet-stage-sparks i:first-child{--spark-color:#38bdf8;top:24%;left:15%}.pet-stage-sparks i:nth-child(2){--spark-color:#facc15;animation-delay:.52s;top:18%;right:17%}.pet-stage-sparks i:nth-child(3){--spark-color:#f472b6;animation-delay:1.04s;bottom:25%;left:19%}.pet-stage-sparks i:nth-child(4){--spark-color:#34d399;animation-delay:1.56s;bottom:30%;right:18%}.pet-score-burst{z-index:7;color:#fff;pointer-events:none;text-shadow:0 1px #0f172a38;border-radius:8px;padding:5px 8px;font-size:17px;font-weight:1000;line-height:1;animation:1.05s ease-out both petScoreBurst;position:absolute;top:15px;right:18px}.pet-score-burst.plus{background:linear-gradient(135deg,#22c55e,#2f6df6);box-shadow:0 12px 20px #2f6df638,0 0 18px #22c55e57}.pet-score-burst.minus{background:linear-gradient(135deg,#fb7185,#d7263d);box-shadow:0 12px 20px #d7263d33,0 0 18px #fb71854d}@keyframes petCardFloat{0%,to{transform:translateY(0)rotate(-.6deg)scale(1)}50%{transform:translateY(-7px)rotate(.7deg)scale(1.022)}}@keyframes petEggBreathe{0%,to{transform:translateY(0)scale(1)rotate(0)}42%{transform:translateY(-4px)scale(1.036)rotate(-1deg)}70%{transform:translateY(0)scale(.995)rotate(.8deg)}}@keyframes petLightSweep{0%,68%,to{opacity:0;transform:translate(-48px)rotate(16deg)}18%{opacity:.68}42%{opacity:0;transform:translate(160px)rotate(16deg)}}@keyframes honorBadgeSweep{0%,62%,to{opacity:0;transform:translate(-20px)rotate(18deg)}18%{opacity:.72}38%{opacity:0;transform:translate(110px)rotate(18deg)}}@keyframes petScoreHop{0%{transform:translateY(0)scale(1)}38%{transform:translateY(-18px)scale(1.08)rotate(-1.4deg)}72%{transform:translateY(3px)scale(.99)rotate(.8deg)}to{transform:translateY(0)scale(1)}}@keyframes petScoreDip{0%,to{transform:translateY(0)scale(1)}44%{transform:translateY(7px)scale(.965)}}@keyframes petSparkFloat{0%,to{opacity:0;transform:translateY(10px)scale(.45)}42%{opacity:.9}72%{opacity:.35;transform:translateY(-18px)scale(1.08)}}@keyframes petScoreBurst{0%{opacity:0;transform:translateY(10px)scale(.72)}22%{opacity:1;transform:translateY(0)scale(1.08)}to{opacity:0;transform:translateY(-26px)scale(.94)}}@media (prefers-reduced-motion:reduce){.honor-badge:after,.pet-light-sweep,.pet-stage img,.pet-stage-sparks i,.pet-score-burst{animation:none!important}}.progress{box-sizing:border-box;background:#eff6ffe0;border:1px solid #cbd9eecc;border-radius:999px;height:9px;overflow:hidden;box-shadow:inset 0 1px 2px #2b3d6214}.progress-row{grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:8px;min-height:18px;display:grid}.progress-row .progress{min-width:0}.progress-row>span{color:#3a4964;white-space:nowrap;background:linear-gradient(135deg,#ffffffeb,#eff6ffdb);border:1px solid #cbd9eeb8;border-radius:999px;justify-content:center;align-items:center;min-width:42px;min-height:18px;padding:0 6px;font-size:11px;font-weight:950;line-height:1;display:inline-flex}.progress span{border-radius:inherit;background:linear-gradient(90deg, var(--green), var(--blue), var(--yellow));height:100%;display:block;position:relative;box-shadow:0 0 10px #2f6df62e}.progress span:after{content:"";background:#ffffff85;border-radius:999px;height:2px;position:absolute;inset:1px 4px auto}.card-stats{grid-template-columns:max-content max-content max-content;justify-content:space-between;align-items:center;gap:6px;min-height:24px;margin-top:3px;display:grid}.card-stats>span{color:#3a4964;white-space:nowrap;background:#ffffffb8;border:1px solid #cbd9eeb8;border-radius:999px;align-items:center;min-height:22px;padding:0 6px;font-size:11px;font-weight:900;display:inline-flex;box-shadow:0 5px 12px #2b3d620f}.card-actions{justify-content:center;align-items:center;gap:5px;min-width:max-content;min-height:24px;display:flex;overflow:visible}.card-actions.empty{pointer-events:none}.card-actions button,.rule-manage-row button{border:1px solid var(--line);color:#34405a;background:#ffffffdb;border-radius:8px;min-height:30px;font-size:12px;font-weight:800}.card-actions button{color:#1d4fb8;white-space:nowrap;background:radial-gradient(circle at 24% 18%,#fffffffa,#0000 32%),linear-gradient(#fffffffa,#e5f0fff0);border-color:#2f6df64d;border-radius:999px;justify-content:center;align-items:center;min-width:44px;min-height:24px;padding:0 8px;font-size:11px;font-weight:950;line-height:1;display:inline-flex;box-shadow:inset 0 1px #ffffffe6,0 7px 14px #2f6df621}.card-actions button:hover,.card-actions button:focus-visible{background:radial-gradient(circle at 24% 18%,#fff,#0000 32%),linear-gradient(135deg,#eff8ff,#dbeafe);border-color:#2f6df661;outline:none;transform:translateY(-1px);box-shadow:inset 0 1px #fffffff2,0 9px 16px #2f6df62e}.card-actions button:disabled{box-shadow:none;color:#7a879b;cursor:not-allowed;background:#f1f5f9d1;border-color:#94a3b838;transform:none}.rule-manage-row .rule-icon-action{color:#4a5c78;background:radial-gradient(circle at 28% 18%,#fffffff5,#0000 32%),linear-gradient(#fffffff5,#eff6ffe0);border:1px solid #cbd9eef5;border-radius:8px;place-items:center;width:30px;min-height:30px;padding:0;transition:border-color .16s,box-shadow .16s,background .16s,transform .16s;display:grid;position:relative;box-shadow:0 3px 8px #30446e14}.rule-manage-row .rule-icon-action:hover:not(:disabled),.rule-manage-row .rule-icon-action:focus-visible{border-color:#2f6df657;outline:none;transform:translateY(-1px);box-shadow:0 7px 15px #2f6df621,0 0 0 3px #2f6df614}.rule-icon-action span,.rule-icon-action span:before,.rule-icon-action span:after{content:"";position:absolute}.rule-icon-action.edit span{background:#2f6df6;border-radius:999px;width:12px;height:4px;transform:rotate(-35deg)}.rule-icon-action.edit span:before{background:#9bb8ff;border-radius:2px 0 0 2px;width:3px;height:4px;top:0;left:-4px}.rule-icon-action.edit span:after{border-top:2px solid #0000;border-bottom:2px solid #0000;border-left:5px solid #f4b740;width:0;height:0;top:0;right:-4px}.rule-manage-row .rule-icon-action.delete{color:#b4232d}.rule-manage-row .rule-icon-action.delete:hover:not(:disabled),.rule-manage-row .rule-icon-action.delete:focus-visible{border-color:#e5484d57;box-shadow:0 7px 15px #e5484d21,0 0 0 3px #e5484d14}.rule-icon-action.delete span{border:2px solid;border-top:0;border-radius:0 0 3px 3px;width:11px;height:10px}.rule-icon-action.delete span:before{background:currentColor;border-radius:999px;width:15px;height:2px;top:-4px;left:-2px}.rule-icon-action.delete span:after{border:2px solid;border-bottom:0;border-radius:3px 3px 0 0;width:7px;height:3px;top:-7px;left:2px}.danger-text{color:#b4232d!important}.performance-grid,.leaderboard-grid{grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:12px;display:grid}.performance-card,.leaderboard-card{border:1px solid var(--line);background:#ffffffe6;border-radius:8px;padding:12px}.score-pill{border-radius:8px;padding:5px 9px;font-weight:900}.score-pill.plus{color:#067647;background:#10a86f1f}.score-pill.minus{color:#b4232d;background:#e5484d1f}.radar{width:100%;max-width:250px;margin:4px auto;display:block}.radar-grid,.radar-line{fill:none;stroke:#2f6df62e;stroke-width:1px}.radar-area{fill:#2f6df638;stroke:var(--blue);stroke-width:2.5px}.radar-dot{fill:var(--yellow);stroke:#fff;stroke-width:1.6px}.radar-label{fill:#55627a;font-size:8px;font-weight:800}.category-score-list{color:#40506b;grid-template-columns:repeat(2,minmax(0,1fr));gap:6px;font-size:12px;display:grid}.leaderboard-card ol{gap:8px;margin:12px 0 0;padding:0;list-style:none;display:grid}.leaderboard-card li{background:#f7faffdb;border-radius:8px;grid-template-columns:28px 1fr auto;align-items:center;gap:8px;padding:8px;display:grid}.leaderboard-card em{color:var(--blue);font-style:normal;font-weight:900}.rank{width:26px;height:26px;color:var(--blue);background:#eaf0ff;border-radius:8px;place-items:center;font-weight:900;display:grid}.rank-1,.rank-2,.rank-3{color:#6a3b00;background:linear-gradient(135deg,#ffe08a,#ffb84d)}.record-tools{grid-template-columns:minmax(180px,1fr) repeat(3,minmax(120px,150px));gap:8px;display:grid}.record-summary{flex-wrap:wrap;justify-content:flex-start;margin:12px 0}.record-summary span{border:1px solid var(--line);background:#ffffffd1;border-radius:8px;padding:8px 10px}.record-retention-note{color:var(--muted);margin:-4px 0 12px;font-size:12px;font-weight:800}.record-list{gap:8px;display:grid}.record-row{border:1px solid var(--line);background:#ffffffdb;border-radius:8px;align-items:flex-start;padding:10px}.record-row div:first-child{gap:4px;display:grid}.record-tags{flex-wrap:wrap;justify-content:flex-end;gap:6px;display:flex}.record-tags span{color:#38517a;background:#eef4ff;border-radius:8px;padding:4px 7px;font-weight:800}.record-tags .plus{color:#067647;background:#e8fff4}.record-tags .minus{color:#b4232d;background:#fff0f1}.record-more{margin-top:12px}.rule-action-group,.rule-manage-group,.rule-form{gap:8px;margin-top:10px;display:grid}.rule-manager-body .rule-form,.rule-manager-body .rule-manage-group{margin-top:0}.rule-form{background:linear-gradient(#fffffff5,#f8fbffe6),#ffffffe6;border:1px solid #dae4f2eb;border-radius:8px;padding:9px;box-shadow:inset 0 1px #ffffffbd}.rule-form>input{height:42px;font-weight:900}.rule-form .form-row{align-items:stretch}.rule-score-field{flex:0 0 132px;gap:5px;width:132px;display:grid}.score-stepper{background:linear-gradient(#fffffffa,#f7fafff0),#fffffff0;border:1px solid #c5d3eadb;border-radius:8px;flex:0 0 118px;grid-template-columns:34px minmax(0,1fr) 34px;align-items:center;width:118px;display:grid;overflow:hidden;box-shadow:inset 0 1px #ffffffdb,0 6px 14px #2b3d6212}.rule-score-field .score-stepper{flex:none;width:100%}.score-stepper:focus-within{border-color:#2f6df6b8;box-shadow:0 0 0 4px #2f6df61f,0 12px 24px #2f6df61f}.score-stepper.plus{background:linear-gradient(#fffffffa,#f0fff8f0),#fffffff0;border-color:#10a86f6b}.score-stepper.minus{background:linear-gradient(#fffffffa,#fff6f7f0),#fffffff0;border-color:#e5484d5c}.score-stepper.invalid{background:linear-gradient(#fffffffa,#fff0f1f0),#fffffff0;border-color:#e5484db8}.score-stepper.plus:focus-within{border-color:#10a86fb8;box-shadow:0 0 0 4px #10a86f1f,0 12px 24px #10a86f1a}.score-stepper.minus:focus-within,.score-stepper.invalid:focus-within{border-color:#e5484db8;box-shadow:0 0 0 4px #e5484d1f,0 12px 24px #e5484d1a}.score-stepper button{color:#2f5fc9;background:#2f6df60f;border:0;place-items:center;height:40px;font-size:20px;font-weight:1000;line-height:1;transition:background .16s,color .16s;display:grid}.score-stepper button:hover:not(:disabled),.score-stepper button:focus-visible{color:#1d4fb8;background:#2f6df624;outline:none}.score-stepper.plus button{color:#067647;background:#10a86f14}.score-stepper.minus button,.score-stepper.invalid button{color:#b4232d;background:#e5484d14}.score-stepper input{height:40px;box-shadow:none;color:#172033;text-align:center;background:0 0;border:0;border-radius:0;padding:0 4px;font-weight:1000}.score-stepper input:hover,.score-stepper input:focus{box-shadow:none;background:0 0;border:0}.rule-score-feedback{min-height:15px;margin:0 1px;font-size:11px;font-weight:900;line-height:1.25}.rule-score-feedback.plus{color:#067647}.rule-score-feedback.minus,.rule-score-feedback.invalid{color:#b4232d}.rule-limit-note{color:#b4232d;margin:-2px 1px 0;font-size:12px;font-weight:900;line-height:1.45}.rule-action-group h3,.rule-manage-group h3{color:#2c3954;margin:4px 0 0;font-size:14px}.rule-sort-list{gap:8px;display:grid}.rule-sort-list.drag-over{outline-offset:3px;border-radius:8px;outline:2px dashed #2f6df647}.rule-sort-list-active{position:relative}.rule-empty-note{min-height:40px;color:var(--muted);background:#f8fcffb8;border:1px dashed #bfdbfeeb;border-radius:8px;place-items:center;font-size:12px;font-weight:900;display:grid}.rule-action-item{min-width:0;display:block}.rule-action{--rule-accent:#2f6df6;--rule-accent-strong:#14a3c7;--rule-accent-soft:#2f6df61a;--rule-accent-border:#2f6df638;--rule-accent-shadow:#2f6df61f;background:linear-gradient(180deg, #fffffff5, #f8fcffeb), radial-gradient(circle at 94% 18%, var(--rule-accent-soft), transparent 38%);color:#253149;border:1px solid #dce6f6f0;border-radius:8px;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:8px;min-height:50px;padding:7px 8px 7px 10px;transition:transform .16s,border-color .16s,box-shadow .16s,background .16s;display:grid;position:relative;overflow:hidden;box-shadow:inset 0 1px #ffffffeb,0 8px 18px #2b3d6214}.rule-action:before{content:"";background:linear-gradient(180deg, var(--rule-accent), var(--rule-accent-strong));opacity:.86;border-radius:999px;width:3px;position:absolute;top:8px;bottom:8px;left:0}.rule-action:hover{border-color:var(--rule-accent-border);box-shadow:inset 0 1px 0 #fffffff2, 0 12px 24px var(--rule-accent-shadow), 0 4px 14px #2b3d6214;transform:translateY(-1px)}.rule-action:active{transform:translateY(0)}.rule-action.plus{--rule-accent:#10a86f;--rule-accent-strong:#34d399;--rule-accent-soft:#10a86f1f;--rule-accent-border:#10a86f57;--rule-accent-shadow:#10a86f24}.rule-action.minus{--rule-accent:#e5484d;--rule-accent-strong:#fb7185;--rule-accent-soft:#e5484d1a;--rule-accent-border:#e5484d52;--rule-accent-shadow:#e5484d21}.rule-action.plus em{color:#067647;background:linear-gradient(135deg,#ecfdf3,#d1fae5);border-color:#10a86f57}.rule-action.minus em{color:#b4232d;background:linear-gradient(135deg,#fff1f2,#ffe4e6);border-color:#e5484d52}.rule-action-main{width:100%;min-width:0;min-height:38px;color:inherit;text-align:left;background:0 0;border:0;grid-template-columns:minmax(0,1fr) minmax(44px,auto);align-items:center;gap:8px;padding:0;display:grid}.rule-action-main:focus-visible{outline-offset:2px;border-radius:6px;outline:2px solid #2f6df652}.rule-action-text,.rule-manage-text{align-content:center;gap:3px;min-width:0;display:grid}.rule-action-main strong,.rule-action-main em,.rule-manage-row strong,.rule-manage-row em{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.rule-category-tag{border:1px solid var(--honor-border,#3b82f66b);background:linear-gradient(135deg, var(--honor-bg-start,#eff8ff), var(--honor-bg-end,#dbeafe));max-width:100%;box-shadow:0 4px 9px var(--honor-shadow,#3b82f621);color:var(--honor-text,#1d4ed8);text-overflow:ellipsis;white-space:nowrap;border-radius:999px;justify-self:start;padding:2px 6px;font-size:10px;font-weight:900;line-height:1.1;display:inline-block;overflow:hidden}.rule-action-main em,.rule-manage-row em{text-align:right;border:1px solid;border-radius:999px;justify-content:center;justify-self:end;align-items:center;min-width:44px;min-height:24px;padding:2px 8px;font-size:12px;font-style:normal;font-weight:950;line-height:1;display:inline-flex;box-shadow:0 6px 12px #2b3d6214}.rule-manage-row{border:1px solid var(--line);background:#ffffffc7;border-radius:8px;grid-template-columns:minmax(0,1fr) minmax(44px,auto) auto repeat(2,auto);align-items:center;gap:6px;padding:7px 8px;font-size:12px;display:grid}.rule-manage-row .plus{color:#067647;background:linear-gradient(135deg,#ecfdf3,#d1fae5);border-color:#10a86f57}.rule-manage-row .minus{color:#b4232d;background:linear-gradient(135deg,#fff1f2,#ffe4e6);border-color:#e5484d52}.rule-manage-row .rule-drag-handle{justify-self:end}.rule-drag-handle{color:#64748b;cursor:grab;touch-action:none;background:radial-gradient(circle at 28% 18%,#fffffff0,#0000 32%),linear-gradient(#fffffff5,#eff6ffe0);border:1px solid #cbd9eef5;border-radius:999px;flex:none;place-items:center;width:28px;height:28px;min-height:28px;padding:0;font-size:17px;font-weight:1000;line-height:1;transition:color .15s,border-color .15s,box-shadow .15s,background .15s,transform .15s;display:grid;box-shadow:0 3px 8px #30446e14}.rule-drag-handle:hover,.rule-drag-handle:focus-visible{color:var(--blue);border-color:#2f6df657;outline:none;transform:translateY(-1px);box-shadow:0 6px 14px #2f6df624,0 0 0 3px #2f6df614}.rule-action:hover .rule-drag-handle{color:var(--rule-accent);border-color:var(--rule-accent-border);box-shadow:0 6px 14px var(--rule-accent-shadow), 0 0 0 3px var(--rule-accent-soft)}.rule-drag-handle:active{cursor:grabbing}.rule-drag-handle:disabled{cursor:not-allowed}.rule-drag-handle span{pointer-events:none;transform:translateY(-1px)}.rule-drag-handle-preview{pointer-events:none}.rule-preview-action{border:1px solid var(--line);color:#34405a;background:#ffffffd6;border-radius:8px;justify-content:center;align-items:center;min-width:48px;min-height:28px;padding:0 10px;font-size:12px;font-weight:800;display:inline-flex}.rule-drag-placeholder{background:linear-gradient(135deg,#eff6ffb8,#fff7df9e);border:2px dashed #2f6df657;border-radius:8px;box-shadow:inset 0 1px #ffffffc7}.rule-drag-float{z-index:1000;pointer-events:none;opacity:.98;filter:drop-shadow(0 22px 28px #0f172a3d);will-change:transform;position:fixed;top:0;left:0}.rule-drag-float .rule-action,.rule-drag-float .rule-manage-row{background:#fffffffa;width:100%}body.rule-dragging{cursor:grabbing;-webkit-user-select:none;user-select:none}.empty-state{min-height:260px;color:var(--muted);text-align:center;align-content:center;place-items:center;gap:8px;display:grid}.empty-state strong{color:var(--ink);font-size:22px}.loading-screen{place-items:center;min-height:100vh;padding:20px;display:grid}.loading-card{text-align:center;place-items:center;gap:8px;min-width:280px;padding:28px;display:grid}.loading-orbit{border:4px solid #2f6df624;border-top-color:var(--blue);border-radius:50%;width:42px;height:42px;animation:.9s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.modal-backdrop{z-index:30;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#10192d73;place-items:center;padding:18px;display:grid;position:fixed;inset:0}.modal{width:min(680px,100%);max-height:min(86vh,760px);padding:16px;overflow:auto}.modal>input,.modal textarea,.modal .field,.pet-choice-grid,.modal .input-shell,.modal-field-shell{margin-top:12px}.modal>input{height:42px;font-weight:900}.modal-head{align-items:flex-start}.modal-head p{color:var(--muted);margin:5px 0 0}.modal-head.danger h2{color:#b4232d}.close-btn{color:#5d6b84;background:radial-gradient(circle at 32% 20%,#fffffff5,#0000 32%),linear-gradient(#fffffffa,#eff6ffe6);border:1px solid #cbd9eeeb;border-radius:8px;flex:none;place-items:center;width:34px;height:34px;line-height:1;transition:border-color .16s,box-shadow .16s,color .16s,transform .16s;display:grid;position:relative;box-shadow:0 5px 12px #30446e1a}.close-btn span,.close-btn span:after{content:"";background:currentColor;border-radius:999px;width:14px;height:2px;position:absolute}.close-btn span{transform:rotate(45deg)}.close-btn span:after{inset:0;transform:rotate(90deg)}.close-btn:hover,.close-btn:focus-visible{color:#1d4fb8;border-color:#2f6df657;outline:none;transform:translateY(-1px);box-shadow:0 8px 18px #2f6df624,0 0 0 3px #2f6df614}.modal-actions{justify-content:flex-end;margin-top:14px}.segmented{background:#f7faffe6;border:1px solid #c5d3eadb;border-radius:8px;grid-template-columns:1fr 1fr;gap:6px;margin-top:12px;padding:5px;display:grid;position:relative;box-shadow:inset 0 1px #ffffffd1}.segmented:before{content:"";background:linear-gradient(135deg, var(--blue), #14a3c7);border-radius:7px;width:calc(50% - 8px);height:calc(100% - 10px);transition:transform .2s;position:absolute;top:5px;left:5px;box-shadow:0 10px 18px #2f6df638}.segmented.is-second:before{transform:translate(calc(100% + 6px))}.segmented button{z-index:1;color:#56647d;background:0 0;border:0;border-radius:7px;height:38px;font-weight:900;transition:color .18s,transform .18s;position:relative}.segmented button.active{color:#fff}.segmented button:hover:not(.active):not(:disabled),.segmented button:focus-visible:not(.active){color:#1d4fb8;outline:none;transform:translateY(-1px)}.field{color:var(--muted);gap:6px;font-size:13px;font-weight:800;display:grid}.batch-name-panel{background:linear-gradient(#fffffffa,#f7fafff0),#fffffff0;border:1px solid #c5d3eadb;border-radius:8px;gap:8px;margin-top:12px;transition:border-color .18s,box-shadow .18s;display:grid;position:relative;overflow:hidden;box-shadow:inset 0 1px #ffffffdb,0 8px 18px #2b3d6214}.single-student-add-row{grid-template-columns:minmax(160px,280px) auto minmax(170px,1fr);align-items:center;gap:7px 6px;margin-top:12px;display:grid}.single-student-add-row .modal-field-shell{margin-top:0}.single-student-add-actions{justify-content:flex-end;align-items:center;gap:6px;display:flex}.batch-name-panel:focus-within{border-color:#2f6df6b8;box-shadow:0 0 0 4px #2f6df61f,0 12px 24px #2f6df61f}.batch-name-panel textarea{min-height:168px;box-shadow:none;resize:vertical;background:0 0;border:0;border-radius:0;margin:0;padding:14px 14px 0;line-height:1.7}.batch-name-panel textarea:hover,.batch-name-panel textarea:focus{box-shadow:none;background:0 0;border:0}.batch-name-meta{justify-content:space-between;align-items:center;gap:8px;padding:0 10px 10px;display:flex}.batch-name-meta span{color:#38517a;background:#eff6ffeb;border:1px solid #2f6df629;border-radius:8px;min-width:0;padding:4px 8px;font-size:12px;font-weight:900}.batch-name-meta .input-action{width:28px;height:28px}.batch-name-meta .input-action:disabled{opacity:.34;box-shadow:none}.student-limit-note{background:#eff6ffc2;border:1px solid #2f6df62e;border-radius:8px;gap:4px;margin-top:12px;padding:9px 11px;display:grid}.student-limit-note.compact{background:#eff6ff9e;grid-template-columns:1fr;align-items:center;gap:1px;width:100%;max-width:100%;margin-top:0;padding:7px 10px}.student-limit-note.compact strong,.student-limit-note.compact span{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.student-limit-note strong{color:#38517a;font-size:13px;font-weight:1000}.student-limit-note span{color:var(--muted);font-size:12px;font-weight:800}.student-limit-note.blocked{background:#fff0f1db;border-color:#e5484d47}.student-limit-note.blocked strong,.student-limit-note.blocked span{color:#b4232d}.backup-import-box{gap:10px;margin-top:14px;display:grid}.backup-import-box p{color:var(--muted);margin:0;font-size:13px;line-height:1.7}.backup-mode-card,.backup-requirements,.backup-limit-note,.restore-warning{background:#f8fbffe0;border:1px solid #c5d3ead1;border-radius:8px;padding:10px 12px}.backup-mode-card,.backup-requirements,.backup-limit-note{gap:4px;display:grid}.backup-mode-card strong,.backup-requirements strong,.backup-limit-note strong,.restore-warning strong{color:var(--ink);font-size:13px;font-weight:1000}.backup-mode-card span,.backup-requirements span,.backup-limit-note span{color:var(--muted);font-size:12px;font-weight:800;line-height:1.6}.backup-mode-card{background:linear-gradient(135deg,#fffffff5,#eff6ffe0),#f8fbffe6}.backup-limit-note{background:#eff6ffc7;border-color:#2f6df633}.backup-requirements{background:#f0fdf8d1;border-color:#10a86f33}.backup-limit-note.blocked{background:#fff0f1db;border-color:#e5484d47}.backup-limit-note.blocked strong,.backup-limit-note.blocked span{color:#b4232d}.backup-summary-row{flex-wrap:wrap;gap:6px;display:flex}.backup-summary-row span{color:#38517a;background:#eff6ffeb;border:1px solid #2f6df624;border-radius:8px;padding:4px 8px;font-size:12px;font-weight:900}.restore-warning{background:radial-gradient(circle at 100% 0,#e5484d1f,#0000 34%),#fff7f7eb;border-color:#e5484d42;gap:10px;display:grid}.restore-warning strong{color:#9f1f2a}.restore-confirm{cursor:pointer;color:#5f2b32;grid-template-columns:22px minmax(0,1fr);align-items:center;gap:8px;font-size:13px;font-weight:900;display:grid;position:relative}.restore-confirm input{opacity:0;pointer-events:none;position:absolute}.restore-confirm>span{background:#ffffffeb;border:1px solid #be34415c;border-radius:7px;width:22px;height:22px;display:block;position:relative;box-shadow:inset 0 1px #ffffffdb}.restore-confirm.checked>span{background:linear-gradient(135deg,#ff5c6c,#d7263d);border-color:#d7263db8}.restore-confirm input:focus-visible+span{outline-offset:2px;outline:3px solid #e5484d29}.restore-confirm.checked>span:after{content:"";border-bottom:2px solid #fff;border-right:2px solid #fff;width:6px;height:10px;position:absolute;top:4px;left:7px;transform:rotate(45deg)}.restore-confirm em{min-width:0;font-style:normal}.file-picker{min-height:130px;color:var(--blue);text-align:center;cursor:pointer;background:radial-gradient(circle at 50% 0,#2f6df629,#0000 44%),linear-gradient(135deg,#fffffff5,#eff6ffe6);border:1px dashed #2f6df66b;border-radius:8px;align-content:center;place-items:center;gap:8px;padding:18px;font-weight:900;transition:border-color .18s,background .18s,box-shadow .18s,transform .18s;display:grid;box-shadow:inset 0 1px #ffffffe0,0 10px 24px #2f6df614}.file-picker:hover,.file-picker.dragging{background:radial-gradient(circle at 50% 0,#2f6df638,#0000 44%),linear-gradient(135deg,#fff,#e6f1fff5);border-color:#2f6df6b8;transform:translateY(-1px);box-shadow:0 0 0 4px #2f6df61a,0 16px 30px #2f6df621}.file-picker.loaded{color:#067647;background:radial-gradient(circle at 50% 0,#10a86f26,#0000 44%),linear-gradient(135deg,#fff,#ebfff6f0);border-color:#10a86f80}.file-picker input{display:none}.file-picker strong,.file-picker em{text-overflow:ellipsis;white-space:nowrap;max-width:90%;overflow:hidden}.file-picker strong{color:#23314d;font-size:15px}.file-picker em{color:var(--muted);font-size:12px;font-style:normal}.file-picker-icon{background:radial-gradient(circle at 32% 22%,#ffffffdb,#0000 32%),linear-gradient(135deg,#2f6df6eb,#13a8b8e6);border-radius:8px;place-items:center;width:42px;height:42px;display:grid;position:relative;box-shadow:0 12px 22px #2f6df638}.file-picker.loaded .file-picker-icon{background:radial-gradient(circle at 32% 22%,#ffffffdb,#0000 32%),linear-gradient(135deg,#10a86ff0,#13a8b8e6);box-shadow:0 12px 22px #10a86f33}.file-picker-icon:before{content:"";border:2px solid #fff;border-radius:4px;width:18px;height:20px;position:absolute}.file-picker-icon:after{content:"";border-top:2px solid #fff;border-left:2px solid #fff;width:10px;height:10px;position:absolute;top:12px;transform:rotate(45deg)}.form-error,.form-success{border-radius:8px;padding:8px 10px;font-size:13px}.form-error{color:#b4232d;background:#fff0f1}.form-success{color:#067647;background:#e8fff4}.pet-choice-grid{grid-template-columns:repeat(auto-fill,minmax(128px,1fr));gap:10px;display:grid}.password-change-fields{gap:12px;display:grid}.pet-choice{border:1px solid var(--line);background:#ffffffdb;border-radius:8px;place-items:center;gap:6px;min-height:150px;font-weight:900;display:grid}.pet-choice.selected{background:#eef4ff;border-color:#2f6df6b8;box-shadow:0 0 0 4px #2f6df61f}.pet-choice img{object-fit:contain;filter:drop-shadow(0 10px 14px #202d4c2e);width:96px;height:96px}.public-page,.auth-page,.legal-page{min-height:100vh;padding:20px}.public-page{background:radial-gradient(circle at 18% 14%,#2f6df633,#0000 29%),radial-gradient(circle at 82% 18%,#f4b7402e,#0000 25%),radial-gradient(circle at 54% 88%,#10a86f21,#0000 28%),linear-gradient(135deg,#f7fbff 0%,#fff9ef 52%,#f6fff8 100%);grid-template-rows:1fr auto;align-items:center;gap:16px;display:grid}.entry-shell{justify-self:center;gap:18px;width:min(460px,100%);display:grid}.entry-brand{text-align:center;justify-items:center;gap:10px;display:grid}.entry-brand h1{letter-spacing:0;margin:0;font-size:clamp(34px,7vw,48px);line-height:1}.public-nav{justify-content:space-between;align-items:center;gap:14px;padding:10px 12px;display:flex}.public-nav nav{align-items:center;gap:10px;display:flex}.public-nav a,.public-footer a,.legal-page a,.auth-card footer a{color:var(--blue);font-weight:900;text-decoration:none}.public-logo,.auth-logo{align-items:center;gap:10px;display:inline-flex}.public-logo span{background:linear-gradient(135deg, var(--blue), var(--cyan));color:#fff;border-radius:8px;place-items:center;width:40px;height:40px;font-weight:900;display:grid}.public-logo strong{color:var(--ink);font-size:18px}.public-nav-cta{background:linear-gradient(135deg, var(--blue), #14a3c7);border-radius:8px;padding:8px 12px;box-shadow:0 10px 18px #2f6df633;color:#fff!important}.public-hero{grid-template-columns:minmax(0,1.08fr) minmax(280px,.92fr);align-items:stretch;gap:18px;display:grid}.public-copy,.public-showcase,.public-features article,.auth-card,.legal-page{box-shadow:var(--shadow);background:#ffffffd6;border:1px solid #ffffffb8;border-radius:8px}.public-copy{padding:28px}.public-kicker{color:var(--blue);margin:0 0 10px;font-weight:900}.public-copy h1{margin:0;font-size:clamp(38px,6vw,68px);line-height:.96}.public-copy p{max-width:42rem;color:var(--muted);margin:16px 0 0;font-size:17px;line-height:1.8}.public-actions{flex-wrap:wrap;gap:10px;margin-top:22px;display:flex}.public-showcase{place-items:center;gap:14px;padding:20px;display:grid}.public-pet-card{text-align:center;background:linear-gradient(#fffffff0,#f4fafffa);border-radius:8px;width:min(100%,320px);padding:16px;box-shadow:0 16px 30px #1f2f5424}.public-pet-card.main{transform:translateY(-4px)}.public-pet-card.mini{opacity:.94;width:min(88%,250px)}.public-pet-card img{object-fit:contain;width:100%;height:200px}.public-pet-card strong,.public-pet-card span{display:block}.public-pet-card strong{color:var(--ink);margin-top:8px;font-size:18px}.public-pet-card span{color:var(--muted);font-size:13px}.public-features{grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;display:grid}.public-features article{padding:16px}.public-features h2{margin:0 0 8px;font-size:18px}.public-features p{color:var(--muted);margin:0;line-height:1.7}.public-footer{color:var(--muted);flex-wrap:wrap;justify-content:center;align-items:center;gap:12px;padding:4px 0 14px;font-size:13px;display:flex}.auth-page{background:radial-gradient(circle at 16% 16%,#2f6df629,#0000 28%),radial-gradient(circle at 84% 20%,#f4b74029,#0000 25%),linear-gradient(135deg,#f7fbff 0%,#fff9ef 52%,#f6fff8 100%);place-items:center;gap:18px;display:grid}.auth-card{justify-self:center;width:min(440px,100%);padding:18px}.auth-tabs{border:1px solid var(--line);background:#f7faffe6;border-radius:10px;grid-template-columns:1fr 1fr;gap:6px;margin-bottom:18px;padding:5px;display:grid;position:relative}.auth-tabs:before{content:"";background:linear-gradient(135deg, var(--blue), #14a3c7);border-radius:8px;width:calc(50% - 8px);height:calc(100% - 10px);transition:transform .2s;position:absolute;top:5px;left:5px;box-shadow:0 10px 18px #2f6df638}.auth-tabs.is-second:before{transform:translate(calc(100% + 6px))}.auth-tabs button{z-index:1;color:#56647d;background:0 0;border:0;border-radius:8px;height:40px;font-weight:900;transition:transform .18s,box-shadow .18s,background .18s,color .18s;position:relative}.auth-tabs button.active{color:#fff}.auth-tabs button:hover:not(.active):not(:disabled){background:#ffffffd1;transform:translateY(-1px)}.auth-card header p{color:var(--blue);margin:0;font-weight:900}.auth-card header h1,.auth-card header h2{margin:0 0 8px;font-size:28px;line-height:1.15}.auth-card header span{color:var(--muted);line-height:1.7}.auth-card form{gap:12px;margin-top:20px;display:grid}.auth-card label{color:var(--muted);gap:6px;font-size:13px;font-weight:800;display:grid}.auth-error{color:#b4232d;background:#fff0f1;border-radius:8px;padding:8px 10px;font-size:13px}.auth-card footer{color:var(--muted);text-align:center;margin-top:16px;font-size:13px}.dev-preview-link{color:var(--blue);background:#ffffffb8;border:1px dashed #2f6df66b;border-radius:8px;justify-self:center;padding:8px 12px;font-size:13px;font-weight:900;text-decoration:none}.dev-preview-link:hover{background:#2f6df614}.legal-page{align-content:start;gap:14px;width:min(760px,100vw - 40px);margin:24px auto;padding:24px;display:grid}.legal-page p{color:var(--muted);margin:0;line-height:1.8}.activate-page{align-items:center}.activate-shell{justify-self:center;gap:12px;width:min(520px,100%);display:grid}.activate-brand{text-align:center;justify-items:center;gap:6px;display:grid}.activate-brand span{color:var(--blue);font-size:14px;font-weight:1000}.activate-brand h1{margin:0;font-size:clamp(30px,6vw,44px);line-height:1.05}.activate-brand p{color:var(--muted);margin:0;font-size:13px;font-weight:900}.activate-status,.activate-card{box-shadow:var(--shadow);background:#ffffffdb;border:1px solid #ffffffb8;border-radius:8px}.activate-status{gap:8px;padding:14px;display:grid}.activate-status strong{color:#1d4fb8;background:#2f6df61a;border-radius:999px;width:max-content;padding:5px 10px;font-size:12px;font-weight:1000}.activate-status.readonly strong,.activate-status.locked strong,.activate-status.deletionEligible strong{color:#b4232d;background:#e5484d1a}.activate-status p{color:var(--ink);margin:0;font-weight:900;line-height:1.7}.activate-status div{flex-wrap:wrap;gap:7px;display:flex}.activate-status div span{color:var(--muted);background:#f7fafff0;border-radius:999px;padding:5px 9px;font-size:12px;font-weight:900}.activate-card{gap:12px;padding:16px;display:grid}.activate-actions{flex-wrap:wrap;justify-content:center;gap:8px;display:flex}.summon-modal{width:min(960px,100%)}.summon-intro{color:#fff;background:linear-gradient(135deg,#070e1cf5,#0f1f3de6);border:1px solid #cbd9eee6;border-radius:8px;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-top:12px;padding:10px 12px;display:flex;box-shadow:0 12px 24px #0f172a3d}.summon-intro span{color:#ffffffd6;letter-spacing:.04em;background:#ffffff1f;border-radius:999px;align-items:center;height:26px;padding:0 10px;font-size:11px;font-weight:900;display:inline-flex}.summon-intro strong{color:#fff;min-width:0;font-size:16px;font-weight:1000}.summon-intro p{color:#ffffffb3;margin:0;font-size:12px;font-weight:800}.summon-player{background:radial-gradient(circle at 50% 35%,#2f6df657,#0000 38%),linear-gradient(135deg,#050816,#0f1f3d 58%,#15102b);border:1px solid #cbd9ee38;border-radius:8px;min-height:430px;margin-top:12px;position:relative;overflow:hidden;box-shadow:0 18px 34px #0f172a3d,inset 0 1px #ffffff0f}.summon-player video{opacity:0;cursor:pointer;object-fit:contain;background:#050816;width:100%;min-height:430px;max-height:68vh;transition:opacity .28s;display:block}.summon-player video.ready{opacity:1}.summon-loading{z-index:2;color:#fff;text-align:center;align-content:center;place-items:center;gap:12px;display:grid;position:absolute;inset:0}.summon-loading:before{content:"";border:2px solid #ffffff47;border-top-color:#ffd666eb;border-radius:50%;width:230px;height:230px;animation:1.2s linear infinite spin;position:absolute}.summon-loading img{z-index:1;object-fit:contain;filter:drop-shadow(0 20px 24px #00000059);width:min(280px,66vw);height:240px;position:relative}.summon-loading strong{z-index:1;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff24;border-radius:8px;padding:8px 13px;position:relative}.summon-controls-zone{z-index:4;padding:42px 14px 14px;position:absolute;bottom:0;left:0;right:0}.summon-controls{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);opacity:0;pointer-events:none;background:#070e1cb8;border:1px solid #ffffff2e;border-radius:8px;grid-template-columns:auto auto minmax(90px,1fr) auto auto;align-items:center;gap:8px;padding:8px;transition:opacity .18s,transform .18s;display:grid;transform:translateY(12px);box-shadow:0 16px 30px #0000003d,inset 0 1px #ffffff1f}.summon-controls-zone:hover .summon-controls,.summon-controls-zone:focus-within .summon-controls{opacity:1;pointer-events:auto;transform:translateY(0)}.video-main-control,.video-icon-control{color:#fff;border:0;border-radius:8px;place-items:center;padding:0;font-weight:1000;line-height:1;transition:background .16s,transform .16s,box-shadow .16s;display:grid}.video-main-control{background:linear-gradient(135deg, var(--blue), #14a3c7);width:38px;height:38px;font-size:16px;box-shadow:0 10px 18px #2f6df647}.video-icon-control{background:#ffffff1f;width:34px;height:34px;font-size:13px}.video-main-control:hover:not(:disabled),.video-icon-control:hover:not(:disabled),.video-main-control:focus-visible,.video-icon-control:focus-visible{outline:none;transform:translateY(-1px);box-shadow:0 10px 18px #2f6df63d,0 0 0 3px #ffffff1a}.video-icon-control:hover:not(:disabled),.video-icon-control:focus-visible{background:#fff3}.video-progress{cursor:pointer;border-radius:999px;outline:none;min-width:80px;height:18px;position:relative}.video-progress:before{content:"";background:#ffffff38;border-radius:999px;height:6px;position:absolute;top:50%;left:0;right:0;transform:translateY(-50%)}.video-progress span{background:linear-gradient(90deg,#ffd166,#2f6df6,#13a8b8);border-radius:999px;min-width:6px;height:6px;position:absolute;top:50%;left:0;transform:translateY(-50%);box-shadow:0 0 16px #2f6df657}.video-progress:focus-visible:before{box-shadow:0 0 0 4px #ffffff1f}.video-time{color:#ffffffdb;text-align:center;white-space:nowrap;min-width:86px;font-size:12px;font-weight:900}.summon-fallback{background:#07111f;border-radius:8px;place-items:center;min-height:360px;margin-top:12px;display:grid}.summon-fallback img{object-fit:contain;max-width:80%;max-height:340px}.levelup-backdrop{background:radial-gradient(circle at 50% 35%,#ffd36647,#0000 30%),#0c152a9e}.levelup-modal{background:radial-gradient(circle at 50% 30%,#ffe08a61,#0000 30%),radial-gradient(circle at 16% 18%,#2f6df61f,#0000 24%),radial-gradient(circle at 86% 22%,#10a86f1a,#0000 24%),linear-gradient(160deg,#fffffffa,#eef6fffa);border:1px solid #ffdf80b8;width:min(720px,100%);position:relative;overflow:hidden}.levelup-burst{background:conic-gradient(#0000,#ffd26642,#0000 14%,#2f6df624,#0000 32%);animation:8s linear infinite spin;position:absolute;inset:-80px}.levelup-modal>:not(.levelup-burst){z-index:1;position:relative}.levelup-head{text-align:center;justify-items:center;gap:5px;display:grid}.levelup-head span{color:#6b3d00;letter-spacing:.08em;background:linear-gradient(135deg,#ffe08a,#ffb84d);border-radius:8px;padding:6px 12px;font-size:12px;font-weight:900;box-shadow:0 10px 20px #ffb84d33}.levelup-head h2{color:#16213e;text-shadow:0 2px #ffffffd1;margin:0;font-size:clamp(30px,5vw,46px);line-height:1}.levelup-head p{color:#53627c;margin:0;font-weight:800}.levelup-stage{background:radial-gradient(circle at 12% 18%,#ffd16633,#0000 22%),radial-gradient(circle at 88% 22%,#2f6df624,#0000 22%),radial-gradient(circle at 18% 84%,#10a86f1f,#0000 22%),linear-gradient(#ffffffe6,#f2f8fff5);border:1px solid #ffdf80b8;border-radius:8px;place-items:center;height:min(48vh,360px);min-height:250px;margin:8px 0;padding:24px 16px 28px;display:grid;position:relative;overflow:visible;box-shadow:inset 0 1px #ffffffe6,0 14px 28px #202d4c1f}.levelup-stage:before{content:"";background:linear-gradient(90deg,#0000,#2f6df629,#ffb84d29,#0000);border-radius:999px;height:12px;position:absolute;bottom:10px;left:10%;right:10%}.levelup-stage:after{content:"";opacity:.72;pointer-events:none;background:radial-gradient(circle at 8% 24%,#ffb84d80 0 3px,#0000 4px),radial-gradient(circle at 92% 28%,#2f6df661 0 3px,#0000 4px),radial-gradient(circle at 15% 78%,#10a86f57 0 3px,#0000 4px),radial-gradient(circle at 84% 76%,#f43f5e4d 0 3px,#0000 4px);border-radius:8px;position:absolute;inset:14px}.levelup-stage-tag{z-index:2;color:#6b3d00;letter-spacing:.04em;background:linear-gradient(135deg,#ffe08a,#ffb84d);border-radius:999px;align-items:center;height:26px;padding:0 10px;font-size:11px;font-weight:1000;display:inline-flex;position:absolute;top:10px;left:10px;box-shadow:0 10px 18px #ffb84d33}.levelup-stage img{z-index:2;object-fit:contain;filter:drop-shadow(0 14px 18px #202d4c2e);max-width:min(360px,78vw);max-height:calc(100% - 42px);animation:2.2s ease-in-out infinite levelupFloat;position:relative}.levelup-stats{background:#ffffffd1;border:1px solid #cbd9eee6;border-radius:8px;flex-wrap:wrap;justify-content:center;gap:8px;padding:9px;display:flex;box-shadow:0 8px 18px #2b3d6214}.levelup-stats span{color:#34405a;background:radial-gradient(circle at 22% 14%,#fffffff0,#0000 30%),linear-gradient(#ffffffc7,#eff6ffdb);border:1px solid #2f6df629;border-radius:999px;padding:7px 10px;font-size:13px;font-weight:900}.levelup-modal .modal-actions{justify-content:center;gap:10px}.levelup-modal .btn{min-width:112px;font-weight:950}.levelup-modal .btn.secondary{color:#640;background:linear-gradient(135deg,#fff2bf,#ffd166);box-shadow:0 12px 24px #f4b74038}.levelup-modal .btn.primary{box-shadow:0 14px 28px #2f6df642}@keyframes levelupFloat{0%,to{transform:translateY(0)scale(1)}50%{transform:translateY(-8px)scale(1.035)}}.toast{z-index:40;color:#fff;background:#172033;border-radius:8px;max-width:min(420px,100vw - 40px);padding:12px 14px;font-weight:800;position:fixed;bottom:20px;right:20px;box-shadow:0 16px 34px #17203347}.admin-page{min-height:100vh;padding:16px}.admin-shell{gap:12px;width:min(1440px,100%);margin:0 auto;display:grid}.admin-hero,.admin-card{box-shadow:var(--shadow);background:#ffffffe6;border:1px solid #ffffffb8;border-radius:8px}.admin-hero{justify-content:space-between;align-items:center;gap:14px;padding:16px;display:flex}.admin-hero span{color:#1d4fb8;background:#2f6df61a;border-radius:999px;align-items:center;height:26px;padding:0 10px;font-size:12px;font-weight:1000;display:inline-flex}.admin-hero h1,.admin-card h2,.detail-section h3{margin:0}.admin-hero h1{margin-top:8px;font-size:clamp(26px,4vw,40px);line-height:1}.admin-hero p,.admin-card p,.teacher-detail-head p{color:var(--muted);margin:6px 0 0;font-size:13px;font-weight:800}.admin-hero-actions,.admin-card-head,.admin-filter-row,.admin-filter-pills,.admin-quick-row,.admin-inline-form{align-items:center;gap:8px;display:flex}.admin-tabs{background:#ffffffc7;border:1px solid #cbd9eec7;border-radius:8px;flex-wrap:wrap;gap:6px;padding:6px;display:flex;box-shadow:0 10px 24px #1f2f5414}.admin-tabs button,.admin-filter-pills button,.admin-quick-row button{color:#40506d;background:#f7fafff5;border:0;border-radius:8px;min-height:34px;padding:0 11px;font-size:13px;font-weight:950;transition:background .16s,color .16s,transform .16s,box-shadow .16s}.admin-tabs button:hover,.admin-filter-pills button:hover,.admin-quick-row button:hover{color:#1d4fb8;background:#2f6df614;transform:translateY(-1px)}.admin-tabs button.active,.admin-filter-pills button.active,.admin-quick-row button.active{background:linear-gradient(135deg, var(--blue), #14a3c7);color:#fff;box-shadow:0 10px 18px #2f6df633}.admin-quick-row button.danger-lite{color:#b4232d;background:#e5484d1a}.admin-quick-row button.danger-lite:hover:not(:disabled){color:#981b25;background:#e5484d29}.admin-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;display:grid}.admin-card{min-width:0;padding:14px}.metric-card{gap:8px;display:grid}.metric-card span,.metric-card em{color:var(--muted);font-size:13px;font-style:normal;font-weight:900}.metric-card strong{font-size:38px;line-height:1}.status-card{gap:8px;display:grid}.cleanup-card{background:linear-gradient(135deg,#fff0f1eb,#ffffffe0 62%),#ffffffe6;border-color:#e5484d3d;flex-direction:column;justify-content:space-between;gap:12px;min-height:160px;display:flex}.cleanup-card span{color:#9f1f2b;font-size:13px;font-weight:1000}.cleanup-card strong{margin-top:8px;font-size:38px;line-height:1;display:block}.cleanup-card p{color:#9f1f2b;line-height:1.55}.status-row{border-top:1px solid #e2e8f0e6;justify-content:space-between;align-items:center;gap:10px;padding-top:8px;display:flex}.admin-two-column{grid-template-columns:minmax(520px,1.15fr) minmax(380px,.85fr);align-items:start;gap:12px;display:grid}.codes-layout{grid-template-columns:minmax(360px,.72fr) minmax(520px,1.28fr)}.admin-card-head{justify-content:space-between;margin-bottom:12px}.admin-filter-row{flex-wrap:wrap;margin-bottom:10px}.admin-filter-row-secondary{background:#f8fbff9e;border:1px solid #dae4f2b8;border-radius:8px;align-items:flex-start;padding:8px}.filter-label{min-height:34px;color:var(--muted);flex:none;align-items:center;font-size:12px;font-weight:1000;display:inline-flex}.admin-search-shell{flex:260px;width:min(320px,100%)}.admin-filter-pills{flex-wrap:wrap}.admin-table,.code-list,.audit-list,.mini-list{gap:7px;display:grid}.empty-note{color:var(--muted);text-align:center;background:#f8fbffb3;border:1px dashed #adbcd2d1;border-radius:8px;margin:0;padding:12px;font-size:13px;font-weight:850}.admin-table{max-height:66vh;padding-right:4px;overflow:auto}.admin-table-row{width:100%;min-height:60px;color:var(--ink);text-align:left;background:#ffffffd1;border:1px solid #dae4f2e6;border-radius:8px;grid-template-columns:minmax(0,1fr) auto minmax(104px,auto);align-items:center;gap:10px;padding:9px 10px;transition:border-color .16s,background .16s,box-shadow .16s,transform .16s;display:grid}.admin-table-row:hover,.admin-table-row.selected{background:linear-gradient(135deg,#2f6df614,#13a8b80d);border-color:#2f6df657;transform:translateY(-1px);box-shadow:0 10px 18px #2f6df61a}.admin-table-row span:first-child,.code-card div{gap:3px;min-width:0;display:grid}.admin-table-row strong,.code-card strong,.mini-list strong,.audit-row strong{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.admin-table-row em,.admin-date,.code-card span,.code-card em,.mini-list span,.audit-row span,.audit-row em{color:var(--muted);font-size:12px;font-style:normal;font-weight:850}.code-card small{color:#355178;text-overflow:ellipsis;white-space:nowrap;background:#2f6df614;border-radius:999px;width:fit-content;max-width:100%;padding:3px 8px;font-size:12px;font-weight:900;overflow:hidden}.admin-date{justify-items:end;gap:2px;line-height:1.15;display:grid}.admin-date em{color:#667085b8;font-size:11px;font-weight:900}.admin-date strong{color:#344054;font-size:12px;font-weight:1000}.admin-status{border-radius:999px;align-items:center;width:max-content;height:26px;padding:0 9px;font-size:12px;font-weight:1000;display:inline-flex}.admin-status.trial{color:#1d4fb8;background:#2f6df61a}.admin-status.active{color:#08764f;background:#10a86f1f}.admin-status.expired{color:#8a5a00;background:#f4b74029}.admin-status.suspended{color:#9f1f2a;background:#e5484d1f}.teacher-detail{gap:13px;display:grid;position:sticky;top:12px}.teacher-detail.empty{color:var(--muted)}.teacher-detail-head{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.teacher-detail-head h2{overflow-wrap:anywhere}.detail-stats{grid-template-columns:repeat(3,1fr);gap:8px;display:grid}.detail-stats span{color:var(--muted);background:#f8fbffd6;border:1px solid #dae4f2e6;border-radius:8px;gap:2px;padding:9px;font-size:12px;font-weight:900;display:grid}.detail-stats strong{color:var(--ink);font-size:16px}.detail-section{border-top:1px solid #e2e8f0e6;gap:8px;padding-top:12px;display:grid}.detail-section h3{font-size:14px}.admin-quick-row{flex-wrap:wrap}.admin-inline-form{align-items:stretch}.admin-inline-form input{flex:auto;min-width:0}.admin-inline-form .btn{flex:none}.admin-limit-form{grid-template-columns:minmax(0,1fr) minmax(0,1fr) auto;align-items:end;gap:8px;display:grid}.admin-limit-form label{color:var(--muted);gap:5px;font-size:12px;font-weight:900;display:grid}.admin-limit-form input{min-width:0}.detail-note{color:var(--muted);margin:0;font-size:12px;font-weight:850;line-height:1.55}.danger-zone{background:#fff0f16b;border-color:#e5484d38;border-radius:8px;padding:10px}.danger-zone p{color:#9f1f2b;margin:0 0 8px;font-size:12px;font-weight:850;line-height:1.6}.admin-form-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.admin-form-grid label{color:var(--muted);gap:6px;font-size:12px;font-weight:900;display:grid}.admin-form-grid .wide{grid-column:1/-1}.code-list{max-height:70vh;padding-right:4px;overflow:auto}.code-pagination{color:var(--muted);background:#f8fbff9e;border:1px solid #dae4f2b8;border-radius:8px;justify-content:space-between;align-items:center;gap:10px;margin-bottom:10px;padding:8px 10px;font-size:12px;font-weight:900;display:flex}.code-pagination div{gap:7px;display:flex}.code-pagination button{color:#1d4fb8;background:#2f6df61a;border:0;border-radius:8px;height:32px;padding:0 10px;font-weight:950}.code-pagination button:disabled{cursor:not-allowed;color:#667085b8;background:#e5eaf2b8}.code-card{background:#ffffffd6;border:1px solid #dae4f2e6;border-radius:8px;grid-template-columns:minmax(0,1fr) auto minmax(140px,auto) auto;align-items:center;gap:10px;padding:10px;display:grid}.code-card.used{opacity:.72;background:#f8fafcc7}.code-card.expired{background:#fff6f6b8;border-color:#e5484d33}.code-state{border-radius:999px;align-items:center;width:max-content;height:26px;padding:0 9px;font-size:12px;font-weight:1000;display:inline-flex}.code-state.unused{color:#08764f;background:#10a86f1f}.code-state.used{color:#465265;background:#6670851f}.code-state.expired{color:#9f1f2a;background:#e5484d1f}.code-card-actions{justify-content:flex-end;gap:7px;display:flex}.code-card button{color:#1d4fb8;background:#2f6df61a;border:0;border-radius:8px;height:32px;padding:0 10px;font-weight:950}.code-card button.danger-lite{color:#b4232d;background:#e5484d1a}.code-delete-panel{background:linear-gradient(135deg,#fff0f1eb,#ffffffd1);border:1px solid #e5484d3d;border-radius:8px;gap:8px;margin-top:12px;padding:12px;display:grid}.code-delete-panel div:first-child{gap:3px;display:grid}.code-delete-panel strong{font-size:14px}.code-delete-panel span,.code-delete-panel p{color:#9f1f2b;font-size:12px;font-weight:850}.code-delete-panel p{margin:0;line-height:1.55}.audit-row,.mini-list article{background:#fffc;border:1px solid #dae4f2e6;border-radius:8px;gap:4px;padding:10px;display:grid}.audit-row{grid-template-columns:150px minmax(0,1fr) minmax(180px,auto);align-items:center}.activation-history em{color:var(--muted);font-size:12px;font-style:normal;font-weight:850;line-height:1.45}@media (max-width:1100px){.admin-grid,.admin-two-column,.codes-layout{grid-template-columns:1fr}.teacher-detail{position:static}.audit-row,.code-card,.admin-table-row,.admin-limit-form,.app-layout{grid-template-columns:1fr}.side-panel{max-height:none;padding-right:0;position:static;overflow:visible}.public-hero,.public-features{grid-template-columns:1fr}}@media (max-width:1120px){.topbar{grid-template-columns:1fr;grid-template-areas:"main""subscription"}.topbar-main{padding-bottom:2px;overflow-x:auto}.subscription-banner{width:100%}}@media (max-width:720px){.workbench{padding:10px}.toolbar,.topbar-main{flex-wrap:wrap;align-items:stretch;overflow-x:visible}.classroom-menu{flex-basis:auto;width:100%;min-width:0}.topbar .classroom-menu,.topbar .topbar-search,.topbar .selection-actions,.topbar .view-tabs,.subscription-banner{flex:auto;width:100%;min-width:0}.topbar .view-tabs{justify-content:flex-start;overflow-x:auto}.subscription-banner{flex-direction:column;align-items:flex-start}.classroom-menu-panel{width:100%}.search-box,.toolbar-actions{flex-wrap:wrap;width:100%}.selection-actions,.data-menu,.account-menu{flex:150px}.data-menu-trigger,.account-menu-trigger{justify-content:center;width:100%}.data-menu-panel{left:0;right:auto}.record-tools{grid-template-columns:1fr}.view-head{flex-direction:column;align-items:stretch}.rule-form .form-row{grid-template-columns:1fr;display:grid}.score-stepper{flex-basis:auto;width:100%}.single-student-add-row{grid-template-columns:1fr}.single-student-add-actions{justify-content:stretch}.single-student-add-actions .btn{flex:1 1 0}.student-limit-note.compact{grid-template-columns:1fr;width:100%}.rule-score-field{flex-basis:auto;width:100%}.summon-player,.summon-player video{min-height:320px}.summon-controls-zone{padding:32px 10px 10px}.summon-controls{opacity:1;pointer-events:auto;grid-template-columns:auto auto 1fr auto;transform:none}.summon-controls .video-time{text-align:left;order:2;grid-column:1/-1}.summon-controls .video-progress{min-width:0}.pet-grid,.performance-grid,.leaderboard-grid{grid-template-columns:1fr}.public-page,.auth-page,.legal-page{padding:12px}.entry-shell{width:100%}.public-nav,.public-nav nav{flex-direction:column;align-items:stretch}.public-copy{padding:20px}.public-copy p{font-size:15px}}@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-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}
