:root{--c-primary: #2bee7c;--c-primary-dark: #1fa85a;--c-primary-bg: #e8fcf2;--c-accent: #7f13ec;--c-accent-dark: #6b11c9;--c-accent-bg: #f2e7fe;--c-gold: #ffb703;--c-gold-bg: #fff8e1;--c-success: #22c55e;--c-success-bg: #f0fdf4;--c-warning: #f59e0b;--c-warning-bg: #fffbeb;--c-error: #ef4444;--c-error-bg: #fef2f2;--c-info: #3b82f6;--c-info-bg: #eff6ff;--c-math: #22c55e;--c-math-bg: #f0fdf4;--c-lithuanian: #3b82f6;--c-lithuanian-bg: #eff6ff;--c-science: #14b8a6;--c-science-bg: #f0fdfa;--c-history: #f59e0b;--c-history-bg: #fffbeb;--c-art: #a855f7;--c-art-bg: #faf5ff;--c-white: #ffffff;--c-bg: #f6f8f7;--c-surface: #ffffff;--c-border: #e2e8e5;--c-border-light: #eef2f0;--c-text: #111814;--c-text-secondary:#618972;--c-text-inv: #ffffff;--c-purple: var(--c-accent);--c-purple-light: #a78bfa;--c-purple-bg: var(--c-accent-bg);--c-green: var(--c-success);--c-green-light: #86efac;--c-green-bg: var(--c-success-bg);--c-blue: var(--c-info);--c-blue-light: #93c5fd;--c-blue-bg: var(--c-info-bg);--c-red: var(--c-error);--c-red-light: #fca5a5;--c-red-bg: var(--c-error-bg);--c-orange: #f97316;--c-orange-light: #fdba74;--c-orange-bg: #fff7ed;--c-yellow: var(--c-gold);--c-yellow-light: #fef08a;--c-yellow-bg: var(--c-gold-bg);--c-teal: var(--c-science);--c-teal-light: #5eead4;--c-teal-bg: var(--c-science-bg);--c-pink: #ec4899;--c-pink-light: #f9a8d4;--c-pink-bg: #fce7f3;--c-text-light: var(--c-text-secondary);--font-display: "Lexend", sans-serif;--font-body: "Lexend", sans-serif;--fs-xs: .75rem;--fs-sm: .875rem;--fs-base: 1rem;--fs-md: 1.125rem;--fs-lg: 1.375rem;--fs-xl: 1.75rem;--fs-2xl: 2.25rem;--fs-3xl: 3rem;--fs-4xl: 3.5rem;--fw-regular: 400;--fw-medium: 500;--fw-semi: 600;--fw-bold: 700;--fw-extra: 800;--fw-black: 900;--lh-tight: 1.2;--lh-normal: 1.5;--lh-loose: 1.75;--sp-1: 4px;--sp-2: 8px;--sp-3: 12px;--sp-4: 16px;--sp-5: 20px;--sp-6: 24px;--sp-8: 32px;--sp-10: 40px;--sp-12: 48px;--sp-16: 64px;--sp-20: 80px;--r-sm: 8px;--r-md: 12px;--r-lg: 16px;--r-xl: 24px;--r-2xl: 32px;--r-full: 9999px;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .04);--shadow-card: 0 0 0 1px rgba(0, 0, 0, .03), 0 2px 8px rgba(0, 0, 0, .04);--shadow-soft: 0 4px 20px -2px rgba(0, 0, 0, .05);--shadow-lg: 0 10px 40px -10px rgba(0, 0, 0, .08);--shadow-btn: 0 4px 0 0 var(--c-primary-dark);--shadow-glow: 0 0 15px rgba(43, 238, 124, .3);--shadow-pop: 0 6px 0 rgba(0, 0, 0, .08);--shadow-md: var(--shadow-card);--ease-bounce: cubic-bezier(.34, 1.56, .64, 1);--ease-smooth: cubic-bezier(.4, 0, .2, 1);--dur-fast: .15s;--dur-norm: .25s;--dur-slow: .4s}html.dark{--c-bg: #102218;--c-surface: #1a2c22;--c-border: #2d4a3a;--c-border-light: #243d30;--c-text: #f0f4f2;--c-text-secondary:#9ab3a4;--c-shadow-card: 0 0 0 1px rgba(255,255,255,.04), 0 2px 8px rgba(0,0,0,.2)}html[data-role=parent]{--c-primary: #308ce8;--c-primary-dark: #2563eb;--c-primary-bg: #eff6ff;--shadow-btn: 0 4px 0 0 var(--c-primary-dark);--shadow-glow: 0 0 15px rgba(48, 140, 232, .3)}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes ping{75%,to{transform:scale(2);opacity:0}}[data-theme=grade-1-4]{--c-purple: #f97316;--c-purple-light: #fdba74;--c-purple-bg: #fff7ed;--c-pink: #f43f5e;--c-pink-light: #fda4af;--c-pink-bg: #fff1f2;--c-orange: #eab308;--c-orange-light: #fde047;--c-orange-bg: #fefce8;--c-green: #22c55e;--c-green-light: #86efac;--c-green-bg: #f0fdf4;--c-blue: #06b6d4;--c-blue-light: #67e8f9;--c-blue-bg: #ecfeff;--c-yellow: #f59e0b;--c-yellow-light: #fcd34d;--c-yellow-bg: #fffbeb;--c-red: #ef4444;--c-red-light: #fca5a5;--c-red-bg: #fef2f2;--c-teal: #10b981;--c-teal-light: #6ee7b7;--c-teal-bg: #ecfdf5;--c-bg: #fffbf5;--c-surface: #ffffff;--c-border: #fde6c8;--c-text: #4a2c0a;--c-text-light: #9a7249;--c-text-inv: #ffffff;--font-display: "Fredoka", "Nunito", sans-serif;--font-body: "Nunito", sans-serif;--fs-xs: .8rem;--fs-sm: .95rem;--fs-base: 1.1rem;--fs-md: 1.25rem;--fs-lg: 1.5rem;--fs-xl: 2rem;--fs-2xl: 2.5rem;--fs-3xl: 3.25rem;--r-sm: 12px;--r-md: 18px;--r-lg: 26px;--r-xl: 34px;--shadow-sm: 0 2px 8px rgba(249, 115, 22, .1);--shadow-md: 0 4px 16px rgba(249, 115, 22, .14);--shadow-lg: 0 8px 32px rgba(249, 115, 22, .18);--shadow-pop: 0 6px 0 rgba(0, 0, 0, .1)}[data-theme=grade-1-4] .lw-header{background:linear-gradient(135deg,#f97316,#f43f5e)}[data-theme=grade-1-4] .progress__fill{background:linear-gradient(90deg,#f97316,#f43f5e)}[data-theme=grade-1-4] .ds-section__title{background:linear-gradient(135deg,#f97316,#f43f5e);-webkit-background-clip:text;background-clip:text}[data-theme=grade-5-8]{--c-purple: #0d9488;--c-purple-light: #5eead4;--c-purple-bg: #f0fdfa;--c-pink: #8b5cf6;--c-pink-light: #c4b5fd;--c-pink-bg: #f5f3ff;--c-orange: #ea580c;--c-orange-light: #fb923c;--c-orange-bg: #fff7ed;--c-green: #16a34a;--c-green-light: #4ade80;--c-green-bg: #f0fdf4;--c-blue: #2563eb;--c-blue-light: #60a5fa;--c-blue-bg: #eff6ff;--c-yellow: #ca8a04;--c-yellow-light: #facc15;--c-yellow-bg: #fefce8;--c-red: #dc2626;--c-red-light: #f87171;--c-red-bg: #fef2f2;--c-teal: #0891b2;--c-teal-light: #22d3ee;--c-teal-bg: #ecfeff;--c-bg: #f0fdf8;--c-surface: #ffffff;--c-border: #c6f0e2;--c-text: #134e3e;--c-text-light: #4d7c6a;--c-text-inv: #ffffff;--font-display: "Fredoka", "Nunito", sans-serif;--font-body: "Nunito", sans-serif;--fs-xs: .75rem;--fs-sm: .875rem;--fs-base: 1rem;--fs-md: 1.125rem;--fs-lg: 1.375rem;--fs-xl: 1.75rem;--fs-2xl: 2.25rem;--fs-3xl: 3rem;--r-sm: 8px;--r-md: 12px;--r-lg: 18px;--r-xl: 24px;--shadow-sm: 0 2px 6px rgba(13, 148, 136, .08);--shadow-md: 0 4px 14px rgba(13, 148, 136, .12);--shadow-lg: 0 8px 28px rgba(13, 148, 136, .16);--shadow-pop: 0 5px 0 rgba(0, 0, 0, .08)}[data-theme=grade-5-8] .lw-header{background:linear-gradient(135deg,#0d9488,#2563eb)}[data-theme=grade-5-8] .progress__fill{background:linear-gradient(90deg,#0d9488,#22d3ee)}[data-theme=grade-5-8] .ds-section__title{background:linear-gradient(135deg,#0d9488,#2563eb);-webkit-background-clip:text;background-clip:text}[data-theme=grade-9-12]{--c-purple: #4338ca;--c-purple-light: #818cf8;--c-purple-bg: #eef2ff;--c-pink: #be185d;--c-pink-light: #f472b6;--c-pink-bg: #fdf2f8;--c-orange: #c2410c;--c-orange-light: #fb923c;--c-orange-bg: #fff7ed;--c-green: #15803d;--c-green-light: #4ade80;--c-green-bg: #f0fdf4;--c-blue: #1d4ed8;--c-blue-light: #60a5fa;--c-blue-bg: #eff6ff;--c-yellow: #a16207;--c-yellow-light: #fbbf24;--c-yellow-bg: #fefce8;--c-red: #b91c1c;--c-red-light: #f87171;--c-red-bg: #fef2f2;--c-teal: #0f766e;--c-teal-light: #2dd4bf;--c-teal-bg: #f0fdfa;--c-bg: #f8fafc;--c-surface: #ffffff;--c-border: #e2e8f0;--c-text: #1e293b;--c-text-light: #64748b;--c-text-inv: #ffffff;--font-display: "Nunito", sans-serif;--font-body: "Nunito", sans-serif;--fs-xs: .7rem;--fs-sm: .825rem;--fs-base: .95rem;--fs-md: 1.05rem;--fs-lg: 1.25rem;--fs-xl: 1.6rem;--fs-2xl: 2rem;--fs-3xl: 2.5rem;--lh-tight: 1.25;--lh-normal: 1.6;--lh-loose: 1.8;--r-sm: 6px;--r-md: 10px;--r-lg: 14px;--r-xl: 20px;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .06), 0 1px 2px rgba(0, 0, 0, .04);--shadow-md: 0 4px 6px rgba(0, 0, 0, .05), 0 2px 4px rgba(0, 0, 0, .04);--shadow-lg: 0 10px 25px rgba(0, 0, 0, .08), 0 4px 10px rgba(0, 0, 0, .04);--shadow-pop: 0 4px 0 rgba(0, 0, 0, .06);--ease-bounce: cubic-bezier(.25, 1, .5, 1);--dur-fast: .12s;--dur-norm: .2s;--dur-slow: .3s}[data-theme=grade-9-12] .lw-header{background:linear-gradient(135deg,#312e81,#4338ca)}[data-theme=grade-9-12] .progress__fill{background:linear-gradient(90deg,#4338ca,#818cf8)}[data-theme=grade-9-12] .ds-section__title{background:linear-gradient(135deg,#4338ca,#818cf8);-webkit-background-clip:text;background-clip:text}[data-theme=grade-9-12] .card:hover,[data-theme=grade-9-12] .lesson-card:hover{transform:translateY(-2px)}[data-theme=grade-9-12] .btn:active{transform:translateY(2px)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}img,svg{display:block;max-width:100%}button,input,textarea,select{font:inherit}html{scroll-behavior:smooth}body{font-family:var(--font-body);font-size:var(--fs-base);line-height:var(--lh-normal);color:var(--c-text);background:var(--c-bg);min-height:100vh;-webkit-font-smoothing:antialiased}a{color:var(--c-primary-dark);text-decoration:none;font-weight:var(--fw-semi)}a:hover{text-decoration:underline}h1,h2,h3,h4,h5{font-family:var(--font-display);line-height:var(--lh-tight);color:var(--c-text);letter-spacing:-.015em}h1{font-size:var(--fs-3xl);font-weight:var(--fw-black)}h2{font-size:var(--fs-2xl);font-weight:var(--fw-bold)}h3{font-size:var(--fs-xl);font-weight:var(--fw-bold)}h4{font-size:var(--fs-lg);font-weight:var(--fw-semi)}h5{font-size:var(--fs-md);font-weight:var(--fw-semi)}.material-symbols-outlined{font-variation-settings:"FILL" 0,"wght" 400,"GRAD" 0,"opsz" 24}.icon-filled,.material-symbols-outlined.filled{font-variation-settings:"FILL" 1,"wght" 400,"GRAD" 0,"opsz" 24}.animate-shimmer{background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.4) 50%,transparent 100%);background-size:200% 100%;animation:shimmer 2s infinite}.hide-scrollbar::-webkit-scrollbar{display:none}.hide-scrollbar{-ms-overflow-style:none;scrollbar-width:none}.app-shell{display:flex;flex-direction:column;min-height:100vh;height:100vh;overflow:hidden}.app-shell__body{display:flex;flex:1;overflow:hidden}.page-wrap{max-width:1200px;margin:0 auto;padding:var(--sp-8) var(--sp-6)}.lw-header{background:#fffc;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);color:var(--c-text);padding:0 var(--sp-8);height:80px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--c-border-light);position:sticky;top:0;z-index:100}.lw-header__logo{font-family:var(--font-display);font-size:var(--fs-xl);font-weight:var(--fw-black);display:flex;align-items:center;gap:var(--sp-3);color:var(--c-text);letter-spacing:-.015em}.lw-header__logo-icon{width:32px;height:32px;background:var(--c-primary);border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;color:var(--c-text-inv)}.lw-header__nav{display:flex;gap:var(--sp-4);margin-left:auto}.lw-header__nav a{color:var(--c-text-secondary);font-weight:var(--fw-medium);font-size:var(--fs-sm);padding:var(--sp-2) var(--sp-4);border-radius:var(--r-full);transition:all var(--dur-fast) var(--ease-smooth);text-decoration:none}.lw-header__nav a:hover{color:var(--c-text);background:var(--c-bg);text-decoration:none}.lw-header__nav a.active{color:var(--c-text);background:var(--c-primary-bg);font-weight:var(--fw-bold)}.lw-header__search{position:relative;width:100%;max-width:400px}.lw-header__search input{width:100%;padding:var(--sp-2) var(--sp-3) var(--sp-2) var(--sp-10);border:none;border-radius:var(--r-lg);background:var(--c-bg);color:var(--c-text);font-size:var(--fs-sm);font-weight:var(--fw-medium);transition:box-shadow var(--dur-fast) var(--ease-smooth)}.lw-header__search input::placeholder{color:var(--c-text-secondary)}.lw-header__search input:focus{outline:none;box-shadow:0 0 0 2px var(--c-primary-bg)}.lw-header__search-icon{position:absolute;left:var(--sp-3);top:50%;transform:translateY(-50%);color:var(--c-text-secondary);pointer-events:none}.lw-header__actions{display:flex;align-items:center;gap:var(--sp-4)}.currency-pill{display:flex;align-items:center;gap:var(--sp-2);padding:var(--sp-1) var(--sp-3);border-radius:var(--r-full);font-size:var(--fs-sm);font-weight:var(--fw-bold);border:1px solid}.currency-pill--gold{background:var(--c-gold-bg);border-color:#fde68a;color:#92400e}.currency-pill--blue{background:var(--c-info-bg);border-color:#bfdbfe;color:#1e40af}.currency-pill--streak{background:var(--c-orange-bg);border-color:#fed7aa;color:#9a3412}.notification-btn{position:relative;padding:var(--sp-2);border-radius:var(--r-lg);border:none;background:transparent;color:var(--c-text-secondary);cursor:pointer;transition:all var(--dur-fast) var(--ease-smooth)}.notification-btn:hover{background:var(--c-bg);color:var(--c-text)}.notification-btn__dot{position:absolute;top:var(--sp-2);right:var(--sp-2);width:8px;height:8px;background:var(--c-error);border-radius:50%;border:2px solid var(--c-surface)}.lw-sidebar{width:256px;background:var(--c-surface);border-right:1px solid var(--c-border-light);flex-shrink:0;display:flex;flex-direction:column;height:100%;overflow-y:auto;box-shadow:var(--shadow-soft);z-index:20}.lw-sidebar__header{padding:var(--sp-6);display:flex;align-items:center;gap:var(--sp-3)}.lw-sidebar__title{font-family:var(--font-display);font-size:var(--fs-xs);font-weight:var(--fw-bold);text-transform:uppercase;letter-spacing:.08em;color:var(--c-text-secondary);margin-bottom:var(--sp-3)}.lw-sidebar__list{list-style:none;display:flex;flex-direction:column;gap:var(--sp-1)}.lw-sidebar__item{padding:var(--sp-3) var(--sp-4);border-radius:var(--r-lg);font-weight:var(--fw-medium);cursor:pointer;transition:all var(--dur-fast) var(--ease-smooth);display:flex;align-items:center;gap:var(--sp-3)}.lw-sidebar__item:hover{background:var(--c-bg);color:var(--c-text);text-decoration:none}.lw-sidebar__item--active{background:var(--c-primary-bg);color:var(--c-primary-dark);font-weight:var(--fw-semi)}.lw-sidebar__item--active:hover{background:var(--c-primary-bg);color:var(--c-primary-dark);text-decoration:none}a.lw-sidebar__item{color:var(--c-text-secondary);text-decoration:none}a.lw-sidebar__item:hover{color:var(--c-text);text-decoration:none}a.lw-sidebar__item.lw-sidebar__item--active{color:var(--c-primary-dark)}.lw-sidebar__group{margin-bottom:var(--sp-1)}.lw-sidebar__grade{padding:var(--sp-3) var(--sp-4);border-radius:var(--r-lg);font-weight:var(--fw-bold);cursor:pointer;display:flex;align-items:center;gap:var(--sp-3);transition:all var(--dur-fast) var(--ease-smooth);-webkit-user-select:none;user-select:none}.lw-sidebar__grade:hover{background:var(--c-primary-bg);color:var(--c-primary-dark)}.lw-sidebar__grade--has-active{color:var(--c-primary-dark)}.lw-sidebar__grade-icon{flex-shrink:0}.lw-sidebar__grade-label{flex:1}.lw-sidebar__chevron{font-size:var(--fs-xs);transition:transform var(--dur-norm) var(--ease-smooth);color:var(--c-text-secondary)}.lw-sidebar__chevron--open{transform:rotate(90deg)}.lw-sidebar__subjects{display:none;flex-direction:column;gap:var(--sp-1);padding-left:var(--sp-4)}.lw-sidebar__subjects--open{display:flex}.lw-sidebar__subitem{font-size:var(--fs-sm);padding:var(--sp-2) var(--sp-3);font-weight:var(--fw-semi)}.lw-sidebar__loading{color:var(--c-text-secondary);font-size:var(--fs-sm)}.lw-sidebar__section{margin-top:var(--sp-8)}.lw-sidebar__user{margin-top:auto;padding:var(--sp-4)}.lw-sidebar__user-card{background:var(--c-bg);padding:var(--sp-4);border-radius:var(--r-lg);display:flex;align-items:center;gap:var(--sp-3);border:1px solid var(--c-border-light)}.lw-sidebar__avatar{width:40px;height:40px;border-radius:50%;object-fit:cover;border:2px solid var(--c-surface);box-shadow:var(--shadow-sm)}.lw-footer{background:var(--c-surface);border-top:1px solid var(--c-border-light);padding:var(--sp-5) var(--sp-8);text-align:center;font-size:var(--fs-sm);color:var(--c-text-secondary)}.lw-main{flex:1;padding:var(--sp-8);overflow-y:auto}.lw-mobile-nav{display:none;position:fixed;bottom:0;left:0;right:0;background:var(--c-surface);border-top:1px solid var(--c-border-light);padding:var(--sp-3) var(--sp-2);padding-bottom:env(safe-area-inset-bottom,var(--sp-3));z-index:30;justify-content:space-around}.lw-mobile-nav__item{display:flex;flex-direction:column;align-items:center;gap:2px;color:var(--c-text-secondary);text-decoration:none;font-size:10px;font-weight:var(--fw-medium);transition:color var(--dur-fast) var(--ease-smooth)}.lw-mobile-nav__item--active{color:var(--c-primary-dark)}@media (max-width: 767px){.lw-sidebar{display:none}.lw-mobile-nav{display:flex}.lw-header{height:64px;padding:0 var(--sp-4)}.lw-main{padding:var(--sp-4);padding-bottom:80px}}.progress-bar{width:100%;border-radius:var(--r-full);overflow:hidden;background:var(--c-border-light)}.progress-bar--sm{height:8px}.progress-bar--md{height:12px}.progress-bar--lg{height:24px}.progress-bar__fill{height:100%;border-radius:var(--r-full);background:var(--c-primary);position:relative;transition:width var(--dur-slow) var(--ease-smooth)}.leaderboard-row{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-3);border-radius:var(--r-lg);transition:background var(--dur-fast) var(--ease-smooth);cursor:pointer}.leaderboard-row:hover{background:var(--c-bg)}.leaderboard-row--me{background:var(--c-primary-bg);border:1px solid rgba(43,238,124,.2)}.leaderboard-row__rank{width:24px;text-align:center;font-weight:var(--fw-bold);font-size:var(--fs-sm)}.leaderboard-row__name{flex:1;font-weight:var(--fw-medium);font-size:var(--fs-sm)}.leaderboard-row__score{font-weight:var(--fw-bold);font-size:var(--fs-xs);color:var(--c-text-secondary)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--sp-2);padding:var(--sp-3) var(--sp-6);border:none;border-radius:var(--r-lg);font-family:var(--font-display);font-size:var(--fs-base);font-weight:var(--fw-bold);cursor:pointer;transition:all var(--dur-fast) var(--ease-smooth);position:relative;text-decoration:none;line-height:1}.btn:focus-visible{outline:3px solid var(--c-primary-bg);outline-offset:2px}.btn--primary{background:var(--c-primary);color:var(--c-text);box-shadow:var(--shadow-btn)}.btn--primary:hover{background:var(--c-primary-dark);box-shadow:0 2px 0 0 var(--c-primary-dark);transform:translateY(2px)}.btn--primary:active{box-shadow:none;transform:translateY(4px)}.btn--accent{background:var(--c-accent);color:var(--c-text-inv);box-shadow:0 4px 0 0 var(--c-accent-dark)}.btn--accent:hover{background:var(--c-accent-dark);box-shadow:0 2px 0 0 var(--c-accent-dark);transform:translateY(2px)}.btn--accent:active{box-shadow:none;transform:translateY(4px)}.btn--purple{background:var(--c-accent);color:var(--c-text-inv);box-shadow:0 4px 0 0 var(--c-accent-dark)}.btn--pink{background:var(--c-pink);color:var(--c-text-inv);box-shadow:var(--shadow-pop)}.btn--orange{background:var(--c-orange);color:var(--c-text-inv);box-shadow:var(--shadow-pop)}.btn--green{background:var(--c-success);color:var(--c-text-inv);box-shadow:var(--shadow-pop)}.btn--blue{background:var(--c-info);color:var(--c-text-inv);box-shadow:var(--shadow-pop)}.btn--yellow{background:var(--c-gold);color:var(--c-text);box-shadow:var(--shadow-pop)}.btn--red{background:var(--c-error);color:var(--c-text-inv);box-shadow:var(--shadow-pop)}.btn--teal{background:var(--c-science);color:var(--c-text-inv);box-shadow:var(--shadow-pop)}.btn--pink:active,.btn--orange:active,.btn--green:active,.btn--blue:active,.btn--yellow:active,.btn--red:active,.btn--teal:active{transform:translateY(3px);box-shadow:none}.btn--outline{background:transparent;border:2px solid var(--c-primary);color:var(--c-primary-dark);box-shadow:none}.btn--outline:hover{background:var(--c-primary);color:var(--c-text);border-color:var(--c-primary)}.btn--ghost{background:transparent;color:var(--c-primary-dark);box-shadow:none}.btn--ghost:hover{background:var(--c-primary-bg)}.btn--ghost:active{transform:none}.btn--soft{background:var(--c-primary-bg);color:var(--c-primary-dark);box-shadow:none}.btn--soft:hover{background:var(--c-primary);color:var(--c-text)}.btn--sm{padding:var(--sp-2) var(--sp-4);font-size:var(--fs-sm)}.btn--lg{padding:var(--sp-4) var(--sp-10);font-size:var(--fs-lg)}.btn--xl{padding:var(--sp-5) var(--sp-12);font-size:var(--fs-xl)}.btn--pill{border-radius:var(--r-full)}.btn--round{width:48px;height:48px;padding:0;border-radius:50%}.btn--round.btn--lg{width:64px;height:64px}.btn:disabled,.btn--disabled{background:var(--c-border);color:var(--c-text-secondary);box-shadow:none;cursor:not-allowed;transform:none}.card{background:var(--c-surface);border-radius:var(--r-xl);box-shadow:var(--shadow-card);padding:var(--sp-6);transition:all var(--dur-norm) var(--ease-smooth);border:1px solid var(--c-border-light);overflow:hidden}.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.card--purple{border-color:var(--c-purple-light);background:var(--c-accent-bg)}.card--pink{border-color:var(--c-pink-light);background:var(--c-pink-bg)}.card--orange{border-color:var(--c-orange-light);background:var(--c-orange-bg)}.card--green{border-color:var(--c-green-light);background:var(--c-success-bg)}.card--blue{border-color:var(--c-blue-light);background:var(--c-info-bg)}.card--teal{border-color:var(--c-teal-light);background:var(--c-science-bg)}.card--yellow{border-color:var(--c-yellow-light);background:var(--c-gold-bg)}.card--selected{outline:4px solid var(--c-primary);outline-offset:2px;box-shadow:var(--shadow-soft)}.card__icon{width:56px;height:56px;border-radius:var(--r-lg);display:flex;align-items:center;justify-content:center;font-size:1.8rem;margin-bottom:var(--sp-4);background:var(--c-surface);box-shadow:var(--shadow-sm);transition:transform var(--dur-norm) var(--ease-bounce)}.card:hover .card__icon{transform:scale(1.1)}.card__title{font-family:var(--font-display);font-size:var(--fs-lg);font-weight:var(--fw-bold);margin-bottom:var(--sp-2)}.card__text{font-size:var(--fs-sm);color:var(--c-text-secondary);line-height:var(--lh-loose)}.card__footer{margin-top:var(--sp-4);padding-top:var(--sp-4);border-top:1px solid var(--c-border-light);display:flex;justify-content:space-between;align-items:center}.stat-card{text-align:center;padding:var(--sp-5);display:flex;flex-direction:column;justify-content:space-between}.stat-card__value{font-family:var(--font-display);font-size:var(--fs-3xl);font-weight:var(--fw-black);line-height:1}.stat-card__label{font-size:var(--fs-sm);color:var(--c-text-secondary);margin-top:var(--sp-2);font-weight:var(--fw-semi)}.stat-card__trend{font-size:var(--fs-xs);font-weight:var(--fw-bold);padding:var(--sp-1) var(--sp-2);border-radius:var(--r-full)}.stat-card__trend--up{background:var(--c-primary-bg);color:var(--c-primary-dark)}.stat-card__trend--down{background:var(--c-error-bg);color:var(--c-error)}.subject-card{display:flex;flex-direction:column;justify-content:space-between;height:256px;padding:var(--sp-5);cursor:pointer}.subject-card__progress{width:100%;height:10px;background:var(--c-border-light);border-radius:var(--r-full);overflow:hidden;margin-bottom:var(--sp-2)}.subject-card__progress-fill{height:100%;border-radius:var(--r-full);background:var(--c-primary);transition:width var(--dur-slow) var(--ease-smooth)}.game-card{display:flex;flex-direction:column;height:100%;cursor:pointer}.game-card__image{height:192px;overflow:hidden;position:relative}.game-card__image img,.game-card__image>div{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease-smooth)}.game-card:hover .game-card__image img,.game-card:hover .game-card__image>div{transform:scale(1.1)}.game-card__badge{position:absolute;top:var(--sp-3);right:var(--sp-3);z-index:1}.lesson-card{display:flex;gap:var(--sp-5);align-items:center;padding:var(--sp-5);background:var(--c-surface);border-radius:var(--r-xl);box-shadow:var(--shadow-card);border:1px solid var(--c-border-light);transition:all var(--dur-norm) var(--ease-smooth)}.lesson-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);border-color:var(--c-primary)}.lesson-card__icon{width:48px;height:48px;border-radius:var(--r-lg);display:flex;align-items:center;justify-content:center;font-size:1.5rem;flex-shrink:0}.lesson-card__body{flex:1;min-width:0}.lesson-card__title{font-family:var(--font-display);font-size:var(--fs-md);font-weight:var(--fw-bold);margin-bottom:var(--sp-1)}.lesson-card__meta{font-size:var(--fs-xs);color:var(--c-text-secondary);display:flex;gap:var(--sp-4);margin-bottom:var(--sp-3)}.achievement-card{text-align:center}.achievement-card__icon-wrap{position:relative;width:96px;height:96px;margin:0 auto var(--sp-4)}.achievement-card__circle{width:96px;height:96px;border-radius:50%;display:flex;align-items:center;justify-content:center;border:4px solid;transition:transform var(--dur-norm) var(--ease-bounce)}.card:hover .achievement-card__circle{transform:scale(1.05)}.achievement-card--locked{opacity:.8}.achievement-card--locked .achievement-card__circle{border-style:dashed;border-color:var(--c-border);background:var(--c-bg)}.badge{display:inline-flex;align-items:center;gap:var(--sp-1);padding:var(--sp-1) var(--sp-3);border-radius:var(--r-full);font-family:var(--font-display);font-size:var(--fs-xs);font-weight:var(--fw-bold)}.badge--purple{background:var(--c-purple-bg);color:var(--c-purple)}.badge--pink{background:var(--c-pink-bg);color:var(--c-pink)}.badge--orange{background:var(--c-orange-bg);color:var(--c-orange)}.badge--green{background:var(--c-green-bg);color:var(--c-green)}.badge--blue{background:var(--c-blue-bg);color:var(--c-blue)}.badge--yellow{background:var(--c-yellow-bg);color:#b45309}.badge--red{background:var(--c-red-bg);color:var(--c-red)}.badge--teal{background:var(--c-teal-bg);color:var(--c-teal)}.tag{display:inline-flex;align-items:center;gap:var(--sp-2);padding:var(--sp-2) var(--sp-4);border-radius:var(--r-full);font-family:var(--font-display);font-size:var(--fs-sm);font-weight:var(--fw-bold);border:2px solid}.tag--purple{border-color:var(--c-purple-light);background:var(--c-purple-bg);color:var(--c-purple)}.tag--pink{border-color:var(--c-pink-light);background:var(--c-pink-bg);color:var(--c-pink)}.tag--green{border-color:var(--c-green-light);background:var(--c-green-bg);color:var(--c-green)}.tag--blue{border-color:var(--c-blue-light);background:var(--c-blue-bg);color:var(--c-blue)}.tag--orange{border-color:var(--c-orange-light);background:var(--c-orange-bg);color:var(--c-orange)}.tag__remove{width:18px;height:18px;border:none;background:none;cursor:pointer;font-size:var(--fs-sm);line-height:1;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:background var(--dur-fast)}.tag__remove:hover{background:#0000001a}.avatar{width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:var(--fw-black);font-size:var(--fs-lg);color:var(--c-text-inv);flex-shrink:0;border:3px solid var(--c-white);box-shadow:var(--shadow-sm)}.avatar--sm{width:36px;height:36px;font-size:var(--fs-sm)}.avatar--lg{width:64px;height:64px;font-size:var(--fs-xl)}.avatar--xl{width:88px;height:88px;font-size:var(--fs-2xl)}.avatar--purple{background:var(--c-purple)}.avatar--pink{background:var(--c-pink)}.avatar--orange{background:var(--c-orange)}.avatar--green{background:var(--c-green)}.avatar--blue{background:var(--c-blue)}.avatar--teal{background:var(--c-teal)}.avatar-stack{display:flex}.avatar-stack .avatar{margin-left:-12px}.avatar-stack .avatar:first-child{margin-left:0}.input-group{display:flex;flex-direction:column;gap:var(--sp-2)}.input-group__label{font-family:var(--font-display);font-weight:var(--fw-bold);font-size:var(--fs-sm);color:var(--c-text)}.input{padding:var(--sp-3) var(--sp-4);border:2px solid var(--c-border);border-radius:var(--r-lg);font-size:var(--fs-base);background:var(--c-white);outline:none;transition:border-color var(--dur-fast) var(--ease-smooth),box-shadow var(--dur-fast) var(--ease-smooth);width:100%;color:var(--c-text)}.input::placeholder{color:var(--c-text-secondary)}.input:focus{border-color:var(--c-primary);box-shadow:0 0 0 3px var(--c-primary-bg)}.input--error{border-color:var(--c-error)}.input--error:focus{box-shadow:0 0 0 3px var(--c-error-bg)}.input--success{border-color:var(--c-success)}.input--success:focus{box-shadow:0 0 0 3px var(--c-success-bg)}textarea.input{resize:vertical;min-height:80px}.input-hint{font-size:var(--fs-xs);color:var(--c-text-secondary)}.input-hint--error{color:var(--c-error)}.input-hint--success{color:var(--c-success)}.checkbox-label,.radio-label{display:flex;align-items:center;gap:var(--sp-3);font-weight:var(--fw-semi);cursor:pointer}.checkbox-label input,.radio-label input{width:22px;height:22px;accent-color:var(--c-primary);cursor:pointer}.select{-webkit-appearance:none;-moz-appearance:none;appearance:none;padding:var(--sp-3) var(--sp-4);padding-right:var(--sp-10);border:2px solid var(--c-border);border-radius:var(--r-lg);font-size:var(--fs-base);background:var(--c-white) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='%23618972'%3E%3Cpath d='M4 6l4 4 4-4'/%3E%3C/svg%3E") no-repeat right 12px center;outline:none;cursor:pointer;width:100%;color:var(--c-text)}.select:focus{border-color:var(--c-primary);box-shadow:0 0 0 3px var(--c-primary-bg)}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-6);max-width:600px}.form-grid--full{grid-column:1 / -1}.progress{width:100%;height:16px;background:var(--c-border-light);border-radius:var(--r-full);overflow:hidden}.progress__fill{height:100%;border-radius:var(--r-full);transition:width var(--dur-slow) var(--ease-smooth);background:var(--c-primary)}.progress--accent .progress__fill{background:var(--c-accent)}.progress--gold .progress__fill{background:var(--c-gold)}.progress--blue .progress__fill{background:var(--c-info)}.progress--orange .progress__fill{background:var(--c-warning)}.progress--lg{height:24px}.progress--sm{height:8px}.stars{display:flex;gap:var(--sp-1)}.star{font-size:1.5rem;cursor:pointer;transition:transform var(--dur-fast) var(--ease-bounce);filter:grayscale(100%);opacity:.4}.star:hover{transform:scale(1.3)}.star--filled{filter:none;opacity:1}.alert{padding:var(--sp-4) var(--sp-5);border-radius:var(--r-lg);border-left:6px solid;display:flex;align-items:flex-start;gap:var(--sp-3);font-weight:var(--fw-semi)}.alert__icon{font-size:1.4rem;flex-shrink:0}.alert--info{background:var(--c-blue-bg);border-color:var(--c-blue);color:var(--c-blue)}.alert--success{background:var(--c-green-bg);border-color:var(--c-green);color:var(--c-green)}.alert--warning{background:var(--c-yellow-bg);border-color:var(--c-yellow);color:var(--c-yellow)}.alert--danger{background:var(--c-red-bg);border-color:var(--c-red);color:var(--c-red)}.tooltip-wrap{position:relative;display:inline-block}.tooltip-wrap .tooltip{visibility:hidden;opacity:0;position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%) translateY(4px);padding:var(--sp-2) var(--sp-3);background:var(--c-text);color:var(--c-text-inv);font-size:var(--fs-xs);font-weight:var(--fw-bold);border-radius:var(--r-sm);white-space:nowrap;transition:opacity var(--dur-fast),transform var(--dur-fast);z-index:50}.tooltip-wrap:hover .tooltip{visibility:visible;opacity:1;transform:translate(-50%) translateY(0)}.skeleton{background:linear-gradient(90deg,var(--c-border) 25%,var(--c-bg) 50%,var(--c-border) 75%);background-size:200% 100%;animation:skeleton-shimmer 1.5s infinite;border-radius:var(--r-sm)}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton--text{height:16px;width:60%}.skeleton--title{height:28px;width:40%}.skeleton--circle{width:56px;height:56px;border-radius:50%}.skeleton--card{height:120px;width:100%;border-radius:var(--r-lg)}.skeleton--bar{height:12px;width:80%;border-radius:var(--r-full)}.tabs{display:flex;gap:var(--sp-1);border-bottom:3px solid var(--c-border)}.tab{padding:var(--sp-3) var(--sp-5);font-family:var(--font-display);font-weight:var(--fw-bold);color:var(--c-text-light);border:none;background:none;cursor:pointer;border-bottom:3px solid transparent;margin-bottom:-3px;transition:all var(--dur-fast) var(--ease-smooth)}.tab:hover{color:var(--c-primary-dark)}.tab--active{color:var(--c-primary-dark);border-bottom-color:var(--c-primary-dark)}.achievement{display:flex;flex-direction:column;align-items:center;gap:var(--sp-3);padding:var(--sp-5);text-align:center;width:130px}.achievement__medal{width:72px;height:72px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:2.2rem;border:4px solid;box-shadow:var(--shadow-md)}.achievement__medal--gold{background:var(--c-yellow-bg);border-color:var(--c-yellow)}.achievement__medal--silver{background:var(--c-blue-bg);border-color:var(--c-blue-light)}.achievement__medal--bronze{background:var(--c-orange-bg);border-color:var(--c-orange-light)}.achievement__name{font-family:var(--font-display);font-size:var(--fs-sm);font-weight:var(--fw-bold)}.achievement--locked{opacity:.4;filter:grayscale(80%)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#11181466;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:200}.modal{background:var(--c-surface);border-radius:var(--r-xl);padding:var(--sp-8);box-shadow:var(--shadow-lg);max-width:440px;width:100%;text-align:center}.modal__icon{font-size:3rem;margin-bottom:var(--sp-4)}.modal__title{font-family:var(--font-display);font-size:var(--fs-xl);font-weight:var(--fw-black);margin-bottom:var(--sp-3)}.modal__text{color:var(--c-text-light);margin-bottom:var(--sp-6)}.modal__actions{display:flex;gap:var(--sp-3);justify-content:center}@keyframes pop-in{0%{transform:scale(0) rotate(-12deg);opacity:0}60%{transform:scale(1.15) rotate(3deg);opacity:1}to{transform:scale(1) rotate(0);opacity:1}}.pop-in{animation:pop-in var(--dur-slow) var(--ease-bounce) both}@keyframes wiggle{0%,to{transform:rotate(0)}25%{transform:rotate(-6deg)}75%{transform:rotate(6deg)}}.wiggle:hover{animation:wiggle .4s var(--ease-bounce)}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.float{animation:float 3s ease-in-out infinite}.text-center{text-align:center}.text-muted{color:var(--c-text-light)}.text-purple{color:var(--c-purple)}.text-green{color:var(--c-green)}.text-orange{color:var(--c-orange)}.text-pink{color:var(--c-pink)}.mt-2{margin-top:var(--sp-2)}.mt-4{margin-top:var(--sp-4)}.mt-6{margin-top:var(--sp-6)}.mt-8{margin-top:var(--sp-8)}.mb-2{margin-bottom:var(--sp-2)}.mb-4{margin-bottom:var(--sp-4)}.mb-6{margin-bottom:var(--sp-6)}.flex{display:flex}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.items-end{align-items:flex-end}.justify-between{justify-content:space-between}.gap-1{gap:var(--sp-1)}.gap-2{gap:var(--sp-2)}.gap-3{gap:var(--sp-3)}.gap-4{gap:var(--sp-4)}.gap-5{gap:var(--sp-5)}.gap-6{gap:var(--sp-6)}.w-full{width:100%}.ds-section{margin-bottom:var(--sp-16)}.ds-section__title{font-family:var(--font-display);font-size:var(--fs-2xl);font-weight:var(--fw-black);margin-bottom:var(--sp-2);background:linear-gradient(135deg,var(--c-primary),var(--c-accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.ds-section__desc{color:var(--c-text-light);margin-bottom:var(--sp-6);font-size:var(--fs-md)}.ds-row{display:flex;flex-wrap:wrap;gap:var(--sp-4);align-items:flex-start}.ds-col{display:flex;flex-direction:column;gap:var(--sp-3)}.swatch-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:var(--sp-4)}.swatch{border-radius:var(--r-md);overflow:hidden;box-shadow:var(--shadow-sm)}.swatch__color{height:64px}.swatch__info{padding:var(--sp-2) var(--sp-3);background:var(--c-white)}.swatch__name{font-family:var(--font-display);font-size:var(--fs-xs);font-weight:var(--fw-bold)}.swatch__hex{font-size:var(--fs-xs);color:var(--c-text-light)}.type-row{display:flex;align-items:baseline;gap:var(--sp-6);margin-bottom:var(--sp-4)}.type-label{font-size:var(--fs-xs);color:var(--c-text-light);width:80px;flex-shrink:0}.spacing-demo{display:flex;gap:var(--sp-3);align-items:flex-end;flex-wrap:wrap}.spacing-box{background:var(--c-primary-bg);border:2px solid var(--c-primary);border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;font-size:var(--fs-xs);font-weight:var(--fw-bold);color:var(--c-primary-dark)}.modal-demo{position:relative;background:var(--c-border);border-radius:var(--r-xl);padding:var(--sp-12);display:flex;align-items:center;justify-content:center;min-height:340px}.modal-demo .modal{position:relative}.progress-row{max-width:500px}.alert-col{max-width:550px}.lesson-col{max-width:520px}.skeleton-card-w,.card-w-260{width:260px}.stat-card-w{width:170px}.bg-purple{background:var(--c-purple)}.bg-pink{background:var(--c-pink)}.bg-orange{background:var(--c-orange)}.bg-green{background:var(--c-green)}.bg-blue{background:var(--c-blue)}.bg-yellow{background:var(--c-yellow)}.bg-red{background:var(--c-red)}.bg-teal{background:var(--c-teal)}.bg-purple-light{background:var(--c-purple-bg)}.bg-pink-light{background:var(--c-pink-bg)}.bg-orange-light{background:var(--c-orange-bg)}.bg-green-light{background:var(--c-green-bg)}.bg-blue-light{background:var(--c-blue-bg)}.bg-yellow-light{background:var(--c-yellow-bg)}.bg-red-light{background:var(--c-red-bg)}.bg-teal-light{background:var(--c-teal-bg)}.icon-bg-purple-light{background:var(--c-purple-light)}.icon-bg-green-light{background:var(--c-green-light)}.icon-bg-orange-light{background:var(--c-orange-light)}.icon-bg-blue-light{background:var(--c-blue-light)}.icon-bg-purple-bg{background:var(--c-purple-bg)}.icon-bg-green-bg{background:var(--c-green-bg)}.icon-bg-orange-bg{background:var(--c-orange-bg)}.icon-bg-blue-bg{background:var(--c-blue-bg)}.text-bold{font-weight:var(--fw-bold)}.text-sm{font-size:var(--fs-sm)}.text-xs{font-size:var(--fs-xs)}.w-20{width:20%}.w-30{width:30%}.w-45{width:45%}.w-60{width:60%}.w-75{width:75%}.w-90{width:90%}.w-100{width:100%}.sp-demo-1{width:4px;height:4px}.sp-demo-2{width:8px;height:8px}.sp-demo-3{width:12px;height:12px}.sp-demo-4{width:16px;height:16px}.sp-demo-5{width:20px;height:20px}.sp-demo-6{width:24px;height:24px}.sp-demo-8{width:32px;height:32px}.sp-demo-10{width:40px;height:40px}.sp-demo-12{width:48px;height:48px}.sp-demo-16{width:64px;height:64px}.pop-in--delay-1{animation-delay:.1s}.pop-in--delay-2{animation-delay:.2s}.pop-in--delay-3{animation-delay:.3s}.card--tab-content{border-radius:0 0 var(--r-lg) var(--r-lg);border-top:none}.learn-content{padding:var(--sp-8);line-height:var(--lh-loose)}.learn-content h1{font-size:var(--fs-2xl);margin:var(--sp-6) 0 var(--sp-3)}.learn-content h2{font-size:var(--fs-xl);margin:var(--sp-6) 0 var(--sp-3);border-bottom:2px solid var(--c-border);padding-bottom:var(--sp-2)}.learn-content h3{font-size:var(--fs-lg);margin:var(--sp-5) 0 var(--sp-2)}.learn-content h4{font-size:var(--fs-md);margin:var(--sp-4) 0 var(--sp-2)}.learn-content h1:first-child,.learn-content h2:first-child{margin-top:0}.learn-content p{margin-bottom:var(--sp-3)}.learn-content ul,.learn-content ol{margin:var(--sp-2) 0 var(--sp-4) var(--sp-6)}.learn-content li{margin-bottom:var(--sp-1)}.learn-content li>ul,.learn-content li>ol{margin-top:var(--sp-1);margin-bottom:var(--sp-1)}.learn-content strong{font-weight:var(--fw-bold);color:var(--c-text)}.learn-content em{font-style:italic}.learn-content table{width:100%;border-collapse:collapse;margin:var(--sp-4) 0;font-size:var(--fs-sm)}.learn-content th,.learn-content td{border:1px solid var(--c-border);padding:var(--sp-2) var(--sp-3);text-align:left}.learn-content th{background:var(--c-primary-bg);font-weight:var(--fw-bold);font-family:var(--font-display)}.learn-content tr:nth-child(2n) td{background:var(--c-bg)}.learn-content code{background:var(--c-bg);padding:2px 6px;border-radius:var(--r-sm);font-size:.9em}.learn-content pre{background:var(--c-bg);padding:var(--sp-4);border-radius:var(--r-md);overflow-x:auto;margin:var(--sp-4) 0}.learn-content pre code{background:none;padding:0}.learn-content hr{border:none;border-top:2px solid var(--c-border);margin:var(--sp-6) 0}
