@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-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-500:#fb2c36;--color-green-600:#00a544;--color-black:#000;--color-white:#fff;--spacing:.25rem;--container-xs:20rem;--container-md:28rem;--container-lg:32rem;--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-500:lab(55.4814% 75.0732 48.8528);--color-green-600:lab(59.0978% -58.6621 41.2579)}}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.fixed{position:fixed}.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}.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-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)}.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-9{height:calc(var(--spacing)*9)}.h-10{height:calc(var(--spacing)*10)}.h-12{height:calc(var(--spacing)*12)}.h-28{height:calc(var(--spacing)*28)}.max-h-\[70vh\]{max-height:70vh}.min-h-\[40px\]{min-height:40px}.min-h-\[44px\]{min-height:44px}.min-h-\[52px\]{min-height:52px}.min-h-\[100px\]{min-height:100px}.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-9{width:calc(var(--spacing)*9)}.w-10{width:calc(var(--spacing)*10)}.w-12{width:calc(var(--spacing)*12)}.w-28{width:calc(var(--spacing)*28)}.w-\[calc\(100\%-2rem\)\]{width:calc(100% - 2rem)}.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-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)}.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-black\/40{background-color:#0006}@supports (color:color-mix(in lab, red, red)){.bg-black\/40{background-color:color-mix(in oklab,var(--color-black)40%,transparent)}}.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-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-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-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}.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-green-600{color:var(--color-green-600)}.text-red-500{color:var(--color-red-500)}.antialiased{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.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)}.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)}}.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_auto\]{grid-template-columns: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\:inline-flex{display:inline-flex}.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.md\:grid-cols-3{grid-template-columns:repeat(3,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\.1fr_1fr\]{grid-template-columns:1.1fr 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)}}@media (min-width:80rem){.xl\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.xl\:grid-cols-6{grid-template-columns:repeat(6,minmax(0,1fr))}}@media (min-width:96rem){.\32 xl\:grid-cols-7{grid-template-columns:repeat(7,minmax(0,1fr))}}}: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}: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;align-items:center;gap:16px;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;background:0 0;border:none;justify-content:center;padding:8px 0;top:16px}: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;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}.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))}}.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;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 var(--border);color:var(--text);background:#ffffffd9;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{background:var(--accent-soft);color:var(--accent-strong);border-color:var(--accent)}@supports (color:color-mix(in lab, red, red)){.nav-action:hover,.nav-action.is-active{border-color:color-mix(in srgb,var(--accent)40%,var(--border))}}.nav-action:hover,.nav-action.is-active{box-shadow:0 10px 18px rgba(var(--accent-rgb),.2)}.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%}.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{border-radius:24px;align-items:flex-start;top:20px}.classroom-icons{justify-content:flex-end;width:100%}}.card{background:var(--panel);border:1px solid var(--border);box-shadow:var(--shadow);border-radius:24px}.grid-compact{gap:12px}.pet-grid--manual{grid-template-columns:repeat(var(--pet-grid-cols,4),minmax(0,1fr))}@media (max-width:768px){.pet-grid--manual{grid-template-columns:repeat(2,minmax(0,1fr))}}.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:26px}.muted{color:var(--muted)}.chip{background:var(--accent-soft);color:var(--accent-strong);border-radius:999px;align-items:center;gap:4px;padding:3px 10px;font-size:12px;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:16px;padding:10px 18px;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:16px;padding:10px 16px;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}.stat-card{border:1px solid var(--border);background:#ffffffe6;border-radius:18px;padding:10px 14px;font-size:13px;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-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__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);background:#fffffff0;border-radius:18px;grid-template-columns:auto 1fr auto;align-items:center;gap:12px;padding:10px 14px;display:grid}.leaderboard-row.is-top{background:linear-gradient(90deg,rgba(var(--lb-accent-rgb),.22),#fffffffa);border-color:rgba(var(--lb-accent-rgb),.28)}.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-name{color:var(--text);font-weight:700}.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}.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-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:22px}@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)}.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 var(--border);width:40px;height:40px;color:var(--muted);background:#ffffffd9;border-radius:999px;justify-content:center;align-items:center;transition:background .15s,transform .15s;display:inline-flex;position:absolute;top:18px;right:18px}.score-modal-close:hover{background:var(--accent-soft);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(160px,1fr));gap:14px;margin-top:16px;display:grid}.score-card{border:2px solid rgba(var(--accent-rgb),.18);text-align:center;background:#fffffffa;border-radius:20px;flex-direction:column;align-items:center;gap:10px;padding:16px 14px 14px;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:60px;height:60px;color:var(--accent-strong);border-radius:18px;justify-content:center;align-items:center;font-size:26px;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:14px;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:6px 12px;font-size:12px;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:.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-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-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{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}.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}.card-footer-grid{grid-template-columns:auto 1fr auto;align-items:center;gap:10px;width:100%;display:grid}.metric-stack{flex-direction:column;align-items:center;gap:2px;display:flex}.metric-stack--clickable{cursor:pointer;background:0 0;border:none;padding:0}.metric-stack--clickable:hover .metric-value{color:var(--accent-strong)}.metric-stack--disabled{opacity:.45;filter:grayscale(.2)}.metric-stack .metric-icon{font-size:14px}.metric-stack .metric-value{color:var(--text);font-size:12px;font-weight:700}.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}.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;background:#ffffff47;border:1px solid #ffffffa6;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 #0f172a1f}.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--muted{color:var(--muted)}.level-text-icon{font-size:12px}.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{width:clamp(170px,78%,var(--pet-ill-max,320px));aspect-ratio:1;justify-content:center;align-items:center;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:clamp(140px,62%,calc(var(--pet-ill-max,320px)*.8))}@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}: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(560px,92vw);padding:24px 24px 20px;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:"";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{transition:background .32s,-webkit-backdrop-filter .32s,backdrop-filter .32s;position:fixed;overflow:hidden}.summon-overlay:before,.summon-overlay:after{content:"";opacity:.6;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:.45;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:space-between;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;background:#fffc;border:1px solid #ffd69699;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;display:inline-flex;box-shadow:0 8px 16px #ffcd8c33}.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}.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)}@media (max-width:640px){.classroom-tray{justify-content:space-between;width:calc(100% - 2rem);bottom:92px}.tray-btn{text-align:center;flex:1}.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-topbar{border-bottom:1px solid #e3e8f2;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;margin-bottom:14px;padding:4px 6px 14px;display:flex}.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:#eef2f8;border:1px solid #dde3ef;border-radius:14px;gap:6px;padding:6px;display:inline-flex}.store-tab{color:#667086;cursor:pointer;background:0 0;border:none;border-radius:12px;padding:6px 12px;font-size:12px;font-weight:700;transition:background .16s,color .16s}.store-tab.is-active{color:#3f4adb;background:#fff;box-shadow:0 6px 12px #3f4adb2e}.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-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:center;background:#fff;border-top:1px solid #eef2f8;flex-direction:column;flex:1;align-items:center;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-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)}.magic-fab-footer{justify-content:flex-start;margin-top:12px;display:flex}@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:clamp(140px,82%,var(--pet-ill-max,260px))}.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:.6;transform:scale(1.02)}70%{opacity:.6;transform:scale(1.03)}to{opacity:0;transform:scale(1.05)}}@keyframes levelupHalo{0%{opacity:0;transform:scale(.92)}25%{opacity:.95;transform:scale(1)}70%{opacity:.75;transform:scale(1.06)}to{opacity:0;transform:scale(1.12)}}@keyframes levelupParticle{0%{opacity:0;transform:scale(.6)}30%{opacity:1;transform:scale(1.15)}to{opacity:0;transform:scale(1.35)}}@keyframes levelupConfetti{0%{opacity:0;transform:translate(-50%,-50%)scale(.8)rotate(0)}15%{opacity:1}70%{opacity:.9}to{opacity:0;transform:translate(calc(-50% + var(--dx,0px)),calc(-50% + var(--dy,0px)))scale(1.2)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%{filter:saturate(1.1)brightness(1.03);border-color:#ffd67833;transform:scale(1.035);box-shadow:0 22px 44px #ffd67842}60%{filter:saturate(1.06)brightness(1.015);border-color:#ffd6782e;transform:scale(1.02);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:.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:1;transform:scale(1.04)}70%{opacity:.9;transform:scale(1.06)}to{opacity:0;transform:scale(1.08)}}@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%)}@media (max-width:640px){.toast-pop--responsive{top:16px;bottom:auto}}@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:640px){.nav-glass{-webkit-backdrop-filter:none;backdrop-filter:none;box-shadow:0 10px 22px rgba(var(--accent-rgb),.16)}}.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}@keyframes energyFlow{0%{filter:brightness()}50%{filter:brightness(1.08)}to{filter:brightness()}}.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-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{align-items:start;gap:16px;display:grid}.rule-add-fields,.rule-add-values{gap:8px;display:grid}.rule-sign{gap:6px;display:flex}.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-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}@media (min-width:720px){.rule-add-grid{grid-template-columns:220px 1.2fr 220px}.rule-edit-fields{grid-template-columns:1.4fr .8fr .8fr;align-items:end}.store-add-grid{grid-template-columns:220px 1.2fr 220px}}@media (min-width:640px){.roster-edit-form{grid-template-columns:1.4fr .7fr auto;align-items:end}}@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-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}
