@layer properties{@supports ((-webkit-hyphens:none) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-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-outline-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial;--tw-backdrop-blur:initial;--tw-backdrop-brightness:initial;--tw-backdrop-contrast:initial;--tw-backdrop-grayscale:initial;--tw-backdrop-hue-rotate:initial;--tw-backdrop-invert:initial;--tw-backdrop-opacity:initial;--tw-backdrop-saturate:initial;--tw-backdrop-sepia:initial;--tw-ease:initial}}}@layer theme{:root,:host{--font-sans:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";--font-mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;--color-red-500:oklch(63.7% .237 25.331);--color-red-600:oklch(57.7% .245 27.325);--color-amber-500:oklch(76.9% .188 70.08);--color-green-500:oklch(72.3% .219 149.579);--color-green-600:oklch(62.7% .194 149.214);--color-blue-500:oklch(62.3% .214 259.815);--color-violet-50:oklch(96.9% .016 293.756);--color-violet-100:oklch(94.3% .029 294.588);--color-violet-200:oklch(89.4% .057 293.283);--color-violet-300:oklch(81.1% .111 293.571);--color-violet-400:oklch(70.2% .183 293.541);--color-violet-500:oklch(60.6% .25 292.717);--color-violet-600:oklch(54.1% .281 293.009);--color-violet-700:oklch(49.1% .27 292.581);--color-violet-800:oklch(43.2% .232 292.759);--color-violet-900:oklch(38% .189 293.745);--color-gray-600:oklch(44.6% .03 256.802);--color-gray-900:oklch(21% .034 264.665);--color-neutral-50:oklch(98.5% 0 0);--color-neutral-100:oklch(97% 0 0);--color-neutral-200:oklch(92.2% 0 0);--color-neutral-300:oklch(87% 0 0);--color-neutral-400:oklch(70.8% 0 0);--color-neutral-500:oklch(55.6% 0 0);--color-neutral-600:oklch(43.9% 0 0);--color-neutral-700:oklch(37.1% 0 0);--color-neutral-800:oklch(26.9% 0 0);--color-neutral-900:oklch(20.5% 0 0);--spacing:.25rem;--breakpoint-sm:40rem;--breakpoint-md:48rem;--breakpoint-lg:64rem;--breakpoint-xl:80rem;--breakpoint-2xl:96rem;--text-xs:.75rem;--text-sm:.875rem;--text-base:1rem;--text-lg:1.125rem;--text-xl:1.25rem;--text-2xl:1.5rem;--text-2xl--line-height:calc(2/1.5);--text-3xl:1.875rem;--text-4xl:2.25rem;--text-5xl:3rem;--text-6xl:3.75rem;--font-weight-bold:700;--tracking-tight:-.025em;--tracking-normal:0em;--tracking-wide:.025em;--tracking-wider:.05em;--leading-tight:1.25;--leading-snug:1.375;--leading-normal:1.5;--leading-relaxed:1.625;--leading-loose:2;--radius-sm:.25rem;--radius-md:.375rem;--radius-lg:.5rem;--radius-xl:.75rem;--radius-2xl:1rem;--radius-3xl:1.5rem;--shadow-xs:0 1px 2px 0 #0000000d;--shadow-sm:0 1px 3px 0 #0000001a,0 1px 2px -1px #0000001a;--shadow-md:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a;--shadow-xl:0 20px 25px -5px #0000001a,0 8px 10px -6px #0000001a;--shadow-2xl:0 25px 50px -12px #00000040;--ease-out:cubic-bezier(0,0,.2,1);--animate-spin:spin 1s linear infinite;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4,0,.2,1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono);--color-primary-600:var(--color-violet-600)}}@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%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::-moz-placeholder{opacity:1}::placeholder{opacity:1}@supports (not (-webkit-appearance:-apple-pay-button)) or (contain-intrinsic-size:1px){::-moz-placeholder{color:currentColor}::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::-moz-placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}::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]){-webkit-appearance:button;-moz-appearance:button;appearance:button}::file-selector-button{-webkit-appearance:button;-moz-appearance:button;appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.collapse{visibility:collapse}.visible{visibility:visible}.sr-only{clip-path:inset(50%);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.container{width:100%}@media(min-width:40rem){.container{max-width:40rem}}@media(min-width:48rem){.container{max-width:48rem}}@media(min-width:64rem){.container{max-width:64rem}}@media(min-width:80rem){.container{max-width:80rem}}@media(min-width:96rem){.container{max-width:96rem}}.mx-auto{margin-inline:auto}.mt-2{margin-top:calc(var(--spacing)*2)}.mt-4{margin-top:calc(var(--spacing)*4)}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline{display:inline}.inline-flex{display:inline-flex}.h-12{height:calc(var(--spacing)*12)}.min-h-screen{min-height:100vh}.w-12{width:calc(var(--spacing)*12)}.w-full{width:100%}.transform{transform:var(--tw-rotate-x,)var(--tw-rotate-y,)var(--tw-rotate-z,)var(--tw-skew-x,)var(--tw-skew-y,)}.animate-spin{animation:var(--animate-spin)}.items-center{align-items:center}.justify-center{justify-content:center}.rounded{border-radius:.25rem}.rounded-full{border-radius:3.40282e38px}.border{border-style:var(--tw-border-style);border-width:1px}.border-b-2{border-bottom-style:var(--tw-border-style);border-bottom-width:2px}.border-primary-600{border-color:var(--color-primary-600)}.text-center{text-align:center}.text-2xl{font-size:var(--text-2xl);line-height:var(--tw-leading,var(--text-2xl--line-height))}.font-bold{--tw-font-weight:var(--font-weight-bold);font-weight:var(--font-weight-bold)}.text-gray-600{color:var(--color-gray-600)}.text-gray-900{color:var(--color-gray-900)}.uppercase{text-transform:uppercase}.underline{text-decoration-line:underline}.shadow{--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)}.ring{--tw-ring-shadow:var(--tw-ring-inset,)0 0 0 calc(1px + 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)}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.filter{filter:var(--tw-blur,)var(--tw-brightness,)var(--tw-contrast,)var(--tw-grayscale,)var(--tw-hue-rotate,)var(--tw-invert,)var(--tw-saturate,)var(--tw-sepia,)var(--tw-drop-shadow,)}.backdrop-filter{-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,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))}.ease-out{--tw-ease:var(--ease-out);transition-timing-function:var(--ease-out)}}:root{--color-violet-50:#f5f3ff;--color-violet-100:#ede9fe;--color-violet-200:#ddd6fe;--color-violet-300:#c4b5fd;--color-violet-400:#a78bfa;--color-violet-500:#8b5cf6;--color-violet-600:#7c3aed;--color-violet-700:#6d28d9;--color-violet-800:#5b21b6;--color-violet-900:#4c1d95;--color-neutral-0:#fff;--color-neutral-50:#fafafa;--color-neutral-100:#f5f5f5;--color-neutral-200:#e5e5e5;--color-neutral-300:#d4d4d4;--color-neutral-400:#a3a3a3;--color-neutral-500:#737373;--color-neutral-600:#525252;--color-neutral-700:#404040;--color-neutral-800:#262626;--color-neutral-900:#171717;--color-green-500:#10b981;--color-green-600:#059669;--color-red-500:#ef4444;--color-red-600:#dc2626;--color-amber-500:#f59e0b;--color-blue-500:#3b82f6;--color-exercise-green:#58cc02;--color-exercise-green-dark:#4db902;--color-exercise-green-shadow:#3d9102;--color-exercise-red:#ff4b4b;--color-exercise-blue:#1cb0f6;--color-xp-gold:#ffd900;--color-xp-gold-light:#ffed4e;--color-streak-orange:#ff9600;--color-streak-orange-light:#ffa733;--lang-spanish:#ef4444;--lang-spanish-gradient:linear-gradient(135deg,#ef4444 0%,#dc2626 100%);--lang-french:#3b82f6;--lang-french-gradient:linear-gradient(135deg,#3b82f6 0%,#2563eb 100%);--lang-german:#f59e0b;--lang-german-gradient:linear-gradient(135deg,#f59e0b 0%,#d97706 100%);--lang-italian:#10b981;--lang-italian-gradient:linear-gradient(135deg,#10b981 0%,#059669 100%);--lang-japanese:#ec4899;--lang-japanese-gradient:linear-gradient(135deg,#ec4899 0%,#d946ef 100%);--lang-portuguese:#8b5cf6;--lang-portuguese-gradient:linear-gradient(135deg,#8b5cf6 0%,#7c3aed 100%);--unit-1-gradient:linear-gradient(135deg,#ff6b9d 0%,#c06c84 100%);--unit-2-gradient:linear-gradient(135deg,orange 0%,tomato 100%);--unit-3-gradient:linear-gradient(135deg,#32cd32 0%,#228b22 100%);--unit-4-gradient:linear-gradient(135deg,#4169e1 0%,#1e3a8a 100%);--unit-5-gradient:linear-gradient(135deg,#9370db 0%,#6a0dad 100%);--unit-6-gradient:linear-gradient(135deg,#00ced1 0%,#008b8b 100%);--unit-7-gradient:linear-gradient(135deg,#20b2aa 0%,#2f4f4f 100%);--unit-8-gradient:linear-gradient(135deg,#ff1493 0%,#c71585 100%);--unit-9-gradient:linear-gradient(135deg,gold 0%,#daa520 100%);--unit-10-gradient:linear-gradient(135deg,#ff69b4 0%,#ff1493 100%);--space-0:0;--space-1:.25rem;--space-2:.5rem;--space-3:.75rem;--space-4:1rem;--space-5:1.25rem;--space-6:1.5rem;--space-8:2rem;--space-10:2.5rem;--space-12:3rem;--space-16:4rem;--space-20:5rem;--space-24:6rem;--radius-none:0;--radius-sm:.25rem;--radius-base:.375rem;--radius-md:.5rem;--radius-lg:.75rem;--radius-xl:1rem;--radius-2xl:1.5rem;--radius-3xl:2rem;--radius-full:9999px;--font-primary:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Oxygen","Ubuntu","Cantarell",sans-serif;--font-heading:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Oxygen","Ubuntu","Cantarell",sans-serif;--font-mono:"SF Mono",Monaco,"Cascadia Code","Roboto Mono",Consolas,monospace;--text-xs:.75rem;--text-sm:.875rem;--text-base:1rem;--text-lg:1.125rem;--text-xl:1.25rem;--text-2xl:1.5rem;--text-3xl:1.875rem;--text-4xl:2.25rem;--text-5xl:3rem;--text-6xl:3.75rem;--font-light:300;--font-normal:400;--font-medium:500;--font-semibold:600;--font-bold:700;--font-extrabold:800;--leading-none:1;--leading-tight:1.25;--leading-snug:1.375;--leading-normal:1.5;--leading-relaxed:1.625;--leading-loose:2;--tracking-tight:-.02em;--tracking-normal:0;--tracking-wide:.02em;--tracking-wider:.05em;--z-dropdown:1000;--z-sticky:1020;--z-fixed:1030;--z-modal-backdrop:1040;--z-modal:1050;--z-popover:1060;--z-tooltip:1070;--transition-fast:.2s ease;--transition-base:.3s cubic-bezier(.4,0,.2,1);--transition-slow:.4s cubic-bezier(.4,0,.2,1);--transition-bounce:.5s cubic-bezier(.68,-.55,.265,1.55);--container-max-width:1280px;--header-height:64px;--sidebar-width:280px;--sidebar-collapsed-width:80px;--bottom-nav-height:64px;--breakpoint-sm:640px;--breakpoint-md:768px;--breakpoint-lg:1024px;--breakpoint-xl:1280px;--breakpoint-2xl:1536px}:root,[data-theme=light]{--bg-page:var(--color-violet-50);--bg-card:var(--color-neutral-0);--bg-card-hover:var(--color-neutral-50);--bg-secondary:var(--color-violet-100);--bg-tertiary:var(--color-violet-200);--bg-input:var(--color-violet-200);--bg-overlay:#4c1d9566;--bg-overlay-heavy:#000000b3;--text-primary:#1f2937;--text-secondary:#6b7280;--text-tertiary:#9ca3af;--text-disabled:#d1d5db;--text-inverse:#fff;--text-brand:var(--color-violet-600);--border-default:#e5e7eb;--border-subtle:#f3f4f6;--border-strong:#d1d5db;--border-focus:var(--color-violet-500);--shadow-xs:0 1px 2px #0000000d;--shadow-sm:0 2px 4px #0000000f;--shadow-md:0 6px 12px #0000001a;--shadow-lg:0 10px 20px #0000001f;--shadow-xl:0 20px 40px #00000026;--shadow-2xl:0 25px 50px #0003;--shadow-inner:inset 0 2px 4px #0000000d;--shadow-brand:0 10px 25px -5px #8b5cf64d;--gradient-brand:linear-gradient(135deg,#667eea 0%,#764ba2 100%);--gradient-hero:var(--gradient-brand);--gradient-card:linear-gradient(145deg,#fff 0%,#f9fafb 100%);--gradient-accent:linear-gradient(135deg,#f093fb 0%,#f5576c 100%);--status-success-bg:#d1fae5;--status-success-text:#065f46;--status-success-border:#6ee7b7;--status-error-bg:#fee2e2;--status-error-text:#991b1b;--status-error-border:#fca5a5;--status-warning-bg:#fef3c7;--status-warning-text:#92400e;--status-warning-border:#fcd34d;--status-info-bg:#dbeafe;--status-info-text:#1e40af;--status-info-border:#93c5fd}[data-theme=dark]{--bg-page:#0f0d1a;--bg-card:#1e1b2e;--bg-card-hover:#252238;--bg-secondary:#161326;--bg-tertiary:#2d2a3e;--bg-input:#2d2a3e;--bg-overlay:#0009;--bg-overlay-heavy:#000000d9;--text-primary:#f3f0ff;--text-secondary:#a19db5;--text-tertiary:#6b6780;--text-disabled:#4a4660;--text-inverse:#171717;--text-brand:var(--color-violet-300);--border-default:#2d2a3e;--border-subtle:#1e1b2e;--border-strong:#3d3a50;--border-focus:var(--color-violet-400);--shadow-xs:0 1px 2px #0003;--shadow-sm:0 2px 4px #0000004d;--shadow-md:0 6px 12px #0006;--shadow-lg:0 10px 20px #00000080;--shadow-xl:0 20px 40px #0009;--shadow-2xl:0 25px 50px #000000b3;--shadow-inner:inset 0 2px 4px #0003;--shadow-brand:0 10px 25px -5px #8b5cf633;--gradient-brand:linear-gradient(135deg,#5b6abf 0%,#6b3fa0 100%);--gradient-hero:var(--gradient-brand);--gradient-card:linear-gradient(145deg,#1e1b2e 0%,#252238 100%);--gradient-accent:linear-gradient(135deg,#c084fc 0%,#e879a0 100%);--status-success-bg:#10b98126;--status-success-text:#6ee7b7;--status-success-border:#10b9814d;--status-error-bg:#ef444426;--status-error-text:#fca5a5;--status-error-border:#ef44444d;--status-warning-bg:#f59e0b26;--status-warning-text:#fcd34d;--status-warning-border:#f59e0b4d;--status-info-bg:#3b82f626;--status-info-text:#93c5fd;--status-info-border:#3b82f64d}:root,[data-theme=light]{--btn-primary-bg:var(--color-violet-600);--btn-primary-hover:var(--color-violet-700);--btn-primary-text:#fff;--btn-primary-shadow:var(--shadow-brand);--card-bg:var(--bg-card);--card-radius:var(--radius-2xl);--card-shadow:var(--shadow-lg);--card-border:var(--border-default);--input-bg:var(--bg-input);--input-border:var(--border-default);--input-focus-ring:#8b5cf633;--input-radius:var(--radius-xl)}[data-theme=dark]{--btn-primary-bg:var(--color-violet-600);--btn-primary-hover:var(--color-violet-500);--btn-primary-text:#fff;--btn-primary-shadow:0 10px 25px -5px #8b5cf626;--card-bg:var(--bg-card);--card-radius:var(--radius-2xl);--card-shadow:var(--shadow-lg);--card-border:var(--border-default);--input-bg:var(--bg-input);--input-border:var(--border-strong);--input-focus-ring:#8b5cf64d;--input-radius:var(--radius-xl)}:root{--primary-color:var(--color-violet-500);--primary-color-light:var(--color-violet-400);--primary-color-lighter:var(--color-violet-300);--primary-color-dark:var(--color-violet-600);--primary-color-darker:var(--color-violet-700);--primary-50:var(--color-violet-50);--primary-100:var(--color-violet-100);--primary-200:var(--color-violet-200);--primary-300:var(--color-violet-300);--primary-400:var(--color-violet-400);--primary-500:var(--color-violet-500);--primary-600:var(--color-violet-600);--primary-700:var(--color-violet-700);--primary-800:var(--color-violet-800);--primary-900:var(--color-violet-900);--bg-primary:var(--bg-card);--bg-hover:var(--bg-tertiary);--bg-active:var(--color-violet-400);--border-primary:var(--border-default);--border-secondary:var(--border-strong);--border-color:var(--border-default);--gradient-primary:var(--gradient-brand);--gradient-success:linear-gradient(135deg,#4facfe 0%,#00f2fe 100%);--gradient-glass:linear-gradient(-45deg,#ee7752,#e73c7e,#23a6d5,#23d5ab);--gradient-glass-overlay:linear-gradient(to bottom,transparent 0%,#0006 100%);--gradient-neon-blue:linear-gradient(90deg,#00c6ff,#0072ff);--secondary-color:var(--color-green-500);--secondary-color-light:#34d399;--secondary-color-dark:var(--color-green-600);--accent-color:var(--color-violet-500);--accent-color-light:var(--color-violet-400);--accent-color-dark:var(--color-violet-600);--success:var(--color-green-500);--success-color:var(--color-green-500);--success-bg:var(--status-success-bg);--success-border:var(--status-success-border);--warning:var(--color-amber-500);--warning-color:var(--color-amber-500);--warning-bg:var(--status-warning-bg);--warning-border:var(--status-warning-border);--error:var(--color-red-500);--error-color:var(--color-red-500);--error-bg:var(--status-error-bg);--error-border:var(--status-error-border);--info:var(--color-blue-500);--info-color:var(--color-blue-500);--info-bg:var(--status-info-bg);--info-border:var(--status-info-border);--neutral-50:var(--color-neutral-50);--neutral-100:var(--color-neutral-100);--neutral-200:var(--color-neutral-200);--neutral-300:var(--color-neutral-300);--neutral-400:var(--color-neutral-400);--neutral-500:var(--color-neutral-500);--neutral-600:var(--color-neutral-600);--neutral-700:var(--color-neutral-700);--neutral-800:var(--color-neutral-800);--neutral-900:var(--color-neutral-900);--shadow:var(--shadow-md);--shadow-base:var(--shadow-md);--shadow-primary:var(--shadow-brand);--shadow-success:0 10px 25px -5px #10b9814d;--shadow-warning:0 10px 25px -5px #f59e0b4d;--shadow-error:0 10px 25px -5px #ef44444d;--rounded-sm:var(--radius-sm);--rounded:var(--radius-base);--rounded-md:var(--radius-md);--rounded-lg:var(--radius-lg);--rounded-xl:var(--radius-xl);--rounded-2xl:var(--radius-2xl);--rounded-3xl:var(--radius-3xl);--rounded-full:var(--radius-full);--glass-bg-heavy:#ffffff26;--glass-bg-medium:#ffffff1a;--glass-bg-light:#ffffff0d;--glass-bg-lighter:#fff3;--glass-bg-dark:#0003;--glass-bg-darker:#0006;--glass-border:#fff3;--glass-border-light:#ffffff1a;--glass-border-strong:#ffffff4d}@media(prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}*{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;height:100%;font-size:16px;transition:background-color .3s,color .3s}body{min-height:100vh;font-family:var(--font-primary);font-size:var(--text-base);font-weight:var(--font-normal);line-height:var(--leading-normal);background-color:var(--bg-page);color:var(--text-primary);margin:0}#root{height:100%}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);font-weight:var(--font-bold);line-height:var(--leading-tight);color:var(--text-primary)}h1{font-size:clamp(var(--text-2xl),5vw,var(--text-4xl))}h2{font-size:clamp(var(--text-xl),4vw,var(--text-3xl))}h3{font-size:var(--text-2xl)}h4{font-size:var(--text-xl)}h5{font-size:var(--text-lg)}h6{font-size:var(--text-base)}p{margin-bottom:var(--space-4);color:var(--text-secondary)}a{color:var(--text-brand);transition:color var(--transition-fast);text-decoration:none}a:hover{color:var(--color-violet-700);text-decoration:underline}[data-theme=dark] a:hover{color:var(--color-violet-200)}:focus-visible{outline:2px solid var(--border-focus);outline-offset:2px}:focus:not(:focus-visible){outline:none}.skip-link{top:-100%;left:var(--space-4);z-index:var(--z-tooltip);padding:var(--space-3)var(--space-6);background:var(--bg-card);color:var(--text-brand);border:2px solid var(--border-focus);border-radius:var(--radius-lg);font-weight:var(--font-semibold);transition:top var(--transition-fast);text-decoration:none;position:absolute}.skip-link:focus{top:var(--space-4)}.btn{justify-content:center;align-items:center;gap:var(--space-2);padding:var(--space-3)var(--space-6);font-family:var(--font-primary);font-size:var(--text-base);font-weight:var(--font-medium);line-height:var(--leading-none);border-radius:var(--radius-lg);cursor:pointer;white-space:nowrap;-webkit-user-select:none;-moz-user-select:none;user-select:none;border:none;min-width:44px;min-height:44px;transition:transform .2s,box-shadow .2s,background-color .2s,color .2s,border-color .2s,opacity .2s;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--btn-primary-bg);color:var(--btn-primary-text);box-shadow:var(--shadow-sm)}.btn-primary:hover:not(:disabled){background:var(--btn-primary-hover);box-shadow:var(--btn-primary-shadow);transform:translateY(-2px)}.btn-primary:active:not(:disabled){box-shadow:none;transform:translateY(1px)}.btn-secondary{background-color:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-default)}.btn-secondary:hover:not(:disabled){background-color:var(--bg-card-hover);border-color:var(--border-strong)}.btn-outline{color:var(--text-brand);border:2px solid var(--text-brand);background-color:#0000}.btn-outline:hover:not(:disabled){background-color:var(--btn-primary-bg);color:var(--btn-primary-text)}.btn-ghost{color:var(--text-secondary);background-color:#0000}.btn-ghost:hover:not(:disabled){background-color:var(--bg-tertiary);color:var(--text-primary)}.btn-sm{padding:var(--space-2)var(--space-4);font-size:var(--text-sm);min-height:36px}.btn-lg{padding:var(--space-4)var(--space-8);font-size:var(--text-lg);min-height:52px}.input{width:100%;padding:var(--space-3)var(--space-4);font-family:var(--font-primary);font-size:var(--text-base);line-height:var(--leading-normal);color:var(--text-primary);background-color:var(--input-bg);border:2px solid var(--input-border);border-radius:var(--input-radius);min-height:44px;transition:border-color .2s,box-shadow .2s}.input::-moz-placeholder{color:var(--text-tertiary)}.input::placeholder{color:var(--text-tertiary)}.input:hover{border-color:var(--border-strong)}.input:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px var(--input-focus-ring);outline:none}.input:disabled{background-color:var(--bg-tertiary);color:var(--text-disabled);cursor:not-allowed}.input-group{position:relative}.input-icon{left:var(--space-4);color:var(--text-tertiary);pointer-events:none;position:absolute;top:50%;transform:translateY(-50%)}.input-group .input{padding-left:var(--space-12)}.card{background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--card-radius);box-shadow:var(--shadow-sm);transition:transform .2s,box-shadow .2s}.card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.card-elevated{box-shadow:var(--card-shadow)}.card-flat{box-shadow:none;border:1px solid var(--card-border)}.card-header{padding:var(--space-6);border-bottom:1px solid var(--card-border)}.card-body{padding:var(--space-6)}.card-footer{padding:var(--space-6);border-top:1px solid var(--card-border);background-color:var(--bg-secondary);border-bottom-left-radius:var(--card-radius);border-bottom-right-radius:var(--card-radius)}.badge{align-items:center;gap:var(--space-1);padding:var(--space-1)var(--space-3);font-size:var(--text-xs);font-weight:var(--font-semibold);line-height:var(--leading-none);border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.05em;display:inline-flex}.badge-primary{background-color:var(--color-violet-500);color:var(--text-inverse)}.badge-success{background-color:var(--status-success-bg);color:var(--status-success-text)}.badge-warning{background-color:var(--status-warning-bg);color:var(--status-warning-text)}.badge-error{background-color:var(--status-error-bg);color:var(--status-error-text)}.gradient-primary{background:var(--gradient-brand)}.gradient-hero{background:var(--gradient-hero)}.text-primary{color:var(--text-primary)}.text-secondary{color:var(--text-secondary)}.text-tertiary{color:var(--text-tertiary)}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}@keyframes wobble{0%,to{transform:rotate(0)scale(1)}25%{transform:rotate(-5deg)scale(1.05)}75%{transform:rotate(5deg)scale(1.05)}}@keyframes bounceIn{0%{opacity:0;transform:scale(0)}60%{transform:scale(1.2)}to{opacity:1;transform:scale(1)}}@keyframes confettiFall{0%{opacity:1;transform:translateY(-100vh)rotate(0)}to{opacity:0;transform:translateY(100vh)rotate(720deg)}}@keyframes scoreCircleDraw{0%{stroke-dashoffset:var(--circumference)}to{stroke-dashoffset:var(--final-offset)}}@keyframes pulseGlow{0%,to{box-shadow:0 0 5px #8b5cf64d}50%{box-shadow:0 0 20px #8b5cf699}}.animate-fade-in{animation:fadeIn var(--transition-base)ease-out}.animate-slide-in{animation:slideInRight var(--transition-base)ease-out}.animate-wobble{animation:1s ease-in-out infinite wobble}.animate-bounce-in{animation:.6s ease-out bounceIn}.animate-pulse-glow{animation:2s ease-in-out infinite pulseGlow}.spinner{border-radius:var(--radius-full);border:3px solid #ffffff4d;border-top-color:#fff;width:20px;height:20px;animation:.6s linear infinite spin;display:inline-block}.sr-only{clip:rect(0,0,0,0);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-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-outline-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}@property --tw-backdrop-blur{syntax:"*";inherits:false}@property --tw-backdrop-brightness{syntax:"*";inherits:false}@property --tw-backdrop-contrast{syntax:"*";inherits:false}@property --tw-backdrop-grayscale{syntax:"*";inherits:false}@property --tw-backdrop-hue-rotate{syntax:"*";inherits:false}@property --tw-backdrop-invert{syntax:"*";inherits:false}@property --tw-backdrop-opacity{syntax:"*";inherits:false}@property --tw-backdrop-saturate{syntax:"*";inherits:false}@property --tw-backdrop-sepia{syntax:"*";inherits:false}@property --tw-ease{syntax:"*";inherits:false}.nav-shell{display:flex;flex-direction:column;min-height:100vh}.nav-header{display:none;position:sticky;top:0;z-index:var(--z-sticky);background:var(--bg-card);border-bottom:1px solid var(--border-default);box-shadow:var(--shadow-sm);height:var(--header-height)}.nav-header-inner{display:flex;align-items:center;justify-content:space-between;max-width:var(--container-max-width);margin:0 auto;padding:0 var(--space-6);height:100%;gap:var(--space-6)}.nav-brand{display:flex;align-items:center;gap:var(--space-3);cursor:pointer;flex-shrink:0}.nav-brand:focus-visible{outline:2px solid var(--border-focus);outline-offset:2px;border-radius:var(--radius-lg)}.nav-logo{width:40px;height:40px;background:var(--gradient-brand);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;font-size:20px}.nav-title{font-size:var(--text-xl);font-weight:var(--font-bold);color:var(--text-brand)}.nav-desktop{display:flex;align-items:center;gap:var(--space-1)}.nav-link{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);border:none;background:none;border-radius:var(--radius-lg);color:var(--text-secondary);font-size:var(--text-sm);font-weight:var(--font-medium);cursor:pointer;transition:background-color .2s ease,color .2s ease;min-height:44px}.nav-link:hover{background:var(--bg-secondary);color:var(--text-primary)}.nav-link-active{background:var(--bg-secondary);color:var(--text-brand);font-weight:var(--font-semibold)}.nav-actions{display:flex;align-items:center;gap:var(--space-3);flex-shrink:0}.nav-profile-btn{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2);border:none;background:none;border-radius:var(--radius-lg);cursor:pointer;transition:background-color .2s ease;min-height:44px}.nav-profile-btn:hover{background:var(--bg-secondary)}.nav-avatar{width:36px;height:36px;border-radius:var(--radius-full);background:var(--gradient-brand);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:var(--font-bold);font-size:var(--text-sm);flex-shrink:0}.nav-user-info{display:flex;flex-direction:column;align-items:flex-start;line-height:1.2}.nav-user-name{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--text-primary)}.nav-user-role{font-size:var(--text-xs);color:var(--text-tertiary)}.nav-logout-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border:1px solid var(--border-default);background:var(--bg-card);border-radius:var(--radius-lg);color:var(--text-secondary);font-size:var(--text-lg);cursor:pointer;transition:background-color .2s ease,color .2s ease;min-height:44px;min-width:44px}.nav-logout-btn:hover{background:var(--status-error-bg);color:var(--color-red-500);border-color:var(--status-error-border)}.nav-main{flex:1;padding-bottom:calc(var(--bottom-nav-height) + var(--space-4))}.nav-mobile{position:fixed;bottom:0;left:0;right:0;z-index:var(--z-fixed);display:flex;align-items:center;justify-content:space-around;height:var(--bottom-nav-height);background:var(--bg-card);border-top:1px solid var(--border-default);box-shadow:0 -2px 10px #00000014;padding:0 var(--space-2)}.nav-mobile-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:var(--space-2);border:none;background:none;color:var(--text-tertiary);font-size:var(--text-xs);cursor:pointer;transition:color .2s ease;min-height:44px;min-width:44px;border-radius:var(--radius-lg)}.nav-mobile-item:hover{color:var(--text-secondary)}.nav-mobile-active{color:var(--text-brand)}.nav-mobile-icon{font-size:20px;line-height:1}.nav-mobile-label{font-weight:var(--font-medium)}@media(min-width:768px){.nav-header{display:block}.nav-mobile{display:none}.nav-main{padding-bottom:0}}@media(max-width:900px){.theme-toggle-label{display:none}}.admin-dashboard{min-height:100%;background-color:var(--bg-page);padding:var(--space-8) var(--space-6)}.admin-dashboard-inner{max-width:var(--container-max-width);margin:0 auto;display:flex;flex-direction:column;gap:var(--space-10)}.admin-hero{position:relative;overflow:hidden;border-radius:var(--radius-2xl);background:var(--gradient-hero);padding:var(--space-10) var(--space-12);color:var(--text-inverse);box-shadow:var(--shadow-2xl)}.admin-hero-content{position:relative;z-index:1;max-width:38rem}.admin-hero-title{font-size:var(--text-4xl);font-weight:var(--font-extrabold);line-height:var(--leading-tight);letter-spacing:var(--tracking-tight);margin:0 0 var(--space-4) 0;color:var(--text-inverse)}.admin-hero-subtitle{font-size:var(--text-lg);font-weight:var(--font-medium);opacity:.9;margin:0 0 var(--space-8) 0;color:var(--text-inverse)}.admin-hero-actions{display:flex;flex-wrap:wrap;gap:var(--space-4)}.admin-btn-hero-solid{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-8);border-radius:var(--radius-xl);border:none;background:var(--bg-card);color:var(--text-brand);font-size:var(--text-base);font-weight:var(--font-bold);cursor:pointer;transition:transform var(--transition-fast),box-shadow var(--transition-fast);box-shadow:0 4px #00000026;min-height:44px}.admin-btn-hero-solid:hover{transform:translateY(-2px);box-shadow:0 6px #00000026}.admin-btn-hero-solid:active{transform:translateY(1px);box-shadow:0 2px #00000026}.admin-btn-hero-ghost{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-8);border-radius:var(--radius-xl);border:2px solid var(--glass-border);background:var(--glass-bg-medium);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);color:var(--text-inverse);font-size:var(--text-base);font-weight:var(--font-bold);cursor:pointer;transition:background-color var(--transition-fast);min-height:44px}.admin-btn-hero-ghost:hover{background:var(--glass-bg-heavy)}.admin-hero-decor{position:absolute;right:-5%;top:-20%;opacity:.1;pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none;font-size:240px;line-height:1}.admin-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:var(--space-6)}.admin-stat-card{background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid var(--border-subtle);padding:var(--space-6);box-shadow:0 20px 40px #2d2e370a;transition:transform var(--transition-base)}.admin-stat-card:hover{transform:translateY(-4px)}.admin-stat-top{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:var(--space-4)}.admin-stat-icon{width:48px;height:48px;border-radius:var(--radius-xl);display:flex;align-items:center;justify-content:center;flex-shrink:0}.admin-stat-icon--violet{background:var(--bg-secondary);color:var(--color-violet-600)}.admin-stat-icon--green{background:var(--status-success-bg);color:var(--color-green-600)}.admin-stat-icon--red{background:var(--status-error-bg);color:var(--color-red-500)}.admin-stat-icon--amber{background:var(--status-warning-bg);color:var(--color-amber-500)}.admin-stat-badge{display:inline-flex;align-items:center;padding:var(--space-1) var(--space-2);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--font-bold);white-space:nowrap}.admin-stat-badge--violet{background:var(--bg-secondary);color:var(--color-violet-600)}.admin-stat-badge--green{background:var(--status-success-bg);color:var(--color-green-600)}.admin-stat-number{font-size:var(--text-2xl);font-weight:var(--font-extrabold);color:var(--text-primary);line-height:var(--leading-none);margin-bottom:var(--space-1)}.admin-stat-label{font-size:var(--text-xs);font-weight:var(--font-bold);color:var(--text-tertiary);text-transform:uppercase;letter-spacing:var(--tracking-wider)}.admin-placeholder{background:var(--bg-secondary);border-radius:var(--radius-lg);border:2px dashed var(--border-strong);padding:var(--space-12) var(--space-10);display:flex;flex-direction:column;align-items:center;text-align:center}.admin-placeholder-icon-wrap{width:80px;height:80px;background:var(--bg-card);border-radius:var(--radius-2xl);display:flex;align-items:center;justify-content:center;margin-bottom:var(--space-6);box-shadow:var(--shadow-lg);color:var(--text-brand);font-size:40px}.admin-placeholder-title{font-size:var(--text-3xl);font-weight:var(--font-extrabold);color:var(--text-primary);margin:0 0 var(--space-3) 0}.admin-placeholder-desc{font-size:var(--text-base);font-weight:var(--font-medium);color:var(--text-secondary);max-width:32rem;margin:0}.admin-locked-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-6);margin-top:var(--space-12);width:100%}.admin-locked-card{background:var(--bg-card);border-radius:var(--radius-xl);border:1px solid var(--border-subtle);padding:var(--space-6);display:flex;align-items:center;gap:var(--space-4)}.admin-locked-icon{width:40px;height:40px;border-radius:var(--radius-lg);background:var(--bg-page);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--text-tertiary);font-size:20px}.admin-locked-label{display:flex;flex-direction:column;gap:var(--space-1);text-align:left}.admin-locked-name{font-size:var(--text-sm);font-weight:var(--font-bold);color:var(--text-primary)}.admin-locked-status{font-size:var(--text-xs);font-weight:var(--font-extrabold);text-transform:uppercase;letter-spacing:var(--tracking-wider);color:var(--text-tertiary)}@media(max-width:640px){.admin-dashboard{padding:var(--space-6) var(--space-4)}.admin-hero{padding:var(--space-8) var(--space-6)}.admin-hero-title{font-size:var(--text-3xl)}.admin-hero-subtitle{font-size:var(--text-base)}.admin-locked-grid{grid-template-columns:1fr}}@keyframes loginFloat{0%,to{transform:translateY(0) rotate(0)}50%{transform:translateY(-30px) rotate(15deg)}}.login-floating-icons{position:fixed;inset:0;pointer-events:none;z-index:0;overflow:hidden}.login-floating-icon{position:absolute;opacity:.12;color:var(--color-violet-500);animation:loginFloat 8s ease-in-out infinite;-webkit-user-select:none;-moz-user-select:none;user-select:none}.login-page{min-height:100vh;width:100%;background:var(--bg-secondary);display:flex;align-items:center;justify-content:center;position:relative;padding:var(--space-4);overflow:hidden}.login-card{position:relative;z-index:1;background:#ffffffb3;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.5);border-radius:var(--radius-3xl);box-shadow:0 40px 80px -15px #2d2e371a;padding:var(--space-8);width:100%;max-width:480px;display:flex;flex-direction:column;align-items:center;color:var(--text-primary);transition:transform .3s ease,box-shadow .3s ease}[data-theme=dark] .login-card{background:#1e1b2ed9;border:1px solid rgba(255,255,255,.08);box-shadow:0 40px 80px -15px #0006}.login-card:hover{transform:translateY(-5px);box-shadow:0 50px 90px -15px #2d2e3726}@media(min-width:768px){.login-card{padding:var(--space-12)}}.login-header{margin-bottom:var(--space-10);display:flex;flex-direction:column;align-items:center;text-align:center}.logo-icon{width:80px;height:80px;background:#8b5cf61a;border-radius:var(--radius-2xl);display:flex;align-items:center;justify-content:center;margin-bottom:var(--space-6);border:1px solid rgba(139,92,246,.2);box-shadow:var(--shadow-inner);color:var(--color-violet-600)}[data-theme=dark] .logo-icon{background:#8b5cf626;border-color:#8b5cf64d}.login-header h1{font-size:var(--text-3xl);font-weight:var(--font-extrabold);color:var(--text-primary);margin-bottom:var(--space-2);letter-spacing:var(--tracking-tight)}.login-header p{font-size:var(--text-base);color:var(--text-secondary);font-weight:var(--font-medium);padding:0 var(--space-4)}.login-tabs{display:flex;padding:6px;border-radius:var(--radius-full);margin-bottom:var(--space-8);width:100%;background:#f1effc80;border:1px solid rgba(173,172,183,.1)}[data-theme=dark] .login-tabs{background:#2d2a3e80;border-color:#ffffff0d}.login-tab{flex:1;padding:10px 24px;border-radius:var(--radius-full);border:none;font-size:var(--text-sm);font-weight:var(--font-semibold);cursor:pointer;transition:background-color .3s ease,color .3s ease,box-shadow .3s ease;min-height:44px;background:transparent;color:var(--text-secondary)}.login-tab:hover{color:var(--text-primary)}.login-tab-active{background:var(--bg-card);color:var(--text-brand);box-shadow:var(--shadow-sm);border:1px solid rgba(173,172,183,.05)}[data-theme=dark] .login-tab-active{background:var(--bg-card)}.login-form{width:100%;display:flex;flex-direction:column;gap:var(--space-5)}.login-form .input-group{display:flex;flex-direction:column;gap:var(--space-2)}.login-form .input-group label{font-size:11px;font-weight:var(--font-extrabold);text-transform:uppercase;letter-spacing:.1em;color:var(--text-secondary);margin-left:var(--space-2)}.login-form .input-wrapper{position:relative}.login-form .input-wrapper .input-icon{position:absolute;left:var(--space-4);top:50%;transform:translateY(-50%);color:var(--text-tertiary);pointer-events:none;transition:color .2s ease}.login-form .input{width:100%;background:#ffffff80;border:1px solid rgba(173,172,183,.2);border-radius:var(--radius-xl);padding:var(--space-4) var(--space-4) var(--space-4) var(--space-12);color:var(--text-primary);font-size:var(--text-base);font-weight:var(--font-medium);transition:border-color .2s ease,box-shadow .2s ease,background-color .2s ease;min-height:56px}[data-theme=dark] .login-form .input{background:#2d2a3e80;border-color:#ffffff1a}.login-form .input::-moz-placeholder{color:var(--text-tertiary);opacity:.6}.login-form .input::placeholder{color:var(--text-tertiary);opacity:.6}.login-form .input:focus{outline:none;background:var(--bg-card);border-color:#8b5cf64d;box-shadow:0 0 0 4px #8b5cf61a}.login-form .input:focus~.input-icon,.login-form .input-wrapper:focus-within .input-icon{color:var(--color-violet-500)}.form-options{display:flex;justify-content:space-between;align-items:center;font-size:var(--text-sm);color:var(--text-secondary)}.checkbox-label{display:flex;align-items:center;gap:var(--space-2);cursor:pointer;min-height:44px}.checkbox{width:18px;height:18px;border-radius:var(--radius-sm);border:2px solid var(--border-strong);background:var(--bg-card);-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer;position:relative}.checkbox:checked{background:var(--color-violet-600);border-color:var(--color-violet-600)}.checkbox:checked:after{content:"✓";position:absolute;color:#fff;font-size:12px;font-weight:700;top:50%;left:50%;transform:translate(-50%,-50%)}.forgot-password{color:var(--text-brand);text-decoration:none;font-weight:var(--font-bold);font-size:var(--text-xs);transition:color .2s ease;min-height:44px;display:flex;align-items:center}.forgot-password:hover{text-decoration:underline}.btn-login{width:100%;background:var(--color-violet-600);color:#fff;border:none;border-radius:var(--radius-xl);padding:18px var(--space-6);font-size:var(--text-base);font-weight:var(--font-bold);cursor:pointer;margin-top:var(--space-6);display:flex;align-items:center;justify-content:center;gap:var(--space-3);min-height:56px;box-shadow:0 6px #541bb0,0 8px 15px -4px #702ae166;transition:transform .2s cubic-bezier(.34,1.56,.64,1),box-shadow .2s cubic-bezier(.34,1.56,.64,1)}.btn-login:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px #541bb0,0 12px 20px -4px #702ae180}.btn-login:active:not(:disabled){transform:translateY(4px);box-shadow:0 2px #541bb0,0 4px 6px -2px #702ae14d}.btn-login:disabled{opacity:.7;cursor:not-allowed;transform:none;background:var(--color-neutral-400);box-shadow:0 4px 0 0 var(--color-neutral-500)}.login-error{color:var(--status-error-text);text-align:center;font-size:var(--text-sm);background:var(--status-error-bg);padding:var(--space-3);border-radius:var(--radius-lg);border:1px solid var(--status-error-border)}.social-login{width:100%}.divider{display:flex;align-items:center;gap:var(--space-4);margin:var(--space-10) 0 var(--space-8);width:100%}.divider:before,.divider:after{content:"";flex:1;height:1px;background:#adacb733}.divider-text{font-size:11px;font-weight:var(--font-extrabold);text-transform:uppercase;letter-spacing:.15em;color:var(--text-secondary);background:transparent;padding:0 var(--space-2);white-space:nowrap}.social-buttons{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4)}.btn-social{display:flex;align-items:center;justify-content:center;gap:var(--space-3);background:#ffffff80;border:1px solid rgba(173,172,183,.2);border-radius:var(--radius-xl);padding:14px var(--space-4);cursor:pointer;transition:background-color .2s ease,box-shadow .2s ease,transform .2s ease;color:var(--text-primary);font-size:var(--text-sm);font-weight:var(--font-bold);min-height:52px}[data-theme=dark] .btn-social{background:#2d2a3e80;border-color:#ffffff1a}.btn-social:hover{background:var(--bg-card);box-shadow:var(--shadow-md);transform:translateY(-1px)}.demo-badge{margin-top:var(--space-10);padding:var(--space-5);background:linear-gradient(135deg,rgba(139,92,246,.1),transparent);border-radius:var(--radius-2xl);border:1px solid rgba(139,92,246,.2);text-align:center;width:100%;box-shadow:var(--shadow-inner)}.demo-badge-label{display:flex;align-items:center;justify-content:center;gap:var(--space-2);font-size:11px;font-weight:900;text-transform:uppercase;letter-spacing:.2em;color:var(--text-brand);margin-bottom:var(--space-3)}.demo-badge-divider{width:100%;height:1px;background:#8b5cf61a;margin-bottom:var(--space-3)}.demo-credentials{display:inline-block;background:#fffc;padding:var(--space-2) var(--space-4);border-radius:var(--radius-lg);color:var(--text-brand);font-family:var(--font-mono);font-size:12px;font-weight:var(--font-bold);box-shadow:var(--shadow-sm);border:1px solid rgba(139,92,246,.05)}[data-theme=dark] .demo-credentials{background:#2d2a3ecc}.course-catalog{min-height:100vh;width:100%;background:var(--bg-page);padding:var(--space-6) var(--space-6) var(--space-16);overflow-x:hidden}.catalog-container{max-width:1400px;margin:0 auto;display:flex;flex-direction:column;gap:0}.catalog-header{text-align:center;padding:var(--space-10) var(--space-4) var(--space-12);max-width:640px;margin:0 auto}.catalog-header h1{font-size:clamp(2.5rem,6vw,4.5rem);font-weight:var(--font-extrabold);color:var(--text-primary);letter-spacing:var(--tracking-tight);line-height:1.05;margin-bottom:var(--space-4)}.catalog-header h1 .headline-italic{font-style:italic;font-weight:var(--font-normal);color:var(--color-violet-600)}.catalog-header p{font-size:var(--text-xl);font-weight:var(--font-medium);color:var(--text-secondary);line-height:var(--leading-relaxed);margin:0}.catalog-filters{display:flex;flex-direction:column;align-items:center;gap:var(--space-3);background:#ffffff80;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);padding:var(--space-3);border-radius:var(--radius-full);border:1px solid rgba(255,255,255,.8);box-shadow:0 10px 40px #2d2e3714;max-width:900px;width:100%;margin:0 auto var(--space-16)}[data-theme=dark] .catalog-filters{background:#1e1b2e99;border-color:var(--border-default)}.filter-divider{display:none;width:1px;height:2rem;background:var(--border-default);opacity:.4;flex-shrink:0}.filter-group{position:relative;flex:1;width:100%}.filter-group-icon{position:absolute;left:var(--space-5);top:50%;transform:translateY(-50%);color:var(--color-violet-600);pointer-events:none;display:flex;align-items:center}.filter-group-icon svg{width:18px;height:18px}.filter-select{-moz-appearance:none;appearance:none;-webkit-appearance:none;width:100%;padding:var(--space-4) var(--space-10) var(--space-4) 3rem;background:transparent;border:none;border-radius:var(--radius-full);color:var(--text-primary);font-weight:var(--font-bold);font-size:var(--text-base);cursor:pointer;transition:background var(--transition-fast);outline:none}.filter-select:hover{background:#702ae10d}.filter-select:focus-visible{outline:2px solid var(--color-violet-500);outline-offset:2px;border-radius:var(--radius-full)}.filter-select option{background:var(--bg-card);color:var(--text-primary)}.filter-chevron{position:absolute;right:var(--space-5);top:50%;transform:translateY(-50%);color:var(--text-tertiary);pointer-events:none;transition:transform var(--transition-fast)}.filter-chevron svg{width:16px;height:16px}.filter-group:hover .filter-chevron{transform:translateY(calc(-50% + 1px))}.btn-apply-filters{width:100%;padding:var(--space-4) var(--space-10);background:var(--btn-primary-bg);color:var(--btn-primary-text);border:none;border-radius:var(--radius-full);font-weight:var(--font-extrabold);font-size:var(--text-base);cursor:pointer;transition:all var(--transition-fast);box-shadow:0 8px 20px #702ae140;white-space:nowrap;flex-shrink:0}.btn-apply-filters:hover{background:var(--btn-primary-hover);box-shadow:0 12px 28px #702ae159;transform:translateY(-1px)}.btn-apply-filters:active{transform:scale(.96);box-shadow:0 4px 12px #702ae133}.btn-apply-filters:focus-visible{outline:2px solid var(--color-violet-500);outline-offset:3px}.btn-clear{background:transparent;border:1px solid var(--border-default);border-radius:var(--radius-full);padding:var(--space-4) var(--space-8);color:var(--text-secondary);font-weight:var(--font-bold);font-size:var(--text-sm);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;flex-shrink:0}.btn-clear:hover{background:var(--bg-card-hover);color:var(--text-primary);border-color:var(--color-violet-300);transform:translateY(-1px)}.btn-clear:focus-visible{outline:2px solid var(--color-violet-500);outline-offset:3px}.course-grid{display:grid;grid-template-columns:1fr;gap:var(--space-8);padding:var(--space-2) 0}.course-card{background:var(--bg-card);border-radius:var(--radius-3xl);padding:var(--space-8);box-shadow:0 20px 50px #2d2e370d;outline:1px solid rgba(173,172,183,.1);border-bottom:4px solid transparent;transition:transform var(--transition-slow),box-shadow var(--transition-slow),border-color var(--transition-slow);display:flex;flex-direction:column;position:relative;cursor:pointer}.course-card:nth-child(odd){--card-accent: var(--color-violet-600)}.course-card:nth-child(3n){--card-accent: var(--color-amber-500)}.course-card:nth-child(4n){--card-accent: var(--color-red-500)}.course-card:hover{transform:translateY(-8px) scale(1.02);box-shadow:0 30px 60px #2d2e3724;border-bottom-color:var(--card-accent, var(--color-violet-600));z-index:2}.course-card:focus-visible{outline:2px solid var(--color-violet-500);outline-offset:4px}.card-top-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-10)}.course-flag{font-size:4.5rem;line-height:1;filter:drop-shadow(0 10px 15px rgba(0,0,0,.15)) drop-shadow(0 4px 6px rgba(0,0,0,.1));transition:transform var(--transition-slow);display:block}.course-card:hover .course-flag{transform:scale(1.1) rotate(3deg)}.course-card:nth-child(2n):hover .course-flag{transform:scale(1.1) rotate(-3deg)}.difficulty-badge{padding:var(--space-2) var(--space-5);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--font-extrabold);text-transform:uppercase;letter-spacing:var(--tracking-wider);line-height:1}.difficulty-badge--beginner{background:var(--color-violet-100);color:var(--color-violet-900);box-shadow:0 0 15px -2px #702ae166}.difficulty-badge--elementary{background:var(--color-violet-100);color:var(--color-violet-900);box-shadow:0 0 15px -2px #702ae159}.difficulty-badge--intermediate{background:#ff955a;color:#552100;box-shadow:0 0 15px -2px #ff955a66}.difficulty-badge--advanced,.difficulty-badge--expert{background:#f74b6d;color:#510017;box-shadow:0 0 15px -2px #b413404d}[data-theme=dark] .difficulty-badge--beginner,[data-theme=dark] .difficulty-badge--elementary{background:#b28cff33;color:var(--color-violet-300)}.card-body h3{font-size:var(--text-2xl);font-weight:var(--font-extrabold);color:var(--text-primary);line-height:1.25;margin-bottom:var(--space-3);letter-spacing:var(--tracking-tight)}.card-body p{font-size:var(--text-base);color:var(--text-secondary);line-height:var(--leading-relaxed);margin-bottom:var(--space-8);display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;opacity:.8;transition:opacity var(--transition-fast);flex:1}.course-card:hover .card-body p{opacity:1}.card-footer{display:flex;align-items:center;justify-content:space-between;padding-top:var(--space-6);border-top:1px solid rgba(173,172,183,.1);margin-top:auto}.card-meta{display:flex;align-items:center;gap:var(--space-2);color:var(--text-tertiary);font-size:var(--text-sm);font-weight:var(--font-bold)}.card-meta svg{width:20px;height:20px;flex-shrink:0}.btn-view-course{background:#702ae10d;color:var(--color-violet-600);border:none;border-radius:var(--radius-full);padding:var(--space-2) var(--space-6);font-weight:var(--font-bold);font-size:var(--text-sm);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.btn-view-course:hover{background:var(--color-violet-600);color:#fff;transform:translateY(-1px)}.btn-view-course:focus-visible{outline:2px solid var(--color-violet-500);outline-offset:3px}[data-theme=dark] .btn-view-course{background:#a476ff26;color:var(--color-violet-300)}[data-theme=dark] .btn-view-course:hover{background:var(--color-violet-600);color:#fff}.catalog-empty{grid-column:1 / -1;text-align:center;padding:var(--space-16) var(--space-4);color:var(--text-secondary)}.catalog-empty h3{font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--text-primary);margin-bottom:var(--space-2)}.catalog-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:var(--space-4);color:var(--text-secondary)}.spinner{width:44px;height:44px;border:3px solid var(--border-default);border-top-color:var(--color-violet-500);border-radius:50%;animation:spin .8s linear infinite}.catalog-error{display:flex;align-items:center;justify-content:center;min-height:60vh;padding:var(--space-8)}.alert-error{background:var(--status-error-bg);color:var(--status-error-text);border:1px solid var(--status-error-border);border-radius:var(--radius-xl);padding:var(--space-6) var(--space-8);font-weight:var(--font-semibold);text-align:center}.pagination-container{display:flex;align-items:center;justify-content:center;gap:var(--space-12);padding-top:var(--space-16);flex-wrap:wrap}.pagination-prev,.pagination-next{display:inline-flex;align-items:center;gap:var(--space-3);color:var(--text-secondary);font-weight:var(--font-extrabold);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:var(--tracking-wider);background:transparent;border:none;cursor:pointer;transition:color var(--transition-fast);padding:var(--space-2)}.pagination-prev:hover:not(:disabled),.pagination-next:hover:not(:disabled){color:var(--color-violet-600)}.pagination-prev:disabled,.pagination-next:disabled{opacity:.35;cursor:not-allowed}.pagination-prev:focus-visible,.pagination-next:focus-visible{outline:2px solid var(--color-violet-500);outline-offset:4px;border-radius:var(--radius-base)}.pagination-prev svg,.pagination-next svg{width:16px;height:16px;transition:transform var(--transition-fast);flex-shrink:0}.pagination-prev:hover:not(:disabled) svg{transform:translate(-3px)}.pagination-next:hover:not(:disabled) svg{transform:translate(3px)}.pagination-pages{display:flex;align-items:center;gap:var(--space-3)}.pagination-page-btn{width:3rem;height:3rem;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-full);font-weight:var(--font-extrabold);font-size:var(--text-base);border:none;cursor:pointer;transition:all var(--transition-fast);background:transparent;color:var(--text-secondary)}.pagination-page-btn:hover:not(.active){background:var(--bg-card-hover);color:var(--text-primary)}.pagination-page-btn.active{background:var(--color-violet-600);color:#fff;box-shadow:0 6px 16px #702ae14d;cursor:default}.pagination-page-btn:focus-visible{outline:2px solid var(--color-violet-500);outline-offset:2px}.pagination-ellipsis{color:var(--text-tertiary);font-weight:var(--font-bold);padding:0 var(--space-1);-webkit-user-select:none;-moz-user-select:none;user-select:none}@media(min-width:768px){.course-catalog{padding:var(--space-6) var(--space-8) var(--space-16)}.catalog-filters{flex-direction:row}.filter-divider{display:block}.filter-group,.btn-apply-filters,.btn-clear{width:auto}.course-grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:1024px){.course-catalog{padding:var(--space-6) var(--space-12) var(--space-16)}.course-grid{grid-template-columns:repeat(3,1fr)}}@media(prefers-reduced-motion:reduce){.course-card:hover,.course-card:hover .course-flag{transform:none}}@keyframes wl-slide-up-in{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}@keyframes wl-slide-down-out{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(100%)}}@keyframes wl-fade-scale-in{0%{opacity:0;transform:scale(.95) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes wl-fade-scale-out{0%{opacity:1;transform:scale(1) translateY(0)}to{opacity:0;transform:scale(.95) translateY(8px)}}@keyframes wl-backdrop-in{0%{opacity:0}to{opacity:1}}@keyframes wl-backdrop-out{0%{opacity:1}to{opacity:0}}.wl-toast-region{position:fixed;bottom:calc(var(--bottom-nav-height, 64px) + var(--space-4, 1rem));left:var(--space-4, 1rem);right:var(--space-4, 1rem);z-index:calc(var(--z-tooltip, 1070) + 10);display:flex;flex-direction:column;align-items:stretch;gap:var(--space-2, .5rem);pointer-events:none}@media(min-width:640px){.wl-toast-region{bottom:var(--space-8, 2rem);left:auto;right:var(--space-8, 2rem);width:360px;align-items:flex-end}}.wl-toast{pointer-events:all;display:flex;align-items:flex-start;gap:var(--space-3, .75rem);padding:var(--space-4, 1rem);background:var(--bg-card);border:1px solid var(--border-default);border-left-width:4px;border-radius:var(--radius-lg, .75rem);box-shadow:var(--shadow-xl);font-family:var(--font-primary);font-size:var(--text-sm, .875rem);line-height:var(--leading-normal, 1.5);color:var(--text-primary);width:100%;position:relative}.wl-toast--entering{animation:wl-slide-up-in .3s cubic-bezier(.4,0,.2,1) forwards}.wl-toast--leaving{animation:wl-slide-down-out .25s cubic-bezier(.4,0,.2,1) forwards}.wl-toast--success{border-left-color:var(--color-green-500)}.wl-toast--error{border-left-color:var(--color-red-500)}.wl-toast--info{border-left-color:var(--color-blue-500)}.wl-toast__icon{flex-shrink:0;width:20px;height:20px;margin-top:1px}.wl-toast--success .wl-toast__icon{color:var(--color-green-500)}.wl-toast--error .wl-toast__icon{color:var(--color-red-500)}.wl-toast--info .wl-toast__icon{color:var(--color-blue-500)}.wl-toast__message{flex:1;min-width:0;font-weight:var(--font-medium, 500)}.wl-toast__close{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;margin:-4px -4px 0 0;background:transparent;border:none;border-radius:var(--radius-base, .375rem);color:var(--text-tertiary);cursor:pointer;transition:background-color var(--transition-fast),color var(--transition-fast);min-width:44px;min-height:44px}.wl-toast__close:hover{background-color:var(--bg-tertiary);color:var(--text-primary)}.wl-toast__close:focus-visible{outline:2px solid var(--border-focus);outline-offset:2px}.wl-dialog-backdrop{position:fixed;inset:0;z-index:var(--z-modal-backdrop, 1040);background:var(--bg-overlay-heavy);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:var(--space-4, 1rem)}.wl-dialog-backdrop--entering{animation:wl-backdrop-in .2s ease forwards}.wl-dialog-backdrop--leaving{animation:wl-backdrop-out .15s ease forwards}.wl-dialog{position:relative;z-index:var(--z-modal, 1050);width:100%;max-width:420px;background:var(--bg-card);border:1px solid var(--border-default);border-radius:var(--radius-2xl, 1.5rem);box-shadow:var(--shadow-2xl);font-family:var(--font-primary);overflow:hidden}.wl-dialog--entering{animation:wl-fade-scale-in .25s cubic-bezier(.4,0,.2,1) forwards}.wl-dialog--leaving{animation:wl-fade-scale-out .2s cubic-bezier(.4,0,.2,1) forwards}.wl-dialog__header{display:flex;align-items:flex-start;gap:var(--space-3, .75rem);padding:var(--space-6, 1.5rem) var(--space-6, 1.5rem) 0}.wl-dialog__icon{flex-shrink:0;width:40px;height:40px;border-radius:var(--radius-full, 9999px);display:flex;align-items:center;justify-content:center}.wl-dialog--default .wl-dialog__icon{background:var(--status-info-bg);color:var(--color-blue-500)}.wl-dialog--danger .wl-dialog__icon{background:var(--status-error-bg);color:var(--color-red-500)}.wl-dialog__title-group{flex:1;min-width:0}.wl-dialog__title{margin:0;font-size:var(--text-lg, 1.125rem)!important;font-weight:var(--font-semibold, 600)!important;line-height:var(--leading-tight, 1.25)!important;color:var(--text-primary)!important}.wl-dialog__body{padding:var(--space-4, 1rem) var(--space-6, 1.5rem) var(--space-6, 1.5rem)}.wl-dialog__body p{margin:0;font-size:var(--text-sm, .875rem);line-height:var(--leading-relaxed, 1.625);color:var(--text-secondary)}.wl-dialog__footer{display:flex;flex-direction:column;gap:var(--space-2, .5rem);padding:var(--space-4, 1rem) var(--space-6, 1.5rem) var(--space-6, 1.5rem);border-top:1px solid var(--border-subtle)}@media(min-width:400px){.wl-dialog__footer{flex-direction:row-reverse;justify-content:flex-start}}.wl-dialog__btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2, .5rem);padding:var(--space-3, .75rem) var(--space-5, 1.25rem);font-family:var(--font-primary);font-size:var(--text-sm, .875rem);font-weight:var(--font-semibold, 600);line-height:var(--leading-none, 1);border-radius:var(--radius-lg, .75rem);border:2px solid transparent;cursor:pointer;min-height:44px;min-width:80px;transition:background-color var(--transition-fast),color var(--transition-fast),border-color var(--transition-fast),box-shadow var(--transition-fast),transform .15s ease;white-space:nowrap;flex:1}@media(min-width:400px){.wl-dialog__btn{flex:0 0 auto}}.wl-dialog__btn:focus-visible{outline:2px solid var(--border-focus);outline-offset:2px}.wl-dialog__btn:active{transform:scale(.97)}.wl-dialog--default .wl-dialog__btn--confirm{background:var(--btn-primary-bg);color:var(--btn-primary-text);border-color:var(--btn-primary-bg)}.wl-dialog--default .wl-dialog__btn--confirm:hover{background:var(--btn-primary-hover);border-color:var(--btn-primary-hover);box-shadow:var(--shadow-brand)}.wl-dialog--danger .wl-dialog__btn--confirm{background:var(--color-red-500);color:#fff;border-color:var(--color-red-500)}.wl-dialog--danger .wl-dialog__btn--confirm:hover{background:var(--color-red-600);border-color:var(--color-red-600);box-shadow:var(--shadow-error, 0 10px 25px -5px rgba(239, 68, 68, .3))}.wl-dialog__btn--cancel{background:transparent;color:var(--text-secondary);border-color:var(--border-strong)}.wl-dialog__btn--cancel:hover{background:var(--bg-tertiary);color:var(--text-primary);border-color:var(--border-strong)}@media(prefers-reduced-motion:reduce){.wl-toast--entering,.wl-toast--leaving,.wl-dialog--entering,.wl-dialog--leaving,.wl-dialog-backdrop--entering,.wl-dialog-backdrop--leaving{animation:none!important;transition:none!important}}.course-detail{min-height:100vh;width:100%;background:var(--bg-page);display:flex;align-items:flex-start;justify-content:center;padding:var(--space-6)}.detail-dashboard{width:100%;max-width:1400px;background:var(--bg-card);border-radius:var(--radius-2xl);box-shadow:0 40px 80px #2d2e3714;ring:1px solid rgba(173,172,183,.15);outline:1px solid rgba(173,172,183,.15);display:flex;flex-direction:column;overflow:hidden}.detail-hero-panel{background:linear-gradient(to bottom,var(--bg-secondary) 0%,rgba(247,245,255,.4) 100%);padding:var(--space-10);display:flex;flex-direction:column;border-bottom:1px solid rgba(173,172,183,.1)}[data-theme=dark] .detail-hero-panel{background:linear-gradient(to bottom,var(--bg-secondary) 0%,var(--bg-card) 100%)}.back-btn{display:inline-flex;align-items:center;gap:var(--space-2);color:var(--color-violet-600);font-weight:var(--font-bold);font-size:var(--text-sm);text-transform:uppercase;letter-spacing:var(--tracking-wider);background:transparent;border:none;cursor:pointer;margin-bottom:var(--space-10);transition:transform var(--transition-fast);padding:0}.back-btn:hover{transform:translate(-4px)}.back-btn:focus-visible{outline:2px solid var(--color-violet-500);outline-offset:4px;border-radius:var(--radius-base)}[data-theme=dark] .back-btn{color:var(--color-violet-300)}.hero-icon-large{font-size:4.5rem;margin-bottom:var(--space-6);line-height:1;filter:drop-shadow(0 4px 8px rgba(0,0,0,.15))}.hero-title{font-size:var(--text-4xl);font-weight:var(--font-extrabold);color:var(--text-primary);line-height:1.1;letter-spacing:var(--tracking-tight);margin-bottom:var(--space-4)}.hero-desc{font-size:var(--text-base);color:var(--text-secondary);line-height:var(--leading-relaxed);font-weight:var(--font-medium);margin-bottom:0}.stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4);margin-top:var(--space-8);margin-bottom:auto}.stat-card{background:#fffc;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);padding:var(--space-4);border-radius:var(--radius-lg);border:1px solid rgba(255,255,255,.5);display:flex;flex-direction:column;gap:var(--space-1)}[data-theme=dark] .stat-card{background:#2d2a3e99;border-color:var(--border-default)}.stat-label{font-size:.625rem;font-weight:var(--font-bold);color:var(--text-tertiary);text-transform:uppercase;letter-spacing:var(--tracking-wider)}.stat-value{font-size:var(--text-xl);font-weight:var(--font-bold);color:var(--text-primary);display:flex;align-items:center;gap:var(--space-1)}.stat-star{color:#815100;font-size:var(--text-base)}.enroll-btn{margin-top:var(--space-8);width:100%;padding:var(--space-5) var(--space-6);background:linear-gradient(90deg,#702ae1,#8c52ff,#702ae1);background-size:200% auto;color:#f8f0ff;border:none;border-radius:var(--radius-xl);font-size:var(--text-lg);font-weight:var(--font-extrabold);cursor:pointer;transition:all .5s ease;box-shadow:0 8px 20px #702ae14d;outline:2px solid rgba(112,42,225,.2);outline-offset:2px}.enroll-btn:hover{background-position:right center;box-shadow:0 12px 28px #702ae166;transform:translateY(-1px)}.enroll-btn:active{transform:scale(.96)}.enroll-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.enroll-btn:focus-visible{outline:2px solid var(--color-violet-500);outline-offset:4px}.enrolled-badge{margin-top:var(--space-8);width:100%;padding:var(--space-5) var(--space-6);background:linear-gradient(135deg,var(--color-green-500) 0%,var(--color-green-600) 100%);color:#fff;border-radius:var(--radius-xl);font-size:var(--text-lg);font-weight:var(--font-extrabold);text-align:center;display:flex;align-items:center;justify-content:center;gap:var(--space-2);box-shadow:var(--shadow-success)}.detail-content-panel{flex:1;display:flex;flex-direction:column;background:var(--bg-card);overflow:hidden;min-height:0}.content-header{padding:var(--space-10) var(--space-10) var(--space-6);flex-shrink:0}.content-header-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-2)}.content-header h2{font-size:var(--text-3xl);font-weight:var(--font-extrabold);color:var(--text-primary);margin:0;letter-spacing:var(--tracking-tight)}.content-header-label{font-size:var(--text-xs);font-weight:var(--font-bold);color:var(--text-tertiary);text-transform:uppercase;letter-spacing:var(--tracking-wider)}.progress-row{display:flex;align-items:center;gap:var(--space-6);margin-top:var(--space-4)}.progress-track{flex:1;height:10px;background:var(--bg-secondary);border-radius:var(--radius-full);overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,var(--color-violet-600) 0%,var(--color-violet-300) 100%);border-radius:var(--radius-full);position:relative;transition:width .4s ease;overflow:hidden}.progress-fill:after{content:"";position:absolute;inset:0;background:#fff3;animation:progressShimmer 2s ease-in-out infinite}@keyframes progressShimmer{0%,to{opacity:1}50%{opacity:.5}}.progress-text{font-size:var(--text-sm);font-weight:var(--font-bold);color:var(--color-violet-600);white-space:nowrap;flex-shrink:0}[data-theme=dark] .progress-text{color:var(--color-violet-300)}.units-list{flex:1;overflow-y:auto;overflow-x:hidden;padding:var(--space-2) var(--space-10) var(--space-10);display:flex;flex-direction:column;gap:var(--space-5);min-height:0;scrollbar-width:thin;scrollbar-color:var(--border-strong) transparent}.units-list::-webkit-scrollbar{width:6px}.units-list::-webkit-scrollbar-track{background:transparent}.units-list::-webkit-scrollbar-thumb{background:var(--border-default);border-radius:var(--radius-full)}.units-list::-webkit-scrollbar-thumb:hover{background:var(--border-strong)}.unit-item{border-radius:var(--radius-xl);transition:all var(--transition-base);flex-shrink:0}.unit-item--active{background:var(--bg-secondary);outline:2px solid rgba(112,42,225,.1);animation:unitPulse 3s cubic-bezier(.4,0,.6,1) infinite}@keyframes unitPulse{0%,to{outline-color:#702ae11a}50%{outline-color:#702ae140}}.unit-item--collapsed{background:var(--bg-card);border:1px solid rgba(173,172,183,.15)}.unit-item--collapsed:hover{background:var(--bg-secondary);cursor:pointer}.unit-item--collapsed:focus-within{outline:2px solid var(--color-violet-500);outline-offset:2px}.unit-summary{padding:var(--space-6);display:flex;align-items:center;gap:var(--space-5);cursor:pointer}.unit-summary:focus-visible{outline:2px solid var(--color-violet-500);outline-offset:-4px;border-radius:var(--radius-xl)}.unit-number{width:3.5rem;height:3.5rem;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:var(--font-extrabold);font-size:var(--text-2xl);flex-shrink:0;transition:all var(--transition-fast)}.unit-number--active{background:var(--color-violet-600);color:#fff;box-shadow:0 6px 16px #702ae133}.unit-number--inactive{background:var(--bg-secondary);color:var(--text-secondary)}.unit-item--collapsed:hover .unit-number--inactive{background:var(--color-violet-100);color:var(--color-violet-900)}[data-theme=dark] .unit-item--collapsed:hover .unit-number--inactive{background:#a476ff33;color:var(--color-violet-300)}.unit-info{flex:1;min-width:0}.unit-info h3{font-size:var(--text-xl);font-weight:var(--font-bold);color:var(--text-primary);margin-bottom:var(--space-1);line-height:1.3}.unit-info p{font-size:var(--text-sm);color:var(--text-tertiary);font-weight:var(--font-medium)}.unit-current-tag{font-size:var(--text-xs);font-weight:var(--font-bold);color:var(--color-violet-600);text-transform:uppercase;letter-spacing:var(--tracking-tight)}[data-theme=dark] .unit-current-tag{color:var(--color-violet-300)}.unit-dot-separator{display:inline-block;width:4px;height:4px;border-radius:50%;background:var(--border-strong);vertical-align:middle;margin:0 var(--space-2)}.unit-end-icon{color:var(--text-tertiary);flex-shrink:0;display:flex;align-items:center;transition:all var(--transition-fast)}.unit-end-icon svg{width:20px;height:20px}.unit-item[data-expanded=true] .unit-chevron{transform:rotate(180deg)}.unit-locked-pill{background:var(--bg-secondary);color:var(--text-tertiary);padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);font-size:.625rem;font-weight:var(--font-bold);text-transform:uppercase;letter-spacing:var(--tracking-wider);transition:all var(--transition-fast)}.unit-item--collapsed:hover .unit-locked-pill{background:var(--bg-card)}.unit-progress-badge{background:var(--color-violet-100);color:var(--color-violet-700);padding:var(--space-2) var(--space-3);border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:var(--font-semibold);flex-shrink:0}[data-theme=dark] .unit-progress-badge{background:#a476ff33;color:var(--color-violet-300)}.unit-details{padding:0 var(--space-6) var(--space-6) var(--space-6);animation:slideDown .25s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.unit-description{font-size:var(--text-sm);color:var(--text-secondary);line-height:var(--leading-relaxed);margin-bottom:var(--space-4);padding-left:calc(3.5rem + var(--space-5))}.enrollment-prompt{background:var(--status-warning-bg);border:1px solid var(--status-warning-border);border-radius:var(--radius-lg);padding:var(--space-6);text-align:center;margin:var(--space-4) 0}.enrollment-prompt p{margin:0;font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--status-warning-text)}.lessons-list{display:flex;flex-direction:column;gap:var(--space-3);margin-top:var(--space-3)}.lesson-item{background:var(--bg-card);border:1px solid rgba(173,172,183,.05);border-radius:var(--radius-lg);padding:var(--space-4);display:flex;align-items:center;gap:var(--space-4);cursor:pointer;transition:transform var(--transition-fast);position:relative;overflow:hidden}.lesson-item:hover:not(.locked){transform:translate(8px)}.lesson-item:focus-visible{outline:2px solid var(--color-violet-500);outline-offset:2px}.lesson-item.current-lesson{box-shadow:0 8px 24px #702ae114;outline:2px solid var(--color-violet-600);outline-offset:-2px}.lesson-item.current-lesson:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--color-violet-600);border-radius:var(--radius-full) 0 0 var(--radius-full)}@keyframes pulseGlow{0%,to{outline-color:#702ae166}50%{outline-color:#702ae1cc}}.lesson-item.completed{border-color:transparent}.lesson-item.locked{opacity:.55;cursor:not-allowed}.lesson-status-icon{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:var(--text-sm);font-weight:var(--font-bold);flex-shrink:0;background:#b28cff26;color:var(--color-violet-600);transition:background var(--transition-fast)}.lesson-item.current-lesson .lesson-status-icon{background:var(--color-violet-600);color:#fff;box-shadow:0 4px 8px #702ae14d}.lesson-item.completed .lesson-status-icon{background:#b28cff26;color:var(--color-violet-600)}.lesson-item.locked .lesson-status-icon{background:var(--bg-secondary);color:var(--text-tertiary)}[data-theme=dark] .lesson-status-icon{background:#a476ff26;color:var(--color-violet-300)}.lesson-info{flex:1;min-width:0}.lesson-info h4{font-size:.9375rem;font-weight:var(--font-bold);color:var(--text-primary);margin:0 0 var(--space-1) 0;line-height:1.3}.lesson-meta{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-xs);color:var(--text-tertiary);font-weight:var(--font-semibold);text-transform:uppercase;letter-spacing:var(--tracking-wide)}.lesson-meta-sep{color:var(--border-strong);-webkit-user-select:none;-moz-user-select:none;user-select:none}.lesson-type{color:var(--text-tertiary)}.lesson-item.current-lesson .lesson-meta{color:var(--color-violet-600)}[data-theme=dark] .lesson-item.current-lesson .lesson-meta{color:var(--color-violet-300)}.lesson-xp-badge{font-size:var(--text-xs);font-weight:var(--font-bold);color:var(--color-violet-600);flex-shrink:0;margin-right:var(--space-2)}[data-theme=dark] .lesson-xp-badge{color:var(--color-violet-300)}.lesson-action-icon{flex-shrink:0;color:var(--color-violet-600);display:flex;align-items:center;opacity:0;transition:opacity var(--transition-fast)}.lesson-item:hover .lesson-action-icon,.lesson-item.current-lesson .lesson-action-icon{opacity:1}.lesson-action-icon svg{width:24px;height:24px}.resume-badge{background:var(--color-violet-600);color:#fff;padding:var(--space-2) var(--space-4);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--font-bold);flex-shrink:0;animation:slideIn .3s ease-out}@keyframes slideIn{0%{opacity:0;transform:translate(12px)}to{opacity:1;transform:translate(0)}}.locked-badge{background:var(--bg-secondary);color:var(--text-tertiary);padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--font-medium);flex-shrink:0}.btn-start{margin-top:var(--space-5);padding:var(--space-3) var(--space-6);background:var(--btn-primary-bg);color:var(--btn-primary-text);border:none;border-radius:var(--radius-lg);font-weight:var(--font-bold);font-size:var(--text-sm);cursor:pointer;transition:all var(--transition-fast)}.btn-start:hover{background:var(--btn-primary-hover);transform:translateY(-2px);box-shadow:var(--shadow-brand)}.btn-start:focus-visible{outline:2px solid var(--color-violet-500);outline-offset:3px}.detail-loading,.detail-error{display:flex;align-items:center;justify-content:center;min-height:60vh;width:100%}.detail-loading .spinner{width:44px;height:44px;border:3px solid var(--border-default);border-top-color:var(--color-violet-500);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.detail-error-msg{background:var(--status-error-bg);color:var(--status-error-text);border:1px solid var(--status-error-border);border-radius:var(--radius-xl);padding:var(--space-6) var(--space-8);font-weight:var(--font-semibold);text-align:center}@media(min-width:1024px){.course-detail{padding:var(--space-12);align-items:center;min-height:100vh}.detail-dashboard{flex-direction:row;height:880px;max-height:90vh}.detail-hero-panel{width:400px;flex-shrink:0;border-bottom:none;border-right:1px solid rgba(173,172,183,.1);overflow-y:auto}.detail-content-panel{border-radius:0 var(--radius-2xl) var(--radius-2xl) 0}}@media(max-width:767px){.course-detail{padding:var(--space-3)}.detail-dashboard{border-radius:var(--radius-xl)}.detail-hero-panel{padding:var(--space-6)}.content-header{padding:var(--space-6) var(--space-6) var(--space-4)}.content-header h2{font-size:var(--text-2xl)}.units-list{padding:var(--space-2) var(--space-6) var(--space-6)}.unit-summary{padding:var(--space-4)}.unit-number{width:2.75rem;height:2.75rem;font-size:var(--text-xl)}.unit-info h3{font-size:var(--text-base)}.unit-details{padding:0 var(--space-4) var(--space-4)}.unit-description{padding-left:0}.lesson-item,.lesson-meta{flex-wrap:wrap}.progress-row{flex-direction:column;align-items:flex-start;gap:var(--space-2)}.progress-track{width:100%}}@media(prefers-reduced-motion:reduce){.unit-item--active{animation:none}.progress-fill:after{animation:none}.lesson-item:hover:not(.locked){transform:none}.detail-dashboard{transition:none}}.exercise-player{min-height:100dvh;background:var(--bg-page);display:flex;flex-direction:column;font-family:var(--font-primary)}.exercise-top-bar{position:sticky;top:0;z-index:var(--z-sticky);background:var(--bg-card);border-bottom:1px solid var(--border-subtle);padding:12px 24px;display:flex;align-items:center;gap:16px;min-height:64px;box-shadow:var(--shadow-xs)}.ex-exit-btn{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:40px;height:40px;border:none;background:transparent;color:var(--text-secondary);border-radius:var(--radius-full);cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast),transform var(--transition-fast)}.ex-exit-btn:hover{background:var(--bg-secondary);color:var(--text-primary)}.ex-exit-btn:active{transform:scale(.92)}.ex-exit-btn:focus-visible{outline:3px solid var(--border-focus);outline-offset:2px}.ex-progress-wrap{flex:1;max-width:640px}.ex-progress-track{height:14px;background:var(--bg-tertiary);border-radius:var(--radius-full);overflow:hidden}.ex-progress-fill{height:100%;background:linear-gradient(90deg,var(--color-violet-600) 0%,var(--color-violet-400) 100%);border-radius:var(--radius-full);transition:width .7s cubic-bezier(.4,0,.2,1);box-shadow:0 0 10px #702ae14d}.ex-stats{display:flex;align-items:center;gap:8px;flex-shrink:0}.ex-stat-pill{display:flex;align-items:center;gap:5px;padding:6px 12px;border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:var(--font-bold);line-height:1;white-space:nowrap}.ex-stat-pill--streak{background:#ff96001f;color:var(--color-streak-orange);border:1.5px solid rgba(255,150,0,.2)}.ex-stat-pill--xp{background:#8b5cf61f;color:var(--color-violet-600);border:1.5px solid rgba(139,92,246,.2)}[data-theme=dark] .ex-stat-pill--xp{color:var(--color-violet-300)}.ex-stat-pill--hearts{background:#ff4b4b1a;color:var(--color-exercise-red);border:1.5px solid rgba(255,75,75,.2);gap:4px}.ex-stat-icon{font-size:16px;line-height:1}.ex-stat-value{font-size:var(--text-sm);font-weight:var(--font-extrabold)}.ex-hearts{display:flex;gap:2px;align-items:center}.ex-heart{font-size:18px;line-height:1;transition:transform .3s cubic-bezier(.68,-.55,.265,1.55)}.ex-heart--lost{opacity:.25;filter:grayscale(1);animation:heartLoss .4s cubic-bezier(.68,-.55,.265,1.55)}@keyframes heartLoss{0%{transform:scale(1.3)}50%{transform:scale(.7)}to{transform:scale(1)}}.exercise-content{flex:1;display:flex;align-items:center;justify-content:center;padding:40px 24px 24px}.exercise-card{width:100%;max-width:800px;background:var(--bg-card);border-radius:var(--radius-2xl);padding:40px 36px;box-shadow:var(--shadow-lg);border:1px solid var(--border-subtle)}.ex-type-badge{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--font-extrabold);text-transform:uppercase;letter-spacing:var(--tracking-wider);margin-bottom:20px}.ex-type-badge--mc{background:#702ae11f;color:var(--color-violet-600);border:1px solid rgba(112,42,225,.2)}[data-theme=dark] .ex-type-badge--mc{color:var(--color-violet-300)}.ex-type-badge--fill{background:#58cc021f;color:var(--color-exercise-green-dark);border:1px solid rgba(88,204,2,.25)}.ex-type-badge--match{background:#1cb0f61f;color:var(--color-exercise-blue);border:1px solid rgba(28,176,246,.25)}.ex-type-badge--speak{background:#ff96001f;color:var(--color-streak-orange);border:1px solid rgba(255,150,0,.25)}.ex-type-badge--listen{background:#8b5cf61a;color:var(--color-violet-600);border:1px solid rgba(139,92,246,.2)}[data-theme=dark] .ex-type-badge--listen{color:var(--color-violet-300)}.ex-question-label{font-size:var(--text-sm);font-weight:var(--font-extrabold);text-transform:uppercase;letter-spacing:var(--tracking-wider);color:var(--text-secondary);margin-bottom:8px}.ex-question-heading{font-size:clamp(1.25rem,3vw,1.75rem);font-weight:var(--font-extrabold);color:var(--text-primary);line-height:var(--leading-tight);margin:0 0 28px;word-wrap:break-word;overflow-wrap:break-word;white-space:normal}.ex-question-heading em{color:var(--color-violet-600);font-style:italic}[data-theme=dark] .ex-question-heading em{color:var(--color-violet-300)}.ex-question-image{max-width:100%;border-radius:var(--radius-xl);margin-top:var(--space-4)}.ex-hint-box{display:flex;align-items:flex-start;gap:12px;background:var(--status-warning-bg);border:1px solid var(--status-warning-border);border-radius:var(--radius-xl);padding:14px 16px;margin-bottom:20px}.ex-hint-icon{font-size:20px;flex-shrink:0;margin-top:1px}.ex-hint-text{font-size:var(--text-sm);color:var(--status-warning-text);line-height:var(--leading-relaxed);font-weight:var(--font-medium)}.ex-options-grid{display:flex;flex-direction:column;gap:12px}.ex-option-btn{display:flex;align-items:center;gap:16px;width:100%;padding:16px 20px;background:var(--bg-card);border:2px solid var(--border-default);border-radius:var(--radius-xl);cursor:pointer;text-align:left;font-size:var(--text-lg);font-weight:var(--font-medium);color:var(--text-primary);transition:border-color var(--transition-fast),background var(--transition-fast),transform .15s ease,box-shadow .15s ease;box-shadow:0 4px 0 var(--border-default);position:relative}.ex-option-btn:hover:not(:disabled){border-color:var(--border-strong);background:var(--bg-card-hover);transform:translateY(-2px);box-shadow:0 6px 0 var(--border-strong)}.ex-option-btn:active:not(:disabled){transform:translateY(2px);box-shadow:0 2px 0 var(--border-default)}.ex-option-btn:focus-visible{outline:3px solid var(--border-focus);outline-offset:2px}.ex-option-btn:disabled{cursor:not-allowed;opacity:.55}.ex-option-btn--selected{background:#702ae112;border-color:var(--color-violet-600);border-width:2px;box-shadow:0 4px 0 var(--color-violet-700);transform:translateY(-2px)}.ex-option-btn--selected:hover:not(:disabled){box-shadow:0 6px 0 var(--color-violet-700)}[data-theme=dark] .ex-option-btn--selected{background:#a78bfa1f;border-color:var(--color-violet-400);box-shadow:0 4px 0 var(--color-violet-600)}.ex-option-letter{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--radius-lg);font-size:var(--text-sm);font-weight:var(--font-extrabold);border:2px solid var(--border-strong);color:var(--text-secondary);background:var(--bg-secondary);transition:background var(--transition-fast),border-color var(--transition-fast),color var(--transition-fast)}.ex-option-btn--selected .ex-option-letter{background:var(--color-violet-600);border-color:var(--color-violet-700);color:#fff}[data-theme=dark] .ex-option-btn--selected .ex-option-letter{background:var(--color-violet-500);border-color:var(--color-violet-400)}.ex-option-text{flex:1;font-size:var(--text-lg);font-weight:var(--font-medium);line-height:var(--leading-snug)}.ex-fill-wrap{display:flex;flex-direction:column;gap:20px}.ex-fill-input-wrap{position:relative}.ex-fill-input{width:100%;padding:16px 48px 16px 16px;background:var(--bg-secondary);border:2px solid var(--border-default);border-bottom-color:var(--color-exercise-green);border-bottom-width:3px;border-radius:var(--radius-xl) var(--radius-xl) var(--radius-md) var(--radius-md);font-size:var(--text-lg);font-weight:var(--font-medium);color:var(--text-primary);outline:none;transition:border-color var(--transition-fast),background var(--transition-fast),box-shadow var(--transition-fast);font-family:var(--font-primary)}.ex-fill-input::-moz-placeholder{color:var(--text-tertiary);font-weight:var(--font-normal)}.ex-fill-input::placeholder{color:var(--text-tertiary);font-weight:var(--font-normal)}.ex-fill-input:focus{background:var(--bg-card);border-color:var(--color-exercise-green);border-bottom-width:3px;box-shadow:0 0 0 3px #58cc0226}.ex-fill-input:disabled{opacity:.6;cursor:not-allowed}.ex-fill-kbd-hint{position:absolute;right:12px;top:50%;transform:translateY(-50%);font-size:10px;font-weight:var(--font-bold);color:var(--text-tertiary);background:var(--bg-tertiary);border:1px solid var(--border-default);border-radius:var(--radius-sm);padding:2px 6px;letter-spacing:.03em}.ex-fill-hint-text{display:flex;align-items:center;gap:6px;font-size:var(--text-sm);color:var(--text-secondary)}.ex-did-you-know{display:flex;align-items:flex-start;gap:12px;background:var(--bg-secondary);border-radius:var(--radius-xl);padding:14px 16px}.ex-dyk-thumb{width:36px;height:36px;border-radius:var(--radius-md);-o-object-fit:cover;object-fit:cover;flex-shrink:0;background:var(--bg-tertiary)}.ex-dyk-title{font-size:var(--text-sm);font-weight:var(--font-bold);color:var(--text-primary);margin-bottom:2px}.ex-dyk-body{font-size:var(--text-sm);color:var(--text-secondary);line-height:var(--leading-relaxed)}.ex-match-progress{text-align:center;font-size:var(--text-base);font-weight:var(--font-bold);color:var(--color-violet-600);margin-bottom:20px}[data-theme=dark] .ex-match-progress{color:var(--color-violet-300)}.ex-match-grid{display:flex;flex-direction:column;gap:12px}.ex-match-col-header{display:grid;grid-template-columns:1fr 1fr;gap:16px;padding:0 4px}.ex-match-col-label{font-size:var(--text-xs);font-weight:var(--font-extrabold);text-transform:uppercase;letter-spacing:.1em}.ex-match-columns{display:grid;grid-template-columns:1fr 1fr;gap:16px}.ex-match-col{display:flex;flex-direction:column;gap:10px}.ex-match-item{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:14px 16px;background:var(--bg-card);border:2px solid var(--border-default);border-radius:var(--radius-xl);cursor:pointer;font-size:var(--text-base);font-weight:var(--font-medium);color:var(--text-primary);text-align:center;transition:all var(--transition-fast);box-shadow:0 2px 0 var(--border-default);position:relative}.ex-match-item:hover:not(:disabled){border-color:var(--color-exercise-blue);background:#1cb0f60d;transform:translateY(-1px)}.ex-match-item:focus-visible{outline:3px solid var(--border-focus);outline-offset:2px}.ex-match-item:disabled{cursor:not-allowed;opacity:.5}.ex-match-item--selected{background:#1cb0f614;border-color:var(--color-exercise-blue);border-width:2px;color:var(--color-exercise-blue);font-weight:var(--font-bold);box-shadow:0 2px 0 var(--color-exercise-blue)}.ex-match-item--matched{background:#8b5cf60f;border-color:var(--color-violet-300);color:var(--text-secondary);font-weight:var(--font-semibold);cursor:default;box-shadow:none;opacity:.75}.ex-match-num{width:22px;height:22px;border-radius:var(--radius-full);background:var(--color-violet-500);color:#fff;font-size:11px;font-weight:var(--font-extrabold);display:flex;align-items:center;justify-content:center;flex-shrink:0}.ex-match-item--matched .ex-match-num{background:var(--color-violet-500)}.ex-match-hint{grid-column:1 / -1;text-align:center;font-size:var(--text-sm);color:var(--color-exercise-blue);font-weight:var(--font-medium);display:flex;align-items:center;justify-content:center;gap:6px;padding-top:8px}.ex-speak-phrase-card{background:var(--bg-card);border:1px solid var(--border-default);border-radius:var(--radius-2xl);padding:24px;margin-bottom:32px;box-shadow:var(--shadow-sm)}.ex-speak-phrase{font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--color-violet-600);font-style:italic;margin-bottom:8px}[data-theme=dark] .ex-speak-phrase{color:var(--color-violet-300)}.ex-speak-pronunciation{font-size:var(--text-sm);color:var(--text-secondary);font-family:var(--font-mono);margin-bottom:12px}.ex-speak-listen-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border:none;background:none;color:var(--color-exercise-blue);font-size:var(--text-sm);font-weight:var(--font-semibold);cursor:pointer;border-radius:var(--radius-full);transition:background var(--transition-fast)}.ex-speak-listen-btn:hover{background:#1cb0f61a}.ex-record-area{display:flex;flex-direction:column;align-items:center;gap:16px}.ex-record-btn{width:88px;height:88px;border-radius:var(--radius-full);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#e53e3e,#c53030);box-shadow:0 8px 24px #c5303059,0 4px #9b2c2c;transition:transform var(--transition-fast),box-shadow var(--transition-fast);color:#fff}.ex-record-btn:hover:not(:disabled){transform:scale(1.05);box-shadow:0 12px 28px #c5303066,0 4px #9b2c2c}.ex-record-btn:active:not(:disabled){transform:scale(.95);box-shadow:0 4px 12px #c530304d,0 2px #9b2c2c}.ex-record-btn:focus-visible{outline:3px solid var(--border-focus);outline-offset:4px}.ex-record-btn:disabled{cursor:not-allowed;opacity:.6}.ex-record-btn--recording{background:linear-gradient(135deg,#e53e3e,#c53030);animation:recordPulse 1.2s ease-in-out infinite}@keyframes recordPulse{0%,to{box-shadow:0 8px 24px #c5303059,0 4px #9b2c2c}50%{box-shadow:0 8px 32px #c5303099,0 4px #9b2c2c;transform:scale(1.04)}}.ex-record-btn--done{background:linear-gradient(135deg,var(--color-exercise-green) 0%,var(--color-exercise-green-dark) 100%);box-shadow:0 8px 24px #58cc0259,0 4px 0 var(--color-exercise-green-shadow)}.ex-record-status{font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--text-secondary)}.ex-record-status--recording{color:var(--color-exercise-red);animation:blink 1s ease-in-out infinite}@keyframes blink{0%,to{opacity:1}50%{opacity:.5}}.ex-phase-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:var(--radius-full);font-size:10px;font-weight:var(--font-bold);text-transform:uppercase;letter-spacing:var(--tracking-wider);background:var(--bg-secondary);color:var(--text-tertiary);border:1px solid var(--border-subtle)}.ex-listen-play-area{display:flex;flex-direction:column;align-items:center;gap:12px;margin:24px 0 28px}.ex-play-btn{width:80px;height:80px;border-radius:var(--radius-full);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;background:var(--color-violet-600);box-shadow:0 8px 24px #702ae166;color:#fff;transition:transform var(--transition-fast),box-shadow var(--transition-fast)}.ex-play-btn:hover:not(:disabled){transform:scale(1.06);box-shadow:0 12px 32px #702ae180}.ex-play-btn:active:not(:disabled){transform:scale(.95)}.ex-play-btn:focus-visible{outline:3px solid var(--border-focus);outline-offset:4px}.ex-play-btn:disabled{opacity:.6;cursor:not-allowed}.ex-play-status{font-size:var(--text-sm);color:var(--text-secondary);font-weight:var(--font-medium)}.ex-sound-waves{display:flex;align-items:center;gap:3px;height:28px}.ex-sound-wave{width:4px;border-radius:2px;background:#fff;animation:soundWave .9s ease-in-out infinite}.ex-sound-wave:nth-child(1){height:8px;animation-delay:0s}.ex-sound-wave:nth-child(2){height:20px;animation-delay:.15s}.ex-sound-wave:nth-child(3){height:14px;animation-delay:.3s}.ex-sound-wave:nth-child(4){height:24px;animation-delay:.45s}.ex-sound-wave:nth-child(5){height:10px;animation-delay:.6s}@keyframes soundWave{0%,to{transform:scaleY(.5);opacity:.5}50%{transform:scaleY(1.2);opacity:1}}.ex-listen-answer-area{display:flex;flex-direction:column;gap:8px}.ex-listen-label{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--text-secondary)}.ex-listen-textarea{width:100%;min-height:100px;padding:16px;background:var(--bg-secondary);border:2px solid var(--border-default);border-radius:var(--radius-xl);font-size:var(--text-base);font-weight:var(--font-medium);color:var(--text-primary);outline:none;resize:none;font-family:var(--font-primary);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.ex-listen-textarea::-moz-placeholder{color:var(--text-tertiary)}.ex-listen-textarea::placeholder{color:var(--text-tertiary)}.ex-listen-textarea:focus{border-color:var(--color-violet-500);box-shadow:0 0 0 3px #8b5cf626}.ex-listen-textarea:disabled{opacity:.6;cursor:not-allowed}.exercise-bottom-bar{position:sticky;bottom:0;z-index:var(--z-sticky);background:var(--bg-card);border-top:1px solid var(--border-subtle);padding:16px 24px 24px;display:flex;align-items:center;justify-content:space-between;gap:16px;min-height:80px;box-shadow:0 -4px 16px #0000000f}[data-theme=dark] .exercise-bottom-bar{box-shadow:0 -4px 16px #0000004d}.ex-hint-btn{display:flex;align-items:center;gap:8px;padding:12px 20px;background:var(--bg-card);border:2px solid var(--border-default);border-radius:var(--radius-full);color:var(--text-secondary);font-size:var(--text-sm);font-weight:var(--font-semibold);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.ex-hint-btn:hover:not(:disabled){background:var(--status-warning-bg);border-color:var(--status-warning-border);color:var(--status-warning-text)}.ex-hint-btn:active:not(:disabled){transform:translateY(1px)}.ex-hint-btn:focus-visible{outline:3px solid var(--border-focus);outline-offset:2px}.ex-hint-btn:disabled{opacity:.4;cursor:not-allowed}.ex-check-btn{flex:1;max-width:360px;display:flex;align-items:center;justify-content:center;gap:10px;padding:16px 32px;border:none;border-radius:var(--radius-full);font-size:var(--text-base);font-weight:var(--font-extrabold);text-transform:uppercase;letter-spacing:var(--tracking-wider);cursor:pointer;transition:transform .15s ease,box-shadow .15s ease,background var(--transition-fast),opacity var(--transition-fast);background:linear-gradient(135deg,var(--color-violet-600) 0%,var(--color-violet-500) 100%);color:#fff;box-shadow:0 4px 0 var(--color-violet-800);min-height:56px}.ex-check-btn:hover:not(:disabled){opacity:.93;transform:translateY(-1px);box-shadow:0 5px 0 var(--color-violet-800)}.ex-check-btn:active:not(:disabled){transform:translateY(3px);box-shadow:0 1px 0 var(--color-violet-800)}.ex-check-btn:focus-visible{outline:3px solid var(--border-focus);outline-offset:3px}.ex-check-btn:disabled,.ex-check-btn--disabled{background:var(--bg-tertiary);color:var(--text-tertiary);cursor:not-allowed;box-shadow:0 4px 0 var(--border-default);transform:none}.ex-check-btn--active{background:linear-gradient(135deg,var(--color-exercise-green) 0%,var(--color-exercise-green-dark) 100%);box-shadow:0 4px 0 var(--color-exercise-green-shadow)}.ex-check-btn--active:hover:not(:disabled){box-shadow:0 5px 0 var(--color-exercise-green-shadow)}.ex-check-btn--active:active:not(:disabled){box-shadow:0 1px 0 var(--color-exercise-green-shadow)}.ex-spinner{width:18px;height:18px;border:3px solid rgba(255,255,255,.35);border-top-color:#fff;border-radius:50%;animation:exSpin .7s linear infinite}@keyframes exSpin{to{transform:rotate(360deg)}}.ex-feedback-overlay{position:fixed;inset:0;z-index:var(--z-modal);display:flex;align-items:flex-end;justify-content:center}@media(min-width:640px){.ex-feedback-overlay{align-items:center;background:var(--bg-overlay-heavy);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}}.ex-feedback-backdrop{display:none}@media(min-width:640px){.ex-feedback-backdrop{display:block;position:absolute;inset:0;cursor:default}}.ex-feedback-sheet{position:relative;width:100%;max-width:600px;padding:32px 28px 36px;border-radius:var(--radius-3xl) var(--radius-3xl) 0 0;text-align:center;animation:sheetSlideUp .35s cubic-bezier(.34,1.56,.64,1);border-top:4px solid transparent;box-shadow:0 -8px 40px #0000002e}@media(min-width:640px){.ex-feedback-sheet{border-radius:var(--radius-3xl);padding:40px 36px;box-shadow:0 24px 60px #0000004d;animation:sheetPopIn .35s cubic-bezier(.34,1.56,.64,1)}}@keyframes sheetSlideUp{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes sheetPopIn{0%{transform:scale(.88) translateY(24px);opacity:0}to{transform:scale(1) translateY(0);opacity:1}}.ex-feedback-sheet--correct{background:#fff;border-top-color:var(--color-exercise-green)}[data-theme=dark] .ex-feedback-sheet--correct{background:var(--bg-card)}.ex-feedback-sheet--incorrect{background:#fff;border-top-color:var(--color-exercise-red)}[data-theme=dark] .ex-feedback-sheet--incorrect{background:var(--bg-card)}.ex-fb-icon{width:72px;height:72px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;margin:0 auto 16px;animation:feedbackBounce .5s cubic-bezier(.68,-.55,.265,1.55)}@keyframes feedbackBounce{0%{transform:scale(.4);opacity:0}60%{transform:scale(1.2)}to{transform:scale(1);opacity:1}}.ex-fb-icon--correct{background:var(--color-exercise-green);box-shadow:0 6px 20px #58cc0266}.ex-fb-icon--incorrect{background:var(--color-exercise-red);box-shadow:0 6px 20px #ff4b4b66}.ex-fb-title{font-size:clamp(1.5rem,4vw,2rem);font-weight:var(--font-extrabold);margin-bottom:12px}.ex-fb-title--correct{color:var(--color-exercise-green)}.ex-fb-title--incorrect{color:var(--color-exercise-red)}.ex-fb-xp{display:inline-flex;align-items:center;gap:6px;padding:8px 18px;background:linear-gradient(135deg,var(--color-xp-gold) 0%,var(--color-xp-gold-light) 100%);border-radius:var(--radius-full);font-size:var(--text-base);font-weight:var(--font-extrabold);color:#5a3d00;margin-bottom:20px;box-shadow:0 3px #c8a000}.ex-fb-comparison{background:var(--bg-secondary);border-radius:var(--radius-xl);padding:16px;margin-bottom:20px;text-align:left}.ex-fb-answer-row{margin-bottom:12px}.ex-fb-answer-row:last-child{margin-bottom:0}.ex-fb-answer-label{display:block;font-size:var(--text-xs);font-weight:var(--font-extrabold);text-transform:uppercase;letter-spacing:var(--tracking-wider);color:var(--text-tertiary);margin-bottom:6px}.ex-fb-answer-val{display:block;padding:10px 14px;border-radius:var(--radius-lg);font-size:var(--text-base);font-weight:var(--font-semibold)}.ex-fb-answer-val--wrong{background:var(--status-error-bg);color:var(--status-error-text);border:1px solid var(--status-error-border);text-decoration:line-through;text-decoration-color:var(--color-exercise-red)}.ex-fb-answer-val--right{background:var(--status-success-bg);color:var(--status-success-text);border:1px solid var(--status-success-border)}.ex-fb-match-table{width:100%;margin-bottom:16px;border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--border-default)}.ex-fb-match-header{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;padding:8px 12px;background:var(--bg-tertiary);font-size:10px;font-weight:var(--font-extrabold);text-transform:uppercase;letter-spacing:.08em;color:var(--text-secondary)}.ex-fb-match-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;padding:10px 12px;border-top:1px solid var(--border-subtle);font-size:var(--text-sm);align-items:center}.ex-fb-match-row--correct{background:#58cc020d}.ex-fb-match-row--wrong{background:#ff4b4b0d}.ex-fb-match-source{font-weight:var(--font-semibold);color:var(--text-primary)}.ex-fb-match-answer{display:flex;align-items:center;gap:6px;font-weight:var(--font-medium);color:var(--text-primary)}.ex-fb-match-answer--wrong{color:var(--color-exercise-red);text-decoration:line-through}.ex-fb-match-correct{color:var(--color-exercise-green);font-weight:var(--font-bold)}.ex-fb-explanation{display:flex;align-items:flex-start;gap:10px;background:var(--status-info-bg);border-radius:var(--radius-xl);padding:12px 14px;margin-bottom:20px;text-align:left}.ex-fb-explanation-icon{flex-shrink:0;font-size:16px;margin-top:1px}.ex-fb-explanation-text{font-size:var(--text-sm);color:var(--status-info-text);line-height:var(--leading-relaxed)}.ex-fb-continue-btn{width:100%;padding:16px;border:none;border-radius:var(--radius-full);font-size:var(--text-base);font-weight:var(--font-extrabold);text-transform:uppercase;letter-spacing:var(--tracking-wider);cursor:pointer;display:flex;align-items:center;justify-content:center;gap:10px;transition:transform .15s ease,box-shadow .15s ease,opacity var(--transition-fast);margin-bottom:10px}.ex-fb-continue-btn--correct{background:linear-gradient(135deg,var(--color-exercise-green) 0%,var(--color-exercise-green-dark) 100%);color:#fff;box-shadow:0 4px 0 var(--color-exercise-green-shadow)}.ex-fb-continue-btn--correct:hover{opacity:.93;transform:translateY(-1px);box-shadow:0 5px 0 var(--color-exercise-green-shadow)}.ex-fb-continue-btn--correct:active{transform:translateY(3px);box-shadow:0 1px 0 var(--color-exercise-green-shadow)}.ex-fb-continue-btn--incorrect{background:linear-gradient(135deg,var(--color-violet-600) 0%,var(--color-violet-500) 100%);color:#fff;box-shadow:0 4px 0 var(--color-violet-800)}.ex-fb-continue-btn--incorrect:hover{opacity:.93;transform:translateY(-1px);box-shadow:0 5px 0 var(--color-violet-800)}.ex-fb-continue-btn--incorrect:active{transform:translateY(3px);box-shadow:0 1px 0 var(--color-violet-800)}.ex-fb-continue-btn:focus-visible{outline:3px solid var(--border-focus);outline-offset:3px}.ex-fb-auto-hint{display:flex;align-items:center;justify-content:center;gap:6px;font-size:var(--text-xs);color:var(--text-tertiary)}.ex-fb-auto-dot{width:6px;height:6px;border-radius:var(--radius-full);background:var(--color-exercise-green);animation:dotPulse2 1.2s ease-in-out infinite}@keyframes dotPulse2{0%,to{opacity:.4;transform:scale(.8)}50%{opacity:1;transform:scale(1.2)}}.ex-confetti-layer{position:fixed;inset:0;pointer-events:none;overflow:hidden;z-index:calc(var(--z-modal) + 1)}.ex-confetti-piece{position:absolute;width:9px;height:9px;top:-20px;border-radius:2px;animation:confettiFall 2.8s linear forwards}@keyframes confettiFall{0%{transform:translateY(0) rotate(0);opacity:1}90%{opacity:1}to{transform:translateY(105vh) rotate(720deg);opacity:0}}.ex-gameover-overlay{position:fixed;inset:0;z-index:var(--z-modal);background:var(--bg-overlay-heavy);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;padding:24px}.ex-gameover-card{background:var(--bg-card);border-radius:var(--radius-3xl);padding:44px 36px 36px;max-width:460px;width:100%;text-align:center;box-shadow:var(--shadow-2xl);animation:sheetPopIn .4s cubic-bezier(.34,1.56,.64,1)}.ex-gameover-heart-icon{font-size:72px;line-height:1;margin-bottom:16px;animation:feedbackBounce .6s cubic-bezier(.68,-.55,.265,1.55);display:block}.ex-gameover-title{font-size:clamp(1.75rem,5vw,2.25rem);font-weight:var(--font-extrabold);color:var(--color-exercise-red);margin-bottom:8px}.ex-gameover-subtitle{font-size:var(--text-base);color:var(--text-secondary);margin-bottom:28px}.ex-gameover-stats{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:28px}.ex-gameover-stat-card{background:var(--bg-secondary);border-radius:var(--radius-xl);padding:16px}.ex-gameover-stat-label{font-size:var(--text-xs);font-weight:var(--font-extrabold);text-transform:uppercase;letter-spacing:var(--tracking-wider);color:var(--text-tertiary);margin-bottom:6px;display:block}.ex-gameover-stat-value{font-size:var(--text-2xl);font-weight:var(--font-extrabold);color:var(--text-primary)}.ex-gameover-stat-value--xp{color:var(--color-violet-600);display:flex;align-items:center;justify-content:center;gap:4px}[data-theme=dark] .ex-gameover-stat-value--xp{color:var(--color-violet-300)}.ex-gameover-try-btn{width:100%;padding:16px;border:none;border-radius:var(--radius-full);font-size:var(--text-base);font-weight:var(--font-extrabold);text-transform:uppercase;letter-spacing:var(--tracking-wider);cursor:pointer;background:linear-gradient(135deg,var(--color-violet-600) 0%,var(--color-violet-500) 100%);color:#fff;box-shadow:0 4px 0 var(--color-violet-800);display:flex;align-items:center;justify-content:center;gap:10px;margin-bottom:12px;transition:transform .15s ease,box-shadow .15s ease,opacity var(--transition-fast)}.ex-gameover-try-btn:hover{opacity:.92;transform:translateY(-1px);box-shadow:0 5px 0 var(--color-violet-800)}.ex-gameover-try-btn:active{transform:translateY(3px);box-shadow:0 1px 0 var(--color-violet-800)}.ex-gameover-try-btn:focus-visible{outline:3px solid var(--border-focus);outline-offset:3px}.ex-gameover-back-btn{width:100%;padding:15px;border:2px solid var(--border-default);border-radius:var(--radius-full);font-size:var(--text-base);font-weight:var(--font-semibold);cursor:pointer;background:var(--bg-card);color:var(--text-primary);display:flex;align-items:center;justify-content:center;gap:8px;margin-bottom:20px;transition:background var(--transition-fast),border-color var(--transition-fast)}.ex-gameover-back-btn:hover{background:var(--bg-secondary);border-color:var(--border-strong)}.ex-gameover-back-btn:focus-visible{outline:3px solid var(--border-focus);outline-offset:2px}.ex-gameover-tip{display:flex;align-items:center;justify-content:center;gap:6px;font-size:var(--text-xs);color:var(--text-tertiary)}.ex-complete-screen{min-height:100dvh;background:var(--bg-page);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px 24px;text-align:center}.ex-complete-emoji{font-size:72px;margin-bottom:16px;animation:celebrate .8s cubic-bezier(.68,-.55,.265,1.55);display:block}@keyframes celebrate{0%{transform:scale(.3) rotate(-20deg);opacity:0}60%{transform:scale(1.2) rotate(10deg)}80%{transform:scale(.95) rotate(-5deg)}to{transform:scale(1) rotate(0);opacity:1}}.ex-complete-title{font-size:clamp(2rem,5vw,3rem);font-weight:var(--font-extrabold);color:var(--text-primary);margin-bottom:8px}.ex-complete-subtitle{font-size:var(--text-lg);color:var(--text-secondary);margin-bottom:36px;font-weight:var(--font-medium)}.ex-complete-score-row{display:flex;gap:20px;align-items:center;justify-content:center;margin-bottom:36px;flex-wrap:wrap;width:100%;max-width:640px}.ex-score-circle-wrap{background:var(--bg-card);border-radius:var(--radius-2xl);padding:28px;box-shadow:var(--shadow-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}.ex-score-circle{position:relative;width:140px;height:140px}.ex-score-circle svg{transform:rotate(-90deg)}.ex-score-text{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}.ex-score-pct{font-size:var(--text-3xl);font-weight:var(--font-extrabold);color:var(--color-violet-600);line-height:1}[data-theme=dark] .ex-score-pct{color:var(--color-violet-300)}.ex-score-label{font-size:var(--text-xs);font-weight:var(--font-extrabold);text-transform:uppercase;letter-spacing:var(--tracking-wider);color:var(--text-secondary);margin-top:4px}.ex-complete-stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;flex:1;min-width:200px}.ex-complete-stat{background:var(--bg-card);border-radius:var(--radius-xl);padding:16px 12px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;align-items:center;gap:6px}.ex-complete-stat-icon{font-size:20px}.ex-complete-stat-value{font-size:var(--text-xl);font-weight:var(--font-extrabold);color:var(--text-primary);line-height:1}.ex-complete-stat-label{font-size:10px;font-weight:var(--font-extrabold);text-transform:uppercase;letter-spacing:var(--tracking-wider);color:var(--text-tertiary)}.ex-complete-actions{display:flex;gap:12px;width:100%;max-width:480px;flex-wrap:wrap}.ex-complete-btn-primary{flex:1;min-width:180px;padding:16px 24px;border:none;border-radius:var(--radius-full);font-size:var(--text-base);font-weight:var(--font-extrabold);cursor:pointer;background:linear-gradient(135deg,var(--color-violet-600) 0%,var(--color-violet-500) 100%);color:#fff;box-shadow:0 4px 0 var(--color-violet-800);transition:transform .15s ease,box-shadow .15s ease,opacity var(--transition-fast)}.ex-complete-btn-primary:hover{opacity:.92;transform:translateY(-1px);box-shadow:0 5px 0 var(--color-violet-800)}.ex-complete-btn-primary:active{transform:translateY(3px);box-shadow:0 1px 0 var(--color-violet-800)}.ex-complete-btn-primary:focus-visible{outline:3px solid var(--border-focus);outline-offset:3px}.ex-complete-btn-secondary{flex:1;min-width:180px;padding:15px 24px;border:2px solid var(--color-violet-600);border-radius:var(--radius-full);font-size:var(--text-base);font-weight:var(--font-extrabold);cursor:pointer;background:var(--bg-card);color:var(--color-violet-600);transition:background var(--transition-fast),border-color var(--transition-fast)}[data-theme=dark] .ex-complete-btn-secondary{border-color:var(--color-violet-400);color:var(--color-violet-300)}.ex-complete-btn-secondary:hover{background:#702ae10f}.ex-complete-btn-secondary:focus-visible{outline:3px solid var(--border-focus);outline-offset:3px}.ex-loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100dvh;gap:20px;background:var(--bg-page)}.ex-loading-spinner{width:48px;height:48px;border:5px solid var(--bg-tertiary);border-top-color:var(--color-violet-600);border-radius:50%;animation:exSpin .8s linear infinite}.ex-loading-text{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--text-secondary)}@media(max-width:639px){.exercise-top-bar{padding:8px 14px;gap:10px;min-height:54px}.ex-progress-wrap{max-width:none}.ex-stat-pill{padding:5px 9px;font-size:11px}.ex-stat-icon{font-size:14px}.ex-heart{font-size:15px}.exercise-content{padding:20px 0 0;align-items:stretch}.exercise-card{padding:20px 16px;border-radius:0;border-left:none;border-right:none;box-shadow:none;flex:1}.ex-question-heading{font-size:1.2rem}.exercise-bottom-bar{padding:12px 16px 20px;gap:10px;min-height:auto}.ex-hint-btn{padding:11px 14px;font-size:var(--text-xs)}.ex-check-btn{max-width:none;padding:14px 24px;font-size:var(--text-sm);min-height:50px}.ex-match-grid{gap:8px}.ex-match-item{padding:12px 10px;font-size:var(--text-sm)}.ex-complete-score-row{flex-direction:column;align-items:center}.ex-complete-stats-grid{width:100%;max-width:320px}.ex-gameover-card{padding:36px 24px 28px;margin:0 8px}}@media(prefers-reduced-motion:reduce){.ex-progress-fill,.ex-option-btn,.ex-match-item,.ex-check-btn,.ex-feedback-sheet,.ex-gameover-card{transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}.ex-confetti-piece{animation:none;display:none}}@media(prefers-contrast:high){.ex-option-btn{border-width:3px}.ex-check-btn:disabled,.ex-check-btn--disabled{opacity:.5}}.ex-type-badge--writing{background:#58cc021a;color:var(--color-exercise-green-dark);border:1px solid rgba(88,204,2,.25)}.ex-type-badge--translation{background:#1cb0f61a;color:var(--color-exercise-blue);border:1px solid rgba(28,176,246,.25)}.ex-type-badge--conversation{background:#702ae11a;color:var(--color-violet-600);border:1px solid rgba(112,42,225,.2)}[data-theme=dark] .ex-type-badge--conversation{color:var(--color-violet-300)}.ex-type-badge--truefalse{background:#ff4b4b1a;color:var(--color-exercise-red);border:1px solid rgba(255,75,75,.2)}.ex-type-badge--ordering{background:#ff96001a;color:var(--color-streak-orange);border:1px solid rgba(255,150,0,.2)}.ex-type-badge--fallback{background:var(--bg-secondary);color:var(--text-secondary);border:1px solid var(--border-default)}.ex-fallback-hint{display:flex;align-items:flex-start;gap:10px;background:var(--status-info-bg);border:1px solid var(--status-info-border);border-radius:var(--radius-xl);padding:12px 14px;margin-bottom:20px}.ex-fallback-hint-icon{flex-shrink:0;color:var(--status-info-text);margin-top:1px;display:flex;align-items:center}.ex-fallback-hint-text{font-size:var(--text-sm);color:var(--status-info-text);line-height:var(--leading-relaxed);font-weight:var(--font-medium);margin:0}.ex-fallback-input-area{display:flex;flex-direction:column;gap:16px}.ex-fallback-textarea-wrap{display:flex;flex-direction:column;gap:8px}.ex-fallback-textarea-label{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--text-secondary);display:block}.ex-fallback-textarea{width:100%;min-height:120px;padding:14px 16px;background:var(--bg-secondary);border:2px solid var(--border-default);border-bottom-color:var(--ex-fallback-accent, var(--color-violet-600));border-bottom-width:3px;border-radius:var(--radius-xl) var(--radius-xl) var(--radius-md) var(--radius-md);font-size:var(--text-base);font-weight:var(--font-medium);color:var(--text-primary);font-family:var(--font-primary);line-height:var(--leading-relaxed);outline:none;resize:vertical;transition:border-color var(--transition-fast),background var(--transition-fast),box-shadow var(--transition-fast)}.ex-fallback-textarea::-moz-placeholder{color:var(--text-tertiary);font-weight:var(--font-normal)}.ex-fallback-textarea::placeholder{color:var(--text-tertiary);font-weight:var(--font-normal)}.ex-fallback-textarea:focus{background:var(--bg-card);border-color:var(--ex-fallback-accent, var(--color-violet-600));border-bottom-width:3px;box-shadow:0 0 0 3px color-mix(in srgb,var(--ex-fallback-accent, var(--color-violet-600)) 15%,transparent)}.ex-fallback-textarea:disabled{opacity:.6;cursor:not-allowed;resize:none}[data-theme=dark] .ex-fallback-textarea{background:var(--bg-secondary);border-color:var(--border-default)}[data-theme=dark] .ex-fallback-textarea:focus{background:var(--bg-tertiary)}.ex-fallback-char-hint{font-size:var(--text-xs);color:var(--text-tertiary);font-weight:var(--font-medium);margin:0;min-height:1.2em}.ex-fallback-tf-group{border:none;padding:0;margin:0}.ex-fallback-tf-legend{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--text-secondary);margin-bottom:14px;display:block;width:100%;float:left}.ex-fallback-tf-options{display:flex;gap:14px;flex-wrap:wrap;clear:both}.ex-fallback-tf-radio{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.ex-fallback-tf-option{flex:1;min-width:130px;display:flex;align-items:center;gap:14px;padding:18px 20px;background:var(--bg-card);border:2px solid var(--border-default);border-radius:var(--radius-xl);cursor:pointer;font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--text-primary);transition:border-color var(--transition-fast),background var(--transition-fast),box-shadow var(--transition-fast),transform .15s ease;box-shadow:0 4px 0 var(--border-default);-webkit-user-select:none;-moz-user-select:none;user-select:none}.ex-fallback-tf-option:not(.ex-fallback-tf-option--disabled):hover{border-color:var(--border-strong);background:var(--bg-card-hover);transform:translateY(-2px);box-shadow:0 6px 0 var(--border-strong)}.ex-fallback-tf-radio:focus-visible+.ex-fallback-tf-icon{outline:3px solid var(--border-focus);outline-offset:2px;border-radius:var(--radius-full)}.ex-fallback-tf-option--selected{background:#58cc0212;border-color:var(--color-exercise-green);box-shadow:0 4px 0 var(--color-exercise-green-shadow);transform:translateY(-2px);color:var(--color-exercise-green-dark)}.ex-fallback-tf-option--selected:not(.ex-fallback-tf-option--disabled):hover{box-shadow:0 6px 0 var(--color-exercise-green-shadow)}.ex-fallback-tf-option--selected.ex-fallback-tf-option--false{background:#ff4b4b12;border-color:var(--color-exercise-red);box-shadow:0 4px #c83b3b;color:var(--color-exercise-red)}.ex-fallback-tf-option--selected.ex-fallback-tf-option--false:not(.ex-fallback-tf-option--disabled):hover{box-shadow:0 6px #c83b3b}[data-theme=dark] .ex-fallback-tf-option--selected{background:#58cc021a}[data-theme=dark] .ex-fallback-tf-option--selected.ex-fallback-tf-option--false{background:#ff4b4b1a}.ex-fallback-tf-option--disabled{opacity:.55;cursor:not-allowed}.ex-fallback-tf-option--disabled:hover{transform:none}.ex-fallback-tf-icon{flex-shrink:0;width:36px;height:36px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;background:var(--bg-secondary);border:2px solid var(--border-strong);transition:background var(--transition-fast),border-color var(--transition-fast),color var(--transition-fast)}.ex-fallback-tf-option--selected .ex-fallback-tf-icon--true{background:var(--color-exercise-green);border-color:var(--color-exercise-green-dark);color:#fff}.ex-fallback-tf-option--selected.ex-fallback-tf-option--false .ex-fallback-tf-icon--false{background:var(--color-exercise-red);border-color:#c83b3b;color:#fff}.ex-fallback-tf-label{font-size:var(--text-lg);font-weight:var(--font-semibold);line-height:var(--leading-snug)}@media(max-width:639px){.ex-fallback-tf-options{flex-direction:column;gap:10px}.ex-fallback-tf-option{min-width:unset;padding:16px}.ex-fallback-textarea{min-height:100px;font-size:var(--text-sm)}}@media(prefers-reduced-motion:reduce){.ex-fallback-tf-option,.ex-fallback-textarea{transition-duration:.01ms!important;animation-duration:.01ms!important}}@media(prefers-contrast:high){.ex-fallback-tf-option,.ex-fallback-textarea{border-width:3px}}[data-theme=dark] .ex-feedback-sheet--correct,[data-theme=dark] .ex-feedback-sheet--incorrect{border-top-width:4px}[data-theme=dark] .ex-fill-input{background:var(--bg-secondary);border-color:var(--border-default);border-bottom-color:var(--color-exercise-green)}[data-theme=dark] .ex-fill-input:focus{background:var(--bg-tertiary)}.lp-shell{min-height:100vh;background:var(--bg-page);padding-bottom:var(--space-20)}.lp-subheader{background:var(--bg-card);box-shadow:var(--shadow-sm);position:sticky;top:0;z-index:var(--z-sticky);border-bottom:1px solid var(--border-subtle)}.lp-subheader-inner{max-width:800px;margin:0 auto;padding:0 var(--space-6)}.lp-subheader-row{display:flex;align-items:flex-start;gap:var(--space-4);padding-top:var(--space-5);padding-bottom:var(--space-4)}.lp-back-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;min-width:40px;border:none;background:var(--bg-secondary);color:var(--text-brand);border-radius:var(--radius-lg);cursor:pointer;transition:background var(--transition-fast),transform var(--transition-fast),color var(--transition-fast);flex-shrink:0}.lp-back-btn:hover{background:var(--btn-primary-bg);color:var(--btn-primary-text);transform:translate(-2px)}.lp-back-btn:active{transform:translate(-1px) scale(.96)}.lp-back-btn:focus-visible{outline:2px solid var(--border-focus);outline-offset:2px}.lp-title-block{flex:1;min-width:0}.lp-breadcrumb{display:flex;align-items:center;gap:var(--space-1);font-size:var(--text-xs);font-weight:700;text-transform:uppercase;letter-spacing:var(--tracking-wider);color:var(--text-secondary);margin-bottom:var(--space-1)}.lp-breadcrumb-sep{color:var(--text-tertiary)}.lp-lesson-title{font-size:var(--text-2xl);font-weight:var(--font-extrabold);color:var(--text-primary);line-height:var(--leading-tight);margin:0 0 var(--space-1) 0;letter-spacing:var(--tracking-tight)}.lp-lesson-desc{font-size:var(--text-sm);color:var(--text-secondary);margin:0;line-height:var(--leading-relaxed)}.lp-status{flex-shrink:0;padding-top:var(--space-1)}.lp-badge{display:inline-block;padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--font-bold);white-space:nowrap}.lp-badge--success{background:var(--status-success-bg);color:var(--status-success-text);border:1px solid var(--status-success-border)}.lp-badge--progress{background:var(--bg-secondary);color:var(--text-brand)}.lp-badge--neutral{background:var(--bg-tertiary);color:var(--text-secondary)}.lp-tablist{display:flex;align-items:center;gap:var(--space-8);overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.lp-tablist::-webkit-scrollbar{display:none}.lp-tab{position:relative;display:flex;align-items:center;gap:var(--space-2);padding:var(--space-4) 0;border:none;background:transparent;color:var(--text-secondary);font-size:var(--text-sm);font-weight:var(--font-medium);cursor:pointer;white-space:nowrap;transition:color var(--transition-fast),opacity var(--transition-fast);opacity:.6}.lp-tab:hover{color:var(--text-brand);opacity:1}.lp-tab--active{color:var(--text-brand);font-weight:var(--font-bold);opacity:1}.lp-tab:focus-visible{outline:2px solid var(--border-focus);outline-offset:4px;border-radius:var(--radius-sm)}.lp-tab-count{display:inline-flex;align-items:center;justify-content:center;background:var(--bg-secondary);color:var(--text-brand);border-radius:var(--radius-full);font-size:10px;font-weight:var(--font-bold);padding:1px var(--space-2);min-width:20px;line-height:1.4}.lp-tab--active .lp-tab-count{background:var(--btn-primary-bg);color:var(--btn-primary-text)}.lp-tab-indicator{position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--text-brand);border-radius:2px 2px 0 0}.lp-body{max-width:800px;margin:0 auto;padding:var(--space-8) var(--space-6)}.lp-panel{animation:lp-fadeUp var(--transition-base) both}.lp-content-card{background:var(--bg-card);border-radius:var(--card-radius);box-shadow:var(--shadow-lg);padding:var(--space-8) var(--space-10);position:relative;overflow:hidden;outline:1px solid var(--border-subtle)}.lp-meta-row{display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-6);margin-bottom:var(--space-8);color:var(--text-secondary)}.lp-meta-item{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-xs);font-weight:var(--font-medium)}.lp-meta-item svg{color:var(--text-brand);flex-shrink:0}.lp-meta-item--xp svg{color:var(--color-amber-500)}.lp-article{color:var(--text-primary);line-height:var(--leading-relaxed);font-size:var(--text-base)}.lp-article h2,.lp-article h3{font-size:var(--text-2xl);font-weight:var(--font-extrabold);color:var(--text-brand);margin-bottom:var(--space-4);letter-spacing:var(--tracking-tight)}.lp-article p{font-size:var(--text-lg);font-weight:var(--font-medium);opacity:.9;margin-bottom:var(--space-6);line-height:var(--leading-relaxed)}.lp-article p:last-child{margin-bottom:0}.lp-foreign-word{display:inline;font-style:italic;font-weight:var(--font-semibold);color:var(--text-brand);background:var(--bg-secondary);border-radius:var(--radius-sm);padding:0 var(--space-1);text-decoration:underline;text-decoration-color:var(--border-focus);text-underline-offset:2px;cursor:default}.lp-markdown-content h2{font-size:var(--text-xl);font-weight:var(--font-bold);color:var(--text-brand);margin-top:var(--space-8);margin-bottom:var(--space-3);letter-spacing:var(--tracking-tight)}.lp-markdown-content h3{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--text-primary);margin-top:var(--space-6);margin-bottom:var(--space-2)}.lp-markdown-content p{font-size:var(--text-base);line-height:var(--leading-relaxed);margin-bottom:var(--space-4);color:var(--text-secondary)}.lp-markdown-content strong{font-weight:var(--font-semibold);color:var(--text-primary)}.lp-markdown-content em{font-style:italic;color:var(--text-brand)}.lp-markdown-content ul,.lp-markdown-content ol{padding-left:var(--space-6);margin-bottom:var(--space-4)}.lp-markdown-content li{font-size:var(--text-base);line-height:var(--leading-relaxed);margin-bottom:var(--space-2);color:var(--text-secondary)}.lp-markdown-content li strong{color:var(--text-primary)}.lp-markdown-content table{width:100%;border-collapse:collapse;margin:var(--space-4) 0 var(--space-6);font-size:var(--text-sm);border-radius:var(--radius-md);overflow:hidden;border:1px solid var(--border-subtle)}.lp-markdown-content thead{background:var(--bg-secondary)}.lp-markdown-content th{padding:var(--space-3) var(--space-4);text-align:left;font-weight:var(--font-semibold);color:var(--text-primary);border-bottom:2px solid var(--border-default)}.lp-markdown-content td{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border-subtle);color:var(--text-secondary)}.lp-markdown-content tbody tr:hover{background:var(--bg-secondary)}.lp-markdown-content tbody tr:last-child td{border-bottom:none}.lp-markdown-content hr{border:none;border-top:1px solid var(--border-subtle);margin:var(--space-6) 0}.lp-markdown-content code{background:var(--bg-secondary);padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm);font-size:.9em;color:var(--text-brand)}.lp-markdown-content blockquote{border-left:3px solid var(--border-focus);margin:var(--space-4) 0;padding:var(--space-3) var(--space-4);background:var(--bg-secondary);border-radius:0 var(--radius-md) var(--radius-md) 0}.lp-markdown-content blockquote p{margin-bottom:var(--space-2);color:var(--text-primary)}.lp-markdown-content blockquote p:last-child{margin-bottom:0}.lp-media{margin-top:var(--space-6);padding-top:var(--space-6);border-top:1px solid var(--border-subtle)}.lp-media h4{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--text-secondary);margin-bottom:var(--space-3);text-transform:uppercase;letter-spacing:var(--tracking-wider)}.lp-audio{width:100%}.lp-video{width:100%;border-radius:var(--radius-lg)}.lp-content-cta{margin-top:var(--space-12);padding-top:var(--space-8);display:flex;flex-direction:column;align-items:center;gap:var(--space-4)}.lp-content-cta-hint{font-size:var(--text-xs);color:var(--text-secondary);margin:0}.lp-btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-8);border-radius:var(--radius-xl);font-size:var(--text-sm);font-weight:var(--font-bold);cursor:pointer;border:none;transition:transform var(--transition-fast),box-shadow var(--transition-fast),background var(--transition-fast),opacity var(--transition-fast);white-space:nowrap}.lp-btn:active{transform:translateY(2px)}.lp-btn:focus-visible{outline:2px solid var(--border-focus);outline-offset:2px}.lp-btn--primary{background:var(--btn-primary-bg);color:var(--btn-primary-text);box-shadow:0 4px 0 0 var(--color-violet-700);padding-top:var(--space-4);padding-bottom:var(--space-4)}.lp-btn--primary:hover{background:var(--btn-primary-hover);transform:translateY(-2px);box-shadow:0 6px 0 0 var(--color-violet-700)}.lp-btn--primary:active{transform:translateY(2px);box-shadow:none}.lp-btn--ghost{background:transparent;color:var(--text-brand);border:2px solid var(--border-focus);opacity:.8}.lp-btn--ghost:hover{background:var(--bg-secondary);opacity:1}.lp-btn--lg{padding:var(--space-4) var(--space-10);font-size:var(--text-base)}.lp-flashcard-grid{display:grid;grid-template-columns:1fr;gap:var(--space-6);margin-bottom:var(--space-8)}@media(min-width:640px){.lp-flashcard-grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:900px){.lp-flashcard-grid{grid-template-columns:repeat(3,1fr)}}.lp-flashcard{perspective:1000px;height:280px;width:100%;cursor:pointer}.lp-flashcard:focus-visible{outline:2px solid var(--border-focus);outline-offset:4px;border-radius:var(--radius-lg)}.lp-flashcard-inner{position:relative;width:100%;height:100%;transform-style:preserve-3d;transition:transform .6s cubic-bezier(.4,0,.2,1)}.lp-flashcard--flipped .lp-flashcard-inner{transform:rotateY(180deg)}.lp-flashcard:not(.lp-flashcard--flipped):hover .lp-flashcard-inner{box-shadow:var(--shadow-xl)}.lp-flashcard-face{position:absolute;inset:0;backface-visibility:hidden;-webkit-backface-visibility:hidden;border-radius:var(--radius-lg);display:flex;flex-direction:column;align-items:center;justify-content:space-between;padding:var(--space-8);text-align:center}.lp-flashcard-face--front{background:var(--gradient-brand);box-shadow:0 20px 40px #702ae126}.lp-flashcard-face--back{background:var(--bg-card);border:2px solid var(--border-focus);transform:rotateY(180deg);box-shadow:var(--shadow-sm)}.lp-flashcard-icon{width:48px;height:48px;border-radius:var(--radius-full);background:#fff3;display:flex;align-items:center;justify-content:center;color:var(--btn-primary-text);flex-shrink:0}.lp-flashcard-icon--back{background:var(--bg-secondary);color:var(--text-brand)}.lp-flashcard-front-body{display:flex;flex-direction:column;align-items:center;gap:var(--space-2)}.lp-flashcard-word{font-size:var(--text-3xl);font-weight:var(--font-extrabold);color:var(--btn-primary-text);letter-spacing:var(--tracking-tight);margin:0}.lp-flashcard-pronunciation{font-size:var(--text-base);font-style:italic;color:#fffc;font-weight:var(--font-medium);letter-spacing:.01em}.lp-flashcard-pos{font-size:var(--text-xs);font-weight:var(--font-bold);text-transform:uppercase;letter-spacing:var(--tracking-wider);color:#ffffffa6;background:#ffffff26;padding:2px var(--space-2);border-radius:var(--radius-full)}.lp-flashcard-hint{display:inline-block;font-size:var(--text-sm);font-weight:var(--font-medium);background:var(--btn-primary-text);color:var(--text-brand);padding:var(--space-1) var(--space-4);border-radius:var(--radius-full)}.lp-flashcard-hint--back{background:transparent;color:var(--text-tertiary);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:var(--tracking-wider)}.lp-flashcard-translation-block{display:flex;flex-direction:column;align-items:center;gap:var(--space-2);padding:0 var(--space-2)}.lp-flashcard-translation-label{display:block;font-size:var(--text-xs);font-weight:var(--font-bold);text-transform:uppercase;letter-spacing:var(--tracking-wider);color:var(--text-secondary)}.lp-flashcard-translation{font-size:var(--text-3xl);font-weight:var(--font-extrabold);color:var(--text-primary);letter-spacing:var(--tracking-tight);margin:0}.lp-flashcard-dict-hint{font-size:var(--text-sm);color:var(--text-secondary);line-height:var(--leading-relaxed);text-align:center;margin:0}.lp-flashcard-dict-hint strong{color:var(--text-brand);font-style:italic}.lp-mastery-bar{background:var(--bg-secondary);border-radius:var(--radius-lg);padding:var(--space-6) var(--space-8);display:flex;flex-direction:column;gap:var(--space-4);border:1px solid var(--border-subtle);margin-bottom:var(--space-8)}@media(min-width:640px){.lp-mastery-bar{flex-direction:row;align-items:center;justify-content:space-between}}.lp-mastery-info{display:flex;align-items:center;gap:var(--space-4)}.lp-mastery-icon{width:48px;height:48px;min-width:48px;border-radius:var(--radius-full);background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;color:var(--text-brand)}.lp-mastery-title{font-weight:var(--font-bold);color:var(--text-primary);margin:0 0 var(--space-1) 0}.lp-mastery-sub{font-size:var(--text-sm);color:var(--text-secondary);margin:0}.lp-progress-track{width:100%;height:8px;background:var(--bg-tertiary);border-radius:var(--radius-full);overflow:hidden}@media(min-width:640px){.lp-progress-track{width:256px;min-width:180px;flex-shrink:0}}.lp-progress-fill{height:100%;background:var(--gradient-brand);border-radius:var(--radius-full);box-shadow:0 0 10px #702ae133;transition:width var(--transition-slow)}.lp-vocab-actions{display:flex;align-items:center;justify-content:center;gap:var(--space-4);flex-wrap:wrap;margin-top:var(--space-8)}.lp-exercises-intro{background:var(--bg-card);border-radius:var(--card-radius);box-shadow:var(--shadow-sm);padding:var(--space-8);text-align:center;margin-bottom:var(--space-6);outline:1px solid var(--border-subtle)}.lp-exercises-intro h3{font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--text-primary);margin-bottom:var(--space-2)}.lp-exercises-intro p{color:var(--text-secondary);font-size:var(--text-base);margin:0 0 var(--space-4) 0}.lp-exercises-meta{display:flex;gap:var(--space-6);justify-content:center;font-size:var(--text-sm);color:var(--text-secondary)}.lp-exercise-list{display:flex;flex-direction:column;gap:var(--space-4)}.lp-exercise-item{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-5);background:var(--bg-card);border-radius:var(--radius-xl);box-shadow:var(--shadow-xs);outline:1px solid var(--border-subtle);transition:box-shadow var(--transition-fast),transform var(--transition-fast)}.lp-exercise-item:hover{box-shadow:var(--shadow-md);transform:translate(4px)}.lp-exercise-num{width:40px;height:40px;min-width:40px;display:flex;align-items:center;justify-content:center;background:var(--gradient-brand);color:var(--btn-primary-text);border-radius:var(--radius-full);font-size:var(--text-lg);font-weight:var(--font-bold);flex-shrink:0}.lp-exercise-details{flex:1;min-width:0}.lp-exercise-details h4{font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--text-primary);margin:0 0 var(--space-1) 0}.lp-exercise-question{font-size:var(--text-sm);color:var(--text-secondary);margin:0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.lp-exercise-hint{font-size:var(--text-xs);color:var(--text-tertiary);margin:var(--space-1) 0 0 0}.lp-exercise-meta{display:flex;gap:var(--space-3);margin-top:var(--space-2);flex-wrap:wrap}.lp-exercise-pts,.lp-exercise-time,.lp-exercise-speech{font-size:var(--text-xs);font-weight:var(--font-semibold);color:var(--text-secondary);background:var(--bg-secondary);padding:2px var(--space-2);border-radius:var(--radius-full)}.lp-empty-state{background:var(--bg-card);border-radius:var(--card-radius);box-shadow:var(--shadow-sm);padding:var(--space-16) var(--space-6);text-align:center}.lp-empty-icon{font-size:4rem;margin-bottom:var(--space-4);opacity:.5}.lp-empty-state h3{font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--text-primary);margin-bottom:var(--space-2)}.lp-empty-state p{color:var(--text-secondary);font-size:var(--text-base);margin:0}.lp-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-16) var(--space-6);gap:var(--space-4);min-height:60vh}.lp-loading p{color:var(--text-secondary);font-size:var(--text-lg);margin:0}@media(max-width:640px){.lp-subheader-inner{padding:0 var(--space-4)}.lp-subheader-row{padding-top:var(--space-4);padding-bottom:var(--space-3);gap:var(--space-3)}.lp-lesson-title{font-size:var(--text-xl)}.lp-tablist{gap:var(--space-6)}.lp-body{padding:var(--space-6) var(--space-4)}.lp-content-card{padding:var(--space-6)}.lp-vocab-actions{flex-direction:column}.lp-vocab-actions .lp-btn{width:100%}.lp-flashcard{height:240px}.lp-flashcard-word,.lp-flashcard-translation{font-size:var(--text-2xl)}.lp-flashcard-pronunciation{font-size:var(--text-sm)}.lp-flashcard-dict-hint{font-size:var(--text-xs)}.lp-btn--lg{padding:var(--space-4) var(--space-6)}}@keyframes lp-fadeUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media(prefers-reduced-motion:reduce){.lp-panel{animation:none}.lp-flashcard-inner{transition:none}.lp-flashcard--flipped .lp-flashcard-face--front{opacity:0;pointer-events:none}.lp-flashcard--flipped .lp-flashcard-face--back{opacity:1;pointer-events:auto}.lp-flashcard-face--back{transform:none;opacity:0;transition:opacity var(--transition-fast)}.lp-flashcard-face--front{transition:opacity var(--transition-fast)}.lp-btn--primary:hover,.lp-back-btn:hover,.lp-exercise-item:hover{transform:none}.lp-progress-fill{transition:none}}.student-dashboard{min-height:100vh;background:var(--bg-page);font-family:var(--font-primary);color:var(--text-primary);padding:var(--space-4);padding-bottom:calc(var(--bottom-nav-height) + var(--space-6))}.dashboard-container{max-width:var(--container-max-width);margin:0 auto;display:flex;flex-direction:column;gap:var(--space-8)}.dashboard-loading{display:flex;justify-content:center;align-items:center;min-height:60vh;color:var(--text-brand);font-size:var(--text-lg);font-weight:var(--font-semibold)}.welcome-hero{background:var(--gradient-hero);border-radius:var(--radius-3xl);padding:var(--space-8) var(--space-6);overflow:hidden;position:relative;box-shadow:var(--shadow-brand);color:var(--color-neutral-0)}.hero-blob-top{position:absolute;top:-5rem;right:-5rem;width:20rem;height:20rem;background:#ffffff1a;border-radius:var(--radius-full);filter:blur(60px);pointer-events:none;aria-hidden:true}.hero-blob-bottom{position:absolute;bottom:-4rem;left:-4rem;width:16rem;height:16rem;background:#b28cff33;border-radius:var(--radius-full);filter:blur(50px);pointer-events:none;aria-hidden:true}.hero-inner{position:relative;z-index:1;display:flex;flex-direction:column;gap:var(--space-8)}.hero-text h1{font-size:var(--text-3xl);font-weight:var(--font-extrabold);letter-spacing:var(--tracking-tight);line-height:var(--leading-tight);margin:0 0 var(--space-2) 0;color:inherit}.hero-text p{font-size:var(--text-base);opacity:.9;margin:0;color:inherit}.hero-stats{display:flex;flex-wrap:wrap;gap:var(--space-4);margin-top:var(--space-6)}.hero-stat-pill{display:flex;align-items:center;gap:var(--space-3);background:var(--glass-bg-medium);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid var(--glass-border);border-radius:var(--radius-2xl);padding:var(--space-3) var(--space-5);box-shadow:var(--shadow-md);min-width:120px}.hero-stat-icon{font-size:2rem;line-height:1;flex-shrink:0}.hero-stat-icon--fire{animation:fire-pulse 2s infinite ease-in-out}@keyframes fire-pulse{0%,to{transform:scale(1);filter:drop-shadow(0 0 4px rgba(255,149,90,.6))}50%{transform:scale(1.15);filter:drop-shadow(0 0 12px rgba(255,149,90,.9))}}@media(prefers-reduced-motion:reduce){.hero-stat-icon--fire{animation:none}}.hero-stat-value{font-size:var(--text-2xl);font-weight:var(--font-extrabold);line-height:1;color:inherit}.hero-stat-label{font-size:.625rem;font-weight:var(--font-extrabold);text-transform:uppercase;letter-spacing:.15em;opacity:.8;color:inherit}.hero-globe-wrap{display:none}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-5)}.section-title{font-size:var(--text-2xl);font-weight:var(--font-extrabold);color:var(--text-primary);letter-spacing:var(--tracking-tight);margin:0}.btn-view-all{background:#7c3aed12;border:none;color:var(--text-brand);font-size:var(--text-sm);font-weight:var(--font-bold);padding:var(--space-2) var(--space-4);border-radius:var(--radius-full);cursor:pointer;transition:background var(--transition-fast);white-space:nowrap}.btn-view-all:hover{background:#7c3aed24}.btn-view-all:focus-visible{outline:2px solid var(--border-focus);outline-offset:2px}.continue-learning-card{background:var(--bg-card);border-radius:var(--radius-3xl);padding:var(--space-6);box-shadow:var(--shadow-lg);border:1px solid var(--border-default);transition:box-shadow var(--transition-base)}.continue-learning-card:hover{box-shadow:var(--shadow-xl)}.clc-course-row{display:flex;flex-direction:column;gap:var(--space-5);margin-bottom:var(--space-6)}.clc-course-flag{width:5rem;height:5rem;background:var(--bg-secondary);border-radius:var(--radius-2xl);display:flex;align-items:center;justify-content:center;font-size:2.75rem;line-height:1;flex-shrink:0;border:1px solid var(--border-subtle);box-shadow:var(--shadow-inner)}.clc-course-meta{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-2);flex-wrap:wrap;gap:var(--space-2)}.clc-level-badge{font-size:.625rem;font-weight:var(--font-extrabold);text-transform:uppercase;letter-spacing:.12em;color:var(--text-brand);background:#7c3aed1f;border-radius:var(--radius-base);padding:var(--space-1) var(--space-3)}.clc-lessons-count{font-size:var(--text-sm);font-weight:var(--font-bold);color:var(--text-secondary)}.clc-course-name{font-size:var(--text-2xl);font-weight:var(--font-extrabold);color:var(--text-primary);margin:0 0 var(--space-5) 0;line-height:var(--leading-tight)}.clc-progress-bar-track{width:100%;height:1rem;background:var(--bg-tertiary);border-radius:var(--radius-full);overflow:hidden;box-shadow:var(--shadow-inner)}.clc-progress-bar-fill{height:100%;background:var(--gradient-brand);border-radius:var(--radius-full);box-shadow:0 0 12px #7c3aed66;position:relative;transition:width 1s ease-out}.clc-progress-bar-fill:after{content:"";position:absolute;inset:0;background:repeating-linear-gradient(45deg,rgba(255,255,255,.15) 0px,rgba(255,255,255,.15) 5px,transparent 5px,transparent 10px);border-radius:inherit;animation:progress-stripe 1.5s linear infinite}@keyframes progress-stripe{0%{background-position:0 0}to{background-position:28px 0}}@media(prefers-reduced-motion:reduce){.clc-progress-bar-fill:after{animation:none}}.clc-actions{display:flex;gap:var(--space-4);flex-wrap:wrap}.btn-continue-lesson{flex:1;min-width:140px;background:var(--btn-primary-bg);color:var(--btn-primary-text);font-size:var(--text-base);font-weight:var(--font-bold);border:none;border-radius:var(--radius-2xl);padding:var(--space-4) var(--space-6);cursor:pointer;box-shadow:0 6px 0 var(--color-violet-700);transition:transform var(--transition-fast),box-shadow var(--transition-fast)}.btn-continue-lesson:hover{transform:translateY(-2px)}.btn-continue-lesson:active{transform:translateY(4px);box-shadow:none}.btn-continue-lesson:focus-visible{outline:2px solid var(--border-focus);outline-offset:3px}.btn-course-details{flex:1;min-width:120px;background:var(--bg-secondary);color:var(--text-primary);font-size:var(--text-base);font-weight:var(--font-bold);border:1px solid var(--border-default);border-radius:var(--radius-2xl);padding:var(--space-4) var(--space-6);cursor:pointer;transition:background var(--transition-fast)}.btn-course-details:hover{background:var(--bg-tertiary)}.btn-course-details:focus-visible{outline:2px solid var(--border-focus);outline-offset:2px}.daily-mission-strip{margin-top:var(--space-6);background:linear-gradient(135deg,#ff955a14,#b28cff14);border:1px solid var(--border-default);border-radius:var(--radius-3xl);padding:var(--space-5) var(--space-6);display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);transition:border-color var(--transition-fast)}.daily-mission-strip:hover{border-color:#ff955a4d}.dms-left{display:flex;align-items:center;gap:var(--space-4)}.dms-icon-wrap{width:3.5rem;height:3.5rem;background:var(--color-streak-orange);border-radius:var(--radius-xl);display:flex;align-items:center;justify-content:center;font-size:1.75rem;box-shadow:var(--shadow-md);flex-shrink:0;transition:transform var(--transition-base)}.daily-mission-strip:hover .dms-icon-wrap{transform:scale(1.1)}.dms-title{font-size:var(--text-lg);font-weight:var(--font-extrabold);color:var(--text-primary);margin:0 0 var(--space-1) 0}.dms-subtitle{font-size:var(--text-sm);color:var(--text-secondary);margin:0}.dms-right{text-align:right;flex-shrink:0}.dms-count{font-size:var(--text-2xl);font-weight:var(--font-extrabold);color:var(--color-streak-orange);line-height:1}.dms-count-total{font-size:var(--text-lg);opacity:.4}.dms-progress-track{width:8rem;height:.5rem;background:var(--bg-tertiary);border-radius:var(--radius-full);overflow:hidden;margin-top:var(--space-2)}.dms-progress-fill{height:100%;background:var(--color-streak-orange);border-radius:var(--radius-full);transition:width .8s ease-out}.empty-state{background:var(--bg-card);border-radius:var(--radius-2xl);padding:var(--space-10) var(--space-6);text-align:center;border:2px dashed var(--border-strong);color:var(--text-secondary)}.empty-state p{margin:0 0 var(--space-4) 0}.btn-browse{display:inline-block;background:var(--btn-primary-bg);color:var(--btn-primary-text);border:none;border-radius:var(--radius-xl);padding:var(--space-3) var(--space-6);font-size:var(--text-base);font-weight:var(--font-bold);cursor:pointer;transition:background var(--transition-fast),transform var(--transition-fast)}.btn-browse:hover{background:var(--btn-primary-hover);transform:translateY(-1px)}.btn-browse:focus-visible{outline:2px solid var(--border-focus);outline-offset:2px}.recommended-list{display:flex;flex-direction:column;gap:var(--space-4)}.rec-card{background:var(--bg-card);border-radius:var(--radius-2xl);padding:var(--space-5) var(--space-5);border:1px solid var(--border-default);display:flex;align-items:flex-start;gap:var(--space-4);cursor:pointer;transition:transform var(--transition-base),box-shadow var(--transition-base);box-shadow:var(--shadow-sm);position:relative}.rec-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}.rec-card:focus-visible{outline:2px solid var(--border-focus);outline-offset:2px}.rec-card-icon{width:3.5rem;height:3.5rem;flex-shrink:0;background:var(--bg-secondary);border-radius:var(--radius-xl);display:flex;align-items:center;justify-content:center;font-size:1.75rem;border:1px solid var(--border-subtle);transition:background var(--transition-fast)}.rec-card:hover .rec-card-icon{background:#7c3aed12}.rec-card-body{flex:1;min-width:0}.rec-card-top-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-2);gap:var(--space-2)}.rec-level-badge{font-size:.625rem;font-weight:var(--font-extrabold);text-transform:uppercase;letter-spacing:.12em;padding:var(--space-1) var(--space-3);border-radius:var(--radius-full)}.rec-level-badge--beginner{color:var(--text-brand);background:#7c3aed1f}.rec-level-badge--intermediate{color:#92400e;background:#ffc88566}.rec-level-badge--advanced{color:var(--status-success-text);background:var(--status-success-bg)}.rec-card-chevron{color:var(--text-tertiary);font-size:var(--text-lg);opacity:0;transition:opacity var(--transition-fast),transform var(--transition-fast);flex-shrink:0}.rec-card:hover .rec-card-chevron{opacity:1;transform:translate(2px)}.rec-card-title{font-size:var(--text-base);font-weight:var(--font-bold);color:var(--text-primary);margin:0 0 var(--space-1) 0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.rec-card-desc{font-size:var(--text-sm);color:var(--text-secondary);margin:0;line-height:var(--leading-relaxed);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.btn-explore-more{width:100%;margin-top:var(--space-4);padding:var(--space-4);background:transparent;border:2px dashed var(--border-strong);border-radius:var(--radius-2xl);color:var(--text-secondary);font-size:var(--text-base);font-weight:var(--font-bold);cursor:pointer;transition:border-color var(--transition-fast),color var(--transition-fast),background var(--transition-fast)}.btn-explore-more:hover{border-color:var(--color-violet-500);color:var(--text-brand);background:#7c3aed0a}.btn-explore-more:focus-visible{outline:2px solid var(--border-focus);outline-offset:2px}@media(min-width:640px){.student-dashboard{padding:var(--space-6)}.welcome-hero{padding:var(--space-10) var(--space-10)}.hero-text h1{font-size:var(--text-4xl)}.hero-text p{font-size:var(--text-lg)}.clc-course-row{flex-direction:row;align-items:center}.clc-course-info{flex:1}}@media(min-width:1024px){.student-dashboard{padding:var(--space-8);padding-bottom:var(--space-16)}.welcome-hero{padding:var(--space-12) var(--space-12)}.hero-inner{flex-direction:row;justify-content:space-between;align-items:center}.hero-text{text-align:left;max-width:60%}.hero-text h1{font-size:var(--text-5xl)}.hero-stats{justify-content:flex-start}.hero-globe-wrap{display:flex;align-items:center;justify-content:center;width:16rem;height:16rem;background:var(--glass-bg-medium);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border:1px solid var(--glass-border);border-radius:var(--radius-full);position:relative;flex-shrink:0}.hero-globe-emoji{font-size:6rem;filter:drop-shadow(0 4px 24px rgba(0,0,0,.2));animation:globe-float 4s ease-in-out infinite}@keyframes globe-float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}@media(prefers-reduced-motion:reduce){.hero-globe-emoji{animation:none}}.hero-orbit{position:absolute;border:1px solid var(--glass-border-light);border-radius:var(--radius-full);animation:orbit-spin 25s linear infinite}.hero-orbit--outer{width:100%;height:100%;animation-duration:25s}.hero-orbit--inner{width:70%;height:70%;animation-duration:18s;animation-direction:reverse}@media(prefers-reduced-motion:reduce){.hero-orbit{animation:none}}@keyframes orbit-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.hero-orbit-flag{position:absolute;font-size:1.5rem;filter:drop-shadow(0 2px 4px rgba(0,0,0,.2))}.hero-orbit--outer .hero-orbit-flag{top:-1.25rem;left:50%;transform:translate(-50%)}.hero-orbit--inner .hero-orbit-flag{top:50%;left:-1.25rem;transform:translateY(-50%)}.dashboard-main-grid{display:grid;grid-template-columns:1.6fr 1fr;gap:var(--space-10);align-items:start}}.teacher-dashboard{display:flex;min-height:100%;background-color:var(--bg-page)}.teacher-sidebar{display:none}@media(min-width:768px){.teacher-sidebar{display:flex;flex-direction:column;width:var(--sidebar-width);min-height:100vh;background:var(--bg-secondary);border-right:1px solid var(--border-subtle);padding:var(--space-6);gap:var(--space-8);position:sticky;top:var(--header-height);height:calc(100vh - var(--header-height));overflow-y:auto;flex-shrink:0}}.teacher-sidebar-brand{display:flex;align-items:center;gap:var(--space-3)}.teacher-sidebar-logo{width:40px;height:40px;border-radius:var(--radius-xl);background:var(--gradient-brand);display:flex;align-items:center;justify-content:center;color:#fff;font-size:20px;flex-shrink:0}.teacher-sidebar-brand-text{display:flex;flex-direction:column}.teacher-sidebar-brand-name{font-size:var(--text-base);font-weight:var(--font-bold);color:var(--text-primary);line-height:var(--leading-tight)}.teacher-sidebar-brand-sub{font-size:var(--text-xs);color:var(--text-tertiary)}.teacher-sidebar-nav{flex:1;display:flex;flex-direction:column;gap:var(--space-1)}.teacher-sidebar-link{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-radius:var(--radius-xl);border:none;background:none;color:var(--text-secondary);font-size:var(--text-base);font-weight:var(--font-medium);cursor:pointer;text-align:left;transition:background-color var(--transition-fast),color var(--transition-fast),transform var(--transition-fast),box-shadow var(--transition-fast);min-height:44px;width:100%;text-decoration:none}.teacher-sidebar-link:hover{background:#ffffff80;transform:translate(4px);color:var(--text-primary)}.teacher-sidebar-link:focus-visible{outline:2px solid var(--border-focus);outline-offset:2px}.teacher-sidebar-link--active{background:var(--bg-card);color:var(--text-brand);font-weight:var(--font-semibold);box-shadow:var(--shadow-sm)}.teacher-sidebar-link-icon{font-size:20px;flex-shrink:0}.teacher-sidebar-footer{display:flex;flex-direction:column;gap:var(--space-4)}.teacher-sidebar-cta{width:100%;display:flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);border-radius:var(--radius-xl);border:none;background:var(--gradient-brand);color:#fff;font-size:var(--text-base);font-weight:var(--font-semibold);cursor:pointer;box-shadow:0 4px 0 var(--color-violet-700);transition:transform var(--transition-fast),box-shadow var(--transition-fast);min-height:44px}.teacher-sidebar-cta:hover{transform:translateY(-2px);box-shadow:0 6px 0 var(--color-violet-700)}.teacher-sidebar-cta:active{transform:translateY(1px);box-shadow:0 2px 0 var(--color-violet-700)}.teacher-sidebar-divider{border:none;border-top:1px solid var(--border-subtle);margin:0}.teacher-sidebar-meta-links{display:flex;flex-direction:column;gap:var(--space-1)}.teacher-sidebar-meta-link{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-4);border-radius:var(--radius-lg);border:none;background:none;font-size:var(--text-sm);color:var(--text-secondary);cursor:pointer;transition:color var(--transition-fast);min-height:44px;width:100%;text-align:left;text-decoration:none}.teacher-sidebar-meta-link:hover{color:var(--text-primary)}.teacher-sidebar-meta-link--danger:hover{color:var(--color-red-500)}.teacher-main{flex:1;display:flex;flex-direction:column;min-width:0;padding:var(--space-8) var(--space-8) var(--space-12)}@media(max-width:767px){.teacher-main{padding:var(--space-6) var(--space-4) var(--space-12)}}.teacher-content{max-width:1024px;margin:0 auto;width:100%;display:flex;flex-direction:column;gap:var(--space-8)}.teacher-hero{position:relative;overflow:hidden;border-radius:var(--radius-2xl);background:var(--gradient-brand);padding:var(--space-10);color:#fff;box-shadow:0 20px 40px #2d2e370f}.teacher-hero-blob{position:absolute;top:-6rem;right:-6rem;width:16rem;height:16rem;background:#ffffff1a;border-radius:var(--radius-full);filter:blur(3rem);pointer-events:none;transition:transform .7s ease}.teacher-hero:hover .teacher-hero-blob{transform:scale(1.1)}.teacher-hero-inner{position:relative;z-index:1;display:flex;flex-direction:column;gap:var(--space-8)}@media(min-width:768px){.teacher-hero-inner{flex-direction:row;align-items:flex-end;justify-content:space-between}}.teacher-hero-body{max-width:36rem}.teacher-hero-badge{display:inline-flex;align-items:center;gap:var(--space-2);background:var(--glass-bg-medium);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);color:#fff;font-size:var(--text-sm);font-weight:var(--font-semibold);padding:var(--space-1) var(--space-4);border-radius:var(--radius-full);margin-bottom:var(--space-4)}.teacher-hero-title{font-size:var(--text-4xl);font-weight:var(--font-extrabold);line-height:var(--leading-tight);letter-spacing:var(--tracking-tight);color:#fff;margin:0 0 var(--space-3) 0}@media(min-width:768px){.teacher-hero-title{font-size:var(--text-5xl)}}.teacher-hero-subtitle{font-size:var(--text-lg);font-weight:var(--font-medium);color:var(--color-violet-300);margin:0;opacity:.95}.teacher-hero-actions{display:flex;flex-wrap:wrap;gap:var(--space-4);flex-shrink:0}.teacher-btn-hero-solid{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-8);border-radius:var(--radius-xl);border:none;background:var(--bg-card);color:var(--text-brand);font-size:var(--text-base);font-weight:var(--font-bold);cursor:pointer;box-shadow:0 20px 40px #2d2e370f;transition:transform var(--transition-fast);min-height:44px}.teacher-btn-hero-solid:hover{transform:translateY(-3px)}.teacher-btn-hero-solid:active{transform:translateY(1px)}.teacher-btn-hero-tint{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-8);border-radius:var(--radius-xl);border:1px solid var(--glass-border);background:var(--glass-bg-heavy);color:#fff;font-size:var(--text-base);font-weight:var(--font-bold);cursor:pointer;transition:background-color var(--transition-fast);min-height:44px}.teacher-btn-hero-tint:hover{background:var(--glass-bg-medium);color:#fff}.teacher-placeholder{background:var(--bg-card);border-radius:var(--radius-2xl);border:1px solid var(--border-subtle);padding:var(--space-12) var(--space-10);box-shadow:0 20px 40px #2d2e370f;display:flex;flex-direction:column;align-items:center;text-align:center;position:relative;overflow:hidden}.teacher-placeholder-watermark{position:absolute;bottom:-5rem;left:-5rem;opacity:.04;font-size:300px;pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none;line-height:1;color:var(--text-primary)}.teacher-placeholder-icon-wrap{width:96px;height:96px;background:var(--bg-secondary);border-radius:var(--radius-3xl);display:flex;align-items:center;justify-content:center;margin-bottom:var(--space-8);color:var(--text-brand);font-size:48px}.teacher-placeholder-title{font-size:var(--text-3xl);font-weight:var(--font-extrabold);color:var(--text-primary);margin:0 0 var(--space-4) 0}.teacher-placeholder-phase-badge{display:inline-block;padding:var(--space-1) var(--space-4);border-radius:var(--radius-full);background:var(--status-warning-bg);color:var(--status-warning-text);font-size:var(--text-sm);font-weight:var(--font-bold);margin-bottom:var(--space-6)}.teacher-placeholder-desc{font-size:var(--text-lg);color:var(--text-secondary);line-height:var(--leading-relaxed);max-width:40rem;margin:0 0 var(--space-10) 0}.teacher-feature-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-6);width:100%;text-align:left}.teacher-feature-card{background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-2xl);padding:var(--space-6)}.teacher-feature-icon{font-size:28px;color:var(--text-brand);margin-bottom:var(--space-3);display:block}.teacher-feature-name{font-size:var(--text-base);font-weight:var(--font-bold);color:var(--text-primary);margin:0 0 var(--space-2) 0}.teacher-feature-desc{font-size:var(--text-xs);color:var(--text-secondary);line-height:var(--leading-relaxed);margin:0}.teacher-placeholder-footnote{display:flex;align-items:center;gap:var(--space-2);margin-top:var(--space-10);color:var(--text-tertiary);font-size:var(--text-sm);font-weight:var(--font-medium)}@media(max-width:640px){.teacher-hero{padding:var(--space-8) var(--space-6)}.teacher-hero-title{font-size:var(--text-3xl)}.teacher-hero-subtitle{font-size:var(--text-base)}.teacher-placeholder{padding:var(--space-8) var(--space-6)}.teacher-feature-grid{grid-template-columns:1fr}}.ps-page{min-height:100vh;background-color:var(--bg-page);padding:var(--space-6) var(--space-4) var(--space-16)}.ps-page-inner{max-width:720px;margin:0 auto;display:flex;flex-direction:column;gap:var(--space-6)}@media(min-width:768px){.ps-page{padding:var(--space-8) var(--space-6) var(--space-12)}}.ps-visually-hidden{position:absolute;width:1px;height:1px;margin:-1px;padding:0;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.ps-section-card{background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--radius-2xl);box-shadow:var(--card-shadow);padding:var(--space-6);display:flex;flex-direction:column;gap:var(--space-6);transition:box-shadow var(--transition-fast)}.ps-section-title{font-family:var(--font-heading);font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--text-primary);margin:0;padding-bottom:var(--space-4);border-bottom:1px solid var(--border-default)}.ps-profile-header{background:var(--gradient-brand);border-radius:var(--radius-2xl);box-shadow:var(--shadow-brand);padding:var(--space-8) var(--space-6);display:flex;flex-direction:column;align-items:center;gap:var(--space-4);text-align:center;position:relative;color:var(--text-inverse)}@media(min-width:640px){.ps-profile-header{flex-direction:row;text-align:left;align-items:flex-start}}.ps-avatar{width:96px;height:96px;border-radius:var(--radius-full);background:#fff3;border:3px solid rgba(255,255,255,.5);display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:var(--shadow-lg)}.ps-avatar-initial{font-size:var(--text-4xl);font-weight:var(--font-bold);color:#fff;line-height:1;-webkit-user-select:none;-moz-user-select:none;user-select:none}.ps-profile-header-info{display:flex;flex-direction:column;gap:var(--space-2);flex:1}.ps-display-name{font-size:clamp(var(--text-xl),4vw,var(--text-2xl));font-weight:var(--font-bold);color:#fff;margin:0;line-height:var(--leading-tight)}.ps-email{font-size:var(--text-sm);color:#fffc;margin:0}.ps-role-badge{display:inline-flex;align-items:center;padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--font-semibold);letter-spacing:var(--tracking-wide);text-transform:uppercase;width:-moz-fit-content;width:fit-content}.ps-role-badge--student{background:#ffffff40;color:#fff;border:1px solid rgba(255,255,255,.4)}.ps-role-badge--teacher{background:#10b9814d;color:#fff;border:1px solid rgba(16,185,129,.5)}.ps-role-badge--admin{background:#f59e0b4d;color:#fff;border:1px solid rgba(245,158,11,.5)}.ps-edit-btn{align-self:flex-start;flex-shrink:0;background:#ffffff26!important;border-color:#fff6!important;color:#fff!important}.ps-edit-btn:hover{background:#ffffff40!important}.ps-profile-form{display:flex;flex-direction:column;gap:var(--space-4)}.ps-form-group{display:flex;flex-direction:column;gap:var(--space-2)}.ps-form-label{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-primary);display:flex;align-items:center;gap:var(--space-2);cursor:pointer}.ps-form-readonly-badge{font-size:var(--text-xs);font-weight:var(--font-normal);color:var(--text-tertiary);background:var(--bg-tertiary);border:1px solid var(--border-default);padding:1px var(--space-2);border-radius:var(--radius-full)}.ps-form-optional{font-size:var(--text-xs);color:var(--text-tertiary);font-weight:var(--font-normal)}.ps-form-input,.ps-form-select,.ps-form-textarea{font-family:var(--font-primary);font-size:var(--text-base);color:var(--text-primary);background:var(--input-bg);border:1.5px solid var(--input-border);border-radius:var(--input-radius);padding:var(--space-3) var(--space-4);width:100%;box-sizing:border-box;transition:border-color var(--transition-fast),box-shadow var(--transition-fast);-webkit-appearance:none;-moz-appearance:none;appearance:none;min-height:44px}.ps-form-select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--space-4) center;padding-right:var(--space-10);cursor:pointer}.ps-form-textarea{resize:vertical;min-height:88px;line-height:var(--leading-normal)}.ps-form-input:focus-visible,.ps-form-select:focus-visible,.ps-form-textarea:focus-visible{outline:2px solid var(--border-focus);outline-offset:0;border-color:var(--border-focus);box-shadow:0 0 0 3px var(--input-focus-ring)}.ps-form-input--error,.ps-form-input--error:focus-visible{border-color:var(--color-red-500);box-shadow:0 0 0 3px #ef444426}.ps-form-input--readonly{opacity:.65;cursor:not-allowed;color:var(--text-secondary)}.ps-form-input:disabled,.ps-form-select:disabled,.ps-form-textarea:disabled{opacity:.6;cursor:not-allowed}.ps-form-error{font-size:var(--text-xs);color:var(--status-error-text);margin:0;display:flex;align-items:flex-start;gap:var(--space-1)}.ps-form-hint{font-size:var(--text-xs);color:var(--text-tertiary);margin:0;line-height:var(--leading-relaxed)}.ps-char-counter{text-align:right}.ps-form-actions{display:flex;gap:var(--space-3);flex-wrap:wrap;padding-top:var(--space-2)}.ps-btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-6);border-radius:var(--radius-xl);font-family:var(--font-primary);font-size:var(--text-sm);font-weight:var(--font-semibold);cursor:pointer;border:1.5px solid transparent;min-height:44px;min-width:44px;text-decoration:none;transition:transform var(--transition-fast),box-shadow var(--transition-fast),background-color var(--transition-fast),border-color var(--transition-fast),color var(--transition-fast);white-space:nowrap}.ps-btn:focus-visible{outline:2px solid var(--border-focus);outline-offset:2px}.ps-btn:active{transform:translateY(1px)}.ps-btn--primary{background:var(--btn-primary-bg);color:var(--btn-primary-text);box-shadow:var(--btn-primary-shadow)}.ps-btn--primary:hover:not(:disabled){background:var(--btn-primary-hover);transform:translateY(-2px);box-shadow:var(--shadow-brand)}.ps-btn--secondary{background:var(--bg-secondary);color:var(--text-primary);border-color:var(--border-default)}.ps-btn--secondary:hover:not(:disabled){background:var(--bg-tertiary);border-color:var(--border-strong)}.ps-btn--danger{background:var(--color-red-600);color:#fff;border-color:transparent}.ps-btn--danger:hover:not(:disabled){background:var(--color-red-500);transform:translateY(-2px);box-shadow:var(--shadow-error)}.ps-btn--danger:disabled,.ps-btn--danger[aria-disabled=true]{opacity:.45;cursor:not-allowed;transform:none}.ps-btn--sm{padding:var(--space-2) var(--space-4);font-size:var(--text-xs);min-height:36px}.ps-toggles-list{display:flex;flex-direction:column;gap:var(--space-1)}.ps-toggle-row{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);padding:var(--space-3) 0;border-bottom:1px solid var(--border-subtle);min-height:44px}.ps-toggle-row:last-child{border-bottom:none}.ps-toggle-label{font-size:var(--text-sm);color:var(--text-primary);font-weight:var(--font-medium);cursor:pointer;flex:1}.ps-toggle-btn{position:relative;width:48px;height:28px;border:none;border-radius:var(--radius-full);background:var(--border-strong);cursor:pointer;flex-shrink:0;padding:0;transition:background-color var(--transition-fast)}.ps-toggle-btn--on{background:var(--color-violet-600)}.ps-toggle-btn:focus-visible{outline:2px solid var(--border-focus);outline-offset:2px}.ps-toggle-thumb{position:absolute;top:3px;left:3px;width:22px;height:22px;border-radius:var(--radius-full);background:#fff;box-shadow:var(--shadow-sm);transition:transform var(--transition-fast)}.ps-toggle-btn--on .ps-toggle-thumb{transform:translate(20px)}.ps-xp-goal-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-3)}@media(min-width:480px){.ps-xp-goal-grid{grid-template-columns:repeat(4,1fr)}}.ps-xp-card{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-1);padding:var(--space-4) var(--space-3);background:var(--bg-secondary);border:2px solid var(--border-default);border-radius:var(--radius-xl);cursor:pointer;transition:border-color var(--transition-fast),background-color var(--transition-fast),transform var(--transition-fast),box-shadow var(--transition-fast);min-height:90px;text-align:center}.ps-xp-card:hover{background:var(--bg-tertiary);border-color:var(--border-focus);transform:translateY(-2px)}.ps-xp-card:focus-visible{outline:2px solid var(--border-focus);outline-offset:2px}.ps-xp-card--selected{border-color:var(--color-violet-500);background:var(--bg-secondary);box-shadow:0 0 0 3px var(--input-focus-ring),var(--shadow-brand)}.ps-xp-card-value{font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--text-brand);line-height:1}.ps-xp-card--selected .ps-xp-card-value{color:var(--color-violet-600)}.ps-xp-card-unit{font-size:var(--text-xs);color:var(--text-secondary);font-weight:var(--font-medium)}.ps-xp-card-label{font-size:var(--text-xs);color:var(--text-tertiary);font-weight:var(--font-medium)}.ps-xp-card--selected .ps-xp-card-label{color:var(--text-brand);font-weight:var(--font-semibold)}.ps-appearance-row{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);flex-wrap:wrap}.ps-stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-4)}@media(min-width:480px){.ps-stats-grid{grid-template-columns:repeat(4,1fr)}}.ps-stat-card{display:flex;flex-direction:column;align-items:center;gap:var(--space-2);padding:var(--space-5) var(--space-4);background:var(--bg-secondary);border:1px solid var(--border-default);border-radius:var(--radius-xl);text-align:center;transition:transform var(--transition-fast),box-shadow var(--transition-fast)}.ps-stat-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}.ps-stat-icon{font-size:var(--text-2xl);line-height:1}.ps-stat-value{font-size:var(--text-xl);font-weight:var(--font-bold);color:var(--text-primary);line-height:1}.ps-stat-label{font-size:var(--text-xs);color:var(--text-secondary);font-weight:var(--font-medium);line-height:var(--leading-snug)}.ps-badges-row{display:flex;gap:var(--space-4);overflow-x:auto;padding-bottom:var(--space-3);list-style:none;margin:0;padding-left:0;scroll-behavior:smooth;-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:var(--border-default) transparent}.ps-badges-row::-webkit-scrollbar{height:4px}.ps-badges-row::-webkit-scrollbar-track{background:transparent}.ps-badges-row::-webkit-scrollbar-thumb{background:var(--border-default);border-radius:var(--radius-full)}.ps-badges-row li{display:flex;flex-direction:column;align-items:center;gap:var(--space-2);flex-shrink:0}.ps-badge{width:60px;height:60px;border-radius:var(--radius-full);background:var(--gradient-brand);display:flex;align-items:center;justify-content:center;font-size:var(--text-2xl);box-shadow:var(--shadow-md);cursor:default;transition:transform var(--transition-fast),box-shadow var(--transition-fast);border:2px solid transparent}.ps-badge:hover{transform:translateY(-3px) scale(1.05);box-shadow:var(--shadow-xl)}.ps-badge--locked{background:var(--bg-tertiary);box-shadow:none;border:2px dashed var(--border-default);opacity:.5}.ps-badge--locked:hover{transform:none;box-shadow:none}.ps-badge-name{font-size:var(--text-xs);color:var(--text-secondary);text-align:center;max-width:70px;line-height:var(--leading-tight);white-space:normal}.ps-subsection{display:flex;flex-direction:column;gap:var(--space-4);padding-top:var(--space-2)}.ps-subsection+.ps-subsection{padding-top:var(--space-4);border-top:1px solid var(--border-subtle)}.ps-subsection--inline{flex-direction:row;align-items:flex-start;justify-content:space-between;gap:var(--space-4);flex-wrap:wrap}.ps-subsection-title{font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--text-primary);margin:0}.ps-subsection-label{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--text-secondary);margin:0;text-transform:uppercase;letter-spacing:var(--tracking-wider)}.ps-connected-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:var(--space-1)}.ps-connected-item{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);padding:var(--space-3) var(--space-4);background:var(--bg-secondary);border:1px solid var(--border-default);border-radius:var(--radius-lg);min-height:60px}.ps-connected-info{display:flex;align-items:center;gap:var(--space-3)}.ps-connected-icon{width:36px;height:36px;border-radius:var(--radius-md);background:var(--btn-primary-bg);color:#fff;display:flex;align-items:center;justify-content:center;font-size:var(--text-base);font-weight:var(--font-bold);flex-shrink:0}.ps-connected-icon--github{background:var(--color-neutral-800)}[data-theme=dark] .ps-connected-icon--github{background:var(--color-neutral-600)}.ps-connected-name{display:block;font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--text-primary)}.ps-connected-status{display:block;font-size:var(--text-xs);font-weight:var(--font-medium)}.ps-connected-status--on{color:var(--status-success-text)}.ps-connected-status--off{color:var(--text-tertiary)}.ps-divider{border:none;border-top:1px solid var(--border-default);margin:0}.ps-danger-zone{background:var(--status-error-bg);border:1px solid var(--status-error-border);border-radius:var(--radius-xl);padding:var(--space-4);margin-top:var(--space-4)}.ps-danger-title{color:var(--status-error-text)}.ps-link{display:inline-flex;align-items:center;gap:var(--space-1);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-brand);text-decoration:none;transition:color var(--transition-fast),-webkit-text-decoration var(--transition-fast);transition:color var(--transition-fast),text-decoration var(--transition-fast);transition:color var(--transition-fast),text-decoration var(--transition-fast),-webkit-text-decoration var(--transition-fast)}.ps-link:hover{text-decoration:underline}.ps-link:focus-visible{outline:2px solid var(--border-focus);outline-offset:2px;border-radius:var(--radius-sm)}.ps-link--subtle{color:var(--text-secondary)}.ps-link--subtle:hover{color:var(--text-brand)}.ps-toast{position:fixed;bottom:calc(var(--bottom-nav-height) + var(--space-4));left:50%;transform:translate(-50%);display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4) var(--space-5);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);font-size:var(--text-sm);font-weight:var(--font-medium);max-width:calc(100vw - var(--space-8));z-index:var(--z-modal);animation:ps-toast-in var(--transition-bounce) forwards;white-space:nowrap}@media(min-width:640px){.ps-toast{bottom:var(--space-6);left:auto;right:var(--space-6);transform:none}}.ps-toast--success{background:var(--status-success-bg);color:var(--status-success-text);border:1px solid var(--status-success-border)}.ps-toast--error{background:var(--status-error-bg);color:var(--status-error-text);border:1px solid var(--status-error-border)}.ps-toast-icon{font-size:var(--text-base);font-weight:var(--font-bold);flex-shrink:0}.ps-toast-message{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis}.ps-toast-close{background:none;border:none;cursor:pointer;font-size:var(--text-xl);line-height:1;color:inherit;opacity:.7;padding:0;min-height:24px;min-width:24px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.ps-toast-close:hover{opacity:1}.ps-toast-close:focus-visible{outline:2px solid currentColor;outline-offset:2px;border-radius:var(--radius-sm)}@keyframes ps-toast-in{0%{opacity:0;transform:translate(-50%) translateY(12px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@media(min-width:640px){@keyframes ps-toast-in{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}}.ps-dialog-backdrop{position:fixed;inset:0;background:var(--bg-overlay-heavy);display:flex;align-items:center;justify-content:center;padding:var(--space-6);z-index:var(--z-modal-backdrop);animation:ps-fade-in .2s ease forwards}.ps-dialog{background:var(--bg-card);border:1px solid var(--border-default);border-radius:var(--radius-2xl);box-shadow:var(--shadow-2xl);padding:var(--space-8) var(--space-6);max-width:480px;width:100%;display:flex;flex-direction:column;gap:var(--space-5);z-index:var(--z-modal);animation:ps-slide-up var(--transition-bounce) forwards}.ps-dialog-icon{font-size:var(--text-4xl);text-align:center;line-height:1}.ps-dialog-title{font-size:var(--text-xl);font-weight:var(--font-bold);color:var(--status-error-text);text-align:center;margin:0}.ps-dialog-desc{font-size:var(--text-sm);color:var(--text-secondary);text-align:center;margin:0;line-height:var(--leading-relaxed)}.ps-dialog-confirm-field{display:flex;flex-direction:column;gap:var(--space-2)}.ps-dialog-actions{display:flex;gap:var(--space-3);flex-wrap:wrap;justify-content:flex-end}.ps-empty-state{display:flex;flex-direction:column;align-items:center;gap:var(--space-3);padding:var(--space-8) var(--space-4);text-align:center;color:var(--text-secondary);font-size:var(--text-sm)}.ps-empty-icon{font-size:var(--text-4xl);line-height:1}.ps-skeleton--header{display:flex;gap:var(--space-5);align-items:center;background:var(--card-bg);border-radius:var(--radius-2xl);padding:var(--space-8) var(--space-6);box-shadow:var(--card-shadow)}.ps-skeleton--card{background:var(--card-bg);border-radius:var(--radius-2xl);padding:var(--space-6);box-shadow:var(--card-shadow);display:flex;flex-direction:column;gap:var(--space-4)}.ps-skeleton-circle{width:96px;height:96px;border-radius:var(--radius-full);background:var(--bg-tertiary);flex-shrink:0;animation:ps-shimmer 1.5s ease-in-out infinite}.ps-skeleton-lines{flex:1;display:flex;flex-direction:column;gap:var(--space-3)}.ps-skeleton-line{height:16px;border-radius:var(--radius-full);background:var(--bg-tertiary);animation:ps-shimmer 1.5s ease-in-out infinite}.ps-skeleton-line--sm{width:40%}.ps-skeleton-line--md{width:60%}.ps-skeleton-line--lg{width:80%}@keyframes ps-shimmer{0%,to{opacity:1}50%{opacity:.4}}@keyframes ps-fade-in{0%{opacity:0}to{opacity:1}}@keyframes ps-slide-up{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@media(prefers-reduced-motion:reduce){.ps-toast,.ps-dialog-backdrop,.ps-dialog,.ps-skeleton-circle,.ps-skeleton-line,.ps-badge,.ps-xp-card,.ps-stat-card{animation:none!important;transition-duration:.01ms!important}}
