@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-translate-x:0;--tw-translate-y:0;--tw-translate-z:0;--tw-space-y-reverse:0;--tw-border-style:solid;--tw-font-weight:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--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;--tw-backdrop-blur:initial;--tw-backdrop-brightness:initial;--tw-backdrop-contrast:initial;--tw-backdrop-grayscale:initial;--tw-backdrop-hue-rotate:initial;--tw-backdrop-invert:initial;--tw-backdrop-opacity:initial;--tw-backdrop-saturate:initial;--tw-backdrop-sepia:initial}}}@layer theme{:root,:host{--font-mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;--color-red-50:#fef2f2;--color-red-200:#ffcaca;--color-red-500:#fb2c36;--color-red-600:#e40014;--color-red-700:#bf000f;--color-green-600:#00a544;--color-emerald-50:#ecfdf5;--color-emerald-200:#a4f4cf;--color-emerald-700:#007956;--color-rose-50:#fff1f2;--color-rose-200:#ffccd3;--color-rose-600:#e70044;--color-black:#000;--color-white:#fff;--spacing:.25rem;--container-xs:20rem;--container-md:28rem;--container-lg:32rem;--container-xl:36rem;--container-2xl:42rem;--container-3xl:48rem;--container-4xl:56rem;--container-7xl:80rem;--text-xs:.75rem;--text-xs--line-height:calc(1/.75);--text-sm:.875rem;--text-sm--line-height:calc(1.25/.875);--text-base:1rem;--text-base--line-height:calc(1.5/1);--text-lg:1.125rem;--text-lg--line-height:calc(1.75/1.125);--text-xl:1.25rem;--text-xl--line-height:calc(1.75/1.25);--text-2xl:1.5rem;--text-2xl--line-height:calc(2/1.5);--text-3xl:1.875rem;--text-3xl--line-height:calc(2.25/1.875);--text-4xl:2.25rem;--text-4xl--line-height:calc(2.5/2.25);--font-weight-semibold:600;--radius-xl:.75rem;--radius-2xl:1rem;--radius-3xl:1.5rem;--blur-sm:8px;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4,0,.2,1);--default-font-family:var(--font-body);--default-mono-font-family:var(--font-mono)}@supports (color:lab(0% 0 0)){:root,:host{--color-red-50:lab(96.5005% 4.18508 1.52328);--color-red-200:lab(86.017% 19.8815 7.75869);--color-red-500:lab(55.4814% 75.0732 48.8528);--color-red-600:lab(48.4493% 77.4328 61.5452);--color-red-700:lab(40.4273% 67.2623 53.7441);--color-green-600:lab(59.0978% -58.6621 41.2579);--color-emerald-50:lab(97.8462% -6.94966 1.85487);--color-emerald-200:lab(90.2247% -31.039 9.47084);--color-emerald-700:lab(44.4871% -41.0396 11.0361);--color-rose-50:lab(96.2369% 4.94155 1.28011);--color-rose-200:lab(86.806% 19.1909 4.07754);--color-rose-600:lab(49.1882% 81.577 36.0311)}}}@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{.collapse{visibility:collapse}.absolute{position:absolute}.fixed{position:fixed}.static{position:static}.inset-0{inset:calc(var(--spacing)*0)}.top-4{top:calc(var(--spacing)*4)}.bottom-3{bottom:calc(var(--spacing)*3)}.left-1\/2{left:50%}.z-40{z-index:40}.z-50{z-index:50}.z-\[60\]{z-index:60}.z-\[2200\]{z-index:2200}.mx-auto{margin-inline:auto}.mt-1{margin-top:calc(var(--spacing)*1)}.mt-2{margin-top:calc(var(--spacing)*2)}.mt-3{margin-top:calc(var(--spacing)*3)}.mt-4{margin-top:calc(var(--spacing)*4)}.mt-5{margin-top:calc(var(--spacing)*5)}.mt-6{margin-top:calc(var(--spacing)*6)}.mb-2{margin-bottom:calc(var(--spacing)*2)}.mb-4{margin-bottom:calc(var(--spacing)*4)}.mb-6{margin-bottom:calc(var(--spacing)*6)}.ml-1{margin-left:calc(var(--spacing)*1)}.ml-2{margin-left:calc(var(--spacing)*2)}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline-flex{display:inline-flex}.table{display:table}.h-3{height:calc(var(--spacing)*3)}.h-3\.5{height:calc(var(--spacing)*3.5)}.h-4{height:calc(var(--spacing)*4)}.h-5{height:calc(var(--spacing)*5)}.h-6{height:calc(var(--spacing)*6)}.h-8{height:calc(var(--spacing)*8)}.h-9{height:calc(var(--spacing)*9)}.h-10{height:calc(var(--spacing)*10)}.h-12{height:calc(var(--spacing)*12)}.h-14{height:calc(var(--spacing)*14)}.h-28{height:calc(var(--spacing)*28)}.max-h-\[70vh\]{max-height:70vh}.min-h-\[32px\]{min-height:32px}.min-h-\[36px\]{min-height:36px}.min-h-\[44px\]{min-height:44px}.min-h-\[60vh\]{min-height:60vh}.min-h-\[90px\]{min-height:90px}.min-h-screen{min-height:100vh}.w-3{width:calc(var(--spacing)*3)}.w-3\.5{width:calc(var(--spacing)*3.5)}.w-4{width:calc(var(--spacing)*4)}.w-5{width:calc(var(--spacing)*5)}.w-6{width:calc(var(--spacing)*6)}.w-8{width:calc(var(--spacing)*8)}.w-10{width:calc(var(--spacing)*10)}.w-12{width:calc(var(--spacing)*12)}.w-14{width:calc(var(--spacing)*14)}.w-28{width:calc(var(--spacing)*28)}.w-\[calc\(100\%-2rem\)\]{width:calc(100% - 2rem)}.w-fit{width:fit-content}.w-full{width:100%}.max-w-2xl{max-width:var(--container-2xl)}.max-w-3xl{max-width:var(--container-3xl)}.max-w-4xl{max-width:var(--container-4xl)}.max-w-7xl{max-width:var(--container-7xl)}.max-w-lg{max-width:var(--container-lg)}.max-w-md{max-width:var(--container-md)}.max-w-xl{max-width:var(--container-xl)}.max-w-xs{max-width:var(--container-xs)}.min-w-\[44px\]{min-width:44px}.min-w-\[180px\]{min-width:180px}.flex-1{flex:1}.-translate-x-1\/2{--tw-translate-x:calc(calc(1/2*100%)*-1);translate:var(--tw-translate-x)var(--tw-translate-y)}.cursor-pointer{cursor:pointer}.resize{resize:both}.scroll-mt-36{scroll-margin-top:calc(var(--spacing)*36)}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.items-end{align-items:flex-end}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-1{gap:calc(var(--spacing)*1)}.gap-2{gap:calc(var(--spacing)*2)}.gap-3{gap:calc(var(--spacing)*3)}.gap-4{gap:calc(var(--spacing)*4)}.gap-6{gap:calc(var(--spacing)*6)}:where(.space-y-2>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing)*2)*var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing)*2)*calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-3>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing)*3)*var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing)*3)*calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-4>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing)*4)*var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing)*4)*calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-6>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing)*6)*var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing)*6)*calc(1 - var(--tw-space-y-reverse)))}.overflow-hidden{overflow:hidden}.overflow-y-auto{overflow-y:auto}.rounded-2xl{border-radius:var(--radius-2xl)}.rounded-3xl{border-radius:var(--radius-3xl)}.rounded-full{border-radius:3.40282e38px}.rounded-xl{border-radius:var(--radius-xl)}.border{border-style:var(--tw-border-style);border-width:1px}.border-b{border-bottom-style:var(--tw-border-style);border-bottom-width:1px}.border-dashed{--tw-border-style:dashed;border-style:dashed}.border-\[var\(--accent\)\]{border-color:var(--accent)}.border-\[var\(--border\)\]{border-color:var(--border)}.border-emerald-200{border-color:var(--color-emerald-200)}.border-red-200{border-color:var(--color-red-200)}.border-rose-200{border-color:var(--color-rose-200)}.bg-\[var\(--accent-soft\)\]{background-color:var(--accent-soft)}.bg-black\/30{background-color:#0000004d}@supports (color:color-mix(in lab, red, red)){.bg-black\/30{background-color:color-mix(in oklab,var(--color-black)30%,transparent)}}.bg-emerald-50{background-color:var(--color-emerald-50)}.bg-red-50{background-color:var(--color-red-50)}.bg-red-50\/70{background-color:#fef2f2b3}@supports (color:color-mix(in lab, red, red)){.bg-red-50\/70{background-color:color-mix(in oklab,var(--color-red-50)70%,transparent)}}.bg-rose-50{background-color:var(--color-rose-50)}.bg-transparent{background-color:#0000}.bg-white{background-color:var(--color-white)}.bg-white\/80{background-color:#fffc}@supports (color:color-mix(in lab, red, red)){.bg-white\/80{background-color:color-mix(in oklab,var(--color-white)80%,transparent)}}.bg-white\/90{background-color:#ffffffe6}@supports (color:color-mix(in lab, red, red)){.bg-white\/90{background-color:color-mix(in oklab,var(--color-white)90%,transparent)}}.p-2{padding:calc(var(--spacing)*2)}.p-3{padding:calc(var(--spacing)*3)}.p-4{padding:calc(var(--spacing)*4)}.p-5{padding:calc(var(--spacing)*5)}.p-6{padding:calc(var(--spacing)*6)}.p-8{padding:calc(var(--spacing)*8)}.px-2{padding-inline:calc(var(--spacing)*2)}.px-3{padding-inline:calc(var(--spacing)*3)}.px-4{padding-inline:calc(var(--spacing)*4)}.px-5{padding-inline:calc(var(--spacing)*5)}.px-6{padding-inline:calc(var(--spacing)*6)}.py-0\.5{padding-block:calc(var(--spacing)*.5)}.py-1{padding-block:calc(var(--spacing)*1)}.py-1\.5{padding-block:calc(var(--spacing)*1.5)}.py-2{padding-block:calc(var(--spacing)*2)}.py-2\.5{padding-block:calc(var(--spacing)*2.5)}.py-3{padding-block:calc(var(--spacing)*3)}.py-4{padding-block:calc(var(--spacing)*4)}.py-5{padding-block:calc(var(--spacing)*5)}.py-6{padding-block:calc(var(--spacing)*6)}.py-12{padding-block:calc(var(--spacing)*12)}.pt-1{padding-top:calc(var(--spacing)*1)}.pt-5{padding-top:calc(var(--spacing)*5)}.pt-6{padding-top:calc(var(--spacing)*6)}.pb-4{padding-bottom:calc(var(--spacing)*4)}.pb-5{padding-bottom:calc(var(--spacing)*5)}.pb-28{padding-bottom:calc(var(--spacing)*28)}.text-center{text-align:center}.text-left{text-align:left}.text-2xl{font-size:var(--text-2xl);line-height:var(--tw-leading,var(--text-2xl--line-height))}.text-3xl{font-size:var(--text-3xl);line-height:var(--tw-leading,var(--text-3xl--line-height))}.text-4xl{font-size:var(--text-4xl);line-height:var(--tw-leading,var(--text-4xl--line-height))}.text-base{font-size:var(--text-base);line-height:var(--tw-leading,var(--text-base--line-height))}.text-lg{font-size:var(--text-lg);line-height:var(--tw-leading,var(--text-lg--line-height))}.text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.text-xl{font-size:var(--text-xl);line-height:var(--tw-leading,var(--text-xl--line-height))}.text-xs{font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height))}.text-\[10px\]{font-size:10px}.text-\[11px\]{font-size:11px}.text-\[12px\]{font-size:12px}.text-\[13px\]{font-size:13px}.font-semibold{--tw-font-weight:var(--font-weight-semibold);font-weight:var(--font-weight-semibold)}.text-\[var\(--accent-strong\)\]{color:var(--accent-strong)}.text-\[var\(--muted\)\]{color:var(--muted)}.text-\[var\(--text\)\]{color:var(--text)}.text-emerald-700{color:var(--color-emerald-700)}.text-green-600{color:var(--color-green-600)}.text-red-500{color:var(--color-red-500)}.text-red-600{color:var(--color-red-600)}.text-red-700{color:var(--color-red-700)}.text-rose-600{color:var(--color-rose-600)}.antialiased{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.accent-\[var\(--accent\)\]{accent-color:var(--accent)}.opacity-70{opacity:.7}.shadow-2xl{--tw-shadow:0 25px 50px -12px var(--tw-shadow-color,#00000040);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-\[0_28px_60px_rgba\(0\,0\,0\,0\.18\)\]{--tw-shadow:0 28px 60px var(--tw-shadow-color,#0000002e);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-sm{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a),0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.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,)}.backdrop-blur-sm{--tw-backdrop-blur:blur(var(--blur-sm));-webkit-backdrop-filter:var(--tw-backdrop-blur,)var(--tw-backdrop-brightness,)var(--tw-backdrop-contrast,)var(--tw-backdrop-grayscale,)var(--tw-backdrop-hue-rotate,)var(--tw-backdrop-invert,)var(--tw-backdrop-opacity,)var(--tw-backdrop-saturate,)var(--tw-backdrop-sepia,);backdrop-filter:var(--tw-backdrop-blur,)var(--tw-backdrop-brightness,)var(--tw-backdrop-contrast,)var(--tw-backdrop-grayscale,)var(--tw-backdrop-hue-rotate,)var(--tw-backdrop-invert,)var(--tw-backdrop-opacity,)var(--tw-backdrop-saturate,)var(--tw-backdrop-sepia,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}@media (hover:hover){.hover\:bg-\[color-mix\(in_srgb\,var\(--accent-soft\)_70\%\,var\(--panel\)\)\]:hover{background-color:var(--accent-soft)}@supports (color:color-mix(in lab, red, red)){.hover\:bg-\[color-mix\(in_srgb\,var\(--accent-soft\)_70\%\,var\(--panel\)\)\]:hover{background-color:color-mix(in srgb,var(--accent-soft)70%,var(--panel))}}.hover\:bg-\[color-mix\(in_srgb\,var\(--accent-soft\)_80\%\,var\(--panel\)\)\]:hover{background-color:var(--accent-soft)}@supports (color:color-mix(in lab, red, red)){.hover\:bg-\[color-mix\(in_srgb\,var\(--accent-soft\)_80\%\,var\(--panel\)\)\]:hover{background-color:color-mix(in srgb,var(--accent-soft)80%,var(--panel))}}.hover\:bg-\[var\(--accent-soft\)\]:hover{background-color:var(--accent-soft)}.hover\:text-\[var\(--accent-strong\)\]:hover{color:var(--accent-strong)}.hover\:underline:hover{text-decoration-line:underline}}.focus-visible\:ring-2:focus-visible{--tw-ring-shadow:var(--tw-ring-inset,)0 0 0 calc(2px + var(--tw-ring-offset-width))var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.focus-visible\:ring-\[var\(--accent\)\]:focus-visible{--tw-ring-color:var(--accent)}.focus-visible\:ring-offset-2:focus-visible{--tw-ring-offset-width:2px;--tw-ring-offset-shadow:var(--tw-ring-inset,)0 0 0 var(--tw-ring-offset-width)var(--tw-ring-offset-color)}.focus-visible\:ring-offset-\[var\(--bg\)\]:focus-visible{--tw-ring-offset-color:var(--bg)}.focus-visible\:outline-none:focus-visible{--tw-outline-style:none;outline-style:none}@media (min-width:40rem){.sm\:col-span-2{grid-column:span 2/span 2}.sm\:block{display:block}.sm\:max-w-md{max-width:var(--container-md)}.sm\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.sm\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.sm\:grid-cols-\[1fr_120px_auto\]{grid-template-columns:1fr 120px auto}.sm\:grid-cols-\[1fr_auto\]{grid-template-columns:1fr auto}.sm\:grid-cols-\[72px_1fr_auto\]{grid-template-columns:72px 1fr auto}.sm\:grid-cols-\[88px_1fr_auto\]{grid-template-columns:88px 1fr auto}.sm\:grid-cols-\[auto_1fr\]{grid-template-columns:auto 1fr}.sm\:items-center{align-items:center}.sm\:items-end{align-items:flex-end}.sm\:pt-36{padding-top:calc(var(--spacing)*36)}.sm\:pb-10{padding-bottom:calc(var(--spacing)*10)}}@media (min-width:48rem){.md\:col-span-2{grid-column:span 2/span 2}.md\:hidden{display:none}.md\:inline-flex{display:inline-flex}.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (min-width:64rem){.lg\:hidden{display:none}.lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.lg\:grid-cols-5{grid-template-columns:repeat(5,minmax(0,1fr))}.lg\:grid-cols-\[1\.3fr_1fr\]{grid-template-columns:1.3fr 1fr}.lg\:px-6{padding-inline:calc(var(--spacing)*6)}.lg\:pt-28{padding-top:calc(var(--spacing)*28)}}}:root{--bg:#fff7f1;--panel:#fff;--text:#3a2e2a;--muted:#8b7c76;--accent:#e79ab3;--accent-strong:#d780a0;--accent-soft:#fde6ee;--accent-rgb:231,154,179;--accent-strong-rgb:215,128,160;--accent-soft-rgb:253,230,238;--cta:var(--accent);--cta-strong:var(--accent-strong);--cta-rgb:var(--accent-rgb);--cta-strong-rgb:var(--accent-strong-rgb);--border:#f1e2dc;--shadow:0 14px 30px rgba(var(--accent-rgb),.18),0 6px 12px rgba(var(--cta-rgb),.16);--bg-top:#fff8f4;--bg-bottom:#f6f7fb;--hero-start:#fffffffa;--hero-end:#ffeef4eb;--reward-duration:2.4s;--reward-jump-duration:.7s;--reward-feed-duration:1s;--levelup-duration:3.2s;--levelup-spark-duration:2.8s}html{-moz-text-size-adjust:100%;text-size-adjust:100%}:root[data-page=dashboard]{scrollbar-width:thin;scrollbar-color:rgba(var(--accent-rgb),.35)transparent}:root[data-page=dashboard]::-webkit-scrollbar{width:8px;height:8px}:root[data-page=dashboard]::-webkit-scrollbar-track{background:0 0}:root[data-page=dashboard]::-webkit-scrollbar-thumb{background-color:rgba(var(--accent-rgb),.35);background-clip:content-box;border:2px solid #0000;border-radius:999px}:root[data-page=dashboard]::-webkit-scrollbar-thumb:hover{background-color:rgba(var(--accent-rgb),.5)}:root[data-page=dashboard] body{scrollbar-width:thin;scrollbar-color:rgba(var(--accent-rgb),.35)transparent}:root[data-page=dashboard] body::-webkit-scrollbar{width:8px;height:8px}:root[data-page=dashboard] body::-webkit-scrollbar-track{background:0 0}:root[data-page=dashboard] body::-webkit-scrollbar-thumb{background-color:rgba(var(--accent-rgb),.35);background-clip:content-box;border:2px solid #0000;border-radius:999px}:root[data-page=dashboard] body::-webkit-scrollbar-thumb:hover{background-color:rgba(var(--accent-rgb),.5)}:root[data-loading=on]{touch-action:none;height:100%;overflow:hidden}:root[data-loading=on] body{height:100%;overflow:hidden}:root[data-classroom=on][data-page=dashboard]{--reward-duration:2.8s;--reward-jump-duration:.8s;--reward-feed-duration:1.1s;--levelup-duration:3.6s;--levelup-spark-duration:3.2s}:root[data-classroom=on][data-page=dashboard] .card-island-link,:root[data-classroom=on][data-page=dashboard] .card-hover-tip{display:none!important}:root[data-classroom=on][data-page=dashboard] .progress-line{opacity:.55}:root[data-classroom=on][data-page=dashboard] .nav-glass nav,:root[data-classroom=on][data-page=dashboard] .classroom-icons,:root[data-classroom=on][data-page=dashboard] .classroom-actions>:not(.classroom-exit){display:none}:root[data-classroom=on][data-page=dashboard] .classroom-exit{display:inline-flex}:root[data-classroom=on][data-page=dashboard] .classroom-search,:root[data-classroom=on][data-page=dashboard] .classroom-marquee{display:none}:root[data-classroom=on][data-page=dashboard] .app-header{display:none!important}:root[data-classroom=on][data-page=dashboard] .app-shell{padding-left:16px;padding-right:16px;max-width:none!important;padding-top:20px!important}:root[data-page=dashboard] .app-header{display:none!important}:root[data-page=dashboard] .app-shell{padding-left:20px;padding-right:20px;max-width:none!important;padding-top:20px!important}:root[data-page=dashboard] .classroom-bar{top:20px}[data-theme=forest]{--bg:#f1f7f3;--panel:#fff;--text:#24352b;--muted:#5f7a6a;--accent:#3baa77;--accent-strong:#2f9464;--accent-soft:#dff4ea;--accent-rgb:59,170,119;--accent-strong-rgb:47,148,100;--accent-soft-rgb:223,244,234;--border:#ddeee5;--shadow:0 12px 28px rgba(var(--accent-rgb),.14);--bg-top:#f3faf6;--bg-bottom:#eef5f1;--hero-start:#fffffffa;--hero-end:#dff4eac7}[data-theme=ocean]{--bg:#f1f7fa;--panel:#fff;--text:#123041;--muted:#5c7a88;--accent:#3ba9c5;--accent-strong:#2793b2;--accent-soft:#d7f0f6;--accent-rgb:59,169,197;--accent-strong-rgb:39,147,178;--accent-soft-rgb:215,240,246;--border:#ddecf3;--shadow:0 12px 28px rgba(var(--accent-rgb),.14);--bg-top:#f2f8fb;--bg-bottom:#eef5f9;--hero-start:#fffffffa;--hero-end:#d7f0f6c7}[data-theme=berry]{--bg:#fbf2f7;--panel:#fff;--text:#2e1a2a;--muted:#7a5c6a;--accent:#d96c96;--accent-strong:#c95a86;--accent-soft:#f7d8e6;--accent-rgb:217,108,150;--accent-strong-rgb:201,90,134;--accent-soft-rgb:247,216,230;--border:#f0dbe6;--shadow:0 12px 28px rgba(var(--accent-rgb),.14);--bg-top:#fcf2f7;--bg-bottom:#f7eef4;--hero-start:#fffffffa;--hero-end:#f7d8e6c7}[data-theme=pink]{--bg:#fff5f8;--panel:#fff;--text:#3b2430;--muted:#8c6b78;--accent:#f48fb1;--accent-strong:#ec5f8c;--accent-soft:#fde3ed;--accent-rgb:244,143,177;--accent-strong-rgb:236,95,140;--accent-soft-rgb:253,227,237;--border:#f4d8e3;--shadow:0 12px 28px rgba(var(--accent-rgb),.14);--bg-top:#fff6fa;--bg-bottom:#f9edf2;--hero-start:#fffffffa;--hero-end:#fde3edc7}[data-theme=purple]{--bg:#f8f5ff;--panel:#fff;--text:#2e1f44;--muted:#6b5c7a;--accent:#b388ff;--accent-strong:#8e66ff;--accent-soft:#efe3ff;--accent-rgb:179,136,255;--accent-strong-rgb:142,102,255;--accent-soft-rgb:239,227,255;--border:#e6dcf5;--shadow:0 12px 28px rgba(var(--accent-rgb),.14);--bg-top:#faf7ff;--bg-bottom:#f1edff;--hero-start:#fffffffa;--hero-end:#efe3ffc7}[data-theme=indigo]{--bg:#f4f6ff;--panel:#fff;--text:#1f2544;--muted:#58607a;--accent:#8c9eff;--accent-strong:#5c6bc0;--accent-soft:#e3e8ff;--accent-rgb:140,158,255;--accent-strong-rgb:92,107,192;--accent-soft-rgb:227,232,255;--border:#dbe2f5;--shadow:0 12px 28px rgba(var(--accent-rgb),.14);--bg-top:#f6f7ff;--bg-bottom:#eef1ff;--hero-start:#fffffffa;--hero-end:#e3e8ffc7}[data-theme=sky]{--bg:#f2f8ff;--panel:#fff;--text:#17324a;--muted:#5d7a90;--accent:#64b5f6;--accent-strong:#1e88e5;--accent-soft:#d9efff;--accent-rgb:100,181,246;--accent-strong-rgb:30,136,229;--accent-soft-rgb:217,239,255;--border:#d7e9f8;--shadow:0 12px 28px rgba(var(--accent-rgb),.14);--bg-top:#f4f9ff;--bg-bottom:#edf4ff;--hero-start:#fffffffa;--hero-end:#d9efffc7}[data-theme=cyan]{--bg:#f1fbfd;--panel:#fff;--text:#0f3740;--muted:#5e7f86;--accent:#26c6da;--accent-strong:#00acc1;--accent-soft:#d6f7fb;--accent-rgb:38,198,218;--accent-strong-rgb:0,172,193;--accent-soft-rgb:214,247,251;--border:#d6eef2;--shadow:0 12px 28px rgba(var(--accent-rgb),.14);--bg-top:#f3fcfe;--bg-bottom:#ecf7fb;--hero-start:#fffffffa;--hero-end:#d6f7fbc7}[data-theme=teal]{--bg:#f2fbf9;--panel:#fff;--text:#0f3f38;--muted:#5a7d75;--accent:#4db6ac;--accent-strong:#00897b;--accent-soft:#d7f5f1;--accent-rgb:77,182,172;--accent-strong-rgb:0,137,123;--accent-soft-rgb:215,245,241;--border:#d6ece7;--shadow:0 12px 28px rgba(var(--accent-rgb),.14);--bg-top:#f4fcfa;--bg-bottom:#edf6f4;--hero-start:#fffffffa;--hero-end:#d7f5f1c7}[data-theme=green]{--bg:#f3faf5;--panel:#fff;--text:#1c3c27;--muted:#5f7a67;--accent:#66bb6a;--accent-strong:#43a047;--accent-soft:#ddf5df;--accent-rgb:102,187,106;--accent-strong-rgb:67,160,71;--accent-soft-rgb:221,245,223;--border:#d9eee0;--shadow:0 12px 28px rgba(var(--accent-rgb),.14);--bg-top:#f5fbf7;--bg-bottom:#eef6f1;--hero-start:#fffffffa;--hero-end:#ddf5dfc7}[data-theme=yellow]{--bg:#fffdf3;--panel:#fff;--text:#4b3a12;--muted:#8a7a4b;--accent:#fdd835;--accent-strong:#f9a825;--accent-soft:#fff4c2;--accent-rgb:253,216,53;--accent-strong-rgb:249,168,37;--accent-soft-rgb:255,244,194;--border:#f5e9c4;--shadow:0 12px 28px rgba(var(--accent-rgb),.14);--bg-top:#fffef6;--bg-bottom:#fbf5de;--hero-start:#fffffffa;--hero-end:#fff4c2c7}[data-theme=orange]{--bg:#fff7f0;--panel:#fff;--text:#4a2b12;--muted:#8a6a4b;--accent:#ffb74d;--accent-strong:#fb8c00;--accent-soft:#ffe7c2;--accent-rgb:255,183,77;--accent-strong-rgb:251,140,0;--accent-soft-rgb:255,231,194;--border:#f6e0c6;--shadow:0 12px 28px rgba(var(--accent-rgb),.14);--bg-top:#fff8f3;--bg-bottom:#f9f0e4;--hero-start:#fffffffa;--hero-end:#ffe7c2c7}[data-theme=red]{--bg:#fff4f4;--panel:#fff;--text:#3f1f1f;--muted:#8a5d5d;--accent:#ef5350;--accent-strong:#e53935;--accent-soft:#ffd6d6;--accent-rgb:239,83,80;--accent-strong-rgb:229,57,53;--accent-soft-rgb:255,214,214;--border:#f2d1d1;--shadow:0 12px 28px rgba(var(--accent-rgb),.14);--bg-top:#fff6f6;--bg-bottom:#f7eded;--hero-start:#fffffffa;--hero-end:#ffd6d6c7}*{text-rendering:optimizeLegibility}body{background:linear-gradient(180deg,var(--bg-top)0%,var(--bg-bottom)100%);min-height:100vh;color:var(--text);font-family:var(--font-body),var(--font-body-latin),system-ui,sans-serif;line-height:1.6}a,button{touch-action:manipulation;-webkit-tap-highlight-color:transparent}.app-title{font-family:var(--font-display),var(--font-body),var(--font-body-latin),sans-serif;letter-spacing:.2px}.nav-glass{border:1px solid var(--border);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#ffffffe6}.nav-pill{border:1px solid var(--border);color:var(--text);cursor:pointer;background:#ffffffb3;border-radius:999px;padding:9px 14px;font-weight:600;transition:background .18s,color .18s,box-shadow .18s}.nav-pill:hover{border-color:var(--accent-soft);background:var(--accent-soft);color:var(--accent-strong);box-shadow:0 10px 18px rgba(var(--accent-rgb),.2)}.classroom-bar{border:1px solid var(--border);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);z-index:35;background:#ffffffc7;border-radius:999px;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding:12px 18px;display:flex;position:sticky;top:92px}.classroom-bar--shell{position:relative;top:auto}:root[data-classroom=on][data-page=dashboard] .classroom-bar{box-shadow:none;-webkit-backdrop-filter:none;backdrop-filter:none;z-index:80;background:0 0;border:none;padding:0;display:flex;position:fixed;top:16px;left:auto;right:16px}:root[data-classroom=on][data-page=dashboard] .classroom-left,:root[data-classroom=on][data-page=dashboard] .classroom-honor{display:none}:root[data-classroom=on][data-page=dashboard] .classroom-right{flex:none;min-width:0}:root[data-classroom=on][data-page=dashboard] .classroom-meta{text-align:center}:root[data-classroom=on][data-page=dashboard] .classroom-meta-row{justify-content:center}:root[data-classroom=on][data-page=dashboard] .classroom-meta .text-sm{font-size:18px}:root[data-classroom=on][data-page=dashboard] .classroom-meta .text-xs{font-size:12px}:root[data-classroom=on][data-page=dashboard] .levelup-overlay,:root[data-classroom=on][data-page=dashboard] .levelup-overlay:before{animation-duration:var(--levelup-duration)}:root[data-classroom=on][data-page=dashboard] .levelup-confetti,:root[data-classroom=on][data-page=dashboard] .levelup-particle{animation-duration:var(--levelup-spark-duration)}:root[data-classroom=on][data-page=dashboard] .levelup-pop:before,:root[data-classroom=on][data-page=dashboard] .levelup-pop:after,:root[data-classroom=on][data-page=dashboard] .levelup-pop .levelup-burst,:root[data-classroom=on][data-page=dashboard] .levelup-pop .pet-figure{animation-duration:var(--levelup-duration)}.classroom-search{border:1px solid var(--border);background:#ffffffe6;border-radius:999px;align-items:center;gap:8px;min-width:220px;padding:8px 12px;display:inline-flex}.classroom-search-input{color:var(--text);background:0 0;border:none;outline:none;width:140px;min-width:0;font-size:12px}.classroom-search-input::placeholder{color:var(--muted)}.classroom-meta{min-width:160px}.classroom-meta-row{align-items:center;gap:12px;display:flex}.classroom-meta-text{flex-direction:column;gap:2px;display:flex}.classroom-meta-title{align-items:center;gap:8px;display:flex}.classroom-left{flex-wrap:wrap;flex:320px;align-items:center;gap:14px;min-width:240px;display:flex}.classroom-right{flex:320px;justify-content:flex-end;align-items:center;min-width:240px;display:flex}.classroom-meta-name{color:var(--text);white-space:nowrap;font-size:14px;font-weight:700}.classroom-meta-sub{color:var(--muted);font-size:12px;font-weight:600}.classroom-meta-count{color:var(--text);font-weight:700}.classroom-honor{background:#ffffffb3;border:1px solid #fff9;border-radius:999px;flex:0 320px;justify-content:center;align-items:center;min-width:220px;max-width:360px;height:32px;padding:0 16px;display:inline-flex;position:relative;overflow:hidden;box-shadow:inset 0 1px #fff9}.classroom-honor-item{width:100%;color:var(--muted);white-space:nowrap;text-overflow:ellipsis;animation:honorFadeSingle var(--honor-interval,2.8s)ease-in-out;justify-content:center;align-items:center;padding:0 12px;font-size:12px;font-weight:600;display:inline-flex;overflow:hidden}@keyframes honorFadeSingle{0%{opacity:0;transform:translateY(4px)}12%{opacity:1;transform:translateY(0)}45%{opacity:1}60%{opacity:0;transform:translateY(-4px)}to{opacity:0;transform:translateY(-4px)}}@media (prefers-reduced-motion:reduce){.classroom-honor-item{opacity:1;animation:none;transform:none}.classroom-honor-item:not(:first-child){display:none}}.class-switcher-btn--compact{border:1px solid rgba(var(--accent-rgb),.2);background:var(--accent-soft);padding:3px 10px;font-size:11px}@supports (color:color-mix(in lab, red, red)){.class-switcher-btn--compact{background:color-mix(in srgb,var(--accent-soft)70%,var(--panel))}}.class-switcher-btn--mobile{color:var(--text);box-shadow:none;background:0 0;border:none;margin:0;padding:0;font-size:13px;font-weight:700;line-height:1;margin-left:0!important}.energy-orb{box-sizing:border-box;background:conic-gradient(var(--accent-strong)var(--energy,0%),rgba(var(--accent-rgb),.18)var(--energy,0%));width:44px;height:44px;box-shadow:0 10px 18px rgba(var(--accent-rgb),.18);border-radius:50%;justify-content:center;align-items:center;padding:4px;display:flex}.energy-orb__inner{width:100%;height:100%;color:var(--accent-strong);box-shadow:inset 0 0 10px rgba(var(--accent-rgb),.2);background:#fffffff5;border-radius:50%;justify-content:center;align-items:center;font-size:12px;font-weight:700;display:flex}:root[data-classroom=on][data-page=dashboard] .energy-orb{width:56px;height:56px}:root[data-classroom=on][data-page=dashboard] .energy-orb__inner{font-size:13px}.classroom-marquee{white-space:nowrap;flex:1;min-width:180px;overflow:hidden}.classroom-marquee-track{white-space:nowrap;will-change:transform;align-items:center;gap:28px;animation:18s linear infinite marqueeSlide;display:inline-flex}.classroom-marquee-item{color:var(--muted);font-size:12px}.classroom-icons{align-items:center;gap:8px;display:inline-flex}.classroom-actions{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:8px;display:inline-flex}.pet-swap-trigger{border:1px solid rgba(var(--accent-rgb),.22);width:26px;height:26px;color:var(--accent-strong);opacity:.45;z-index:5;background:#ffffffd9;border-radius:999px;grid-area:1/1;justify-content:center;place-self:start;align-items:center;transition:opacity .15s,transform .15s,box-shadow .15s;display:inline-flex;position:relative}.pet-swap-trigger:hover{opacity:.9;box-shadow:0 8px 14px rgba(var(--accent-rgb),.18);transform:translateY(-1px)}.classroom-exit{display:none}.nav-action{border:1px solid rgba(var(--accent-rgb),.12);color:var(--muted);background:#fff9;border-radius:999px;align-items:center;gap:6px;padding:8px 12px;font-size:12px;font-weight:600;transition:background .16s,color .16s,border-color .16s,box-shadow .16s;display:inline-flex}.nav-action:hover,.nav-action.is-active{color:var(--text);border-color:rgba(var(--accent-rgb),.3);box-shadow:0 10px 18px rgba(var(--accent-rgb),.12);background:#ffffffe6}.nav-action--ghost{background:#ffffff8c}.nav-action--ghost:hover,.nav-action--ghost.is-active{color:var(--accent-strong);background:#ffffffeb}.nav-action--primary{background:var(--accent);border-color:var(--accent)}@supports (color:color-mix(in lab, red, red)){.nav-action--primary{border-color:color-mix(in srgb,var(--accent)60%,var(--border))}}.nav-action--primary{color:#fff;box-shadow:0 12px 20px rgba(var(--accent-rgb),.25)}.nav-action--primary:hover,.nav-action--primary.is-active{background:var(--accent-strong);color:#fff;border-color:var(--accent-strong)}@supports (color:color-mix(in lab, red, red)){.nav-action--primary:hover,.nav-action--primary.is-active{border-color:color-mix(in srgb,var(--accent-strong)70%,var(--border))}}.nav-more{position:relative}.nav-more-panel{border:1px solid var(--border);min-width:200px;box-shadow:0 18px 36px rgba(var(--accent-rgb),.22);z-index:50;background:#fffffff5;border-radius:18px;gap:8px;padding:12px;display:grid;position:absolute;top:calc(100% + 10px);right:0}details.nav-more{position:relative}details.nav-more>summary{cursor:pointer;list-style:none}details.nav-more>summary::-webkit-details-marker{display:none}details.nav-more .nav-more-panel{display:none}details.nav-more[open] .nav-more-panel{display:grid}.nav-more-item{border:1px solid var(--border);color:var(--text);background:#ffffffe6;border-radius:12px;align-items:center;gap:8px;padding:8px 10px;font-size:12px;font-weight:600;transition:background .15s,color .15s,border-color .15s;display:inline-flex}.nav-more-item:hover{background:var(--accent-soft);color:var(--accent-strong);border-color:var(--accent)}@supports (color:color-mix(in lab, red, red)){.nav-more-item:hover{border-color:color-mix(in srgb,var(--accent)40%,var(--border))}}.nav-more-item.is-disabled{opacity:.5;cursor:not-allowed;pointer-events:none;background:#ffffffbf}.nav-more-note{color:var(--muted);margin-left:auto;font-size:10px}.nav-card-disabled{opacity:.55;cursor:not-allowed}.nav-more-toggle{justify-content:space-between;width:100%}.nav-more-sfx{border:1px solid var(--border);color:var(--text);background:#ffffffe6;border-radius:12px;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:8px;padding:8px 10px;font-size:12px;display:grid}.nav-more-sfx.is-disabled{opacity:.55}.nav-more-sfx-label,.nav-more-sfx-value{color:var(--muted);white-space:nowrap;font-size:11px;font-weight:700}.nav-more-sfx-range{width:100%;accent-color:var(--accent)}.icon-btn{border:1px solid var(--border);width:32px;height:32px;color:var(--accent-strong);background:#fffc;border-radius:10px;justify-content:center;align-items:center;transition:transform .16s,box-shadow .16s,background .16s;display:inline-flex}.icon-btn:hover{background:var(--accent-soft);box-shadow:0 10px 18px rgba(var(--accent-rgb),.22);transform:translateY(-1px)}@keyframes marqueeSlide{0%{transform:translate(0)}to{transform:translate(-50%)}}@media (prefers-reduced-motion:reduce){.classroom-marquee-track{animation:none}}@media (max-width:640px){.classroom-bar{top:8px;top:calc(env(safe-area-inset-top,0px) + 8px);z-index:45;min-height:72px;box-shadow:0 14px 26px rgba(var(--accent-rgb),.2);border-radius:18px;grid-template:"meta search""honor actions"/1fr 1fr;align-items:center;gap:6px 10px;padding:8px 10px;display:grid;position:sticky}.classroom-icons{justify-content:flex-end;width:100%}.classroom-honor{border-radius:999px;grid-area:honor;min-width:0;max-width:none;height:24px;padding:0 10px;display:flex}.classroom-right{flex:none;grid-area:actions;justify-content:flex-end;align-self:center;width:auto;min-width:0;display:flex}.classroom-actions{flex-wrap:nowrap;justify-content:flex-end;gap:6px;width:auto}.classroom-actions .nav-action{border-radius:10px;justify-content:center;width:32px;height:32px;padding:0}.classroom-actions .nav-action span,.nav-action--leaderboard{display:none}.nav-more-panel{min-width:190px}.nav-more-item--lucky,.nav-more-item--codes,.nav-more-item--mode{display:none}.nav-more-item--leaderboard{display:flex}.classroom-meta-row{align-items:center;gap:8px}.classroom-meta-title{align-items:center;gap:6px}.classroom-meta-name{font-size:13px}.classroom-left{min-width:0;display:contents}.classroom-meta{grid-area:meta;min-width:0}.classroom-meta-sub{display:none}.energy-orb{width:34px;height:34px}.energy-orb__inner{font-size:10px}.classroom-search{background:#fff;grid-area:search;gap:6px;width:100%;min-width:0;height:32px;padding:6px 10px}.classroom-search-input{font-size:11px}.pet-grid{gap:12px 10px;margin:0}.pet-grid>.pet-card{box-sizing:border-box;width:100%;min-width:0;margin:0}.pet-grid>.pet-grid-sentinel{width:100%;height:1px;margin:0}.grid-compact{gap:12px 10px}.pet-card{box-shadow:0 10px 18px rgba(var(--accent-rgb),.14),0 2px 5px #0f172a0a}.card-island{aspect-ratio:3/4.2;min-height:auto;padding:clamp(6px,2.2vw,10px) clamp(8px,2.6vw,12px) clamp(8px,2.4vw,12px)}.card-island-name{max-width:clamp(92px,38vw,128px);min-height:auto;font-size:clamp(16px,4.2vw,22px)}.card-island-petname{max-width:clamp(70px,30vw,96px);font-size:clamp(10px,2.4vw,12px)}.card-island-level{padding:2px 6px;font-size:clamp(10px,2.4vw,12px)}.card-island-pet{padding-top:clamp(6px,2vw,12px)}.pet-ill-island{width:clamp(120px,70%,200px)}.pet-ill-island .pet-figure{transform:translateY(-2px)scale(clamp(.92,.02vw + .92,1))}.energy-bar{width:68%;height:clamp(6px,1.6vw,10px)}.progress-stack{gap:clamp(3px,1vw,5px);min-height:clamp(22px,6vw,28px)}.classroom-search-input{width:100%}.mobile-nav-label{display:none}.mobile-nav-bar{padding:6px}.mobile-nav-bar svg{width:20px;height:20px}.mobile-more-sheet{border-radius:24px;padding:16px}.mobile-more-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.mobile-more-card{text-align:center;flex-direction:column;align-items:center;gap:6px;padding:10px}.mobile-more-icon{border-radius:12px;width:36px;height:36px}.mobile-more-label{font-size:12px}.nav-more-note{margin-left:0;font-size:10px}}.card{background:var(--panel);border:1px solid var(--border);box-shadow:var(--shadow);border-radius:20px}.grid-compact{gap:12px}.pet-grid-wrap{position:relative}.pet-grid{will-change:opacity,transform;grid-template-columns:repeat(var(--pet-grid-cols,4),minmax(0,1fr));transition:opacity .22s,transform .22s,filter .22s;display:grid}.pet-grid--loading{opacity:0;pointer-events:none;filter:blur(8px);transform:translateY(10px)scale(.98)}.pet-grid-loading{z-index:20;border:1px solid var(--border);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:linear-gradient(#fffffff2,#ffffffd1);border-radius:28px;flex-direction:column;gap:16px;padding:16px;display:flex;position:absolute;inset:0}.pet-grid-loading-head{justify-content:space-between;align-items:center;gap:12px;display:flex}.pet-grid-loading-title{color:var(--text);font-size:14px;font-weight:700}.pet-grid-loading-sub{color:var(--muted);font-size:12px}.pet-grid-loading-pulse{border:2px solid rgba(var(--accent-rgb),.25);border-top-color:var(--accent-strong);width:34px;height:34px;box-shadow:inset 0 0 10px rgba(var(--accent-rgb),.25);border-radius:50%;animation:.9s linear infinite petGridSpin}.pet-grid-loading-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px;display:grid}.pet-grid-loading-card{border:1px solid rgba(var(--accent-rgb),.16);background:linear-gradient(90deg,rgba(var(--accent-rgb),.14)0%,#ffffffe6 45%,rgba(var(--accent-rgb),.12)100%);background-size:200% 100%;border-radius:22px;min-height:170px;animation:1.2s ease-in-out infinite petGridShimmer}.loading-overlay{z-index:1200;width:100vw;height:100vh;min-height:100dvh;color:var(--text);background:radial-gradient(120% 140% at 10% 10%,rgba(var(--accent-rgb),.2),transparent 55%),radial-gradient(100% 130% at 90% 15%,rgba(var(--accent-strong-rgb),.16),transparent 58%),linear-gradient(180deg,var(--bg-top)0%,var(--bg-bottom)100%);pointer-events:all;place-items:center;padding:24px;transition:opacity .32s,transform .32s;display:grid;position:fixed!important;inset:0!important}.loading-overlay.is-leaving{opacity:0;transform:translateY(-6px)scale(.985)}.loading-card{border:1px solid rgba(var(--accent-rgb),.2);width:min(480px,100vw - 48px);box-shadow:var(--shadow);background:#fffffff0;border-radius:28px;flex-direction:column;align-items:center;gap:14px;margin-inline:auto;padding:26px 26px 22px;display:flex}.loading-ill-wrap{place-items:center;width:160px;height:160px;display:grid;position:relative}.loading-ill-placeholder{background:radial-gradient(circle at 30% 30%,#fffffff2,transparent 55%),radial-gradient(circle at 70% 20%,rgba(var(--accent-rgb),.28),transparent 60%),linear-gradient(145deg,rgba(var(--accent-rgb),.18),#ffffffe6);box-shadow:0 18px 34px rgba(var(--accent-rgb),.18);opacity:1;border-radius:30px;transition:opacity .3s;animation:2.2s ease-in-out infinite loadingFloat;position:absolute;inset:0}.loading-ill-wrap.is-ready .loading-ill-placeholder{opacity:0}.loading-ill{object-fit:contain;opacity:0;width:100%;height:100%;filter:drop-shadow(0 16px 24px rgba(var(--accent-rgb),.22));transition:opacity .35s,transform .35s;transform:translateY(6px)scale(.98)}.loading-ill.is-ready{opacity:1;transform:translateY(0)scale(1)}.loading-title{letter-spacing:.02em;font-size:16px;font-weight:700}.loading-subtitle{color:var(--muted);margin-top:-6px;font-size:12px}.loading-bar{background:rgba(var(--accent-rgb),.15);border-radius:999px;width:min(240px,70%);height:8px;position:relative;overflow:hidden}.loading-bar-fill{border-radius:inherit;background:linear-gradient(90deg,rgba(var(--accent-strong-rgb),.9),#ffffffe6,rgba(var(--accent-strong-rgb),.9));width:0%;height:100%;transition:width .18s;display:block}.pet-grid-sentinel{width:100%;height:1px}.pet-grid--manual{grid-template-columns:repeat(var(--pet-grid-cols,4),minmax(0,1fr))}:root[data-classroom=on][data-page=dashboard] .pet-grid,:root[data-classroom=on][data-page=dashboard] .pet-grid--manual{grid-template-columns:repeat(var(--pet-grid-cols,6),minmax(0,1fr))!important}@media (max-width:768px){.pet-grid--manual{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width:640px){.pet-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.pet-grid--manual{grid-template-columns:repeat(2,minmax(0,1fr))!important}}@media (max-width:900px){:root[data-classroom=on][data-page=dashboard] .pet-grid,:root[data-classroom=on][data-page=dashboard] .pet-grid--manual{grid-template-columns:repeat(2,minmax(0,1fr))!important}}@media (max-width:640px){.loading-card{border-radius:24px;padding:22px 20px 20px}.loading-ill-wrap{width:140px;height:140px}}@media (prefers-reduced-motion:reduce){.pet-grid-loading-card,.pet-grid-loading-pulse,.loading-bar-fill,.loading-ill-placeholder{animation:none}}@keyframes petGridShimmer{0%{background-position:0%}to{background-position:200%}}@keyframes petGridSpin{to{transform:rotate(360deg)}}@keyframes loadingFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}@keyframes loadingBarSlide{0%{transform:translate(-40%)}to{transform:translate(140%)}}.shadow-accent-hero{box-shadow:0 18px 35px rgba(var(--accent-rgb),.22)}.shadow-accent-toast{box-shadow:0 12px 25px rgba(var(--accent-rgb),.25)}.soft-card{border:1px solid var(--border);box-shadow:var(--shadow);background:#fffffff0;border-radius:20px}.muted{color:var(--muted)}.chip{background:var(--accent-soft);color:var(--accent-strong);border-radius:999px;align-items:center;gap:4px;padding:2px 8px;font-size:11px;font-weight:600;display:inline-flex}.chip--plus{color:#2f9464;background:#d5f5e5f2;border:1px solid #9ee0c6cc}.chip--minus{color:#c35746;background:#ffe2daf2;border:1px solid #f5c1b4cc}.chip-icon{margin-top:1px;font-size:11px}.rule-card{border-color:rgba(var(--accent-rgb),.18);background:#fffffff2}.rule-card--plus{border-color:#9ee0c6d9;box-shadow:0 10px 20px #54c4901f}.rule-card--minus{border-color:#f5c1b4d9;box-shadow:0 10px 20px #e57c6c1f}.rule-card--plus:after,.rule-card--minus:after{content:"";border-radius:inherit;pointer-events:none;position:absolute;inset:1px}.rule-card--plus:after{background:linear-gradient(#e7f9f199,#fff0);box-shadow:inset 0 0 0 1px #9ee0c673}.rule-card--minus:after{background:linear-gradient(#ffe8e299,#fff0);box-shadow:inset 0 0 0 1px #f5c1b473}.chip--muted{color:var(--muted);box-shadow:inset 0 0 0 1px rgba(var(--accent-rgb),.18);background:#f5f2f6eb;font-weight:500}.btn-primary{background:linear-gradient(135deg,var(--accent),var(--accent-strong));color:#fff;border:2px solid #ffffffe6;border-radius:12px;font-weight:700;transition:transform .18s,box-shadow .18s;box-shadow:0 8px 18px #6d5bd038,inset 0 1px #fff9}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 10px 20px #6d5bd042}.btn-primary:active{transform:translateY(1px);box-shadow:0 6px 12px #6d5bd033,inset 0 2px 6px #00000014}.btn-secondary{border:2px solid var(--border);color:var(--text);background:linear-gradient(#fff,#f7f6ff);border-radius:12px;font-weight:600;box-shadow:0 6px 14px #6d5bd01f}.btn-secondary:active{transform:translateY(1px);box-shadow:0 4px 10px #6d5bd01f}.btn-cta{background:linear-gradient(135deg,var(--cta),var(--cta-strong));color:#fff;box-shadow:0 8px 18px rgba(var(--cta-rgb),.24),inset 0 1px 0 #ffffff8c;border:2px solid #ffffffe6;border-radius:16px;padding:10px 18px;font-weight:700;transition:transform .18s,box-shadow .18s}.btn-cta:hover{box-shadow:0 10px 20px rgba(var(--cta-rgb),.26);transform:translateY(-1px)}.btn-cta:active{box-shadow:0 6px 12px rgba(var(--cta-rgb),.22),inset 0 2px 6px #00000014;transform:translateY(1px)}.hero-card{background:linear-gradient(135deg,var(--hero-start),var(--hero-end));border:1px solid var(--border);box-shadow:var(--shadow);border-radius:28px}.settings-shell{gap:22px;display:grid}.settings-hero{padding:26px;position:relative;overflow:hidden}.settings-hero:before{content:"";background:radial-gradient(circle at 12% 20%,rgba(var(--accent-rgb),.2),transparent 60%),radial-gradient(circle at 88% 0%,rgba(var(--accent-soft-rgb),.7),transparent 55%);opacity:.9;position:absolute;inset:0}.settings-hero:after{content:"";background-image:radial-gradient(rgba(var(--accent-rgb),.12)1px,transparent 1px);opacity:.35;pointer-events:none;background-size:18px 18px;position:absolute;inset:0}.settings-hero-row{z-index:1;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:18px;display:flex;position:relative}.settings-hero-main{gap:6px;max-width:640px;display:grid}.settings-hero-kicker{background:rgba(var(--accent-rgb),.16);color:var(--accent-strong);border-radius:999px;align-items:center;gap:6px;width:fit-content;padding:6px 12px;font-size:12px;font-weight:700;display:inline-flex}.settings-hero-title{color:var(--text);font-size:30px;font-weight:800}.settings-hero-sub{color:var(--muted);font-size:13px}.settings-hero-metrics{flex-wrap:wrap;gap:10px;margin-top:10px;display:flex}.settings-hero-actions{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.settings-draft-note{border:1px solid rgba(var(--accent-rgb),.2);color:var(--muted);background:#ffffffd9;border-radius:999px;align-items:center;gap:6px;padding:6px 12px;font-size:11px;display:inline-flex}.settings-layout{grid-template-columns:minmax(0,240px) minmax(0,1fr);align-items:start;gap:20px;display:grid}.settings-sidebar{align-self:start;gap:16px;display:grid;position:sticky;top:24px}.settings-sidebar-card{border:1px solid rgba(var(--accent-rgb),.18);box-shadow:0 18px 30px rgba(var(--accent-rgb),.14);background:#ffffffeb;border-radius:22px;padding:14px}.settings-sidebar-title{color:var(--accent-strong);margin-bottom:10px;font-size:12px;font-weight:700}.settings-nav{gap:10px;display:grid}.settings-nav-save{text-align:left;width:100%}.settings-nav-save:disabled{opacity:.6;cursor:not-allowed;box-shadow:none;transform:none}.settings-nav-item{color:var(--text);background:#ffffffeb;border:1px solid #0000;border-radius:16px;gap:2px;padding:10px 12px;transition:transform .16s,box-shadow .16s,border-color .16s;display:grid}.settings-nav-item:hover{border-color:rgba(var(--accent-rgb),.35);box-shadow:0 12px 22px rgba(var(--accent-rgb),.18);transform:translateY(-1px)}.settings-nav-label{font-size:13px;font-weight:700}.settings-nav-desc{color:var(--muted);font-size:11px}.settings-summary{gap:10px;display:grid}.settings-summary-item{color:var(--muted);justify-content:space-between;gap:8px;font-size:12px;display:flex}.settings-summary-item strong{color:var(--text);font-weight:700}.settings-main{min-width:0}.settings-grid{gap:18px;display:grid}.settings-panel{border:1px solid rgba(var(--accent-rgb),.18);box-shadow:0 18px 32px rgba(var(--accent-rgb),.12);background:linear-gradient(#fffffffa,#f9f8fceb)}.settings-panel--wide{grid-column:1/-1}.sfx-panel .sfx-master-row{align-items:center}.sfx-panel .sfx-toggle{border-radius:999px;padding:4px 10px;font-size:11px}.sfx-panel .sfx-range{height:6px}.sfx-panel .sfx-event-list{gap:10px}.sfx-panel .sfx-row{border-radius:14px;gap:8px;padding:8px 10px}.sfx-panel .sfx-row label{font-size:12px}.sfx-panel .sfx-select{border-radius:12px;height:34px;padding:0 10px;font-size:12px}.sfx-panel .sfx-preview-btn{border-radius:10px;min-height:30px;padding:4px 10px;font-size:11px}.activation-code-card{border-radius:20px;padding:12px 14px}.activation-code-head{justify-content:space-between;align-items:center;gap:10px;display:flex}.activation-code-meta{min-width:0}.activation-code-value{color:var(--text);font-size:14px;font-weight:700}.activation-code-sub{color:var(--muted);white-space:nowrap;text-overflow:ellipsis;margin-top:2px;font-size:11px;overflow:hidden}.activation-code-form{grid-template-columns:auto 1fr auto;align-items:end;gap:10px;margin-top:8px;display:grid}.activation-code-field{gap:4px;display:grid}.activation-code-input{width:96px;padding:6px 10px}.activation-code-note{color:var(--muted);align-self:center;font-size:11px}.admin-shell{gap:16px;display:grid}.admin-hero{border:1px solid var(--border);background:#fff;border-radius:18px;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;padding:18px 20px;display:flex}.admin-hero--compact{padding:14px 18px}.admin-kicker{color:var(--accent-strong);font-size:11px;font-weight:700}.admin-title{color:var(--text);font-size:20px;font-weight:800}.admin-title--compact{font-size:16px}.admin-sub{color:var(--muted);margin-top:2px;font-size:11px}.admin-stats{flex-wrap:wrap;gap:10px;display:flex}.admin-stat{border:1px solid var(--border);min-width:92px;color:var(--muted);background:#f8f8fce6;border-radius:12px;gap:2px;padding:8px 12px;font-size:11px;display:grid}.admin-stat strong{color:var(--text);font-size:14px}.admin-card{border:1px solid var(--border);background:#fff;border-radius:16px;padding:14px;box-shadow:0 14px 30px #0f172a14}.admin-card--table{padding:10px}.admin-form{grid-template-columns:repeat(2,minmax(0,1fr)) auto;align-items:end;gap:12px;display:grid}.admin-filters{grid-template-columns:repeat(5,minmax(0,1fr)) auto;align-items:end;gap:12px;display:grid}.admin-filter-meta{color:var(--muted);justify-content:space-between;align-items:center;margin-top:8px;font-size:11px;display:flex}.admin-error{color:#b42318;background:#ffe3e1cc;border:1px solid #ffbcb8cc;border-radius:10px;margin-top:8px;padding:8px 10px;font-size:12px}.admin-success{color:#0f766e;background:#ccfbf1cc;border:1px solid #99f6e4d9;border-radius:10px;margin-top:8px;padding:8px 10px;font-size:12px}.admin-field{gap:6px;display:grid}.admin-field--actions{flex-wrap:wrap;justify-content:flex-end;align-items:flex-end;gap:8px;display:flex}.admin-input{border-radius:12px;min-height:36px;padding:6px 10px;font-size:12px}.admin-note{color:var(--muted);font-size:11px}.admin-link{color:var(--muted);cursor:pointer;background:0 0;border:1px dashed #0000;border-radius:10px;padding:6px 8px;font-size:12px;text-decoration:none}.admin-link:hover{color:var(--text);background:rgba(var(--accent-rgb),.08);border-color:rgba(var(--accent-rgb),.2)}.admin-pagination{color:var(--muted);justify-content:space-between;align-items:center;gap:10px;margin-top:10px;font-size:12px;display:flex}.admin-pagination--single{justify-content:flex-start}.admin-page-link{border:1px solid var(--border);color:var(--text);background:#fff;border-radius:10px;align-items:center;gap:6px;padding:6px 12px;font-weight:600;text-decoration:none;display:inline-flex}.admin-page-link.is-disabled,.admin-page-link:disabled{opacity:.4;pointer-events:none}.admin-page-info{color:var(--text);font-weight:600}.admin-table{gap:10px;padding-bottom:4px;display:grid;overflow-x:auto}.admin-table-head,.admin-table-row{grid-template-columns:1.45fr .95fr 1.3fr 1.15fr .95fr 1fr .9fr .9fr;align-items:center;gap:12px;min-width:1160px;display:grid}.admin-table-head{color:var(--muted);padding:0 10px;font-size:11px}.admin-table-row{border:1px solid var(--border);background:#fff;border-radius:14px;padding:10px}.admin-table-row--risk{align-items:start}.admin-cell{min-width:0}.admin-code{color:var(--text);white-space:nowrap;font-family:SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:12px;font-weight:700}.admin-status{gap:2px;display:grid}.admin-status.is-used .admin-status-text{color:#1f9d75}.admin-status.is-expired .admin-status-text{color:#c2410c}.admin-status-text{color:var(--text);font-size:12px;font-weight:700}.admin-status-sub{color:var(--muted);white-space:nowrap;text-overflow:ellipsis;font-size:11px;overflow:hidden}.admin-used-name{color:var(--text);font-size:12px;font-weight:600}.admin-used{gap:2px;display:grid}.admin-actions{justify-content:flex-end;display:flex}.admin-actions--stack{justify-items:end;gap:8px;display:grid}.admin-valid{gap:6px;display:grid}.admin-valid-form{grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:8px;display:grid}.admin-frozen-tag{color:#be123c;background:#fb71851f;border:1px solid #fb718559;border-radius:999px;align-items:center;margin-left:6px;padding:1px 6px;font-size:10px;font-weight:700;display:inline-flex}.admin-metrics,.admin-activity{gap:4px;display:grid}.admin-metric-row{color:var(--muted);justify-content:space-between;align-items:center;gap:8px;font-size:11px;display:flex}.admin-metric-row strong{color:var(--text);font-size:12px;font-weight:700}.admin-risk{justify-items:start;gap:4px;display:grid}.admin-risk-badge{border:1px solid #0000;border-radius:999px;align-items:center;padding:2px 8px;font-size:11px;font-weight:700;display:inline-flex}.admin-risk-badge--low{color:#166534;background:#bbf7d059;border-color:#4ade8073}.admin-risk-badge--medium{color:#92400e;background:#fed7aa66;border-color:#fbbf2480}.admin-risk-badge--high{color:#991b1b;background:#fecaca80;border-color:#f871718c}.admin-risk-score{color:var(--muted);font-size:11px}.admin-detail-panel{gap:12px;display:grid}.admin-detail-head{justify-content:space-between;align-items:center;gap:12px;display:flex}.admin-detail-title{color:var(--text);font-size:15px;font-weight:800}.admin-detail-sub{color:var(--muted);margin-top:4px;font-size:12px}.admin-detail-grid{grid-template-columns:minmax(0,1.1fr) minmax(0,1fr);align-items:start;gap:12px;display:grid}.admin-detail-metrics{gap:8px;display:grid}.admin-detail-item{border:1px solid var(--border);color:var(--muted);background:#f8f8fcbf;border-radius:12px;justify-content:space-between;align-items:center;gap:12px;padding:10px 12px;font-size:12px;display:flex}.admin-detail-item strong{color:var(--text);text-align:right;font-weight:700}.admin-detail-logs{border:1px solid var(--border);background:#ffffffeb;border-radius:12px;padding:10px}.admin-detail-logs-title{color:var(--text);margin-bottom:8px;font-size:12px;font-weight:700}.admin-log-list{gap:6px;display:grid}.admin-log-item{border:1px solid var(--border);background:#f8f8fcb3;border-radius:10px;padding:8px 10px}.admin-log-main{color:var(--text);font-size:12px;font-weight:600}.admin-log-sub{color:var(--muted);margin-top:2px;font-size:11px}.admin-empty{text-align:center;color:var(--muted);border:1px dashed var(--border);background:#f8f8fc99;border-radius:12px;padding:18px;font-size:12px}@media (max-width:900px){.activation-code-form{grid-template-columns:1fr;align-items:start}.activation-code-input{width:100%}.admin-form{grid-template-columns:1fr}.admin-field--actions{justify-content:flex-start}.admin-filters,.admin-valid-form{grid-template-columns:1fr}.admin-actions--stack{justify-items:start}.admin-detail-grid{grid-template-columns:1fr}.admin-pagination{flex-direction:column;align-items:flex-start}}@media (min-width:1024px){.settings-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width:1024px){.settings-layout{grid-template-columns:1fr}.settings-sidebar{position:static}}@media (max-width:640px){.settings-hero-title{font-size:22px}.settings-hero{padding:20px}}.classes-shell{gap:20px;display:grid}.manage-shell{gap:16px;display:grid}.manage-hero{padding:20px 22px}.manage-kicker{color:var(--accent-strong);font-size:11px;font-weight:700}.manage-title{margin-top:4px;font-size:24px;font-weight:800}.manage-sub{color:var(--muted);margin-top:6px;font-size:12px}.manage-tabs-bar{gap:8px;display:grid}.manage-tabs{flex-wrap:wrap;gap:10px;display:flex}.manage-tab{border:1px solid rgba(var(--accent-rgb),.18);color:var(--muted);background:#ffffffb3;border-radius:999px;padding:8px 14px;font-size:12px;font-weight:700;transition:background .16s,color .16s,box-shadow .16s,border-color .16s}.manage-tab.is-active{background:var(--accent);color:#fff;border-color:var(--accent)}@supports (color:color-mix(in lab, red, red)){.manage-tab.is-active{border-color:color-mix(in srgb,var(--accent)70%,var(--border))}}.manage-tab.is-active{box-shadow:0 12px 20px rgba(var(--accent-rgb),.25)}.manage-subtabs{scrollbar-width:none;flex-wrap:nowrap;gap:8px;padding-bottom:4px;display:flex;overflow-x:auto}.manage-subtabs::-webkit-scrollbar{display:none}.manage-subtab{border:1px solid var(--border);color:var(--muted);white-space:nowrap;background:#ffffffd9;border-radius:999px;padding:6px 12px;font-size:12px;font-weight:600;transition:background .16s,color .16s,border-color .16s}.manage-subtab.is-active{background:rgba(var(--accent-rgb),.14);color:var(--accent-strong);border-color:rgba(var(--accent-rgb),.3)}.manage-panels{gap:16px;display:grid}.manage-panel{border:1px solid rgba(var(--accent-rgb),.16);box-shadow:0 16px 30px rgba(var(--accent-rgb),.12);background:#ffffffeb;border-radius:22px;padding:14px}.manage-shell button{min-height:36px}.manage-shell .btn-primary,.manage-shell .btn-secondary{border-radius:12px;padding:8px 14px;font-size:12px}.manage-shell .btn-ghost-pill{padding:6px 10px;font-size:11px}.manage-shell .students-dialog-content,.manage-shell .activity-dialog-content{gap:12px;min-height:auto;box-shadow:none!important;z-index:0!important;background:0 0!important;border:0!important;margin:0!important;padding:0!important;position:static!important}.manage-shell .students-dialog-list,.manage-shell .activity-dialog-list{margin-top:0!important}.manage-shell .students-dialog-tools,.manage-shell .activity-dialog-body{box-shadow:none!important;background:0 0!important;border:0!important;margin-top:0!important;padding:0!important}.manage-shell .students-dialog-list,.manage-shell .activity-dialog-list,.manage-shell .activity-dialog-side{box-shadow:none!important;background:0 0!important;border:0!important;padding:0!important}.manage-shell .students-dialog-tools:before{display:none}.manage-shell input,.manage-shell textarea,.manage-shell .admin-input{border-radius:12px;min-height:36px;padding:6px 10px}.manage-section{gap:16px;display:grid}.manage-students,.manage-activity{gap:14px;display:grid}.manage-students-tools{border:1px solid var(--border);background:#fff;border-radius:20px;gap:12px;padding:12px;display:grid}.manage-students-tools-head{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;display:flex}.manage-students-title{color:var(--text);font-size:15px;font-weight:700}.manage-students-sub{color:var(--muted);margin-top:4px;font-size:12px}.manage-students-tools-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.manage-students-tool-card{border:1px solid rgba(var(--accent-rgb),.14);background:rgba(var(--accent-soft-rgb),.25);border-radius:16px;gap:8px;padding:10px;display:grid}.manage-students-card-title-row{justify-content:space-between;align-items:center;gap:8px;display:flex}.manage-students-card-title{color:var(--text);font-size:13px;font-weight:700}.manage-students-form{gap:8px;display:grid}.manage-students-list{border:1px solid var(--border);background:#fff;border-radius:20px;gap:10px;padding:12px;display:grid}.manage-students-list-head{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;display:flex}.manage-students-list-title{color:var(--text);font-size:14px;font-weight:700}.manage-students-list-actions{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.manage-students-list-body{gap:10px;display:grid}.manage-activity-head{flex-wrap:wrap;justify-content:flex-start;align-items:flex-start;gap:12px;display:flex}.manage-activity-title{color:var(--text);align-items:center;gap:8px;font-size:16px;font-weight:700;display:inline-flex}.manage-activity-icon{background:rgba(var(--accent-rgb),.16);border-radius:10px;justify-content:center;align-items:center;width:30px;height:30px;display:inline-flex}.manage-activity-sub{color:var(--muted);margin-top:4px;font-size:12px}.manage-activity-actions{flex-wrap:wrap;justify-content:flex-start;gap:10px;width:100%;display:flex}.manage-activity-body{grid-template-columns:minmax(0,1fr) 220px;gap:12px;display:grid}.manage-activity-body--single{grid-template-columns:minmax(0,1fr)}.manage-activity-list{border:1px solid var(--border);background:#fff;border-radius:20px;gap:8px;padding:12px;display:grid}.manage-activity-meta{color:var(--muted);font-size:12px}.manage-activity-scroll{gap:6px;display:grid}.manage-activity-side{gap:10px;display:grid}.manage-activity-card{border:1px solid var(--border);background:#fff;border-radius:16px;gap:6px;padding:12px;display:grid}.manage-activity-card-title{color:var(--muted);font-size:12px;font-weight:700}.manage-activity-card-value{color:var(--accent-strong);font-size:20px;font-weight:800}.manage-activity-card-label{color:var(--muted);font-size:11px}.manage-activity-card--hint{background:rgba(var(--accent-soft-rgb),.28)}.manage-activity-card-text{color:var(--text);font-size:12px;line-height:1.5}.manage-section--admin{margin-top:6px}.manage-settings .settings-sidebar{display:none}.manage-settings .settings-layout{grid-template-columns:1fr}.manage-settings .settings-grid{gap:14px}.manage-settings[data-scope=class] #class-security,.manage-settings[data-scope=system] #system-basic,.manage-settings[data-scope=system] #system-layout,.manage-settings[data-scope=system] #system-stages,.manage-settings[data-scope=system] #system-rules,.manage-settings[data-scope=system] #system-themes,.manage-shell[data-primary=class] .manage-settings .settings-panel{display:none}.manage-shell[data-primary=class][data-sub=basic] .manage-settings #class-basic,.manage-shell[data-primary=class][data-sub=basic] .manage-settings #class-sync,.manage-shell[data-primary=class][data-sub=basic] .manage-settings #class-layout,.manage-shell[data-primary=class][data-sub=basic] .manage-settings #class-themes,.manage-shell[data-primary=class][data-sub=basic] .manage-settings #class-audio,.manage-shell[data-primary=class][data-sub=basic] .manage-settings #class-stages,.manage-shell[data-primary=class][data-sub=rules] .manage-settings #class-rules{display:block}.manage-section--classes,.manage-shell[data-primary=class][data-sub=classes] .manage-settings{display:none}.manage-shell[data-primary=class][data-sub=classes] .manage-section--classes{display:grid}.manage-shell[data-primary=system][data-sub=codes] .manage-settings{display:none}.manage-shell[data-primary=system] .manage-settings{display:grid}.manage-shell[data-primary=system] .manage-section--admin{display:none}.manage-shell[data-primary=system][data-sub=codes] .manage-section--admin{display:grid}.manage-shell[data-primary=system] .manage-section--notice,.manage-shell[data-primary=system][data-sub=notice] .manage-settings{display:none}.manage-shell[data-primary=system][data-sub=notice] .manage-section--notice{display:grid}@media (max-width:640px){.manage-hero{padding:16px}.manage-title{font-size:20px}.manage-tabs{gap:8px}.manage-tab{padding:6px 10px;font-size:11px}.manage-subtab{padding:5px 10px;font-size:11px}.manage-panel{padding:10px}}@media (max-width:900px){.manage-students-tools-grid,.manage-activity-body{grid-template-columns:1fr}.manage-activity-side{order:2}}.classes-hero{padding:26px;position:relative;overflow:hidden}.classes-hero:before{content:"";background:radial-gradient(circle at 15% 20%,rgba(var(--accent-rgb),.18),transparent 60%),radial-gradient(circle at 85% 0%,rgba(var(--accent-soft-rgb),.6),transparent 55%);opacity:.9;position:absolute;inset:0}.classes-hero:after{content:"";background-image:radial-gradient(rgba(var(--accent-rgb),.12)1px,transparent 1px);opacity:.35;pointer-events:none;background-size:18px 18px;position:absolute;inset:0}.classes-hero-main{z-index:1;gap:8px;max-width:640px;display:grid;position:relative}.classes-hero-kicker{background:rgba(var(--accent-rgb),.16);color:var(--accent-strong);border-radius:999px;align-items:center;gap:6px;width:fit-content;padding:6px 12px;font-size:12px;font-weight:700;display:inline-flex}.classes-hero-title{font-size:28px;font-weight:800}.classes-hero-sub{color:var(--muted);font-size:13px}.classes-hero-stats{flex-wrap:wrap;gap:10px;margin-top:8px;display:flex}.classes-hero-badge{z-index:1;background:rgba(var(--accent-soft-rgb),.9);width:96px;height:96px;color:var(--accent-strong);border-radius:50%;justify-content:center;align-items:center;font-size:40px;display:flex;position:relative}.classes-grid{gap:18px;display:grid}.classes-panel{border:1px solid rgba(var(--accent-rgb),.18);box-shadow:0 18px 32px rgba(var(--accent-rgb),.12);background:linear-gradient(#fffffffa,#f9f8fceb)}.classes-panel--list{grid-column:1/-1}.class-card{border:1px solid rgba(var(--accent-rgb),.16);background:#ffffffeb;border-radius:20px;gap:10px;padding:14px;transition:transform .16s,box-shadow .16s,border-color .16s;display:grid}.class-card:hover{box-shadow:0 16px 28px rgba(var(--accent-rgb),.16);transform:translateY(-1px)}.class-card.is-active{border-color:rgba(var(--accent-rgb),.4);box-shadow:0 18px 30px rgba(var(--accent-rgb),.2)}.class-card-head{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;display:flex}.class-card-name{font-size:16px;font-weight:700}.class-card-sub{color:var(--muted);font-size:12px}.class-card-form{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.class-card-remove{margin-top:4px}.roster-shell{gap:20px;display:grid}.roster-hero{position:relative;overflow:hidden}.roster-hero-row,.roster-hero-badge{z-index:1;position:relative}.roster-grid{gap:16px;display:grid}.roster-panel{border:1px solid rgba(var(--accent-rgb),.16);box-shadow:0 16px 30px rgba(var(--accent-rgb),.12);background:linear-gradient(#fffffffa,#f8f8fceb)}.roster-panel--list{grid-column:1/-1}.activity-shell{gap:20px;display:grid}.activity-hero{padding:26px;position:relative;overflow:hidden}.activity-hero:before{content:"";background:radial-gradient(circle at 16% 20%,rgba(var(--accent-rgb),.2),transparent 60%),radial-gradient(circle at 80% 0%,rgba(var(--accent-soft-rgb),.65),transparent 55%);opacity:.9;position:absolute;inset:0}.activity-hero:after{content:"";background-image:radial-gradient(rgba(var(--accent-rgb),.12)1px,transparent 1px);opacity:.35;pointer-events:none;background-size:18px 18px;position:absolute;inset:0}.activity-hero-main{z-index:1;gap:6px;max-width:660px;display:grid;position:relative}.activity-hero-kicker{background:rgba(var(--accent-rgb),.16);color:var(--accent-strong);border-radius:999px;align-items:center;gap:6px;width:fit-content;padding:6px 12px;font-size:12px;font-weight:700;display:inline-flex}.activity-hero-title{font-size:28px;font-weight:800}.activity-hero-sub{color:var(--muted);font-size:13px}.activity-hero-stats{flex-wrap:wrap;gap:10px;margin-top:10px;display:flex}.activity-hero-badge{z-index:1;background:rgba(var(--accent-soft-rgb),.9);width:96px;height:96px;color:var(--accent-strong);border-radius:50%;justify-content:center;align-items:center;display:flex;position:relative}.activity-grid{gap:16px;display:grid}.activity-panel{padding:20px}.activity-side{gap:12px;display:grid}.activity-tip-card{padding:16px}.activity-tip-title{color:var(--text);font-size:13px;font-weight:700}.activity-tip-text{color:var(--muted);margin-top:6px;font-size:12px}.activity-row{border:1px solid rgba(var(--accent-rgb),.16);box-shadow:0 10px 20px rgba(var(--accent-rgb),.12)}.activity-dialog-backdrop{z-index:60;-webkit-backdrop-filter:blur(10px);background:#0a0a1259;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.activity-dialog{background:var(--panel);border:1px solid var(--border);border-radius:26px;flex-direction:column;width:min(760px,92vw);max-height:84vh;display:flex;position:relative;overflow:hidden;box-shadow:0 28px 60px #00000040}.activity-dialog-close{border:1px solid rgba(var(--accent-rgb),.2);width:32px;height:32px;color:var(--accent-strong);background:#ffffffbf;border-radius:10px;justify-content:center;align-items:center;transition:transform .16s,box-shadow .16s;display:inline-flex;position:absolute;top:14px;right:14px}.activity-dialog-close:hover{box-shadow:0 8px 16px rgba(var(--accent-rgb),.18);transform:translateY(-1px)}.activity-dialog-content{flex-direction:column;flex:1;gap:14px;min-height:0;padding:18px 20px 20px;display:flex}.activity-dialog-head{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding-right:44px;display:flex}.activity-dialog-title{color:var(--text);align-items:center;gap:8px;font-size:20px;font-weight:800;display:inline-flex}.activity-dialog-icon{background:rgba(var(--accent-rgb),.16);border-radius:12px;justify-content:center;align-items:center;width:34px;height:34px;display:inline-flex}.activity-dialog-sub{color:var(--muted);margin-top:4px;font-size:12px}.activity-dialog-actions{flex-wrap:wrap;gap:10px;margin-right:6px;display:flex}.activity-dialog-body{flex:1;grid-template-columns:minmax(0,1fr) 200px;gap:14px;min-height:0;display:grid}.activity-dialog-list{border:1px solid var(--border);background:#fff;border-radius:18px;flex-direction:column;gap:10px;min-height:0;padding:10px 12px;display:flex}.activity-dialog-list-head{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;display:flex}.activity-dialog-meta{color:var(--muted);font-size:12px}.activity-dialog-scroll{flex:1;gap:6px;min-height:0;padding-right:6px;display:grid;overflow:auto}.activity-dialog-scroll::-webkit-scrollbar{width:6px}.activity-dialog-scroll::-webkit-scrollbar-track{background:0 0}.activity-dialog-scroll::-webkit-scrollbar-thumb{background:rgba(var(--accent-rgb),.22);border-radius:999px}.activity-dialog-side{align-content:start;gap:12px;display:grid}.activity-dialog-card{border:1px solid rgba(var(--accent-rgb),.14);box-shadow:0 10px 18px rgba(var(--accent-rgb),.12);background:#fff;border-radius:16px;padding:12px}.activity-dialog-card-title{color:var(--muted);font-size:12px;font-weight:600}.activity-dialog-card-value{color:var(--accent-strong);font-size:20px;font-weight:800}.activity-dialog-card-label{color:var(--muted);font-size:11px}.activity-dialog-card--hint{background:rgba(var(--accent-soft-rgb),.5);border-color:rgba(var(--accent-rgb),.18)}.activity-dialog-card-text{color:var(--muted);margin-top:6px;font-size:12px;line-height:1.5}@media (max-width:900px){.activity-dialog{width:min(680px,94vw)}.activity-dialog-body{grid-template-columns:minmax(0,1fr)}.activity-dialog-side{order:2}}@media (max-width:640px){.activity-dialog-backdrop{justify-content:stretch;align-items:stretch;padding:0}.activity-dialog{border-radius:0;width:100%;height:100%;max-height:100vh}.activity-dialog-content{gap:10px;padding:12px 14px 16px}.activity-dialog-head{flex-direction:column;align-items:flex-start;gap:6px;padding-right:0}.activity-dialog-title{font-size:18px}.activity-dialog-sub{font-size:11px}.activity-dialog-actions{gap:8px;width:100%;margin-right:0}.activity-action{flex:1;justify-content:center;padding:8px 10px;font-size:12px}.activity-dialog-body{grid-template-columns:1fr;gap:10px}.activity-dialog-side{display:none}.activity-dialog-list{padding:10px}.activity-dialog-meta{font-size:11px}.activity-dialog-scroll{gap:8px;padding-right:0}}.students-dialog-backdrop{z-index:60;-webkit-backdrop-filter:blur(10px);background:#0a0a1259;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.students-dialog{background:var(--panel);border:1px solid var(--border);border-radius:26px;flex-direction:column;width:min(980px,94vw);max-height:86vh;display:flex;position:relative;overflow:hidden;box-shadow:0 28px 60px #00000040}.students-dialog-close{border:1px solid rgba(var(--accent-rgb),.2);width:32px;height:32px;color:var(--accent-strong);background:#ffffffbf;border-radius:10px;justify-content:center;align-items:center;transition:transform .16s,box-shadow .16s;display:inline-flex;position:absolute;top:14px;right:14px}.students-dialog-close:hover{box-shadow:0 8px 16px rgba(var(--accent-rgb),.18);transform:translateY(-1px)}.students-dialog-content{flex-direction:column;flex:1;gap:10px;min-height:0;padding:16px 18px 18px;display:flex}.students-dialog-head{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;display:flex}.students-dialog-title{color:var(--text);font-size:20px;font-weight:800}.students-dialog-sub{color:var(--muted);margin-top:4px;font-size:12px}.students-dialog-tools{border:1px solid rgba(var(--accent-rgb),.18);background:rgba(var(--accent-soft-rgb),.28);border-radius:20px;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:14px;padding:10px;display:grid;position:relative}.students-tool-tabs{border:1px solid var(--border);background:#ffffffe6;border-radius:999px;grid-template-columns:repeat(2,minmax(0,1fr));gap:6px;padding:4px;display:none}.students-tool-tab{color:var(--muted);background:0 0;border-radius:999px;padding:6px 10px;font-size:12px;font-weight:700;transition:background .16s,color .16s}.students-tool-tab.is-active{background:var(--accent);color:#fff;box-shadow:0 10px 16px rgba(var(--accent-rgb),.2)}.students-dialog-tools:before{content:"";background:rgba(var(--accent-rgb),.14);width:1px;position:absolute;top:10px;bottom:10px;left:50%}.students-tool-block{gap:8px;display:grid}.students-tool-title{color:var(--text);font-size:13px;font-weight:700}.students-tool-row{justify-content:space-between;align-items:center;gap:8px;display:flex}.students-tool-form{gap:8px;display:grid}.students-dialog-list{border:1px solid rgba(var(--accent-rgb),.18);background:#fff;border-radius:20px;flex-direction:column;flex:1;gap:8px;min-height:0;padding:12px;display:flex}.students-dialog-list-head{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;display:flex}.students-dialog-list-title{color:var(--text);font-size:15px;font-weight:700}.students-dialog-list-actions{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.students-dialog-scroll{flex:1;min-height:0;padding-right:6px;overflow:auto}.students-dialog-scroll::-webkit-scrollbar{width:6px}.students-dialog-scroll::-webkit-scrollbar-track{background:0 0}.students-dialog-scroll::-webkit-scrollbar-thumb{background:rgba(var(--accent-rgb),.22);border-radius:999px}@media (max-width:900px){.students-dialog{width:min(760px,94vw)}.students-dialog-tools{grid-template-columns:minmax(0,1fr)}.students-dialog-tools:before{display:none}}@media (max-width:640px){.students-dialog-backdrop{justify-content:stretch;align-items:stretch;padding:0}.students-dialog{border-radius:0;width:100%;height:100%;max-height:100vh}.students-dialog-content{padding:12px 14px 16px}.students-dialog-close{top:12px;right:12px}.students-dialog-head{gap:6px}.students-dialog-title{font-size:18px}.students-dialog-sub{font-size:11px}.students-dialog-tools{gap:10px;padding:8px}.students-tool-tabs{display:grid}.students-dialog-tools[data-tab=single] .students-tool-block--batch,.students-dialog-tools[data-tab=batch] .students-tool-block--single,.students-tool-row .btn-ghost-pill{display:none}.students-tool-form{gap:6px}.quick-chip{padding:4px 8px;font-size:11px}.students-dialog-list{padding:10px}.students-dialog-list-head{gap:6px}.students-dialog-list-actions{justify-content:space-between;width:100%}.mobile-sheet{border-radius:0;width:100%;height:100%;max-height:100vh}.mobile-sheet .score-modal{flex-direction:column;height:100%;display:flex}.mobile-sheet .score-modal-body,.mobile-sheet .modal-scroll{flex:1;max-height:none;overflow-y:auto}.badge-wall-overlay{justify-content:stretch;align-items:stretch;padding:0}.badge-wall{border-radius:0;width:100%;height:100%;max-height:100vh}.badge-wall-body{padding:12px 14px 16px}}.activity-shell--modal{gap:12px}.activity-modal{gap:14px;display:grid}.activity-modal-toolbar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;display:flex}.activity-modal-count{color:var(--muted);font-size:12px;font-weight:600}.activity-modal-actions{flex-wrap:wrap;gap:10px;display:flex}.activity-action{display:inline-flex}.activity-action .activity-modal-content{flex:1;grid-template-columns:minmax(0,1fr) 220px;gap:14px;min-height:0;display:grid}.activity-action{align-items:center}.activity-action .activity-modal-list{background:rgba(var(--accent-soft-rgb),.28);border:1px solid rgba(var(--accent-rgb),.18);border-radius:20px;gap:10px;min-height:0;padding:14px;display:grid}.activity-action .activity-list-scroll{min-height:0;max-height:100%;padding-right:6px;overflow:auto}.activity-action .activity-list-scroll::-webkit-scrollbar{width:6px}.activity-action .activity-list-scroll::-webkit-scrollbar-track{background:0 0}.activity-action .activity-list-scroll::-webkit-scrollbar-thumb{background:rgba(var(--accent-rgb),.22);border-radius:999px}.activity-action .activity-modal-side{align-content:start;gap:12px;display:grid}.activity-action .activity-side-card{border:1px solid rgba(var(--accent-rgb),.14);box-shadow:0 12px 22px rgba(var(--accent-rgb),.12);background:#fff;border-radius:18px;padding:14px}.activity-action .activity-side-title{color:var(--muted);font-size:12px;font-weight:600}.activity-action .activity-side-value{color:var(--accent-strong);font-size:22px;font-weight:800}.activity-action .activity-side-label{color:var(--muted);font-size:11px}.activity-action .activity-side-card--hint{background:rgba(var(--accent-soft-rgb),.5);border-color:rgba(var(--accent-rgb),.18)}.activity-action .activity-side-text{color:var(--muted);margin-top:6px;font-size:12px;line-height:1.5}.activity-action{background:var(--panel);color:var(--text);border:1px solid #0000;border-radius:14px;justify-content:center;padding:10px 16px;font-size:13px;font-weight:700;transition:transform .15s,box-shadow .15s,background .15s}.activity-action:hover{box-shadow:0 10px 18px rgba(var(--accent-rgb),.14);transform:translateY(-1px)}.activity-action--export{background:rgba(var(--accent-soft-rgb),.65);border-color:rgba(var(--accent-rgb),.2);color:var(--accent-strong)}.activity-action--clear{color:#e1566f;background:#f05a781f;border-color:#f05a784d}.activity-modal-meta{color:var(--muted);font-size:12px}.activity-day{gap:8px;display:grid}.activity-day-label{color:var(--muted);background:#f4f6fb;border-radius:999px;align-self:center;padding:4px 12px;font-size:12px;font-weight:600;position:relative}.activity-day-label:before,.activity-day-label:after{content:"";background:var(--border);width:90px;height:1px;position:absolute;top:50%}.activity-day-label:before{margin-right:12px;right:100%}.activity-day-label:after{margin-left:12px;left:100%}.activity-day-list{gap:8px;display:grid}.activity-item{border-bottom:1px solid var(--border);background:0 0;border-radius:0;align-items:center;gap:10px;padding:10px 6px;display:flex}.activity-item-time{color:#8fa1bf;min-width:54px;font-size:11px}.activity-item-dot{background:#eef2f8;border:1px solid #e1e7f2;border-radius:50%;flex-shrink:0;width:28px;height:28px}.activity-item-summary{white-space:nowrap;flex:1;align-items:center;gap:8px;min-width:0;display:flex;overflow:hidden}.activity-item-name{color:var(--text);font-weight:700}.activity-item-text{color:var(--text)}.activity-item-detail-inline{color:var(--muted);background:#f3f5fa;border-radius:10px;flex-shrink:0;padding:2px 6px;font-size:12px}.activity-day-list .activity-item:last-child{border-bottom:none}.activity-empty{text-align:center;color:var(--muted);padding:24px 0;font-size:13px}.rules-only-shell{gap:18px;display:grid}.rules-only-hero{padding:24px;position:relative;overflow:hidden}.rules-only-hero:before{content:"";background:radial-gradient(circle at 15% 20%,rgba(var(--accent-rgb),.2),transparent 60%),radial-gradient(circle at 85% 0%,rgba(var(--accent-soft-rgb),.65),transparent 55%);opacity:.9;position:absolute;inset:0}.rules-only-hero:after{content:"";background-image:radial-gradient(rgba(var(--accent-rgb),.12)1px,transparent 1px);opacity:.35;pointer-events:none;background-size:18px 18px;position:absolute;inset:0}.rules-only-kicker{z-index:1;background:rgba(var(--accent-rgb),.16);color:var(--accent-strong);border-radius:999px;align-items:center;padding:6px 12px;font-size:12px;font-weight:700;display:inline-flex;position:relative}.rules-only-title{z-index:1;margin-top:8px;font-size:26px;font-weight:800;position:relative}.rules-only-sub{z-index:1;color:var(--muted);margin-top:4px;font-size:13px;position:relative}.rules-only-stats{z-index:1;flex-wrap:wrap;gap:10px;margin-top:12px;display:flex;position:relative}.rules-panel{border:1px solid rgba(var(--accent-rgb),.18);box-shadow:0 18px 32px rgba(var(--accent-rgb),.12);background:linear-gradient(#fffffffa,#f9f8fceb)}.rules-focus{border-color:rgba(var(--accent-rgb),.45);box-shadow:0 0 0 2px rgba(var(--accent-rgb),.2);position:relative}@media (min-width:1024px){.classes-grid{grid-template-columns:minmax(260px,360px) minmax(0,1fr)}.roster-grid{grid-template-columns:minmax(0,1.1fr) minmax(0,1fr)}.activity-grid{grid-template-columns:minmax(0,1fr) minmax(0,280px);align-items:start}}@media (max-width:640px){.classes-hero-title,.activity-hero-title{font-size:22px}.classes-hero,.activity-hero{padding:20px}}.stat-card{border:1px solid var(--border);background:#ffffffe6;border-radius:14px;padding:8px 12px;font-size:12px;font-weight:600}.leaderboard-shell{flex-direction:column;gap:26px;display:flex}.leaderboard-hero{background:radial-gradient(circle at 12% 18%,rgba(var(--accent-rgb),.18),transparent 55%),radial-gradient(circle at 85% 0%,rgba(var(--accent-rgb),.2),transparent 46%),linear-gradient(135deg,var(--hero-start),var(--hero-end));border:1px solid var(--border);box-shadow:0 22px 45px rgba(var(--accent-rgb),.18);border-radius:30px;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:24px;padding:28px 30px;display:flex;position:relative;overflow:hidden}.leaderboard-hero:before{content:"";background:radial-gradient(circle,rgba(var(--accent-rgb),.2),rgba(var(--accent-rgb),0)70%);opacity:.85;border-radius:50%;width:280px;height:280px;position:absolute;top:-110px;right:-90px}.leaderboard-hero:after{content:"";background:radial-gradient(circle,rgba(var(--accent-rgb),.14),rgba(var(--accent-rgb),0)72%);opacity:.8;border-radius:50%;width:320px;height:320px;position:absolute;bottom:-130px;left:-130px}.leaderboard-hero__content{z-index:1;max-width:680px;position:relative}.leaderboard-kicker{background:rgba(var(--accent-rgb),.14);color:var(--accent-strong);border-radius:999px;align-items:center;gap:6px;padding:6px 12px;font-size:12px;font-weight:700;display:inline-flex}.leaderboard-title{color:var(--text);margin-top:10px;font-size:30px;font-weight:800}.leaderboard-desc{color:var(--muted);margin-top:6px;font-size:13px}.leaderboard-stats{flex-wrap:wrap;gap:10px;margin-top:16px;display:flex}.leaderboard-stat{border:1px solid rgba(var(--accent-rgb),.2);color:var(--text);background:#ffffffeb;border-radius:14px;align-items:center;gap:8px;padding:8px 12px;font-size:12px;font-weight:600;display:inline-flex}.leaderboard-stat strong{color:var(--accent-strong);font-size:14px;font-weight:700}.leaderboard-hero__badge{z-index:1;background:radial-gradient(circle at 30% 30%,#fff,rgba(var(--accent-rgb),.16));width:112px;height:112px;color:var(--accent-strong);border:1px solid rgba(var(--accent-rgb),.2);box-shadow:0 18px 32px rgba(var(--accent-rgb),.26);border-radius:50%;justify-content:center;align-items:center;display:flex;position:relative}.leaderboard-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;display:grid}.leaderboard-grid--single{grid-template-columns:minmax(0,1fr)}.leaderboard-tabs{flex-wrap:wrap;gap:8px;display:flex}.leaderboard-tab{border:1px solid rgba(var(--accent-rgb),.22);min-width:90px;color:var(--muted);background:#ffffffdb;border-radius:999px;justify-content:center;align-items:center;padding:7px 14px;font-size:12px;font-weight:700;transition:background .18s,color .18s,border-color .18s,transform .18s;display:inline-flex}.leaderboard-tab:hover{background:rgba(var(--accent-rgb),.12);color:var(--accent-strong);transform:translateY(-1px)}.leaderboard-tab.is-active{color:var(--accent-strong);background:rgba(var(--accent-rgb),.18);border-color:rgba(var(--accent-rgb),.34);box-shadow:0 10px 16px rgba(var(--accent-rgb),.12)}.leaderboard-week-toggle{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;margin-bottom:12px;display:flex}.leaderboard-week-toggle__label{color:var(--muted);font-size:12px;font-weight:700}.leaderboard-week-toggle__actions{align-items:center;gap:6px;display:inline-flex}.leaderboard-week-toggle__btn{border:1px solid rgba(var(--lb-accent-rgb),.22);color:var(--muted);background:#ffffffe6;border-radius:999px;padding:6px 12px;font-size:12px;font-weight:700;transition:all .16s}.leaderboard-week-toggle__btn.is-active{color:var(--lb-accent);border-color:rgba(var(--lb-accent-rgb),.36);background:rgba(var(--lb-accent-rgb),.16)}.leaderboard-card{--lb-accent-rgb:var(--accent-rgb);--lb-accent:var(--accent-strong);--lb-soft:rgba(var(--accent-rgb),.16);border:1px solid rgba(var(--lb-accent-rgb),.18);box-shadow:0 18px 34px rgba(var(--lb-accent-rgb),.14);background:#fffffff0;border-radius:26px;padding:18px;position:relative;overflow:hidden}.leaderboard-card:before{content:"";background:radial-gradient(circle,var(--lb-soft),transparent 70%);opacity:.8;pointer-events:none;border-radius:50%;width:200px;height:200px;position:absolute;top:-50px;right:-60px}.leaderboard-card--today{--lb-accent-rgb:var(--cta-rgb);--lb-accent:var(--cta-strong);--lb-soft:rgba(var(--cta-rgb),.18)}.leaderboard-card--total{--lb-accent-rgb:var(--accent-rgb);--lb-accent:var(--accent-strong);--lb-soft:rgba(var(--accent-rgb),.18)}.leaderboard-card--group{--lb-accent-rgb:86,165,132;--lb-accent:#2f8f67;--lb-soft:#56a58433}.leaderboard-card--week{--lb-accent-rgb:92,141,219;--lb-accent:#3d63b4;--lb-soft:#5c8ddb33}.leaderboard-card__header{z-index:1;justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px;display:flex;position:relative}.leaderboard-card__title{color:var(--text);font-size:20px;font-weight:800}.leaderboard-card__subtitle{color:var(--muted);margin-top:4px;font-size:12px}.leaderboard-chip{background:rgba(var(--lb-accent-rgb),.18);color:var(--lb-accent);border:1px solid rgba(var(--lb-accent-rgb),.26);z-index:1;border-radius:999px;align-items:center;gap:6px;padding:6px 12px;font-size:12px;font-weight:700;display:inline-flex;position:relative}.leaderboard-chip--today{background:rgba(var(--cta-rgb),.18);color:var(--cta-strong);border-color:rgba(var(--cta-rgb),.35)}.leaderboard-chip--total{background:rgba(var(--accent-rgb),.18);color:var(--accent-strong);border-color:rgba(var(--accent-rgb),.32)}.leaderboard-list{z-index:1;flex-direction:column;gap:10px;display:flex;position:relative}.leaderboard-row{border:1px solid rgba(var(--lb-accent-rgb),.18);box-shadow:inset 0 0 0 1px #ffffffb3,0 8px 16px rgba(var(--lb-accent-rgb),.08);animation:.45s both leaderboardRise;animation-delay:var(--row-delay,0s);background:#fffffff0;border-radius:18px;grid-template-columns:auto 1fr auto;align-items:center;gap:12px;padding:10px 14px;display:grid;position:relative;overflow:hidden}.leaderboard-row.is-top{background:linear-gradient(90deg,rgba(var(--lb-accent-rgb),.22),#fffffffa);border-color:rgba(var(--lb-accent-rgb),.28)}.leaderboard-row.is-top-1{background:linear-gradient(120deg,#fff4d2f2,#fffffffa);border-color:#e7be6099;box-shadow:inset 0 0 0 1px #ffffffb3,0 14px 26px #e7be602e}.leaderboard-row.is-top-1:before{content:"";opacity:.8;pointer-events:none;border:1px solid #e7be6099;border-radius:16px;animation:2.6s ease-in-out infinite leaderboardGlow;position:absolute;inset:1px;box-shadow:0 0 0 1px #e7be602e}.leaderboard-row.is-top:after{content:"";opacity:.75;pointer-events:none;background:linear-gradient(115deg,#0000 20%,#ffffffa6 46%,#0000 70%);animation:2.4s ease-out leaderboardShine;position:absolute;inset:-40%}.leaderboard-row.is-top-2{background:linear-gradient(120deg,#eceff5f5,#fffffffa);border-color:#b4becd8c}.leaderboard-row.is-top-3{background:linear-gradient(120deg,#f8e8dcf5,#fffffffa);border-color:#cd9a7680}.leaderboard-row>*{z-index:1;position:relative}.leaderboard-rank{background:rgba(var(--lb-accent-rgb),.16);min-width:44px;height:28px;color:var(--lb-accent);border-radius:999px;justify-content:center;align-items:center;padding:0 10px;font-size:12px;font-weight:700;display:inline-flex}.leaderboard-rank.is-icon{background:rgba(var(--lb-accent-rgb),.2);min-width:40px;height:30px;font-size:16px;font-weight:600}.leaderboard-row.is-top .leaderboard-rank{background:rgba(var(--lb-accent-rgb),.26)}.leaderboard-rank--medal{background:linear-gradient(145deg,#ffffffd9,#fff6);border-radius:12px;min-width:38px;height:32px;font-size:16px;box-shadow:inset 0 0 0 1px #fff9,0 8px 14px #00000014}.leaderboard-rank--medal.rank-1{color:#a56512;background:linear-gradient(145deg,#fff6d6,#ffe7a3)}.leaderboard-rank--medal.rank-2{color:#6f7b8a;background:linear-gradient(145deg,#f3f6fb,#dfe6f0)}.leaderboard-rank--medal.rank-3{color:#8a4f22;background:linear-gradient(145deg,#f6e2d3,#e8c1a3)}.leaderboard-name{color:var(--text);font-weight:700}@supports (color:color-mix(in lab, red, red)){.leaderboard-name{color:color-mix(in srgb,var(--text)70%,var(--lb-accent)30%)}}.leaderboard-name-wrap{align-items:center;gap:8px;display:inline-flex}.leaderboard-metric{border:1px solid rgba(var(--lb-accent-rgb),.22);color:var(--lb-accent);background:#fffffff5;border-radius:999px;align-items:center;gap:6px;padding:6px 12px;font-size:12px;font-weight:700;display:inline-flex}.leaderboard-metric__label{color:var(--muted);font-size:11px;font-weight:600}.leaderboard-metric-group{align-items:center;gap:8px;display:inline-flex}.leaderboard-metric--primary{background:rgba(var(--lb-accent-rgb),.14);border-color:rgba(var(--lb-accent-rgb),.3);color:var(--lb-accent)}.leaderboard-metric--secondary{border-color:rgba(var(--lb-accent-rgb),.18);color:var(--lb-accent);opacity:.9;background:#fffffff2;justify-content:center;min-width:72px;padding:5px 8px}.leaderboard-metric__icon{color:#78787899;filter:grayscale();font-size:13px}.leaderboard-metric__value{font-weight:800}.leaderboard-metric__value.is-negative{color:#cf5a4c}.leaderboard-delta{border:1px solid rgba(var(--lb-accent-rgb),.22);background:#fffffff2;border-radius:999px;align-items:center;gap:6px;padding:6px 12px;font-weight:700;display:inline-flex}.leaderboard-delta__label{color:var(--muted);font-size:11px;font-weight:600}.leaderboard-delta__value{color:var(--lb-accent);font-size:12px}.leaderboard-delta.is-plus .leaderboard-delta__value{color:#2f9464}.leaderboard-delta.is-minus .leaderboard-delta__value{color:#d86555}.leaderboard-delta.is-zero .leaderboard-delta__value{color:var(--muted)}.leaderboard-tag{color:#1a6b47;background:#2f946429;border:1px solid #2f946447;border-radius:999px;align-items:center;padding:2px 8px;font-size:10px;font-weight:700;display:inline-flex}@keyframes leaderboardRise{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes leaderboardShine{0%{opacity:0;transform:translate(-60%)rotate(0)}45%{opacity:.6}to{opacity:0;transform:translate(60%)rotate(0)}}@keyframes leaderboardGlow{0%,to{opacity:.6}50%{opacity:1}}@media (prefers-reduced-motion:reduce){.leaderboard-row{animation:none}.leaderboard-row.is-top:after{opacity:.3;animation:none}.leaderboard-row.is-top-1:before{animation:none}}.leaderboard-empty{text-align:center;color:var(--muted);border:1px dashed rgba(var(--lb-accent-rgb),.25);background:#ffffffd9;border-radius:16px;padding:14px;font-size:12px}@media (max-width:980px){.leaderboard-grid{grid-template-columns:1fr}}@media (max-width:900px){.leaderboard-hero{flex-direction:column;align-items:flex-start}.leaderboard-hero__badge{align-self:flex-end}}.pet-card{border:1px solid var(--accent);border-radius:20px}@supports (color:color-mix(in lab, red, red)){.pet-card{border:1px solid color-mix(in srgb,var(--accent)18%,var(--border))}}.pet-card{background:linear-gradient(180deg,#fffffffa,rgba(var(--accent-soft-rgb),.9));box-shadow:0 14px 24px rgba(var(--accent-rgb),.16),0 2px 6px #0f172a0d;transition:transform .18s,box-shadow .18s,border-color .18s;position:relative;overflow:hidden;transform:translateZ(0)}.rule-kind{letter-spacing:.2px;border-radius:999px;justify-content:center;align-items:center;margin-top:2px;padding:2px 10px;font-size:12px;font-weight:700;display:inline-flex}.rule-kind--plus{color:#2f9464;background:#d5f5e5e6;border:1px solid #9ee0c6cc}.rule-kind--minus{color:#c35746;background:#ffe2dae6;border:1px solid #f5c1b4cc}.pet-card:hover{border-color:rgba(var(--accent-rgb),.45);box-shadow:0 18px 30px rgba(var(--accent-rgb),.18);animation-play-state:paused;transform:translateY(0)}.sort-mode-tip{border:1px solid var(--accent);border-radius:999px;align-items:center;gap:8px;padding:8px 12px;display:inline-flex}@supports (color:color-mix(in lab, red, red)){.sort-mode-tip{border:1px solid color-mix(in srgb,var(--accent)30%,var(--border))}}.sort-mode-tip{background:var(--accent-soft)}@supports (color:color-mix(in lab, red, red)){.sort-mode-tip{background:color-mix(in srgb,var(--accent-soft)75%,var(--panel))}}.sort-mode-tip{color:var(--accent-strong);font-size:12px;font-weight:700}.pet-card.sort-mode{cursor:grab;-webkit-user-select:none;user-select:none}.pet-card.sort-mode .pet-swap-trigger,.pet-card.sort-mode .card-data-item--clickable{pointer-events:none}.pet-card.sort-mode.is-dragging{opacity:.42;transform:scale(.98)}.pet-card.sort-mode.is-dragover{border-color:var(--accent-strong)}@supports (color:color-mix(in lab, red, red)){.pet-card.sort-mode.is-dragover{border-color:color-mix(in srgb,var(--accent-strong)65%,var(--border))}}.pet-card.sort-mode.is-dragover{box-shadow:0 20px 32px rgba(var(--accent-rgb),.22)}.pet-card.undo-mode{box-shadow:0 10px 22px #e35a5a2e;border:2px solid #e35a5a!important;border-radius:0!important}.pet-card.undo-mode .pet-swap-trigger,.pet-card.undo-mode .card-data-item--clickable{pointer-events:none}.undo-badge{color:#c74848;z-index:5;background:#ffebebeb;border:1px solid #e35a5a80;border-radius:8px;justify-content:center;align-items:center;width:28px;height:28px;display:inline-flex;position:absolute;top:14px;right:14px;box-shadow:0 8px 14px #e35a5a29}.pet-card.undo-shake{animation:.4s ease-in-out undoShake}.lucky-pick{box-shadow:0 20px 40px rgba(var(--cta-rgb),.3);border-color:var(--cta);animation:1.1s ease-out luckyPulse}@supports (color:color-mix(in lab, red, red)){.lucky-pick{border-color:color-mix(in srgb,var(--cta)55%,var(--panel))}}.reward-pulse{animation:rewardPulse var(--reward-duration)ease-out;box-shadow:0 14px 28px var(--accent),0 0 22px var(--accent)}@supports (color:color-mix(in lab, red, red)){.reward-pulse{box-shadow:0 14px 28px color-mix(in srgb,var(--accent)32%,transparent),0 0 22px color-mix(in srgb,var(--accent)45%,transparent)}}.reward-bubble{background:var(--accent-soft);border-radius:999px;padding:7px 14px;position:absolute;top:32%;left:50%;transform:translate(-50%,-50%)}@supports (color:color-mix(in lab, red, red)){.reward-bubble{background:color-mix(in srgb,var(--accent-soft)70%,var(--panel))}}.reward-bubble{color:var(--accent-strong);z-index:5;opacity:0;box-shadow:0 10px 18px var(--accent);font-size:13px;font-weight:700}@supports (color:color-mix(in lab, red, red)){.reward-bubble{box-shadow:0 10px 18px color-mix(in srgb,var(--accent)30%,transparent)}}.reward-bubble{animation:rewardBubble var(--reward-duration)ease-out;pointer-events:none;animation-fill-mode:both}.reward-bubble--big{letter-spacing:.7px;box-shadow:0 14px 26px var(--accent);padding:10px 20px;font-size:20px}@supports (color:color-mix(in lab, red, red)){.reward-bubble--big{box-shadow:0 14px 26px color-mix(in srgb,var(--accent)38%,transparent)}}.reward-bubble--big{text-shadow:0 3px 8px rgba(var(--accent-rgb),.4)}.reward-bubble--plain{box-shadow:none;color:#f6a63f;text-shadow:0 8px 16px #f6a63f59,0 0 12px #ffd27873;background:0 0;border:none;padding:6px 10px;font-size:24px;animation:.95s cubic-bezier(.22,1,.36,1) rewardBubbleFloat;top:22%}.reward-bubble--plain:before,.reward-bubble--plain:after{display:none}.score-modal{flex-direction:column;display:flex}.score-modal-head{border-bottom:1px solid var(--border);background:radial-gradient(circle at 15% 20%,rgba(var(--accent-rgb),.22),transparent 55%),linear-gradient(135deg,#fffffffa,rgba(var(--accent-soft-rgb),.35));padding:24px 26px 20px;position:relative}.score-modal-head--compact{padding-bottom:16px}.score-modal-kicker{color:var(--accent-strong);font-size:12px;font-weight:700}.score-modal-title{color:var(--text);margin-top:6px;font-size:24px;font-weight:800}.score-modal-sub{color:var(--muted);margin-top:6px;font-size:13px}.score-modal-close{border:1px solid rgba(var(--accent-rgb),.16);width:34px;height:34px;color:var(--muted);border-radius:999px;position:absolute;top:18px;right:18px}@supports (color:color-mix(in lab, red, red)){.score-modal-close{color:color-mix(in srgb,var(--muted)85%,var(--text))}}.score-modal-close{opacity:.72;background:#ffffffa6;justify-content:center;align-items:center;transition:background .15s,transform .15s,opacity .15s;display:inline-flex}.score-modal-close:hover{background:rgba(var(--accent-rgb),.14);opacity:1;transform:translateY(-1px)}.score-modal-body{max-height:75vh;padding:20px 26px 24px;overflow-y:auto}.score-toolbar{flex-wrap:nowrap;align-items:center;gap:12px;display:flex}.score-toolbar .score-search{flex:1;min-width:260px}.score-search{border:1px solid rgba(var(--accent-rgb),.28);box-shadow:0 8px 18px rgba(var(--accent-rgb),.12);background:#fffffff5;border-radius:999px;align-items:center;gap:8px;padding:8px 14px;display:flex}.score-search-input{min-height:34px;box-shadow:none;background:0 0;border:none;padding:0}.score-search-input:focus{box-shadow:none;outline:none}.score-filter{flex-wrap:nowrap;gap:8px;margin-left:auto;display:flex}.score-filter-chip{border:1px solid rgba(var(--accent-rgb),.2);color:var(--muted);background:#ffffffe6;border-radius:999px;padding:6px 12px;font-size:12px;font-weight:700;transition:all .15s}@media (max-width:820px){.score-toolbar{flex-wrap:wrap}.score-filter{flex-wrap:wrap;margin-left:0}}.score-filter-chip.is-active{background:rgba(var(--accent-rgb),.18);color:var(--accent-strong);border-color:rgba(var(--accent-rgb),.35)}.score-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px;margin-top:16px;display:grid}@media (max-width:640px){.score-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin-top:12px}.score-card{border-radius:14px;gap:6px;padding:10px 8px 8px}.score-card-icon{border-radius:12px;width:40px;height:40px;font-size:18px}.score-card-name{font-size:12px}.score-card-value{gap:4px;padding:3px 8px;font-size:10px}}.score-card{border:2px solid rgba(var(--accent-rgb),.18);text-align:center;background:#fffffffa;border-radius:18px;flex-direction:column;align-items:center;gap:8px;padding:12px 10px 10px;transition:transform .16s,box-shadow .16s,border-color .16s;display:flex;box-shadow:0 14px 24px #0f172a0f}.score-card.is-plus{border-color:#3dae7259;box-shadow:0 16px 26px #3dae721f}.score-card.is-minus{border-color:#f18e7866;box-shadow:0 16px 26px #f18e7824}.score-card.is-active{border-color:rgba(var(--accent-rgb),.6);background:rgba(var(--accent-rgb),.08)}.score-card.is-pending{opacity:.7}.score-card:hover{transform:translateY(-2px)}.score-card-icon{background:rgba(var(--accent-rgb),.12);width:48px;height:48px;color:var(--accent-strong);border-radius:14px;justify-content:center;align-items:center;font-size:22px;display:flex}.score-card.is-plus .score-card-icon{color:#2f9464;background:#3dae7229}.score-card.is-minus .score-card-icon{color:#d86555;background:#f18e782e}.score-card-name{color:var(--text);font-size:13px;font-weight:700}.score-card-value{border:1px solid rgba(var(--accent-rgb),.22);color:var(--accent-strong);background:#fffffff2;border-radius:999px;align-items:center;gap:6px;padding:4px 10px;font-size:11px;font-weight:700;display:inline-flex}.score-card.is-plus .score-card-value{color:#2f9464;border-color:#3dae7247}.score-card.is-minus .score-card-value{color:#d86555;border-color:#f18e7852}.score-card-unit{font-size:12px}.score-empty{text-align:center;color:var(--muted);border:1px dashed rgba(var(--accent-rgb),.28);background:#ffffffe6;border-radius:16px;padding:12px;font-size:12px}.score-error{border:1px solid rgba(var(--accent-rgb),.25);background:rgba(var(--accent-soft-rgb),.6);color:var(--accent-strong);border-radius:16px;margin-top:14px;padding:10px 12px;font-size:12px}.score-modal-actions{justify-content:flex-end;gap:10px;margin-top:18px;display:flex}.reward-bubble--big:not(.reward-bubble--minus):before,.reward-bubble--big:not(.reward-bubble--minus):after{content:"";opacity:0;width:6px;height:6px;animation:rewardSparkle var(--reward-duration)ease-out;pointer-events:none;background:#ffe9a8;border-radius:50%;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)scale(.8);box-shadow:-26px -18px #ffdd87f2,22px -14px #ffd366e6,28px 6px #ffe398e6,-20px 14px #ffedb4d9,6px 22px #ffdd87f2}.reward-bubble--big:not(.reward-bubble--minus):after{background:#fff4cf;width:4px;height:4px;box-shadow:-10px -26px #ffefc3f2,12px -22px #ffecb8d9,30px -4px #ffe5a6e6,-28px 0 #ffefc3e6,8px 26px #ffe9afd9}.reward-bubble--minus{background:var(--border)}@supports (color:color-mix(in lab, red, red)){.reward-bubble--minus{background:color-mix(in srgb,var(--border)70%,var(--panel))}}.reward-bubble--minus{color:var(--muted)}.reward-food{z-index:8;opacity:0;filter:drop-shadow(0 6px 12px rgba(var(--accent-rgb),.35));animation:rewardFeedFast var(--reward-feed-duration)cubic-bezier(.22,1,.36,1);pointer-events:none;font-size:30px;position:absolute;top:52%;left:50%;transform:translate(-50%,-50%)scale(.4)}.reward-food-emoji{transform-origin:50%;animation:.38s ease-out rewardFoodShake;display:inline-block}.reward-food:after{content:"";opacity:0;width:6px;height:6px;animation:rewardBite var(--reward-feed-duration)ease-out;pointer-events:none;background:#ffe9a8;border-radius:50%;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)scale(.4);box-shadow:-10px -8px #ffe496f2,10px -6px #ffe08ce6,12px 6px #ffecb2e6,-8px 8px #ffeebcd9}.reward-food:before{content:"";opacity:0;width:14px;height:14px;animation:rewardFlash var(--reward-feed-duration)ease-out;pointer-events:none;background:#fff0c8f2;border-radius:50%;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)scale(.3);box-shadow:0 0 18px #ffd678cc,0 0 30px #ffd6788c}.reward-stars{color:#fff2c6;opacity:0;text-shadow:-28px -18px #ffe8a9f2,22px -16px #ffe098e6,30px 4px #ffecb2e6,-22px 16px #ffeebcd9,8px 26px #ffe196d9;filter:drop-shadow(0 6px 12px #ffd67899);animation:rewardStars var(--reward-duration)ease-out;pointer-events:none;font-size:12px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)scale(.6)}.levelup-burst{border-radius:inherit;opacity:0;z-index:2;pointer-events:none;background:radial-gradient(circle at 50% 55%,#ffe9b280,#fff0 75%);position:absolute;inset:0}.levelup-overlay{border-radius:inherit;-webkit-backdrop-filter:blur(9px)saturate(1.12);backdrop-filter:blur(9px)saturate(1.12);z-index:6;text-align:center;opacity:0;pointer-events:none;isolation:isolate;animation:levelupOverlay var(--levelup-duration)ease-out;background:radial-gradient(circle at 50% 35%,#fffaec80,#ffd69652);flex-direction:column;justify-content:center;align-items:center;gap:6px;animation-fill-mode:both;display:flex;position:absolute;inset:-2px;overflow:hidden;box-shadow:inset 0 0 18px #ffd67829,0 10px 22px #ffc65c24}.levelup-overlay:before{content:"";opacity:.6;animation:levelupHalo var(--levelup-duration)ease-out;z-index:0;pointer-events:none;background:radial-gradient(circle,#ffffff80,#fff0 60%);position:absolute;inset:-25% -10%}.levelup-overlay:after{content:"";opacity:0;animation:levelupDust var(--levelup-spark-duration)ease-out;z-index:0;pointer-events:none;background-image:radial-gradient(circle,#ffffffb3 0 1.4px,#0000 2px),radial-gradient(circle,#ffd6788c 0 1.2px,#0000 2.2px);background-position:0 -20px,40px -30px;background-size:120px 120px,90px 90px;position:absolute;inset:-20%}.levelup-overlay .levelup-center-glow{border-radius:inherit;opacity:var(--levelup-glow-opacity,.7);pointer-events:none;z-index:0;background:radial-gradient(circle,#ffffff52,#fff0 65%);position:absolute;inset:16%}.levelup-title{letter-spacing:.6px;color:#0000;text-shadow:0 8px 16px #f2a64066,0 0 16px #ffd27873;z-index:1;background:linear-gradient(#ffd77c 0%,#f7a63a 60%,#e6792f 100%);-webkit-background-clip:text;background-clip:text;font-size:26px;font-weight:900;animation:1.7s cubic-bezier(.22,1,.36,1) levelupTitleDrop;position:relative}.levelup-sub{color:#7d4f16e0;box-shadow:none;z-index:1;background:0 0;border:none;border-radius:0;padding:0;font-size:13px;font-weight:700;animation:1.5s ease-out levelupSubPop;position:relative}.levelup-particle{opacity:0;width:10px;height:10px;animation:levelupParticle var(--levelup-spark-duration)ease-out;background:#ffd56b;border-radius:50%;position:absolute;box-shadow:0 0 12px #ffd678a6}.levelup-particle.p1{top:22%;left:18%}.levelup-particle.p2{width:6px;height:6px;top:20%;right:18%}.levelup-particle.p3{width:8px;height:8px;bottom:20%;left:22%}.levelup-particle.p4{width:6px;height:6px;bottom:18%;right:22%}.levelup-particle.p5{width:5px;height:5px;top:18%;left:40%}.levelup-particle.p6{width:5px;height:5px;bottom:16%;right:40%}.levelup-particle.p7{width:6px;height:6px;bottom:32%;left:12%}.levelup-particle.p8{width:7px;height:7px;bottom:30%;right:12%}.levelup-particle.p9{width:4px;height:4px;top:30%;left:34%}.levelup-particle.p10{width:4px;height:4px;top:32%;right:34%}.levelup-particle.p11{width:5px;height:5px;top:48%;left:8%}.levelup-particle.p12{width:5px;height:5px;top:46%;right:8%}.levelup-particle.p13{width:6px;height:6px;top:8%;left:26%}.levelup-particle.p14{width:6px;height:6px;top:10%;right:26%}.levelup-particle.p15{width:6px;height:6px;bottom:8%;left:30%}.levelup-particle.p16{width:6px;height:6px;bottom:10%;right:30%}.levelup-confetti{opacity:0;filter:drop-shadow(0 6px 10px #f2a64073);animation:levelupConfetti var(--levelup-spark-duration)ease-out;z-index:2;pointer-events:none;font-size:16px;position:absolute}.levelup-confetti.c1{--dx:-10px;--dy:-18px;--rot:-18deg;top:24%;left:18%}.levelup-confetti.c2{--dx:12px;--dy:-20px;--rot:16deg;animation-delay:40ms;top:22%;right:18%}.levelup-confetti.c3{--dx:-8px;--dy:16px;--rot:12deg;animation-delay:80ms;bottom:24%;left:28%}.levelup-confetti.c4{--dx:10px;--dy:18px;--rot:-12deg;animation-delay:.12s;bottom:26%;right:26%}.levelup-confetti.c5{--dx:-4px;--dy:-14px;--rot:8deg;animation-delay:60ms;top:18%;left:45%}.levelup-confetti.c6{--dx:6px;--dy:12px;--rot:-6deg;animation-delay:.1s;bottom:18%;right:44%}.levelup-confetti.c7{--dx:-14px;--dy:-8px;--rot:14deg;animation-delay:70ms;top:50%;left:10%}.levelup-confetti.c8{--dx:16px;--dy:-6px;--rot:-16deg;animation-delay:.11s;top:48%;right:10%}.levelup-confetti.c9{--dx:-6px;--dy:20px;--rot:8deg;animation-delay:.14s;bottom:12%;left:50%}.levelup-confetti.c10{--dx:8px;--dy:-18px;--rot:-10deg;animation-delay:90ms;top:10%;right:52%}.levelup-ring{opacity:0;width:66%;height:66%;animation:levelupRing var(--levelup-duration)ease-out;z-index:1;pointer-events:none;border:1px solid #ffd678b3;border-radius:50%;position:absolute;box-shadow:0 0 18px #ffd67873}.levelup-ring.r2{border-color:#ffe29699;width:82%;height:82%;animation-delay:.12s}.levelup-sigil{color:#ffd27a;opacity:0;filter:drop-shadow(0 4px 10px #f2a64066);animation:levelupSigil var(--levelup-spark-duration)ease-out;z-index:2;pointer-events:none;font-size:14px;font-weight:700;position:absolute}.levelup-sigil.s1{animation-delay:40ms;top:16%;left:20%}.levelup-sigil.s2{animation-delay:80ms;top:14%;right:18%}.levelup-sigil.s3{animation-delay:.12s;bottom:18%;left:24%}.levelup-sigil.s4{animation-delay:.16s;bottom:16%;right:22%}.levelup-pop:before{content:"";opacity:0;animation:levelupSweep var(--levelup-duration)ease-out;z-index:4;pointer-events:none;background:linear-gradient(120deg,#0000 20%,#ffd67899 48%,#0000 70%);position:absolute;inset:-40% -10%;transform:translate(-30%)}.levelup-pop:after{content:"";border-radius:inherit;opacity:0;animation:levelupGlow var(--levelup-duration)ease-out;pointer-events:none;border:2px solid #ffd678bf;position:absolute;inset:-2px;box-shadow:0 0 26px #ffd6788c,0 0 46px #ffd67866}.levelup-pop{--levelup-overlay-opacity:.6;--levelup-halo-opacity:.95;--levelup-dust-opacity:.7;--levelup-glow-opacity:.7;--levelup-burst-opacity:1;--levelup-burst-scale-peak:1.04;--levelup-burst-scale-mid:1.06;--levelup-burst-scale-end:1.08;--levelup-card-scale-peak:1.035;--levelup-card-scale-mid:1.02;--levelup-particle-scale:1;--levelup-confetti-scale:1;animation:levelupCard var(--levelup-duration)cubic-bezier(.22,1,.36,1);transform-origin:50%;will-change:transform,box-shadow,filter;border-color:#0000}.levelup-celebrate{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:6px;display:flex}.levelup-stars{letter-spacing:4px;color:#f3b24f;font-size:18px;animation:1s ease-out levelUpSparkle}.levelup-label{color:var(--text);border:1px solid var(--border);background:#ffffffdb;border-radius:999px;padding:4px 12px;font-size:14px;font-weight:700;box-shadow:0 6px 16px #0f172a1f}.archive-hero{align-items:center;gap:24px;display:grid}@media (min-width:1024px){.archive-hero{grid-template-columns:1.1fr .9fr}}.archive-hero-pet{flex-direction:column;justify-content:center;align-items:center;display:flex}.archive-pet-wrap{aspect-ratio:1;background:radial-gradient(circle,var(--accent-soft)0%,var(--panel)70%);border-radius:999px;width:clamp(220px,36vw,360px);position:relative}@supports (color:color-mix(in lab, red, red)){.archive-pet-wrap{background:radial-gradient(circle,color-mix(in srgb,var(--accent-soft)70%,var(--panel))0%,var(--panel)70%)}}.archive-pet-wrap{box-shadow:0 20px 36px var(--accent);justify-content:center;align-items:center;display:flex}@supports (color:color-mix(in lab, red, red)){.archive-pet-wrap{box-shadow:0 20px 36px color-mix(in srgb,var(--accent)25%,transparent)}}.archive-pet-wrap:after{content:"";background:radial-gradient(ellipse,var(--accent),transparent 70%);width:65%;height:12%;position:absolute;bottom:12%;left:50%;transform:translate(-50%)}@supports (color:color-mix(in lab, red, red)){.archive-pet-wrap:after{background:radial-gradient(ellipse,color-mix(in srgb,var(--accent)30%,transparent),transparent 70%)}}.archive-pet-wrap:after{filter:blur(4px)}.archive-pet{width:58%;height:58%;font-size:clamp(4rem,8vw,6rem)}@media (max-width:640px){.archive-hero{grid-template-columns:1fr}.archive-pet-wrap{width:clamp(180px,68vw,280px)}}.pet-emoji-float{transform-origin:50%;animation:5.5s ease-in-out infinite floatEmoji;display:inline-flex}.pet-ill{isolation:isolate;justify-content:center;align-items:center;line-height:1;display:inline-flex;position:relative;overflow:visible}.pet-ill:before{content:"";background:radial-gradient(circle at 30% 30%,rgba(var(--accent-soft-rgb),.8),transparent 70%);opacity:.9;filter:blur(2px);z-index:0;pointer-events:none;position:absolute;inset:-35%}.pet-ill:after{content:"";background:radial-gradient(ellipse,rgba(var(--accent-rgb),.28),transparent 70%);filter:blur(2px);z-index:0;pointer-events:none;width:70%;height:14%;position:absolute;bottom:2px;left:50%;transform:translate(-50%)}.pet-ill img,.pet-ill .pet-emoji{z-index:1;filter:drop-shadow(0 4px 8px var(--accent));position:relative}@supports (color:color-mix(in lab, red, red)){.pet-ill img,.pet-ill .pet-emoji{filter:drop-shadow(0 4px 8px color-mix(in srgb,var(--accent)30%,transparent))}}.mystery-egg{animation:2.6s ease-in-out infinite eggWiggle;position:relative}.mystery-egg-image{animation:2.6s ease-in-out infinite eggWiggle}.pet-card.egg-card .mystery-egg,.pet-card.egg-card .mystery-egg-image{animation:none}.mystery-egg:after{content:"?";color:var(--accent-strong);text-shadow:0 4px 8px rgba(var(--accent-rgb),.35);font-size:14px;position:absolute;top:-10px;right:-4px}.pet-ill img{object-fit:contain;width:100%;height:100%}.pet-portrait{flex:0 0 60%;justify-content:flex-start;align-items:flex-end;min-width:150px;max-width:220px;margin-left:-10px;display:flex;position:relative}.pet-ill-hero{width:100%;height:clamp(130px,28vw,180px)}.pet-figure{transform-origin:0;justify-content:center;align-items:center;width:100%;height:100%;display:flex;transform:translate(-10px)translateY(-6px)scale(1.12)}.pet-figure img,.pet-figure .pet-emoji{filter:drop-shadow(0 4px 8px var(--accent))}@supports (color:color-mix(in lab, red, red)){.pet-figure img,.pet-figure .pet-emoji{filter:drop-shadow(0 4px 8px color-mix(in srgb,var(--accent)30%,transparent))}}.card-emotion{position:relative}.card-3d{overflow:hidden}.card-3d:before{content:"";background:radial-gradient(circle,rgba(var(--accent-soft-rgb),.95),rgba(var(--accent-soft-rgb),0));z-index:0;border-radius:50%;width:72%;height:58%;position:absolute;bottom:18%;left:12%}.card-top{z-index:3;justify-content:space-between;align-items:center;font-size:11px;display:flex;position:relative}.glass-pill{background:var(--accent-soft)}@supports (color:color-mix(in lab, red, red)){.glass-pill{background:color-mix(in srgb,var(--accent-soft)70%,var(--panel))}}.glass-pill{color:var(--accent-strong);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.card-island{aspect-ratio:3/4;min-height:180px;box-shadow:0 10px 22px rgba(var(--accent-rgb),.12),0 6px 12px #0f172a0f;border:1px solid var(--accent);background:linear-gradient(#fffffffa 0%,#ffffffe6 48%,#f4f6faf5 49%,#eff1f7f5 100%);flex-direction:column;align-items:center;gap:4px;padding:8px 10px 10px;display:flex;position:relative;overflow:hidden}@supports (color:color-mix(in lab, red, red)){.card-island{border:1px solid color-mix(in srgb,var(--accent)18%,#dfe4ee)}}:root[data-classroom=on][data-page=dashboard] .card-island{min-height:240px;box-shadow:0 22px 44px rgba(var(--accent-rgb),.2),0 10px 18px #0f172a14;border-color:var(--accent)}@supports (color:color-mix(in lab, red, red)){:root[data-classroom=on][data-page=dashboard] .card-island{border-color:color-mix(in srgb,var(--accent)25%,#dfe4ee)}}.card-island:before{content:"";z-index:0;background:radial-gradient(circle,#fff5faeb,#0000 72%);border-radius:50%;width:76%;height:56%;position:absolute;bottom:22%;left:12%}.card-island:after{content:"";opacity:.7;pointer-events:none;z-index:1;background:radial-gradient(circle at 20% 12%,#ffffffe6,#fff0 55%);position:absolute;inset:0}.card-island-footer{z-index:3;flex-direction:column;align-items:center;gap:6px;width:100%;padding:0 10px;display:flex;position:absolute;bottom:10px;left:0;right:0}.progress-stack{flex-direction:column;justify-content:center;align-items:center;gap:4px;width:100%;min-height:28px;display:flex}.progress-stack .energy-bar{width:100%}.progress-remaining{color:var(--muted);align-items:center;gap:4px;font-size:10px;display:inline-flex}.progress-remaining-count{color:var(--text);font-weight:700}.progress-remaining-icon{font-size:11px}.summon-text{color:#7d4f16;letter-spacing:.4px;text-shadow:0 4px 10px #ffc65c59;background:0 0;border:none;padding:0;font-size:12px;font-weight:700}.summon-pill{letter-spacing:.4px;color:#8c5a12;background:linear-gradient(135deg,#fff4d2fa,#ffd6a0fa);border:1px solid #ffcd8cd9;border-radius:999px;align-items:center;gap:6px;padding:6px 14px;font-size:12px;font-weight:700;animation:3.4s ease-in-out infinite summonBreath;display:inline-flex;position:relative;box-shadow:0 10px 18px #ffcd8c59,inset 0 0 0 1px #ffffffb3}.summon-pill-text{z-index:1;position:relative}.summon-pill-hint{color:#d69c3ce6;text-shadow:0 4px 8px #ffc85a80;font-size:10px;animation:3.4s ease-in-out infinite summonHint;position:absolute;top:-12px;left:50%;transform:translate(-50%)}.summon-pill-nut{filter:drop-shadow(0 0 6px #ffc85ab3);font-size:12px;animation:3.4s ease-in-out infinite summonNut}@keyframes summonBreath{0%,to{transform:translateY(0)scale(1);box-shadow:0 10px 18px #ffcd8c52,inset 0 0 0 1px #ffffffb3}50%{transform:translateY(-1px)scale(1.03);box-shadow:0 12px 22px #ffcd8c66,inset 0 0 0 1px #fffc}}@keyframes summonNut{0%,to{transform:translateY(0)scale(1)}50%{transform:translateY(-2px)scale(1.08)}}@keyframes summonHint{0%,to{opacity:.35;transform:translate(-50%)}50%{opacity:.9;transform:translate(-50%,-2px)}}@media (prefers-reduced-motion:reduce){.summon-pill,.summon-pill-hint,.summon-pill-nut{animation:none}}.card-data-bar{justify-content:space-between;align-items:center;gap:10px;width:100%;min-height:20px;font-size:12px;display:flex}.card-data-item{color:var(--muted);align-items:center;gap:6px;font-weight:600;display:inline-flex}.card-data-item--clickable{cursor:pointer;background:0 0;border:none;padding:0}.card-data-item--clickable:hover .card-data-value{color:var(--accent-strong)}.card-data-item--disabled{opacity:.45;filter:grayscale(.2)}.card-data-icon{font-size:13px}.card-data-value{color:var(--text);font-weight:700}.badge-wall-overlay{z-index:60;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#0f172a73;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.badge-wall{--badge-size:clamp(96px,13vw,140px);background:#fff;border:1px solid #f8d9b5cc;border-radius:24px;flex-direction:column;width:clamp(320px,88vw,720px);max-height:86vh;display:flex;position:relative;overflow:hidden;box-shadow:0 24px 52px #0f172a2e}.badge-wall-glow{display:none}.badge-wall-body{z-index:1;overscroll-behavior:contain;scrollbar-gutter:stable;gap:clamp(10px,1.6vw,16px);min-height:0;padding:clamp(12px,2vw,18px);display:grid;position:relative;overflow-y:auto}.badge-wall-header{color:#fff;background:linear-gradient(135deg,#f2b63a,#f0a926);border:1px solid #f8d9b5e6;border-radius:clamp(14px,2vw,18px);justify-content:space-between;align-items:center;gap:clamp(8px,1.4vw,12px);padding:clamp(10px,1.6vw,14px);display:flex}.badge-wall-heading{align-items:center;gap:10px;display:inline-flex}.badge-wall-icon{color:#fff;background:#ffffff47;border:1px solid #ffffffa6;border-radius:clamp(10px,1.6vw,14px);justify-content:center;align-items:center;width:clamp(30px,4.6vw,38px);height:clamp(30px,4.6vw,38px);display:inline-flex;box-shadow:inset 0 0 0 1px #ffffff59}.badge-wall-title{color:#fff;align-items:baseline;gap:8px;font-size:clamp(16px,2.4vw,18px);font-weight:800;display:inline-flex}.badge-wall-name{font-size:clamp(18px,2.6vw,20px)}.badge-wall-title-text{color:#fff;font-size:clamp(14px,2.2vw,16px);font-weight:800}.badge-wall-sub{color:#ffffffd9;margin-top:2px;font-size:clamp(10px,1.4vw,11px)}.badge-wall-close{color:#fff;opacity:.75;background:#ffffff2e;border:1px solid #fff6;border-radius:999px;justify-content:center;align-items:center;width:clamp(28px,4.4vw,32px);height:clamp(28px,4.4vw,32px);display:inline-flex;box-shadow:0 6px 12px #0f172a14}.badge-wall-close:hover{opacity:1;background:#ffffff47}.badge-wall-hero{background:#ffffffe6;border:1px solid #f8d9b5b3;border-radius:clamp(14px,2vw,18px);grid-template-columns:minmax(0,1.1fr) minmax(0,1fr);gap:clamp(8px,1.2vw,12px);padding:clamp(10px,1.6vw,12px);display:grid;box-shadow:inset 0 0 0 1px #fff9}.badge-wall-hero--simple{box-shadow:none;background:0 0;border:none;grid-template-columns:1fr;padding:0}@media (max-width:720px){.badge-wall-hero{grid-template-columns:1fr}}.badge-progress{gap:8px;display:grid}.badge-progress-top{color:var(--text);justify-content:space-between;align-items:center;font-size:12px;font-weight:700;display:flex}.badge-progress-count{color:var(--accent-strong);font-weight:800}.badge-progress-track{background:rgba(var(--accent-rgb),.15);border-radius:999px;height:9px;overflow:hidden}.badge-progress-fill{border-radius:inherit;background:linear-gradient(90deg,var(--cta),var(--accent));height:100%}@supports (color:color-mix(in lab, red, red)){.badge-progress-fill{background:linear-gradient(90deg,var(--cta),color-mix(in srgb,var(--accent)80%,#fff))}}.badge-progress-fill{box-shadow:0 0 10px rgba(var(--accent-rgb),.35)}.badge-progress-hint{color:var(--muted);font-size:11px}.badge-hero-stats{grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:clamp(10px,2vw,14px);display:grid}.badge-hero-stats--full{width:100%}.badge-hero-card{text-align:center;box-shadow:0 8px 16px rgba(var(--accent-rgb),.12);background:#fffffffa;border:1px solid #f8d9b5cc;border-radius:clamp(12px,2vw,16px);justify-items:center;gap:clamp(2px,.8vw,6px);padding:clamp(10px,1.6vw,14px);display:grid}.badge-hero-card--peach{background:linear-gradient(135deg,#fff4e4fa,#fffaf4fa);border-color:#f4c68fbf}.badge-hero-card--rose{background:linear-gradient(135deg,#ffecf2fa,#fffafcfa);border-color:#eeb4c6bf}.badge-hero-card--mint{background:linear-gradient(135deg,#e7f9f1fa,#f7fffbfa);border-color:#b2e8cfbf}.badge-hero-card--muted{color:var(--muted);background:#ffffffb3}.badge-hero-icon{color:#b4622e;background:#fff1e1e6;border:1px solid #f4c68f8c;border-radius:999px;justify-content:center;align-items:center;width:clamp(26px,3.8vw,32px);height:clamp(26px,3.8vw,32px);margin-bottom:2px;display:inline-flex}.badge-hero-icon--accent{color:#c66a3a;background:#ffe9d3f2}.badge-hero-icon--gold{color:#a96a1c;background:#fff4dcf2}.badge-hero-icon--rose{color:#c16b7b;background:#ffe3ebe6}.badge-hero-label{color:#7b5a49;font-size:clamp(10px,1.4vw,12px);font-weight:700}.badge-hero-value{color:#4b2b1c;font-size:clamp(18px,3vw,24px);font-weight:800}.badge-hero-sub{color:var(--muted);font-size:clamp(9px,1.2vw,10px)}.badge-wall-section{gap:6px;display:grid}.badge-wall-section-title{color:var(--text);align-items:center;gap:6px;font-size:clamp(11px,1.5vw,12px);font-weight:700;display:inline-flex}.badge-wall-section-sub{color:var(--muted);margin-bottom:4px;font-size:11px}.badge-grid{grid-template-columns:repeat(auto-fill,minmax(var(--badge-size),var(--badge-size)));place-content:start;gap:clamp(8px,1.4vw,12px);display:grid}.badge-grid--wall{grid-template-columns:repeat(auto-fill,minmax(var(--badge-size),var(--badge-size)));width:fit-content;max-width:100%}.badge-tile{background:#fffffffa;border:1px solid #f4d6b8bf;border-radius:clamp(12px,2vw,14px);justify-items:center;gap:clamp(4px,.8vw,6px);padding:clamp(6px,1.2vw,10px);transition:transform .2s,box-shadow .2s;display:grid;position:relative}.badge-tile--earned{box-shadow:0 8px 16px rgba(var(--accent-rgb),.14)}.badge-tile--empty{opacity:.55;filter:grayscale(.15);background:#ffffffb3;border-style:dashed}.badge-tile-ill{aspect-ratio:1;background:linear-gradient(135deg,#fff8eccc,#fffffffa);border-radius:clamp(12px,2vw,18px);justify-content:center;align-items:center;width:100%;height:auto;display:flex;position:relative;overflow:hidden}.badge-tile-ill img{object-fit:contain;width:100%;height:100%}.badge-item{justify-items:center;gap:6px;display:grid}.badge-name-pill{color:#5f412f;text-align:center;max-width:calc(var(--badge-size) + 6px);text-overflow:ellipsis;white-space:nowrap;background:#fff6ebf2;border:1px solid #f4d6b8bf;border-radius:999px;padding:4px 10px;font-size:clamp(11px,1.6vw,13px);font-weight:700;line-height:1;overflow:hidden}.badge-tile-placeholder{color:#3a2e2a73;text-shadow:0 6px 12px rgba(var(--accent-rgb),.2);font-size:22px;font-weight:700}.badge-tile-count{color:var(--text);border:1px solid rgba(var(--accent-rgb),.25);background:#ffffffd9;border-radius:999px;padding:2px 6px;font-size:10px;font-weight:700;position:absolute;top:6px;right:6px}.badge-empty{color:var(--muted);text-align:center;grid-column:1/-1;padding:10px 0 0;font-size:12px}.badge-history{gap:6px;display:grid}.badge-history-row{background:#f8fcfff2;border:1px solid #f8d9b58c;border-radius:16px;justify-content:space-between;align-items:center;gap:10px;padding:12px 14px;display:flex}.badge-history-item{color:var(--text);align-items:center;gap:8px;font-size:12px;font-weight:600;display:inline-flex}.badge-history-icon{font-size:14px}.badge-history-cost{color:#f25f5c;font-size:12px;font-weight:800}.badge-wall-section--history{border-top:1px solid #f8d9b566;padding-top:10px}.card-island-top{z-index:3;justify-content:space-between;align-items:center;font-size:11px;display:flex;position:absolute;top:10px;left:10px;right:10px}.card-island-head{z-index:4;grid-template-rows:auto auto;grid-template-columns:1fr auto 1fr;align-items:start;gap:4px 8px;display:grid;position:absolute;top:8px;left:10px;right:10px}.card-island-info{text-align:right;flex-direction:column;grid-area:1/3/3;align-items:flex-end;gap:2px;display:flex}.card-island-topline{align-items:center;gap:8px;display:inline-flex}.level-text{color:var(--accent-strong);align-items:center;gap:6px;font-size:11px;font-weight:700;display:inline-flex}.level-text--max{color:#8c5a12;background:linear-gradient(135deg,#fff4d2fa,#ffd6a0fa);border:1px solid #ffcd8cd9;border-radius:999px;padding:2px 8px;box-shadow:0 8px 16px #ffcd8c47,inset 0 0 0 1px #ffffffb3}.level-text--muted{color:var(--muted)}.level-text-icon{font-size:12px}.level-text-crown{filter:drop-shadow(0 0 6px #ffc85ab3);font-size:11px}.card-island-name{color:var(--accent-strong);grid-area:1/2/3;font-size:24px;font-weight:800}@supports (color:color-mix(in lab, red, red)){.card-island-name{color:color-mix(in srgb,var(--accent-strong)85%,var(--text))}}.card-island-name{text-shadow:0 2px 6px rgba(var(--accent-rgb),.25);-webkit-line-clamp:2;text-overflow:ellipsis;text-align:center;-webkit-box-orient:vertical;justify-self:center;max-width:130px;min-height:2.2em;margin-top:4px;line-height:1.15;display:-webkit-box;overflow:hidden}:root[data-classroom=on][data-page=dashboard] .card-island-name{text-shadow:0 2px 6px #0f172a2e;min-height:2.3em;font-size:28px;font-weight:800}.card-island-petname{color:var(--muted);letter-spacing:.3px;white-space:nowrap;text-overflow:ellipsis;max-width:86px;font-size:11px;overflow:hidden}:root[data-classroom=on][data-page=dashboard] .card-island-petname{font-size:14px}.card-island-level{color:var(--accent-strong);background:var(--accent-soft);border-radius:999px;padding:2px 8px;font-size:12px;font-weight:600}@supports (color:color-mix(in lab, red, red)){.card-island-level{background:color-mix(in srgb,var(--accent-soft)65%,var(--panel))}}.card-island-level{border:1px solid var(--accent)}@supports (color:color-mix(in lab, red, red)){.card-island-level{border:1px solid color-mix(in srgb,var(--accent)35%,var(--panel))}}.card-island-pet{z-index:2;flex:1;justify-content:center;align-items:center;width:100%;padding-top:14px;display:flex;position:relative}.pet-ill-island{aspect-ratio:1;justify-content:center;align-items:center;width:max(170px,78%);display:flex;position:relative}.pet-ill-island:before{content:"";background:radial-gradient(ellipse,var(--accent-soft),transparent 70%);width:90%;height:22%;position:absolute;bottom:4px;left:50%;transform:translate(-50%)}@supports (color:color-mix(in lab, red, red)){.pet-ill-island:before{background:radial-gradient(ellipse,color-mix(in srgb,var(--accent-soft)55%,transparent),transparent 70%)}}.pet-ill-island:before{filter:blur(6px);z-index:0}.pet-ill-island:after{content:"";background:radial-gradient(ellipse,var(--accent),transparent 70%);width:72%;height:16%;position:absolute;bottom:6px;left:50%;transform:translate(-50%)}@supports (color:color-mix(in lab, red, red)){.pet-ill-island:after{background:radial-gradient(ellipse,color-mix(in srgb,var(--accent)35%,transparent),transparent 70%)}}.pet-ill-island:after{filter:blur(2px);z-index:0}.pet-ill-island .pet-figure{width:100%;height:100%;transform:translateY(-4px)scale(1)}:root[data-classroom=on][data-page=dashboard] .pet-ill-island .pet-figure{transform:translateY(-4px)scale(1.06)}:root[data-classroom=on][data-page=dashboard] .pet-ill-island{width:max(140px,62%)}@media (prefers-reduced-motion:no-preference){.card-island .pet-figure{animation:4s ease-in-out infinite floatEmoji}.card-island:hover .pet-figure{animation:.52s ease-out petCheer}.levelup-pop .levelup-burst{animation:levelUpBurst var(--levelup-duration)ease-out}.levelup-pop .pet-figure{animation:levelUpPet var(--levelup-duration)ease-out}.reward-jump .pet-figure{animation:rewardJump var(--reward-jump-duration)ease-out,rewardShake .38s ease-out,rewardAfterShock .5s ease-out .24s}.reward-jump .pet-emoji-float{animation:none}.reward-jump .pet-figure img,.reward-jump .pet-figure .pet-emoji{animation:.35s ease-out rewardChomp}}.energy-bar{background:var(--accent);border-radius:999px;width:72%;height:10px;margin-top:0}@supports (color:color-mix(in lab, red, red)){.energy-bar{background:color-mix(in srgb,var(--accent)18%,#d6dce6)}}.energy-bar{box-shadow:inset 0 2px 8px rgba(var(--accent-rgb),.18),0 4px 10px rgba(var(--accent-rgb),.12);z-index:3;overflow:hidden}.energy-bar__fill{background:linear-gradient(90deg,var(--accent),var(--cta-strong));border-radius:999px;height:100%;display:block}@supports (color:color-mix(in lab, red, red)){.energy-bar__fill{background:linear-gradient(90deg,color-mix(in srgb,var(--accent)75%,#ffd7b0),var(--cta-strong))}}.energy-bar__fill{box-shadow:0 0 12px var(--accent),inset 0 0 6px #fff6}@supports (color:color-mix(in lab, red, red)){.energy-bar__fill{box-shadow:0 0 12px color-mix(in srgb,var(--accent)35%,transparent),inset 0 0 6px #fff6}}.energy-bar__fill{transition:width .26s;animation:3.2s linear infinite energyFlow}.energy-bar--thin{height:12px;position:relative;overflow:hidden}.energy-bar--thin:after{content:"";pointer-events:none;opacity:.55;background-image:linear-gradient(90deg,#0000 0 calc(25% - .5px),#fff6 calc(25% - .5px) calc(25% + .5px),#0000 calc(25% + .5px) calc(50% - .5px),#fff6 calc(50% - .5px) calc(50% + .5px),#0000 calc(50% + .5px) calc(75% - .5px),#fff6 calc(75% - .5px) calc(75% + .5px),#0000 calc(75% + .5px) 100%);position:absolute;inset:0}:root[data-classroom=on][data-page=dashboard] .energy-bar{width:82%}:root[data-classroom=on][data-page=dashboard] .energy-bar--thin{height:14px}:root[data-classroom=on][data-page=dashboard] .reward-bubble--big{letter-spacing:.9px;padding:11px 22px;font-size:22px}:root[data-classroom=on][data-page=dashboard] .reward-stars{font-size:14px}.level-badge{border:1px solid var(--border);color:var(--text);z-index:3;background:#ffffffe0;border-radius:999px;align-items:center;gap:6px;margin-top:6px;padding:6px 12px;font-size:12px;font-weight:700;display:inline-flex;box-shadow:0 8px 16px #0f172a1f}.level-badge-icon{font-size:14px;line-height:1}.level-badge--egg{color:#9d7c66;background:linear-gradient(#fff8f2,#f4efe9);border-color:#f2e3d6}.level-badge--wood{color:#8a5a2b;background:linear-gradient(#f6efe5,#e7d5bf);border-color:#d8bfa4}.level-badge--bronze{color:#8a4f24;background:linear-gradient(#fff0e3,#f0c6a2);border-color:#e0b18a}.level-badge--silver{color:#4a5b73;background:linear-gradient(#f6f7fb,#d7deea);border-color:#c1cad9}.level-badge--gold{color:#9b6500;background:linear-gradient(#fff5d6,#ffd68a);border-color:#f0c56c}.card-hover-tip{color:var(--muted);opacity:0;z-index:3;pointer-events:none;flex-direction:column;gap:2px;font-size:11px;transition:opacity .18s,transform .18s;display:flex;position:absolute;bottom:26px;left:16px;transform:translateY(4px)}.card-hover-tip em{color:var(--accent-strong);font-style:normal;font-weight:600}.card-island-level-float{z-index:3;color:var(--panel);background:var(--accent-strong);border-radius:999px;padding:3px 9px;font-size:10px;font-weight:700;position:absolute;top:32%;right:16%}@supports (color:color-mix(in lab, red, red)){.card-island-level-float{background:color-mix(in srgb,var(--accent-strong)85%,var(--panel))}}.card-island-level-float{box-shadow:0 8px 14px var(--accent)}@supports (color:color-mix(in lab, red, red)){.card-island-level-float{box-shadow:0 8px 14px color-mix(in srgb,var(--accent)35%,transparent)}}.card-actions-island{bottom:12px;right:12px}.btn-ghost-pill{border:1px solid var(--accent);border-radius:999px}@supports (color:color-mix(in lab, red, red)){.btn-ghost-pill{border:1px solid color-mix(in srgb,var(--accent)45%,var(--panel))}}.btn-ghost-pill{background:var(--accent-soft)}@supports (color:color-mix(in lab, red, red)){.btn-ghost-pill{background:color-mix(in srgb,var(--accent-soft)65%,var(--panel))}}.btn-ghost-pill{color:var(--accent-strong);box-shadow:0 8px 14px var(--accent);padding:5px 12px;font-weight:600}@supports (color:color-mix(in lab, red, red)){.btn-ghost-pill{box-shadow:0 8px 14px color-mix(in srgb,var(--accent)30%,transparent)}}.btn-ghost-pill{transition:background .18s,border-color .18s,color .18s,box-shadow .18s}.btn-ghost-pill:hover{background:var(--accent-soft)}@supports (color:color-mix(in lab, red, red)){.btn-ghost-pill:hover{background:color-mix(in srgb,var(--accent-soft)80%,var(--panel))}}.btn-ghost-pill:hover{border-color:var(--accent)}@supports (color:color-mix(in lab, red, red)){.btn-ghost-pill:hover{border-color:color-mix(in srgb,var(--accent)60%,var(--panel))}}.btn-ghost-pill:hover{box-shadow:0 10px 16px var(--accent)}@supports (color:color-mix(in lab, red, red)){.btn-ghost-pill:hover{box-shadow:0 10px 16px color-mix(in srgb,var(--accent)35%,transparent)}}.card-island-link{z-index:4;align-items:center;gap:8px;display:flex;position:absolute;bottom:28px;right:16px}.card-island:hover{box-shadow:0 14px 28px rgba(var(--accent-rgb),.18),0 0 0 1px rgba(var(--accent-rgb),.2);transform:scale(1.02)}.card-island:focus-visible{box-shadow:0 14px 28px rgba(var(--accent-rgb),.2),0 0 0 2px rgba(var(--accent-rgb),.35);outline:none}.card-metrics{width:100%;color:var(--muted);opacity:1;z-index:3;justify-content:space-between;align-items:center;gap:8px;margin-top:0;padding:0 4px;font-size:11px;display:flex;transform:translateY(0)}.metric-item{border:1px solid rgba(var(--accent-rgb),.15);background:#fffc;border-radius:999px;align-items:center;gap:4px;padding:2px 8px;display:inline-flex}.metric-icon{font-size:12px}.metric-value{color:var(--text);font-weight:700}:root[data-classroom=on][data-page=dashboard] .card-metrics{display:none}.summon-ready{border-color:#ffd28cbf;animation:3.6s ease-in-out infinite summonPulse;box-shadow:0 18px 36px #ffc57840,0 0 0 1px #ffd69673}.summon-tag{color:#8c5a12;z-index:4;background:linear-gradient(135deg,#ffecc6f2,#ffd596f2);border-radius:999px;padding:4px 10px;font-size:11px;font-weight:700;position:absolute;top:12px;left:12px;box-shadow:0 10px 18px #ffcd8c52}:root[data-classroom=on][data-page=dashboard] .summon-tag{padding:5px 12px;font-size:12px}.summon-card{z-index:2;isolation:isolate;will-change:transform,opacity;background:linear-gradient(#fffffffa,#fff6e8f2) padding-box padding-box,linear-gradient(135deg,#f7b34a,#f05ab0) border-box;border:2px solid #0000;border-radius:28px;width:min(430px,86vw);padding:22px 22px 18px;transition:transform .52s cubic-bezier(.22,.61,.36,1),opacity .52s,filter .52s;animation:.32s ease-out summonPop;position:relative;overflow:visible;box-shadow:0 36px 70px #ffb67859,0 0 0 6px #ffdca02e}.summon-card:before{content:"";border-radius:inherit;opacity:.9;pointer-events:none;background:radial-gradient(circle at 50% 0,#fffcf0f2,#0000 55%);position:absolute;inset:0}.summon-card:after{content:"";filter:blur(18px);opacity:.45;z-index:-1;mix-blend-mode:screen;pointer-events:none;background:conic-gradient(#ffc578e6,#f05ab0bf,#7aa7ffb3,#ffc578e6);border-radius:32px;animation:10s linear infinite auraSpin,4.8s ease-in-out infinite auraPulse;position:absolute;inset:-14px}.summon-corner-glow{opacity:.7;pointer-events:none;z-index:1;background:radial-gradient(circle,#ffd696a6 0%,#0000 65%),radial-gradient(circle,#ff82b666 0%,#0000 70%);width:120px;height:120px;position:absolute;top:-36px;right:18px}.summon-overlay{-webkit-backdrop-filter:blur(8px);background:#0f0b1652;transition:background .32s,-webkit-backdrop-filter .32s,backdrop-filter .32s;position:fixed;overflow:hidden}.summon-overlay:before,.summon-overlay:after{content:"";opacity:.45;pointer-events:none;z-index:0;background:radial-gradient(circle at 20% 20%,#ffc87840,#0000 40%),radial-gradient(circle at 80% 30%,#ff78b433,#0000 45%),radial-gradient(circle at 50% 80%,#ffdca038,#0000 42%);animation:10s ease-in-out infinite auroraDrift;position:absolute;inset:-20%}.summon-overlay:after{opacity:.35;animation-duration:14s}.summon-overlay.is-closing{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);pointer-events:none;background:#00000026}.summon-card.is-closing{transform:translate(var(--summon-close-x,0),var(--summon-close-y,0))scale(var(--summon-close-scale,.2));opacity:.35;filter:blur(1px)}.summon-lens{pointer-events:none;z-index:1;position:absolute;inset:0}.summon-lens:before,.summon-lens:after{content:"";filter:blur(10px);mix-blend-mode:screen;opacity:.6;background:radial-gradient(circle,#ffffff59,#fff0 65%);border-radius:50%;width:46%;height:46%;animation:9s ease-in-out infinite lensDrift;position:absolute}.summon-lens:before{top:-8%;left:-6%}.summon-lens:after{opacity:.45;animation-delay:1.6s;bottom:-12%;right:-4%}.summon-falling{z-index:1;pointer-events:none;position:absolute;inset:0}.summon-star{opacity:0;background:radial-gradient(circle,#ffecbef2,#ffecbe00);border-radius:50%;width:8px;height:8px;animation:4.6s linear infinite starFall;position:absolute;top:-10%;box-shadow:0 0 12px #ffd696cc}.summon-star.s1{animation-delay:0s;left:12%}.summon-star.s2{animation-delay:.64s;left:22%}.summon-star.s3{animation-delay:1.2s;left:34%}.summon-star.s4{animation-delay:1.8s;left:46%}.summon-star.s5{animation-delay:.9s;left:58%}.summon-star.s6{animation-delay:1.5s;left:68%}.summon-star.s7{animation-delay:2.1s;left:76%}.summon-star.s8{animation-delay:2.6s;left:84%}.summon-star.s9{animation-delay:2.3s;left:18%}.summon-star.s10{animation-delay:2.8s;left:40%}.summon-star.s11{animation-delay:3.2s;left:62%}.summon-star.s12{animation-delay:3.6s;left:90%}.summon-confetti{z-index:1;pointer-events:none;position:absolute;inset:0}.summon-confetti .ribbon{opacity:.9;filter:drop-shadow(0 4px 8px #ffc87859);background:linear-gradient(#ffd678e6,#ff96d2e6);border-radius:6px;width:10px;height:22px;animation:5.6s linear infinite ribbonFall;position:absolute;top:-12%}.summon-confetti .r1{animation-delay:0s;left:16%}.summon-confetti .r2{height:18px;animation-delay:.7s;left:28%}.summon-confetti .r3{background:linear-gradient(#ffa0d2f2,#ffd678e6);animation-delay:1.4s;left:40%}.summon-confetti .r4{height:20px;animation-delay:2.2s;left:52%}.summon-confetti .r5{width:8px;animation-delay:1.2s;left:64%}.summon-confetti .r6{animation-delay:1.8s;left:72%}.summon-confetti .r7{height:16px;animation-delay:2.6s;left:82%}.summon-confetti .r8{width:9px;animation-delay:3.2s;left:90%}.summon-dust{z-index:1;pointer-events:none;position:absolute;inset:0}.summon-dust .dust{opacity:.7;filter:blur(.4px);background:radial-gradient(circle,#ffecbee6,#ffecbe00);border-radius:50%;width:6px;height:6px;animation:6.8s ease-in-out infinite dustDrift;position:absolute}.summon-dust .d1{animation-delay:0s;top:20%;left:18%}.summon-dust .d2{animation-delay:.6s;top:30%;left:62%}.summon-dust .d3{animation-delay:1.2s;top:46%;left:26%}.summon-dust .d4{animation-delay:.9s;top:52%;left:72%}.summon-dust .d5{animation-delay:1.5s;top:68%;left:34%}.summon-dust .d6{animation-delay:1.8s;top:70%;left:58%}.summon-dust .d7{animation-delay:2.1s;top:38%;left:48%}.summon-dust .d8{animation-delay:2.4s;top:24%;left:80%}.summon-dust .d9{animation-delay:2.7s;top:60%;left:14%}.summon-dust .d10{animation-delay:3s;top:16%;left:44%}.summon-sparkles{pointer-events:none;z-index:1;position:absolute;inset:0}.summon-sparkles .spark{background:radial-gradient(circle,#ffecbef2,#ffecbe00);border-radius:50%;width:8px;height:8px;animation:2.6s ease-in-out infinite sparkleFloat;position:absolute;box-shadow:0 0 10px #ffd696a6}.summon-sparkles .s1{animation-delay:0s;top:12%;left:22%}.summon-sparkles .s2{animation-delay:.12s;top:18%;right:18%}.summon-sparkles .s3{animation-delay:.2s;top:36%;left:12%}.summon-sparkles .s4{animation-delay:.32s;top:42%;right:14%}.summon-sparkles .s5{animation-delay:.18s;bottom:18%;left:26%}.summon-sparkles .s6{animation-delay:.26s;bottom:16%;right:22%}.summon-header{z-index:2;justify-content:center;align-items:center;display:flex;position:relative}.summon-title{letter-spacing:1.2px;text-shadow:0 8px 16px #ffc87866;-webkit-text-fill-color:transparent;color:#0000;background:linear-gradient(90deg,#f59b2c,#f05a90);-webkit-background-clip:text;align-items:center;gap:6px;font-size:22px;font-weight:800;display:inline-flex}.summon-title-icon{filter:drop-shadow(0 4px 8px #ffc67873);color:#f59b2c;-webkit-text-fill-color:#f59b2c;font-size:18px}.summon-close{color:#b56f1a;opacity:.78;background:#ffffffa6;border:1px solid #ffd69673;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;display:inline-flex;position:absolute;top:0;right:0;box-shadow:0 6px 12px #ffcd8c24}.summon-close:hover{opacity:1;background:#ffffffc7}.summon-body{z-index:2;text-align:center;flex-direction:column;align-items:center;gap:10px;margin-top:14px;display:flex;position:relative}.summon-body:before,.summon-body:after{opacity:.85;color:var(--cta-strong);pointer-events:none;font-size:14px;position:absolute;top:-6px}.summon-body:before{content:"*";left:18%}.summon-body:after{content:"*";right:18%}.summon-celebrate{color:#b5600f;background:linear-gradient(135deg,#ffe7b9f2,#ffd6a0e6);border-radius:999px;align-items:center;gap:8px;padding:6px 14px;font-size:17px;font-weight:800;display:inline-flex;box-shadow:0 12px 24px #ffc8784d}.summon-celebrate-icon{font-size:16px}.summon-celebrate-text{letter-spacing:.6px}.summon-congrats{color:#8f5a18;font-size:15px;font-weight:700}.summon-pet{aspect-ratio:1;filter:drop-shadow(0 22px 28px #ffc87859);justify-content:center;align-items:center;width:clamp(180px,54vw,240px);animation:3.4s ease-in-out infinite summonFloat;display:flex;position:relative}.summon-pet:before{content:"";filter:blur(6px);background:radial-gradient(#ffd69673,#0000 70%);width:86%;height:26%;position:absolute;bottom:10%;left:50%;transform:translate(-50%)}.summon-ring{pointer-events:none;background:radial-gradient(circle,#ffecbe2e,#0000 70%);border:2px solid #ffd69699;border-radius:50%;position:absolute;inset:8%;box-shadow:0 0 22px #ffd69659,inset 0 0 20px #ffd69638}.summon-pet:after{content:"";border:2px solid #ffd69699;border-radius:50%;width:82%;height:82%;position:absolute;box-shadow:inset 0 0 16px #ffd69640}.summon-pet img,.summon-pet .pet-emoji{object-fit:contain;width:72%;height:72%}.summon-petname{color:#3a2e2a;font-size:20px;font-weight:800}.summon-subtitle{color:#a06d22;font-size:13px;font-weight:600}.summon-reward{background:#ffffffdb;border:1px solid #ffd6968c;border-radius:16px;flex-direction:column;gap:4px;margin-top:6px;padding:10px 14px;display:flex;box-shadow:0 10px 22px #ffc87833}.summon-reward-title{color:#d07a16;align-items:center;gap:6px;font-size:14px;font-weight:700;display:inline-flex}.summon-reward-desc{color:#9b6a26;font-size:12px}.summon-medal{font-size:16px;animation:1s ease-in-out infinite summonMedalBob}@keyframes summonMedalBob{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}@media (prefers-reduced-motion:reduce){.summon-medal{animation:none}}.summon-actions{z-index:2;justify-content:center;gap:12px;margin-top:18px;display:flex;position:relative}.summon-confirm{color:#fff;background:linear-gradient(135deg,#f7b34a,#f0629b);border:1px solid #ffffffb3;position:relative;overflow:hidden;box-shadow:0 12px 24px #f0787859}.summon-confirm:after{content:"";opacity:.7;background:linear-gradient(120deg,#0000 20%,#ffffff80,#0000 70%);animation:2.4s ease-in-out infinite summonShine;position:absolute;inset:0;transform:translate(-60%)}.summon-error{color:#b7651b;text-align:center;background:#fffaf0d9;border:1px solid #ffd69699;border-radius:16px;margin-top:12px;padding:8px 12px;font-size:12px}@keyframes summonPulse{0%{box-shadow:0 18px 36px #ffc57838,0 0 0 1px #ffd69673}50%{box-shadow:0 24px 48px #ffc57852,0 0 0 2px #ffd6968c}to{box-shadow:0 18px 36px #ffc57838,0 0 0 1px #ffd69673}}.classroom-tray{z-index:45;border:1px solid rgba(var(--accent-rgb),.15);box-shadow:0 12px 24px rgba(var(--accent-rgb),.18);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#ffffffb8;border-radius:999px;gap:12px;padding:6px 8px;display:flex;position:fixed;bottom:18px;left:50%;transform:translate(-50%)}@media (max-width:640px){.classroom-tray,.batch-tray{bottom:78px}}.batch-tray{z-index:46;border:1px solid rgba(var(--accent-rgb),.18);box-shadow:0 14px 26px rgba(var(--accent-rgb),.22);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#ffffffdb;border-radius:999px;flex-wrap:wrap;align-items:center;gap:10px;padding:8px 10px;display:flex;position:fixed;bottom:16px;left:50%;transform:translate(-50%)}.batch-count{color:var(--text);border:1px solid rgba(var(--accent-rgb),.15);background:#ffffffe6;border-radius:999px;padding:4px 8px;font-size:12px;font-weight:700}.batch-count span{color:var(--accent-strong);margin:0 2px}.batch-actions{align-items:center;gap:6px;display:flex}.bulk-check{border:2px solid rgba(var(--accent-rgb),.4);color:#fff;z-index:6;background:#ffffffe6;border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;font-size:12px;font-weight:800;transition:transform .16s,background .16s,border-color .16s;display:flex;position:absolute;top:12px;left:12px}.bulk-check.is-on{background:linear-gradient(135deg,var(--accent),var(--accent-strong));border-color:rgba(var(--accent-rgb),.5);transform:scale(1.05)}.bulk-selected{border-color:rgba(var(--accent-rgb),.45);box-shadow:0 16px 30px rgba(var(--accent-rgb),.2),0 0 0 2px rgba(var(--accent-rgb),.2)}:root[data-classroom=on][data-page=dashboard] .batch-tray{display:none}@media (max-width:1024px){.classroom-search{justify-content:flex-start;width:100%}}:root[data-classroom=on][data-page=dashboard] .classroom-tray{display:none}:root[data-classroom=on][data-page=dashboard] .magic-fab{opacity:.35;transform:scale(.92)}.tray-btn{border:1px solid #0000;border-radius:999px;padding:8px 16px;font-size:12px;font-weight:700;transition:transform .16s,box-shadow .16s,background .16s}.tray-btn--primary{background:linear-gradient(135deg,var(--accent),var(--accent-strong));color:#fff;box-shadow:0 10px 18px rgba(var(--accent-rgb),.24)}.tray-btn--primary:hover{transform:translateY(-1px)}.tray-btn--ghost{border-color:rgba(var(--accent-rgb),.2);color:var(--text);background:#ffffffb3;box-shadow:0 6px 12px #0f172a1a}.tray-btn--ghost:hover{background:var(--accent-soft);transform:translateY(-1px)}.tray-select{border:1px solid rgba(var(--accent-rgb),.2);color:var(--text);background:#ffffffb8;border-radius:999px;min-width:108px;padding:9px 14px;font-size:12px;font-weight:700;line-height:1;box-shadow:0 6px 12px #0f172a1a}.tray-select:focus{border-color:rgba(var(--accent-rgb),.45);box-shadow:0 0 0 2px rgba(var(--accent-rgb),.18),0 6px 12px #0f172a1f;outline:none}@media (max-width:640px){.classroom-tray{justify-content:space-between;width:calc(100% - 2rem);bottom:92px}.tray-btn{text-align:center;flex:1}.tray-select{flex:1;min-width:120px}.card-island{aspect-ratio:4/5}}.magic-fab{z-index:50;border:1px solid var(--border);background:linear-gradient(135deg,#fffffff2,rgba(var(--accent-soft-rgb),.9));color:var(--text);box-shadow:var(--shadow);border-radius:999px;align-items:center;gap:8px;padding:12px 16px;font-size:13px;font-weight:700;transition:transform .16s,box-shadow .16s;display:inline-flex;position:fixed;bottom:30px;right:24px}.magic-fab:hover{box-shadow:0 18px 32px rgba(var(--accent-rgb),.25);transform:translateY(-2px)}.magic-fab-overlay{z-index:55;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#0f172a47;position:fixed;inset:0}.magic-fab-panel{border:1px solid var(--border);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#ffffffe6;border-radius:24px;width:min(320px,100% - 2rem);padding:16px;position:fixed;bottom:96px;right:24px;box-shadow:0 24px 48px #0000002e}.magic-fab-header{justify-content:space-between;align-items:center;display:flex}.magic-fab-close{border:1px solid var(--border);width:30px;height:30px;color:var(--muted);background:#fff;border-radius:50%;justify-content:center;align-items:center;display:inline-flex}.magic-fab-grid{gap:10px;margin-top:12px;display:grid}.magic-fab-item{border:1px solid var(--border);color:var(--text);background:#ffffffe6;border-radius:16px;align-items:center;gap:10px;padding:10px 12px;transition:transform .16s,background .16s;display:flex}.magic-fab-item:hover{background:var(--accent-soft);transform:translateY(-1px)}.magic-fab-icon{background:var(--accent-soft);width:34px;height:34px;color:var(--accent-strong);border-radius:12px;justify-content:center;align-items:center;display:inline-flex}.magic-fab-icon[data-tone=mint]{color:#2e9a6a;background:#c6f0dccc}.magic-fab-icon[data-tone=rose]{background:rgba(var(--accent-soft-rgb),.8);color:#d66a90}.magic-fab-icon[data-tone=gold]{color:#c58b1f;background:#ffecc6d9}.magic-fab-icon[data-tone=lavender]{color:#7a5bd6;background:#e6defcd9}.magic-fab-icon[data-tone=sky]{color:#3a7cc5;background:#d2eaffd9}.magic-fab-icon[data-tone=slate]{color:#5a6b85;background:#e1e6efd9}.store-item-card{border:1px solid rgba(var(--accent-rgb),.18);box-shadow:0 12px 24px rgba(var(--accent-rgb),.12);background:linear-gradient(#fffffff5,#faf6f8e6)}.store-hero{background:radial-gradient(circle at 12% 18%,rgba(var(--accent-soft-rgb),.7),transparent 55%),radial-gradient(circle at 85% 10%,#ffffffe6,transparent 45%),linear-gradient(180deg,#fffffff0,#f5f8ffe0);border:1px solid rgba(var(--accent-rgb),.2);box-shadow:0 22px 44px rgba(var(--accent-rgb),.16);border-radius:28px;padding:24px;position:relative;overflow:hidden}.store-shell{background:#fff;border:1px solid #dde3ef;border-radius:28px;padding:18px;box-shadow:0 18px 36px #23304a1f}.store-shell--compact{box-shadow:none;background:0 0;border:none;border-radius:20px;padding:0}.store-topbar{border-bottom:1px solid #e3e8f2;gap:12px;margin-bottom:14px;padding:4px 6px 12px;display:grid}.store-topbar-row{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;display:flex}.store-tabs-bar{z-index:6;background:#fffffff5;border:1px solid #e3e8f2;border-radius:16px;align-self:flex-start;padding:6px;position:sticky;top:88px;box-shadow:0 10px 20px #5a698c1f}.store-tabs-bar--modal{width:100%;box-shadow:none;background:0 0;border:none;padding:0;position:static;top:auto}.store-brand{align-items:center;gap:12px;display:flex}.store-brand-icon{color:#fff;background:#5b6bff;border-radius:14px;justify-content:center;align-items:center;width:44px;height:44px;font-size:20px;display:flex;box-shadow:0 12px 22px #5b6bff4d}.store-brand-name{color:#1f2a44;font-size:20px;font-weight:800}.store-brand-sub{letter-spacing:1.6px;color:#a8b0c4;font-size:10px;font-weight:700}.store-tabs{background:#ffffffe0;border:1px solid #96a0be47;border-radius:16px;gap:6px;padding:6px;display:inline-flex;box-shadow:0 12px 24px #5e6ea01f}.store-tab{color:#667086;cursor:pointer;background:0 0;border:none;border-radius:12px;align-items:center;gap:6px;padding:8px 14px;font-size:12px;font-weight:700;transition:background .16s,color .16s,box-shadow .16s,transform .16s;display:inline-flex}.store-tab.is-active{color:#3f4adb;background:linear-gradient(135deg,#5b6bff1f,#8c78ff38);transform:translateY(-1px);box-shadow:0 8px 16px #3f4adb2e}.store-tab-icon{color:#3f4adb;background:#5b6bff1f;border-radius:6px;justify-content:center;align-items:center;width:18px;height:18px;display:inline-flex}.store-hero-bar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;width:100%;display:flex}.store-hero-bar--tabs{justify-content:flex-start}.store-hero-stat{color:#6b758a;background:#ffffffe6;border:1px solid #96a0be4d;border-radius:999px;align-items:center;gap:8px;padding:6px 12px;font-size:12px;font-weight:700;display:inline-flex;box-shadow:0 10px 18px #5a698c1f}.store-hero-stat span{color:var(--accent-strong);font-size:14px}.store-topbar-meta{text-align:center;background:#fff;border-radius:16px;min-width:90px;padding:10px 14px;box-shadow:0 10px 20px #5a698c1a}.store-meta-label{color:#9aa3b5;font-size:10px}.store-meta-value{color:#3f4adb;font-size:18px;font-weight:800}.store-panel{background:#f3f6fb;border:1px solid #e1e7f2;border-radius:24px;padding:18px}.store-shell--compact .store-panel{background:0 0;border:none;border-radius:18px;padding:10px}.store-panel--compact{background:0 0!important;border:none!important;border-radius:16px!important;padding:8px!important}.store-panel--compact .store-card-grid{justify-items:stretch;width:100%}.store-panel-meta{color:#6b758a;background:#ffffffeb;border:1px solid #e1e7f2;border-radius:999px;align-items:center;gap:8px;margin-bottom:12px;padding:6px 12px;font-size:12px;font-weight:700;display:inline-flex}.store-panel-meta-value{color:var(--accent-strong);font-size:14px}.store-debug{z-index:9999;color:#e7ecf5;white-space:pre-wrap;background:#0f1219db;border-radius:10px;max-width:min(90vw,420px);max-height:45vh;padding:8px 10px;font-size:10px;line-height:1.4;position:fixed;bottom:12px;right:12px;overflow:auto;box-shadow:0 12px 24px #0000004d}.store-card-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));justify-items:center;gap:16px;display:grid}.store-card{text-align:left;background:#fff;border:1px solid #e2e8f4;border-radius:22px;flex-direction:column;width:220px;min-height:260px;transition:transform .16s,box-shadow .16s;display:flex;overflow:hidden;box-shadow:0 18px 28px #23304a1f}.store-card:hover{transform:translateY(-3px);box-shadow:0 22px 34px #444c6029}.store-card.is-out{opacity:.6;box-shadow:none}.store-card-top{background:#eef2ff;justify-content:flex-start;align-items:center;height:104px;padding-left:16px;display:flex;position:relative}.store-card-icon{color:#5b6bff;background:#ffffffe6;border-radius:50%;justify-content:center;align-items:center;width:60px;height:60px;font-size:26px;display:flex;box-shadow:0 8px 16px #00000014}.store-card-badge{color:#fff;background:#f5b221;border-radius:999px;justify-content:center;align-items:center;min-width:28px;height:30px;padding:0 10px;font-size:11px;font-weight:700;display:flex;position:absolute;top:12px;right:12px;box-shadow:0 8px 14px #f6b81c4d}.store-card-body{text-align:left;background:#fff;border-top:1px solid #eef2f8;flex-direction:column;flex:1;align-items:flex-start;gap:4px;padding:12px 16px 16px;display:flex}.store-card-title{color:#2f3b53;font-size:15px;font-weight:800}.store-card-sub{color:#8a94a7;min-height:12px;margin-top:4px;font-size:10px}.store-card-footer{color:#7a869c;justify-content:space-between;align-items:center;width:100%;margin-top:8px;font-size:10px;display:flex}.store-card-point{align-items:center;gap:4px;font-weight:700;display:inline-flex}.store-card-button{color:#fff;background:#5b6bff;border-radius:14px;width:100%;margin-top:8px;padding:8px 12px;font-size:12px;font-weight:700;box-shadow:0 10px 18px #5b6bff47}.store-card.tone-0 .store-card-top{background:#e8f0ff}.store-card.tone-0 .store-card-icon{color:#5b6bff}.store-card.tone-0 .store-card-button{background:#5b6bff}.store-card.tone-1 .store-card-top{background:#f2e9ff}.store-card.tone-1 .store-card-icon{color:#8a63ff}.store-card.tone-1 .store-card-button{background:#8a63ff}.store-card.tone-2 .store-card-top{background:#fff1e2}.store-card.tone-2 .store-card-icon{color:#ff8a34}.store-card.tone-2 .store-card-button{background:#ff8a34}.store-card.tone-3 .store-card-top{background:#fbe9f4}.store-card.tone-3 .store-card-icon{color:#ff5ea1}.store-card.tone-3 .store-card-button{background:#ff5ea1}.store-card.tone-4 .store-card-top{background:#e6f6ff}.store-card.tone-4 .store-card-icon{color:#3bb1ff}.store-card.tone-4 .store-card-button{background:#3bb1ff}.store-card.tone-5 .store-card-top{background:#fff8d9}.store-card.tone-5 .store-card-icon{color:#f4b024}.store-card.tone-5 .store-card-button{background:#f4b024}.store-shell--compact .store-card-grid{grid-template-columns:1fr!important;justify-items:stretch!important}.store-shell--compact .store-card{text-align:center;min-height:auto;width:100%!important;max-width:none!important}.store-shell--compact .store-card-top{height:92px;justify-content:center!important;padding-left:0!important}.store-shell--compact .store-card-icon{width:56px;height:56px;font-size:24px}.store-shell--compact .store-card-body{text-align:center;align-items:center;padding:10px 14px 14px}.store-card-compact{text-align:center;grid-template-columns:1fr;place-items:center;gap:10px;width:100%;padding:12px 14px 16px;display:grid}.store-card-compact-icon{width:72px;height:72px;box-shadow:inset 0 0 12px rgba(var(--accent-rgb),.12),0 10px 18px rgba(var(--accent-rgb),.12);background:#ffffffeb;border-radius:18px;place-items:center;display:grid;position:relative}.store-card-compact-emoji{font-size:32px}.store-card-compact-badge{color:#fff;background:#f5b221;border-radius:999px;justify-content:center;align-items:center;min-width:28px;height:28px;padding:0 8px;font-size:11px;font-weight:700;display:inline-flex;position:absolute;top:-6px;right:-6px;box-shadow:0 8px 14px #f6b81c4d}.store-card-compact-body{text-align:center;place-items:center;gap:6px;width:100%;display:grid}.store-card--compact .store-card-footer{justify-content:center;gap:12px}.store-card--compact .store-card-button{width:min(100%,240px);padding:9px 18px}.store-card-grid--compact{grid-template-columns:1fr;justify-items:stretch}.store-card--compact{text-align:center;width:100%;max-width:none;min-height:auto}.store-card--compact .store-card-top{justify-content:center;height:92px;padding-left:0}.store-card--compact .store-card-icon{width:56px;height:56px;font-size:24px}.store-card--compact .store-card-body{text-align:center;align-items:center;padding:10px 14px 14px}.store-records{gap:12px;display:grid}.store-record-list{gap:10px;display:grid}.store-record-item{background:#fff;border:1px solid #dce4f0cc;border-radius:16px;justify-content:space-between;align-items:center;gap:12px;padding:12px 14px;display:flex}.store-record-title{color:#2f3b53;font-size:13px;font-weight:700}.store-record-sub{color:#8a94a7;font-size:11px}.store-record-time{color:#9aa3b5;font-size:11px}.store-manage-panel{gap:16px;display:grid}.store-manage-tip{color:#8a94a7;font-size:11px}:root{--store-bg-0:#e8f0ff;--store-accent-0:#5b6bff;--store-bg-1:#f2e9ff;--store-accent-1:#8a63ff;--store-bg-2:#fff1e2;--store-accent-2:#ff8a34;--store-bg-3:#fbe9f4;--store-accent-3:#ff5ea1;--store-bg-4:#e6f6ff;--store-accent-4:#3bb1ff;--store-bg-5:#fff8d9;--store-accent-5:#f4b024}.store-hero:before,.store-hero:after{content:"";filter:blur();opacity:.55;pointer-events:none;border-radius:50%;position:absolute}.store-hero:before{background:radial-gradient(circle,rgba(var(--accent-rgb),.2),transparent 70%);width:180px;height:180px;top:-50px;left:-40px}.store-hero:after{background:radial-gradient(circle,rgba(var(--accent-soft-rgb),.7),transparent 70%);width:220px;height:220px;bottom:-80px;right:-60px}.store-hero-content{z-index:1;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;display:flex;position:relative}.store-hero-badge{background:rgba(var(--accent-soft-rgb),.9);color:var(--accent-strong);border-radius:999px;align-items:center;gap:6px;padding:6px 12px;font-size:11px;font-weight:700;display:inline-flex}.store-hero-title{font-size:30px;font-weight:800;font-family:var(--font-display),var(--font-body),var(--font-body-latin),sans-serif;letter-spacing:.4px;color:var(--text);margin-top:8px}.store-hero-sub{color:var(--muted);margin-top:6px;font-size:13px}.store-hero-meta{border:1px solid rgba(var(--accent-rgb),.25);text-align:center;min-width:120px;box-shadow:0 14px 26px rgba(var(--accent-rgb),.18);background:#fffffff2;border-radius:20px;padding:12px 16px}.store-hero-meta-label{color:var(--muted);font-size:11px}.store-hero-meta-value{color:var(--accent-strong);font-size:22px;font-weight:800}.store-stage{background:radial-gradient(circle at 18% 18%,rgba(var(--accent-soft-rgb),.5),transparent 55%),linear-gradient(180deg,#fffffffa,#f2f6ffeb);border:1px solid rgba(var(--accent-rgb),.2);box-shadow:0 20px 36px rgba(var(--accent-rgb),.14);border-radius:28px;padding:22px;position:relative;overflow:hidden}.store-stage:after{content:"";background-image:radial-gradient(rgba(var(--accent-rgb),.08)1px,transparent 1px);opacity:.35;pointer-events:none;background-size:18px 18px;position:absolute;inset:0}.store-stage-head{justify-content:space-between;align-items:center;gap:12px;display:flex}.store-kicker{color:var(--accent-strong);font-size:11px;font-weight:700}.store-stage-title{font-size:22px;font-weight:800;font-family:var(--font-display),var(--font-body),var(--font-body-latin),sans-serif;margin-top:6px}.store-stage-sub{color:var(--muted);margin-top:4px;font-size:12px}.store-stage-grid{z-index:1;gap:16px;margin-top:16px;display:grid;position:relative}.store-feature-card{text-align:left;background:linear-gradient(180deg,#fffffffa,#f9f8ffeb)padding-box,linear-gradient(135deg,rgba(var(--accent-rgb),.35),rgba(var(--accent-strong-rgb),.25))border-box;width:100%;box-shadow:0 20px 40px rgba(var(--accent-rgb),.2),inset 0 0 20px #fff9;cursor:pointer;border:1px solid #0000;border-radius:24px;gap:12px;padding:18px;transition:transform .16s,box-shadow .16s,border-color .16s;display:grid;position:relative;overflow:hidden}.store-feature-card:hover{box-shadow:0 26px 44px rgba(var(--accent-rgb),.24);transform:translateY(-2px)}.store-feature-card.is-out{opacity:.6;box-shadow:none}.store-feature-card:disabled,.store-shelf-card:disabled{cursor:not-allowed}.store-feature-icon{width:72px;height:72px;box-shadow:inset 0 0 12px rgba(var(--accent-rgb),.12),0 10px 18px rgba(var(--accent-rgb),.15);background:#fffffffa;border-radius:22px;justify-content:center;align-items:center;font-size:32px;display:flex}.store-feature-name{font-size:20px;font-weight:800}.store-feature-desc{color:var(--muted);font-size:12px}.store-feature-meta{flex-wrap:wrap;gap:8px;display:flex}.store-feature-cta{background:linear-gradient(135deg,rgba(var(--accent-rgb),.3),rgba(var(--accent-strong-rgb),.3));color:var(--accent-strong);border-radius:999px;justify-content:center;align-items:center;margin-top:6px;padding:6px 14px;font-size:12px;font-weight:700;display:inline-flex}.store-shelf-grid{grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px;display:grid}.store-shelf-card{text-align:center;border:1px solid rgba(var(--accent-rgb),.18);box-shadow:0 14px 26px rgba(var(--accent-rgb),.16);cursor:pointer;background:#fffffffa;border-radius:20px;gap:6px;padding:12px 10px;transition:transform .16s,box-shadow .16s;display:grid}.store-shelf-card:hover{box-shadow:0 18px 30px rgba(var(--accent-rgb),.2);transform:translateY(-2px)}.store-shelf-card.is-out{opacity:.6;box-shadow:none}.store-shelf-icon{width:56px;height:56px;box-shadow:inset 0 0 10px rgba(var(--accent-rgb),.12),0 8px 14px rgba(var(--accent-rgb),.14);background:#fffffffa;border-radius:18px;justify-content:center;align-items:center;margin:0 auto;font-size:24px;display:flex}.store-shelf-name{font-size:14px;font-weight:700}.store-shelf-desc{color:var(--muted);min-height:14px;font-size:11px}.store-shelf-meta{flex-wrap:wrap;justify-content:center;gap:6px;display:flex}.store-chip{background:linear-gradient(135deg,rgba(var(--accent-rgb),.18),rgba(var(--accent-strong-rgb),.12));color:var(--accent-strong);border-radius:999px;padding:3px 8px;font-size:10px;font-weight:700}.store-chip.is-out{color:var(--muted);background:#0000000d}.store-empty{border:1px dashed rgba(var(--accent-rgb),.2);text-align:center;color:var(--muted);border-radius:18px;margin-top:16px;padding:24px}.store-editor{border:1px dashed rgba(var(--accent-rgb),.22);background:#ffffffeb;border-radius:24px;padding:0;overflow:hidden}.store-editor-summary{cursor:pointer;justify-content:space-between;align-items:center;gap:12px;padding:16px 18px;list-style:none;display:flex}.store-editor-summary::-webkit-details-marker{display:none}.store-editor-title{font-size:16px;font-weight:700}.store-editor-sub{color:var(--muted);font-size:12px}.store-editor-pill{background:rgba(var(--accent-rgb),.12);color:var(--accent-strong);border-radius:999px;padding:6px 12px;font-size:11px;font-weight:700}.store-editor-body{border-top:1px dashed rgba(var(--accent-rgb),.2);padding:16px 18px 20px}@media (min-width:1024px){.store-stage-grid{grid-template-columns:minmax(240px,1.1fr) minmax(280px,2fr);align-items:start}}.store-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px;display:grid}@media (min-width:1280px){.store-grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:18px}}@media (min-width:1536px){.store-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}}.store-item-icon{width:52px;height:52px;box-shadow:inset 0 0 12px rgba(var(--accent-rgb),.15);background:#fffffff2;border-radius:18px;justify-content:center;align-items:center;font-size:24px;display:flex}.store-item-card .store-item-icon{border-radius:20px;width:60px;height:60px;font-size:28px}.store-manage-card{border:1px solid rgba(var(--accent-rgb),.18);box-shadow:0 10px 20px rgba(var(--accent-rgb),.12);background:linear-gradient(#fffffffa,#faf6f8eb)}.store-manage-card.is-open{border-color:rgba(var(--accent-rgb),.45);box-shadow:0 16px 30px rgba(var(--accent-rgb),.18);background:linear-gradient(180deg,#fffffffc,rgba(var(--accent-soft-rgb),.9))}.store-manage-head{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.store-manage-meta{flex-direction:column;gap:2px;display:flex}.store-manage-form{border:1px dashed rgba(var(--accent-rgb),.25);box-shadow:inset 0 0 12px rgba(var(--accent-rgb),.12);background:#ffffffdb;border-radius:16px;margin-top:14px;padding:12px}.student-choice{border:1px solid rgba(var(--accent-rgb),.18);box-shadow:0 10px 18px rgba(var(--accent-rgb),.12);background:#fffffff5;border-radius:18px;transition:transform .16s,box-shadow .16s,border-color .16s}.student-choice button{text-align:left;width:100%;padding:14px 16px}.student-choice:hover{box-shadow:0 14px 26px rgba(var(--accent-rgb),.18);border-color:rgba(var(--accent-rgb),.3);transform:translateY(-1px)}.student-choice.is-disabled{opacity:.55;box-shadow:none}.student-choice.is-disabled:hover{box-shadow:none;transform:none}.pet-choice-grid{grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:4px;display:grid}@media (min-width:768px){.pet-choice-grid{grid-template-columns:repeat(auto-fit,minmax(130px,1fr))}}.pet-choice-card{box-shadow:none;background:0 0;border:none;border-radius:18px;transition:transform .18s;position:relative;overflow:hidden}.pet-choice-card:before{content:"";opacity:0;pointer-events:none;background:0 0;position:absolute;inset:0}.pet-choice-card:hover,.pet-choice-card.is-selected{transform:translateY(-2px)}.pet-choice-card.is-disabled{opacity:.55;box-shadow:none}.pet-choice-card.is-disabled:hover{box-shadow:none;transform:none}.pet-choice-button{cursor:pointer;background:0 0;border:none;flex-direction:column;align-items:center;gap:2px;width:100%;height:100%;padding:2px 2px 6px;display:flex}.pet-choice-button:disabled{cursor:not-allowed}.pet-choice-ill{border:1px solid rgba(var(--accent-rgb),.18);width:clamp(104px,14vw,132px);height:clamp(104px,14vw,132px);box-shadow:none;background:0 0;border-radius:14px;justify-content:center;align-items:center;padding:0;display:flex}.pet-choice-ill img,.pet-choice-ill .pet-emoji{object-fit:contain;width:100%;height:100%}.pet-choice-name{color:var(--text);margin-top:2px;font-size:14px;font-weight:700}.pet-choice-tagline{display:none}.pet-choice-card.is-selected .pet-choice-ill{border-color:rgba(var(--accent-rgb),.45);box-shadow:0 0 0 2px rgba(var(--accent-rgb),.14)}.pet-choice-badge{background:linear-gradient(135deg,rgba(var(--accent-rgb),.95),rgba(var(--accent-strong-rgb),.95));color:#fff;box-shadow:0 6px 12px rgba(var(--accent-rgb),.25);border-radius:999px;padding:3px 8px;font-size:10px;font-weight:700;position:absolute;top:10px;right:10px}.modal-overlay{overscroll-behavior:contain}.modal-scroll{overscroll-behavior:contain;-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:rgba(var(--accent-rgb),.22)transparent}.modal-scroll::-webkit-scrollbar{width:6px}.modal-scroll::-webkit-scrollbar-track{background:0 0}.modal-scroll::-webkit-scrollbar-thumb{background:rgba(var(--accent-rgb),.22);background-clip:content-box;border:2px solid #0000;border-radius:999px}.modal-scroll::-webkit-scrollbar-thumb:hover{background:rgba(var(--accent-rgb),.36)}.modal-backdrop{z-index:60;background:radial-gradient(circle at 20% 20%,rgba(var(--accent-rgb),.18),transparent 55%),radial-gradient(circle at 80% 10%,rgba(var(--accent-soft-rgb),.6),transparent 50%),#0a0a1266;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.modal-panel{border:1px solid rgba(var(--accent-rgb),.18);background:#fffffffa;border-radius:32px;flex-direction:column;width:min(1120px,96vw);height:min(86vh,920px);min-height:70vh;max-height:92vh;display:flex;overflow:hidden;box-shadow:0 30px 90px #00000047}.modal-hero{background:linear-gradient(135deg,rgba(var(--accent-soft-rgb),.85),#fffffffa);border-bottom:1px solid rgba(var(--accent-rgb),.18);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding:26px 24px 22px;display:flex;position:relative;overflow:hidden}.modal-hero-main{z-index:1;align-items:center;gap:12px;display:flex;position:relative}.modal-hero-icon{color:#fff;background:linear-gradient(135deg,#5b6bff,#7b8bff);border-radius:14px;justify-content:center;align-items:center;width:44px;height:44px;font-size:20px;display:inline-flex;box-shadow:0 14px 24px #5b6bff47}.modal-hero:after{content:"";background-image:radial-gradient(rgba(var(--accent-rgb),.14)1px,transparent 1px);opacity:.35;pointer-events:none;background-size:18px 18px;position:absolute;inset:0}.modal-hero-content{z-index:1;gap:4px;display:grid;position:relative}.modal-hero-extra{z-index:1;flex-basis:100%;margin-top:10px;position:relative}.modal-header-dock{z-index:2;border-bottom:1px solid rgba(var(--accent-rgb),.14);background:#fffffff5;padding:10px 22px 12px;position:relative}.modal-header-dock:empty{display:none}.modal-hero-extra .store-tabs-bar{background:#ffffffeb;border:1px solid #e3e8f2;border-radius:14px;width:fit-content;padding:6px;box-shadow:0 10px 18px #5a698c1f}.modal-hero-kicker{color:var(--accent-strong);font-size:11px;font-weight:700}.modal-hero-title{color:var(--text);letter-spacing:.3px;font-size:24px;font-weight:800;line-height:1.2}.modal-hero-sub{letter-spacing:2px;text-transform:uppercase;color:#9aa4b8;font-size:11px}.modal-hero-orb{opacity:.6;filter:blur();pointer-events:none;border-radius:50%;position:absolute}.modal-hero-orb.orb-1{background:radial-gradient(circle,rgba(var(--accent-rgb),.35),transparent 70%);width:180px;height:180px;top:-70px;left:-50px}.modal-hero-orb.orb-2{background:radial-gradient(circle,rgba(var(--accent-soft-rgb),.8),transparent 70%);width:220px;height:220px;bottom:-90px;right:-70px}.modal-close{border:1px solid rgba(var(--accent-rgb),.16);width:32px;height:32px;color:var(--accent-strong);opacity:.72;background:#ffffffb3;border-radius:10px;justify-content:center;align-items:center;transition:transform .16s,box-shadow .16s,background .16s,opacity .16s;display:inline-flex;position:relative}.modal-close:hover{background:rgba(var(--accent-rgb),.14);box-shadow:0 8px 16px rgba(var(--accent-rgb),.14);opacity:1;transform:translateY(-1px)}.modal-hero .modal-close{z-index:1;position:absolute;top:16px;right:16px}.modal-body{background:linear-gradient(#fffffff5,#f8f8fce6);flex:1;padding:18px 22px 24px;overflow:auto}.modal-panel--store .modal-hero{background:var(--panel);border-bottom:1px solid var(--border);z-index:2;padding:18px 24px;overflow:visible}.modal-panel--store .modal-hero-extra{justify-content:flex-start;align-items:center;gap:10px;margin-top:8px;display:flex}.modal-panel--store .modal-header-dock{background:var(--panel);border-bottom:1px solid var(--border);padding:10px 18px 12px}.modal-panel--store .modal-header-dock .store-tabs-bar--modal{width:100%}.modal-panel--store .store-tabs-bar--modal{z-index:2;width:auto;position:relative}.modal-panel--store .modal-body{padding-top:14px}.modal-panel--store .modal-hero:after,.modal-panel--store .modal-hero-orb{display:none}.modal-panel--store .modal-hero-main{gap:10px}.modal-panel--store .modal-hero-icon{background:var(--accent);width:40px;height:40px;box-shadow:0 10px 20px rgba(var(--accent-rgb),.25);border-radius:14px}.modal-panel--store .modal-hero-title{letter-spacing:0;font-size:22px}.modal-panel--store .modal-hero-sub{letter-spacing:1.6px;text-transform:uppercase;color:var(--muted);font-size:11px}.modal-panel--store .store-hero-bar{flex-wrap:wrap;gap:10px}.modal-panel--store .store-hero-stat{box-shadow:none;color:var(--muted);background:0 0;border:none;padding:0;font-weight:600}.modal-panel--store .store-hero-stat span{color:var(--accent-strong)}.modal-panel--store .store-tabs{background:rgba(var(--accent-soft-rgb),.55);border:1px solid rgba(var(--accent-rgb),.18);box-shadow:none;z-index:2;border-radius:14px;padding:4px;position:relative}.modal-panel--store .store-tab{color:var(--text);border-radius:10px;padding:6px 12px;font-size:12px}.modal-panel--store .store-tab.is-active{color:var(--accent-strong);box-shadow:0 6px 12px rgba(var(--accent-rgb),.18);background:#fff;transform:none}.modal-panel--store .store-tab-icon{color:var(--muted);opacity:.7;background:0 0}.modal-panel--store .store-tab.is-active .store-tab-icon{color:var(--accent-strong);opacity:1}.modal-panel--admin{border:1px solid var(--border);background:#f6f7fb;width:min(1100px,96vw)}.modal-panel--admin .modal-hero{border-bottom:1px solid var(--border);z-index:3;background:#fff;padding:18px 18px 16px}.modal-panel--admin .modal-hero:after,.modal-panel--admin .modal-hero-orb{display:none}.modal-panel--admin .modal-hero-icon{background:rgba(var(--accent-rgb),.18);width:36px;height:36px;color:var(--accent-strong);box-shadow:none;border-radius:10px}.modal-panel--admin .modal-hero-title{letter-spacing:0;font-size:20px;line-height:1.2}.modal-panel--admin .modal-hero-sub{text-transform:none;letter-spacing:.4px}.modal-panel--admin .modal-hero-extra{flex:100%;width:100%;margin-top:10px;display:flex}.modal-panel--admin .modal-header-dock{border-bottom:1px solid var(--border);background:#fff;padding:10px 18px 12px}.modal-panel--admin .modal-header-dock .manage-tabs-bar,.modal-panel--admin .modal-hero-extra .manage-tabs-bar{width:100%}.modal-panel--admin .modal-hero-extra:empty{margin-top:0;display:none}.modal-panel--admin .modal-body{z-index:1;background:#f6f7fb;padding:16px;position:relative}.modal-panel--leaderboard{border:1px solid var(--border);background:#f6f7fb;width:min(900px,92vw)}.modal-panel--leaderboard .modal-hero{border-bottom:1px solid var(--border);background:#fff;padding:16px 18px 14px}.modal-panel--leaderboard .modal-hero:after,.modal-panel--leaderboard .modal-hero-orb,.modal-panel--leaderboard .modal-hero-sub,.modal-panel--leaderboard .modal-header-dock{display:none}.modal-panel--leaderboard .modal-hero-icon{background:rgba(var(--accent-rgb),.16);width:36px;height:36px;color:var(--accent-strong);box-shadow:none;border-radius:10px}.modal-panel--leaderboard .modal-hero-title{letter-spacing:0;font-size:20px}.modal-panel--leaderboard .modal-hero-extra{margin:0;display:none}.modal-panel--leaderboard .modal-body{background:#f6f7fb;padding:14px}.modal-panel--leaderboard .leaderboard-shell{max-width:760px;margin:0 auto}.modal-panel--activity{width:min(880px,92vw)}.modal-panel--activity .modal-hero{background:var(--panel);border-bottom:1px solid var(--border);flex-wrap:nowrap;padding:16px 20px}.modal-panel--activity .modal-hero:after,.modal-panel--activity .modal-hero-orb,.modal-panel--activity .modal-hero-extra{display:none}.modal-panel--activity .modal-hero-icon{background:rgba(var(--accent-rgb),.16);width:36px;height:36px;box-shadow:none;border-radius:12px}.modal-panel--activity .modal-hero-title{letter-spacing:0;font-size:20px}.modal-panel--activity .modal-body{flex-direction:column;padding:12px 18px 18px;display:flex;overflow:hidden}.modal-body .store-topbar{z-index:6;background:#fff;border-radius:18px;padding-top:10px;position:sticky;top:0}.modal-body .store-tabs-bar{box-shadow:none;background:0 0;border:none;padding:0;position:static;top:auto}@media (max-width:640px){.modal-backdrop{justify-content:stretch;align-items:stretch;padding:0}.modal-panel{border-radius:0;width:100%;height:100%;max-height:100vh}.modal-hero{padding:16px 14px}.modal-hero-title{font-size:20px}.modal-header-dock,.modal-panel--admin .modal-header-dock{padding:8px 14px 10px}.modal-body{padding:12px 14px 16px}.modal-panel--store .modal-hero{padding:14px 14px 12px}.modal-panel--store .modal-hero-extra{width:100%;margin-top:8px}.modal-panel--store .store-tabs-bar--modal{width:100%}.modal-panel--store .store-tabs{flex-wrap:nowrap;justify-content:space-between;width:100%}.modal-panel--store .store-tab{flex:1;justify-content:center;padding:6px 8px;font-size:11px}.modal-panel--store .store-hero-stat{font-size:11px}}.magic-fab-footer{justify-content:flex-start;margin-top:12px;display:flex}.release-notice-backdrop{z-index:75;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0c101880;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.release-notice-panel{border:1px solid rgba(var(--accent-rgb),.2);background:#fff;border-radius:20px;width:min(560px,100%);padding:18px 18px 16px;box-shadow:0 20px 48px #00000038}.release-notice-kicker{background:rgba(var(--accent-rgb),.14);color:var(--accent-strong);border-radius:999px;align-items:center;gap:6px;padding:4px 10px;font-size:12px;font-weight:700;display:inline-flex}.release-notice-title{color:var(--text);margin-top:10px;font-size:24px;line-height:1.3}.release-notice-summary{color:var(--muted);margin-top:6px;font-size:14px}.release-notice-meta{flex-wrap:wrap;gap:8px;margin-top:12px;display:flex}.release-notice-meta span{border:1px solid var(--border);color:var(--muted);background:var(--panel);border-radius:999px;padding:3px 10px;font-size:12px}.release-notice-list{gap:8px;margin-top:12px;display:grid}.release-notice-list li{border:1px solid var(--border);background:var(--panel);color:var(--text);border-radius:12px;padding:8px 10px;font-size:13px;line-height:1.5}.release-notice-actions{justify-content:flex-end;margin-top:14px;display:flex}@media (max-width:640px){.release-notice-backdrop{padding:12px}.release-notice-panel{border-radius:16px;padding:14px}.release-notice-title{font-size:20px}}@media (max-width:1024px){.magic-fab,.magic-fab-overlay,.magic-fab-panel{display:none}}.card-link-muted{color:var(--accent-strong);font-size:11px;font-weight:500;transition:color .16s}.card-link-muted:hover{color:var(--accent-strong)}.pet-layer{z-index:2;pointer-events:none;justify-content:flex-start;align-items:flex-end;width:58%;height:70%;display:flex;position:absolute;bottom:24px;left:14px}.pet-layer .pet-ill-hero{width:100%;height:100%}.card-meta{min-height:96px;padding-top:6px;padding-left:20px}.card-meta-3d{z-index:3;margin-left:58%;padding-top:20px;padding-left:18px;position:relative}.card-actions{z-index:3;align-items:center;gap:8px;display:flex;position:absolute;bottom:12px;right:12px}.card-actions.card-actions-island{bottom:12px;right:12px}.egg-card .pet-figure img,.egg-card .pet-figure .pet-emoji{filter:drop-shadow(0 8px 18px rgba(var(--accent-rgb),.24))}.egg-card .pet-ill:before{background:radial-gradient(circle at 30% 30%,rgba(var(--accent-soft-rgb),.85),transparent 70%)}.egg-card .pet-ill:after{background:radial-gradient(ellipse,rgba(var(--accent-rgb),.18),transparent 70%)}.btn-link-pill{border:1px solid rgba(var(--accent-rgb),.4);background:rgba(var(--accent-soft-rgb),.6);color:var(--accent-strong);border-radius:999px;padding:5px 12px;font-weight:600;transition:background .18s,border-color .18s,color .18s}.btn-link-pill:hover{background:rgba(var(--accent-rgb),.25);border-color:rgba(var(--accent-rgb),.55)}.progress-line{background:rgba(var(--accent-rgb),.16);z-index:0;border-radius:999px;width:100%;height:4px;position:relative;overflow:hidden}.progress-line__fill{background:linear-gradient(90deg,var(--accent),var(--accent-strong));border-radius:999px;height:100%;display:block}.progress-line-island{background:var(--accent-soft);border-radius:2px;width:80%;height:4px;position:absolute;bottom:10px;left:10%}@supports (color:color-mix(in lab, red, red)){.progress-line-island{background:color-mix(in srgb,var(--accent-soft)60%,var(--panel))}}.progress-line-island{z-index:1}@media (hover:hover) and (pointer:fine){.card-island:hover .card-hover-tip{opacity:1;transform:translateY(0)}}@media (hover:none){.card-hover-tip{display:none}}.progress-line-3d{width:80%;height:3px;position:absolute;bottom:10px;left:10%}@media (max-width:640px){.pet-portrait{flex-basis:52%;min-width:120px;max-width:180px;margin-left:-6px}.pet-figure{transform:translate(-6px)translateY(-4px)scale(1.08)}.card-meta{min-height:84px;padding-left:14px}.card-meta-3d{margin-left:52%;padding-top:16px;padding-left:12px}.pet-layer{width:54%;height:68%;bottom:22px;left:10px}.progress-line-3d{width:84%;bottom:8px;left:8%}.card-island{min-height:220px}.card-island-head{top:4px}.card-island-name{max-width:110px;min-height:2.2em;font-size:20px}.pet-ill-island{width:max(140px,82%)}.card-island-level-float{padding:3px 8px;font-size:9px;top:30%;right:16%}.card-hover-tip{bottom:24px;left:12px}.card-island-link{bottom:24px;right:12px}.reward-bubble{font-size:11px;top:50%}.progress-line-island{width:84%;bottom:8px;left:8%}}.soft-progress{background:linear-gradient(180deg,#ffffffe6,rgba(var(--accent-soft-rgb),.7));width:100%;height:10px;box-shadow:inset 0 2px 6px rgba(var(--accent-rgb),.18);border-radius:999px;position:relative;overflow:hidden}.soft-progress__fill{background:linear-gradient(90deg,var(--accent),var(--accent-strong));height:100%;box-shadow:0 6px 14px rgba(var(--accent-rgb),.22);border-radius:999px;display:block}.egg-card{background:linear-gradient(140deg,#fffffff2,rgba(var(--accent-soft-rgb),.9));border-style:dashed;border-color:rgba(var(--accent-rgb),.45)}@keyframes petCheer{0%{transform:translateY(-10px)scale(1.05)}40%{transform:translateY(-18px)scale(1.08)rotate(-3deg)}70%{transform:translateY(-8px)scale(1.02)rotate(2deg)}to{transform:translateY(-10px)scale(1.05)}}@keyframes luckyPulse{0%{transform:scale(1)}40%{transform:scale(1.03)}to{transform:scale(1)}}@keyframes eggWiggle{0%,to{transform:rotate(0)scale(1)}40%{transform:rotate(-3deg)scale(1.02)}70%{transform:rotate(3deg)scale(1.01)}}@keyframes floatEmoji{0%,to{transform:translateY(0)scale(1)}50%{transform:translateY(-6px)scale(1.02)}}@keyframes rewardPulse{0%{transform:translateY(0)scale(1)}30%{transform:translateY(-6px)scale(1.02)}60%{transform:translateY(-2px)scale(1.01)}to{transform:translateY(0)scale(1)}}@keyframes rewardBubble{0%{opacity:0;transform:translate(-50%,10px)scale(.94)}25%{opacity:1;transform:translate(-50%,-4px)scale(1)}70%{opacity:1;transform:translate(-50%,-16px)scale(1.04)}to{opacity:0;transform:translate(-50%,-36px)scale(1.06)}}@keyframes rewardJump{0%{transform:translateY(8px)scale(1.1,.92)}18%{transform:translateY(-34px)scale(1.16)}40%{transform:translateY(-10px)scale(1.06)}62%{transform:translateY(-24px)scale(1.1)}82%{transform:translateY(-8px)scale(1.03)}to{transform:translateY(0)scale(1.02)}}@keyframes rewardSparkle{0%{opacity:0;transform:translate(-50%,-50%)scale(.6)}30%{opacity:1;transform:translate(-50%,-50%)scale(1.05)}to{opacity:0;transform:translate(-50%,-50%)scale(1.25)}}@keyframes rewardBubbleFloat{0%{opacity:0;transform:translate(-50%,-40px)scale(.9)}35%{opacity:1;transform:translate(-50%,-12px)scale(1.04)}70%{opacity:1;transform:translate(-50%,-54px)scale(1.04)}to{opacity:0;transform:translate(-50%,-84px)scale(1.06)}}@keyframes rewardStars{0%{opacity:0;transform:translate(-50%,-50%)scale(.55)}28%{opacity:1;transform:translate(-50%,-50%)scale(1.05)}to{opacity:0;transform:translate(-50%,-50%)scale(1.3)}}@keyframes rewardFoodShake{0%{transform:translateY(0)scale(1)}35%{transform:translateY(-4px)scale(1.1)rotate(-10deg)}60%{transform:translateY(2px)scale(.96)rotate(8deg)}to{transform:translateY(0)scale(1)}}@keyframes rewardFlash{0%,35%{opacity:0;transform:translate(-50%,-50%)scale(.3)}60%{opacity:1;transform:translate(-50%,-50%)scale(1)}to{opacity:0;transform:translate(-50%,-50%)scale(1.6)}}@keyframes rewardFeedFast{0%{opacity:0;transform:translate(calc(-50% + var(--food-start-x,0px)),calc(-50% + var(--food-start-y,36px)))scale(.4)rotate(-12deg)}28%{opacity:1;transform:translate(calc(-50% + var(--food-end-x,0px)),calc(-50% + var(--food-end-y,-22px)))scale(1.15)rotate(8deg)}55%{opacity:1;transform:translate(calc(-50% + var(--food-end-x,0px)),calc(-50% + var(--food-end-y,-22px)))scale(.98)rotate(-6deg)}to{opacity:0;transform:translate(calc(-50% + var(--food-end-x,0px)),calc(-50% + var(--food-end-y,-22px)))scale(.2)rotate(10deg)}}@keyframes rewardBite{0%,45%{opacity:0;transform:translate(-50%,-50%)scale(.3)}70%{opacity:1;transform:translate(-50%,-50%)scale(1)}to{opacity:0;transform:translate(-50%,-50%)scale(1.4)}}@keyframes rewardChomp{0%{transform:scale(1)}35%{transform:scale(1.08,.9)translateY(3px)}65%{transform:scale(.98,1.06)translateY(-2px)}to{transform:scale(1)}}@keyframes rewardShake{0%{transform:translateY(0)scale(1.02)}25%{transform:translateY(-6px)scale(1.04)rotate(-4deg)}50%{transform:translateY(-2px)scale(1.03)rotate(4deg)}75%{transform:translateY(-4px)scale(1.03)rotate(-3deg)}to{transform:translateY(0)scale(1.02)}}@keyframes rewardAfterShock{0%{transform:translateY(0)scale(1.02)}35%{transform:translateY(-4px)scale(1.04)rotate(-2deg)}70%{transform:translateY(-2px)scale(1.03)rotate(2deg)}to{transform:translateY(0)scale(1.02)}}@keyframes levelupOverlay{0%{opacity:0;transform:scale(.96)}25%{opacity:var(--levelup-overlay-opacity,.6);transform:scale(1.02)}70%{opacity:var(--levelup-overlay-opacity,.6);transform:scale(1.03)}to{opacity:0;transform:scale(1.05)}}@keyframes levelupHalo{0%{opacity:0;transform:scale(.92)}25%{opacity:var(--levelup-halo-opacity,.95);transform:scale(1)}70%{opacity:var(--levelup-halo-opacity,.75);transform:scale(1.06)}to{opacity:0;transform:scale(1.12)}}@keyframes levelupParticle{0%{opacity:0;transform:scale(calc(.6*var(--levelup-particle-scale,1)))}30%{opacity:var(--levelup-particle-opacity,1);transform:scale(calc(1.15*var(--levelup-particle-scale,1)))}to{opacity:0;transform:scale(calc(1.35*var(--levelup-particle-scale,1)))}}@keyframes levelupConfetti{0%{opacity:0;transform:translate(-50%,-50%)scale(calc(.8*var(--levelup-confetti-scale,1)))rotate(0deg)}15%{opacity:var(--levelup-confetti-opacity,1)}70%{opacity:var(--levelup-confetti-opacity,.9)}to{opacity:0;transform:translate(calc(-50% + var(--dx,0px)),calc(-50% + var(--dy,0px)))scale(calc(1.2*var(--levelup-confetti-scale,1)))rotate(var(--rot,0deg))}}@keyframes levelUpSparkle{0%{opacity:0;transform:scale(.9)}40%{opacity:1;transform:scale(1.05)}to{opacity:0;transform:scale(1.12)}}@keyframes levelupSweep{0%{opacity:0;transform:translate(-40%)}25%{opacity:1}70%{opacity:.9}to{opacity:0;transform:translate(40%)}}@keyframes levelupGlow{0%{opacity:0;transform:scale(.98)}25%{opacity:.75;transform:scale(1.02)}70%{opacity:.7;transform:scale(1.04)}to{opacity:0;transform:scale(1.06)}}@keyframes levelupCard{0%{box-shadow:0 12px 28px rgba(var(--accent-rgb),.18);border-color:rgba(var(--accent-rgb),.2);filter:saturate()brightness();transform:scale(1)}25%{transform:scale(var(--levelup-card-scale-peak,1.035));filter:saturate(1.1)brightness(1.03);border-color:#ffd67833;box-shadow:0 22px 44px #ffd67842}60%{transform:scale(var(--levelup-card-scale-mid,1.02));filter:saturate(1.06)brightness(1.015);border-color:#ffd6782e;box-shadow:0 18px 36px #ffd67833}to{box-shadow:0 12px 28px rgba(var(--accent-rgb),.18);border-color:rgba(var(--accent-rgb),.2);filter:saturate()brightness();transform:scale(1)}}@keyframes levelupDust{0%{opacity:0;background-position:0 -20px,40px -30px}30%{opacity:var(--levelup-dust-opacity,.65)}to{opacity:0;background-position:0 70px,40px 90px}}@keyframes levelupTitleDrop{0%{opacity:0;transform:translateY(-24px)scale(.92)}35%{opacity:1;transform:translateY(0)scale(1.05)}55%{transform:translateY(-8px)scale(1.02)}70%{transform:translateY(0)scale(1.01)}85%{transform:translateY(-4px)scale(1.005)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes levelupSubPop{0%{opacity:0;transform:translateY(6px)scale(.92)}45%{opacity:1;transform:translateY(0)scale(1.02)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes levelUpBurst{0%{opacity:0;transform:scale(.96)}30%{opacity:var(--levelup-burst-opacity,1);transform:scale(var(--levelup-burst-scale-peak,1.04))}70%{opacity:var(--levelup-burst-opacity,.9);transform:scale(var(--levelup-burst-scale-mid,1.06))}to{opacity:0;transform:scale(var(--levelup-burst-scale-end,1.08))}}@keyframes levelupRing{0%{opacity:0;transform:scale(.9)}35%{opacity:.9;transform:scale(1)}to{opacity:0;transform:scale(1.18)}}@keyframes levelupSigil{0%{opacity:0;transform:translateY(6px)scale(.9)}40%{opacity:1;transform:translateY(0)scale(1)}to{opacity:0;transform:translateY(-8px)scale(1.05)}}@keyframes levelUpPet{0%{transform:translateY(-10px)scale(1.05)}30%{transform:translateY(-22px)scale(1.1)}60%{transform:translateY(-8px)scale(1.03)}to{transform:translateY(-10px)scale(1.05)}}@keyframes summonPop{0%{opacity:0;transform:translateY(10px)scale(.96)}60%{opacity:1;transform:translateY(0)scale(1.02)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes summonFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}@keyframes sparkleFloat{0%,to{opacity:.5;transform:translateY(0)scale(.9)}50%{opacity:1;transform:translateY(-6px)scale(1.1)}}@keyframes summonShine{0%{opacity:0;transform:translate(-60%)}40%{opacity:.9}to{opacity:0;transform:translate(60%)}}@keyframes auraSpin{0%{transform:rotate(0)scale(1)}to{transform:rotate(360deg)scale(1)}}@keyframes auraPulse{0%{opacity:.35}50%{opacity:.55}to{opacity:.35}}@keyframes auroraDrift{0%{transform:translateY(0)scale(1)}50%{transform:translateY(-2%)scale(1.02)}to{transform:translateY(0)scale(1)}}@keyframes starFall{0%{opacity:0;transform:translateY(0)scale(.6)}15%{opacity:1}to{opacity:0;transform:translateY(120vh)scale(1)}}@keyframes ribbonFall{0%{opacity:0;transform:translateY(0)rotate(0)}15%{opacity:1}to{opacity:0;transform:translateY(120vh)rotate(180deg)}}@keyframes dustDrift{0%,to{opacity:.4;transform:translateY(0)scale(.9)}50%{opacity:.9;transform:translateY(-6px)scale(1.1)}}@keyframes lensDrift{0%{transform:translate(0)scale(1)}50%{transform:translate(6px,-6px)scale(1.05)}to{transform:translate(0)scale(1)}}.toast-pop{animation:2.6s ease-in-out toastPop}.toast-pop--responsive{top:auto;bottom:84px;transform:translate(-50%)}.undo-toast{z-index:60;border:1px solid var(--border);color:var(--text);background:#fffffff5;border-radius:999px;align-items:center;gap:12px;padding:8px 14px;font-size:13px;font-weight:600;display:inline-flex;position:fixed;bottom:84px;left:50%;transform:translate(-50%)}.undo-toast-btn{background:var(--accent-soft);color:var(--accent-strong);border-radius:999px;padding:4px 10px;font-size:12px;font-weight:700;transition:background .15s,transform .15s}.undo-toast-btn:hover{background:var(--accent-soft)}@supports (color:color-mix(in lab, red, red)){.undo-toast-btn:hover{background:color-mix(in srgb,var(--accent-soft)80%,var(--panel))}}.undo-toast-btn:hover{transform:translateY(-1px)}.undo-toast-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}@media (max-width:640px){.toast-pop--responsive{top:auto;bottom:calc(16px + env(safe-area-inset-bottom))}.undo-toast{bottom:calc(16px + env(safe-area-inset-bottom))}}@keyframes toastPop{0%{opacity:0;transform:translate(-50%,8px)scale(.98)}12%{opacity:1;transform:translate(-50%)scale(1)}82%{opacity:1;transform:translate(-50%)scale(1)}to{opacity:0;transform:translate(-50%,-6px)scale(.98)}}@media (prefers-reduced-motion:reduce){*{transition:none!important;animation:none!important}}@media (max-width:900px){.nav-glass{-webkit-backdrop-filter:none;backdrop-filter:none;box-shadow:0 10px 22px rgba(var(--accent-rgb),.16)}.loading-overlay{padding:16px}.loading-card{width:min(420px,100vw - 32px)}.store-tabs-bar{width:100%;position:static;top:72px}.store-tabs{flex-wrap:nowrap;justify-content:space-between;width:100%;overflow-x:auto}.store-card-grid{grid-template-columns:1fr;justify-items:stretch}.store-card{text-align:center;width:100%;max-width:none;min-height:auto}.store-card-top{justify-content:center;height:92px;padding-left:0}.store-card-icon{width:56px;height:56px;font-size:24px}.store-card-body{padding:10px 14px 14px}}@media (max-width:1200px){.store-card-grid{grid-template-columns:1fr;justify-items:stretch}.store-card{text-align:center;width:100%;max-width:none;min-height:auto}.store-card-top{justify-content:center;padding-left:0}.store-card-body{text-align:center;align-items:center}}.level-badge--mini{gap:4px;padding:4px 8px;font-size:11px;position:absolute;top:34%;right:18%;box-shadow:0 6px 12px #0f172a1a}.level-badge--mini .level-badge-icon{font-size:13px}:root[data-classroom=on][data-page=dashboard] .level-badge--mini{padding:6px 10px;font-size:13px}:root[data-classroom=on][data-page=dashboard] .level-badge--mini .level-badge-icon{font-size:15px}.empty-hint{color:var(--muted);letter-spacing:.4px;z-index:3;margin-top:6px;font-size:12px}@media (hover:none) and (pointer:coarse){.store-tabs{flex-wrap:nowrap;justify-content:space-between;width:100%;overflow-x:auto}.store-tabs-bar{width:100%;position:static;top:auto}.store-card-grid{grid-template-columns:1fr;justify-items:stretch}.store-card{text-align:center;width:100%;max-width:none;min-height:auto}.store-card-top{justify-content:center;height:92px;padding-left:0}.store-card-icon{width:56px;height:56px;font-size:24px}.store-card-body{align-items:center;padding:10px 14px 14px}}.pet-adopt-hint{color:var(--accent-strong);border:1px solid rgba(var(--accent-rgb),.25);box-shadow:0 10px 18px rgba(var(--accent-rgb),.16);opacity:0;pointer-events:none;background:#ffffffeb;border-radius:999px;padding:6px 12px;font-size:12px;font-weight:700;transition:opacity .16s,transform .16s;position:absolute;bottom:14px;left:50%;transform:translate(-50%,6px)}.pet-card.egg-card:hover .pet-adopt-hint{opacity:1;transform:translate(-50%)}.pet-card.egg-card:hover .empty-hint{opacity:0;transform:translateY(4px)}.pet-card.undo-mode .pet-adopt-hint{display:none}@keyframes energyFlow{0%{filter:brightness()}50%{filter:brightness(1.08)}to{filter:brightness()}}@keyframes undoShake{0%{transform:translate(0)}20%{transform:translate(-6px)}40%{transform:translate(6px)}60%{transform:translate(-4px)}80%{transform:translate(4px)}to{transform:translate(0)}}.icon-picker{gap:8px;display:grid}.icon-picker-head{justify-content:space-between;align-items:center;gap:8px;display:flex}.icon-picker-label{color:var(--text);font-size:12px;font-weight:600}.icon-picker-preview{border:1px solid var(--border);width:36px;height:36px;box-shadow:inset 0 0 0 1px rgba(var(--accent-rgb),.15);background:#ffffffe6;border-radius:12px;justify-content:center;align-items:center;font-size:18px;display:flex}.icon-picker-groups{flex-wrap:wrap;gap:6px;display:flex}.icon-picker-tab{border:1px solid var(--border);color:var(--muted);background:#fffc;border-radius:999px;padding:4px 10px;font-size:11px;font-weight:600;transition:background .15s,color .15s,border-color .15s}.icon-picker-tab.is-active{color:var(--accent-strong);background:var(--accent-soft);border-color:var(--accent)}@supports (color:color-mix(in lab, red, red)){.icon-picker-tab.is-active{border-color:color-mix(in srgb,var(--accent)40%,var(--border))}}.icon-picker-grid{grid-template-columns:repeat(auto-fill,minmax(36px,1fr));gap:6px;display:grid}.icon-picker-item{border:1px solid var(--border);background:#ffffffe6;border-radius:12px;justify-content:center;align-items:center;width:36px;height:36px;font-size:18px;transition:transform .12s,box-shadow .12s,border-color .12s;display:flex}.icon-picker-item.is-active{border-color:var(--accent);background:var(--accent-soft);box-shadow:0 8px 16px rgba(var(--accent-rgb),.2);transform:translateY(-1px)}.icon-picker--compact .icon-picker-grid{grid-template-columns:repeat(auto-fill,minmax(30px,1fr))}.icon-picker--compact .icon-picker-item{border-radius:10px;width:30px;height:30px;font-size:16px}.stepper{gap:6px;display:grid}.stepper-label{color:var(--muted);font-size:11px;font-weight:600}.stepper-body{align-items:center;gap:6px;display:flex}.stepper-btn{border:1px solid var(--border);width:32px;height:32px;color:var(--accent-strong);background:#ffffffe6;border-radius:10px;font-weight:700}.stepper-value{text-align:center;border:1px solid var(--border);background:#fffc;border-radius:999px;min-width:48px;padding:6px 10px;font-weight:700}.stepper-input{outline:none}.stepper-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.stepper-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.stepper-input[type=number]{-moz-appearance:textfield}.stepper--compact .stepper-btn{width:28px;height:28px}.stepper--compact .stepper-value{min-width:40px;padding:5px 8px;font-size:12px}.quick-grid{flex-wrap:wrap;gap:6px;display:flex}.quick-chip{border:1px solid var(--border);color:var(--muted);background:#ffffffd9;border-radius:999px;padding:4px 10px;font-size:11px;font-weight:600;transition:background .15s,color .15s,border-color .15s}.quick-chip:hover,.quick-chip.is-active{background:var(--accent-soft);color:var(--accent-strong);border-color:var(--accent)}@supports (color:color-mix(in lab, red, red)){.quick-chip:hover,.quick-chip.is-active{border-color:color-mix(in srgb,var(--accent)40%,var(--border))}}.theme-dot{width:10px;height:10px;box-shadow:0 0 0 2px var(--border);border-radius:999px;display:inline-flex}.stage-card{border:1px dashed var(--border);background:#fff9;border-radius:16px;gap:8px;padding:12px;display:grid}.stage-card .stepper-body{justify-content:center}.stage-card .stepper-value{flex:none;width:64px}.stage-static{color:var(--muted);text-align:center;border:1px solid var(--border);background:#ffffffd9;border-radius:999px;padding:6px 10px;font-size:12px;font-weight:700}.rule-add{gap:12px;display:grid}.rule-add-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));align-items:start;gap:16px;display:grid}.rule-add-fields,.rule-add-values{gap:8px;min-width:0;display:grid}.rule-sign{gap:6px;display:flex}.rule-add-values .stepper{width:100%}.rule-add-values .stepper-body{grid-template-columns:28px minmax(0,1fr) 28px;align-items:center;gap:6px;width:100%;display:grid}.rule-add-values .stepper-value{width:100%;min-width:0}.rule-add-values .stepper-btn{width:28px;height:28px}.rule-add-actions{justify-content:flex-end;display:flex}.rule-row{justify-content:space-between;align-items:center;gap:12px;display:flex}.rule-meta{align-items:center;gap:12px;display:flex}.rule-icon{background:var(--accent-soft);width:44px;height:44px;box-shadow:inset 0 0 0 1px rgba(var(--accent-rgb),.2);border-radius:14px;justify-content:center;align-items:center;font-size:22px;display:flex}.rule-actions{align-items:center;gap:8px;display:flex}.rule-value{border:1px solid #0000;border-radius:999px;padding:4px 10px;font-size:12px;font-weight:700}.rule-value--pos{background:var(--accent-soft)}@supports (color:color-mix(in lab, red, red)){.rule-value--pos{background:color-mix(in srgb,var(--accent-soft)85%,var(--panel))}}.rule-value--pos{color:var(--accent-strong);border-color:var(--accent)}@supports (color:color-mix(in lab, red, red)){.rule-value--pos{border-color:color-mix(in srgb,var(--accent)45%,var(--border))}}.rule-value--neg{color:var(--muted);background:#94a3b82e;border-color:#94a3b859}.rule-edit{gap:10px;margin-top:12px;display:grid}.rule-edit-form,.rule-edit-fields{gap:10px;display:grid}.rule-delete{margin-top:6px}.store-add-form{gap:12px;display:grid}.store-add-grid{align-items:start;gap:16px;display:grid}.store-add-fields{gap:8px;display:grid}.store-add-values{gap:10px;display:grid}.store-add-actions{justify-content:flex-end;display:flex}.roster-card.is-open{border-color:var(--accent)}@supports (color:color-mix(in lab, red, red)){.roster-card.is-open{border-color:color-mix(in srgb,var(--accent)35%,var(--border))}}.roster-card.is-open{box-shadow:0 16px 28px rgba(var(--accent-rgb),.18),0 4px 10px #0f172a0f}.roster-actions{align-items:center;gap:6px;display:inline-flex}.roster-row-head{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;display:flex}.roster-row-main{align-items:center;gap:12px;min-width:0;display:flex}.roster-row-tools{align-items:center;gap:8px;display:inline-flex}.roster-meta-line{margin-top:2px}.roster-level-chip{font-weight:700}.roster-edit-toggle{justify-content:center;min-width:56px}.roster-action-btn{border:1px solid var(--border);width:34px;height:34px;color:var(--muted);background:#ffffffe6;border-radius:12px;justify-content:center;align-items:center;transition:transform .16s,box-shadow .16s,background .16s,color .16s;display:inline-flex}.roster-action-btn:hover{background:var(--accent-soft);color:var(--accent-strong);box-shadow:0 10px 18px rgba(var(--accent-rgb),.2);transform:translateY(-1px)}.roster-action-btn:disabled{opacity:.4;cursor:not-allowed;box-shadow:none;transform:none}.roster-action-btn--danger{color:#c35746;background:#fff2f0eb;border-color:#f5c1b4bf}.roster-action-btn--danger:hover{color:#b6473a;background:#ffe2daf2}.roster-edit-form{gap:12px;display:grid}.roster-edit-wrap{border-top:1px dashed var(--accent)}@supports (color:color-mix(in lab, red, red)){.roster-edit-wrap{border-top:1px dashed color-mix(in srgb,var(--accent)25%,var(--border))}}.roster-edit-wrap{padding-top:12px}.roster-edit-actions{flex-wrap:wrap;align-items:center;gap:10px;display:flex}@media (min-width:720px){.rule-add-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.rule-edit-fields{grid-template-columns:1.4fr .8fr .8fr;align-items:end}.store-add-grid{grid-template-columns:220px 1.2fr 220px}}@media (max-width:1100px){.rule-add-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.rule-add-values{grid-column:1/-1}}@media (min-width:1280px){.rule-add-grid{grid-template-columns:minmax(180px,220px) minmax(0,1.2fr) minmax(180px,220px)}}@media (min-width:640px){.roster-edit-form{grid-template-columns:minmax(0,1fr) minmax(0,1fr);align-items:end}.roster-edit-form>button{justify-self:end}}@media (min-width:980px){.roster-edit-form{grid-template-columns:1.3fr 1fr auto auto}.roster-edit-form>button{justify-self:stretch}}@media (max-width:680px){.roster-row-head{align-items:flex-start}.roster-row-tools{justify-content:flex-end;width:100%}}@media (max-width:900px){.modal-panel--activity{width:min(760px,94vw)}.activity-modal-content{grid-template-columns:minmax(0,1fr)}.activity-modal-side{order:2}}@property --tw-translate-x{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-y{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-z{syntax:"*";inherits:false;initial-value:0}@property --tw-space-y-reverse{syntax:"*";inherits:false;initial-value:0}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@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}@property --tw-backdrop-blur{syntax:"*";inherits:false}@property --tw-backdrop-brightness{syntax:"*";inherits:false}@property --tw-backdrop-contrast{syntax:"*";inherits:false}@property --tw-backdrop-grayscale{syntax:"*";inherits:false}@property --tw-backdrop-hue-rotate{syntax:"*";inherits:false}@property --tw-backdrop-invert{syntax:"*";inherits:false}@property --tw-backdrop-opacity{syntax:"*";inherits:false}@property --tw-backdrop-saturate{syntax:"*";inherits:false}@property --tw-backdrop-sepia{syntax:"*";inherits:false}
