:root{--bg:#fbfbfa;--surface:#fff;--surface-2:#f9f9f8;--border:#eaeaea;--border-strong:#e0e0dd;--text:#1f2023;--text-muted:#787774;--accent-ink:#1a1a1a;--accent-blue:#10476b;--accent-blue-2:#2f5f84;--accent-green:#2f6b4f;--accent-ochre:#8b6400;--pale-blue-bg:#e1f3fe;--pale-blue-fg:#1f6c9f;--pale-green-bg:#edf3ec;--pale-green-fg:#346538;--pale-yellow-bg:#fbf3db;--pale-yellow-fg:#956400;--radius:10px;--radius-sm:6px;--maxw:880px;--font-sans:var(--font-manrope),"Helvetica Neue",system-ui,sans-serif;--font-serif:var(--font-lora),"Iowan Old Style",Georgia,serif;--font-mono:var(--font-mono-jb),ui-monospace,"SF Mono",monospace;--font-jp:"Hiragino Kaku Gothic ProN","Yu Gothic","Meiryo","Noto Sans JP",var(--font-sans)}*{box-sizing:border-box}body,html{margin:0;padding:0;background:var(--bg);color:var(--text);font-family:var(--font-sans);font-size:16px;line-height:1.6;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}.stitch-frame,.stitch-frame-shell{width:100%;min-height:100dvh;background:#f9f9fc}.stitch-frame{display:block;height:100dvh;border:0}.stitch-frame-mobile{display:none}@media (max-width:767px){.stitch-frame-desktop{display:none}.stitch-frame-mobile{display:block}}.jp,:lang(ja){font-family:var(--font-jp)}h1,h2,h3{font-family:var(--font-serif);font-weight:500;letter-spacing:0;line-height:1.1;margin:0}a{color:inherit;text-decoration:none}button{font-family:inherit}.container{max-width:var(--maxw);margin:0 auto;padding:0 24px}.app-page{padding-top:40px;padding-bottom:80px}.app-shell{min-height:100dvh;display:grid;grid-template-columns:236px minmax(0,1fr);background:var(--bg)}.app-shell-focus{display:block}.app-main{min-width:0}.app-content{max-width:1180px;margin:0 auto;padding:40px 48px 88px}.stack{display:flex;flex-direction:column}.muted{color:var(--text-muted)}.mono{font-family:var(--font-mono)}.center{text-align:center}.eyebrow{margin:0 0 6px;color:var(--text-muted);font-family:var(--font-mono);font-size:12px;text-transform:uppercase}.topbar{position:-webkit-sticky;position:sticky;top:0;z-index:20;height:64px;display:flex;align-items:center;justify-content:space-between;padding:0 24px;background:hsla(60,11%,98%,.85);-webkit-backdrop-filter:saturate(180%) blur(8px);backdrop-filter:saturate(180%) blur(8px);border-bottom:1px solid var(--border)}.brand{font-family:var(--font-serif);font-size:18px;letter-spacing:0}.sidebar{position:-webkit-sticky;position:sticky;top:0;height:100dvh;display:flex;flex-direction:column;border-right:1px solid var(--border);background:var(--surface);padding:22px 18px}.sidebar-brand{display:flex;align-items:center;gap:12px;color:var(--accent-blue);margin-bottom:28px}.sidebar-brand strong{display:block;font-size:22px;line-height:1.1}.sidebar-brand small{display:block;color:var(--text-muted);font-size:11px}.brand-mark,.goal-icon,.mini-icon,.profile-dot{display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--border-strong);background:var(--surface-2);color:var(--accent-blue)}.brand-mark{width:38px;height:38px;border-radius:8px;font-weight:800}.side-nav{display:grid;grid-gap:4px;gap:4px}.side-link{display:flex;align-items:center;gap:10px;min-height:38px;padding:8px 10px;border-radius:6px;color:var(--text-muted);font-size:14px;font-weight:600}.side-link:hover{background:var(--surface-2);color:var(--text)}.side-link.active{background:#e8f0f7;color:var(--accent-blue)}.nav-symbol{width:22px;text-align:center;font-weight:700}.sidebar-footer{margin-top:auto;display:grid;grid-gap:10px;gap:10px}.account-email{color:var(--text-muted);font-size:11px;word-break:break-all}.mobile-nav,.mobile-topbar{display:none}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:1px solid var(--border-strong);background:var(--surface);color:var(--text);border-radius:var(--radius-sm);padding:9px 16px;font-size:14px;font-weight:500;cursor:pointer;transition:transform .12s ease,background .2s ease,border-color .2s ease}.btn:hover{border-color:#c9c9c4}.btn:active{transform:scale(.98)}.btn:disabled{opacity:.5;cursor:default}.btn-primary{background:var(--accent-ink);color:#fff;border-color:var(--accent-ink)}.btn-primary:hover{background:#333;border-color:#333}.btn-ghost{background:transparent;border-color:transparent;color:var(--text-muted)}.btn-ghost:hover{color:var(--text);background:var(--surface-2)}.card{border:1px solid var(--border);border-radius:var(--radius)}.card,.panel{background:var(--surface);padding:24px}.panel{border:1px solid var(--border-strong);border-radius:8px}.field{display:flex;flex-direction:column;gap:6px}.label{font-size:13px;color:var(--text-muted)}.input{border:1px solid var(--border-strong);background:var(--surface);border-radius:var(--radius-sm);padding:10px 12px;font-size:15px;color:var(--text);width:100%;transition:border-color .15s ease}.input:focus{outline:none;border-color:#b6b6b0}.input::placeholder{color:#b3b3ae}.badge{display:inline-block;font-size:11px;text-transform:uppercase;letter-spacing:0;padding:2px 8px;border-radius:9999px;font-weight:600;background:var(--pale-blue-bg);color:var(--pale-blue-fg)}.badge-neutral{background:var(--surface-2);color:var(--text-muted);border:1px solid var(--border)}.note-list{display:flex;flex-direction:column;border-top:1px solid var(--border)}.note-row{display:flex;align-items:baseline;gap:16px;padding:16px 4px;border-bottom:1px solid var(--border)}.note-expr{font-size:22px}.note-expr,.note-reading{font-family:var(--font-jp);min-width:120px}.note-reading{color:var(--text-muted);font-size:14px}.note-meaning{flex:1 1}.nav-active,.nav-link{font-size:14px;padding:6px 0;color:var(--text-muted);position:relative}.nav-active,.nav-link:hover{color:var(--text)}.nav-active{font-weight:600}.nav-active:after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:2px;background:var(--accent-ink)}.due-pill{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;padding:2px 8px;border-radius:9999px;background:var(--pale-green-bg);color:var(--pale-green-fg);margin-left:6px}.due-banner{display:flex;align-items:center;justify-content:space-between;gap:16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px 24px;margin-top:24px}.due-banner .count{font-family:var(--font-serif);font-size:40px;line-height:1}.page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;margin-bottom:24px}.page-head h1{font-size:38px}.page-head p{max-width:56ch;margin:10px 0 0}.section-title{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:14px}.section-title h2{font-family:var(--font-sans);font-size:15px;font-weight:700;line-height:1.2}.text-link{color:var(--accent-blue);font-size:13px;font-weight:700}.text-link:hover{text-decoration:underline}.app-heading,.today-hero{display:flex;justify-content:space-between;align-items:flex-start;gap:24px;margin-bottom:28px}.app-heading h1,.today-hero h1{font-family:var(--font-sans);font-size:clamp(30px,5vw,42px);font-weight:800;line-height:1.15;margin:0}.app-heading p,.today-hero p{margin-top:8px}.streak-box{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--border-strong);background:var(--surface);color:var(--accent-ochre);padding:8px 12px;border-radius:4px;font-family:var(--font-mono)}.streak-mark{font-family:var(--font-jp);font-weight:800}.today-grid{display:grid;grid-template-columns:minmax(0,1.3fr) minmax(260px,.7fr);grid-gap:24px;gap:24px}.daily-goal-card{border-top:6px solid var(--accent-blue)}.daily-goal-head{display:flex;justify-content:space-between;gap:18px}.daily-goal-head h2,.section-title h2{margin:0}.goal-icon,.mini-icon{width:48px;height:48px;border-radius:10px;font-family:var(--font-jp);font-size:20px}.goal-total{display:flex;align-items:baseline;gap:12px;margin:30px 0 14px}.goal-total strong{font-family:var(--font-serif);font-size:72px;line-height:.95;font-weight:500}.goal-badges{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:24px}.status-chip{display:inline-flex;align-items:center;min-height:30px;border:1px solid var(--border-strong);border-radius:3px;padding:4px 10px;font-weight:700}.chip-starter{background:#eaf4ef;color:var(--accent-green)}.chip-core{background:#e8f0f7;color:var(--accent-blue)}.goal-bars{display:grid;grid-gap:14px;gap:14px;margin-bottom:24px}.bar-label{display:flex;justify-content:space-between;color:var(--text-muted);font-size:13px;font-weight:700;margin-bottom:6px}.meter{height:8px;border-radius:999px;background:#e4e4e2;overflow:hidden}.meter span{display:block;height:100%;background:var(--accent-green)}.btn-wide{width:100%;min-height:48px;text-transform:uppercase;letter-spacing:.05em}.recent-list,.recent-row{display:grid}.recent-row{grid-template-columns:minmax(56px,auto) 1fr;grid-gap:12px;gap:12px;align-items:baseline;padding:12px 0;border-bottom:1px solid var(--border)}.recent-row .jp{font-size:22px;font-weight:700}.today-section{margin-top:34px}.learning-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:18px;gap:18px}.learning-card{display:grid;grid-gap:8px;gap:8px;border:1px solid var(--border-strong);background:var(--surface);border-radius:8px;padding:22px}.learning-card:hover,.recommendation-row:hover{border-color:var(--accent-blue-2)}.learning-card strong{font-size:21px}.learning-card small{color:var(--accent-blue);font-weight:800}.recommendation-box{margin-top:28px}.today-recommendations{display:grid;grid-gap:1px;gap:1px;border-top:1px solid var(--border)}.recommendation-row{display:grid;grid-template-columns:48px minmax(0,1fr) auto;grid-gap:14px;gap:14px;align-items:center;padding:16px 0;border-bottom:1px solid var(--border)}.recommendation-symbol{display:inline-flex;width:44px;height:44px;align-items:center;justify-content:center;border:1px solid var(--border-strong);border-radius:8px;background:var(--surface-2);color:var(--accent-blue);font-size:24px;font-weight:800}.recommendation-row small,.recommendation-row strong{display:block}.recommendation-row small{color:var(--text-muted)}.notes-form{display:grid;grid-gap:16px;gap:16px}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:16px;gap:16px}.note-panel{margin-top:24px}.dictionary-page{max-width:1040px}.dictionary-heading{align-items:center;margin-bottom:34px}.live-status{display:inline-flex;align-items:center;gap:8px;min-height:34px;border:1px solid var(--border-strong);border-radius:999px;background:var(--surface);color:var(--accent-blue);padding:6px 12px;font-family:var(--font-mono);font-size:12px;text-transform:uppercase}.live-status span{width:8px;height:8px;border-radius:999px;background:var(--accent-green);box-shadow:0 0 0 4px rgba(47,107,79,.12)}.search-panel{display:grid;grid-template-columns:auto minmax(0,1fr) auto auto;align-items:center;grid-gap:14px;gap:14px;background:var(--surface);border:1px solid var(--border-strong);border-radius:8px;padding:14px 16px;box-shadow:0 10px 26px rgba(31,32,35,.04)}.search-panel:focus-within{border-color:var(--accent-blue-2)}.search-icon{display:inline-flex;width:34px;height:34px;align-items:center;justify-content:center;border-radius:999px;background:#e8f0f7;color:var(--accent-blue);font-family:var(--font-serif);font-size:25px;line-height:1}.search-panel .label{font-family:var(--font-mono);font-size:11px;text-transform:uppercase}.search-field .input{min-height:44px;border:0;border-radius:0;padding:0;font-size:19px;background:transparent}.search-field .input:focus{border-color:transparent}.icon-button{display:inline-flex;width:38px;height:38px;align-items:center;justify-content:center;border:1px solid var(--border);border-radius:999px;background:var(--surface);color:var(--text-muted);font-size:23px;line-height:1;cursor:pointer}.icon-button:hover{border-color:var(--border-strong);color:var(--text)}.dictionary-results{margin-top:34px}.recommendation-panel{margin-top:26px;background:var(--surface);border:1px solid var(--border-strong);border-radius:8px;padding:24px}.recommendation-panel .section-title{align-items:flex-start;margin-bottom:18px}.recommendation-panel .section-title p{margin:6px 0 0;max-width:64ch}.recommendation-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));grid-gap:16px;gap:16px}.recommendation-band{position:relative;min-height:176px;border:1px solid var(--border);border-radius:8px;background:var(--surface-2);padding:16px;overflow:hidden}.recommendation-band:after{content:"";position:absolute;top:-28px;right:-28px;width:92px;height:92px;border-radius:999px;background:#e8f0f7;opacity:.8}.recommendation-band.band-starter:after{background:#eaf4ef}.recommendation-band.band-expansion:after{background:#fbf3db}.recommendation-band-head{position:relative;z-index:1;display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:12px}.recommendation-band-title{font-size:18px;font-weight:750;color:var(--accent-blue)}.band-starter .recommendation-band-title{color:var(--accent-green)}.band-expansion .recommendation-band-title{color:var(--accent-ochre)}.recommendation-band-head .mono{color:var(--text-muted);font-size:12px}.recommendation-chips{position:relative;z-index:1;display:grid;grid-template-columns:1fr;grid-gap:8px;gap:8px}.recommendation-chip{display:grid;grid-template-columns:1fr auto;grid-gap:2px 8px;gap:2px 8px;align-items:baseline;text-align:left;border:1px solid var(--border);border-radius:999px;background:var(--surface);color:var(--text);padding:8px 11px;cursor:pointer;transition:background .18s ease,border-color .18s ease,transform .12s ease}.recommendation-chip:hover{background:var(--surface);border-color:var(--border-strong)}.recommendation-chip:active{transform:scale(.99)}.recommendation-chip .jp:first-child{font-size:18px;font-weight:650}.recommendation-chip .muted{grid-column:1/2;font-size:13px}.recommendation-chip .mono{grid-column:2/3;grid-row:1/3;align-self:center;color:var(--text-muted);font-size:12px}.dictionary-list{display:grid;grid-gap:1px;gap:1px;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;background:var(--border)}.dictionary-entry{display:grid;grid-template-columns:minmax(164px,.55fr) minmax(0,1fr) auto;grid-gap:22px;gap:22px;align-items:center;background:var(--surface);padding:18px 20px;transition:background .18s ease}.dictionary-entry:hover{background:#fcfcfb}.dictionary-expression{font-size:34px;font-weight:650;line-height:1.1}.dictionary-reading{color:var(--text-muted);margin-top:6px}.dictionary-meta{display:flex;flex-wrap:wrap;gap:6px;margin-top:12px}.definition-list{margin:0;padding-left:20px}.definition-list li+li{margin-top:4px}.dictionary-pos{margin-top:10px;font-size:13px}.dictionary-result-head{align-items:flex-end;border-bottom:1px solid var(--border);padding-bottom:10px}.dictionary-result-head p{margin:6px 0 0;font-size:13px}.result-flags{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:8px}.study{min-height:100dvh;display:flex;flex-direction:column;gap:28px;padding:108px 24px 56px;background:var(--bg)}.study,.study-top{align-items:center;justify-content:center}.study-top{position:fixed;top:0;left:0;right:0;z-index:30;display:grid;grid-template-columns:44px minmax(0,680px) 44px;grid-gap:18px;gap:18px;padding:28px 24px 18px;background:hsla(60,11%,98%,.9);-webkit-backdrop-filter:saturate(180%) blur(8px);backdrop-filter:saturate(180%) blur(8px)}.study-icon-button{display:inline-flex;width:42px;height:42px;align-items:center;justify-content:center;border:1px solid transparent;border-radius:999px;color:var(--text-muted);background:transparent;font-size:28px;line-height:1}.study-icon-button:hover{border-color:var(--border);background:var(--surface);color:var(--text)}.study-progress{display:grid;grid-gap:8px;gap:8px}.study-progress-row{display:flex;justify-content:space-between;gap:16px;font-size:12px}.study-progress-track{height:5px;border-radius:999px;background:#e4e4e2;overflow:hidden}.study-progress-track span{display:block;height:100%;border-radius:inherit;background:var(--accent-blue);transition:width .25s ease}.study-card{position:relative;width:100%;max-width:680px;min-height:342px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;border:1px solid var(--border-strong);border-radius:8px;background:var(--surface);padding:58px 48px;text-align:center;box-shadow:0 14px 36px rgba(31,32,35,.045)}.study-meta-row{position:absolute;top:18px;left:18px;right:18px;display:flex;justify-content:space-between;gap:12px}.study-expr{font-family:var(--font-jp);font-size:84px;font-weight:650;line-height:1;letter-spacing:0}.study-reading{font-family:var(--font-jp);font-size:24px;color:var(--accent-blue)}.study-divider{width:min(100%,360px);height:1px;background:var(--border);margin:4px 0}.study-meaning{max-width:42ch;font-size:22px;line-height:1.45}.grade-row{display:grid;grid-template-columns:repeat(4,1fr);grid-gap:12px;gap:12px;width:100%;max-width:680px}.grade-button{position:relative;display:grid;place-items:center;grid-gap:3px;gap:3px;min-height:74px;border:1px solid var(--border-strong);border-radius:8px;background:var(--surface);color:var(--text);cursor:pointer;transition:background .18s ease,border-color .18s ease,transform .12s ease}.grade-button:hover{transform:translateY(-1px)}.grade-button:disabled{opacity:.55;cursor:default;transform:none}.grade-button span{font-size:17px;font-weight:800}.grade-button small{color:var(--text-muted);font-size:12px}.grade-button kbd{position:absolute;top:7px;right:8px;color:var(--text-muted);font-family:var(--font-mono);font-size:10px}.grade-again:hover{border-color:#e0b6b6;background:#fff0ef}.grade-hard:hover{border-color:#e0cf9b;background:#fbf3db}.grade-good:hover{border-color:#bad8c5;background:#eaf4ef}.grade-easy:hover{border-color:#b7d2e5;background:#e8f0f7}.study-done{width:min(100%,560px);min-height:280px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:18px;border:1px solid var(--border-strong);border-radius:8px;background:var(--surface);padding:36px;text-align:center}.study-done h1{font-family:var(--font-sans);font-size:28px;font-weight:800}@keyframes fade-up{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}.fade-up{animation:fade-up .5s cubic-bezier(.16,1,.3,1) both}@media (prefers-reduced-motion:reduce){.fade-up{animation:none}}.hero{min-height:calc(100dvh - 64px);display:flex;flex-direction:column;justify-content:center;padding:48px 0}.hero h1{font-size:clamp(40px,7vw,72px);max-width:14ch}.hero p.lead{font-size:19px;color:var(--text-muted);max-width:52ch;margin:20px 0 0}.features{display:grid;grid-gap:1px;gap:1px;background:var(--border);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;margin-top:48px}@media (min-width:768px){.features{grid-template-columns:repeat(3,1fr)}}.feature{background:var(--surface);padding:24px}.feature .k{font-family:var(--font-mono);font-size:12px;color:var(--text-muted)}@media (max-width:760px){.app-shell{display:block;padding-bottom:74px}.sidebar{display:none}.mobile-topbar{position:-webkit-sticky;position:sticky;top:0;z-index:30;display:flex;align-items:center;justify-content:space-between;height:72px;padding:0 22px;background:hsla(60,11%,98%,.92);-webkit-backdrop-filter:saturate(180%) blur(8px);backdrop-filter:saturate(180%) blur(8px);border-bottom:1px solid var(--border-strong)}.mobile-brand{color:var(--accent-blue);font-size:34px;font-weight:800;line-height:1}.profile-dot{width:34px;height:34px;border-radius:999px;font-weight:800}.mobile-nav{position:fixed;left:0;right:0;bottom:0;z-index:40;display:grid;grid-template-columns:repeat(4,1fr);min-height:68px;background:hsla(60,11%,98%,.96);border-top:1px solid var(--border-strong);-webkit-backdrop-filter:saturate(180%) blur(8px);backdrop-filter:saturate(180%) blur(8px)}.mobile-nav-link{display:grid;place-items:center;grid-gap:2px;gap:2px;padding:7px 4px;color:var(--text-muted);font-size:12px;font-weight:650}.mobile-nav-link.active{color:var(--accent-blue)}.mobile-nav-link.active .nav-symbol{background:#e8f0f7}.mobile-nav .nav-symbol{display:inline-flex;width:38px;height:30px;align-items:center;justify-content:center;border-radius:12px}.app-content{padding:32px 22px}.app-heading,.today-hero{align-items:flex-start}.form-grid,.learning-grid,.today-grid{grid-template-columns:1fr}.goal-total strong{font-size:62px}.recommendation-row{grid-template-columns:44px minmax(0,1fr) auto}.topbar{height:auto;align-items:flex-start;gap:12px;padding:14px 18px;flex-direction:column}.dictionary-heading{align-items:flex-start;margin-bottom:20px}.live-status{align-self:flex-start}.dictionary-page .search-panel{position:-webkit-sticky;position:sticky;top:72px;z-index:25;grid-template-columns:auto minmax(0,1fr) auto;gap:10px;margin:0 -10px;border-radius:0 0 8px 8px}.dictionary-page .search-panel .btn-primary{grid-column:1/-1;width:100%}.search-panel{grid-template-columns:1fr}.recommendation-panel{padding:18px}.recommendation-grid{grid-template-columns:1fr}.recommendation-band{min-height:auto}.dictionary-result-head{align-items:flex-start}.result-flags{justify-content:flex-start}.dictionary-entry{grid-template-columns:1fr;gap:14px;align-items:start;padding:18px 4px;border-radius:0}.dictionary-list{border-left:0;border-right:0;border-radius:0;background:transparent}.dictionary-expression{font-size:36px}.dictionary-entry .btn{width:100%}.study{justify-content:space-between;gap:18px;padding:88px 16px 24px}.study-top{grid-template-columns:40px minmax(0,1fr) 40px;gap:8px;padding:14px 14px 12px;border-bottom:1px solid var(--border)}.study-icon-button{width:38px;height:38px}.study-card{min-height:312px;padding:52px 22px 34px;box-shadow:none}.study-expr{font-size:58px}.study-reading{font-size:20px}.study-meaning{font-size:19px}.grade-button{min-height:68px}.grade-row{grid-template-columns:repeat(2,1fr)}}.material-symbols-outlined{font-family:Material Symbols Outlined;font-weight:400;font-style:normal;font-size:24px;line-height:1;letter-spacing:normal;text-transform:none;display:inline-block;white-space:nowrap;word-wrap:normal;direction:ltr;-webkit-font-feature-settings:"liga";-webkit-font-smoothing:antialiased;font-variation-settings:"FILL" 0,"wght" 400,"GRAD" 0,"opsz" 24}.material-symbols-outlined[data-fill=true]{font-variation-settings:"FILL" 1,"wght" 400,"GRAD" 0,"opsz" 24}:root{--st-background:#f9f9fc;--st-surface:#f9f9fc;--st-surface-lowest:#fff;--st-surface-low:#f3f3f7;--st-surface-container:#edeef1;--st-surface-high:#e8e8eb;--st-surface-highest:#e2e2e6;--st-outline:#72787f;--st-outline-variant:#c1c7cf;--st-on-surface:#1a1c1e;--st-on-surface-variant:#42474e;--st-primary:#10476b;--st-primary-container:#2f5f84;--st-on-primary:#fff;--st-on-primary-container:#afd8ff;--st-secondary:#2d694d;--st-secondary-container:#aeedca;--st-on-secondary-container:#326e51;--st-tertiary:#593f00;--st-tertiary-container:#750;--st-tertiary-fixed:#ffdea5;--st-tertiary-fixed-dim:#f1bf5d;--st-error:#ba1a1a;--st-error-container:#ffdad6;--st-on-error-container:#93000a;--st-radius:2px;--st-radius-lg:4px;--st-radius-xl:8px;--st-margin-mobile:16px;--st-margin-desktop:48px;--st-gutter:24px;--st-card-padding:20px;--st-font:var(--font-manrope),"Noto Sans JP",system-ui,sans-serif;--st-jp:"Noto Sans JP","Hiragino Kaku Gothic ProN","Yu Gothic",Meiryo,var(--st-font)}.st-shell{min-height:100dvh;color:var(--st-on-background,var(--st-on-surface))}.st-auth-page{min-height:100dvh;background:linear-gradient(135deg,rgba(225,243,254,.48),transparent 36%),linear-gradient(315deg,rgba(255,222,165,.32),transparent 34%),var(--st-background);color:var(--st-on-surface);font-family:var(--st-font);padding:clamp(24px,5vw,64px)}.st-auth-hero{display:grid;grid-template-columns:minmax(0,1fr) minmax(320px,420px);grid-gap:clamp(28px,6vw,76px);gap:clamp(28px,6vw,76px);align-items:center;width:min(100%,1120px);min-height:calc(100dvh - clamp(48px, 10vw, 128px));margin:0 auto}.st-auth-copy{display:grid;grid-gap:22px;gap:22px}.st-auth-copy h1,.st-auth-status h1{margin:0;color:var(--st-on-surface);font-family:var(--st-font);font-size:clamp(42px,7vw,82px);font-weight:850;line-height:.98;text-wrap:balance}.st-auth-copy p:not(.st-eyebrow){max-width:680px;margin:0;color:var(--st-on-surface-variant);font-size:17px;line-height:28px}.st-auth-actions{display:flex;flex-wrap:wrap;align-items:center;gap:14px;margin-top:8px}.st-auth-panel{position:relative;display:grid;grid-gap:20px;gap:20px;min-height:420px;align-content:end;overflow:hidden;padding:var(--st-card-padding)}.st-auth-panel:before{content:"";position:absolute;inset:24px 24px auto auto;width:120px;height:120px;border-radius:999px;background:color-mix(in srgb,var(--st-secondary-container) 64%,transparent)}.st-auth-panel>*{position:relative;z-index:1}.st-auth-card-top{display:flex;align-items:center;justify-content:space-between;gap:12px}.st-auth-review{color:var(--st-on-surface);font-size:clamp(82px,12vw,132px);font-weight:500;line-height:.95}.st-auth-panel strong{color:var(--st-on-surface);font-size:24px;line-height:32px}.st-auth-features{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));grid-gap:16px;gap:16px;width:min(100%,1120px);margin:-28px auto 0}.st-auth-feature{display:grid;grid-template-columns:auto minmax(0,1fr);grid-gap:14px;gap:14px;align-items:center;padding:18px}.st-auth-feature strong{color:var(--st-on-surface);font-size:16px;line-height:22px}.st-auth-loading{display:grid;place-items:center}.st-auth-status{display:flex;width:min(100%,560px);align-items:center;gap:20px;padding:var(--st-card-padding)}.st-auth-status h1{font-size:clamp(32px,5vw,48px)}.st-auth-spinner{display:inline-flex;width:56px;height:56px;flex:0 0 auto;align-items:center;justify-content:center;border-radius:var(--st-radius-lg);background:var(--st-primary-container);color:var(--st-on-primary-container);animation:st-spin 1.2s linear infinite}.st-focus-shell{min-height:100dvh;background:var(--st-background);color:var(--st-on-surface);font-family:var(--st-font)}.st-main{min-width:0;padding-left:256px}.st-page{width:min(100%,1200px);margin:0 auto}.st-page,.st-sidebar{padding:var(--st-margin-desktop)}.st-sidebar{position:fixed;inset:0 auto 0 0;z-index:50;display:flex;width:256px;flex-direction:column;border-right:1px solid var(--st-outline-variant);background:var(--st-surface)}.st-brand{display:grid;grid-gap:2px;gap:2px;margin-bottom:32px}.st-brand strong,.st-mobile-brand strong{color:var(--st-primary);font-family:var(--st-jp);font-size:40px;font-weight:500;line-height:48px}.st-brand span{color:var(--st-on-surface-variant);font-size:13px;font-weight:500;line-height:16px}.st-nav-list{display:grid;grid-gap:22px;gap:22px;margin:0;padding:0}.st-nav-group{display:grid;grid-gap:8px;gap:8px}.st-nav-group ul{display:grid;grid-gap:4px;gap:4px;margin:0;padding:0;list-style:none}.st-nav-section-label{color:var(--st-on-surface-variant);font-size:11px;font-weight:800;line-height:14px;text-transform:uppercase;letter-spacing:.08em;padding-inline:12px}.st-nav-link{display:flex;min-height:48px;align-items:center;gap:12px;padding:12px;color:var(--st-on-surface-variant);font-size:16px;line-height:24px;transition:background .16s ease,color .16s ease,transform .12s ease}.st-nav-link:hover{background:rgba(47,95,132,.1)}.st-nav-link:active{transform:scale(.99)}.st-nav-link.is-active{border-right:2px solid var(--st-primary);color:var(--st-primary);font-weight:700;background:rgba(47,95,132,.1)}.st-sidebar-footer{display:grid;grid-gap:10px;gap:10px;margin-top:auto}.st-user-email{color:var(--st-on-surface-variant);font-family:var(--font-mono);font-size:11px;overflow-wrap:anywhere}.st-primary-action{display:flex;min-height:46px;align-items:center;justify-content:center;gap:8px;border-radius:var(--st-radius-lg);background:var(--st-primary-container);color:var(--st-on-primary-container);font-size:13px;font-weight:600;line-height:16px;transition:opacity .16s ease,transform .12s ease}.st-primary-action:hover{opacity:.9}.st-primary-action:active{transform:scale(.99)}.st-text-button{border:0;background:transparent;color:var(--st-on-surface-variant);cursor:pointer;font:inherit;font-size:13px;text-align:center}.st-icon{flex:0 0 auto}.st-mobile-nav,.st-mobile-topbar{display:none}.st-page-header{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;border-bottom:1px solid var(--st-outline-variant);padding-bottom:16px}.st-eyebrow{margin:0 0 4px;color:var(--st-on-surface-variant);font-size:13px;font-weight:700;line-height:16px;text-transform:uppercase;letter-spacing:.04em}.st-headline{margin:0;color:var(--st-on-surface);font-family:var(--st-jp);font-size:24px;font-weight:700;line-height:32px}.st-body,.st-muted{margin:0;font-size:16px;line-height:24px}.st-muted{color:var(--st-on-surface-variant)}.st-paper{border:1px solid var(--st-outline-variant);border-radius:var(--st-radius-xl)}.st-paper,.st-paper-interactive{background:var(--st-surface-lowest)}.st-paper-interactive{border:1px solid var(--st-outline-variant);border-radius:var(--st-radius-lg);cursor:pointer;transition:background .16s ease,border-color .16s ease,transform .12s ease}.st-paper-interactive:hover{background:rgba(47,95,132,.1)}.st-paper-interactive:active{transform:scale(.99)}.st-section-label{margin:0 0 16px;border-bottom:1px solid var(--st-outline-variant);padding-bottom:8px;color:var(--st-on-surface-variant);font-size:13px;font-weight:700;line-height:16px;text-transform:uppercase;letter-spacing:.04em}.st-today{display:grid;grid-gap:40px;gap:40px}.st-streak{display:flex;align-items:center;gap:8px;border:1px solid rgba(119,85,0,.2);border-radius:var(--st-radius);background:rgba(119,85,0,.08);padding:6px 12px}.st-streak .st-icon{color:var(--st-tertiary-fixed-dim)}.st-streak span:last-child{color:var(--st-on-surface);font-size:13px;font-weight:700}.st-goal-card{position:relative;overflow:hidden;padding:32px}.st-goal-card:after{content:"";position:absolute;top:-64px;right:-64px;width:256px;height:256px;border-bottom-left-radius:999px;background:rgba(47,95,132,.05);pointer-events:none}.st-goal-main{position:relative;z-index:1;display:flex;align-items:center;justify-content:space-between;gap:24px}.st-goal-kicker{margin:0 0 8px;color:var(--st-primary);font-size:13px;font-weight:800;line-height:16px;text-transform:uppercase;letter-spacing:.08em}.st-goal-stats{display:flex;align-items:flex-end;gap:24px;margin-top:16px}.st-stat{display:grid;grid-gap:2px;gap:2px}.st-stat strong{color:var(--st-on-surface);font-family:var(--st-jp);font-size:40px;font-weight:500;line-height:48px}.st-stat:not(:first-child) strong{color:var(--st-primary);font-family:var(--st-font);font-size:24px;font-weight:700;line-height:32px}.st-stat:nth-child(4) strong{color:var(--st-secondary)}.st-stat span{color:var(--st-on-surface-variant);font-size:13px;font-weight:500;line-height:16px}.st-divider{width:1px;height:40px;background:var(--st-outline-variant)}.st-button{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:52px;border:0;border-radius:var(--st-radius-lg);background:var(--st-primary-container);color:var(--st-on-primary-container);cursor:pointer;font-family:var(--st-font);font-size:13px;font-weight:700;line-height:16px;padding:14px 32px;transition:opacity .16s ease,transform .12s ease}.st-button:hover{opacity:.9}.st-button:active{transform:scale(.99)}.st-progress-block{position:relative;z-index:1;margin-top:32px}.st-progress-row{display:flex;justify-content:space-between;margin-bottom:8px;color:var(--st-on-surface-variant);font-size:13px;font-weight:500;line-height:16px}.st-progress-track{height:4px;overflow:hidden;border-radius:999px;background:var(--st-surface-high)}.st-progress-track span{display:block;height:100%;background:var(--st-primary-container)}.st-dashboard-grid{display:grid;grid-template-columns:minmax(0,8fr) minmax(300px,4fr);grid-gap:var(--st-gutter);gap:var(--st-gutter)}.st-dashboard-left{display:grid;grid-gap:40px;gap:40px}.st-learning-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:16px;gap:16px}.st-learning-card{min-height:160px;flex-direction:column;padding:20px}.st-card-top,.st-learning-card{display:flex;justify-content:space-between}.st-card-top{align-items:flex-start}.st-level{display:inline-flex;border-radius:var(--st-radius);background:rgba(47,95,132,.1);color:var(--st-primary);padding:4px 8px;font-size:13px;font-weight:600;line-height:16px}.st-level.secondary{background:rgba(174,237,202,.3);color:var(--st-secondary)}.st-card-title{margin:0;color:var(--st-on-surface);font-size:18px;font-weight:600;line-height:28px}.st-card-caption{margin:4px 0 0;color:var(--st-on-surface-variant);font-size:13px;line-height:16px}.st-recommendation-list{display:grid;grid-gap:12px;gap:12px}.st-recommendation{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px}.st-recommendation-main{display:flex;align-items:center;gap:16px;min-width:0}.st-rec-icon{width:48px;height:48px;flex:0 0 auto;border-radius:var(--st-radius-lg);background:var(--st-surface-high);color:var(--st-on-surface-variant)}.st-icon-button,.st-rec-icon{display:inline-flex;align-items:center;justify-content:center}.st-icon-button{border:0;background:transparent;color:var(--st-primary);cursor:pointer}.st-notes-panel{height:100%;padding:20px}.st-panel-head{display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--st-outline-variant);padding-bottom:8px;margin-bottom:4px}.st-panel-head h3{margin:0;color:var(--st-on-surface-variant);font-size:13px;font-weight:700;line-height:16px;text-transform:uppercase;letter-spacing:.04em}.st-note-list{margin:0;padding:0;list-style:none}.st-tool-list{display:grid;grid-gap:10px;gap:10px;margin-bottom:20px}.st-tool-card{display:grid;grid-template-columns:auto minmax(0,1fr);grid-gap:12px;gap:12px;align-items:center;border:1px solid var(--st-outline-variant);border-radius:var(--st-radius-lg);background:color-mix(in srgb,var(--st-surface-lowest) 74%,var(--st-surface-high));padding:12px;transition:border-color .18s ease,background .18s ease,transform .16s ease}.st-tool-card:hover{border-color:color-mix(in srgb,var(--st-primary) 38%,var(--st-outline-variant));background:color-mix(in srgb,var(--st-surface-lowest) 74%,var(--st-primary-container));transform:translateY(-1px)}.st-tool-card small,.st-tool-card strong{display:block}.st-tool-card strong{color:var(--st-on-surface);font-size:14px;line-height:20px}.st-tool-card small{color:var(--st-on-surface-variant);font-size:12px;line-height:16px}.st-panel-head-subtle{border-top:1px solid var(--st-outline-variant);padding-top:16px}.st-notes-overview{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));grid-gap:16px;gap:16px}.st-note-stat{display:flex;align-items:center;gap:14px;padding:18px}.st-note-stat>.st-icon{display:inline-flex;width:44px;height:44px;align-items:center;justify-content:center;border-radius:var(--st-radius-lg);background:var(--st-surface-high);color:var(--st-primary)}.st-note-stat span,.st-note-stat strong{display:block}.st-note-stat strong{color:var(--st-on-surface);font-size:28px;font-weight:800;line-height:32px}.st-note-stat span{color:var(--st-on-surface-variant);font-size:13px;line-height:16px}.st-notes-layout{display:grid;grid-template-columns:minmax(0,1fr) 360px;grid-gap:var(--st-gutter);gap:var(--st-gutter);align-items:start}.st-note-library{display:grid;grid-gap:12px;gap:12px}.st-note-card{display:grid;grid-template-columns:minmax(132px,.35fr) minmax(0,1fr) auto;grid-gap:18px;gap:18px;align-items:center;padding:18px}.st-note-main{min-width:0}.st-note-expression{display:block;color:var(--st-on-surface);font-size:34px;font-weight:600;line-height:42px;text-wrap:balance}.st-note-card .st-note-reading{display:block;margin:2px 0 0}.st-note-body{min-width:0}.st-note-body span,.st-note-body strong{display:block}.st-note-body strong{color:var(--st-on-surface);font-size:17px;line-height:24px}.st-note-body span{color:var(--st-on-surface-variant);font-size:12px;font-weight:700;line-height:16px;margin-top:3px;text-transform:uppercase}.st-note-actions{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end}.st-note-kanji-panel{grid-column:1/-1;display:flex;flex-wrap:wrap;gap:8px;border-top:1px solid var(--st-outline-variant);padding-top:14px}.st-note-kanji-chip{display:grid;grid-template-columns:auto minmax(0,1fr) auto;grid-gap:8px;gap:8px;align-items:baseline;max-width:100%;border:1px solid var(--st-outline-variant);border-radius:var(--st-radius-lg);background:color-mix(in srgb,var(--st-surface-lowest) 82%,var(--st-primary-container));color:var(--st-on-surface);padding:8px 10px}.st-note-kanji-chip span{color:var(--st-primary);font-size:22px;font-weight:650;line-height:28px}.st-note-kanji-chip small{min-width:0;color:var(--st-on-surface-variant);font-size:12px;line-height:16px;overflow-wrap:anywhere}.st-note-kanji-chip em{color:var(--st-outline);font-family:var(--font-mono);font-size:10px;font-style:normal;font-weight:800;line-height:12px;text-transform:uppercase}.st-quiet-deck-target{margin-top:12px}.st-quiet-deck-target .st-number-input{width:100%}.st-note-item{display:flex;align-items:baseline;justify-content:space-between;gap:14px;border-bottom:1px solid var(--st-outline-variant);margin:0 -8px;padding:12px 8px;border-radius:var(--st-radius-lg);transition:background .16s ease}.st-note-item:hover{background:var(--st-surface-low)}.st-note-word{color:var(--st-on-surface);font-family:var(--st-jp);font-size:16px;font-weight:600}.st-note-reading,.st-note-time{color:var(--st-on-surface-variant);font-size:13px;line-height:16px}.st-note-reading{margin-left:8px}.st-screen-stack{display:grid;grid-gap:32px;gap:32px}.st-page-actions{display:flex;flex-wrap:wrap;align-items:center;justify-content:flex-end;gap:10px}.st-two-column{display:grid;grid-template-columns:minmax(0,1fr) 340px;grid-gap:var(--st-gutter);gap:var(--st-gutter)}.st-toolbar{justify-content:space-between;gap:16px}.st-search-box,.st-toolbar{display:flex;align-items:center}.st-search-box{min-height:56px;gap:12px;border:1px solid var(--st-outline-variant);border-radius:var(--st-radius-xl);background:var(--st-surface-lowest);color:var(--st-on-surface-variant);padding:0 16px}.st-search-box input,.st-textarea{width:100%;border:0;background:transparent;color:var(--st-on-surface);font:inherit;outline:none}.st-textarea{min-height:240px;resize:vertical}.st-chip-row{display:flex;flex-wrap:wrap;gap:8px}.st-chip{display:inline-flex;min-height:32px;align-items:center;justify-content:center;border:1px solid var(--st-outline-variant);border-radius:var(--st-radius);background:var(--st-surface-lowest);color:var(--st-on-surface-variant);padding:4px 12px;-webkit-appearance:none;-moz-appearance:none;appearance:none;font-size:13px;font-weight:600;line-height:16px;cursor:pointer}.st-chip.is-active{border-color:transparent;background:var(--st-primary-container);color:var(--st-on-primary-container)}.st-table{display:grid;overflow:hidden;border:1px solid var(--st-outline-variant);border-radius:var(--st-radius-xl);background:var(--st-surface-lowest)}.st-row{display:grid;grid-template-columns:96px minmax(0,1fr) auto;grid-gap:20px;gap:20px;align-items:center;border-bottom:1px solid var(--st-outline-variant);padding:18px 20px}.st-row:last-child{border-bottom:0}.st-row-symbol{font-family:var(--st-jp);font-size:40px;font-weight:500;line-height:48px}.st-row-title{display:block;color:var(--st-on-surface);font-size:18px;font-weight:700;line-height:28px}.st-row-sub{display:block;color:var(--st-on-surface-variant);font-size:13px;line-height:16px}.st-card-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:var(--st-gutter);gap:var(--st-gutter)}.st-deck-card,.st-kanji-card,.st-metric-card{display:grid;grid-gap:18px;gap:18px;padding:var(--st-card-padding)}.st-deck-card strong,.st-kanji-card strong,.st-metric-card strong{color:var(--st-on-surface);font-size:20px;line-height:28px}.st-kanji-big{color:var(--st-on-surface);font-family:var(--st-jp);font-size:64px;font-weight:500;line-height:80px}.st-deck-icon{display:inline-flex;width:44px;height:44px;align-items:center;justify-content:center;border-radius:var(--st-radius-lg);background:var(--st-surface-high);color:var(--st-primary)}.st-deck-metrics{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));grid-gap:8px;gap:8px}.st-deck-metrics span{display:grid;grid-gap:2px;gap:2px;border:1px solid var(--st-outline-variant);border-radius:var(--st-radius-lg);background:color-mix(in srgb,var(--st-surface-lowest) 72%,var(--st-surface-high));padding:10px}.st-deck-metrics strong{color:var(--st-on-surface);font-size:18px;line-height:24px}.st-deck-metrics small{color:var(--st-on-surface-variant);font-size:11px;font-weight:700;line-height:14px;text-transform:uppercase}.st-deck-footer{display:grid;grid-gap:8px;gap:8px}.st-personal-decks{padding:0}.st-personal-decks summary{display:flex;min-height:64px;align-items:center;justify-content:space-between;gap:16px;cursor:pointer;list-style:none;padding:18px 20px}.st-personal-decks summary::-webkit-details-marker{display:none}.st-personal-deck-row strong,.st-personal-decks summary strong{display:block;color:var(--st-on-surface);font-size:15px;line-height:20px}.st-personal-deck-row small,.st-personal-decks summary small{display:block;color:var(--st-on-surface-variant);font-size:12px;line-height:16px}.st-personal-deck-body{display:grid;grid-gap:16px;gap:16px;border-top:1px solid var(--st-outline-variant);padding:16px 20px 20px}.st-personal-deck-list{display:grid;grid-gap:8px;gap:8px}.st-personal-deck-row{display:flex;align-items:center;justify-content:space-between;gap:14px;border:1px solid var(--st-outline-variant);border-radius:var(--st-radius-lg);background:color-mix(in srgb,var(--st-surface-lowest) 80%,var(--st-surface-high));padding:12px}.st-personal-deck-form{display:grid;grid-template-columns:minmax(0,1fr) auto;grid-gap:10px;gap:10px;align-items:end}.st-course-hero{position:relative;overflow:hidden}.st-course-hero:after{content:"";position:absolute;right:18px;bottom:-32px;width:160px;height:160px;border-radius:999px;background:color-mix(in srgb,var(--st-primary-container) 28%,transparent);pointer-events:none;transform:translateZ(0);animation:st-soft-float 5.6s ease-in-out infinite}.st-course-board{display:grid;grid-template-columns:minmax(0,1.08fr) minmax(320px,.72fr);grid-gap:var(--st-gutter);gap:var(--st-gutter)}.st-course-overview,.st-course-plan{display:grid;grid-gap:18px;gap:18px;padding:var(--st-card-padding)}.st-course-overview>div,.st-course-plan>div{position:relative;z-index:1}.st-course-overview strong,.st-course-overview>strong{color:var(--st-on-surface)}.st-course-metric-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));grid-gap:10px;gap:10px}.st-course-metric{display:grid;grid-gap:8px;gap:8px;min-height:112px;border:1px solid var(--st-outline-variant);border-radius:var(--st-radius-lg);background:color-mix(in srgb,var(--st-surface-lowest) 72%,var(--st-surface-high));padding:12px}.st-course-metric strong{color:var(--st-on-surface);font-size:30px;line-height:36px}.st-course-metric span{color:var(--st-on-surface-variant);font-size:12px;font-weight:700;line-height:16px;text-transform:uppercase}.st-course-steps{display:grid;grid-gap:10px;gap:10px}.st-course-step{display:grid;grid-template-columns:32px minmax(0,1fr) auto;grid-gap:12px;gap:12px;align-items:start;border:1px solid var(--st-outline-variant);border-radius:var(--st-radius-lg);background:var(--st-surface-lowest);padding:12px}.st-course-step strong{display:block;color:var(--st-on-surface);font-size:15px;line-height:20px}.st-step-index{display:inline-flex;width:28px;height:28px;align-items:center;justify-content:center;border-radius:999px;background:var(--st-primary-container);color:var(--st-on-primary-container);font-family:var(--font-mono);font-size:12px;font-weight:800}.st-course-word-row{grid-template-columns:minmax(124px,.42fr) minmax(0,1fr) auto}.st-course-word-row .st-row-symbol{display:grid;grid-gap:2px;gap:2px;min-width:0}.st-course-word-row .st-row-symbol span{overflow-wrap:anywhere}.st-course-word-row .st-row-symbol small{color:var(--st-on-surface-variant);font-size:14px;line-height:18px}.st-course-actions{display:inline-flex;align-items:center;justify-content:flex-end;gap:8px}.st-course-actions .st-outline-button{min-width:92px}.st-course-toolbar-actions{display:flex;align-items:center;justify-content:flex-end;gap:12px;flex-wrap:wrap}.st-course-toolbar-actions .st-chip-row{justify-content:flex-end}.st-course-sequence-bar{display:flex;align-items:center;justify-content:space-between;gap:14px;border-bottom:1px solid var(--st-outline-variant);padding:0 0 14px;margin:-2px 0 0}.st-course-sequence-bar .st-card-caption{margin:0}.st-course-status{display:inline-flex;width:-moz-fit-content;width:fit-content;max-width:100%;align-items:center;gap:8px;border:1px solid color-mix(in srgb,var(--st-secondary) 28%,var(--st-outline-variant));border-radius:var(--st-radius-lg);background:color-mix(in srgb,var(--st-secondary-container) 46%,var(--st-surface-lowest));color:var(--st-secondary);padding:10px 14px;font-size:13px;font-weight:700;line-height:18px}.st-course-status.is-error{border-color:color-mix(in srgb,var(--st-error) 28%,var(--st-outline-variant));background:color-mix(in srgb,var(--st-error-container) 52%,var(--st-surface-lowest));color:var(--st-error)}.st-course-status .st-icon{font-size:20px}.st-course-status-action{display:inline-flex;min-height:32px;align-items:center;gap:6px;border-radius:var(--st-radius-md);background:var(--st-surface-lowest);color:var(--st-on-surface);padding:6px 10px;font-size:12px;line-height:16px}.st-course-status-action .st-icon{font-size:18px}.st-course-loading{display:grid;grid-template-columns:112px minmax(0,1fr) 92px;grid-gap:18px;gap:18px;align-items:center;padding:18px 20px}.st-course-kanji-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.st-course-kanji-card{display:grid;grid-template-columns:auto minmax(0,1fr) auto;grid-gap:14px;gap:14px;align-items:center;min-height:132px;padding:18px}.st-course-kanji-card .st-kanji-big{font-size:52px;line-height:60px}.st-course-kanji-card small,.st-course-kanji-card strong{display:block}.st-course-kanji-card strong{color:var(--st-on-surface);font-size:17px;line-height:24px}.st-course-kanji-card small{color:var(--st-on-surface-variant);font-size:13px;line-height:18px}.st-personal-detail-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.st-kanji-meta{display:flex;flex-wrap:wrap;gap:8px}.st-kanji-meta span{display:inline-flex;min-height:30px;align-items:center;gap:6px;border-radius:var(--st-radius);background:var(--st-surface-high);color:var(--st-on-surface-variant);padding:4px 10px;font-size:12px;font-weight:700;line-height:16px}.st-kanji-meta .st-icon{font-size:16px}.st-kanji-detail-hero .st-headline{font-size:clamp(72px,14vw,132px);line-height:.95}.st-kanji-detail-grid{display:grid;grid-template-columns:minmax(320px,.82fr) minmax(0,1fr);grid-gap:var(--st-gutter);gap:var(--st-gutter);align-items:stretch}.st-kanji-study-card,.st-writing-card{display:grid;grid-gap:18px;gap:18px;padding:var(--st-card-padding)}.st-kanji-reference{display:grid;place-items:center;min-height:308px;border:1px solid var(--st-outline-variant);border-radius:var(--st-radius-xl);background:linear-gradient(90deg,transparent calc(50% - .5px),hsla(213,8%,52%,.22) 50%,transparent calc(50% + .5px)),linear-gradient(0deg,transparent calc(50% - .5px),hsla(213,8%,52%,.22) 50%,transparent calc(50% + .5px)),var(--st-surface-lowest)}.st-kanji-reference svg{width:min(74%,260px);overflow:visible}.st-kanji-reference-glyph{fill:rgba(31,32,35,.08);font-family:var(--st-jp);font-size:86px;font-weight:600}.st-kanji-reference path{fill:none;stroke:var(--st-primary);stroke-width:4.8;stroke-linecap:round;stroke-linejoin:round;stroke-dasharray:1;stroke-dashoffset:1;animation:st-stroke-draw .68s cubic-bezier(.16,1,.3,1) forwards}.st-kanji-meta-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));grid-gap:10px;gap:10px}.st-kanji-meta-grid span{display:grid;grid-gap:2px;gap:2px;border:1px solid var(--st-outline-variant);border-radius:var(--st-radius-lg);background:var(--st-surface-lowest);padding:12px}.st-kanji-meta-grid strong{color:var(--st-on-surface);font-size:24px;line-height:30px}.st-kanji-meta-grid small{color:var(--st-on-surface-variant);font-size:11px;font-weight:800;line-height:14px;text-transform:uppercase}.st-kanji-readings{display:grid;grid-gap:10px;gap:10px}.st-kanji-readings p{display:grid;grid-template-columns:76px minmax(0,1fr);grid-gap:10px;gap:10px;margin:0}.st-kanji-readings strong{color:var(--st-on-surface-variant);font-size:12px;line-height:20px;text-transform:uppercase}.st-kanji-readings span{color:var(--st-on-surface);overflow-wrap:anywhere}.st-writing-card{grid-template-rows:auto minmax(300px,1fr) auto}.st-writing-canvas{display:block;width:100%;min-height:360px;border:1px solid var(--st-outline-variant);border-radius:var(--st-radius-xl);background:var(--st-surface-lowest);cursor:crosshair;touch-action:none}.st-writing-feedback{display:flex;align-items:center;justify-content:space-between;gap:12px}.st-writing-status{display:grid;min-width:0;grid-gap:5px;gap:5px}.st-writing-status small{color:var(--st-on-surface-variant);font-size:12px;line-height:16px}.st-writing-actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}.st-writing-result{display:grid;grid-template-columns:auto minmax(0,1fr) auto;grid-gap:10px;gap:10px;align-items:center;border:1px solid color-mix(in srgb,var(--st-error) 28%,var(--st-outline-variant));border-radius:var(--st-radius-lg);background:color-mix(in srgb,var(--st-error-container) 54%,var(--st-surface-lowest));color:var(--st-error);padding:12px}.st-writing-result.is-correct{border-color:color-mix(in srgb,var(--st-secondary) 30%,var(--st-outline-variant));background:color-mix(in srgb,var(--st-secondary-container) 48%,var(--st-surface-lowest));color:var(--st-secondary)}.st-writing-result span{display:block;color:var(--st-on-surface);font-weight:700}.st-writing-result small{color:var(--st-on-surface-variant);font-family:var(--font-mono);font-size:11px}.st-writing-score-row{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin-top:4px}.st-writing-score-row strong{color:var(--st-on-surface);font-family:var(--font-mono);font-size:13px}.st-writing-stroke-scores{display:flex;flex-wrap:wrap;gap:5px;margin-top:10px}.st-writing-stroke-scores span{display:inline-flex;min-height:24px;align-items:center;border:1px solid color-mix(in srgb,var(--st-error) 20%,var(--st-outline-variant));border-radius:999px;background:var(--st-surface-lowest);color:var(--st-error);padding:3px 8px;font-family:var(--font-mono);font-size:10px;font-weight:800}.st-writing-stroke-scores span.is-ok{border-color:color-mix(in srgb,var(--st-secondary) 24%,var(--st-outline-variant));color:var(--st-secondary)}.st-empty-state{display:flex;min-height:180px;align-items:center;justify-content:center;gap:16px;padding:var(--st-card-padding);text-align:left}.st-empty-state>.st-icon{color:var(--st-primary);font-size:40px}.st-meter{height:6px;overflow:hidden;border-radius:999px;background:var(--st-surface-high)}.st-meter span{display:block;height:100%;background:var(--st-primary-container)}.st-settings-list{display:grid;overflow:hidden;border:1px solid var(--st-outline-variant);border-radius:var(--st-radius-xl);background:var(--st-surface-lowest)}.st-setting-row{display:flex;min-height:72px;align-items:center;justify-content:space-between;gap:20px;border-bottom:1px solid var(--st-outline-variant);padding:16px 20px}.st-setting-row:last-child{border-bottom:0}.st-switch{width:48px;height:28px;border:0;border-radius:999px;background:var(--st-primary-container);padding:3px}.st-switch span{display:block;width:22px;height:22px;margin-left:auto;border-radius:999px}.st-number-input,.st-switch span{background:var(--st-surface-lowest)}.st-number-input{width:120px;min-height:44px;border:1px solid var(--st-outline-variant);border-radius:var(--st-radius-lg);color:var(--st-on-surface);font:inherit;padding:8px 10px}.st-settings-grid{display:grid;grid-template-columns:340px minmax(0,1fr);grid-gap:var(--st-gutter);gap:var(--st-gutter);align-items:start}.st-account-card{display:grid;grid-gap:14px;gap:14px;padding:var(--st-card-padding)}.st-account-card .st-avatar{width:56px;height:56px}.st-account-card strong{display:block;color:var(--st-on-surface);font-family:var(--font-mono);font-size:13px;line-height:18px;overflow-wrap:anywhere}.st-settings-load{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:10px;gap:10px;margin:16px 0}.st-settings-load span{display:grid;grid-gap:2px;gap:2px;border:1px solid var(--st-outline-variant);border-radius:var(--st-radius-lg);background:var(--st-surface-lowest);padding:12px}.st-settings-load strong{color:var(--st-on-surface);font-size:26px;line-height:32px}.st-settings-load small{color:var(--st-on-surface-variant);font-size:11px;font-weight:700;line-height:14px;text-transform:uppercase}.st-settings-backup-actions{display:flex;flex-wrap:wrap;gap:8px}.st-settings-backup-actions input{display:none}.st-outline-button.is-disabled{cursor:not-allowed;opacity:.58}.st-settings-form{align-self:start}.st-setting-row-rich{align-items:flex-start}.st-setting-control{display:grid;justify-items:end;grid-gap:10px;gap:10px}.st-segmented{display:inline-grid;grid-template-columns:repeat(2,minmax(88px,1fr));overflow:hidden;border:1px solid var(--st-outline-variant);border-radius:var(--st-radius-lg);background:var(--st-surface-lowest)}.st-segmented button{min-height:44px;border:0;background:transparent;color:var(--st-on-surface-variant);cursor:pointer;font:inherit;font-size:13px;font-weight:800;padding:8px 16px}.st-segmented button.is-active{background:var(--st-primary-container);color:var(--st-on-primary-container)}.st-error-text,.st-success-text{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:700;line-height:18px}.st-success-text{color:var(--st-secondary)}.st-analysis-box{padding:20px}.st-analysis-result{display:grid;grid-gap:12px;gap:12px}.st-progress-hero{display:grid;grid-template-columns:minmax(0,1fr) 340px;grid-gap:var(--st-gutter);gap:var(--st-gutter)}.st-progress-summary{display:flex;min-height:220px;align-items:center;justify-content:space-between;gap:28px;padding:var(--st-card-padding)}.st-progress-summary h2{margin:16px 0 8px;color:var(--st-on-surface);font-size:clamp(36px,5vw,64px);font-weight:800;line-height:.98}.st-progress-mini-stats{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px}.st-progress-mini-stats span{display:inline-grid;min-width:112px;gap:2px;padding:10px 12px;border:1px solid var(--st-outline-variant);border-radius:var(--st-radius);background:color-mix(in srgb,var(--st-surface-lowest) 82%,transparent);color:var(--st-on-surface-variant);font-size:11px;font-weight:800;text-transform:uppercase}.st-progress-mini-stats strong{color:var(--st-on-surface);font-size:18px;font-weight:900;line-height:1.1;text-transform:none}.st-progress-ring{display:grid;width:156px;height:156px;flex:0 0 auto;place-items:center;border-radius:999px;background:radial-gradient(circle at center,var(--st-surface-lowest) 58%,transparent 59%),conic-gradient(var(--st-primary-container) 0 86%,var(--st-surface-high) 86% 100%)}.st-progress-ring strong{color:var(--st-on-surface);font-size:34px;font-weight:800;line-height:34px}.st-progress-ring span{margin-top:-38px;color:var(--st-on-surface-variant);font-size:12px;font-weight:700}.st-progress-insight{display:flex;min-height:220px;align-items:flex-end;gap:14px;padding:var(--st-card-padding);background:linear-gradient(135deg,color-mix(in srgb,var(--st-tertiary-container) 46%,var(--st-surface-lowest)),var(--st-surface-lowest))}.st-progress-insight>.st-icon{display:inline-flex;width:48px;height:48px;align-items:center;justify-content:center;border-radius:var(--st-radius-lg);background:hsla(0,0%,100%,.52);color:var(--st-primary)}.st-progress-insight strong{color:var(--st-on-surface);font-size:20px;line-height:28px}.st-activity-chart{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));align-items:end;grid-gap:12px;gap:12px;min-height:260px;padding-top:20px}.st-activity-day{display:grid;height:220px;grid-template-rows:minmax(0,1fr) auto;grid-gap:10px;gap:10px}.st-activity-day span{align-self:end;min-height:28px;border-radius:var(--st-radius) var(--st-radius) 4px 4px;background:linear-gradient(180deg,var(--st-primary-container),color-mix(in srgb,var(--st-primary-container) 42%,var(--st-secondary-container)));transform-origin:bottom;animation:st-bar-rise .42s cubic-bezier(.16,1,.3,1) both}.st-activity-day small{color:var(--st-on-surface-variant);font-size:12px;font-weight:700;text-align:center}.st-candidate-list,.st-focus-item,.st-focus-list{display:grid;grid-gap:10px;gap:10px}.st-focus-item{border:1px solid var(--st-outline-variant);border-radius:var(--st-radius-lg);background:color-mix(in srgb,var(--st-surface-lowest) 72%,var(--st-surface-high));padding:14px}.st-focus-item strong{color:var(--st-on-surface);font-size:15px;line-height:20px}.st-text-pipeline{display:grid;grid-template-columns:minmax(0,1.05fr) minmax(380px,.95fr);grid-gap:var(--st-gutter);gap:var(--st-gutter);align-items:start}.st-analysis-actions,.st-sample-grid{display:flex;flex-wrap:wrap;gap:10px}.st-sample-grid .st-outline-button{justify-content:flex-start;min-width:156px;padding-inline:14px}.st-analysis-actions{justify-content:space-between}.st-candidate-row{display:grid;grid-template-columns:minmax(70px,auto) minmax(0,1fr) auto;grid-gap:14px;gap:14px;align-items:center;width:100%;border:1px solid var(--st-outline-variant);border-radius:var(--st-radius-lg);background:var(--st-surface-lowest);color:inherit;cursor:pointer;padding:12px;text-align:left;transition:background .18s ease,border-color .18s ease,transform .16s ease}.st-candidate-row:hover{border-color:color-mix(in srgb,var(--st-primary) 42%,var(--st-outline-variant));background:color-mix(in srgb,var(--st-surface-lowest) 76%,var(--st-primary-container));transform:translateY(-1px)}.st-candidate-row.is-selected{border-color:transparent;background:color-mix(in srgb,var(--st-primary-container) 58%,var(--st-surface-lowest))}.st-candidate-row:disabled{cursor:default;opacity:.78}.st-candidate-word{color:var(--st-on-surface);font-size:28px;font-weight:600;line-height:36px}.st-candidate-row strong{display:block;color:var(--st-on-surface);font-size:14px;line-height:20px}.st-candidate-row small{display:flex;align-items:baseline;flex-wrap:wrap;gap:2px 8px;color:var(--st-on-surface-variant);font-size:14px;line-height:19px}.st-candidate-row small.jp{font-size:15px;font-weight:600}.st-candidate-meta{display:inline-flex;align-items:baseline;gap:8px;margin-left:4px;font-size:12px;font-weight:400;color:var(--st-outline)}.st-candidate-meta:before{content:"·";color:var(--st-outline-variant)}.st-prepared-strip{display:flex;align-items:center;justify-content:space-between;gap:14px;border-top:1px solid var(--st-outline-variant);margin-top:4px;padding-top:14px}.st-prepared-strip div{display:grid;grid-gap:2px;gap:2px}.st-prepared-strip strong{color:var(--st-on-surface);font-size:28px;line-height:32px}.st-prepared-strip span{color:var(--st-on-surface-variant);font-size:12px;font-weight:700;line-height:16px}.st-saved-study-list{display:flex;flex-wrap:wrap;gap:8px}.st-border-title{border-bottom:1px solid var(--st-outline-variant);padding-bottom:8px;margin-bottom:20px}.st-dictionary-search{display:grid;grid-template-columns:auto minmax(0,1fr) auto auto;align-items:center;grid-gap:14px;gap:14px;min-height:76px;padding:16px 20px}.st-dictionary-search input{width:100%;border:0;background:transparent;color:var(--st-on-surface);font:inherit;font-size:18px;outline:none}.st-round-button{display:inline-flex;width:40px;height:40px;align-items:center;justify-content:center;border:0;border-radius:999px;background:transparent;color:var(--st-on-surface-variant);cursor:pointer}.st-dictionary-bands{grid-template-columns:repeat(3,minmax(0,1fr))}.st-dictionary-band{position:relative;overflow:hidden;display:grid;grid-gap:18px;gap:18px;min-height:210px;padding:var(--st-card-padding)}.st-dictionary-band:after{content:"";position:absolute;top:-28px;right:-28px;width:88px;height:88px;border-radius:999px;background:rgba(47,95,132,.1)}.st-dictionary-band>*{position:relative;z-index:1}.st-dictionary-row{grid-template-columns:minmax(136px,.35fr) minmax(0,1fr) auto}.st-row-symbol{display:grid}.st-row-symbol small{color:var(--st-outline);font-family:var(--st-jp);font-size:16px;font-weight:400;line-height:24px}.st-outline-button{display:inline-flex;min-height:40px;align-items:center;justify-content:center;gap:8px;border:1px solid var(--st-outline-variant);border-radius:var(--st-radius-lg);background:var(--st-surface-lowest);color:var(--st-primary);cursor:pointer;font:inherit;font-size:13px;font-weight:700;padding:8px 14px}.st-outline-button:disabled{opacity:.6;cursor:default}.st-error-text{color:var(--st-error)}.st-search-error{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.st-search-error span{display:inline-flex;align-items:center;gap:6px}.st-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:16px;gap:16px}.st-field{display:grid;grid-gap:6px;gap:6px}.st-field label{color:var(--st-on-surface-variant);font-size:13px;line-height:16px}.st-field input{min-height:44px;border:1px solid var(--st-outline-variant);border-radius:var(--st-radius-lg);background:var(--st-surface-lowest);color:var(--st-on-surface);font:inherit;padding:10px 12px}.st-field input:focus{border-color:var(--st-primary);outline:none}.st-review-focus{min-height:calc(100dvh - 80px);display:flex;flex-direction:column;align-items:center;justify-content:flex-start;gap:32px;background:var(--st-background);color:var(--st-on-surface);padding:24px 24px 48px}.st-review-top{position:-webkit-sticky;position:sticky;top:0;z-index:40;width:min(100%,760px);display:grid;grid-template-columns:44px minmax(0,680px) 44px;grid-gap:18px;gap:18px;border:1px solid var(--st-outline-variant);border-radius:var(--st-radius-xl);padding:12px;background:rgba(249,249,252,.96);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.st-review-icon,.st-review-top{align-items:center;justify-content:center}.st-review-icon{display:inline-flex;width:42px;height:42px;border:0;border-radius:999px;background:transparent;color:var(--st-on-surface-variant)}.st-review-progress{display:grid;grid-gap:8px;gap:8px}.st-review-card{position:relative;width:100%;min-height:342px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:18px;padding:58px 48px;text-align:center}.st-review-study-layout{display:grid;grid-template-columns:minmax(0,680px) minmax(240px,320px);grid-gap:18px;gap:18px;width:min(100%,1038px);align-items:stretch}.st-review-study-panel{display:grid;align-content:start;grid-gap:16px;gap:16px;padding:18px}.st-review-side-stack{display:grid;grid-gap:12px;gap:12px}.st-review-word-summary{display:grid;justify-items:start;grid-gap:6px;gap:6px;border:1px solid var(--st-outline-variant);border-radius:var(--st-radius-lg);background:var(--st-surface-lowest);padding:14px}.st-review-word-summary>span{color:var(--st-on-surface);font-size:34px;font-weight:750;line-height:40px;overflow-wrap:anywhere}.st-review-word-summary>small{color:var(--st-primary);font-size:16px;font-weight:700;line-height:22px}.st-review-pitch-line{justify-content:flex-start;font-size:15px;line-height:24px}.st-review-context-card{display:grid;justify-items:start;grid-gap:8px;gap:8px;border:1px solid color-mix(in srgb,var(--st-secondary) 24%,var(--st-outline-variant));border-radius:var(--st-radius-lg);background:color-mix(in srgb,var(--st-secondary-container) 24%,var(--st-surface-lowest));padding:14px}.st-review-context-card p{margin:0;color:var(--st-on-surface);font-size:15px;font-weight:650;line-height:24px}.st-review-context-card small{color:var(--st-on-surface-variant);font-size:12px;line-height:16px}.st-review-kanji-list{display:grid;grid-gap:8px;gap:8px}.st-review-kanji-row{display:grid;grid-template-columns:auto minmax(0,1fr);grid-gap:2px 10px;gap:2px 10px;align-items:baseline;border:1px solid var(--st-outline-variant);border-radius:var(--st-radius-lg);background:var(--st-surface-lowest);padding:10px}.st-review-kanji-row span{grid-row:1/3;color:var(--st-primary);font-size:30px;font-weight:650;line-height:36px}.st-review-kanji-row strong{color:var(--st-on-surface);font-size:14px;line-height:18px;overflow-wrap:anywhere}.st-review-kanji-row small{color:var(--st-on-surface-variant);font-size:12px;line-height:16px;overflow-wrap:anywhere}.st-review-meta{position:absolute;top:18px;left:18px;right:18px;display:flex;justify-content:space-between;gap:12px}.st-review-word{margin:0;color:var(--st-on-surface);font-family:var(--st-jp);font-size:80px;font-weight:500;line-height:1}.st-review-mode-kicker{gap:8px;border:1px solid var(--st-outline-variant);border-radius:999px;background:color-mix(in srgb,var(--st-surface) 88%,transparent);color:var(--st-on-surface-variant);padding:8px 12px;font-size:12px;line-height:16px;text-transform:uppercase}.st-review-mode-kicker,.st-review-writing-cue{display:inline-flex;align-items:center;font-weight:700}.st-review-writing-cue{gap:10px;border-radius:var(--st-radius-md);background:var(--st-primary-container);color:var(--st-on-primary-container);padding:10px 14px;font-size:14px;line-height:20px}.st-review-answer{display:grid;justify-items:center;grid-gap:14px;gap:14px;width:100%}.st-review-answer h2,.st-review-answer p{margin:0}.st-review-answer p{color:var(--st-primary);font-size:24px;line-height:32px}.st-review-answer span{width:min(100%,360px);height:1px;background:var(--st-outline-variant)}.st-review-answer h2{font-size:24px;line-height:32px}.st-cloze-card{gap:22px}.st-cloze-sentence{max-width:620px;margin:0;color:var(--st-on-surface);font-size:42px;font-weight:650;line-height:1.45;text-align:center;text-wrap:balance}.st-cloze-sentence mark{display:inline-flex;min-width:118px;justify-content:center;border-radius:var(--st-radius-md);background:var(--st-primary-container);color:var(--st-on-primary-container);padding:0 10px 4px}.st-cloze-form{display:grid;grid-template-columns:minmax(0,1fr) auto;grid-gap:10px;gap:10px;width:min(100%,520px)}.st-cloze-form input{min-width:0;border:1px solid var(--st-outline-variant);border-radius:var(--st-radius-md);background:var(--st-surface-lowest);color:var(--st-on-surface);padding:13px 14px;font-size:22px;font-weight:650;line-height:28px;outline:none}.st-cloze-form input:focus{border-color:var(--st-primary);box-shadow:0 0 0 3px color-mix(in srgb,var(--st-primary) 14%,transparent)}.st-cloze-result{width:min(100%,620px)}.st-review-grades,.st-review-show{width:min(100%,680px)}.st-review-grades{display:grid;grid-template-columns:repeat(4,1fr);grid-gap:12px;gap:12px}.st-grade{position:relative;display:grid;place-items:center;grid-gap:3px;gap:3px;min-height:76px;border:1px solid var(--st-outline-variant);border-radius:var(--st-radius-xl);background:var(--st-surface-lowest);color:var(--st-on-surface);cursor:pointer}.st-grade strong{font-size:18px;line-height:28px}.st-grade span{color:var(--st-on-surface-variant);font-size:13px;line-height:16px}.st-grade kbd{position:absolute;top:8px;right:8px;color:var(--st-outline);font-family:var(--font-mono);font-size:10px}.st-grade-again:hover{background:var(--st-error-container);border-color:var(--st-error-container)}.st-grade-hard:hover{background:var(--st-tertiary-fixed);border-color:var(--st-tertiary-fixed)}.st-grade-good:hover{background:var(--st-secondary-container);border-color:var(--st-secondary-container)}.st-grade-easy:hover{background:rgba(47,95,132,.16);border-color:rgba(47,95,132,.16)}.st-review-done{width:min(100%,560px);display:grid;justify-items:center;grid-gap:18px;gap:18px;padding:40px;text-align:center}.st-review-empty-actions{display:flex;flex-wrap:wrap;justify-content:center;gap:10px;width:100%}.st-review-empty-actions>*{min-width:168px}@media (max-width:900px){.st-main{padding-left:0;padding-bottom:88px}.st-sidebar{display:none}.st-mobile-topbar{position:-webkit-sticky;position:sticky;top:0;z-index:40;display:flex;align-items:center;justify-content:space-between;min-height:64px;padding:16px;background:var(--st-surface);box-shadow:0 1px 4px rgba(26,28,30,.08)}.st-mobile-brand{display:flex;align-items:center;gap:12px}.st-avatar{display:inline-flex;width:32px;height:32px;align-items:center;justify-content:center;overflow:hidden;border:1px solid var(--st-outline-variant);border-radius:999px;background:var(--st-surface-high);color:var(--st-on-surface-variant)}.st-mobile-brand strong{font-size:24px;line-height:32px}.st-mobile-profile{display:inline-flex;width:40px;height:40px;align-items:center;justify-content:center;border:0;border-radius:999px;background:transparent;color:var(--st-primary)}.st-mobile-nav{position:fixed;inset:auto 0 0 0;z-index:50;display:flex;justify-content:space-around;align-items:center;background:rgba(249,249,252,.95);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:4px 8px 8px}.st-mobile-nav-item{display:flex;width:64px;height:56px;flex-direction:column;align-items:center;justify-content:center;color:var(--st-on-surface-variant);font-size:13px;font-weight:500;line-height:16px;transition:color .16s ease,transform .12s ease}.st-mobile-nav-item:active{transform:scale(.95)}.st-mobile-nav-item.is-active{color:var(--st-primary);font-weight:700}.st-page{padding:24px 16px}.st-today{gap:32px}.st-page-header{align-items:flex-end;border:0;padding-bottom:0}.st-headline{font-size:20px;line-height:28px}.st-streak{padding:4px 8px}.st-goal-card{padding:20px}.st-goal-main{flex-direction:column;align-items:stretch}.st-goal-kicker{color:var(--st-on-surface);font-size:18px;line-height:28px;text-transform:none;letter-spacing:0}.st-goal-stats{display:grid;grid-template-columns:1fr;grid-gap:10px;gap:10px}.st-stat:first-child strong{font-size:48px;line-height:56px}.st-stat-skeleton.is-large{width:70px;height:56px}.st-stat:not(:first-child){display:inline-flex;align-items:center;gap:6px}.st-divider{display:none}.st-button{width:100%;background:var(--st-primary);color:var(--st-on-primary);font-size:16px;line-height:24px}.st-dashboard-grid{grid-template-columns:1fr;gap:32px}.st-learning-grid{display:flex;gap:16px;overflow-x:auto;margin-inline:calc(var(--st-margin-mobile) * -1);padding-inline:var(--st-margin-mobile);padding-bottom:8px;scrollbar-width:none}.st-learning-grid::-webkit-scrollbar{display:none}.st-learning-card{min-width:200px}.st-section-label{border-bottom:0;padding-bottom:0;color:var(--st-on-surface);font-size:18px;line-height:28px;text-transform:none;letter-spacing:0}.st-recommendation-list{gap:0;overflow:hidden;border:1px solid var(--st-outline-variant);border-radius:var(--st-radius-xl);background:var(--st-surface-lowest)}.st-recommendation{border:0;border-bottom:1px solid var(--st-outline-variant);border-radius:0;background:transparent}.st-recommendation:last-child{border-bottom:0}.st-rec-icon{width:40px;height:40px;border-radius:999px;background:var(--st-surface);border:1px solid var(--st-outline-variant);color:var(--st-primary)}.st-notes-panel{display:none}.st-card-grid,.st-row,.st-two-column{grid-template-columns:1fr}.st-dictionary-search{grid-template-columns:auto minmax(0,1fr) auto}.st-dictionary-search .st-chip{display:none}.st-dictionary-bands,.st-dictionary-row,.st-form-grid{grid-template-columns:1fr}.st-review-focus{justify-content:space-between;padding:88px 16px 24px}.st-review-top{grid-template-columns:40px minmax(0,1fr) 40px;gap:8px;border-bottom:1px solid var(--st-outline-variant);padding:14px}.st-review-card{min-height:312px;padding:52px 22px 34px}.st-review-word{font-size:56px}.st-cloze-sentence{font-size:28px;line-height:1.55}.st-cloze-form{grid-template-columns:1fr}.st-review-grades{grid-template-columns:repeat(2,1fr)}.st-toolbar{align-items:stretch;flex-direction:column}.st-row{gap:10px}.st-kanji-big,.st-row-symbol{font-size:48px;line-height:56px}}.st-review-focus{isolation:isolate;background:linear-gradient(180deg,hsla(0,0%,100%,.34),transparent 34%),var(--st-background)}.st-review-top{box-shadow:0 1px 0 rgba(193,199,207,.72)}.st-review-icon{border:1px solid transparent;cursor:pointer;transition:background-color .18s ease,border-color .18s ease,transform .14s ease}.st-review-icon:hover{border-color:var(--st-outline-variant);background:var(--st-surface-lowest)}.st-review-card{overflow:hidden;min-height:360px;border-radius:var(--st-radius-xl);box-shadow:0 12px 30px rgba(26,28,30,.035);transition:min-height .22s ease,transform .18s ease,border-color .18s ease}.st-review-card:before{content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;background:radial-gradient(circle at 50% 0,rgba(47,95,132,.055),transparent 38%)}.st-review-card.is-revealed{min-height:430px;border-color:var(--st-primary-container)}.st-review-answer,.st-review-meta,.st-review-mode-kicker,.st-review-word,.st-review-writing-cue{position:relative;z-index:1}.st-review-word{transition:transform .22s ease,font-size .22s ease}.st-review-card.is-revealed .st-review-word{transform:translateY(-2px)}.st-review-example{width:min(100%,440px);border:1px solid var(--st-outline-variant);border-radius:var(--st-radius-lg);background:var(--st-surface);padding:14px 16px;text-align:left}.st-review-example p{color:var(--st-on-surface);font-size:16px;line-height:24px}.st-review-example small{display:block;margin-top:4px;color:var(--st-outline);font-size:13px;line-height:16px}.st-review-actions{display:grid;width:min(100%,680px);grid-gap:10px;gap:10px;justify-items:center}.st-review-hint{color:var(--st-outline);font-family:var(--font-mono);font-size:12px}.st-review-grades{align-items:stretch}.st-grade{overflow:hidden}.st-grade:before{content:"";position:absolute;inset:0;opacity:0;background:var(--st-surface-low);transition:opacity .18s ease}.st-grade:hover:before{opacity:1}.st-grade>*{position:relative;z-index:1}@media (max-width:900px){.st-review-card{width:100%;min-height:340px}.st-review-study-layout{grid-template-columns:1fr;width:100%}.st-review-card.is-revealed{min-height:430px}.st-review-actions,.st-review-grades{width:100%}.st-review-empty-actions{align-items:stretch;flex-direction:column}.st-review-hint{display:none}}.st-focus-shell,.st-focus-shell *,.st-review-focus,.st-review-focus *,.st-shell,.st-shell *{box-sizing:border-box}.st-shell{overflow-x:hidden;background:var(--st-background);font-family:var(--st-font)}.st-sidebar{overflow-y:auto;scrollbar-width:thin}.st-main{min-height:100dvh;background:var(--st-background)}.st-page{animation:st-page-in .42s cubic-bezier(.16,1,.3,1) both}.st-page :where(h1,h2,h3,p){font-family:var(--st-font);letter-spacing:0}.st-page .jp,.st-review-focus .jp{font-family:var(--st-jp)}.st-page .st-card-title,.st-page .st-goal-kicker,.st-page .st-headline,.st-page .st-row-title,.st-page .st-section-label,.st-review-focus :where(h1,h2,h3){font-family:var(--st-font)}.st-page .st-headline.jp,.st-page .st-row-symbol,.st-review-focus .st-review-word{font-family:var(--st-jp)}.st-dashboard-grid,.st-goal-card,.st-page-header,.st-review-card,.st-screen-stack>section,.st-settings-list,.st-table{animation:st-rise-in .52s cubic-bezier(.16,1,.3,1) both}.st-goal-card{animation-delay:40ms}.st-dashboard-grid{animation-delay:90ms}.st-screen-stack>section:nth-child(2){animation-delay:40ms}.st-screen-stack>section:nth-child(3){animation-delay:90ms}.st-paper,.st-paper-interactive,.st-settings-list,.st-table{box-shadow:none}.st-button,.st-grade,.st-icon-button,.st-mobile-nav-item,.st-nav-link,.st-outline-button,.st-paper-interactive,.st-primary-action,.st-round-button{will-change:transform;transition:background-color .18s ease,border-color .18s ease,color .18s ease,opacity .18s ease,transform .14s ease}.st-icon-button:hover,.st-outline-button:hover,.st-paper-interactive:hover,.st-round-button:hover{border-color:var(--st-outline);background:rgba(47,95,132,.08)}.st-button:active,.st-grade:active,.st-icon-button:active,.st-outline-button:active,.st-paper-interactive:active,.st-primary-action:active,.st-round-button:active{transform:scale(.99)}.st-nav-link{border-radius:var(--st-radius-lg)}.st-nav-link.is-active{border-radius:var(--st-radius-lg) 0 0 var(--st-radius-lg)}.st-brand strong,.st-mobile-brand strong{white-space:nowrap}.st-mobile-nav{border-top:0;box-shadow:0 -1px 12px rgba(26,28,30,.06)}.st-mobile-nav-item .st-icon{display:inline-flex;width:36px;height:28px;align-items:center;justify-content:center;border-radius:999px}.st-mobile-nav-item.is-active .st-icon{background:rgba(47,95,132,.12)}.st-goal-card:after{animation:st-soft-float 5.2s ease-in-out infinite}.st-meter span,.st-progress-track span{transform-origin:left center;animation:st-fill-in .72s cubic-bezier(.16,1,.3,1) both}.st-dictionary-search{position:-webkit-sticky;position:sticky;top:0;z-index:20}.st-dictionary-search:focus-within,.st-field:focus-within input,.st-number-input:focus,.st-search-box:focus-within{border-color:var(--st-primary);outline:none}.st-search-stream-strip{display:grid;grid-template-columns:minmax(180px,.34fr) minmax(0,1fr);grid-gap:16px;gap:16px;align-items:center;padding:16px}.st-search-stream-strip .st-chip-row{justify-content:flex-end}.st-note-item,.st-row,.st-setting-row{min-width:0}.st-auth-feature,.st-card-caption,.st-card-title,.st-note-body,.st-row-sub,.st-row-title,.st-tool-card{overflow-wrap:anywhere}.st-review-card{animation-delay:60ms}.st-review-answer{animation:st-answer-in .22s ease both}.st-review-word{overflow-wrap:anywhere;max-width:100%}.st-review-grades{animation:st-rise-in .26s cubic-bezier(.16,1,.3,1) both}.st-grade-again strong{color:var(--st-error)}.st-grade-hard strong{color:var(--st-tertiary)}.st-grade-good strong{color:var(--st-secondary)}.st-grade-easy strong{color:var(--st-primary)}.st-live-chip{gap:7px;justify-content:center;min-width:64px}.st-live-chip>span{width:7px;height:7px;border-radius:999px;background:var(--st-outline)}.st-live-chip.is-active>span{background:var(--st-secondary);animation:st-live-pulse 1.4s ease-in-out infinite}.st-dictionary-band.st-band-0:after{background:rgba(174,237,202,.28)}.st-dictionary-band.st-band-2:after{background:rgba(255,222,165,.42)}.st-dictionary-band .st-chip-row{align-content:start;min-height:84px}.st-dictionary-band .st-skeleton{height:32px}.st-word-study-grid{display:grid;grid-template-columns:minmax(0,1.2fr) minmax(280px,.8fr);grid-gap:24px;gap:24px;align-items:stretch}.st-word-card-panel,.st-word-kanji-panel,.st-word-study-loading,.st-word-study-main{display:grid;grid-gap:18px;gap:18px}.st-word-study-main{min-height:360px;align-content:center;overflow:hidden;position:relative}.st-word-study-main:after{content:"";position:absolute;right:-70px;bottom:-90px;width:230px;height:230px;border-radius:999px;background:rgba(47,95,132,.08);pointer-events:none}.st-word-study-actions,.st-word-study-top{display:flex;flex-wrap:wrap;gap:10px;align-items:center}.st-word-study-symbol{position:relative;z-index:1;color:var(--st-on-surface);font-size:104px;font-weight:700;line-height:1;overflow-wrap:anywhere}.st-word-study-reading{margin:0;color:var(--st-primary);font-size:24px;font-weight:700;line-height:32px}.st-pitch-line{flex-wrap:wrap;gap:1px;width:-moz-fit-content;width:fit-content;max-width:100%;color:var(--st-on-surface-variant);font-size:18px;font-weight:750;line-height:28px}.st-pitch-line,.st-pitch-line span{display:inline-flex;justify-content:center}.st-pitch-line span{position:relative;min-width:1.1em;padding:5px 2px 0}.st-pitch-line span.is-high{border-top:2px solid var(--st-primary);color:var(--st-on-surface)}.st-pitch-line i{position:absolute;right:-8px;top:-5px;color:var(--st-error);font-family:var(--st-font);font-size:18px;font-style:normal;line-height:1}.st-word-study-main h2{max-width:680px;margin:0;color:var(--st-on-surface-variant);font-size:28px;font-weight:700;line-height:36px}.st-word-context-inline{position:relative;z-index:1;display:grid;grid-gap:6px;gap:6px;width:min(100%,620px);border:1px solid var(--st-outline-variant);border-radius:var(--st-radius-lg);background:color-mix(in srgb,var(--st-surface-lowest) 88%,transparent);padding:14px 16px}.st-word-context-inline p{margin:0;color:var(--st-on-surface);font-size:18px;font-weight:650;line-height:28px}.st-word-context-inline small{color:var(--st-on-surface-variant);font-size:13px;line-height:18px}.st-word-learning-grid{display:grid;grid-template-columns:minmax(0,.9fr) minmax(0,1.1fr);grid-gap:var(--st-gutter);gap:var(--st-gutter);align-items:start}.st-word-example-list,.st-word-step-list{display:grid;grid-gap:10px;gap:10px}.st-word-step{display:grid;grid-template-columns:auto auto minmax(0,1fr);grid-gap:12px;gap:12px;align-items:center;border:1px solid var(--st-outline-variant);border-radius:var(--st-radius-lg);background:var(--st-surface-lowest);padding:13px 14px}.st-word-step .st-icon{color:var(--st-primary)}.st-word-step small,.st-word-step strong{display:block}.st-word-step small{margin-top:2px;color:var(--st-on-surface-variant);font-size:12px;line-height:16px}.st-word-example{display:grid;justify-items:start;grid-gap:8px;gap:8px;border:1px solid var(--st-outline-variant);border-radius:var(--st-radius-lg);background:var(--st-surface-lowest);padding:14px}.st-word-example.is-saved{border-color:color-mix(in srgb,var(--st-secondary) 30%,var(--st-outline-variant));background:color-mix(in srgb,var(--st-secondary-container) 28%,var(--st-surface-lowest))}.st-word-example p{margin:0;color:var(--st-on-surface);font-size:18px;font-weight:650;line-height:28px}.st-word-example small{color:var(--st-on-surface-variant);font-size:13px;line-height:18px}.st-word-card-list,.st-word-deck-list,.st-word-kanji-list{display:grid;grid-gap:10px;gap:10px}.st-word-card-row,.st-word-kanji-card{display:grid;grid-gap:8px 14px;gap:8px 14px;align-items:center;border:1px solid var(--st-outline-variant);border-radius:var(--st-radius-lg);background:var(--st-surface-lowest);padding:14px}.st-word-kanji-card{grid-template-columns:56px minmax(0,1fr);transition:background-color .18s ease,border-color .18s ease,transform .14s ease}.st-word-kanji-card:hover{border-color:var(--st-outline);background:rgba(47,95,132,.08)}.st-word-kanji-card:active{transform:scale(.99)}.st-word-kanji-card .jp{grid-row:1/3;width:56px;height:56px;display:inline-flex;align-items:center;justify-content:center;border-radius:var(--st-radius-lg);background:var(--st-surface);color:var(--st-primary);font-size:32px;font-weight:800;line-height:1}.st-word-card-row strong,.st-word-kanji-card strong{min-width:0;overflow-wrap:anywhere}.st-word-card-row small,.st-word-kanji-card small{color:var(--st-outline);font-size:12px;font-weight:700;line-height:16px}.st-word-card-row{grid-template-columns:auto minmax(0,1fr) auto auto}.st-word-deck-row{display:flex;align-items:center;justify-content:space-between;gap:14px;border:1px solid var(--st-outline-variant);border-radius:var(--st-radius-lg);background:var(--st-surface-lowest);color:inherit;padding:12px 14px;text-align:left;cursor:pointer;transition:background-color .18s ease,border-color .18s ease,transform .14s ease}.st-word-deck-row:hover:not(:disabled){border-color:var(--st-outline);background:rgba(47,95,132,.08)}.st-word-deck-row:active:not(:disabled){transform:scale(.99)}.st-word-deck-row:disabled{cursor:wait;opacity:.72}.st-word-deck-row small,.st-word-deck-row strong{display:block}.st-word-deck-row small{color:var(--st-outline);font-size:12px;line-height:16px}.st-onboarding-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));grid-gap:28px;gap:28px;align-items:start}.st-onboarding-panel,.st-onboarding-summary{display:grid;grid-gap:20px;gap:20px;border-color:color-mix(in srgb,var(--st-outline-variant) 62%,transparent);background:color-mix(in srgb,var(--st-surface-lowest) 92%,var(--st-surface));padding:22px}.st-onboarding-panel .st-panel-head{align-items:flex-start;border-bottom:0;margin-bottom:0;padding-bottom:0}.st-onboarding-panel .st-panel-head h2{margin:0;color:var(--st-on-surface);font-size:13px;font-weight:850;line-height:18px;text-transform:uppercase}.st-onboarding-options,.st-placement-list{display:grid;grid-gap:12px;gap:12px}.st-onboarding-option,.st-placement-row{width:100%;border:1px solid color-mix(in srgb,var(--st-outline-variant) 68%,transparent);border-radius:var(--st-radius-lg);background:color-mix(in srgb,var(--st-surface-lowest) 94%,var(--st-surface));color:inherit;cursor:pointer;text-align:left;transition:background-color .18s ease,border-color .18s ease,box-shadow .18s ease,transform .14s ease}.st-onboarding-option{display:grid;grid-gap:8px;gap:8px;min-height:86px;padding:15px 16px}.st-onboarding-option .st-icon{color:var(--st-primary)}.st-onboarding-option:hover,.st-placement-row:hover{border-color:color-mix(in srgb,var(--st-primary) 34%,var(--st-outline-variant));background:color-mix(in srgb,var(--st-surface-lowest) 82%,var(--st-primary-container))}.st-onboarding-option:active,.st-placement-row:active{transform:scale(.99)}.st-onboarding-option.is-selected,.st-placement-row.is-known{border-color:color-mix(in srgb,var(--st-primary) 38%,var(--st-outline-variant));background:color-mix(in srgb,var(--st-primary-container) 46%,var(--st-surface-lowest));box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--st-primary) 18%,transparent)}.st-onboarding-option strong{color:var(--st-on-surface);font-size:15px;line-height:20px}.st-onboarding-option small{color:var(--st-on-surface-variant);font-size:12px;line-height:16px}.st-placement-row{display:grid;grid-template-columns:56px minmax(0,1fr) auto;grid-gap:12px;gap:12px;align-items:center;padding:12px}.st-placement-row>.jp:first-child{display:inline-flex;width:52px;height:52px;align-items:center;justify-content:center;border-radius:var(--st-radius-lg);background:var(--st-surface);color:var(--st-primary);font-size:24px;font-weight:800;line-height:1}.st-placement-row small,.st-placement-row strong{display:block}.st-placement-row small{color:var(--st-on-surface-variant);font-size:12px}.st-onboarding-summary{grid-template-columns:minmax(0,1fr) auto;align-items:center;margin-top:4px}.st-word-chip{gap:7px}.st-word-chip small{color:var(--st-outline);font-family:var(--font-mono);font-size:10px;font-weight:700;line-height:12px}.st-dictionary-row .st-outline-button{min-width:92px}.st-dictionary-kanji-links{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}.st-kanji-mini-link{display:inline-flex;min-width:32px;height:32px;align-items:center;justify-content:center;border:1px solid var(--st-outline-variant);border-radius:var(--st-radius);background:var(--st-surface-lowest);color:var(--st-primary);font-size:18px;font-weight:800;line-height:1;transition:background-color .18s ease,border-color .18s ease,transform .14s ease}.st-kanji-mini-link:hover{border-color:var(--st-outline);background:rgba(47,95,132,.08)}.st-kanji-mini-link:active{transform:scale(.96)}.st-analysis-box,.st-deck-card,.st-dictionary-band,.st-goal-card,.st-kanji-card,.st-learning-card,.st-metric-card,.st-notes-panel,.st-recommendation{transform:translateZ(0)}.st-deck-card,.st-kanji-card,.st-learning-card,.st-metric-card{min-height:168px}.st-button:disabled,.st-grade:disabled,.st-outline-button:disabled{opacity:.5;pointer-events:none}.st-panel-head :where(h2,h3){margin:0;color:var(--st-on-surface-variant);font-family:var(--st-font);font-size:13px;font-weight:700;line-height:16px;text-transform:uppercase;letter-spacing:.04em}.st-kanji-big,.st-review-word,.st-row-symbol>span{text-wrap:balance}.st-skeleton{position:relative;display:block;overflow:hidden;min-height:16px;border-radius:var(--st-radius);background:var(--st-surface-high)}.st-skeleton:after{content:"";position:absolute;inset:0;transform:translateX(-100%);background:linear-gradient(90deg,transparent,hsla(0,0%,100%,.62),transparent);animation:st-shimmer 1.4s ease-in-out infinite}.st-stat-skeleton{width:42px;height:32px}.st-stat-skeleton.is-large{width:58px;height:48px}@keyframes st-page-in{0%{opacity:0}to{opacity:1}}@keyframes st-rise-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes st-fill-in{0%{transform:scaleX(.04)}to{transform:scaleX(1)}}@keyframes st-bar-rise{0%{opacity:0;transform:scaleY(.08)}to{opacity:1;transform:scaleY(1)}}@keyframes st-spin{to{transform:rotate(1turn)}}@keyframes st-answer-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes st-soft-float{0%,to{transform:translateZ(0)}50%{transform:translate3d(-6px,5px,0)}}@keyframes st-shimmer{to{transform:translateX(100%)}}@keyframes st-live-pulse{0%,to{box-shadow:0 0 0 0 rgba(45,105,77,.24)}50%{box-shadow:0 0 0 6px rgba(45,105,77,0)}}@keyframes st-stroke-draw{to{stroke-dashoffset:0}}@media (prefers-reduced-motion:reduce){.st-activity-day span,.st-auth-spinner,.st-dashboard-grid,.st-goal-card,.st-goal-card:after,.st-meter span,.st-page,.st-page-header,.st-progress-track span,.st-review-answer,.st-review-card,.st-review-grades,.st-screen-stack>section,.st-settings-list,.st-skeleton:after,.st-table{animation:none}.st-button,.st-grade,.st-icon-button,.st-mobile-nav-item,.st-nav-link,.st-outline-button,.st-paper-interactive,.st-primary-action,.st-round-button{transition:none}}@media (min-width:901px){.st-dictionary-search{top:0}}@media (max-width:900px){.st-shell{min-height:100dvh}.st-main{min-width:0}.st-page{width:100%;padding:24px 16px 108px}.st-page-header{display:flex;gap:14px;flex-wrap:wrap}.st-page-header>*{min-width:0}.st-dictionary-search{top:64px;margin-inline:-16px;border-left:0;border-right:0;border-radius:0;grid-template-columns:auto minmax(0,1fr) auto auto}.st-dictionary-search .st-live-chip{display:inline-flex;min-width:44px;padding-inline:8px}.st-search-stream-strip{grid-template-columns:1fr}.st-search-stream-strip .st-chip-row{justify-content:flex-start}.st-card-grid,.st-course-board,.st-course-kanji-grid,.st-dictionary-bands,.st-kanji-detail-grid,.st-onboarding-grid,.st-onboarding-summary,.st-personal-detail-grid,.st-word-learning-grid,.st-word-study-grid{grid-template-columns:1fr}.st-kanji-detail-hero .st-headline{font-size:84px}.st-word-study-main{min-height:300px}.st-word-study-symbol{font-size:72px}.st-word-study-main h2{font-size:22px;line-height:30px}.st-word-card-row{grid-template-columns:auto minmax(0,1fr)}.st-word-card-row .st-level,.st-word-card-row small{grid-column:2/3;width:-moz-fit-content;width:fit-content}.st-kanji-reference,.st-writing-canvas{min-height:300px}.st-kanji-meta-grid,.st-kanji-readings p{grid-template-columns:1fr}.st-writing-feedback{align-items:stretch;flex-direction:column}.st-writing-actions{justify-content:stretch}.st-writing-actions>*{flex:1 1}.st-course-hero:after{width:112px;height:112px;opacity:.72}.st-course-kanji-card,.st-course-loading,.st-course-metric-grid,.st-course-step,.st-course-word-row{grid-template-columns:1fr}.st-course-kanji-card .st-level,.st-course-word-row .st-outline-button{width:-moz-fit-content;width:fit-content}.st-course-actions{justify-content:flex-start}.st-course-toolbar-actions,.st-course-toolbar-actions .st-chip-row{width:100%;justify-content:flex-start}.st-auth-page{padding:24px 16px 40px}.st-auth-features,.st-auth-hero,.st-settings-grid{grid-template-columns:1fr}.st-auth-hero{min-height:auto}.st-auth-panel{min-height:320px}.st-auth-features{margin-top:18px}.st-auth-actions,.st-auth-status{align-items:stretch;flex-direction:column}.st-page-actions{width:100%;justify-content:stretch}.st-page-actions>*{flex:1 1 160px}.st-segmented,.st-setting-control,.st-toolbar .st-search-box{width:100%}.st-setting-control{justify-items:stretch}.st-settings-load{grid-template-columns:1fr}.st-auth-feature,.st-tool-card{min-width:0}.st-notes-layout,.st-notes-overview,.st-progress-hero,.st-text-pipeline{grid-template-columns:1fr}.st-progress-summary{align-items:flex-start;flex-direction:column;min-height:auto}.st-progress-ring{width:132px;height:132px}.st-progress-insight{min-height:auto;align-items:center}.st-activity-chart{min-height:200px}.st-activity-day{height:164px}.st-candidate-row{grid-template-columns:minmax(54px,auto) minmax(0,1fr)}.st-candidate-row .st-level{grid-column:1/-1;width:-moz-fit-content;width:fit-content}.st-note-card{grid-template-columns:1fr;gap:12px}.st-note-expression{font-size:30px;line-height:38px}.st-note-actions{justify-content:stretch}.st-note-actions>*{flex:1 1 136px}.st-note-kanji-chip{width:100%}.st-analysis-actions,.st-personal-deck-form,.st-prepared-strip{align-items:stretch;flex-direction:column}.st-personal-deck-form{grid-template-columns:1fr}.st-row{padding:16px}.st-setting-row{align-items:stretch;flex-direction:column}.st-number-input{width:100%}.st-review-focus{min-height:100dvh;gap:18px}.st-mobile-nav-item span:last-child{max-width:64px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}}.st-main>.st-review-focus{width:100%;min-height:auto;align-items:stretch;gap:20px;padding:0;background:transparent}.st-main>.st-review-focus .st-review-actions,.st-main>.st-review-focus .st-review-grades,.st-main>.st-review-focus .st-review-study-layout,.st-main>.st-review-focus .st-review-top{width:100%;max-width:1120px;margin-inline:auto}.st-main>.st-review-focus .st-review-done{margin-inline:auto}.ja-reader{position:relative}.ja-reader-note{color:var(--st-tertiary);margin-bottom:8px}.ja-reader-text{white-space:pre-wrap;word-break:break-word;line-height:2;font-size:19px;color:var(--accent-ink)}.ja-reader-text ruby{ruby-position:over}.ja-reader-text rt{font-size:.68em;color:var(--st-on-surface-variant);font-weight:600;-webkit-user-select:none;-moz-user-select:none;user-select:none;line-height:1.1}.ja-gap,.ja-plain{white-space:pre-wrap}.ja-tok-wrap{position:relative;display:inline-block}.ja-tok{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;font:inherit;color:inherit;padding:0 1px;margin:0;cursor:pointer;border-radius:var(--radius-sm);border:none;border-bottom:2px solid transparent;transition:background .12s ease,border-color .12s ease}.ja-tok.is-open,.ja-tok:hover{background:var(--accent-blue);color:#fff}.ja-tok.is-open rt,.ja-tok:hover rt{color:#cfe4f4}.ja-tok.is-known{border-bottom-color:var(--st-secondary)}.ja-card{display:flex;flex-direction:column;gap:8px;background:var(--surface);border:1px solid var(--border-strong);border-radius:var(--radius);padding:14px 16px;box-shadow:0 12px 32px rgba(16,71,107,.16);text-align:left}.ja-card-float{position:fixed;z-index:1000;cursor:default;animation:ja-card-in .12s ease-out}@keyframes ja-card-in{0%{opacity:0}}.ja-catcher{position:fixed;inset:0;z-index:999;background:transparent}.ja-card-head{display:flex;align-items:baseline;gap:10px;flex-wrap:wrap}.ja-card-word{font-size:22px;font-weight:700;color:var(--accent-ink)}.ja-card-reading{font-size:14px;color:var(--accent-blue-2);font-weight:600}.ja-card-pos{font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--st-on-surface-variant)}.ja-card-meaning{font-size:14px;line-height:1.4;color:var(--accent-ink);margin:0}.ja-card-actions{display:flex;align-items:center;gap:8px}.ja-card-known{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:700;color:var(--st-secondary)}