:root{font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:#17202a;background:#fff;font-synthesis:none;--ink: #17202a;--muted: #66707a;--line: #e5e8eb;--red: #ec3f1f;--red-dark: #cf3217;--blue: #1f6dcc;--green: #4f984b;--paper: #fbfaf6}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;-webkit-font-smoothing:antialiased;background:#fff}button,input{font:inherit}button{color:inherit}button:focus-visible{outline:3px solid rgba(31,109,204,.24);outline-offset:3px}.site-header{height:92px;max-width:1440px;margin:auto;padding:0 34px;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;border-bottom:1px solid var(--line)}.brand{border:0;background:transparent;display:flex;align-items:center;gap:14px;padding:0;cursor:pointer;text-align:left;justify-self:start}.brand-mark{width:49px;height:49px;border:2px solid var(--red);border-radius:13px;display:grid;place-items:center;color:var(--red);font:600 25px Georgia,serif}.brand strong{display:block;font-size:20px;letter-spacing:.22em}.brand small{display:block;margin-top:4px;color:#4b535b;font-size:13px;letter-spacing:.02em}.site-header nav{height:100%;display:flex;gap:40px}.site-header nav button{position:relative;border:0;background:transparent;padding:5px 4px 0;cursor:pointer;font-size:15px}.site-header nav button:after{content:"";position:absolute;height:3px;border-radius:3px;bottom:15px;left:0;right:0;transform:scaleX(0);background:var(--red);transition:transform .2s ease}.site-header nav button:hover:after,.site-header nav button.active:after{transform:scaleX(1)}.header-tools{justify-self:end;display:flex;align-items:center;gap:10px}.language-button,.mobile-menu{border:0;background:transparent;display:flex;align-items:center;gap:10px;cursor:pointer}.language-menu{position:relative}.language-popover{position:absolute;top:calc(100% + 12px);right:0;z-index:15;width:138px;padding:6px;background:#fff;border:1px solid var(--line);border-radius:10px;box-shadow:0 14px 38px #161e241f}.language-popover button{width:100%;border:0;background:transparent;padding:10px;border-radius:7px;text-align:left;cursor:pointer}.language-popover button:hover{background:#fff5f1}.account-button{border:1px solid var(--line);background:#fff;border-radius:9px;padding:9px 12px;display:flex;align-items:center;gap:7px;cursor:pointer}.mobile-menu{display:none}.app-frame{max-width:1440px;margin:auto;padding:0 34px 22px}.learner-switcher{height:108px;display:flex;justify-content:flex-end;align-items:center;gap:22px}.learner-switcher>span{font-size:14px;margin-right:2px}.avatar-button{border:0;background:transparent;display:flex;align-items:center;gap:9px;padding:7px 3px;cursor:pointer;position:relative}.avatar-button:after{content:"";position:absolute;left:57px;right:0;bottom:0;height:2px;background:var(--red);transform:scaleX(0)}.avatar-button.active:after{transform:scaleX(1)}.avatar-photo{width:47px;height:47px;border-radius:50%;background-image:url(/assets/children-portraits.png);background-size:300% 100%;background-repeat:no-repeat;border:2px solid transparent}.avatar-photo.uploaded{background-size:cover;background-position:center}.animal-avatar{width:47px;height:47px;flex:0 0 auto;border-radius:50%;background-image:url(/assets/animal-avatars.png);background-size:300% 200%;background-repeat:no-repeat;border:2px solid transparent}.avatar-button.active .animal-avatar{border-color:var(--red);box-shadow:0 0 0 3px #fff}.animal-avatar.large{width:74px;height:74px}.avatar-0{background-position:0% 0%}.avatar-1{background-position:50% 0%}.avatar-2{background-position:100% 0%}.avatar-3{background-position:0% 100%}.avatar-4{background-position:50% 100%}.avatar-5{background-position:100% 100%}.avatar-button.active .avatar-photo{border-color:var(--red);box-shadow:0 0 0 3px #fff}.add-child{background:transparent;border:0;display:flex;align-items:center;gap:10px;cursor:pointer}.add-child svg{width:42px;height:42px;padding:10px;border:1px solid #ccd1d5;border-radius:50%}.home-grid{display:grid;grid-template-columns:44% 56%;min-height:520px}.hero-copy{position:relative;display:grid;grid-template-columns:25% 1fr;align-items:center;min-width:0}.restored-home .hero-copy{margin-top:-92px}.hero-photo{position:absolute;left:-34px;top:-4px;bottom:0;width:25%;background:url(/assets/paper-pencil.png) center / cover;border-radius:0 34px 34px 0;box-shadow:14px 12px 30px #34312b14}.hero-content{grid-column:2;padding:10px 30px 20px 12px}.hero-content>p:first-child{font-size:17px;margin:0 0 24px}.hero-content h1{font-family:Avenir Next,Avenir,Segoe UI,sans-serif;font-size:clamp(38px,3.2vw,54px);line-height:1.12;margin:0;letter-spacing:-.04em;font-weight:650}.hero-content h1 em{color:var(--red);font-style:normal}.hero-subtitle{color:#48535c;font-size:16px;line-height:1.55;max-width:410px;margin:22px 0 32px}.hero-actions{display:flex;gap:14px;flex-wrap:wrap}.primary-button,.secondary-button{min-height:70px;border-radius:10px;display:flex;align-items:center;gap:13px;padding:10px 20px;cursor:pointer;border:1px solid #cbd0d4;background:#fff;text-align:left;transition:transform .18s ease,box-shadow .18s ease}.primary-button{background:var(--red);color:#fff;border-color:var(--red);min-width:225px;box-shadow:0 8px 20px #ec3f1f2e}.primary-button:hover,.secondary-button:hover{transform:translateY(-2px);box-shadow:0 10px 24px #181f261f}.primary-button>svg{width:35px;height:35px;padding:8px;border:1px solid rgba(255,255,255,.65);border-radius:50%}.secondary-button>svg{width:26px;height:26px}.primary-button span,.secondary-button span{display:flex;flex-direction:column;gap:4px}.primary-button small{color:#ffe7e0}.secondary-button small{color:var(--muted)}.lesson-shell{border:1px solid #dfe3e6;border-radius:14px;overflow:hidden;box-shadow:0 8px 30px #19222a09;background:#fffffff5}.home-workspace{align-self:stretch}.home-workspace .lesson-title-row{padding:18px 22px 14px}.home-workspace .lesson-title-row h2{font-size:23px}.home-workspace .method-strip{height:76px;padding:0 16px}.home-workspace .method-item>span{width:36px;height:36px}.home-workspace .method-item p{margin-right:20px}.home-workspace .lesson-grid{min-height:282px}.home-workspace .lesson-grid>article{padding:15px 12px 12px}.home-workspace .stroke-canvas{max-width:155px;margin-bottom:3px}.home-workspace .stroke-step-key{display:none}.home-workspace .paper-sample{width:112px;height:142px}.home-workspace .upload-panel{height:168px}.home-workspace .feedback-panel{min-height:188px}.home-workspace .lesson-complete-row{min-height:52px;padding:7px 12px}.lesson-title-row{padding:22px 24px 18px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--line)}.lesson-title-row small{color:var(--muted)}.lesson-title-row h2{margin:5px 0 0;font-size:25px}.lesson-category{padding:7px 10px;border-radius:999px;background:#f3f6f8;color:var(--muted);font-size:11px;text-transform:capitalize}.link-button,.article-link{border:0;background:transparent;color:var(--blue);display:flex;align-items:center;gap:7px;cursor:pointer;padding:6px}.link-button svg,.article-link svg{width:17px;height:17px}.method-strip{height:86px;display:grid;grid-template-columns:repeat(4,1fr);align-items:center;padding:0 22px}.method-item{display:flex;align-items:center;min-width:0;color:var(--blue);position:relative}.method-item:first-child{color:var(--red)}.method-item:nth-child(3){color:var(--green)}.method-item>span{width:40px;height:40px;border-radius:50%;display:grid;place-items:center;background:color-mix(in srgb,currentColor 9%,white)}.method-item p{display:flex;flex-direction:column;gap:3px;margin:0 24px 0 9px}.method-item small{color:var(--muted);font-size:11px;white-space:nowrap}.method-arrow{position:absolute;right:5px;color:#aab1b7;width:18px}.lesson-grid{margin:0 9px 9px;border:1px solid #e2e5e7;border-radius:11px;display:grid;grid-template-columns:1fr 1fr 1fr 1.12fr;min-height:300px;overflow:hidden}.lesson-grid>article{padding:19px 15px 14px;min-width:0;border-right:1px solid var(--line)}.lesson-grid>article:last-child{border-right:0}.lesson-grid h3{font-size:13px;margin:0 0 12px}.lesson-grid article>p{font-size:12px;line-height:1.5;color:#4c565f;min-height:36px}.letter-stage{width:150px;height:165px;margin:8px auto 5px;position:relative;overflow:hidden}.dynamic-glyph{width:150px;height:165px;margin:8px auto 5px;position:relative;overflow:hidden;display:grid;place-items:center;background:linear-gradient(transparent 49%,#dfe9f2 50%,transparent 51%),linear-gradient(90deg,transparent 49%,#eef2f4 50%,transparent 51%)}.stroke-canvas{width:min(100%,360px);aspect-ratio:200 / 260;margin:0 auto 12px;background:#fff}.stroke-canvas svg{width:100%;height:100%;overflow:visible}.guide-line{fill:none;stroke:#dfe9f2;stroke-width:1.5;stroke-dasharray:4 5}.guide-line.vertical{stroke:#edf1f4}.animated-stroke{fill:none;stroke:#555d63;stroke-width:8;stroke-linecap:round;stroke-linejoin:round}.playing .animated-stroke{stroke-dasharray:1;stroke-dashoffset:1;animation:drawRealStroke .72s ease-out forwards;animation-delay:calc(var(--stroke-index) * .9s)}@keyframes drawRealStroke{to{stroke-dashoffset:0}}.stroke-label{fill:var(--red);font:700 12px Inter,sans-serif}.stroke-step-key{display:flex;justify-content:center;flex-wrap:wrap;gap:8px;margin-bottom:12px}.stroke-step-key span{display:flex;align-items:center;gap:5px;font-size:11px;color:var(--muted)}.stroke-step-key b{width:20px;height:20px;display:grid;place-items:center;border-radius:50%;background:#fff0ec;color:var(--red)}.dynamic-glyph>span{font:112px/1 Georgia,Times New Roman,serif;color:#656b70}.dynamic-glyph .stroke-reveal{background:#fff}.letter-stage img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;transform:scale(1.14)}.stroke-reveal{position:absolute;top:0;right:0;bottom:0;left:0;background:#fff;transform:translate(101%)}.playing .stroke-reveal{animation:revealDiagram 2.4s steps(3,end) both}@keyframes revealDiagram{0%{transform:translate(0)}to{transform:translate(101%)}}.text-action{margin:auto;border:0;color:var(--red);background:transparent;display:flex;align-items:center;gap:7px;font-size:11px;cursor:pointer}.text-action svg{width:32px;height:32px;border:1px solid #d7dadd;border-radius:50%;padding:9px}.paper-sample{width:126px;height:158px;margin:5px auto 9px;background:#fbfaf5 url(/assets/paper-pencil.png) center / cover;box-shadow:0 9px 18px #1f232621;transform:rotate(-4deg);display:grid;place-items:center}.paper-sample span{font:400 108px Comic Sans MS,cursive;color:#403e3bb3}.paper-sample.dynamic span{font-size:clamp(44px,6vw,88px);max-width:100%;overflow:hidden}.article-link{font-size:11px;margin:auto}.upload-panel{height:184px;border:2px dashed #a9cdf3;border-radius:9px;display:grid;place-items:center;position:relative;overflow:hidden;background:#fbfdff}.upload-panel input{display:none}.upload-panel>button{border:0;background:transparent;color:var(--blue);cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:5px}.upload-panel small{color:#4b78ad}.upload-icon{width:48px;height:48px;border-radius:50%;background:#edf5ff;display:grid;place-items:center;margin-bottom:5px}.upload-panel img{width:100%;height:100%;object-fit:cover}.replace-photo{position:absolute;right:6px;top:6px;background:#fff!important;color:var(--ink)!important;padding:5px 8px;border-radius:6px!important;box-shadow:0 2px 8px #0000001f}.analysing{position:absolute;left:8px;right:8px;bottom:8px;background:#17202ad1;color:#fff;padding:7px;border-radius:6px;font-size:11px;text-align:center}.feedback-panel{min-height:205px;border:1px solid #bfd6bc;background:#fbfdf9;border-radius:9px;padding:15px 13px;position:relative;transition:background .25s ease,transform .25s ease}.feedback-panel.revealed{background:#f5fbf2;transform:translateY(-2px)}.feedback-heading{display:flex;gap:9px;align-items:center}.feedback-heading>span{width:29px;height:29px;background:var(--green);color:#fff;display:grid;place-items:center;border-radius:50%}.feedback-panel p{color:#30373c!important;font-size:12px!important;line-height:1.55!important;min-height:0!important;margin:13px 0}.tip{border-top:1px solid #dce5da;padding-top:11px;display:flex;flex-direction:column;gap:4px;font-size:11px;max-width:85%}.tip strong{color:var(--green)}.feedback-leaf{position:absolute;right:8px;bottom:9px;color:var(--green);opacity:.7}.feedback-status{display:inline-flex;margin-top:12px;padding:6px 9px;border-radius:999px;font-size:10px;font-weight:700}.feedback-status.passed{background:#e9f6e6;color:#397536}.feedback-status.retry{background:#fff0ec;color:#a83d28}.lesson-complete-row{min-height:60px;border-top:1px solid var(--line);padding:10px 18px;display:flex;align-items:center;justify-content:space-between;gap:15px}.lesson-complete-row>span{color:var(--muted);font-size:11px}.lesson-complete-row button{border:0;border-radius:8px;background:var(--green);color:#fff;padding:10px 14px;display:flex;align-items:center;gap:7px;cursor:pointer}.lesson-complete-row button:disabled{opacity:.65}.lesson-complete-row button:disabled{cursor:not-allowed;background:#aeb5b9;box-shadow:none}.lesson-preview-card{align-self:stretch;border:1px solid var(--line);border-radius:16px;padding:42px;display:grid;align-content:center;justify-items:start;background:#fff;box-shadow:0 12px 38px #19222a0e}.preview-glyph{font:88px/1 Georgia,serif;color:var(--red);margin:4px 0 12px}.lesson-preview-card h2{font-size:30px;margin:0 0 8px}.lesson-preview-card>p:not(.eyebrow){color:var(--muted);line-height:1.6;max-width:480px}.lesson-card-actions{display:flex;flex-wrap:wrap;align-items:center;gap:10px;margin-top:22px}.preview-start{border:0;border-radius:9px;background:var(--red);color:#fff;padding:13px 17px;display:flex;gap:9px;align-items:center;cursor:pointer}.preview-worksheet{border:1px solid #cfd5d9;border-radius:9px;background:#fff;color:var(--ink);padding:12px 15px;display:flex;gap:8px;align-items:center;cursor:pointer}.preview-start:hover,.preview-worksheet:hover{transform:translateY(-1px);box-shadow:0 8px 18px #19222a17}.reward-shelf{border:1px solid var(--line);border-radius:16px;margin:32px 0 0;padding:24px 28px;display:grid;grid-template-columns:minmax(220px,.8fr) 2fr;gap:28px;align-items:center;background:linear-gradient(120deg,#fffaf1,#fff)}.reward-shelf h2{margin:5px 0 0;font-size:22px;letter-spacing:-.025em}.reward-list{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.reward-list article{min-height:82px;border:1px dashed #d8d3c7;border-radius:12px;padding:13px;display:flex;align-items:center;gap:11px;background:#fffc}.reward-list article>span{width:42px;height:42px;border-radius:50%;display:grid;place-items:center;background:#eef1f3;color:#9ca3a8}.reward-list article.earned{border-style:solid;border-color:#efc45a;box-shadow:0 6px 18px #966c1714}.reward-list article.earned>span{background:#fff0ad;color:#d48800;transform:rotate(-5deg)}.reward-list article div{display:grid;gap:4px}.reward-list article small{color:var(--muted)}.lesson-view{max-width:1320px;margin:auto;padding:28px 0 70px}.lesson-view-bar{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;min-height:64px;border-bottom:1px solid var(--line)}.lesson-view-bar button{border:0;background:transparent;display:flex;align-items:center;gap:7px;cursor:pointer}.lesson-view-bar>div{text-align:center;display:flex;flex-direction:column;gap:3px}.lesson-view-bar>div span{color:var(--muted);font-size:11px}.lesson-view-bar .quiet-action{justify-self:end}.lesson-focus-copy{text-align:center;max-width:680px;margin:42px auto 28px}.lesson-focus-copy h1{font-size:clamp(38px,5vw,64px);margin:0 0 12px;letter-spacing:-.045em}.lesson-focus-copy>p:last-child{color:var(--muted);font-size:17px;line-height:1.6}.lesson-shell.immersive{border-radius:18px}.immersive .method-strip{min-height:96px}.immersive-grid{grid-template-columns:1.15fr .85fr;min-height:760px}.immersive-grid>article{min-height:370px;padding:28px;border-bottom:1px solid var(--line)}.immersive-grid>article:nth-child(2n){border-right:0}.immersive-grid>article:nth-last-child(-n+2){border-bottom:0}.immersive-grid h3{font-size:17px}.immersive-grid article>p{font-size:14px;min-height:0}.stroke-lesson-panel{display:flex;flex-direction:column}.stroke-lesson-panel .letter-animation{flex:1;display:grid;align-content:center}.immersive-grid .paper-sample{width:190px;height:235px}.immersive-grid .upload-panel{height:285px;margin-top:20px}.immersive-grid .feedback-panel{min-height:285px;margin-top:20px;padding:25px}.gender-field{border:0;padding:0;margin:0;display:grid;grid-template-columns:repeat(3,1fr);gap:7px}.gender-field legend{font-size:13px;font-weight:600;margin-bottom:7px}.gender-field label{border:1px solid var(--line);border-radius:8px;padding:9px 7px;display:flex;align-items:center;justify-content:center;text-align:center;cursor:pointer;font-weight:500}.gender-field label.selected{border-color:var(--red);background:#fff5f1;color:var(--red)}.gender-field input{display:none}.avatar-upload-field{cursor:pointer}.avatar-upload-preview{border:1px dashed #bfc7cd;border-radius:10px;padding:12px;display:grid;grid-template-columns:74px 1fr;column-gap:13px;align-items:center}.avatar-upload-preview img{width:74px;height:74px;border-radius:50%;object-fit:cover;grid-row:span 2}.avatar-upload-preview>.animal-avatar{grid-row:span 2}.avatar-upload-preview b{align-self:end}.avatar-upload-preview small{color:var(--muted);align-self:start;line-height:1.35}.file-input{position:absolute;width:1px!important;height:1px!important;opacity:0;pointer-events:none}.progress-row{margin-top:28px;border-top:1px solid var(--line);display:grid;grid-template-columns:1.05fr 1.12fr .95fr}.home-progress{margin-top:14px}.progress-row>article{padding:22px 28px 12px 8px;min-width:0}.progress-row>article+article{border-left:1px solid var(--line);padding-left:28px}.eyebrow{margin:0 0 7px;color:#59626a;font-size:13px}.progress-row h3{margin:0;font-size:17px}.section-title-line{display:flex;justify-content:space-between;align-items:baseline}.section-title-line span{font-size:12px;color:var(--muted)}.letter-chips{display:flex;gap:10px;margin:15px 0}.letter-chips button{width:42px;height:42px;border-radius:50%;border:1px solid #9bbf99;background:#fff;color:#437a40;font-size:20px;position:relative}.letter-chips button.current{background:var(--red);border-color:var(--red);color:#fff}.letter-chips button.done{background:var(--green);color:#fff;border-color:var(--green)}.letter-chips svg{position:absolute;width:14px;height:14px;right:-2px;bottom:-2px;background:var(--green);color:#fff;border-radius:50%;padding:2px}.letter-chips button.more{border-color:#d8dcdf;color:#697178;font-size:12px}.progress-track{height:4px;background:#e7e9e7;border-radius:4px;overflow:hidden}.progress-track span{display:block;width:23%;height:100%;background:var(--green)}.supporting{color:var(--muted);font-size:12px}.week{display:flex;justify-content:space-between;margin:16px 0}.week>div{text-align:center}.week>div span{width:35px;height:35px;border:1px solid #d6dade;display:grid;place-items:center;border-radius:50%;margin-bottom:5px;color:#fff}.week .complete span{background:var(--green);border-color:var(--green)}.week .today span{border:2px solid #4e95ee}.week small{color:var(--muted);font-size:10px}.streak{display:flex;align-items:center;gap:5px;font-size:12px}.streak svg{color:var(--green)}.streak span{color:var(--muted);margin-left:auto;border-left:1px solid var(--line);padding-left:15px}.stage-list{display:grid;gap:8px;margin-top:17px}.stage-list span{display:flex;align-items:center;gap:9px;color:#46515a;font-size:12px}.stage-list b{width:24px;height:24px;border-radius:50%;background:#eef5ed;color:var(--green);display:grid;place-items:center}.explore button{width:100%;border:0;border-bottom:1px solid var(--line);background:transparent;padding:12px 2px;display:grid;grid-template-columns:42px 1fr 20px;align-items:center;gap:10px;text-align:left;cursor:pointer}.explore button>span{color:var(--blue)}.explore button>span svg{width:30px;height:30px}.explore p{margin:0;display:flex;flex-direction:column;gap:3px}.explore small{color:var(--muted);font-size:11px}.explore button>svg{width:16px;color:#9da4aa}.character-icon{width:36px;height:36px;border:1px solid var(--green);border-radius:8px;display:grid;place-items:center;color:var(--green)!important;font:22px Georgia,serif}.parent-banner{width:100%;min-height:66px;border:1px solid #f0ddbb;background:#fffbf3;border-radius:10px;margin-top:18px;padding:14px 28px;display:flex;align-items:center;gap:14px;cursor:pointer;text-align:left}.parent-banner>svg{width:25px;height:25px}.parent-banner>span{color:var(--muted);font-size:12px}.parent-banner b{color:var(--red);font-size:12px;margin-left:auto;display:flex;align-items:center;gap:10px}.simple-view{padding:72px 4vw 80px;max-width:1180px;margin:auto}.simple-view>h1{font-size:clamp(42px,5vw,68px);letter-spacing:-.045em;margin:0;max-width:760px}.view-intro{color:var(--muted);font-size:17px;line-height:1.6;max-width:650px;margin:20px 0 45px}.alphabet-grid{display:grid;grid-template-columns:repeat(7,1fr);border-top:1px solid var(--line);border-left:1px solid var(--line)}.alphabet-grid button{min-height:118px;background:#fff;border:0;border-right:1px solid var(--line);border-bottom:1px solid var(--line);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;cursor:pointer}.alphabet-grid button:hover{background:#fff8f5;color:var(--red)}.alphabet-grid span{font:42px Georgia,serif}.alphabet-grid small{color:var(--muted)}.filter-tabs{display:flex;gap:8px;overflow-x:auto;margin-bottom:22px;padding-bottom:4px}.filter-tabs button{white-space:nowrap;border:1px solid var(--line);background:#fff;border-radius:999px;padding:9px 14px;cursor:pointer}.filter-tabs button.active{background:var(--ink);color:#fff;border-color:var(--ink)}.course-sections{display:grid;gap:56px}.course-section-header{display:flex;justify-content:space-between;align-items:end;margin-bottom:18px}.course-section-header h2{font-size:30px;margin:0 0 7px}.course-section-header p{color:var(--muted);margin:0}.lesson-list{display:grid;grid-template-columns:repeat(3,1fr);border-top:1px solid var(--line);border-left:1px solid var(--line)}.lesson-list button{min-height:94px;border:0;border-right:1px solid var(--line);border-bottom:1px solid var(--line);background:#fff;padding:15px;display:grid;grid-template-columns:55px 1fr 20px;align-items:center;gap:12px;text-align:left;cursor:pointer}.lesson-list button:hover,.lesson-list button.selected{background:#fff7f4}.lesson-glyph{font:34px Georgia,serif;text-align:center;color:var(--red)}.lesson-list button>span:nth-child(2){display:flex;flex-direction:column;gap:6px;min-width:0}.lesson-list small{color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.lesson-list svg{width:17px}.lesson-list .lesson-done{color:#fff;background:var(--green);border-radius:50%;padding:3px}.simple-view .progress-row{margin-top:65px}.milestones{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:38px}.milestones>div{border-top:3px solid var(--green);background:#f7fbf6;padding:24px;display:flex;gap:16px;align-items:center}.milestones svg{color:var(--green);width:26px;height:26px}.milestones span{display:flex;flex-direction:column;gap:5px}.milestones small{color:var(--muted)}.parent-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}.parent-grid article{padding:28px;border:1px solid var(--line);border-radius:12px}.parent-grid article>svg{color:var(--red)}.parent-grid h3{font-size:22px;margin:20px 0 8px}.parent-grid p{color:var(--muted);line-height:1.55;min-height:75px}.parent-grid a{text-decoration:none;width:fit-content}.curriculum-note{margin-top:45px;border-top:1px solid var(--line);padding-top:30px;max-width:820px}.curriculum-note h2{font-size:27px;margin:0 0 12px}.curriculum-note p{color:var(--muted);line-height:1.7}.settings-row{display:flex;justify-content:space-between;align-items:center;border-top:1px solid var(--line);margin-top:45px;padding:25px 0}.settings-row>span{display:flex;flex-direction:column;gap:5px}.settings-row small{color:var(--muted)}.toggle{width:52px;height:29px;padding:3px;border:0;border-radius:20px;background:#cbd0d4;cursor:pointer;transition:background .2s}.toggle i{display:block;width:23px;height:23px;border-radius:50%;background:#fff;transition:transform .2s;box-shadow:0 1px 3px #00000026}.toggle.on{background:var(--green)}.toggle.on i{transform:translate(23px)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#141a1f8c;z-index:20;display:grid;place-items:center;padding:20px}.auth-modal{position:relative;width:min(460px,94vw);background:#fff;border-radius:15px;padding:34px;box-shadow:0 24px 80px #0000003d}.auth-modal.compact{width:min(420px,94vw)}.auth-modal h2{margin:5px 0 8px;font-size:30px;letter-spacing:-.03em}.auth-modal>p:not(.eyebrow){color:var(--muted);line-height:1.55}.modal-close{position:absolute;top:15px;right:15px;width:36px;height:36px;border-radius:50%;border:1px solid var(--line);background:#fff;display:grid;place-items:center;cursor:pointer}.auth-modal form{display:grid;gap:15px;margin-top:24px}.auth-modal label{display:grid;gap:7px;font-size:13px;font-weight:600}.auth-modal input{width:100%;height:46px;border:1px solid #ccd2d7;border-radius:8px;padding:0 12px}.auth-modal input:focus{outline:3px solid rgba(31,109,204,.14);border-color:var(--blue)}.primary-submit{min-height:47px;border:0;border-radius:8px;background:var(--red);color:#fff;font-weight:700;cursor:pointer}.auth-switch{width:100%;border:0;background:transparent;color:var(--blue);margin-top:17px;cursor:pointer}.form-message{padding:10px 12px;border-radius:7px;background:#fff5df;color:#70531a;font-size:12px;line-height:1.45}.demo-notice{display:block;color:var(--muted);text-align:center;margin-top:15px}.worksheet-modal{width:min(900px,96vw);max-height:95vh;background:#f2f2ef;border-radius:14px;overflow:auto;box-shadow:0 24px 80px #00000040}.worksheet-toolbar{min-height:70px;background:#fff;display:flex;align-items:center;justify-content:space-between;padding:14px 20px;border-bottom:1px solid var(--line);position:sticky;top:0;z-index:2}.worksheet-toolbar>div{display:flex;align-items:center;gap:10px}.worksheet-toolbar>div:first-child{flex-direction:column;align-items:flex-start;gap:2px}.worksheet-toolbar span{color:var(--muted);font-size:12px}.worksheet-toolbar button{border:1px solid #d5dadd;background:#fff;border-radius:8px;padding:9px 13px;display:flex;align-items:center;gap:7px;cursor:pointer}.worksheet-toolbar .icon-button{padding:9px}.worksheet-page{width:720px;min-height:950px;background:#fff;margin:28px auto;padding:48px 54px;box-shadow:0 4px 18px #00000017}.worksheet-page header{display:flex;justify-content:space-between;align-items:center;border-bottom:2px solid var(--ink);padding-bottom:12px}.worksheet-page header span{font-weight:800;letter-spacing:.18em}.worksheet-page header p{margin:0;font-size:12px}.worksheet-page h2{font-size:28px;margin:35px 0 8px}.worksheet-page>p{color:var(--muted)}.stroke-breakdown{margin:26px 0 22px;padding:16px 18px;border:1px solid #d8e4ec;border-radius:10px;background:#fbfdff}.stroke-breakdown h3{margin:0 0 12px;font-size:15px}.stroke-breakdown>div{display:flex;gap:10px;flex-wrap:wrap}.stroke-breakdown article{width:92px;height:116px;position:relative;border:1px solid #dbe4ea;border-radius:8px;background:#fff}.stroke-breakdown article b{position:absolute;top:7px;left:8px;z-index:1;width:21px;height:21px;border-radius:50%;display:grid;place-items:center;background:var(--red);color:#fff;font-size:11px}.stroke-breakdown svg{width:100%;height:100%}.worksheet-stroke{fill:none;stroke:#27333b;stroke-width:8;stroke-linecap:round;stroke-linejoin:round}.worksheet-stroke+.worksheet-stroke{stroke:#607887}.stroke-breakdown marker path{fill:var(--red)}.practice-guide-row{height:132px;position:relative;margin-bottom:18px;overflow:hidden;background:#fff}.practice-guide-row .guide-line{position:absolute;left:0;right:0;height:1px;background:#7faed3}.practice-guide-row .guide-line.top{top:8%}.practice-guide-row .guide-line.middle{top:42%;background:repeating-linear-gradient(90deg,#a9c9e1 0 7px,transparent 7px 13px)}.practice-guide-row .guide-line.baseline{top:74%;background:#4f91c4;height:2px}.practice-guide-row .guide-line.descender{top:96%}.guide-examples{position:absolute;top:0;right:0;bottom:3px;left:0;display:grid;grid-template-columns:repeat(4,1fr);align-items:stretch}.trace-glyph{width:100%;height:100%;opacity:.17}.trace-glyph .worksheet-stroke{stroke-width:9}.practice-guide-row.lowercase .guide-examples{transform:translateY(1px) scale(.85);transform-origin:center 72%}.celebration-backdrop{z-index:30}.celebration-card{width:min(430px,92vw);padding:38px;border-radius:18px;background:#fff;text-align:center;box-shadow:0 25px 80px #00000040}.celebration-sticker{width:88px;height:88px;margin:0 auto 18px;border-radius:50%;display:grid;place-items:center;background:#fff1a8;color:#e59300;transform:rotate(-7deg);box-shadow:0 10px 24px #bd81002e}.celebration-sticker svg{width:48px;height:48px}.celebration-card h2{font-size:30px;margin:5px 0 10px}.celebration-card p:not(.eyebrow){color:var(--muted);line-height:1.55}.celebration-card .primary-submit{width:100%;margin-top:10px}.worksheet-page footer{margin-top:35px;padding:18px;background:#fff8ef;border-left:4px solid var(--red)}@media(max-width:1120px){.site-header{grid-template-columns:auto 1fr auto}.site-header nav{gap:22px;justify-content:center}.learner-switcher{justify-content:center}.home-grid{grid-template-columns:1fr;gap:30px}.hero-copy{min-height:460px;grid-template-columns:28% 1fr}.restored-home .hero-copy{margin-top:0}.hero-photo{width:27%}.hero-content{padding-left:30px}.lesson-shell{max-width:920px;width:100%;margin:auto}}@media(max-width:820px){.site-header{height:78px;padding:0 18px}.brand strong{font-size:15px}.brand small{font-size:10px}.brand-mark{width:42px;height:42px}.site-header nav{display:none;position:absolute;top:78px;left:0;right:0;height:auto;padding:16px;background:#fff;z-index:10;border-bottom:1px solid var(--line);flex-direction:column;gap:4px}.site-header nav.open{display:flex}.site-header nav button{padding:14px;text-align:left}.site-header nav button:after{bottom:5px}.language-button span,.language-button .ph-caret-down,.account-button span{display:none}.mobile-menu{display:flex;margin-left:8px}.header-tools{display:flex}.app-frame{padding:0 18px 20px}.learner-switcher{height:auto;min-height:90px;gap:12px;overflow-x:auto;justify-content:flex-start}.learner-switcher>span,.avatar-button>span:not(.avatar-photo),.add-child>span{display:none}.hero-copy{display:block;min-height:auto;padding-top:260px}.hero-photo{top:0;left:-18px;right:-18px;width:auto;height:235px;bottom:auto;border-radius:0 0 24px 24px;background-position:center 56%}.hero-content{padding:34px 0}.hero-content h1{font-size:42px}.home-workspace .lesson-grid{grid-template-columns:1fr 1fr}.home-workspace .lesson-grid>article{min-height:300px}.lesson-grid{grid-template-columns:1fr 1fr}.lesson-grid>article:nth-child(2){border-right:0}.lesson-grid>article:nth-child(-n+2){border-bottom:1px solid var(--line)}.method-strip{overflow-x:auto;grid-template-columns:repeat(4,minmax(150px,1fr))}.progress-row,.reward-shelf{grid-template-columns:1fr}.reward-list{grid-template-columns:1fr 1fr 1fr}.progress-row>article+article{border-left:0;border-top:1px solid var(--line);padding-left:8px}.parent-banner>span{display:none}.alphabet-grid{grid-template-columns:repeat(4,1fr)}.milestones,.parent-grid{grid-template-columns:1fr}.lesson-list{grid-template-columns:1fr 1fr}.lesson-view{padding-top:10px}.lesson-view-bar{grid-template-columns:1fr 1fr}.lesson-view-bar>div{display:none}.immersive-grid{grid-template-columns:1fr}.immersive-grid>article{border-right:0;min-height:330px}.immersive-grid>article:nth-last-child(-n+2){border-bottom:1px solid var(--line)}.immersive-grid>article:last-child{border-bottom:0}.worksheet-page{width:94%;min-height:0;padding:30px}}@media(max-width:520px){.brand small{display:none}.hero-actions{display:grid}.primary-button,.secondary-button{width:100%}.lesson-card-actions{display:grid;width:100%}.preview-start,.preview-worksheet{width:100%;justify-content:center}.lesson-grid{grid-template-columns:1fr}.lesson-grid>article{border-right:0;border-bottom:1px solid var(--line)}.method-strip{padding:0 12px}.lesson-title-row{padding:18px}.lesson-title-row .link-button{font-size:0}.letter-chips{gap:6px}.letter-chips button{width:38px;height:38px}.parent-banner{padding:14px}.parent-banner b{font-size:0}.alphabet-grid{grid-template-columns:repeat(3,1fr)}.lesson-list,.reward-list{grid-template-columns:1fr}.lesson-complete-row{align-items:flex-start;flex-direction:column}.gender-field{grid-template-columns:1fr}.worksheet-toolbar>div:first-child span{display:none}}@media print{body>#root>*:not(.modal-backdrop){display:none!important}.modal-backdrop{position:static;background:#fff;display:block;padding:0}.worksheet-modal{width:auto;max-height:none;overflow:visible;box-shadow:none;background:#fff}.worksheet-toolbar{display:none}.worksheet-page{width:100%;min-height:100vh;margin:0;box-shadow:none}}
