:root{--jp-font: "Noto Sans JP", ui-sans-serif, system-ui, sans-serif;--radical-bg: #2f6fd6;--radical-text: #ffffff;--kanji-bg: #1599ad;--kanji-text: #ffffff;--vocabulary-bg: #7a4bd8;--vocabulary-text: #ffffff;font-family:Inter,var(--jp-font),ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;font-optical-sizing:auto;color:#202323;background:#f4f1eb;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}button,input,select{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed;opacity:.5}.subjectBadge.subjectType-radical{background:var(--radical-bg);color:var(--radical-text)}.subjectBadge.subjectType-kanji{background:var(--kanji-bg);color:var(--kanji-text)}.subjectBadge.subjectType-vocabulary{background:var(--vocabulary-bg);color:var(--vocabulary-text)}.subjectBadge{display:inline-grid;place-items:center;border:2px solid #303436;border-radius:10px;box-shadow:none}.app{display:grid;grid-template-columns:260px minmax(0,1fr);min-height:100vh}.authShell{display:grid;min-height:100vh;place-items:center;padding:24px;background:#f4f1eb}.authPanel{display:grid;gap:16px;width:min(100%,420px);padding:28px;border:1px solid #ded7ca;border-radius:8px;background:#fffdf8;box-shadow:0 16px 40px #1f2a2d14}.authPanel h1{font-size:34px}.authError{padding:10px 12px;border:1px solid #e4c2a9;border-radius:8px;background:#fff4e7;color:#9a4e39;font-weight:700}.googleButton{display:inline-flex;min-height:44px;align-items:center;justify-content:center;gap:9px;border:1px solid #303436;border-radius:8px;background:#fff;color:#202323;font-weight:900}.googleButton:hover{background:#f6f8f8}.sidebar{display:flex;flex-direction:column;gap:24px;padding:22px;background:#1f2a2d;color:#f7f4ee}.brand{display:flex;align-items:center;gap:12px}.brandMark{display:grid;width:46px;height:46px;place-items:center;border-radius:8px;background:#dc5f45;color:#fff;font-family:var(--jp-font);font-size:28px;font-weight:800;font-style:normal}.brand strong,.brand span{display:block}.brand span{margin-top:2px;color:#b8c5c1;font-size:13px}.sidebarLevel{display:grid;gap:6px;width:100%;padding:14px;border:1px solid #42565a;border-radius:8px;background:#172224;color:#f7f4ee;text-align:left}.sidebarLevel:hover{border-color:#6d8589;background:#263538}.sidebarLevel span{color:#aebfba;font-size:12px;font-weight:800;text-transform:uppercase}.sidebarLevel strong{font-size:42px;line-height:.95}.sidebarLevel small{color:#d2ddd9;font-weight:700}.sidebarLevelBar,.levelAdvanceTrack{position:relative;overflow:hidden;height:8px;border-radius:999px;background:#3b4d50}.sidebarLevelBar span,.levelAdvanceTrack span{display:block;height:100%;border-radius:inherit;background:#dc5f45}.nav{display:grid;gap:8px}.nav button,.ghostButton{display:flex;align-items:center;gap:10px;min-height:42px;border:0;border-radius:8px;background:transparent;color:#dce5e2;text-align:left}.nav button{padding:0 12px}.nav button.active,.nav button:hover,.ghostButton:hover{background:#314246;color:#fff}.ghostButton{margin-top:auto;padding:0 12px}.main{min-width:0;padding:28px clamp(18px,4vw,46px)}.topbar{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;margin-bottom:28px}.eyebrow{margin:0 0 6px;color:#697170;font-size:13px;font-weight:700;letter-spacing:0;text-transform:uppercase}h1,h2,p{margin-top:0}h1{margin-bottom:0;font-size:clamp(30px,4vw,46px);line-height:1}h2{margin-bottom:8px}.topActions{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:10px}.pill{display:inline-flex;align-items:center;gap:8px;min-height:36px;padding:0 12px;border:1px solid #d9d3c7;border-radius:999px;background:#fffdf8;color:#3b4241;white-space:nowrap}.pill.accent{border-color:#fac7a0;background:#fff4e7}.heroBand{display:flex;align-items:center;justify-content:space-between;gap:26px;padding:28px;border-radius:8px;background:#fffdf8;box-shadow:0 16px 40px #1f2a2d14}.heroBand h2{margin-bottom:8px;font-size:clamp(34px,5vw,64px)}.heroBand p{max-width:620px;margin-bottom:0;color:#5d6765}.levelSpotlight{display:grid;flex:0 0 150px;min-height:150px;place-items:center;align-content:center;border:2px solid #303436;border-radius:8px;background:#1f2a2d;color:#fffdf8}.levelSpotlight span,.levelSpotlight small{color:#cad8d4;font-weight:800;text-transform:uppercase}.levelSpotlight span{font-size:13px}.levelSpotlight strong{font-size:76px;line-height:.9}.levelSpotlight small{font-size:12px}.levelHeroText{flex:1 1 auto}.levelAdvanceTrack{overflow:visible;max-width:620px;margin-top:18px;background:#e1d8ca}.levelAdvanceTrack span{background:#2f8b7b}.levelAdvanceTrack i{position:absolute;top:-5px;width:3px;height:18px;border-radius:999px;background:#dc5f45}.progressRing{--value: 0%;display:grid;flex:0 0 132px;width:132px;height:132px;place-items:center;border-radius:50%;background:conic-gradient(#2f8b7b var(--value),#e8dfd1 0)}.progressRing span{display:grid;width:92px;height:92px;place-items:center;border-radius:50%;background:#fffdf8;font-size:24px;font-weight:800}.statsGrid,.stageGrid,.kanjiGrid{display:grid;gap:14px}.statsGrid{grid-template-columns:repeat(4,minmax(0,1fr));margin-top:18px}.metric,.stageCard,.kanjiCard,.emptyState,.reviewCard,.tableWrap{border:1px solid #ded7ca;border-radius:8px;background:#fffdf8}.metric{display:grid;gap:8px;min-height:152px;padding:18px}.metricIcon{display:grid;width:38px;height:38px;place-items:center;border-radius:8px;background:#e6f2ee;color:#2f8b7b}.metric svg{width:19px;height:19px}.metric span{color:#687271;font-size:14px}.metric strong{font-size:28px}.metric button,.primaryButton,.secondaryButton{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:38px;padding:0 14px;border:0;border-radius:8px;background:#1f2a2d;color:#fff;font-weight:700}.secondaryButton{border:1px solid #cfc7ba;background:#fffdf8;color:#26302f}.sectionHeader{display:flex;align-items:end;justify-content:space-between;gap:14px;margin:30px 0 12px}.sectionHeader h2{margin:0}.sectionHeader span{color:#697170}.stageGrid{grid-template-columns:repeat(5,minmax(0,1fr))}.stageCard{min-height:126px;padding:16px}.stageCard span,.stageCard small,.kanjiMeta span,.kanjiMeta small{display:block;color:#6a7472}.stageCard strong{display:block;margin:8px 0;font-size:32px}.stageCard small{line-height:1.4}.settingsPage{max-width:720px}.settingsPanel{display:grid;gap:20px;padding:22px;border:1px solid #ded7ca;border-radius:8px;background:#fffdf8}.settingsPanel p{margin-bottom:0;color:#5d6765}.settingControl{display:grid;gap:8px;max-width:220px}.settingControl span{color:#697170;font-size:13px;font-weight:800;text-transform:uppercase}.settingControl input{min-height:44px;padding:0 12px;border:1px solid #cfc7ba;border-radius:8px;background:#fff}.settingSummary{display:flex;align-items:baseline;gap:10px;padding-top:14px;border-top:1px solid #ece5da}.settingSummary strong{font-size:28px}.settingSummary span{color:#697170}.kanjiGrid{grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}.kanjiCard{display:grid;grid-template-columns:auto minmax(0,1fr);gap:12px;padding:16px}.kanjiGlyph,.reviewGlyph,.tableGlyph{font-family:var(--jp-font);font-optical-sizing:auto;font-style:normal}.kanjiGlyph{width:74px;height:74px;font-size:58px;line-height:1}.kanjiMeta{min-width:0}.kanjiMeta strong{display:block;margin:5px 0}.kanjiCard .primaryButton{grid-column:1 / -1}.emptyState{display:grid;min-height:320px;place-items:center;align-content:center;padding:30px;text-align:center}.emptyState p{max-width:440px;color:#687271}.reviewSurface{max-width:720px;margin:0 auto}.reviewProgress{display:flex;align-items:center;gap:12px;margin-bottom:12px}.reviewProgress>div{overflow:hidden;flex:1;height:9px;border-radius:999px;background:#ddd6c9}.reviewProgress>div span{display:block;height:100%;border-radius:inherit;background:#2f8b7b}.reviewCard{display:grid;justify-items:center;padding:clamp(20px,5vw,52px);text-align:center}.promptType{display:inline-flex;align-items:center;justify-content:center;padding:7px 12px;border-radius:999px;background:#ffe8d9;color:#9a4e39;font-weight:800}.reviewGlyph{display:grid;width:min(48vw,210px);height:min(48vw,210px);margin:26px auto;place-items:center;font-size:clamp(96px,18vw,178px);line-height:.9}.reviewGlyph.subjectType-vocabulary{width:min(86vw,560px);min-height:150px;height:auto;padding:18px 24px;font-size:64px;line-height:1.08;white-space:normal;overflow-wrap:anywhere}.answerForm{display:grid;width:100%;grid-template-columns:minmax(0,1fr) auto auto;gap:10px}.answerForm input,.searchBox input,.toolbar select{min-height:44px;border:1px solid #cfc7ba;border-radius:8px;background:#fff;color:#202323}.answerForm input,.searchBox input{width:100%;padding:0 12px}.feedback{margin-top:14px;font-weight:800}.answerReveal{display:grid;gap:5px;margin-top:16px;padding:14px;border:1px solid #e4c2a9;border-radius:8px;background:#fff4e7;text-align:left}.answerReveal span{color:#9a4e39;font-size:13px;font-weight:800;text-transform:uppercase}.answerReveal strong{font-size:18px}.answerReveal small{color:#5d6765}.revealDetails{display:grid;gap:6px;margin-top:8px}.revealDetails p{margin:0;color:#39413f;font-size:14px;line-height:1.45}.feedback.correct{color:#2f8b7b}.feedback.incorrect{color:#c24b3b}.levelGrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(70px,1fr));gap:8px}.levelTile{display:grid;min-height:62px;place-items:center;border:1px solid #d7d0c4;border-radius:8px;background:#fffdf8;color:#222827}.levelTile span{font-weight:900}.levelTile small{color:#6d7472}.levelTile.selected{border-color:#2f8b7b;box-shadow:inset 0 0 0 2px #2f8b7b}.levelTile.locked{background:#ebe5da;color:#818783;opacity:.58}.levelSubjectGroups{display:grid;gap:24px}.levelSubjectGroup h3{margin:0 0 10px}.subjectTileGrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(118px,1fr));gap:10px}.subjectTileGrid.vocabularyTiles{grid-template-columns:repeat(auto-fill,minmax(170px,1fr))}.subjectTile{display:grid;gap:7px;min-height:158px;align-content:center;padding:12px;border:1px solid #ded7ca;border-radius:8px;background:#fffdf8;color:#202323;text-align:center}.levelSubjectGroups .subjectTile.locked{opacity:.46}.levelSubjectGroups .subjectTile.locked:hover{opacity:.62}.subjectTile{justify-items:center}.subjectTile:hover{border-color:#2f8b7b;background:#f1faf6}.subjectTileGrid.vocabularyTiles .subjectTile{min-height:146px}.subjectTileGlyph{overflow:hidden;width:76px;height:76px;font-family:var(--jp-font);font-size:44px;font-weight:800;line-height:1.05;text-overflow:ellipsis;white-space:nowrap}.vocabularyTiles .subjectTileGlyph{width:132px;max-width:100%;font-size:30px}.subjectTile strong{overflow:hidden;font-size:14px;line-height:1.25;text-overflow:ellipsis;white-space:nowrap}.subjectTile small{overflow:hidden;color:#697170;font-size:12px;line-height:1.25;text-overflow:ellipsis;white-space:nowrap}.subjectTileStage{display:inline-flex;align-items:center;justify-content:center;min-height:24px;max-width:100%;padding:0 8px;border:1px solid #d9d3c7;border-radius:999px;background:#f3eee5;color:#2f3836;font-weight:800}.subjectTileReading{max-width:100%;font-family:var(--jp-font)}.toolbar{display:grid;grid-template-columns:minmax(0,1fr) 160px;gap:12px;margin-bottom:16px}.searchBox{position:relative}.searchBox svg{position:absolute;top:13px;left:12px;color:#687271}.searchBox input{padding-left:40px}.toolbar select{padding:0 10px}.tableBlock{margin-top:18px}.tableBlock h3{margin:0 0 10px}.tableWrap{overflow:auto}table{width:100%;border-collapse:collapse;min-width:760px}th,td{padding:12px 14px;border-bottom:1px solid #e7e1d6;text-align:left;vertical-align:top}th{color:#687271;font-size:13px}.tableGlyph{width:74px;font-size:34px;font-weight:700}.tableWord{min-width:120px;width:160px;font-family:var(--jp-font);font-optical-sizing:auto;font-size:24px;font-weight:700;font-style:normal;line-height:1.25;white-space:nowrap;writing-mode:horizontal-tb}.tableWordButton{display:inline-grid;min-width:54px;min-height:44px;padding:4px 10px;border:2px solid #303436;border-radius:10px;color:inherit;font:inherit;font-weight:800;text-align:left;text-decoration:none}.tableWordButton.subjectBadge.subjectType-radical{background:var(--radical-bg);color:var(--radical-text)}.tableWordButton.subjectBadge.subjectType-kanji{background:var(--kanji-bg);color:var(--kanji-text)}.tableWordButton.subjectBadge.subjectType-vocabulary{background:var(--vocabulary-bg);color:var(--vocabulary-text)}.tableGlyph .tableWordButton{font-family:var(--jp-font);font-size:34px}.miniBadgeList{display:flex;flex-wrap:wrap;gap:6px}.miniBadge{min-width:32px;min-height:32px;padding:2px 7px;border:2px solid #303436;border-radius:10px;font-family:var(--jp-font);font-size:18px;font-weight:800;line-height:1}.detailPage{display:grid;gap:18px}.backButton,.externalLink{display:inline-flex;align-items:center;gap:8px;width:fit-content;min-height:38px;padding:0 12px;border:1px solid #cfc7ba;border-radius:8px;background:#fffdf8;color:#26302f;font-weight:700;text-decoration:none}.detailHero{display:grid;grid-template-columns:auto minmax(0,1fr);gap:24px;align-items:center;padding:26px;border-radius:8px;background:#fffdf8;box-shadow:0 16px 40px #1f2a2d14}.detailWord{width:clamp(104px,14vw,156px);height:clamp(104px,14vw,156px);font-family:var(--jp-font);font-optical-sizing:auto;font-size:clamp(58px,9vw,108px);font-weight:800;font-style:normal;line-height:1;white-space:nowrap}.detailWord.subjectType-vocabulary{width:min(100%,440px);min-height:clamp(104px,14vw,156px);height:auto;padding:16px 20px;font-size:52px;line-height:1.08;white-space:normal;overflow-wrap:anywhere}.detailHero h2{margin-bottom:8px;font-size:clamp(30px,4vw,48px)}.detailHero p{color:#5d6765}.detailGrid{display:none;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.wkDetail{display:grid;gap:18px}.wkSection{padding:22px;border:1px solid #ded7ca;border-radius:8px;background:#fffdf8}.wkSection h2{margin:0 0 18px;font-size:28px}.wkField{display:grid;gap:8px;padding:14px 0;border-top:1px solid #ece5da}.wkField:first-of-type{border-top:0;padding-top:0}.wkField h3{margin:0;color:#697170;font-size:13px;font-weight:800;text-transform:uppercase}.wkField p,.wideText p{margin:0;color:#2f3836;line-height:1.65}.readingLine{margin-bottom:16px;font-family:var(--jp-font);font-size:34px;font-weight:800;line-height:1.2}.inlineAction{width:fit-content;min-height:34px;padding:0 12px;border:1px dashed #cfc7ba;border-radius:8px;background:#f7f2e9;color:#697170;font-weight:800}.patternList{display:flex;flex-wrap:wrap;gap:8px}.patternList button{display:inline-flex;min-height:32px;align-items:center;padding:0 10px;border:1px solid #cbded8;border-radius:8px;background:#e6f2ee;color:#255f56;font-family:var(--jp-font);font-weight:800}.patternList button.selected{border-color:#2f8b7b;background:#2f8b7b;color:#fff}.pairedList{display:grid;gap:12px}.pairedLine{display:grid;gap:4px;padding-bottom:12px;border-bottom:1px solid #eee8dd}.pairedLine:last-child{padding-bottom:0;border-bottom:0}.pairedLine span{font-family:var(--jp-font);font-size:18px;font-weight:800}.pairedLine small,.emptyText{color:#697170;line-height:1.45}.componentList{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px}.componentItem{display:grid;gap:4px;padding:12px;border:1px solid #e7e1d6;border-radius:8px;background:#fbf8f1}.componentButton{width:100%;color:#202323;text-align:left}.componentButton:hover:not(:disabled){border-color:#2f8b7b;background:#f1faf6}.componentItem strong{font-family:var(--jp-font);font-size:28px}.componentItem span{font-family:var(--jp-font);font-weight:800}.componentItem small{color:#697170}.detailSection{padding:16px;border:1px solid #ded7ca;border-radius:8px;background:#fffdf8}.detailSection.wide{grid-column:1 / -1}.detailSection h3{margin:0 0 12px}.detailSection p,.detailList{margin:0;color:#3f4846;line-height:1.5}.detailList{display:grid;gap:8px;padding-left:18px}.detailSubblock{display:grid;gap:8px;margin-bottom:14px}.detailSubblock:last-child{margin-bottom:0}.meaningGroups{display:grid;gap:14px}.meaningGroup{display:grid;gap:8px}.meaningGroup>span{color:#697170;font-size:13px;font-weight:800;text-transform:uppercase}.tagList{display:flex;flex-wrap:wrap;gap:8px}.tag{display:inline-flex;align-items:center;min-height:32px;padding:0 10px;border:1px solid #cbded8;border-radius:999px;background:#e6f2ee;color:#255f56;font-weight:800}.tag.muted{border-color:#d9d3c7;background:#f3eee5;color:#596260}.audioGrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px}.audioButton{display:grid;grid-template-columns:auto minmax(0,1fr);grid-template-rows:auto auto;gap:2px 8px;align-items:center;min-height:58px;padding:9px 10px;border:1px solid #cfc7ba;border-radius:8px;background:#fffdf8;color:#26302f;text-align:left}.audioButton:hover{border-color:#2f8b7b;background:#f1faf6}.audioButton svg{grid-row:1 / 3;color:#2f8b7b}.audioButton span{font-family:var(--jp-font);font-weight:800;white-space:nowrap}.audioButton small{overflow:hidden;color:#697170;text-overflow:ellipsis;white-space:nowrap}.levelToast{position:fixed;right:22px;bottom:22px;z-index:20;display:grid;grid-template-columns:auto minmax(0,1fr) auto;gap:12px;align-items:center;width:min(420px,calc(100vw - 24px));padding:14px;border:2px solid #303436;border-radius:8px;background:#fffdf8;color:#202323;box-shadow:0 18px 44px #1f2a2d33}.levelToastMark{display:grid;width:54px;height:54px;place-items:center;border-radius:8px;background:#1f2a2d;color:#fff;font-size:28px;font-weight:900}.levelToast span{color:#dc5f45;font-size:12px;font-weight:900;text-transform:uppercase}.levelToast strong{display:block;font-size:22px}.levelToast p{margin:2px 0 0;color:#5d6765;line-height:1.35}.levelToast button{width:30px;height:30px;border:1px solid #cfc7ba;border-radius:8px;background:#fffdf8;color:#5d6765;font-weight:900}@media(max-width:900px){.app{grid-template-columns:1fr}.sidebar{position:sticky;top:0;z-index:5;flex-direction:row;align-items:center;overflow-x:auto;padding:12px}.brand{flex:0 0 auto}.sidebarLevel{grid-template-columns:auto auto;flex:0 0 150px;width:150px;padding:9px 11px}.sidebarLevel strong{grid-row:1 / 3;grid-column:1;font-size:30px}.sidebarLevel span,.sidebarLevel small{grid-column:2;align-self:center}.sidebarLevelBar{grid-column:1 / -1}.brandMark{width:38px;height:38px;font-size:23px}.nav{display:flex;flex:1 0 auto}.nav button,.ghostButton{white-space:nowrap}.ghostButton{margin-top:0}.topbar,.heroBand,.sectionHeader,.detailHero{align-items:flex-start;flex-direction:column}.statsGrid,.stageGrid,.detailGrid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:560px){.main{padding:18px 12px 28px}.topActions{justify-content:flex-start}.statsGrid,.stageGrid,.detailGrid,.toolbar,.answerForm{grid-template-columns:1fr}.progressRing{flex-basis:112px;width:112px;height:112px}.progressRing span{width:78px;height:78px;font-size:20px}.reviewGlyph.subjectType-vocabulary{width:100%;min-height:118px;padding:14px 16px;font-size:42px}.detailWord.subjectType-vocabulary{width:100%;min-height:104px;font-size:40px}}
