@font-face{font-family:Fredoka;font-style:normal;font-weight:300 700;font-stretch:100%;font-display:swap;src:url(../media/b6df7c92285ebcd2-s.0y4xxz2y19qqs.woff2)format("woff2");unicode-range:U+307-308,U+590-5FF,U+200C-2010,U+20AA,U+25CC,U+FB1D-FB4F}@font-face{font-family:Fredoka;font-style:normal;font-weight:300 700;font-stretch:100%;font-display:swap;src:url(../media/eeba9b1ad34c1404-s.0yczt4r3j28ff.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Fredoka;font-style:normal;font-weight:300 700;font-stretch:100%;font-display:swap;src:url(../media/5d52bd6c4cb3f315-s.p.0ez3bnoxb63ra.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Fredoka Fallback;src:local(Arial);ascent-override:95.64%;descent-override:23.17%;line-gap-override:0.0%;size-adjust:101.84%}.fredoka_72b1f4be-module__pfJjLW__className{font-family:Fredoka,Fredoka Fallback;font-style:normal}.fredoka_72b1f4be-module__pfJjLW__variable{--font-display:"Fredoka", "Fredoka Fallback"}
@font-face{font-family:Nunito;font-style:normal;font-weight:200 1000;font-display:swap;src:url(../media/224e262ef877bfa4-s.1zkvd_innyig_.woff2)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Nunito;font-style:normal;font-weight:200 1000;font-display:swap;src:url(../media/7f11d98043fdedc9-s.2c8-7nzo1jf9r.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Nunito;font-style:normal;font-weight:200 1000;font-display:swap;src:url(../media/e6d00ff86ef9e699-s.1vcas2uk12q5a.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Nunito;font-style:normal;font-weight:200 1000;font-display:swap;src:url(../media/d8cb5ab3660140cd-s.2demiz2t05dx4.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Nunito;font-style:normal;font-weight:200 1000;font-display:swap;src:url(../media/07454f8ad8aaac57-s.p.2kjei9psvcorz.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Nunito Fallback;src:local(Arial);ascent-override:99.71%;descent-override:34.82%;line-gap-override:0.0%;size-adjust:101.39%}.nunito_494ff288-module__5nKHcG__className{font-family:Nunito,Nunito Fallback;font-style:normal}.nunito_494ff288-module__5nKHcG__variable{--font-body:"Nunito", "Nunito Fallback"}
@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-outline-style:solid}}}@layer theme{:root,:host{--font-sans:ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::placeholder{color:color-mix(in oklab, currentcolor 50%, transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.hidden{display:none}.h-full{height:100%}.min-h-full{min-height:100%}.uppercase{text-transform:uppercase}.antialiased{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.outline{outline-style:var(--tw-outline-style);outline-width:1px}}:root{--mobile-bottom-nav-height:64px;--bg:#fff8fb;--bg-soft:#fff1f8;--surface:#ffffffd1;--text:#2b2142;--muted:#6d6287;--primary:#7c3aed;--primary-dark:#5b21b6;--secondary:#ff7ac3;--success:#10b981;--danger:#ef4444;--warning:#f59e0b;--border:#7c3aed1f;--shadow:0 20px 50px #5b21b61f;--radius:24px}*{box-sizing:border-box}html{scroll-behavior:smooth}body{min-height:100vh;font-family:var(--font-body), "Nunito", sans-serif;color:var(--text);background:radial-gradient(circle at 0 0,#ff7ac340,#0000 28%),radial-gradient(circle at 100% 0,#7c3aed2e,#0000 24%),linear-gradient(#fff8fb 0%,#f6f2ff 100%);margin:0}h1,h2,h3,.brand{font-family:var(--font-display), "Fredoka", sans-serif}a{color:inherit;text-decoration:none}button,input,select{font:inherit}img{max-width:100%}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes slide-down{0%{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}.animate-slide-down{animation:.4s slide-down}.install-banner{z-index:50;color:#fff;background:linear-gradient(90deg,#7c3aed,#ff7ac3);padding:12px 16px;position:sticky;top:0}.install-banner-inner{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;max-width:1100px;margin:0 auto;display:flex}.install-title{margin:0;font-weight:800}.install-subtitle{opacity:.92;margin:4px 0 0;font-size:.95rem}.install-actions{flex-wrap:wrap;gap:8px;display:flex}.navbar{z-index:40;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-bottom:1px solid var(--border);background:#fff8fbc7;position:sticky;top:0}.navbar-inner{justify-content:space-between;align-items:center;gap:12px;max-width:1100px;margin:0 auto;padding:14px 16px;display:flex}.brand{align-items:center;gap:10px;font-size:1.25rem;font-weight:700;display:flex}.brand-icon{font-size:1.5rem}.nav-links{gap:8px;display:none}.nav-link{color:var(--muted);border-radius:999px;padding:8px 14px;font-weight:700}.nav-link.active,.nav-link:hover{color:var(--primary-dark);background:#7c3aed1a}.nav-auth,.nav-user,.nav-auth-buttons{align-items:center;gap:8px;display:flex}.nav-user-name{color:var(--muted);font-size:.92rem;font-weight:700}.nav-muted{color:var(--muted)}.mobile-bottom-nav{display:none}.mobile-bottom-nav-item{min-width:0;color:var(--muted);text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:3px;padding:8px 6px;font-size:.72rem;font-weight:800;transition:color .15s,background .15s;display:flex}.mobile-bottom-nav-icon{font-size:1.35rem;line-height:1}.mobile-bottom-nav-item.active,.mobile-bottom-nav-item:hover{color:var(--primary-dark)}.mobile-bottom-nav-item.active{background:#7c3aed14}.btn{cursor:pointer;border:none;border-radius:999px;justify-content:center;align-items:center;gap:8px;padding:12px 20px;font-weight:800;transition:transform .2s,box-shadow .2s,background .2s;display:inline-flex}.btn:hover{transform:translateY(-1px)}.btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.btn-sm{padding:8px 14px;font-size:.92rem}.btn-lg{padding:16px 24px;font-size:1.05rem}.btn-block{width:100%}.btn-primary{background:linear-gradient(135deg, var(--primary), #9333ea);color:#fff;box-shadow:0 10px 24px #7c3aed47}.btn-secondary{color:var(--primary-dark);background:#fff;border:2px solid #7c3aed29}.btn-ghost{color:var(--primary-dark);background:0 0}.landing{max-width:1100px;margin:0 auto;padding:24px 16px 64px}.hero{align-items:center;gap:32px;padding:24px 0 48px;display:grid}.hero-badge{color:var(--primary-dark);background:#7c3aed1a;border-radius:999px;margin-bottom:16px;padding:8px 14px;font-weight:800;display:inline-block}.hero h1{margin:0 0 16px;font-size:clamp(2.4rem,7vw,4.5rem);line-height:1.02}.hero h1 span{background:linear-gradient(135deg, var(--primary), var(--secondary));color:#0000;-webkit-background-clip:text;background-clip:text}.hero-text{max-width:620px;color:var(--muted);margin-bottom:24px;font-size:1.08rem;line-height:1.7}.hero-actions{flex-wrap:wrap;gap:12px;display:flex}.hero-visual{min-height:280px;position:relative}.floating-card{background:var(--surface);box-shadow:var(--shadow);border-radius:20px;padding:16px 20px;font-weight:800;animation:4s ease-in-out infinite float;position:absolute}.card-1{top:20px;left:10%}.card-2{animation-delay:.8s;top:90px;right:8%}.card-3{animation-delay:1.4s;bottom:20px;left:24%}.hero-orbit{opacity:.35;place-items:center;font-size:5rem;display:grid;position:absolute;inset:0}.categories-section{padding-top:16px}.section-header{margin-bottom:24px}.section-header h2{margin:0 0 8px;font-size:clamp(1.8rem,4vw,2.6rem)}.section-header p{color:var(--muted);margin:0}.category-grid{grid-template-columns:repeat(auto-fill,minmax(min(100%,240px),1fr));gap:18px;display:grid}.category-card{border-radius:var(--radius);background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow);padding:24px;transition:transform .25s,box-shadow .25s;position:relative;overflow:hidden}.category-card:hover{transform:translateY(-4px)scale(1.01);box-shadow:0 24px 50px #7c3aed2e}.category-card-glow{background:radial-gradient(circle,#ff7ac359,#0000 70%);width:160px;height:160px;position:absolute;inset:auto -30% -40% auto}.category-card-icon{background:linear-gradient(135deg,#7c3aed1f,#ff7ac32e);border-radius:20px;place-items:center;width:72px;height:72px;margin-bottom:16px;display:grid}.category-card-emoji{font-size:2.4rem}.category-card-image{object-fit:cover;border-radius:12px;width:48px;height:48px}.category-card h3{margin:0 0 8px;font-size:1.35rem}.category-card p{color:var(--muted);margin:0 0 16px}.category-card-cta{color:var(--primary-dark);font-weight:800}.category-card-locked{background:#ffffffb8;border-style:dashed}.category-card-locked .category-card-glow{background:radial-gradient(circle,#7c3aed2e,#0000 70%)}.category-card-lock-badge{font-size:1.2rem;position:absolute;top:16px;right:16px}.auth-providers{gap:12px;margin-bottom:18px;display:grid}.google-signin-wrap{justify-content:center;min-height:44px;display:flex}.google-signin-wrap.disabled{opacity:.6;pointer-events:none}.auth-provider-note{color:var(--muted);text-align:center;background:#7c3aed14;border-radius:14px;margin:0;padding:12px 14px;font-size:.92rem}.auth-divider{color:var(--muted);align-items:center;gap:12px;margin:0 0 18px;font-size:.88rem;font-weight:700;display:flex}.auth-divider:before,.auth-divider:after{content:"";background:var(--border);flex:1;height:1px}.page-shell,.learn-page{max-width:760px;margin:0 auto;padding:24px 16px 48px}.learn-shell{gap:20px;display:grid}.learn-topbar,.learn-header,.learn-controls{justify-content:space-between;align-items:center;gap:12px;display:flex}.learn-status-buttons{gap:8px;display:flex}.status-btn{color:var(--text);cursor:pointer;background:#fff;border:2px solid #7c3aed24;border-radius:999px;padding:10px 14px;font-weight:800}.status-btn.active.success{border-color:var(--success);color:#047857;background:#10b98126}.status-btn.active.danger{border-color:var(--danger);color:#b91c1c;background:#ef44441f}.learn-header{justify-content:flex-start}.learn-category-icon{width:56px;height:56px;box-shadow:var(--shadow);background:#fff;border-radius:18px;place-items:center;font-size:2rem;display:grid}.learn-category-name{margin:0;font-weight:800}.learn-counter{color:var(--muted);margin:4px 0 0}.learn-card{background:var(--surface);border:1px solid var(--border);border-radius:calc(var(--radius) + 8px);box-shadow:var(--shadow);text-align:center;padding:24px;overflow:hidden}.learn-card-body{will-change:transform, opacity}.learn-item-visible{opacity:1;transform:none}.learn-item-enter,.learn-item-exit,.admin-anim-preview-enter,.admin-anim-preview-exit{animation-duration:.45s;animation-timing-function:cubic-bezier(.22,1,.36,1);animation-fill-mode:both}.learn-enter-none,.learn-exit-none{animation-duration:10ms}.learn-enter-fade{animation-name:learnEnterFade}.learn-exit-fade{animation-name:learnExitFade}.learn-enter-slide-up{animation-name:learnEnterSlideUp}.learn-exit-slide-up{animation-name:learnExitSlideUp}.learn-enter-slide-down{animation-name:learnEnterSlideDown}.learn-exit-slide-down{animation-name:learnExitSlideDown}.learn-enter-slide-left{animation-name:learnEnterSlideLeft}.learn-exit-slide-left{animation-name:learnExitSlideLeft}.learn-enter-slide-right{animation-name:learnEnterSlideRight}.learn-exit-slide-right{animation-name:learnExitSlideRight}.learn-enter-zoom-in{animation-name:learnEnterZoomIn}.learn-exit-zoom-in{animation-name:learnExitZoomIn}.learn-enter-zoom-out{animation-name:learnEnterZoomOut}.learn-exit-zoom-out{animation-name:learnExitZoomOut}.learn-enter-bounce{animation-name:learnEnterBounce}.learn-exit-bounce{animation-name:learnExitBounce}.learn-enter-pop{animation-name:learnEnterPop}.learn-exit-pop{animation-name:learnExitPop}.learn-enter-spin{animation-name:learnEnterSpin}.learn-exit-spin{animation-name:learnExitSpin}@keyframes learnEnterFade{0%{opacity:0}to{opacity:1}}@keyframes learnExitFade{0%{opacity:1}to{opacity:0}}@keyframes learnEnterSlideUp{0%{opacity:0;transform:translateY(36px)}to{opacity:1;transform:translateY(0)}}@keyframes learnExitSlideUp{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-36px)}}@keyframes learnEnterSlideDown{0%{opacity:0;transform:translateY(-36px)}to{opacity:1;transform:translateY(0)}}@keyframes learnExitSlideDown{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(36px)}}@keyframes learnEnterSlideLeft{0%{opacity:0;transform:translate(40px)}to{opacity:1;transform:translate(0)}}@keyframes learnExitSlideLeft{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(-40px)}}@keyframes learnEnterSlideRight{0%{opacity:0;transform:translate(-40px)}to{opacity:1;transform:translate(0)}}@keyframes learnExitSlideRight{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(40px)}}@keyframes learnEnterZoomIn{0%{opacity:0;transform:scale(.72)}to{opacity:1;transform:scale(1)}}@keyframes learnExitZoomIn{0%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(1.12)}}@keyframes learnEnterZoomOut{0%{opacity:0;transform:scale(1.12)}to{opacity:1;transform:scale(1)}}@keyframes learnExitZoomOut{0%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(.72)}}@keyframes learnEnterBounce{0%{opacity:0;transform:translateY(24px)scale(.92)}60%{opacity:1;transform:translateY(-8px)scale(1.03)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes learnExitBounce{0%{opacity:1;transform:translateY(0)scale(1)}to{opacity:0;transform:translateY(24px)scale(.92)}}@keyframes learnEnterPop{0%{opacity:0;transform:scale(.5)}70%{opacity:1;transform:scale(1.08)}to{opacity:1;transform:scale(1)}}@keyframes learnExitPop{0%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(.5)}}@keyframes learnEnterSpin{0%{opacity:0;transform:rotate(-120deg)scale(.85)}to{opacity:1;transform:rotate(0)scale(1)}}@keyframes learnExitSpin{0%{opacity:1;transform:rotate(0)scale(1)}to{opacity:0;transform:rotate(120deg)scale(.85)}}.learn-image-wrap{aspect-ratio:1;background:linear-gradient(135deg,#f3e8ff,#ffe4f3);border-radius:28px;width:min(100%,420px);margin:0 auto 20px;position:relative;overflow:hidden}.learn-image{object-fit:cover}.learn-fallback{aspect-ratio:1;background:linear-gradient(135deg,#ddd6fe,#fbcfe8);border-radius:28px;place-items:center;width:min(100%,320px);margin:0 auto 20px;display:grid;position:relative}.learn-fallback-icon{opacity:.35;font-size:4rem}.learn-fallback-letter{color:var(--primary-dark);font-family:Fredoka,sans-serif;font-size:6rem;position:absolute}.learn-item-name{margin:0;font-size:clamp(2rem,8vw,3.4rem)}.learn-speech{border-top:1px dashed #7c3aed29;margin-top:20px;padding-top:18px}.learn-speech-unavailable{color:var(--muted);font-size:.92rem;line-height:1.5}.learn-speech-actions{flex-wrap:wrap;justify-content:center;gap:10px;display:flex}.learn-speech-btn{color:var(--primary-dark);cursor:pointer;background:#fff;border:2px solid #7c3aed29;border-radius:999px;padding:12px 18px;font-weight:800;transition:transform .2s,box-shadow .2s,background .2s}.learn-speech-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 10px 24px #7c3aed1f}.learn-speech-btn.listen{background:linear-gradient(135deg,#7c3aed1a,#ff7ac329)}.learn-speech-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}.learn-speech-btn:disabled{opacity:.65;cursor:not-allowed;transform:none}.learn-speech-status,.learn-speech-heard,.learn-speech-feedback{margin:14px 0 0;font-size:.95rem}.learn-speech-status.listening{color:var(--primary-dark);font-weight:800;animation:1s ease-in-out infinite pulse-speech}.learn-speech-heard{color:var(--muted)}.learn-speech-feedback.success{color:#047857;font-weight:800}.learn-speech-feedback.error{color:#b91c1c;font-weight:700}.learn-speech-feedback.neutral{color:var(--muted)}@keyframes pulse-speech{0%,to{opacity:1}50%{opacity:.55}}.learn-login-hint,.learn-message{color:var(--muted);margin-top:16px}.learn-login-hint a{color:var(--primary-dark);font-weight:800}.learn-controls{flex-wrap:wrap}.learn-dots{flex-wrap:wrap;flex:1;justify-content:center;gap:8px;display:flex}.learn-dot{cursor:pointer;background:#7c3aed2e;border:none;border-radius:999px;width:12px;height:12px}.learn-dot.active{background:var(--primary);transform:scale(1.2)}.learn-dot.done{background:var(--success)}.learn-dot.practice{background:var(--danger)}.dashboard-hero h1{margin:8px 0;font-size:clamp(2rem,5vw,3rem)}.dashboard-kicker,.dashboard-date{color:var(--muted);margin:0}.dashboard-stats{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin:24px 0;display:grid}.stat-card{box-shadow:var(--shadow);border:1px solid var(--border);background:#fff;border-radius:22px;padding:20px}.stat-card.success{background:linear-gradient(#10b9811f,#fff)}.stat-card.danger{background:linear-gradient(#ef44441a,#fff)}.stat-card.highlight{background:linear-gradient(#7c3aed1f,#fff)}.stat-number{font-family:Fredoka,sans-serif;font-size:2.2rem;display:block}.stat-label{color:var(--muted);font-weight:700}.dashboard-grid{gap:16px;display:grid}.dashboard-list{box-shadow:var(--shadow);border:1px solid var(--border);background:#fff;border-radius:22px;padding:20px}.dashboard-list h3{margin-top:0}.dashboard-list ul{gap:10px;margin:0;padding:0;list-style:none;display:grid}.dashboard-list li{background:#7c3aed0d;border-radius:14px;grid-template-columns:auto 1fr;align-items:center;gap:4px 10px;padding:10px 12px;display:grid}.dashboard-list li small{color:var(--muted);grid-column:2}.dashboard-empty{color:var(--muted)}.dashboard-history{box-shadow:var(--shadow);background:#fff;border-radius:22px;margin-top:24px;padding:20px}.history-bars{align-items:end;gap:10px;padding-bottom:8px;display:flex;overflow-x:auto}.history-bar-wrap{text-align:center;min-width:48px;color:var(--muted);font-size:.82rem}.history-bar{background:linear-gradient(180deg, var(--secondary), var(--primary));border-radius:999px 999px 4px 4px;width:100%;min-height:12px;margin-bottom:8px}.dashboard-footer{justify-content:center;margin-top:24px;display:flex}.admin-app{--admin-sidebar:#111827;--admin-sidebar-hover:#ffffff0f;--admin-sidebar-active:#6366f138;--admin-border:#e5e7eb;--admin-surface:#fff;--admin-muted:#6b7280;--admin-text:#111827;--admin-accent:#4f46e5;--admin-bg:#f3f4f6;background:var(--admin-bg);min-height:100vh;color:var(--admin-text);font-family:var(--font-body), "Segoe UI", sans-serif;display:flex}.admin-sidebar-backdrop{z-index:30;background:#11182773;border:none;position:fixed;inset:0}.admin-sidebar{background:var(--admin-sidebar);color:#f9fafb;z-index:40;flex-direction:column;width:260px;padding:20px 16px;transition:transform .25s;display:flex;position:fixed;inset:0 auto 0 0;transform:translate(-100%)}.admin-app.sidebar-open .admin-sidebar{transform:translate(0)}.admin-sidebar-brand{border-bottom:1px solid #ffffff14;align-items:center;gap:12px;padding:8px 10px 24px;display:flex}.admin-sidebar-logo{background:linear-gradient(135deg,#6366f1,#8b5cf6);border-radius:12px;place-items:center;width:42px;height:42px;font-size:.95rem;font-weight:800;display:grid}.admin-sidebar-brand strong{font-size:.98rem;display:block}.admin-sidebar-brand span{color:#9ca3af;font-size:.78rem}.admin-sidebar-nav{flex:1;padding:20px 0}.admin-sidebar-label{letter-spacing:.08em;text-transform:uppercase;color:#6b7280;margin:0 10px 10px;font-size:.72rem}.admin-sidebar-link{color:#d1d5db;border-radius:10px;align-items:center;gap:12px;margin-bottom:4px;padding:11px 12px;transition:background .2s,color .2s;display:flex}.admin-sidebar-link:hover,.admin-sidebar-link.active{background:var(--admin-sidebar-active);color:#fff}.admin-sidebar-link.subtle{color:#9ca3af}.admin-sidebar-icon{text-align:center;opacity:.9;width:18px}.admin-sidebar-footer{border-top:1px solid #ffffff14;padding-top:16px}.admin-sidebar-user{align-items:center;gap:10px;padding:12px 10px 4px;display:flex}.admin-sidebar-avatar{background:#ffffff1f;border-radius:999px;place-items:center;width:36px;height:36px;font-weight:700;display:grid}.admin-sidebar-user strong{font-size:.92rem;display:block}.admin-sidebar-user span{color:#9ca3af;font-size:.78rem}.admin-main{flex-direction:column;flex:1;min-width:0;display:flex}.admin-topbar{z-index:20;border-bottom:1px solid var(--admin-border);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffffeb;justify-content:space-between;align-items:center;gap:16px;padding:18px 20px;display:flex;position:sticky;top:0}.admin-topbar-left{align-items:center;gap:14px;display:flex}.admin-topbar-kicker{text-transform:uppercase;letter-spacing:.08em;color:var(--admin-muted);margin:0;font-size:.78rem}.admin-topbar h1{font-size:1.45rem;font-family:var(--font-body), "Segoe UI", sans-serif;margin:2px 0 0;font-weight:700}.admin-topbar-actions{align-items:center;gap:12px;display:flex}.admin-topbar-user{color:var(--admin-muted);font-size:.92rem}.admin-mobile-toggle{border:1px solid var(--admin-border);cursor:pointer;background:#fff;border-radius:10px;justify-content:center;align-items:center;width:40px;height:40px;display:inline-flex}.admin-content{padding:24px 20px 40px}.admin-page{gap:20px;display:grid}.admin-stats-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;display:grid}.admin-stat-card{background:var(--admin-surface);border:1px solid var(--admin-border);border-radius:16px;padding:20px}.admin-stat-label{color:var(--admin-muted);margin-bottom:8px;font-size:.85rem;display:block}.admin-stat-card strong{font-size:2rem;line-height:1}.admin-stat-card p{color:var(--admin-muted);margin:10px 0 0;font-size:.88rem}.admin-panel-card{background:var(--admin-surface);border:1px solid var(--admin-border);border-radius:16px;padding:22px}.admin-panel-card-wide{min-width:0}.admin-panel-head{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:18px;display:flex}.admin-panel-head-actions{flex-wrap:wrap;justify-content:flex-end;align-items:end;gap:12px;display:flex}.admin-dropzone-wrap{gap:10px;display:grid}.admin-dropzone{border:2px dashed var(--admin-border);cursor:pointer;background:#fff;border-radius:16px;min-height:180px;transition:border-color .2s,background .2s,box-shadow .2s;position:relative;overflow:hidden}.admin-dropzone:hover,.admin-dropzone.dragging{background:#eef2ff;border-color:#818cf8;box-shadow:inset 0 0 0 1px #4f46e51f}.admin-dropzone-empty{text-align:center;min-height:180px;color:var(--admin-muted);place-content:center;gap:6px;padding:20px;display:grid}.admin-dropzone-empty strong{color:var(--admin-text)}.admin-dropzone-icon{font-size:2rem}.admin-dropzone-preview{aspect-ratio:1;background:#f3f4f6;width:100%;min-height:180px;max-height:220px;position:relative}.admin-dropzone-image{object-fit:contain}.admin-dropzone-loading{color:var(--admin-text);background:#ffffffb8;place-items:center;font-weight:700;display:grid;position:absolute;inset:0}.admin-dropzone-url{grid-template-columns:1fr auto;gap:8px;display:grid}.admin-dropzone-url input{border:1px solid var(--admin-border);background:#fff;border-radius:10px;width:100%;padding:10px 12px}.admin-image-field{border:1px dashed var(--admin-border);background:#fafafa;border-radius:14px;gap:10px;padding:14px;display:grid}.admin-image-field-head{justify-content:space-between;align-items:center;gap:12px;font-weight:600;display:flex}.admin-item-thumb{border:1px solid var(--admin-border);background:#f3f4f6;border-radius:12px;justify-content:center;align-items:center;display:inline-flex;overflow:hidden}.admin-item-thumb img{object-fit:cover;width:100%;height:100%}.admin-item-thumb-md{width:56px;height:56px}.admin-item-thumb-lg{width:96px;height:96px}.admin-item-thumb-empty{color:var(--admin-muted);font-size:.9rem}.admin-bulk-animations{border:1px solid var(--admin-border);background:#fafafa;border-radius:14px;flex-wrap:wrap;justify-content:space-between;align-items:end;gap:16px;margin-bottom:18px;padding:16px;display:flex}.admin-bulk-animations strong{margin-bottom:4px;display:block}.admin-bulk-animations p{color:var(--admin-muted);margin:0;font-size:.88rem}.admin-bulk-animations-controls{flex-wrap:wrap;align-items:end;gap:12px;display:flex}.admin-bulk-animations-controls label{color:var(--admin-muted);gap:6px;font-size:.82rem;font-weight:600;display:grid}.admin-bulk-animations-controls select{border:1px solid var(--admin-border);background:#fff;border-radius:10px;min-width:140px;padding:8px 10px}.admin-table-drop-cell{border:2px dashed var(--admin-border);cursor:pointer;background:#fafafa;border-radius:12px;place-items:center;width:64px;height:64px;transition:border-color .2s,background .2s;display:grid;position:relative;overflow:hidden}.admin-table-drop-cell:hover,.admin-table-drop-cell.dragging{background:#eef2ff;border-color:#818cf8}.admin-table-drop-placeholder{color:var(--admin-muted);text-align:center;padding:4px;font-size:.72rem;font-weight:700;line-height:1.2}.admin-table-drop-image{object-fit:cover;width:100%;height:100%}.admin-table-drop-loading{color:var(--admin-text);background:#ffffffc7;place-items:center;font-size:.68rem;font-weight:700;display:grid;position:absolute;inset:0}.admin-panel-head h2{font-size:1.1rem;font-family:var(--font-body), "Segoe UI", sans-serif;margin:0 0 4px}.admin-panel-head p{color:var(--admin-muted);margin:0;font-size:.92rem}.admin-tabs{border-bottom:1px solid var(--admin-border);flex-wrap:wrap;gap:8px;margin-bottom:20px;padding-bottom:16px;display:flex}.admin-tab{border:1px solid var(--admin-border);color:var(--admin-muted);font:inherit;cursor:pointer;background:#fff;border-radius:999px;padding:10px 16px;font-size:.9rem;font-weight:600;transition:background .15s,border-color .15s,color .15s}.admin-tab:hover{color:var(--admin-text);border-color:#c7d2fe}.admin-tab.active{color:#4338ca;background:#eef2ff;border-color:#818cf8}.admin-tab-panel{min-width:0}.admin-split{gap:20px;display:grid}.admin-quick-actions{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;display:grid}.admin-quick-action{border:1px solid var(--admin-border);background:#fafafa;border-radius:14px;padding:16px;transition:border-color .2s,transform .2s}.admin-quick-action:hover{border-color:#c7d2fe;transform:translateY(-1px)}.admin-quick-action strong{margin-bottom:6px;display:block}.admin-quick-action span{color:var(--admin-muted);font-size:.88rem}.admin-table-wrap{overflow-x:auto}.admin-table{border-collapse:collapse;width:100%}.admin-table th,.admin-table td{text-align:left;border-bottom:1px solid var(--admin-border);padding:12px 10px;font-size:.92rem}.admin-table th{color:var(--admin-muted);text-transform:uppercase;letter-spacing:.04em;font-size:.8rem;font-weight:600}.admin-table-icon{background:#f3f4f6;border-radius:10px;place-items:center;width:34px;height:34px;display:inline-grid}.admin-table code{color:#4338ca;font-size:.82rem}.admin-table-actions{text-align:right;white-space:nowrap}.admin-form{gap:14px;display:grid}.admin-form label{color:var(--admin-text);gap:8px;font-size:.88rem;font-weight:600;display:grid}.admin-form input,.admin-form select{border:1px solid var(--admin-border);background:#fff;border-radius:10px;width:100%;padding:11px 12px}.admin-form input:focus,.admin-form select:focus{border-color:#a5b4fc;outline:2px solid #4f46e52e}.admin-btn{cursor:pointer;border:1px solid #0000;border-radius:10px;justify-content:center;align-items:center;gap:8px;padding:10px 16px;font-size:.92rem;font-weight:600;transition:background .2s,border-color .2s;display:inline-flex}.admin-btn-sm{padding:7px 12px;font-size:.82rem}.admin-btn-primary{background:var(--admin-accent);color:#fff}.admin-btn-primary:hover{background:#4338ca}.admin-btn-secondary{border-color:var(--admin-border);color:var(--admin-text);background:#fff}.admin-btn-ghost{border-color:var(--admin-border);color:var(--admin-text);background:0 0}.admin-btn-danger{color:#b91c1c;background:#fef2f2;border-color:#fecaca}.admin-alert{border-radius:10px;padding:12px 14px;font-size:.92rem;font-weight:600}.admin-alert.success{color:#047857;background:#ecfdf5;border:1px solid #a7f3d0}.admin-alert.error{color:#b91c1c;background:#fef2f2;border:1px solid #fecaca}.admin-empty,.admin-loading{color:var(--admin-muted);padding:12px 0}.admin-form-note{color:var(--admin-muted);margin:-4px 0 0;font-size:.84rem}.admin-form-actions{flex-wrap:wrap;gap:10px;display:flex}.admin-form-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;display:grid}.admin-anim-preview-wrap{border:1px dashed var(--admin-border);background:#fafafa;border-radius:14px;align-items:center;gap:12px;padding:14px;display:flex}.admin-anim-preview{border:1px solid var(--admin-border);background:linear-gradient(135deg,#eef2ff,#fdf2f8);border-radius:16px;place-items:center;gap:4px;width:88px;height:88px;display:grid}.admin-anim-preview span{font-size:1.4rem}.admin-anim-preview strong{color:var(--admin-muted);font-size:.72rem}.admin-checkbox{grid-auto-flow:column;align-items:center;gap:10px;display:flex!important}.admin-checkbox input{width:auto}.admin-inline-filter{color:var(--admin-muted);gap:6px;font-size:.82rem;font-weight:600;display:grid}.admin-inline-filter select{border:1px solid var(--admin-border);border:1px solid var(--admin-border);background:#fff;border-radius:10px;padding:8px 10px}.admin-inline-filter input[type=date]{border:1px solid var(--admin-border);background:#fff;border-radius:10px;padding:8px 10px}.admin-progress-grid{gap:16px;margin-top:20px;display:grid}.admin-progress-list{border:1px solid var(--admin-border);background:#fafafa;border-radius:14px;padding:16px}.admin-progress-list h3{margin:0 0 12px;font-size:.98rem}.admin-progress-list ul{gap:8px;margin:0;padding:0;list-style:none;display:grid}.admin-progress-list li{border:1px solid var(--admin-border);background:#fff;border-radius:10px;grid-template-columns:auto 1fr;align-items:center;gap:4px 10px;padding:10px 12px;display:grid}.admin-progress-list li small{color:var(--admin-muted);grid-column:2}.admin-progress-list.success{background:#f0fdf4}.admin-progress-list.danger{background:#fef2f2}.admin-history-block{margin-top:24px}.admin-history-block h3{margin:0 0 12px}.admin-history-list{gap:10px;display:grid}.admin-history-item{border:1px solid var(--admin-border);background:#fff;border-radius:12px;flex-wrap:wrap;gap:8px 16px;padding:12px 14px;display:flex}.admin-history-item strong{min-width:140px}.admin-history-item span{color:var(--admin-muted);font-size:.9rem}.admin-table tr.active-row{background:#eef2ff}.auth-form{gap:14px;display:grid}.auth-form label{color:var(--muted);gap:8px;font-weight:700;display:grid}.auth-form input{background:#fff;border:1px solid #7c3aed2e;border-radius:14px;width:100%;padding:12px 14px}.alert,.form-error,.page-error{border-radius:14px;padding:12px 16px;font-weight:700}.alert.success{color:#047857;background:#10b9811f}.alert.error,.form-error,.page-error{color:#b91c1c;background:#ef44441f}.auth-page{place-items:center;min-height:calc(100vh - 80px);padding:24px 16px;display:grid}.auth-card{width:min(100%,460px);box-shadow:var(--shadow);border:1px solid var(--border);background:#fff;border-radius:28px;padding:28px}.auth-header{text-align:center;margin-bottom:20px}.auth-icon{font-size:3rem}.auth-switch{text-align:center;color:var(--muted);margin-top:18px}.auth-switch a{color:var(--primary-dark);font-weight:800}.empty-state,.page-loading{text-align:center;color:var(--muted);padding:48px 16px}.danger-text{color:var(--danger)}@media (min-width:1024px){.admin-sidebar{flex-shrink:0;height:100vh;position:sticky;top:0;transform:none}.admin-sidebar-backdrop,.admin-mobile-toggle{display:none}.admin-split{grid-template-columns:340px minmax(0,1fr)}.admin-progress-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}@media (min-width:768px){.nav-links{display:flex}.hero{grid-template-columns:1.1fr .9fr}.dashboard-stats{grid-template-columns:repeat(4,minmax(0,1fr))}.dashboard-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width:767px){.mobile-bottom-nav{z-index:50;min-height:var(--mobile-bottom-nav-height);padding-bottom:env(safe-area-inset-bottom,0px);border-top:1px solid var(--border);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#fff8fbf5;align-items:stretch;display:flex;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -8px 24px #5b21b614}.landing,.page-shell,.learn-page,.auth-page{padding-bottom:calc(var(--mobile-bottom-nav-height) + env(safe-area-inset-bottom,0px) + 20px)}}@media (max-width:640px){.nav-user-name{display:none}.learn-topbar{flex-direction:column;align-items:stretch}.learn-status-buttons{justify-content:stretch}.status-btn{flex:1}}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}
