:root{--paper: #F6F0E2;--cream: #EFE6D2;--ivory: #FCFAF5;--card: #FFFFFF;--card-2: #FBF8F1;--tint-warm: #FBF1E5;--tint-mint: #E8F6EE;--tint-sky: #E5EEF5;--tint-coral: #FFE6DC;--tint-mango: #FFF1CF;--tint-lavender:#EDE5FA;--ink: #1A1410;--ink-2: #3A2F26;--ink-3: #5C4F40;--muted: #8C7F70;--muted-2: #A89A87;--line: #E7DDC8;--line-2: #D7CAAF;--line-strong: #2A2017;--coral: #FF6B47;--coral-deep: #E84A2C;--coral-soft: #FFB39A;--mango: #FFB627;--mint: #2FBF8F;--mint-deep: #1E9A6E;--ocean: #2A6FA8;--lavender: #8B6FE6;--berry: #E84A6F;--plum: #6B3FA0;--sun: #F7C948;--success: var(--mint);--warn: var(--mango);--danger: var(--berry);--streak: var(--coral);--primary: var(--coral);--primary-deep: var(--coral-deep);--r-xs: 6px;--r-sm: 10px;--r-md: 14px;--r-lg: 20px;--r-xl: 28px;--r-pill: 999px;--shadow-sm: 0 1px 2px rgba(26, 20, 16, .04), 0 2px 6px rgba(26, 20, 16, .04);--shadow-md: 0 4px 14px rgba(26, 20, 16, .06), 0 1px 3px rgba(26, 20, 16, .04);--shadow-lg: 0 16px 40px rgba(26, 20, 16, .1), 0 4px 12px rgba(26, 20, 16, .06);--shadow-pop:0 12px 28px -8px rgba(255, 107, 71, .45), 0 4px 10px rgba(232, 74, 44, .18);--font-display: "Bricolage Grotesque", "Plus Jakarta Sans", system-ui, sans-serif;--font-body: "Plus Jakarta Sans", -apple-system, system-ui, sans-serif;--font-mono: "JetBrains Mono", ui-monospace, "Geist Mono", monospace;--font-serif: "Instrument Serif", "Cormorant Garamond", Georgia, serif;--density: 1}[data-density=compact]{--density: .85}[data-density=cozy]{--density: 1.05}*{box-sizing:border-box}html,body{margin:0;padding:0;background:var(--paper);color:var(--ink);font-family:var(--font-body);font-feature-settings:"ss01" on,"cv11" on;font-size:15px;line-height:1.5;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}body{min-height:100vh;overflow-x:hidden}button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}input,textarea,select{font:inherit;color:inherit}a{color:inherit;text-decoration:none}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#1a14101a;border-radius:999px;border:2px solid transparent;background-clip:padding-box}::-webkit-scrollbar-thumb:hover{background:#1a14102e;border:2px solid transparent;background-clip:padding-box}.app{display:grid;grid-template-columns:248px 1fr;min-height:100vh;background:var(--paper)}.sidebar{position:sticky;top:0;height:100vh;padding:22px 16px;display:flex;flex-direction:column;gap:6px;border-right:1px solid var(--line);background:var(--paper)}.brand{display:flex;align-items:center;gap:10px;padding:8px 10px 18px}.brand-mark{width:38px;height:38px;border-radius:12px;background:var(--ink);display:grid;place-items:center;color:var(--paper);position:relative;overflow:hidden}.brand-mark:after{content:"";position:absolute;inset:auto -10px -14px auto;width:28px;height:28px;border-radius:999px;background:var(--coral)}.brand-name{font-family:var(--font-display);font-weight:700;font-size:22px;letter-spacing:-.02em}.brand-name .brand-me{font-family:var(--font-serif);font-style:italic;font-weight:400;color:var(--coral)}.nav-section-label{font-size:10px;letter-spacing:.12em;font-weight:700;color:var(--muted);padding:14px 12px 6px;text-transform:uppercase}.nav-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:var(--r-md);color:var(--ink-3);font-weight:500;font-size:14.5px;cursor:pointer;transition:background .15s,color .15s,transform .12s;text-align:left;width:100%;white-space:nowrap}.nav-item:hover{background:#1a14100b;color:var(--ink)}.nav-item.active{background:var(--ink);color:var(--paper);font-weight:600}.nav-item.active .nav-icon{color:var(--coral)}.nav-item .nav-icon{width:18px;height:18px;flex-shrink:0}.nav-item .nav-badge{margin-left:auto;background:var(--coral);color:#fff;font-size:10px;font-weight:700;padding:2px 7px;border-radius:999px}.nav-item.active .nav-badge{background:var(--coral)}.sidebar-footer{margin-top:auto;padding:12px 10px 4px;display:flex;flex-direction:column;gap:10px}.streak-pill{display:flex;align-items:center;gap:10px;padding:12px 14px;background:linear-gradient(135deg,#ff7b59,#ff5236);border-radius:var(--r-lg);color:#fff;position:relative;overflow:hidden}.streak-pill:after{content:"";position:absolute;inset:-40% -40% auto auto;width:100px;height:100px;border-radius:999px;background:#ffffff14}.streak-pill .streak-n{font-family:var(--font-display);font-size:28px;font-weight:700;line-height:1}.streak-pill .streak-lbl{font-size:11px;text-transform:uppercase;letter-spacing:.1em;opacity:.9;font-weight:600}.profile-row{display:flex;align-items:center;gap:10px;padding:8px;border-radius:var(--r-md);cursor:pointer}.profile-row:hover{background:#1a14100b}.avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,#ffb39a,#ff6b47);display:grid;place-items:center;color:#fff;font-weight:700;font-size:12px}.main{min-width:0;position:relative}.page{padding:32px 48px 64px;max-width:1180px;margin:0 auto;animation:pageFade .28s ease-out}@keyframes pageFade{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.card{background:var(--card);border:1px solid var(--line);border-radius:var(--r-xl);padding:24px;position:relative}.card-tight{padding:18px;border-radius:var(--r-lg)}.card-flat{background:var(--card-2)}.card-ink{background:var(--ink);color:var(--paper);border-color:transparent}.label-eyebrow{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.14em;color:var(--muted)}.h-display{font-family:var(--font-display);font-weight:700;letter-spacing:-.025em;line-height:1.05;color:var(--ink)}.h-serif{font-family:var(--font-serif);font-weight:400;font-style:italic;letter-spacing:-.01em}.btn{display:inline-flex;align-items:center;gap:8px;padding:11px 18px;border-radius:var(--r-pill);font-weight:600;font-size:14px;transition:transform .12s,box-shadow .15s,background .15s,color .15s;-webkit-user-select:none;user-select:none;white-space:nowrap;border:1px solid transparent}.btn:active{transform:translateY(1px)}.btn:disabled,.btn[disabled]{opacity:.4;cursor:not-allowed;box-shadow:none}.btn:disabled:hover,.btn[disabled]:hover{background:inherit}.btn-primary{background:var(--ink);color:var(--paper)}.btn-primary:hover{background:#2c231b}.btn-coral{background:var(--coral);color:#fff;box-shadow:var(--shadow-pop)}.btn-coral:hover{background:var(--coral-deep)}.btn-ghost{background:transparent;color:var(--ink);border:1px solid var(--line-2)}.btn-ghost:hover{background:#1a14100a}.btn-soft{background:var(--cream);color:var(--ink)}.btn-soft:hover{background:var(--line)}.btn-sm{padding:7px 12px;font-size:13px}.btn-lg{padding:14px 22px;font-size:15px}.btn-block{width:100%;justify-content:center}.btn-icon{padding:9px;aspect-ratio:1}.pill{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:var(--r-pill);font-size:12px;font-weight:600;background:var(--cream);color:var(--ink-2)}.pill-coral{background:var(--tint-coral);color:var(--coral-deep)}.pill-mint{background:var(--tint-mint);color:var(--mint-deep)}.pill-mango{background:var(--tint-mango);color:#8a6b11}.pill-sky{background:var(--tint-sky);color:#1f5f8b}.pill-lavender{background:var(--tint-lavender);color:var(--plum)}.pill-ink{background:var(--ink);color:var(--paper)}.kbd{font-family:var(--font-mono);font-size:11px;background:var(--cream);border:1px solid var(--line);border-bottom-width:2px;padding:1px 6px;border-radius:6px;color:var(--ink-2)}.divider{height:1px;background:var(--line);margin:16px 0}.today-hero{position:relative;background:linear-gradient(135deg,#ffd9c9,#fff1cf 60%,#fae8c9);border-radius:var(--r-xl);padding:32px 36px;overflow:hidden;border:1px solid #F2DDB8}.today-hero:after{content:"";position:absolute;right:-60px;top:-60px;width:320px;height:320px;border-radius:50%;background:radial-gradient(circle at 30% 30%,#FFB39A 0%,transparent 65%);pointer-events:none}.today-hero .hero-content{position:relative;z-index:1;max-width:640px}.today-hero h1{font-family:var(--font-display);font-size:44px;font-weight:700;letter-spacing:-.025em;line-height:1.05;margin:8px 0;color:var(--ink)}.today-hero h1 .hero-em{font-family:var(--font-serif);font-style:italic;font-weight:400;color:var(--coral-deep)}.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.stat-tile{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);padding:16px 18px;display:flex;flex-direction:column;gap:4px}.stat-tile .stat-num{font-family:var(--font-display);font-size:30px;font-weight:700;letter-spacing:-.02em;line-height:1}.stat-tile .stat-lbl{font-size:12px;color:var(--muted);font-weight:500}.stat-tile .stat-spark{height:22px;margin-top:8px;display:flex;align-items:flex-end;gap:2px}.stat-spark .bar{flex:1;background:var(--coral);border-radius:2px;opacity:.6}.section-head{display:flex;align-items:end;justify-content:space-between;margin:36px 0 16px}.section-head h2{font-family:var(--font-display);font-size:26px;font-weight:700;letter-spacing:-.02em;margin:4px 0 0}.section-head .section-sub{font-size:13px;color:var(--muted);margin-top:4px}.word-card{display:grid;grid-template-columns:1fr 1fr;gap:0;overflow:hidden;padding:0}.word-card .word-side{padding:28px 32px}.word-card .word-side+.word-side{border-left:1px dashed var(--line)}.word-card .word-term{font-family:var(--font-display);font-size:46px;font-weight:700;letter-spacing:-.025em;line-height:1;color:var(--coral-deep);margin:8px 0 2px}.word-card .word-ipa{font-family:var(--font-serif);font-style:italic;color:var(--muted);font-size:16px}.word-card .word-def{color:var(--ink-2);font-size:15px;margin:12px 0}.word-card .word-tags{display:flex;flex-wrap:wrap;gap:6px}.word-card .word-example{margin-top:16px;font-family:var(--font-serif);font-style:italic;color:var(--ink-2);font-size:16px;padding:12px 14px;background:var(--card-2);border-radius:var(--r-md);border-left:3px solid var(--coral)}.word-card .word-example em{font-style:normal;font-weight:600;color:var(--coral-deep)}.word-card .word-actions{display:flex;gap:8px;margin-top:14px}.phrase-card{display:grid;grid-template-columns:1fr 320px;gap:24px;align-items:center}.phrase-card .phrase-text{font-family:var(--font-display);font-size:28px;font-weight:700;letter-spacing:-.02em;line-height:1.15}.phrase-card .phrase-meaning{color:var(--muted);margin-top:8px}.phrase-card .phrase-art{height:140px;border-radius:var(--r-lg);background:radial-gradient(circle at 30% 30%,var(--tint-mango),transparent 60%),linear-gradient(135deg,var(--tint-coral),var(--tint-mango));position:relative;overflow:hidden}.dual-tiles{display:grid;grid-template-columns:1fr 1fr;gap:16px}.tip-card{background:linear-gradient(135deg,#fff1cf,#ffe0aa);border:1px solid #F0D9A3;border-radius:var(--r-xl);padding:24px}.tip-card .tip-icon{width:44px;height:44px;background:var(--mango);border-radius:var(--r-md);display:grid;place-items:center;color:#fff}.challenge-card{background:linear-gradient(135deg,#e8f6ee,#d5efe0);border:1px solid #BDE2CE;border-radius:var(--r-xl);padding:24px}.challenge-card .ch-icon{width:44px;height:44px;background:var(--mint-deep);border-radius:var(--r-md);display:grid;place-items:center;color:#fff}.practice-shell{display:grid;grid-template-columns:1fr 320px;gap:20px;align-items:start}.chat-pane{background:var(--card);border:1px solid var(--line);border-radius:var(--r-xl);display:flex;flex-direction:column;min-height:calc(100vh - 130px);overflow:hidden}.chat-header{display:flex;align-items:center;gap:14px;padding:18px 24px;border-bottom:1px solid var(--line);background:var(--card-2)}.chat-header .aria-avatar{width:44px;height:44px;border-radius:50%;background:conic-gradient(from 0deg at 50% 50%,#ff6b47,#ffb627,#2fbf8f,#8b6fe6,#ff6b47);position:relative;padding:3px}.chat-header .aria-avatar:after{content:"A";position:absolute;top:3px;right:3px;bottom:3px;left:3px;background:var(--ink);border-radius:50%;display:grid;place-items:center;color:#fff;font-family:var(--font-display);font-weight:700;font-size:18px}.chat-header .aria-meta{flex:1}.chat-header .aria-name{font-family:var(--font-display);font-weight:700;font-size:17px;letter-spacing:-.01em}.chat-header .aria-status{font-size:12px;color:var(--muted);display:flex;align-items:center;gap:6px}.aria-status .live-dot{width:6px;height:6px;background:var(--mint);border-radius:50%;box-shadow:0 0 #2fbf8f80;animation:livePulse 1.6s ease-out infinite}@keyframes livePulse{0%,to{box-shadow:0 0 #2fbf8f8c}60%{box-shadow:0 0 0 8px #2fbf8f00}}.chat-scroll{flex:1;overflow-y:auto;padding:24px 28px 8px;display:flex;flex-direction:column;gap:18px}.msg-row{display:flex;gap:12px;max-width:78%}.msg-row.user{align-self:flex-end;flex-direction:row-reverse}.msg-bubble{padding:14px 16px;border-radius:var(--r-lg);font-size:15px;line-height:1.45;border:1px solid var(--line);background:var(--card-2)}.msg-row.user .msg-bubble{background:var(--ink);color:var(--paper);border-color:var(--ink);border-bottom-right-radius:8px}.msg-row.ai .msg-bubble{border-bottom-left-radius:8px}.msg-bubble .correction-block{margin-top:10px;padding:10px 12px;background:#ff6b4714;border-radius:var(--r-sm);border-left:3px solid var(--coral);font-size:14px}.msg-bubble .correction-block .ok{color:var(--mint-deep);font-weight:600}.msg-bubble .correction-block .fix{color:var(--coral-deep);font-weight:600}.msg-bubble .correction-block .row{display:flex;gap:8px;align-items:baseline;margin:2px 0}.tiny-icon{width:14px;height:14px;flex-shrink:0;opacity:.7}.msg-mini-avatar{width:32px;height:32px;border-radius:50%;background:var(--ink);display:grid;place-items:center;color:#fff;font-family:var(--font-display);font-weight:700;font-size:14px;flex-shrink:0}.msg-row.user .msg-mini-avatar{background:linear-gradient(135deg,#ffb39a,#ff6b47)}.compose{border-top:1px solid var(--line);padding:16px 24px 18px;background:var(--card);display:flex;align-items:center;gap:12px}.compose-input{flex:1;background:var(--card-2);border:1px solid var(--line);border-radius:var(--r-pill);padding:12px 18px;font-size:14.5px;outline:none;transition:border-color .15s}.compose-input:focus{border-color:var(--ink)}.record-button{position:relative;width:56px;height:56px;border-radius:50%;background:var(--coral);display:grid;place-items:center;color:#fff;box-shadow:var(--shadow-pop);transition:transform .18s,background .18s;flex-shrink:0}.record-button:hover{transform:scale(1.05)}.record-button.recording{background:var(--ink)}.record-button.recording:before,.record-button.recording:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:50%;border:2px solid var(--coral);animation:pulseRing 1.4s ease-out infinite}.record-button.recording:after{animation-delay:.7s}@keyframes pulseRing{0%{transform:scale(1);opacity:.8}to{transform:scale(1.8);opacity:0}}.record-overlay{position:absolute;inset:auto 24px 84px;background:var(--card);border:1px solid var(--line);border-radius:var(--r-xl);padding:20px 22px;box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:16px}.waveform{flex:1;display:flex;align-items:center;gap:3px;height:50px}.waveform .bar{flex:1;background:var(--coral);border-radius:2px;min-height:4px;transition:height .12s}.rec-clock{font-family:var(--font-mono);font-size:13px;color:var(--coral-deep);font-weight:600}.side-panel{background:var(--card);border:1px solid var(--line);border-radius:var(--r-xl);padding:18px}.topic-chip{display:flex;align-items:center;gap:10px;padding:11px 13px;border-radius:var(--r-md);cursor:pointer;transition:background .15s;border:1px solid transparent;background:transparent;font-family:inherit;width:100%}.topic-chip:hover{background:var(--card-2)}.topic-chip.active{background:var(--card-2);border-color:var(--line)}.topic-chip .topic-dot{width:10px;height:10px;border-radius:50%;background:var(--coral);flex-shrink:0}.topic-chip .topic-name{font-weight:600;font-size:13.5px}.topic-chip .topic-desc{font-size:12px;color:var(--muted)}.feedback-block{margin-top:12px;padding:14px;background:var(--card-2);border-radius:var(--r-md);border:1px solid var(--line)}.score-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;margin-top:10px}.score-pill{background:var(--card);border:1px solid var(--line);border-radius:10px;padding:8px 0;text-align:center}.score-pill .val{font-family:var(--font-display);font-weight:700;font-size:20px;color:var(--coral-deep)}.score-pill .lbl{font-size:9.5px;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;font-weight:600}.coach-hero{background:var(--ink);color:var(--paper);border-radius:var(--r-xl);padding:28px 32px;display:grid;grid-template-columns:1fr 280px;gap:20px;align-items:center;position:relative;overflow:hidden}.coach-hero:after{content:"";position:absolute;inset:auto -40px -60px auto;width:320px;height:320px;border-radius:50%;background:radial-gradient(circle,var(--coral) 0%,transparent 60%);opacity:.55}.coach-hero h1{font-family:var(--font-display);font-size:36px;font-weight:700;letter-spacing:-.025em;margin:8px 0}.module-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}.module-card{background:var(--card);border:1px solid var(--line);border-radius:var(--r-xl);padding:22px;cursor:pointer;transition:transform .18s,box-shadow .18s,border-color .15s;position:relative;overflow:hidden;text-align:left;font-family:inherit}.module-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--line-2)}.module-card .module-icon{width:52px;height:52px;border-radius:var(--r-md);display:grid;place-items:center;margin-bottom:16px;color:#fff;font-family:var(--font-display);font-weight:700;font-size:22px}.module-card h3{font-family:var(--font-display);font-size:19px;letter-spacing:-.015em;margin:0 0 6px}.module-card .module-sub{color:var(--muted);font-size:13.5px;margin-bottom:16px;min-height:38px}.progress-track{height:6px;background:var(--cream);border-radius:999px;overflow:hidden}.progress-fill{height:100%;background:var(--coral);border-radius:999px;transition:width .4s ease}.module-card .module-progress-meta{display:flex;justify-content:space-between;font-size:11.5px;color:var(--muted);margin-top:8px;font-weight:600}.lesson-path{position:relative;padding:28px 0}.lesson-node{position:relative;display:flex;align-items:center;gap:16px;margin:16px 0}.lesson-node.offset-r{padding-left:40%}.lesson-node.offset-l{padding-right:40%}.lesson-orb{width:84px;height:84px;border-radius:50%;display:grid;place-items:center;background:var(--coral);color:#fff;font-family:var(--font-display);font-weight:700;font-size:28px;box-shadow:0 6px 0 var(--coral-deep),0 12px 24px #e84a2c40;position:relative;cursor:pointer;transition:transform .15s;flex-shrink:0}.lesson-orb:hover{transform:translateY(-2px)}.lesson-orb.locked{background:var(--cream);color:var(--muted-2);box-shadow:0 4px 0 var(--line-2);cursor:not-allowed}.lesson-orb.done{background:var(--mint);box-shadow:0 6px 0 var(--mint-deep),0 12px 24px #2fbf8f38}.lesson-orb.current:after{content:"";position:absolute;top:-10px;right:-10px;bottom:-10px;left:-10px;border:3px dashed var(--coral);border-radius:50%;animation:spin 12s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.lesson-label{background:var(--card);padding:10px 14px;border-radius:var(--r-md);border:1px solid var(--line);font-size:13.5px;font-weight:600;max-width:240px}.lesson-label small{display:block;color:var(--muted);font-weight:500;font-size:12px;margin-top:2px}.scenario-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}.scenario-card{background:var(--card);border:1px solid var(--line);border-radius:var(--r-xl);padding:0;overflow:hidden;cursor:pointer;transition:transform .18s,box-shadow .18s;display:flex;flex-direction:column;text-align:left;font-family:inherit}.scenario-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.scenario-card .scenario-art{height:120px;position:relative;overflow:hidden}.scenario-card .scenario-body{padding:18px 20px 20px}.scenario-card h3{font-family:var(--font-display);font-size:18px;letter-spacing:-.015em;margin:4px 0 6px}.scenario-card .scenario-sub{color:var(--muted);font-size:13px;min-height:36px}.diff-easy{color:var(--mint-deep)}.diff-medium{color:var(--coral-deep)}.diff-hard{color:#b72e48}.dc-hero{background:radial-gradient(circle at 80% 0%,#FFE0AA 0%,transparent 50%),linear-gradient(135deg,#fff1cf,#ffd9c9);border-radius:var(--r-xl);padding:36px;border:1px solid #F0D9A3;position:relative;overflow:hidden}.req-row{display:flex;align-items:center;gap:12px;padding:14px 16px;background:var(--card);border:1px solid var(--line);border-radius:var(--r-md);margin:8px 0}.req-row.met{background:var(--tint-mint);border-color:#bde2ce}.req-check{width:22px;height:22px;border-radius:50%;border:2px solid var(--line-2);flex-shrink:0;display:grid;place-items:center}.req-row.met .req-check{background:var(--mint);border-color:var(--mint);color:#fff}.drill-card{background:var(--card);border:1px solid var(--line);border-radius:var(--r-xl);padding:36px;text-align:center}.drill-card .drill-term{font-family:var(--font-display);font-size:56px;font-weight:700;letter-spacing:-.03em;color:var(--coral-deep);margin:8px 0 4px;line-height:1}.drill-card .drill-ipa{font-family:var(--font-serif);font-style:italic;color:var(--muted);font-size:18px}.drill-card .drill-def{color:var(--ink-2);font-size:17px;margin:18px auto;max-width:540px}.drill-card .drill-syns{display:flex;justify-content:center;gap:6px;flex-wrap:wrap;margin-bottom:18px}.attempt-card{background:var(--card-2);border:1px solid var(--line);border-radius:var(--r-lg);padding:16px 18px;margin:10px 0}.hl-green{color:var(--mint-deep);font-weight:600}.hl-yellow{color:#c58709;font-weight:600;text-decoration:underline;text-decoration-color:var(--mango);text-decoration-thickness:2px;text-underline-offset:3px}.hl-red{color:var(--berry);font-weight:600;text-decoration:underline;text-decoration-color:var(--berry);text-decoration-thickness:2px;text-underline-offset:3px}.typing-mode-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px}.typing-mode{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);padding:20px;cursor:pointer;transition:transform .15s,border-color .15s;text-align:left;font-family:inherit}.typing-mode:hover{transform:translateY(-2px);border-color:var(--line-2)}.typing-track{background:var(--card);border:1px solid var(--line);border-radius:var(--r-xl);padding:40px;font-family:var(--font-mono);font-size:22px;line-height:1.7;color:var(--muted-2);letter-spacing:-.005em}.typing-track .ch.done{color:var(--ink)}.typing-track .ch.cursor{background:var(--coral);color:#fff;border-radius:3px}.typing-track .ch.wrong{color:var(--berry);background:#e84a6f14}.typing-meter{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:16px}.typing-meter .m-tile{background:var(--card);border:1px solid var(--line);border-radius:var(--r-md);padding:14px;text-align:center}.typing-meter .m-val{font-family:var(--font-display);font-size:28px;font-weight:700;letter-spacing:-.02em}.typing-meter .m-lbl{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.1em;font-weight:600}.tweaks-fab{position:fixed;right:24px;bottom:24px;width:48px;height:48px;border-radius:50%;background:var(--ink);color:#fff;display:grid;place-items:center;box-shadow:var(--shadow-lg);z-index:100;cursor:pointer}.tweaks-panel{position:fixed;right:24px;bottom:84px;width:280px;background:var(--card);border:1px solid var(--line);border-radius:var(--r-xl);box-shadow:var(--shadow-lg);padding:18px;z-index:101}.tweaks-panel h4{font-family:var(--font-display);font-size:15px;margin:0 0 12px}.tweak-row{margin-bottom:14px}.tweak-row .tweak-lbl{font-size:11px;text-transform:uppercase;letter-spacing:.12em;font-weight:700;color:var(--muted);margin-bottom:6px}.swatch-row{display:flex;gap:8px}.swatch{width:28px;height:28px;border-radius:50%;border:2px solid transparent;cursor:pointer}.swatch.active{border-color:var(--ink)}.seg{display:flex;background:var(--cream);border-radius:var(--r-pill);padding:3px;gap:2px}.seg button{flex:1;padding:6px 12px;border-radius:var(--r-pill);font-size:12px;font-weight:600;color:var(--ink-3);transition:background .15s,color .15s}.seg button.on{background:var(--card);color:var(--ink);box-shadow:var(--shadow-sm)}.onboard-shell{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--paper);z-index:1000;overflow-y:auto;display:flex;flex-direction:column;align-items:center;padding:40px 32px 60px;animation:pageFade .3s ease-out}.onboard-bg{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;background:radial-gradient(circle at 15% 20%,rgba(255,107,71,.18) 0%,transparent 40%),radial-gradient(circle at 85% 75%,rgba(139,111,230,.14) 0%,transparent 40%),radial-gradient(circle at 70% 15%,rgba(255,182,39,.16) 0%,transparent 35%);z-index:0}.onboard-top{width:100%;max-width:960px;display:flex;justify-content:space-between;align-items:center;margin-bottom:28px;position:relative;z-index:1}.onboard-steps{display:flex;gap:6px}.onboard-step{width:36px;height:4px;border-radius:999px;background:var(--line);transition:background .25s}.onboard-step.on{background:var(--coral)}.onboard-card{position:relative;z-index:1;background:var(--card);border:1px solid var(--line);border-radius:28px;padding:44px 52px;width:100%;max-width:960px;box-shadow:0 20px 60px #1a141014,0 2px 8px #1a14100a}.onboard-footer{margin-top:28px;font-size:13.5px;color:var(--muted);position:relative;z-index:1}.level-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}.level-card{background:var(--card-2);border:2px solid var(--line);border-radius:22px;padding:22px 22px 24px;cursor:pointer;text-align:left;font-family:inherit;position:relative;transition:transform .15s,border-color .15s,background .15s;display:flex;flex-direction:column}.level-card:hover{transform:translateY(-2px);border-color:var(--line-2)}.level-card.selected{border-color:var(--level-accent);background:var(--card);box-shadow:0 0 0 5px color-mix(in srgb,var(--level-accent) 14%,transparent)}.level-glyph{width:56px;height:56px;border-radius:16px;display:grid;place-items:center;color:#fff;font-family:var(--font-display);font-weight:700;font-size:24px;margin-bottom:18px;letter-spacing:-.02em}.level-cefr{font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:4px}.level-name{font-family:var(--font-display);font-size:24px;font-weight:700;letter-spacing:-.02em;margin-bottom:8px;color:var(--ink)}.level-blurb{font-family:var(--font-serif);font-style:italic;font-size:15px;color:var(--ink-2);line-height:1.45;margin-bottom:16px}.level-bullet{margin-top:auto;padding-top:12px;border-top:1px dashed var(--line-2);font-size:12.5px;color:var(--muted);font-weight:500;line-height:1.5}.level-check{position:absolute;top:18px;right:18px;width:26px;height:26px;border-radius:50%;background:var(--level-accent);color:#fff;display:grid;place-items:center;opacity:0;transform:scale(.6);transition:opacity .2s,transform .2s}.level-card.selected .level-check{opacity:1;transform:scale(1)}.onboard-input{width:100%;background:var(--card-2);border:2px solid var(--line);border-radius:16px;padding:20px 24px;font-family:var(--font-display);font-size:26px;font-weight:600;letter-spacing:-.015em;outline:none;transition:border-color .15s}.onboard-input:focus{border-color:var(--coral)}.goal-picker{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.goal-card{background:var(--card-2);border:2px solid var(--line);border-radius:18px;padding:22px 14px;cursor:pointer;text-align:center;font-family:inherit;transition:transform .15s,border-color .15s,background .15s}.goal-card:hover{transform:translateY(-2px);border-color:var(--line-2)}.goal-card.selected{border-color:var(--coral);background:var(--tint-coral)}.goal-mins{font-family:var(--font-display);font-size:36px;font-weight:700;color:var(--ink);letter-spacing:-.02em;line-height:1}.goal-unit{font-size:11px;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.1em;margin-top:4px}.goal-vibe{font-family:var(--font-serif);font-style:italic;font-size:13px;color:var(--coral-deep);margin-top:10px}.goal-card.selected .goal-vibe{color:var(--coral-deep);font-weight:600}.onboard-summary{margin-top:28px;background:var(--card-2);border:1px solid var(--line);border-radius:18px;padding:18px 22px}.onboard-summary-row{display:flex;justify-content:space-between;padding:8px 0;font-size:14px;border-bottom:1px dashed var(--line)}.onboard-summary-row:last-child{border-bottom:0}.onboard-summary-row strong{font-weight:600;color:var(--ink)}@media (max-width: 760px){.onboard-card{padding:32px 24px;border-radius:22px}.level-grid{grid-template-columns:1fr}.goal-picker{grid-template-columns:repeat(2,1fr)}.onboard-shell h1{font-size:28px!important}}.mobile-tabs{display:none}@media (max-width: 920px){.app{grid-template-columns:1fr}.sidebar{display:none}.page{padding:18px 18px 100px}.today-hero{padding:24px}.today-hero h1{font-size:32px}.stat-grid{grid-template-columns:repeat(2,1fr)}.word-card{grid-template-columns:1fr}.word-card .word-side+.word-side{border-left:0;border-top:1px dashed var(--line)}.phrase-card{grid-template-columns:1fr}.phrase-card .phrase-art{height:80px}.dual-tiles,.practice-shell{grid-template-columns:1fr}.chat-pane{min-height:calc(100vh - 200px)}.coach-hero{grid-template-columns:1fr}.coach-hero h1{font-size:28px}.lesson-node.offset-r,.lesson-node.offset-l{padding-left:0;padding-right:0;justify-content:center}.lesson-label{display:none}.lesson-orb{width:72px;height:72px;font-size:22px}.mobile-tabs{display:flex;position:fixed;bottom:0;left:0;right:0;background:var(--card);border-top:1px solid var(--line);padding:8px 8px 14px;z-index:50;justify-content:space-around}.mobile-tab{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;padding:6px 4px;color:var(--muted);font-size:10.5px;font-weight:600}.mobile-tab.active{color:var(--ink)}.mobile-tab .nav-icon{width:20px;height:20px}.mobile-tab.active .nav-icon{color:var(--coral)}.mobile-tab .dot{position:absolute;bottom:4px;width:4px;height:4px;border-radius:50%;background:var(--coral)}.mobile-header{display:flex;justify-content:space-between;align-items:center;padding:16px 18px 0}.typing-track{padding:24px;font-size:18px}}@media (min-width: 921px){.mobile-header{display:none}}.spinner{width:18px;height:18px;border:2px solid var(--line);border-top-color:var(--coral);border-radius:50%;animation:spin .8s linear infinite;display:inline-block}.toast{position:fixed;bottom:32px;left:50%;transform:translate(-50%);background:var(--ink);color:var(--paper);padding:10px 18px;border-radius:var(--r-pill);font-size:13.5px;z-index:200;box-shadow:var(--shadow-lg);animation:toastIn .25s ease-out}@keyframes toastIn{0%{opacity:0;transform:translate(-50%,10px)}to{opacity:1;transform:translate(-50%)}}@keyframes typingBounce{0%,80%,to{transform:translateY(0);opacity:.4}40%{transform:translateY(-3px);opacity:1}}.text-input,.text-area,.select-input{width:100%;background:var(--card-2);border:1px solid var(--line);border-radius:var(--r-md);padding:11px 14px;font-size:14.5px;outline:none;transition:border-color .15s}.text-input:focus,.text-area:focus,.select-input:focus{border-color:var(--ink)}.text-area{resize:vertical;min-height:90px;font-family:inherit;line-height:1.5}.field-label{display:block;font-size:12px;color:var(--muted);font-weight:600;margin-bottom:6px}.field{margin-bottom:14px}.banner{border-radius:var(--r-md);padding:11px 15px;font-size:13.5px;margin-bottom:14px}.banner-error{background:#fbe3e8;border:1px solid #F0BFC9;color:#b72e48}.banner-info{background:var(--card-2);border:1px solid var(--line);color:var(--muted)}.stack{display:flex;flex-direction:column;gap:12px}.muted{color:var(--muted)}.center-screen{display:grid;place-items:center;min-height:100vh;color:var(--muted)}.empty-state{text-align:center;padding:48px 24px;color:var(--muted)}.typing-dots span{display:inline-block;width:6px;height:6px;margin:0 1px;border-radius:50%;background:var(--muted);animation:typingBounce 1.2s infinite}.typing-dots span:nth-child(2){animation-delay:.15s}.typing-dots span:nth-child(3){animation-delay:.3s}.kbd-board{display:flex;flex-direction:column;gap:6px;background:var(--card-2);border:1px solid var(--line);border-radius:var(--r-lg);padding:10px;-webkit-user-select:none;user-select:none}.kbd-row{display:flex;gap:5px;justify-content:center}.kbd-key{flex:1 1 0;min-width:0;height:40px;border-radius:7px;background:var(--card);border:1px solid var(--line);border-bottom:3px solid var(--line-2);display:grid;place-items:center;font-family:var(--font-mono);font-size:12.5px;color:var(--ink-2)}.kbd-key.wide{flex:1.7 1 0}.kbd-key.space{flex:7 1 0}.kbd-key.next{background:var(--coral);color:#fff;border-bottom-color:var(--coral-deep);box-shadow:0 0 0 3px var(--tint-coral)}.kbd-legend{display:flex;gap:14px;flex-wrap:wrap;font-size:11px;color:var(--muted);margin-top:10px}.kbd-legend span{display:inline-flex;align-items:center;gap:5px}.kbd-legend i{width:11px;height:11px;border-radius:3px;display:inline-block}.tl-stage{margin-bottom:14px}.tl-lessons{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}.tl-lesson{flex:1 1 150px;min-width:140px;text-align:left;background:var(--card-2);border:1px solid var(--line);border-radius:var(--r-md);padding:12px 14px;cursor:pointer;font-family:inherit;transition:transform .12s,border-color .12s}.tl-lesson:hover:not(.locked){transform:translateY(-2px);border-color:var(--line-2)}.tl-lesson.locked{opacity:.5;cursor:not-allowed}.tl-lesson.done{background:var(--tint-mint);border-color:#bde2ce}.tl-stars{color:var(--mango);font-size:13px;letter-spacing:1px}.tl-num{font-family:var(--font-display);font-weight:700;font-size:14px}.legal-shell{min-height:100vh;background:var(--paper);padding:30px 20px 90px}.legal-doc{max-width:760px;margin:0 auto}.legal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:34px}.legal-doc h1{font-size:34px;line-height:1.15;margin:0 0 4px}.legal-updated{color:var(--muted);font-size:13px;margin:0 0 26px}.legal-doc h2{font-family:var(--font-display);font-weight:700;font-size:19px;color:var(--ink);margin:32px 0 8px}.legal-doc p,.legal-doc li{color:var(--ink-3);font-size:15px;line-height:1.65}.legal-doc p{margin:8px 0}.legal-doc ul{padding-left:22px;margin:8px 0}.legal-doc li{margin:5px 0}.legal-doc a{color:var(--coral-deep);font-weight:600}.legal-note{background:var(--tint-mango);border-radius:var(--r-md);padding:13px 16px;font-size:14px;color:var(--ink-2);margin:14px 0 6px}.legal-foot{margin-top:46px;padding-top:20px;border-top:1px solid var(--line);display:flex;gap:18px;flex-wrap:wrap;font-size:14px}.typing-track.lesson{font-size:26px;line-height:1.95}.typing-live{display:flex;align-items:center;gap:16px;flex-wrap:wrap;margin-bottom:12px}.typing-live .lv{font-family:var(--font-display);font-weight:700;font-size:20px;color:var(--ink)}.typing-live .lv span{font-family:var(--font-body);font-size:11px;font-weight:600;color:var(--muted);margin-left:3px}.typing-progress{flex:1;min-width:110px;height:8px;background:var(--card-2);border:1px solid var(--line);border-radius:var(--r-pill);overflow:hidden}.typing-progress>i{display:block;height:100%;background:var(--mint);border-radius:var(--r-pill);transition:width .15s ease}.snd-toggle{border:1px solid var(--line);background:var(--card);border-radius:var(--r-pill);padding:6px 11px;cursor:pointer;font-size:12px;color:var(--muted);font-family:inherit;display:inline-flex;gap:5px;align-items:center}.snd-toggle.on{color:var(--coral-deep);border-color:var(--coral-soft)}.typing-guides{margin-top:16px}.hands-guide{padding:8px 0 2px}.hands{display:flex;justify-content:center;gap:38px;align-items:flex-start}.hand{display:flex;flex-direction:column;align-items:center}.hand-fingers{display:flex;gap:6px;align-items:flex-end}.finger{width:30px;border:1.5px solid var(--line);border-bottom-width:4px;border-radius:9px 9px 5px 5px;background:var(--card);display:flex;align-items:flex-end;justify-content:center;padding-bottom:6px;font-family:var(--font-mono);font-size:12px;color:var(--muted);transition:transform .1s ease,box-shadow .1s ease}.finger.active{transform:translateY(-8px)}.hand-palm{position:relative;width:138px;height:30px;margin-top:-2px;border:1.5px solid var(--line);border-radius:8px 8px 20px 20px;background:var(--card)}.thumb{position:absolute;bottom:4px;width:46px;height:18px;border-radius:var(--r-pill);border:1.5px solid var(--line);background:var(--card)}.hand.left .thumb{right:-15px;transform:rotate(40deg)}.hand.right .thumb{left:-15px;transform:rotate(-40deg)}.hands-caption{text-align:center;font-size:15px;font-weight:600;color:var(--ink-2);margin-top:12px}.intro-steps{margin:18px 0 24px;padding-left:22px}.intro-steps li{margin:10px 0;font-size:15px;line-height:1.6;color:var(--ink-2)}.intro-banner{display:flex;align-items:center;gap:14px;background:var(--tint-lavender);border:1px solid #D9CDF5;border-radius:var(--r-lg);padding:14px 18px;margin-top:16px;cursor:pointer;transition:transform .12s ease}.intro-banner:hover{transform:translateY(-2px)}.intro-banner-icon{width:38px;height:38px;border-radius:var(--r-md);background:#fff;display:grid;place-items:center;color:var(--plum)}@media (max-width: 640px){.typing-track.lesson{font-size:20px}.hands{gap:18px}.finger{width:24px}.hand-palm{width:114px}}.lc-play{display:grid;place-items:center;width:92px;height:92px;border-radius:50%;border:none;cursor:pointer;margin:0 auto;background:var(--coral);color:#fff;box-shadow:var(--shadow-pop);transition:transform .1s ease}.lc-play:hover:not(:disabled){transform:scale(1.04)}.lc-play:disabled{opacity:.6;cursor:default}.lc-option{display:flex;align-items:center;gap:12px;width:100%;text-align:left;padding:12px 15px;margin:7px 0;border:1.5px solid var(--line);border-radius:var(--r-md);background:var(--card);cursor:pointer;font-family:inherit;font-size:14.5px;color:var(--ink-2);transition:border-color .1s ease,background .1s ease}.lc-option:hover:not(.correct):not(.wrong){border-color:var(--line-2)}.lc-option.picked{border-color:var(--coral);background:var(--tint-coral)}.lc-option.correct{border-color:var(--mint);background:var(--tint-mint);color:var(--ink)}.lc-option.wrong{border-color:var(--berry);background:#e84a6f14}.lc-mark{width:22px;height:22px;flex-shrink:0;border-radius:50%;border:1.5px solid var(--line-2);display:grid;place-items:center;font-size:11px;font-weight:700;color:var(--muted)}.lc-option.picked .lc-mark{border-color:var(--coral);background:var(--coral);color:#fff}.lc-option.correct .lc-mark{border-color:var(--mint);background:var(--mint);color:#fff}.lc-option.wrong .lc-mark{border-color:var(--berry);background:var(--berry);color:#fff}.wr-textarea{width:100%;min-height:240px;resize:vertical;box-sizing:border-box;border:1.5px solid var(--line);border-radius:var(--r-md);padding:14px 16px;background:var(--card);font-family:var(--font-body);font-size:15px;line-height:1.6;color:var(--ink)}.wr-textarea:focus{outline:none;border-color:var(--coral)}.wr-textarea:disabled{opacity:.65}.wr-dims{display:flex;gap:10px;flex-wrap:wrap;margin:14px 0 0}.wr-dim{flex:1 1 110px;background:var(--card-2);border:1px solid var(--line);border-radius:var(--r-md);padding:11px 14px}.wr-dim-n{font-family:var(--font-display);font-weight:700;font-size:22px}.wr-dim-l{font-size:11px;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.04em}.wr-correction{border:1px solid var(--line);border-radius:var(--r-md);padding:11px 14px;margin:8px 0;background:var(--card);font-size:14px}.wr-was{color:var(--berry);text-decoration:line-through}.wr-now{color:var(--mint-deep);font-weight:600}
