/*! tailwindcss v4.2.1 | MIT License | https://tailwindcss.com */@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,::backdrop,:after,:before{--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000}}}@layer theme{:host,:root{--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;--spacing:.25rem;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4,0,.2,1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,::backdrop,:after,:before{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}:host,html{-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;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{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}menu,ol,ul{list-style:none}audio,canvas,embed,iframe,img,object,svg,video{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,optgroup,select,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,::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-day-field,::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-hour-field,::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-millisecond-field,::-webkit-datetime-edit-second-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,::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.fixed{position:fixed}.relative{position:relative}.start{inset-inline-start:var(--spacing)}.table{display:table}.grow{flex-grow:1}.ring{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}}:root{--ink:#1f2a44;--muted:#7b849a;--blue:#5476ed;--paper:#f5f1e8;--line:#ded9cd}*{box-sizing:border-box}body,html{min-height:100%;margin:0}body{background:var(--paper);color:var(--ink);overscroll-behavior:none;-webkit-tap-highlight-color:transparent;font-family:Inter,SF Pro Display,PingFang SC,sans-serif}button{font:inherit}.pwa-tools{z-index:45;align-items:center;gap:8px;display:flex;position:fixed;bottom:18px;right:18px}.offline-badge,.pwa-tools button{color:#fff;background:#253452;border:0;border-radius:13px;min-height:40px;padding:0 14px;font-size:12px;font-weight:800;box-shadow:0 8px 25px #17213c35}.pwa-tools button{cursor:pointer}.offline-badge{background:#ad6a35;align-items:center;display:flex}.install-overlay{z-index:100;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:#17213c80;place-items:center;padding:20px;display:grid;position:fixed;inset:0}.install-guide{width:min(440px,100%);color:var(--ink);background:#fff;border-radius:26px;padding:30px;position:relative;box-shadow:0 30px 90px #10182d55}.install-guide>img{border-radius:18px;width:76px;height:76px;box-shadow:0 8px 22px #2534522b}.install-guide .eyebrow{margin-top:20px}.install-guide h2{margin:0;font:700 29px Georgia,Noto Serif SC,serif}.install-guide ol{color:#5f687c;margin:20px 0;padding-left:23px}.install-guide li{margin:10px 0;padding-left:5px}.install-guide>small{color:#8a8177;background:#f3f1eb;border-radius:12px;padding:12px 14px;line-height:1.55;display:block}.install-close{color:#747b88;cursor:pointer;background:#f0eee9;border:0;border-radius:50%;width:36px;height:36px;font-size:22px;position:absolute;top:16px;right:16px}.app-shell{background:radial-gradient(circle at 45% 10%,#fffdf7 0,#f6f1e8 48%,#eee9df 100%);grid-template-columns:92px 1fr;min-height:100vh;display:grid}.side-rail{color:#fff;background:#253452;flex-direction:column;align-items:center;height:100vh;padding:26px 14px;display:flex;position:sticky;top:0}.brand-mark{border:1px solid #8fa0c2;border-radius:14px;place-items:center;width:46px;height:46px;font:700 25px Georgia,serif;display:grid}.side-rail nav{gap:14px;width:100%;margin:auto 0;display:grid}.nav-item{color:#aab5ce;cursor:pointer;background:0 0;border:0;border-radius:15px;gap:5px;padding:12px 4px;font-size:12px;display:grid}.nav-item span{font-size:24px}.nav-item.active{color:#fff;background:#344769}.mistake-nav{position:relative}.mistake-nav em{color:#fff;background:#e36e64;border-radius:9px;place-items:center;min-width:18px;height:18px;padding:0 4px;font-size:10px;font-style:normal;font-weight:700;display:grid;position:absolute;top:5px;right:9px}.profile{color:#253452;overflow-wrap:anywhere;text-align:center;cursor:pointer;background:#edc893;border:0;border-radius:14px;flex:none;place-items:center;width:64px;min-height:42px;padding:8px 6px;font-size:11px;font-weight:800;line-height:1.2;display:grid;box-shadow:0 0 0 3px #ffffff18}.profile-panel{z-index:50;width:360px;color:var(--ink);text-align:left;background:#fff;border:1px solid #ddd8ce;border-radius:22px;padding:22px;position:absolute;bottom:24px;left:88px;box-shadow:0 24px 70px #17213c42}.profile-panel:before{content:"";background:#fff;border-bottom:1px solid #ddd8ce;border-left:1px solid #ddd8ce;width:16px;height:16px;position:absolute;bottom:14px;left:-8px;transform:rotate(45deg)}.profile-panel-head{justify-content:space-between;align-items:start;display:flex}.profile-panel-head p{color:#9b7652;letter-spacing:.14em;margin:0 0 3px;font-size:11px;font-weight:800}.profile-panel-head h2{margin:0;font:700 26px Georgia,Noto Serif SC,serif}.profile-panel-head>button{color:#7b8190;cursor:pointer;background:#f0eee9;border:0;border-radius:50%;width:34px;height:34px;font-size:22px}.name-editor{margin:20px 0 16px}.name-editor label{color:#838a99;margin-bottom:7px;font-size:12px;font-weight:700;display:block}.name-editor>div{grid-template-columns:1fr auto;gap:8px;display:grid}.name-editor input{min-width:0;color:var(--ink);border:1px solid #d7dbe5;border-radius:11px;outline:0;padding:11px 12px;font-size:15px}.name-editor input:focus{border-color:var(--blue);box-shadow:0 0 0 3px #5476ed17}.name-editor button{background:var(--blue);color:#fff;cursor:pointer;border:0;border-radius:11px;padding:0 15px;font-weight:700}.today-summary{background:#f3f5fc;border-radius:15px;padding:15px}.today-summary>p{color:#6f7890;margin:0 0 11px;font-size:12px;font-weight:700}.today-summary>div{grid-template-columns:repeat(3,1fr);gap:8px;display:grid}.today-summary span{color:#8b92a1;flex-direction:column;font-size:11px;display:flex}.today-summary b{color:#344d8f;margin-bottom:2px;font:700 25px Georgia,serif}.activity-history{margin-top:18px}.history-title{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.history-title b{font-size:13px}.history-title span{color:#9a9fa9;font-size:10px}.history-head,.history-row{text-align:center;grid-template-columns:1.5fr repeat(3,1fr);align-items:center;display:grid}.history-head{color:#9b9fa8;padding:0 7px 6px;font-size:10px}.history-head span:first-child,.history-row span{text-align:left}.history-row{border-top:1px solid #eeeae4;padding:9px 7px;font-size:12px}.history-row span{color:#717887}.history-row b{color:#3b4867}.record-note{color:#aaa5a0;text-align:center;margin-top:13px;font-size:10px;display:block}.learning-page{min-width:0;padding:max(34px,env(safe-area-inset-top)) max(5vw,env(safe-area-inset-right)) max(26px,env(safe-area-inset-bottom)) max(5vw,env(safe-area-inset-left));flex-direction:column;min-height:100vh;display:flex}.topbar{justify-content:space-between;align-items:end;margin-bottom:18px;display:flex;position:relative}.unit-title{text-align:left;color:inherit;cursor:pointer;background:0 0;border:0;padding:0}.unit-title.unit-complete .eyebrow,.unit-title.unit-complete h1{color:#3c9660}.unit-detail{color:#8e94a0;margin-top:7px;font-size:11px;font-weight:600;display:block}.eyebrow{color:#a07952;letter-spacing:.16em;margin:0 0 7px;font-size:13px;font-weight:700}.topbar h1{margin:0;font:700 32px/1.1 Georgia,Noto Serif SC,serif}.topbar h1 span{color:#7d8290;margin-left:10px;font:500 16px sans-serif}.unit-progress{width:210px;color:var(--muted);grid-template-columns:1fr auto;gap:8px;font-size:12px;display:grid}.unit-progress strong{color:var(--ink)}.top-stats{gap:18px}.score-badge,.top-stats{align-items:center;display:flex}.score-badge{color:#8a6b47;background:#fffaf0;border:1px solid #ddd5c8;border-radius:14px;gap:6px;height:42px;padding:0 15px;font-size:13px;box-shadow:0 5px 16px #4238210c}.score-badge span{color:#e0a43b;font-size:17px}.score-badge b{color:#253452;font:700 22px Georgia,serif}.progress-track{background:#dcd9d1;border-radius:8px;grid-column:1/-1;height:6px;overflow:hidden}.progress-track i{background:var(--blue);border-radius:8px;width:30%;height:100%;display:block}.unit-menu{z-index:30;overscroll-behavior:contain;background:#fff;border:1px solid #ddd8ce;border-radius:18px;width:min(560px,75vw);max-height:72vh;padding:8px;position:absolute;top:92px;left:0;overflow-y:auto;box-shadow:0 20px 50px #26324c22}.catalog-summary{z-index:2;color:#fff;letter-spacing:.02em;padding:14px 16px;font-size:12px;font-weight:700}.catalog-summary,.course-tabs{background:#253452;border-radius:17px 17px 10px 10px;margin:-8px -8px 6px;position:sticky;top:-8px}.course-tabs{z-index:4;grid-template-columns:1fr 1fr;gap:5px;padding:8px;display:grid}.unit-menu .course-tabs button{color:#cbd4e8;text-align:center;background:#ffffff0e;border:1px solid #ffffff24;border-radius:10px;justify-content:center;align-items:center;gap:7px;padding:10px 8px;font-size:12px;display:flex}.unit-menu .course-tabs button.active,.unit-menu .course-tabs button:hover{color:#344d8f;background:#fff}.unit-menu .course-tabs small{color:inherit;opacity:.72;font-size:10px}.course-tabs+.catalog-summary{color:#344d8f;background:#e9edf9;border-radius:10px;margin:0 0 6px;position:relative;top:auto}.unit-menu button{width:100%;color:var(--ink);text-align:left;cursor:pointer;background:0 0;border:0;border-radius:12px;grid-template-columns:135px 1fr auto;align-items:center;gap:9px;padding:12px 14px;display:grid}.unit-menu button.selected,.unit-menu button:hover{background:#f0f2fb}.unit-menu em,.unit-menu span{color:#8c93a0;font-size:13px;font-style:normal}.unit-menu button.unit-complete{color:#287a49;background:#eaf7ee}.unit-menu button.unit-complete em,.unit-menu button.unit-complete span{color:#4b9466}.unit-menu button.unit-complete.selected{box-shadow:inset 0 0 0 2px #79bb91}.word-source-switch{background:#f4f1eb;border:1px solid #ddd8ce;border-radius:14px;align-self:center;gap:4px;margin:-4px 0 16px;padding:4px;display:flex}.word-source-switch button{color:#777f8e;cursor:pointer;background:0 0;border:0;border-radius:10px;min-width:130px;padding:10px 16px;font-weight:700}.word-source-switch button.active{color:var(--blue);background:#fff;box-shadow:0 3px 12px #29334c16}.word-source-switch button:disabled{opacity:.42;cursor:not-allowed}.word-source-switch small{min-width:22px;height:22px;color:inherit;background:#e5e8f3;border-radius:12px;place-items:center;margin-left:6px;padding:0 6px;display:inline-grid}.stepper{align-self:center;margin:0 0 16px}.stepper,.stepper div{align-items:center;display:flex}.stepper div{color:#aaa9a4;font-size:12px;font-weight:700}.stepper div:not(:last-child):after{content:"";background:#d4d0c8;width:54px;height:1px;margin:0 10px;display:block}.stepper i{border:1px solid #c8c5bf;border-radius:50%;place-items:center;width:23px;height:23px;margin-right:6px;font-size:11px;font-style:normal;display:grid}.stepper .on{color:var(--blue)}.stepper .on i{background:var(--blue);color:#fff;border-color:var(--blue)}.lesson-grid{flex:1;grid-template-columns:minmax(340px,1fr) minmax(340px,.9fr);gap:24px;min-height:490px;display:grid}.action-card,.word-card{background:#ffffffd6;border:1px solid #cec8bccc;border-radius:30px;box-shadow:0 18px 45px #282d3c12}.word-card{flex-direction:column;display:flex}.word-meta{color:#9a8066;letter-spacing:.15em;border-bottom:1px solid #ece8df;justify-content:space-between;padding:26px 28px;font-size:12px;display:flex}.meaning{color:#59627a;letter-spacing:.05em;font-weight:700}.word-main{text-align:center;margin:auto;padding:40px}.part{color:#9a8066;letter-spacing:.2em;font-size:11px;font-weight:700}.word-main h2{letter-spacing:-.04em;margin:18px 0 12px;font:700 clamp(60px,8vw,96px)/.95 Georgia,serif}.phonetic{color:#68728a;font:24px Georgia,serif}.sound-button{background:var(--blue);color:#fff;cursor:pointer;border:0;border-radius:50%;width:76px;height:76px;padding-left:5px;font-size:24px;box-shadow:0 10px 24px #5476ed55}.hint{color:#9aa0ad;margin-top:18px;font-size:12px}.action-card{text-align:center;background:#fbfaf6;flex-direction:column;justify-content:center;align-items:center;padding:42px;display:flex;position:relative;overflow:hidden}.step-pill{color:#6d7690;align-self:flex-start;font-size:13px}.step-pill span{color:#fff;background:#253452;border-radius:50%;place-items:center;width:26px;height:26px;margin-right:7px;display:inline-grid}.action-card h3{margin:32px 0 8px;font:700 28px Georgia,Noto Serif SC,serif}.action-card>p{color:#8a91a0;margin:0;font-size:14px}.record-button{color:#fff;cursor:pointer;background:#6d86e8;border:9px solid #e1e6fb;border-radius:50%;width:112px;height:112px;margin:54px 0 15px;font-size:38px;box-shadow:0 8px 28px #536ec344}.record-label{font-weight:700;color:#59627a!important}.waveform{align-items:center;gap:4px;height:40px;margin-top:42px;display:flex}.waveform i{background:#d5d9e2;border-radius:5px;width:3px;display:block}.record-button.play{padding-left:10px}.record-button.recording{background:#ef6f62;border-color:#f9d9d4;animation:pulse 1s infinite}.repeat-word{flex-direction:column;align-items:center;margin:12px 0 2px;display:flex}.repeat-word small{color:#6172a8;background:#edf0fa;border-radius:999px;margin-bottom:8px;padding:4px 10px;font-weight:700}.repeat-word strong{letter-spacing:-.02em;font:700 40px/.95 Georgia,serif}.repeat-word span{color:#68728a;margin-top:7px;font:17px Georgia,serif}.repeat-word em{color:#725f4c;background:#eee9df;border-radius:999px;margin-top:7px;padding:4px 12px;font-size:12px;font-style:normal;font-weight:700}.spelling-strip{flex-wrap:wrap;justify-content:center;gap:6px;margin:15px 0 2px;display:flex}.spelling-strip i{color:#506bd1;background:#eef1ff;border-radius:9px;place-items:center;width:30px;height:34px;font:700 17px Georgia,serif;transition:all .2s;display:grid}.spelling-strip.done i{color:#41925e;background:#e9f7ed}.action-card.repeat h3{margin:12px 0 5px}.action-card.repeat .record-button{border-width:7px;width:82px;height:82px;margin:16px 0 8px}.action-card.repeat .waveform{margin-top:10px}@keyframes pulse{50%{opacity:.5}}.sentence{max-width:470px;font:700 25px/1.5 Georgia,Noto Serif SC,serif!important}.sentence-zh{margin:0 0 30px!important}.spell-box{background:#fff;border:2px solid #ccd3e3;border-radius:16px;grid-template-columns:1fr auto;width:100%;transition:all .2s;display:grid;overflow:hidden}.sentence-repeat-card{background:#fff;border:1px solid #ded8cc;border-radius:18px;width:100%;margin:26px 0 4px;padding:22px 24px}.sentence-repeat-card h3{margin:0!important;font:700 24px/1.45 Georgia,serif!important}.sentence-repeat-card p{color:#8a91a0;margin:10px 0 0;font-size:13px}.record-button.sentence-mic{width:92px;height:92px;margin:24px 0 10px}.action-card.sentenceRepeat .waveform{margin-top:16px}.spell-box:focus-within{border-color:var(--blue);box-shadow:0 0 0 4px #5476ed18}.spell-box input{min-width:0;color:var(--ink);background:0 0;border:0;outline:0;padding:17px;font-size:18px}.spell-box button{color:#fff;cursor:pointer;background:#253452;border:0;padding:0 23px;font-weight:700}.spell-box.correct{background:#f1fbf4;border-color:#5aaf7a}.spell-box.correct button{background:#5aaf7a;font-size:20px}.feedback{color:#9a7959;opacity:0;min-height:25px;margin-top:22px;font-size:13px;transition:all .2s}.feedback.show{opacity:1}.point-popup{z-index:80;background:#fffaf0;border:1px solid #efd69c;border-radius:22px;flex-direction:column;align-items:center;width:210px;padding:22px;animation:pointIn 1.1s both;display:flex;position:fixed;top:20%;left:50%;transform:translate(-50%);box-shadow:0 22px 60px #352c1f32}.point-popup span{color:#e2a235;font:700 48px/.9 Georgia,serif}.point-popup b{color:#253452;margin-top:10px}.point-popup small{color:#9b866d;margin-top:5px}@keyframes pointIn{0%{opacity:0;transform:translate(-50%,18px)scale(.72)}18%{opacity:1;transform:translate(-50%)scale(1.07)}35%,78%{opacity:1;transform:translate(-50%)scale(1)}to{opacity:0;transform:translate(-50%,-14px)scale(.96)}}.lesson-footer{justify-content:space-between;align-items:center;padding-top:22px;display:flex}.lesson-footer p{color:#9a9eaa;font-size:12px}.lesson-footer p span{color:#9a7959;margin-right:8px;font-weight:700}.lesson-footer button{color:#9b9aa0;background:#d9d7d0;border:0;border-radius:14px;padding:15px 22px;font-weight:700}.lesson-footer button span{margin-left:28px}.lesson-footer button.ready{background:var(--blue);color:#fff;cursor:pointer;box-shadow:0 8px 20px #5476ed35}.activity-page,.result-card,.test-card{background:#fffc;border:1px solid #ddd8ce;border-radius:30px;flex:1;min-height:600px;padding:44px;box-shadow:0 18px 45px #282d3c12}.activity-heading{justify-content:space-between;align-items:center;display:flex}.activity-heading h2{margin:0;font:700 34px Georgia,Noto Serif SC,serif}.match-count{color:var(--blue);font:700 40px Georgia,serif}.match-count span{color:#9ca2ad;font:500 18px sans-serif}.match-board{grid-template-columns:1fr 1fr;gap:54px;max-width:780px;margin:40px auto 0;display:grid}.match-board>div{gap:13px;display:grid}.match-board button{height:70px;color:var(--ink);cursor:pointer;background:#fff;border:1px solid #d8d4cb;border-radius:16px;font:700 20px Georgia,Noto Serif SC,serif;transition:all .18s;box-shadow:0 3px #e4e0d8}.match-board button:hover{border-color:#9babdc;transform:translateY(-2px)}.match-board button.picked{border:2px solid var(--blue);color:var(--blue);box-shadow:none;background:#eef1ff}.match-board button:disabled{color:#54a273;box-shadow:none;opacity:.75;background:#eaf7ee;border-color:#90cba5}.match-board small{color:#8e94a0;margin-top:4px;font:12px sans-serif;display:block}.match-board.wrong button.picked{color:#d85c52;background:#fff1ef;border-color:#e77167;animation:shake .25s}@keyframes shake{25%{transform:translate(-6px)}75%{transform:translate(6px)}}.complete-banner{color:#397551;background:#eaf7ee;border-radius:16px;grid-template-columns:auto 1fr auto;align-items:center;gap:16px;max-width:780px;margin:24px auto 0;padding:18px 20px;display:grid}.complete-banner>span{color:#fff;background:#5aaf7a;border-radius:50%;place-items:center;width:38px;height:38px;font-weight:700;display:grid}.complete-banner b{font-size:16px}.complete-banner p{margin:3px 0 0;font-size:12px}.complete-banner button{color:#fff;cursor:pointer;background:#4d9e6b;border:0;border-radius:12px;padding:13px 18px;font-weight:700}.mistake-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:34px;display:grid}.mistake-grid article{background:#fff;border:1px solid #e1dcd3;border-left:4px solid #e3766d;border-radius:15px;grid-template-columns:1fr auto;align-items:center;padding:18px 20px;display:grid}.mistake-grid article>div{align-items:baseline;gap:10px;display:flex}.mistake-grid b{font:700 22px Georgia,serif}.mistake-grid span{color:#8d94a3;font:13px Georgia,serif}.mistake-grid p{color:#7f6956;grid-column:1;margin:7px 0 0;font-size:13px}.mistake-grid button{width:42px;height:42px;color:var(--blue);cursor:pointer;background:#eef1ff;border:0;border-radius:50%;grid-area:1/2/3}.mistake-empty{color:#8c93a0;flex-direction:column;justify-content:center;align-items:center;min-height:420px;display:flex}.mistake-empty span{color:#4c9d69;background:#eaf7ee;border-radius:50%;place-items:center;width:72px;height:72px;font-size:30px;display:grid}.mistake-empty h3{color:var(--ink);margin:18px 0 5px;font:700 25px Georgia,Noto Serif SC,serif}.mistake-empty p{margin:0}.mistake-grid article.mastered{background:#eef9f2;border-color:#8bc7a0 #8bc7a0 #8bc7a0 #4ba76a}.mistake-grid article.mastered b,.mistake-grid article.mastered p{color:#287a49}.mistake-grid article.mastered button{color:#287a49;background:#d9f0e1}.mastered-mark{color:#3d9360;grid-column:1;margin-top:8px;font-size:12px;font-weight:700}.test-card{padding:0;overflow:hidden}.test-top{color:#7e8593;border-bottom:1px solid #ebe7df;grid-template-columns:1fr auto 1fr;align-items:center;height:76px;padding:0 34px;display:grid}.test-top b{color:var(--ink)}.test-top em{text-align:right;color:#9a7959;font-style:normal;font-weight:700}.test-progress{background:#e5e2db;height:5px}.test-progress i{background:var(--blue);height:100%;transition:all .3s;display:block}.test-question{text-align:center;max-width:600px;margin:0 auto;padding:70px 30px}.test-question>p{color:#9399a5}.test-question h2{margin:18px 0;font:700 54px Georgia,Noto Serif SC,serif}.mini-sound{color:var(--blue);cursor:pointer;background:0 0;border:0;font-weight:700}.test-input{background:#fff;border:2px solid #ccd3e3;border-radius:18px;margin:45px 0 20px;overflow:hidden}.test-input input{text-align:center;width:100%;color:var(--ink);background:0 0;border:0;outline:0;padding:20px;font:700 27px Georgia,serif}.test-input span{color:#9399a5;border-top:1px solid #eeeae3;padding:10px;font-size:13px;display:block}.test-input.correct{background:#f2fbf5;border-color:#5aaf7a}.test-input.correct span{color:#3f8f5d}.test-input.incorrect{background:#fff5f3;border-color:#e3766d}.test-input.incorrect span{color:#c45249}.primary-action{background:var(--blue);color:#fff;cursor:pointer;border:0;border-radius:14px;min-width:210px;padding:16px 28px;font-weight:700;box-shadow:0 8px 22px #5476ed3d}.primary-action.auto-next{opacity:1;cursor:default;background:#57a975;box-shadow:0 8px 22px #57a97532}.retry-note{color:#c2675f!important;margin:12px 0 0!important;font-size:12px!important}.result-card{text-align:center}.result-card,.score-ring{flex-direction:column;justify-content:center;align-items:center;display:flex}.score-ring{outline:5px solid var(--blue);border:12px solid #e1e6fb;border-radius:50%;width:170px;height:170px;margin-bottom:34px}.score-ring strong{color:var(--blue);font:700 68px/.9 Georgia,serif}.score-ring span{color:#7b849a;margin-top:10px}.result-card h2{margin:8px 0;font:700 34px Georgia,Noto Serif SC,serif}.result-card>p:not(.eyebrow){color:#8c93a0}.result-actions{gap:12px;margin-top:25px;display:flex}.result-actions button{color:#4f5d7c;cursor:pointer;background:#fff;border:1px solid #bbc3d5;border-radius:13px;padding:14px 25px;font-weight:700}.result-actions button:last-child{background:var(--blue);color:#fff;border-color:var(--blue)}@media (max-width:850px){.app-shell{grid-template-columns:74px 1fr}.learning-page{padding:24px}.lesson-grid{grid-template-columns:1fr}.action-card{min-height:430px}.side-rail{padding-inline:9px}.activity-page,.result-card,.test-card{min-height:700px}.match-board{gap:25px}}@media (max-width:620px){.app-shell{display:block}.side-rail{z-index:20;flex-direction:row;gap:5px;width:100%;height:72px;padding:8px;position:fixed;top:auto;bottom:0}.brand-mark{display:none}.side-rail nav{justify-content:space-around;width:100%;min-width:0;margin:0;display:flex}.nav-item{width:64px;padding:5px}.nav-item span{font-size:18px}.profile{width:54px;min-height:38px;margin-right:3px;padding:6px 4px;font-size:10px}.profile-panel{width:auto;max-height:calc(100vh - 100px);position:fixed;bottom:82px;left:12px;right:12px;overflow-y:auto}.profile-panel:before{display:none}.pwa-tools{bottom:82px;right:12px}.learning-page{padding:22px 16px 94px}.topbar{align-items:start}.top-stats{gap:7px}.score-badge{padding:0 9px}.score-badge b{font-size:18px}.score-badge{font-size:0}.unit-progress{width:105px}.topbar h1{font-size:25px}.topbar h1 span{display:none}.word-source-switch{width:100%;margin-top:0}.word-source-switch button{flex:1;min-width:0}.stepper div:not(:last-child):after{width:20px}.lesson-grid{min-height:auto}.word-main{padding:35px 20px}.action-card{padding:30px 20px}.lesson-footer p{display:none}.activity-page,.result-card,.test-card{border-radius:22px;min-height:620px;padding:24px}.activity-heading h2{font-size:25px}.match-board{gap:12px}.match-board button{height:64px;font-size:16px}.complete-banner{grid-template-columns:auto 1fr}.complete-banner button{grid-column:1/-1}.test-card{padding:0}.test-question{padding:50px 20px}.test-question h2{font-size:42px}.mistake-grid{grid-template-columns:1fr}}@media (pointer:coarse){button{min-height:44px}.record-button,.sound-button{touch-action:manipulation}}@media (prefers-reduced-motion:reduce){*,:after,:before{transition-duration:.01ms!important;animation-duration:.01ms!important}}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}