:root{color:var(--ink);background:var(--app-bg);font-family:var(--font-ui);font-synthesis:none;text-rendering:optimizeLegibility;--build-tag: "2026-05-23";--font-ui: "PingFang TC", "Noto Sans TC", "Noto Sans CJK TC", "Microsoft JhengHei", "Hiragino Sans", sans-serif;--font-title: "PingFang TC", "Noto Sans TC", "Noto Sans CJK TC", "Microsoft JhengHei", sans-serif;--font-japanese-ui: "Hiragino Sans", "Yu Gothic", "YuGothic", "Noto Sans JP", "Noto Sans CJK JP", var(--font-ui);--font-japanese-display: "Hiragino Mincho ProN", "Yu Mincho", "Noto Serif JP", "Noto Serif CJK JP", "Songti TC", serif;--app-bg: #f4ead8;--paper: #fffaf0;--paper-deep: #efe6cf;--ink: #172126;--muted: #6a6155;--rule: #d8cdb5;--teal: #0f766e;--teal-dark: #115e59;--matcha: #647c5c;--matcha-dark: #4f6549;--vermilion: #b94a2c;--indigo: #647c5c;--gold: #b7791f;--green: #4f7a3f;--shadow: 0 6px 18px rgba(120, 95, 55, .09);--body-grid-row: transparent;--body-grid-column: transparent;--bg-glow-primary: transparent;--bg-glow-secondary: transparent;--panel-glow: transparent;--panel-bg: var(--paper);--panel-border: #d4c7ad;--button-border: #c3b698;--button-text: #172126;--button-hover-shadow: 0 4px 14px rgba(120, 95, 55, .12);--selected-text: #fffaf0;--label-text: #42565a;--field-bg: #fffaf0;--field-border: #94aaa8;--field-disabled-bg: #e7e1d4;--field-disabled-text: #71807f;--focus-fill: rgba(255, 250, 240, .9);--focus-outline: rgba(20, 184, 166, .36);--prompt-chip-border: #9ab2b0;--prompt-chip-text: #42565a;--target-chip-bg: #ffe3d2;--target-chip-border: #f0a070;--target-chip-text: #8d3415;--word-kind-bg: rgba(15, 126, 168, .1);--word-kind-border: rgba(15, 126, 168, .24);--surface-ink: #10161a;--surface-shadow: 0 1px 0 rgba(255, 250, 240, .9);--summary-bg: rgba(15, 118, 110, .12);--summary-border: rgba(15, 118, 110, .28);--summary-text: #0d5d58;--feedback-correct-bg: #e6f7ec;--feedback-correct-border: #95d8ad;--feedback-incorrect-bg: #fff0e7;--feedback-incorrect-border: #f0a385;--feedback-revealed-bg: #fff6dc;--feedback-revealed-border: #dfbc63;--feedback-revealed-title: #8a5d08;--example-rule: rgba(23, 33, 38, .16);--review-row-text: #394b4e;--review-pill-bg: rgba(15, 126, 168, .1);--review-pill-border: rgba(15, 126, 168, .24);color-scheme:light}:root[data-theme=dark]{--app-bg: #1a1814;--paper: #221f1a;--paper-deep: #2b271f;--ink: #f3eddc;--muted: #a89d87;--rule: #3a342a;--teal: #5a9a8e;--teal-dark: #3f7a6f;--matcha: #889c80;--matcha-dark: #6a7d61;--vermilion: #d06a47;--indigo: #889c80;--gold: #d4a64a;--green: #8fb076;--shadow: 0 6px 18px rgba(0, 0, 0, .32);--body-grid-row: transparent;--body-grid-column: transparent;--bg-glow-primary: transparent;--bg-glow-secondary: transparent;--panel-glow: transparent;--panel-bg: var(--paper);--panel-border: #3a342a;--button-border: #4d4538;--button-text: #f3eddc;--button-hover-shadow: 0 4px 14px rgba(0, 0, 0, .4);--selected-text: #101216;--label-text: #d8e6e2;--field-bg: #0d171b;--field-border: #2f535c;--field-disabled-bg: #17262b;--field-disabled-text: #7f9697;--focus-fill: rgba(13, 23, 27, .92);--focus-outline: rgba(56, 189, 248, .48);--prompt-chip-border: #395a62;--prompt-chip-text: #c8d6d4;--target-chip-bg: rgba(249, 115, 22, .17);--target-chip-border: rgba(249, 115, 22, .58);--target-chip-text: #ffbe8a;--word-kind-bg: rgba(56, 189, 248, .13);--word-kind-border: rgba(56, 189, 248, .34);--surface-ink: #fbfff8;--surface-shadow: 0 0 28px rgba(20, 184, 166, .18), 0 2px 0 rgba(0, 0, 0, .8);--summary-bg: rgba(20, 184, 166, .13);--summary-border: rgba(45, 212, 191, .34);--summary-text: #99f6e4;--feedback-correct-bg: rgba(34, 197, 94, .14);--feedback-correct-border: rgba(134, 239, 172, .52);--feedback-incorrect-bg: rgba(249, 115, 22, .15);--feedback-incorrect-border: rgba(251, 146, 60, .58);--feedback-revealed-bg: rgba(251, 191, 36, .13);--feedback-revealed-border: rgba(251, 191, 36, .56);--feedback-revealed-title: #fde68a;--example-rule: rgba(246, 251, 246, .16);--review-row-text: #d8e7e3;--review-pill-bg: rgba(56, 189, 248, .14);--review-pill-border: rgba(56, 189, 248, .34);color-scheme:dark}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background:var(--app-bg)}body,button,input,select{font:inherit;letter-spacing:0}button{align-items:center;border:1px solid var(--button-border);border-radius:8px;color:var(--button-text);cursor:pointer;display:inline-flex;gap:.45rem;justify-content:center;min-height:2.75rem;padding:.58rem .85rem;transition:background .16s ease,border-color .16s ease,box-shadow .16s ease,transform .16s ease}button:hover:not(:disabled){border-color:color-mix(in srgb,var(--teal) 58%,var(--button-border));box-shadow:var(--button-hover-shadow);transform:translateY(-1px)}button:disabled{cursor:not-allowed;opacity:.48}button svg{flex:0 0 auto;height:1rem;width:1rem}.app-shell{min-height:100vh;padding:1.25rem}.app-heading{align-items:end;display:flex;gap:1rem;justify-content:space-between;margin:0 auto 1rem;max-width:1220px}.app-heading h1,.app-heading p,.brand-lockup p,.brand-lockup h2,.review-heading h2,.feedback h2,.word-block p{margin:0}.app-heading h1{color:var(--ink);font-family:var(--font-title);font-size:2rem;font-weight:700;line-height:1.15}.app-heading>p{color:var(--muted);max-width:30rem;text-align:right}.heading-actions{align-items:end;display:flex;gap:.75rem;flex-wrap:wrap;justify-content:flex-end}.heading-actions p{color:var(--muted);max-width:30rem;text-align:right}.theme-toggle{background:color-mix(in srgb,var(--paper) 86%,transparent);color:var(--button-text);flex:0 0 auto;font-weight:800}.language-switch{align-items:center;background:color-mix(in srgb,var(--paper) 72%,transparent);border:1px solid var(--panel-border);border-radius:999px;display:inline-flex;flex:0 0 auto;gap:.25rem;padding:.22rem}.language-switch svg{color:var(--muted);height:1rem;margin-left:.45rem;width:1rem}.language-switch button{background:transparent;border:0;border-radius:999px;color:var(--muted);font-size:.78rem;font-weight:800;min-height:2.1rem;padding:.35rem .62rem}.language-switch button.selected{background:var(--matcha);color:var(--selected-text)}.view-switch{margin:0 auto 1rem;max-width:360px}.view-switch button{font-weight:800}.eyebrow{color:var(--teal);font-size:.76rem;font-weight:800;text-transform:uppercase}.learning-panel{animation:panel-rise .24s ease both;background:var(--paper);border:1px solid var(--panel-border);border-radius:12px;box-shadow:var(--shadow);margin:0 auto;max-width:1220px;padding:1.25rem}.chapter-shell{display:grid;gap:1rem;grid-template-columns:minmax(260px,.7fr) minmax(0,1.55fr);min-height:640px}.chapter-index,.chapter-content{min-width:0}.chapter-index{border-right:1px solid var(--rule);display:grid;gap:1rem;grid-template-rows:auto 1fr auto;padding-right:1rem}.chapter-index-copy{display:grid;gap:.45rem}.chapter-index-copy h2,.chapter-index-copy p,.chapter-content-head h3,.chapter-content-head p{margin:0}.chapter-index-copy h2{color:var(--ink);font-family:var(--font-title);font-size:1.55rem;line-height:1.2}.chapter-index-copy p:last-child,.chapter-content-head p{color:var(--muted);line-height:1.6}.chapter-list{align-content:start;display:grid;gap:.6rem}.chapter-list-button{background:color-mix(in srgb,var(--field-bg) 92%,transparent);border-color:var(--panel-border);color:var(--button-text);display:grid;gap:.28rem;justify-items:start;min-height:0;padding:.8rem;text-align:left}.chapter-list-button.selected{background:color-mix(in srgb,var(--vermilion) 10%,var(--paper));border-color:color-mix(in srgb,var(--vermilion) 55%,var(--panel-border))}.chapter-list-button.complete{border-color:color-mix(in srgb,var(--green) 58%,var(--panel-border))}.chapter-list-button span{color:var(--teal);font-size:.74rem;font-weight:800}.chapter-list-button strong{color:var(--ink);font-size:1rem;line-height:1.28}.chapter-list-button small{color:var(--muted);line-height:1.45;overflow-wrap:anywhere}.chapter-content{display:grid;gap:1rem}.chapter-content-head{border-bottom:1px solid var(--rule);display:grid;gap:.8rem;padding-bottom:1rem}.chapter-content-head h3{color:var(--ink);font-family:var(--font-japanese-display);font-size:clamp(2.1rem,5vw,4.2rem);line-height:1.05}.chapter-actions{align-items:center;display:flex;flex-wrap:wrap;gap:.75rem}.chapter-actions span{color:var(--label-text);font-size:.88rem;font-weight:800}.chapter-lesson{display:grid;gap:.85rem}.learning-hero{align-items:center;border-bottom:1px solid var(--rule);display:flex;justify-content:center;min-height:clamp(520px,calc(100vh - 6rem),680px);padding:2.8rem 1rem}.learning-copy{align-content:start;display:grid;gap:1.05rem;justify-items:center;max-width:720px;text-align:center}.learning-copy h2,.learning-copy p,.focus-formula,.quick-start-heading h3,.quick-start-heading p,.quick-start-card h4,.quick-start-card p,.detail-divider h3,.detail-divider p,.learning-section-copy h3,.learning-section-copy p,.learning-roadmap p,.rule-card h4,.rule-card p,.pipeline-card p,.lesson-card h3,.lesson-card p{margin:0}.learning-copy h2{color:var(--ink);font-family:var(--font-japanese-display);font-size:clamp(2.6rem,7vw,5.2rem);font-weight:700;line-height:1.04}.learning-copy>p:not(.eyebrow){color:var(--muted);font-size:1.02rem;line-height:1.65;max-width:44rem}.learning-copy .start-challenge{font-size:1.04rem;min-width:14rem}.learning-scroll-hint{color:var(--label-text);font-size:.88rem;font-weight:800}.focus-formula{align-items:center;background:linear-gradient(135deg,rgba(249,115,22,.16),transparent 72%),var(--field-bg);border:1px solid var(--summary-border);border-radius:8px;color:var(--summary-text);display:flex;flex-wrap:wrap;font-family:var(--font-japanese-ui);font-weight:800;gap:.48rem;justify-content:center;line-height:1.35;max-width:100%;overflow-wrap:anywhere;padding:.85rem 1rem}.focus-formula span{min-width:0}.focus-formula span+span:before{color:var(--muted);content:"+";font-family:var(--font-ui);font-weight:800;margin-right:.48rem}.learning-path-card{background:linear-gradient(180deg,color-mix(in srgb,var(--field-bg) 92%,transparent),color-mix(in srgb,var(--paper-deep) 74%,transparent));border:1px solid var(--panel-border);border-radius:8px;min-width:0;padding:.95rem}.learning-path-section{margin-top:1.05rem}.learning-roadmap{counter-reset:learning;display:grid;gap:.55rem;grid-template-columns:repeat(3,minmax(0,1fr));list-style:none;margin:.7rem 0 0;padding:0}.learning-roadmap li{background:color-mix(in srgb,var(--paper-deep) 68%,transparent);border-left:3px solid var(--teal);display:grid;gap:.2rem;min-width:0;padding:.58rem 0 .58rem .72rem}.learning-roadmap span,.pipeline-card span{color:var(--teal);font-size:.78rem;font-weight:800}.learning-roadmap strong{color:var(--ink);font-size:.96rem}.learning-roadmap p{color:var(--muted);display:-webkit-box;font-size:.88rem;line-height:1.45;overflow:hidden;-webkit-box-orient:vertical;-webkit-line-clamp:2}.secondary-challenge-button{background:var(--paper);color:var(--button-text);font-weight:800;margin-top:.8rem}.quick-start{display:grid;gap:.8rem;margin-top:1.15rem}.quick-start-heading{align-items:end;display:flex;gap:1rem;justify-content:space-between}.quick-start-heading h3,.detail-divider h3{color:var(--ink);font-size:1.28rem;line-height:1.25}.quick-start-heading>p,.detail-divider>p{color:var(--muted);line-height:1.55;max-width:32rem;text-align:right}.quick-start-grid{display:grid;gap:.75rem;grid-template-columns:repeat(4,minmax(0,1fr))}.quick-start-card{background:linear-gradient(180deg,color-mix(in srgb,var(--field-bg) 96%,var(--indigo) 4%),var(--field-bg));border:1px solid var(--panel-border);border-radius:8px;display:grid;gap:.62rem;min-width:0;padding:.95rem}.quick-start-card.featured{background:linear-gradient(135deg,rgba(249,115,22,.18),transparent 78%),var(--field-bg);border-color:var(--vermilion)}.quick-start-card.complete{border-color:color-mix(in srgb,var(--green) 58%,var(--panel-border))}.quick-start-card.locked{opacity:.72}.quick-start-card span{color:var(--teal);font-size:.78rem;font-weight:800}.quick-start-card h4{color:var(--ink);font-size:1.08rem;line-height:1.25}.quick-start-card p{color:var(--muted);line-height:1.55}.quick-start-card code{background:var(--summary-bg);border:1px solid var(--summary-border);border-radius:6px;color:var(--summary-text);font-family:var(--font-japanese-ui);font-weight:700;overflow-wrap:anywhere;padding:.55rem .62rem}.quick-start-button{background:color-mix(in srgb,var(--paper) 86%,var(--field-bg));color:var(--button-text);font-weight:800;justify-self:start;margin-top:.1rem}.quick-start-card.featured .quick-start-button{background:var(--vermilion);border-color:var(--vermilion);color:var(--selected-text)}.quick-start-card.locked .quick-start-button{background:var(--field-disabled-bg);border-color:var(--panel-border);color:var(--field-disabled-text)}.detail-divider{align-items:end;border-top:1px solid var(--rule);display:flex;gap:1rem;justify-content:space-between;margin-top:1.15rem;padding-top:1.05rem}.learning-section{border-top:1px solid var(--rule);display:grid;gap:.95rem;margin-top:1.15rem;padding-top:1.15rem}.learning-section-copy{display:grid;gap:.35rem;max-width:52rem}.learning-section-copy h3{color:var(--ink);font-size:1.35rem;line-height:1.25}.learning-section-copy p:last-child{color:var(--muted);line-height:1.65}.rule-matrix{display:grid;gap:.75rem}.rule-matrix.three-column{grid-template-columns:repeat(3,minmax(0,1fr))}.rule-card,.pipeline-card{background:linear-gradient(180deg,color-mix(in srgb,var(--field-bg) 96%,var(--teal) 4%),var(--field-bg));border:1px solid var(--panel-border);border-radius:8px;display:grid;gap:.65rem;min-width:0;padding:.95rem}.rule-card h4{color:var(--ink);font-size:1.02rem}.rule-card p{color:var(--muted);line-height:1.55}.rule-card small{border-top:1px solid var(--rule);color:var(--label-text);line-height:1.5;padding-top:.65rem}.sound-table{background:var(--field-bg);border:1px solid var(--panel-border);border-radius:8px;overflow:hidden}.sound-row{align-items:stretch;border-bottom:1px solid var(--rule);display:grid;gap:0;grid-template-columns:minmax(4.7rem,.7fr) minmax(3.7rem,.55fr) minmax(3.7rem,.55fr) minmax(0,2fr)}.sound-row:last-child{border-bottom:0}.sound-row>span,.sound-row>code{align-items:center;border-right:1px solid var(--rule);color:var(--ink);display:flex;min-width:0;overflow-wrap:anywhere;padding:.68rem .75rem}.sound-row>:last-child{border-right:0}.sound-row code,.pipeline-card code{color:var(--summary-text);font-family:var(--font-japanese-ui);font-weight:700}.sound-head{background:linear-gradient(90deg,var(--summary-bg),color-mix(in srgb,var(--summary-bg) 58%,transparent))}.sound-head span{color:var(--summary-text);font-size:.82rem;font-weight:800}.pipeline-grid{display:grid;gap:.75rem;grid-template-columns:repeat(4,minmax(0,1fr))}.pipeline-card code{background:var(--summary-bg);border:1px solid var(--summary-border);border-radius:6px;overflow-wrap:anywhere;padding:.55rem .62rem}.pipeline-card p{color:var(--muted);line-height:1.55}.block-pitfalls{background:color-mix(in srgb,var(--vermilion) 10%,var(--paper));border:1px solid color-mix(in srgb,var(--vermilion) 36%,var(--rule));border-radius:10px;padding:.7rem .9rem}.block-pitfalls-title{color:var(--vermilion);font-size:.82rem;font-weight:700;letter-spacing:.04em;margin:0 0 .4rem;text-transform:uppercase}.block-pitfalls ul{color:var(--ink);line-height:1.6;margin:0;padding-left:1.2rem}.block-pitfalls li{overflow-wrap:anywhere}.block-pitfalls li+li{margin-top:.32rem}.block-drill-note{background:var(--summary-bg);border:1px dashed var(--summary-border);border-radius:8px;color:var(--summary-text);font-size:.84rem;line-height:1.55;margin:0;overflow-wrap:anywhere;padding:.55rem .75rem}.inline-action-row{display:flex;flex-wrap:wrap;gap:.65rem}.inline-drill-button{background:var(--matcha);border-color:var(--matcha-dark);color:var(--selected-text);font-weight:800;justify-self:start;min-width:9rem}.lesson-grid{display:grid;gap:.8rem;grid-template-columns:repeat(3,minmax(0,1fr));margin-top:1.15rem}.lesson-card{background:linear-gradient(180deg,color-mix(in srgb,var(--field-bg) 96%,var(--indigo) 4%),var(--field-bg));border:1px solid var(--panel-border);border-radius:8px;display:grid;gap:.7rem;min-height:17rem;padding:1rem}.lesson-card span{color:var(--teal);font-size:.82rem;font-weight:800}.lesson-card h3{color:var(--ink);font-size:1.1rem;line-height:1.35}.lesson-card p{color:var(--muted);line-height:1.65}.formula-row{align-self:end;display:grid;gap:.45rem}.formula-row code{background:var(--summary-bg);border:1px solid var(--summary-border);border-radius:6px;color:var(--summary-text);font-family:var(--font-japanese-ui);font-weight:700;padding:.5rem .6rem}.start-challenge{background:var(--vermilion);border-color:var(--vermilion);color:var(--selected-text);font-weight:800;min-width:11rem}.practice-layout{display:grid;gap:1rem;grid-template-columns:minmax(236px,.82fr) minmax(340px,1.65fr) minmax(230px,.76fr);margin:0 auto;max-width:1220px}.controls-panel,.drill-panel,.review-panel{animation:panel-rise .24s ease both;background:var(--paper);border:1px solid var(--panel-border);border-radius:12px;box-shadow:var(--shadow);padding:1.15rem}.drill-panel{animation-delay:60ms;min-height:640px}.review-panel{animation-delay:.12s}.brand-lockup{align-items:center;border-bottom:1px solid var(--rule);display:flex;gap:.8rem;margin-bottom:1.1rem;padding-bottom:1rem}.brand-lockup svg{color:var(--teal);height:2rem;width:2rem}.brand-lockup p{color:var(--muted);font-family:var(--font-title);font-size:.82rem}.brand-lockup h2{color:var(--ink);font-family:var(--font-title);font-size:1.55rem;font-weight:700;line-height:1.2}fieldset{border:0;margin:0 0 1rem;padding:0}legend,.select-label{color:var(--label-text);display:block;font-size:.86rem;font-weight:800;margin-bottom:.45rem}.segmented{display:grid;gap:.42rem;grid-template-columns:repeat(2,minmax(0,1fr))}.segmented button,.ghost-button{background:color-mix(in srgb,var(--paper) 88%,var(--field-bg));color:var(--button-text)}.segmented button{min-width:0;white-space:nowrap}.segmented button.selected{background:var(--matcha);border-color:var(--matcha-dark);color:var(--selected-text)}.focus-segmented{grid-template-columns:1fr}select{background:linear-gradient(180deg,color-mix(in srgb,var(--field-bg) 95%,var(--indigo) 5%),var(--field-bg));border:1px solid var(--field-border);border-radius:6px;color:var(--ink);min-height:2.9rem;padding:.64rem .75rem;width:100%}select:focus,button:focus-visible{box-shadow:0 0 0 4px var(--focus-fill);outline:3px solid var(--focus-outline);outline-offset:2px}select:disabled{background:var(--field-disabled-bg);color:var(--field-disabled-text)}.focus-summary{background:var(--summary-bg);border:1px solid var(--summary-border);border-radius:6px;color:var(--summary-text);font-size:.84rem;font-weight:800;line-height:1.45;margin:.6rem 0 1rem;overflow-wrap:anywhere;padding:.64rem .72rem}.mode-toggle{display:flex;flex-direction:column;gap:.5rem}.mode-card{display:flex;flex-direction:column;align-items:flex-start;gap:.18rem;padding:.7rem .8rem;border:1px solid var(--rule);border-radius:9px;background:var(--paper);color:var(--ink);text-align:left;font:inherit;cursor:pointer;transition:border-color .15s ease,background .15s ease,transform .08s ease}.mode-card:hover{border-color:var(--teal)}.mode-card:active{transform:translateY(1px)}.mode-card.selected{border-color:var(--teal);background:color-mix(in srgb,var(--teal) 14%,var(--paper))}.mode-card strong{font-size:1.02rem;font-weight:700;line-height:1.25}.mode-card small{font-size:.78rem;color:var(--muted);line-height:1.4;white-space:normal;overflow-wrap:anywhere;word-break:break-word;-webkit-hyphens:auto;hyphens:auto}.mode-card.selected small{color:color-mix(in srgb,var(--ink) 70%,var(--muted))}.mode-description{padding:.7rem .8rem;margin:.4rem 0 0;border:1px dashed var(--rule);border-radius:9px;background:var(--paper-deep);color:var(--muted);font-size:.85rem;line-height:1.55;white-space:normal;overflow-wrap:anywhere;word-break:break-word;-webkit-hyphens:auto;hyphens:auto}.mode-description p{margin:0}.score-strip{border-bottom:1px solid var(--rule);border-top:1px solid var(--rule);display:grid;gap:.4rem;grid-template-columns:repeat(3,minmax(0,1fr));margin:1rem 0;padding:.8rem 0}.score-strip span{color:var(--muted);display:grid;font-size:.78rem;gap:.18rem;justify-items:center;text-align:center}.score-strip strong{color:var(--ink);font-size:1.25rem;line-height:1}.prompt-header{align-items:center;display:flex;justify-content:space-between}.prompt-header span,.prompt-header strong{border:1px solid var(--prompt-chip-border);border-radius:999px;color:var(--prompt-chip-text);font-size:.88rem;line-height:1;padding:.42rem .72rem}.prompt-header strong{background:linear-gradient(135deg,var(--target-chip-bg),color-mix(in srgb,var(--target-chip-bg) 62%,transparent));border-color:var(--target-chip-border);color:var(--target-chip-text)}.word-block{align-items:center;display:grid;isolation:isolate;justify-items:center;min-height:268px;padding:2rem 0 1.1rem;position:relative}.word-block:before{background:radial-gradient(circle,color-mix(in srgb,var(--teal) 14%,transparent),transparent 66%);content:"";height:14rem;left:50%;pointer-events:none;position:absolute;top:46%;transform:translate(-50%,-50%);width:min(26rem,100%);z-index:-1}.word-block>*{position:relative;z-index:1}.word-kind{align-items:center;background:var(--word-kind-bg);border:1px solid var(--word-kind-border);border-radius:999px;color:var(--indigo);display:inline-flex;font-size:.82rem;font-weight:800;gap:.35rem;margin-bottom:.8rem;padding:.35rem .68rem}.word-kind svg{height:.95rem;width:.95rem}.reading,.meaning{color:var(--muted)}.surface{color:var(--surface-ink);font-family:var(--font-japanese-display);font-size:6rem;line-height:1.05;margin:.35rem 0;overflow-wrap:anywhere;text-align:center;text-shadow:var(--surface-shadow)}.exam-prompt{color:var(--surface-ink);font-family:var(--font-japanese);font-size:clamp(1.35rem,2.4vw,2.05rem);line-height:1.65;max-width:42rem;overflow-wrap:anywhere;text-align:left}.choice-grid{display:grid;gap:.6rem;grid-template-columns:repeat(2,minmax(0,1fr))}.choice-option{background:linear-gradient(180deg,color-mix(in srgb,var(--field-bg) 88%,var(--indigo) 12%),var(--field-bg));border-color:color-mix(in srgb,var(--field-border) 80%,var(--indigo));color:var(--ink);font-family:var(--font-japanese-ui);font-size:1.18rem;font-weight:700;box-shadow:inset 0 1px color-mix(in srgb,var(--ink) 8%,transparent);min-height:3.6rem;overflow-wrap:anywhere;padding:.7rem}.choice-option:hover:not(:disabled){background:linear-gradient(180deg,color-mix(in srgb,var(--field-bg) 78%,var(--teal) 22%),var(--field-bg))}.choice-option:disabled{opacity:1}.choice-option.correct{background:var(--feedback-correct-bg);border-color:var(--green);color:var(--ink)}.choice-option.incorrect{background:var(--feedback-incorrect-bg);border-color:var(--vermilion);color:var(--ink)}.next-button{background:var(--vermilion);border-color:var(--vermilion);color:var(--selected-text);font-weight:800;min-width:5.7rem}.action-row{display:flex;gap:.6rem;justify-content:flex-end;margin-top:.85rem}.feedback{background:var(--field-bg);border:1px solid;border-left-width:5px;border-radius:8px;margin-top:1rem;padding:1rem}.feedback.correct{background:var(--feedback-correct-bg);border-color:var(--feedback-correct-border);border-left-color:var(--green)}.feedback.incorrect{background:var(--feedback-incorrect-bg);border-color:var(--feedback-incorrect-border);border-left-color:var(--vermilion)}.feedback.revealed{background:var(--feedback-revealed-bg);border-color:var(--feedback-revealed-border);border-left-color:var(--gold)}.feedback-title{align-items:center;display:flex;gap:.5rem}.feedback-title svg{height:1.2rem;width:1.2rem}.feedback.correct .feedback-title{color:var(--green)}.feedback.incorrect .feedback-title{color:var(--vermilion)}.feedback.revealed .feedback-title{color:var(--feedback-revealed-title)}.answer-key{color:var(--ink);font-weight:800}.example{border-top:1px solid var(--example-rule);margin-bottom:0;padding-top:.75rem}.example span{color:var(--muted);display:block;margin-top:.25rem}.review-heading{align-items:center;display:flex;justify-content:space-between}.review-heading h2{color:var(--ink);font-size:1rem}.review-heading span{background:var(--review-pill-bg);border:1px solid var(--review-pill-border);border-radius:999px;color:var(--indigo);font-size:.82rem;font-weight:800;padding:.28rem .58rem}.review-panel ul{list-style:none;margin:1rem 0 0;padding:0}.review-panel li{border-bottom:1px solid var(--rule);color:var(--review-row-text);padding:.75rem 0}.review-panel p,.empty-state{color:var(--muted)}@media(max-width:980px){.app-heading{align-items:start;display:grid}.app-heading>p{text-align:left}.practice-layout{grid-template-columns:1fr}.chapter-shell{grid-template-columns:1fr;min-height:0}.chapter-index{border-bottom:1px solid var(--rule);border-right:0;grid-template-rows:auto;padding:0 0 1rem}.chapter-list{grid-template-columns:repeat(2,minmax(0,1fr))}.learning-hero{min-height:clamp(500px,calc(100vh - 8rem),640px)}.quick-start-heading,.detail-divider{align-items:start;display:grid}.quick-start-heading>p,.detail-divider>p{text-align:left}.rule-matrix.three-column{grid-template-columns:1fr}.learning-roadmap,.quick-start-grid,.pipeline-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.lesson-grid{grid-template-columns:1fr}.drill-panel{min-height:auto;order:1}.controls-panel{order:2}.review-panel{order:3}.surface{font-size:5rem}}@media(max-width:560px){body{background:var(--app-bg)}.app-shell{padding:.75rem}.app-heading h1{font-size:1.65rem}.heading-actions{align-items:stretch;display:grid;grid-template-columns:1fr}.heading-actions p{grid-column:1 / -1;text-align:left}.language-switch{border-radius:8px;justify-content:center}.theme-toggle{justify-self:stretch;padding-inline:.72rem}.controls-panel,.drill-panel,.learning-panel,.review-panel{padding:1rem}.chapter-list{grid-template-columns:1fr}.chapter-content-head h3{font-size:2rem}.chapter-actions{display:grid}.chapter-actions .start-challenge{justify-self:stretch}.learning-copy{gap:.75rem}.learning-copy h2{font-size:2.25rem}.learning-copy>p:not(.eyebrow){font-size:.95rem;line-height:1.5}.learning-hero{min-height:calc(100vh - 12rem);padding:2rem .25rem}.focus-formula{display:grid;font-size:.95rem;gap:.35rem;justify-items:center;padding:.75rem}.focus-formula span+span:before{display:block;margin:0 0 .2rem}.learning-path-card{padding:.75rem}.learning-roadmap{gap:.42rem;grid-template-columns:1fr}.learning-roadmap li{align-items:center;display:flex;gap:.5rem;padding:.5rem 0 .5rem .65rem}.learning-roadmap span{flex:0 0 auto;font-size:.72rem}.learning-roadmap strong{font-size:.9rem;line-height:1.25}.learning-roadmap p{display:none}.surface{font-size:4.25rem}.answer-row,.quick-start-grid{grid-template-columns:1fr}.quick-start-button{justify-self:stretch}.choice-grid,.pipeline-grid{grid-template-columns:1fr}.sound-row{grid-template-columns:minmax(3.4rem,.7fr) minmax(2.9rem,.52fr) minmax(2.9rem,.52fr) minmax(0,1.8fr)}.sound-row>span,.sound-row>code{padding:.58rem .5rem}.inline-action-row,.action-row{display:grid}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:1ms!important;scroll-behavior:auto!important;transition-duration:1ms!important}}@keyframes panel-rise{0%{transform:translateY(8px)}to{transform:translateY(0)}}.home-panel{display:flex;flex-direction:column;gap:1.4rem;max-width:940px;margin:0 auto;width:100%}.home-hero{display:flex;flex-direction:column;gap:.9rem}.home-hero-image{width:100%;aspect-ratio:16 / 9;max-height:280px;object-fit:cover;object-position:center 38%;border-radius:.95rem;border:1px solid var(--panel-border);background:var(--paper);display:block}.home-hero-text{display:flex;flex-direction:column;gap:.4rem}.home-hero-text .eyebrow{margin:0;font-weight:700;color:var(--teal-dark);letter-spacing:.18em;text-transform:uppercase}.home-hero-text h1{margin:0;font-size:clamp(1.6rem,3vw,2.1rem);color:var(--ink)}.home-hero-text p{margin:0;color:var(--muted);line-height:1.6}@media(max-width:720px){.home-hero-image{max-height:200px}}.home-banner{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:.8rem;padding:1rem 1.15rem;border-radius:.85rem;border:1px solid var(--panel-border);cursor:pointer;text-align:left;transition:box-shadow .16s ease}.home-banner:hover{box-shadow:var(--button-hover-shadow)}.home-banner-review{background:var(--feedback-incorrect-bg);border-color:var(--feedback-incorrect-border);color:var(--vermilion)}.home-banner-continue{background:var(--summary-bg);border-color:var(--summary-border);color:var(--summary-text)}.home-banner-text{display:flex;flex-direction:column;gap:.2rem}.home-banner-text strong{font-size:1rem;line-height:1.25}.home-banner-text small{font-size:.82rem;color:var(--muted);font-weight:400}.home-content-stats{margin:0;padding:.7rem 1rem;color:var(--ink);font-size:.9rem;text-align:center;border-top:1px solid var(--rule);border-bottom:1px solid var(--rule);font-variant-numeric:tabular-nums;letter-spacing:.02em;line-height:1.6}.home-stats-strip{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem;padding:.9rem 1.1rem;background:var(--paper);border:1px solid var(--rule);border-radius:.85rem}.home-stats-cell{display:flex;flex-direction:column;gap:.15rem;align-items:center;text-align:center}.home-stats-cell strong{font-size:1.4rem;font-variant-numeric:tabular-nums;color:var(--ink)}.home-stats-cell small{font-size:.78rem;color:var(--muted);letter-spacing:.02em}.home-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:.85rem}.home-card{position:relative;display:grid;grid-template-columns:auto 1fr;grid-template-rows:auto auto auto;grid-template-areas:"icon title" "icon body" "icon meta";gap:.35rem .85rem;padding:1.05rem 1.1rem 1.2rem;background:var(--paper);border:1px solid var(--panel-border);border-radius:.95rem;text-align:left;cursor:pointer;transition:box-shadow .16s ease,transform .16s ease}.home-card:hover:not(:disabled){box-shadow:var(--button-hover-shadow);transform:translateY(-1px)}.home-card-stage{grid-area:icon;align-self:start;display:inline-flex;align-items:center;justify-content:center;width:2.2rem;height:2.2rem;margin-top:.1rem;font-family:var(--font-japanese-display);font-size:1.25rem;font-weight:600;color:var(--matcha-dark);background:transparent;border:1px solid color-mix(in srgb,var(--matcha) 42%,var(--rule));border-radius:.4rem;line-height:1}.home-card h2{grid-area:title;margin:0;font-size:1.1rem;color:var(--ink)}.home-card p{grid-area:body;margin:0;font-size:.9rem;color:var(--muted);line-height:1.5}.home-card-meta{grid-area:meta;margin-top:.2rem;font-size:.78rem;color:var(--teal-dark);font-weight:600;letter-spacing:.02em}.home-card-arrow{position:absolute;top:.95rem;right:.95rem;width:1.1rem;height:1.1rem;color:var(--muted)}.home-card-dimmed{opacity:.55;cursor:not-allowed}.home-card-dimmed .home-card-stage{color:var(--field-disabled-text);border-color:var(--rule)}@media(max-width:720px){.home-grid{grid-template-columns:1fr}.home-stats-strip{grid-template-columns:1fr;gap:.6rem}}.dashboard-card{display:flex;flex-direction:column;gap:.7rem;padding:.95rem 1rem;margin-bottom:1rem;background:var(--paper);border:1px solid var(--panel-border);border-radius:.85rem}.dashboard-card .eyebrow{margin:0;color:var(--teal-dark);font-size:.78rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase}.dashboard-review-cta{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:.55rem;padding:.7rem .85rem;background:var(--feedback-revealed-bg);border:1px solid var(--feedback-revealed-border);border-radius:.7rem;color:var(--feedback-revealed-title);font-weight:600;cursor:pointer;text-align:left}.dashboard-review-cta:hover{box-shadow:var(--button-hover-shadow)}.dashboard-review-text{font-size:.95rem}.dashboard-review-action{padding:.18rem .55rem;background:var(--vermilion);color:var(--selected-text);border-radius:999px;font-size:.78rem;font-weight:700;letter-spacing:.02em}.dashboard-review-empty{margin:0;padding:.55rem .7rem;background:var(--summary-bg);border:1px solid var(--summary-border);border-radius:.65rem;color:var(--summary-text);font-size:.9rem}.dashboard-stats{display:flex;flex-wrap:wrap;gap:.45rem;color:var(--muted);font-size:.85rem;font-variant-numeric:tabular-nums}.speak-button{display:inline-flex;align-items:center;justify-content:center;margin-left:.4rem;padding:.2rem;width:1.6rem;height:1.6rem;background:transparent;border:1px solid var(--prompt-chip-border);border-radius:999px;color:var(--teal-dark);cursor:pointer;vertical-align:middle}.speak-button:hover{background:var(--summary-bg);border-color:var(--teal);color:var(--teal)}.speak-button svg{width:.95rem;height:.95rem}.mock-panel{display:flex;flex-direction:column;gap:1.4rem;max-width:920px;margin:0 auto;width:100%}.mock-setup,.mock-running,.mock-results{display:flex;flex-direction:column;gap:1.4rem;background:var(--panel-bg);border:1px solid var(--panel-border);border-radius:1.1rem;padding:1.6rem 1.8rem;box-shadow:var(--shadow)}.mock-setup-head{display:flex;flex-direction:column;gap:.6rem}.mock-setup-head .eyebrow{display:inline-flex;align-items:center;gap:.4rem;color:var(--teal-dark);font-weight:600}.mock-setup-intro{color:var(--muted);line-height:1.6}.mock-setup-meta{display:inline-flex;align-items:center;gap:.4rem;color:var(--gold);font-weight:600}.mock-level-picker{border:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.5rem}.mock-level-picker legend{color:var(--label-text);font-weight:600;font-size:.9rem}.mock-section-list h3,.mock-section-breakdown h3,.mock-wrong-list h3{margin:0 0 .6rem;font-size:1rem;color:var(--ink)}.mock-section-summary{color:var(--muted);margin:0 0 .8rem;font-size:.92rem}.mock-section-rows{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.5rem}.mock-section-row{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:.8rem;padding:.65rem .9rem;background:var(--paper);border:1px solid var(--rule);border-radius:.7rem}.mock-section-row.empty{background:var(--field-disabled-bg);color:var(--field-disabled-text)}.mock-section-row.partial{border-color:var(--feedback-revealed-border);background:var(--feedback-revealed-bg)}.mock-section-badge{display:inline-flex;align-items:center;justify-content:center;min-width:4.2rem;padding:.15rem .55rem;font-size:.78rem;font-weight:600;color:var(--prompt-chip-text);background:#0000000a;border:1px solid var(--prompt-chip-border);border-radius:999px}.mock-section-meta{display:flex;flex-direction:column;gap:.15rem;min-width:0}.mock-section-meta strong{font-family:var(--font-japanese-ui);font-size:.98rem}.mock-section-meta small{color:var(--muted);font-size:.82rem}.mock-section-pool{display:flex;flex-direction:column;align-items:flex-end;gap:.2rem;font-variant-numeric:tabular-nums;font-size:.92rem;color:var(--ink)}.mock-section-warn{display:inline-flex;align-items:center;gap:.3rem;color:var(--vermilion);font-style:normal;font-size:.78rem;font-weight:600}.mock-actions{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:.4rem}.mock-actions .next-button{flex:1 1 auto;min-width:12rem}.mock-running-head{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;flex-wrap:wrap}.mock-running-head .eyebrow{color:var(--teal-dark);font-weight:600}.mock-running-head strong{font-size:1.1rem}.mock-elapsed{display:inline-flex;align-items:center;gap:.3rem;padding:.4rem .7rem;background:var(--summary-bg);border:1px solid var(--summary-border);border-radius:.6rem;font-variant-numeric:tabular-nums;color:var(--summary-text)}.mock-elapsed strong{font-size:1.05rem}.mock-question{display:flex;flex-direction:column;gap:1rem;padding:1rem 1.1rem;background:var(--paper);border:1px solid var(--rule);border-radius:.9rem}.mock-question .prompt-header{display:flex;align-items:center;justify-content:space-between;font-size:.85rem;color:var(--prompt-chip-text)}.mock-question .prompt-header span{display:inline-flex;padding:.15rem .6rem;background:#0000000a;border:1px solid var(--prompt-chip-border);border-radius:999px}.mock-nav{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}.mock-nav .next-button{flex:1 1 auto}.mock-nav .mock-exit{margin-left:auto}.mock-results-head{display:flex;flex-direction:column;gap:.5rem}.mock-results-head h2{margin:0;font-size:1.6rem;color:var(--teal-dark);font-variant-numeric:tabular-nums}.mock-results-meta{color:var(--muted);display:inline-flex;align-items:center;gap:.35rem}.mock-results-gap{display:inline-flex;align-items:center;gap:.4rem;padding:.55rem .8rem;background:var(--feedback-revealed-bg);border:1px solid var(--feedback-revealed-border);border-radius:.6rem;color:var(--feedback-revealed-title);font-size:.92rem}.mock-wrong-list ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.8rem}.mock-wrong-item{padding:.85rem 1rem;background:var(--paper);border:1px solid var(--rule);border-radius:.7rem;display:flex;flex-direction:column;gap:.45rem}.mock-wrong-head{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem}.mock-wrong-prompt{font-family:var(--font-japanese-display);font-size:1.02rem;color:var(--surface-ink)}.mock-wrong-submitted{color:var(--vermilion);font-weight:600}.mock-wrong-explanation{color:var(--review-row-text);font-size:.92rem;line-height:1.55;margin:0}@media(max-width:720px){.mock-setup,.mock-running,.mock-results{padding:1.2rem 1.1rem}.mock-section-row{grid-template-columns:auto 1fr;grid-template-rows:auto auto}.mock-section-pool{grid-column:1 / -1;align-items:flex-start}}
