*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--font-sans:"Inter Tight", "Noto Sans JP", system-ui, -apple-system, sans-serif;--font-serif:"Fraunces", "Noto Serif JP", Georgia, serif;--font-jp:"Noto Sans JP", sans-serif;--font-data:"DM Sans", sans-serif;--font-en:"Source Serif 4", serif;--font-mono:"JetBrains Mono", monospace;--font-title:"Playfair Display", serif;--app-font:var(--font-jp)}:root,[data-theme=light]{--uchi-bg:#f4f2ed;--uchi-line:#e3dfd6;--uchi-primary:#1f4e47;--uchi-primary-hover:#173d38;--uchi-primary-active:#12342f;--uchi-primary-soft:#e5ede8;--uchi-sage:#8da387;--uchi-sage-mid:#7e9575;--uchi-cream:#f0e3db;--uchi-cream-soft:#efe8dc;--uchi-rose:#c88a7a;--uchi-rose-deep:#a8665a;--uchi-paper:#fff;--uchi-row-alt:#faf9f4;--uchi-progress-track:#efeee9;--uchi-hero-from:#efe8dc;--uchi-hero-mid:#dce4d0;--uchi-hero-to:#b8c9b0;--uchi-tag-sage-bg:#eef1e9;--uchi-tag-rose-bg:#f6e5e0;--uchi-tag-plain-bg:#f0efea;--uchi-tag-cream-text:#7c5a4f;--uchi-ink:#2e3528;--uchi-ink-2:#5e6b52;--uchi-ink-3:#8a9080;--uchi-ink-4:#a8aea0;--bg-page:#f7f4ee;--bg-sidebar:#f2efe8;--bg-surface:var(--uchi-paper);--bg-surface-hover:#e4efea;--bg-surface-muted:#efe8da;--text-primary:#17231d;--text-primary-alt:#123f39;--text-deep:#0a0a0a;--text-secondary:#35433e;--text-tertiary:#6f7a74;--text-muted:#8a938c;--border:#ddd8cd;--border-strong:#c9c2b3;--icon-color:#34423d;--scrim:#17231dc7;--scrollbar-thumb:#00000014;--scrollbar-thumb-hover:#00000026;--color-primary:#15564e;--color-primary-hover:#123f39;--color-primary-active:#0e302c;--color-primary-ghost:#e4efea;--color-secondary:#6d8468;--color-secondary-hover:#5b7358;--color-ok:#3d9b5f;--color-ok-bg:#e8f5ec;--color-err:#d04b3c;--color-err-bg:#fceeed;--color-warn:#c08b1e;--color-warn-bg:#fbf3e0;--color-accent:#f6ddd4;--color-accent-soft:#efe8da;--color-divider:#ddd8cd;--color-input-bg:#fff;--color-border-input:#d6d1c5;--course-hero-from:#f0ecdf;--course-hero-to:#dde8d4;--course-active-pale:#e4efea;--book-card-green:#dfead3;--book-card-peach:#f6ddd4;--book-card-sand:#efe8da;--book-card-mint:#e3efeb;--book-card-cream:#f1e8de;--course-on-primary:#fff;--course-cover-shadow:#17231d29;--course-cover-muted-text:#ffffffbd;--course-hero-glass:#ffffff47;--course-hero-badge-muted:#ffffff6b;--course-hero-progress-track:#ffffffdb;--course-hero-divider:#15564e29;--course-hero-watermark:#15564e0d;--uchi-hero-ceramic:#eae2d0;--uchi-hero-cup:#f0ebde;--uchi-hero-vessel-border:#a8917473;--uchi-hero-ceramic-shadow:#d6c8ae;--uchi-hero-stem:#5e5445;--uchi-hero-window-line:#5e6b526b;--uchi-hero-window-fill:#f2efe4d9;--uchi-hero-branch-leaf:#8a9b7c;--uchi-hero-branch-stem:#7a8974;--uchi-hero-table-shadow:#7e95752e;--exercise-bg-page:#f0efec;--exercise-bg-surface:#fff;--exercise-bg-surface-hover:#7c3aed14;--exercise-bg-surface-muted:#f5f5f1;--exercise-text-primary:#1c1929;--exercise-text-primary-alt:#2a2640;--exercise-text-secondary:#4a4560;--exercise-text-tertiary:#8a8599;--exercise-text-muted:#b5b1be;--exercise-border:#e2dfd8;--exercise-border-strong:#ccc8bf;--exercise-icon-color:#4a4560;--exercise-primary:#7c3aed;--exercise-primary-hover:#6d28d9;--exercise-primary-active:#5b21b6;--exercise-primary-ghost:#7c3aed1a;--exercise-secondary:#6baf9a;--exercise-secondary-hover:#579e88;--exercise-input-bg:#f5f5f1;--exercise-border-input:#b8b3a8;--exercise-on-primary:#fff;--card-hover-from:#1f4e4714;--card-hover-to:#8da38714;--card-tag-bg:#00000080;--card-tag-text:#fff}[data-theme=dark]{--uchi-bg:#1f211c;--uchi-line:#3c3a32;--uchi-primary:#72c8b6;--uchi-primary-hover:#5db5a4;--uchi-primary-active:#4ca08f;--uchi-primary-soft:#72c8b624;--uchi-sage:#8ca987;--uchi-sage-mid:#7a9875;--uchi-cream:#342f28;--uchi-cream-soft:#2d2b25;--uchi-rose:#e06b5e;--uchi-rose-deep:#f29a90;--uchi-paper:#252528;--uchi-row-alt:#2a2a2e;--uchi-progress-track:#ffffff1f;--uchi-hero-from:#252820;--uchi-hero-mid:#26342e;--uchi-hero-to:#314237;--uchi-tag-sage-bg:#8ca98729;--uchi-tag-rose-bg:#e06b5e24;--uchi-tag-plain-bg:#ffffff14;--uchi-tag-cream-text:#e0c9b8;--uchi-ink:#f0f0f0;--uchi-ink-2:#b8c0b0;--uchi-ink-3:#8f968a;--uchi-ink-4:#6f766b;--bg-page:#1a1a1e;--bg-sidebar:#202024;--bg-surface:#252528;--bg-surface-hover:#2f2f33;--bg-surface-muted:#2a2a2e;--text-primary:#f0f0f0;--text-primary-alt:#e4e4e7;--text-deep:#fff;--text-secondary:#b0b0b8;--text-tertiary:#8a8a94;--text-muted:#5c5c66;--border:#3a3a3e;--border-strong:#4a4a50;--icon-color:#b0b0b8;--scrim:#000000b3;--scrollbar-thumb:#ffffff1a;--scrollbar-thumb-hover:#fff3;--color-primary:#72c8b6;--color-primary-hover:#5db5a4;--color-primary-active:#4ca08f;--color-primary-ghost:#72c8b624;--color-secondary:#8ca987;--color-secondary-hover:#7a9875;--color-ok:#4db873;--color-ok-bg:#4db8731f;--color-err:#e06b5e;--color-err-bg:#e06b5e1f;--color-warn:#d9a63a;--color-warn-bg:#d9a63a1f;--color-accent:#f6ddd4;--color-accent-soft:#f6ddd41a;--color-divider:#3a3a3e;--color-input-bg:#2a2a2e;--color-border-input:#4a4a50;--course-hero-from:#252820;--course-hero-to:#26342e;--course-active-pale:#72c8b624;--book-card-green:#2d3a2b;--book-card-peach:#402d29;--book-card-sand:#363126;--book-card-mint:#263a35;--book-card-cream:#342f28;--course-on-primary:#0e302c;--course-cover-shadow:#00000047;--course-cover-muted-text:#ffffffad;--course-hero-glass:#ffffff14;--course-hero-badge-muted:#ffffff14;--course-hero-progress-track:#ffffff29;--course-hero-divider:#72c8b638;--course-hero-watermark:#72c8b614;--exercise-bg-page:#1a1a1e;--exercise-bg-surface:#252528;--exercise-bg-surface-hover:#2f2f33;--exercise-bg-surface-muted:#2a2a2e;--exercise-text-primary:#f0f0f0;--exercise-text-primary-alt:#e4e4e7;--exercise-text-secondary:#b0b0b8;--exercise-text-tertiary:#8a8a94;--exercise-text-muted:#5c5c66;--exercise-border:#3a3a3e;--exercise-border-strong:#4a4a50;--exercise-icon-color:#b0b0b8;--exercise-primary:#7b6fe0;--exercise-primary-hover:#6b5fd0;--exercise-primary-active:#5b4fc7;--exercise-primary-ghost:#7b6fe01f;--exercise-secondary:#7ec4ae;--exercise-secondary-hover:#6bb49e;--exercise-input-bg:#2a2a2e;--exercise-border-input:#4a4a50;--exercise-on-primary:#fff;--card-hover-from:#72c8b61f;--card-hover-to:#8ca9871a;--card-tag-bg:#0009;--card-tag-text:#fff}body{background:var(--bg-page);color:var(--text-primary);font-family:var(--app-font,var(--font-jp));-webkit-font-smoothing:antialiased;font-feature-settings:"ss01";overflow:hidden}.num{font-variant-numeric:tabular-nums}#root{width:100vw;height:100vh;position:relative}@keyframes fadeUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes barGrow{0%{width:0}}@keyframes shimmer{0%{background-position:-400px 0}to{background-position:400px 0}}@keyframes shake{10%,90%{transform:translate(-1px)}20%,80%{transform:translate(2px)}30%,50%,70%{transform:translate(-4px)}40%,60%{transform:translate(4px)}}@keyframes micro{0%{transform:scale(1)}50%{transform:scale(1.015)}to{transform:scale(1)}}@keyframes correctPop{0%{opacity:0;transform:scale(.7)}60%{transform:scale(1.15)}to{opacity:1;transform:scale(1)}}@keyframes toastIn{0%{opacity:0;transform:translate(-50%,-12px)}to{opacity:1;transform:translate(-50%)}}@keyframes dotPulse{0%,to{opacity:.3}50%{opacity:1}}.course-list-page{background:#fff;max-width:1000px;min-height:100vh;margin:0 auto;padding:40px 24px}.course-list-header{margin-bottom:32px}.course-list-title{color:var(--text-primary);margin:0 0 8px;font-size:28px;font-weight:700}.course-list-desc{color:var(--text-tertiary);margin:0 0 12px;font-size:15px;line-height:1.6}.course-list-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px;display:grid}.course-card{background:var(--bg-surface-hover);cursor:pointer;text-align:left;font-family:inherit;font-size:inherit;border:2px solid #0000;border-radius:16px;flex-direction:column;padding:0;transition:all .15s;display:flex;overflow:hidden}.course-card:hover{background:var(--bg-surface-muted);transform:translateY(-3px);box-shadow:0 8px 24px #00000014}.course-card__cover{border-radius:16px 16px 0 0;justify-content:center;align-items:center;height:100px;display:flex}.course-card__cover-text{color:#ffffffe6;letter-spacing:2px;font-size:32px;font-weight:700}.course-card__body{flex-direction:column;flex:1;gap:6px;padding:16px 20px 20px;display:flex}.course-card__title{color:var(--text-primary);margin:0;font-size:17px;font-weight:600;line-height:1.4}.course-card__desc{color:var(--text-tertiary);-webkit-line-clamp:2;-webkit-box-orient:vertical;flex:1;margin:0;font-size:13px;line-height:1.5;display:-webkit-box;overflow:hidden}.course-card__footer{justify-content:space-between;align-items:center;margin-top:8px;display:flex}.course-card__lesson-count{color:var(--text-muted);font-size:12px;font-weight:500}.course-card__progress{align-items:center;gap:6px;display:flex}.course-card__progress-track{background:var(--border);border-radius:9999px;width:60px;height:4px;overflow:hidden}.course-card__progress-fill{background:#7c4dff;border-radius:9999px;height:100%;transition:width .3s}.course-card__progress-text{color:#7c4dff;font-size:11px;font-weight:500}.lesson-list-page{background:#fff;max-width:1000px;min-height:100vh;margin:0 auto;padding:40px 24px}.lesson-list-header{margin-bottom:32px}.lesson-list-back{color:#7c4dff;cursor:pointer;background:0 0;border:none;align-items:center;gap:4px;margin-bottom:16px;padding:6px 0;font-family:inherit;font-size:14px;font-weight:500;display:inline-flex}.lesson-list-back:hover{opacity:.8}.lesson-list-title{color:var(--text-primary);margin:0 0 8px;font-size:28px;font-weight:700}.lesson-list-desc{color:var(--text-tertiary);margin:0 0 12px;font-size:15px;line-height:1.6}.lesson-list-meta{color:var(--text-muted);font-size:13px}.lesson-list-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px;display:grid}.lesson-card{background:var(--bg-surface-hover);cursor:pointer;text-align:left;min-height:140px;font-family:inherit;font-size:inherit;border:2px solid #0000;border-radius:12px;flex-direction:column;align-items:flex-start;padding:20px;transition:all .15s;display:flex}.lesson-card:hover{background:var(--bg-surface-muted);transform:translateY(-2px);box-shadow:0 4px 12px #0000000f}.lesson-card--active{background:#f5f0ff;border-color:#7c4dff}.lesson-card--completed{background:#f0fff4;border-color:#4caf50}.lesson-card__header{justify-content:space-between;align-items:center;width:100%;margin-bottom:8px;display:flex}.lesson-card__title{color:var(--text-primary);font-size:17px;font-weight:600}.lesson-card__badge{color:var(--text-muted);font-size:13px;font-weight:500}.lesson-card__subtitle{color:var(--text-tertiary);-webkit-line-clamp:2;-webkit-box-orient:vertical;flex:1;margin:0;font-size:14px;line-height:1.5;display:-webkit-box;overflow:hidden}.lesson-card__progress{align-items:center;gap:8px;width:100%;margin-top:12px;display:flex}.lesson-card__progress-track{background:var(--border);border-radius:9999px;flex:1;height:4px;overflow:hidden}.lesson-card__progress-fill{background:#7c4dff;border-radius:9999px;height:100%;transition:width .3s}.lesson-card__progress-text{color:#7c4dff;white-space:nowrap;font-size:12px;font-weight:500}.lesson-card__completed-badge{color:#4caf50;background:#4caf501a;border-radius:9999px;margin-top:12px;padding:2px 10px;font-size:12px;font-weight:500;display:inline-block}.page{--bg-page:var(--exercise-bg-page);--bg-surface:var(--exercise-bg-surface);--bg-surface-hover:var(--exercise-bg-surface-hover);--bg-surface-muted:var(--exercise-bg-surface-muted);--text-primary:var(--exercise-text-primary);--text-primary-alt:var(--exercise-text-primary-alt);--text-secondary:var(--exercise-text-secondary);--text-tertiary:var(--exercise-text-tertiary);--text-muted:var(--exercise-text-muted);--border:var(--exercise-border);--border-strong:var(--exercise-border-strong);--icon-color:var(--exercise-icon-color);--color-primary:var(--exercise-primary);--color-primary-hover:var(--exercise-primary-hover);--color-primary-active:var(--exercise-primary-active);--color-primary-ghost:var(--exercise-primary-ghost);--color-secondary:var(--exercise-secondary);--color-secondary-hover:var(--exercise-secondary-hover);--color-input-bg:var(--exercise-input-bg);--color-border-input:var(--exercise-border-input);background-color:var(--exercise-bg,#fff);flex-direction:column;width:100vw;height:100vh;display:flex;position:relative}.header{border-bottom:.8px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;height:53px;padding:12px 24px;display:flex}.header-left{align-items:center;gap:24px;max-width:90%;display:flex}.menu-icon{cursor:pointer;color:var(--text-primary);background:0 0;border:none;padding:0;font-size:24px;display:inline-flex}.lesson-title{color:var(--text-deep);white-space:nowrap;text-overflow:ellipsis;font-size:16px;font-weight:500;overflow:hidden}.split-steps-toggle{background:var(--bg-surface-muted);cursor:pointer;font:inherit;border:none;border-radius:999px;align-items:center;gap:8px;padding:4px 10px 4px 4px;transition:background .15s;display:inline-flex}.split-steps-toggle:hover{background:var(--bg-surface-hover)}.split-steps-toggle__track{background:var(--text-muted);border-radius:999px;width:28px;height:16px;transition:background .2s;display:inline-block;position:relative}.split-steps-toggle__thumb{background:#fff;border-radius:50%;width:12px;height:12px;transition:transform .2s;position:absolute;top:2px;left:2px}.split-steps-toggle--on .split-steps-toggle__track{background:var(--color-primary)}.split-steps-toggle--on .split-steps-toggle__thumb{transform:translate(12px)}.split-steps-toggle__label{color:var(--text-secondary);font-size:13px;font-weight:500}.split-steps-toggle--on .split-steps-toggle__label{color:var(--text-primary)}.header-right{align-items:center;gap:16px;display:flex}.header-icon{cursor:pointer;color:var(--text-primary);background:0 0;border:none;padding:0;font-size:24px;transition:color .15s;display:inline-flex}.header-icon--on{color:var(--color-primary)}.progress-bar-container{flex-shrink:0;padding:4px 24px 0}.progress-bar-track{border:.8px solid var(--border-strong);border-radius:8px;height:8px;position:relative;overflow:hidden}.progress-bar-fill{background:linear-gradient(90deg,#10b981,#059669);border-radius:8px;height:100%;transition:all .3s}.score-timer{flex-shrink:0;justify-content:flex-end;align-items:center;gap:12px;padding:16px 24px 0;display:flex}.score{color:#64748b;font-family:Fredoka,sans-serif;font-size:24px;font-weight:900;transition:color .15s}.score--bounce{color:#10b981;animation:.3s ease-out score-bounce}@keyframes score-bounce{0%{transform:scale(1)}40%{transform:scale(1.2)}to{transform:scale(1)}}.perfect-combo-overlay{pointer-events:none;z-index:9999;opacity:0;transition:all .3s ease-out;position:fixed;top:16%;left:50%;transform:translate(-50%)translateY(-16px)}.perfect-combo-overlay--show{opacity:1;transform:translate(-50%)translateY(0)}.perfect-combo-inner{align-items:center;gap:8px;display:flex}.perfect-combo-text{letter-spacing:.05em;color:#ea580c;-webkit-text-stroke:2px #fff;paint-order:stroke;text-shadow:3px 3px 6px #00000026,0 0 30px #ea580c4d;font-size:36px;font-style:italic;font-weight:900}.perfect-combo-x{font-size:24px}.perfect-combo-num{font-variant-numeric:tabular-nums}.timer-icon{width:20px;height:20px;color:var(--text-muted)}.timer{color:var(--text-muted);font-family:Fredoka,sans-serif;font-size:18px;font-weight:500}.main-content{flex-direction:column;flex:1;justify-content:center;align-items:center;gap:12px;min-height:0;padding-bottom:40px;display:flex}.words-row{justify-content:center;align-items:flex-start;gap:16px;display:flex}.word-group{flex-direction:column;align-items:center;gap:2px;display:flex}.words-row--answer{flex-wrap:wrap;max-width:1600px;margin:0 auto;position:relative}.word-column{z-index:1;flex-direction:column;align-items:center;display:flex;position:relative}.phonetic-row{align-items:center;height:24px;margin-bottom:8px;display:flex}.word-box{flex-direction:column;align-items:center;padding-bottom:4px;display:flex;position:relative}.word-highlight{z-index:0;border-radius:8px;transition:all .15s ease-out;position:absolute}.word-underline-bar{border-radius:9999px;width:100%;height:4px;margin-top:-2px}.word-correct-bar{background:#4caf50;border-radius:0 0 4px 4px;width:100%;height:3px;position:absolute;bottom:0;left:0}.phonetic{font-size:var(--phonetic-size,12px);color:var(--text-tertiary);background-color:var(--bg-surface-muted);border-radius:4px;margin-bottom:2px;padding:2px 6px;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-weight:500;line-height:1.4}.word-text{color:var(--text-primary);padding:4px;font-family:Fredoka,sans-serif;font-size:48px;font-weight:500;line-height:1.15;position:relative}.word-underline-wrapper{flex-direction:column;align-items:center;display:flex;position:relative}.pos-tag{color:var(--text-secondary);border:.8px solid var(--border-strong);background-color:#fffc;border-radius:9999px;justify-content:center;align-items:center;margin-top:4px;padding:2px 8px;font-size:11px;font-weight:500;display:flex}.word-meaning{color:var(--text-secondary);text-overflow:ellipsis;white-space:nowrap;max-width:180px;margin-top:4px;font-size:14px;font-weight:500;overflow:hidden}.japanese-sentence{color:var(--text-secondary);text-align:center;margin-top:16px;font-family:Noto Sans JP,Hiragino Sans,Yu Gothic,sans-serif;font-size:24px;font-weight:500}.answer-focus-layout{flex-direction:column;align-items:center;gap:32px;width:min(960px,100vw - 96px);display:flex}.answer-focus-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:14px;flex-direction:column;align-items:center;gap:12px;min-width:220px;max-width:min(320px,100%);padding:28px 36px;display:flex;box-shadow:0 1px 3px #00000005}.answer-focus-card__word{color:var(--text-primary);font-family:Fredoka,sans-serif;font-size:56px;font-weight:600;line-height:1.05}.answer-focus-card__phonetic{color:var(--text-tertiary);font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:24px;font-weight:500}.answer-focus-card__meaning{color:var(--text-secondary);text-align:center;font-family:Noto Sans JP,Hiragino Sans,Yu Gothic,sans-serif;font-size:28px;font-weight:500}.answer-focus-sentence-block{flex-direction:column;align-items:center;gap:20px;width:100%;display:flex}.answer-focus-sentence-row{justify-content:center;align-items:center;gap:8px;width:100%;display:flex}.answer-focus-sentence{flex-wrap:wrap;justify-content:center;align-items:center;gap:10px;display:flex}.answer-focus-token{color:var(--text-primary);cursor:pointer;background:0 0;border:none;border-radius:12px;padding:4px 10px;font-family:Fredoka,sans-serif;font-size:48px;font-weight:500;line-height:1.1;transition:color .15s,background-color .15s}.answer-focus-token:hover,.answer-focus-token--active{color:var(--color-primary)}.answer-focus-token--target{background:var(--color-primary);color:#fff}.answer-focus-token--target:hover,.answer-focus-token--target.answer-focus-token--active{background:var(--color-primary-hover);color:#fff}.answer-focus-translation{text-align:center;margin-top:0}.answer-focus-sentence-row>.slow-play-btn{margin-left:8px}.bottom-bar{justify-content:center;align-items:center;gap:8px;display:flex}.shortcut-btn{cursor:pointer;color:var(--text-deep);white-space:nowrap;background:0 0;border:none;border-radius:6px;flex-shrink:0;align-items:center;gap:6px;padding:8px 16px;font-family:Fredoka,sans-serif;font-size:14px;transition:background-color .15s;display:flex}.shortcut-btn:hover{background-color:var(--bg-surface-muted)}.kbd{background-color:var(--bg-surface-muted);color:var(--text-primary-alt);box-shadow:inset 0 0 0 1px var(--border-strong);border-radius:6px;justify-content:center;align-items:center;padding:4px 8px;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:12px;font-weight:500;line-height:1;display:inline-flex}.shortcut-label{color:var(--icon-color);white-space:nowrap;font-size:14px;font-weight:500}.combo-ring{width:32px;height:32px;position:relative}.combo-ring svg{width:32px;height:32px}.combo-text{color:var(--icon-color);white-space:nowrap;font-size:10px;font-weight:500;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.main-content--question{box-sizing:border-box;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:24px;width:100%;max-width:1600px;min-height:0;margin:0 auto;padding:0 32px 20px;display:flex}.japanese-sentence--question{font-size:var(--question-size,30px);color:var(--text-primary);font-weight:500;line-height:var(--question-line-height,36px);font-family:Noto Sans JP,Hiragino Sans,Yu Gothic,sans-serif}.words-row--question{flex-wrap:wrap;justify-content:center;align-items:flex-end;gap:8px;display:flex;position:relative}.word-slot{cursor:pointer;font:inherit;background:0 0;border:none;justify-content:center;align-items:flex-end;padding:0 12px 8px;display:flex;position:relative}.word-slot--correct{border-bottom:1.6px solid var(--border-strong)}.word-slot--error{border-bottom:1.6px solid #ef4444}.word-slot--shake{animation:.5s cubic-bezier(.36,.07,.19,.97) shake}.word-text--input{font-family:Fredoka,sans-serif;font-size:48px;font-weight:400;line-height:1.2}.word-text--gray{color:var(--text-tertiary)}.word-text--red{color:#ef4444}.word-text--delete{color:#ef4444;text-decoration:line-through}.word-slot--revealed-correct{border-bottom:1.6px solid #ef4444}.word-text--green{color:#22c55e}.word-text--black{color:var(--text-deep)}.comma-separator{color:var(--text-deep);padding:0 0 8px;font-family:Fredoka,sans-serif;font-size:48px;font-weight:500;line-height:1.2}.word-prefilled{padding:0 0 8px}.bottom-bar--question{justify-content:center;align-items:center;gap:16px;display:flex}.bottom-bar-wrapper{flex-shrink:0;justify-content:center;align-items:center;gap:96px;padding:16px 24px 48px;display:flex}.nav-arrow{width:48px;height:54px;color:var(--text-secondary);cursor:pointer;background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;transition:color .15s;display:flex}.nav-arrow:hover{color:var(--text-deep)}.nav-arrow svg{stroke-width:2.5px;width:36px;height:36px}.nav-arrow__tooltip{white-space:nowrap;color:var(--icon-color);background:#fff;border-radius:8px;align-items:center;gap:6px;padding:6px 12px;font-size:13px;display:none;position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);box-shadow:0 2px 8px #0000001f}.nav-arrow{position:relative}.nav-arrow:hover .nav-arrow__tooltip{display:flex}.ai-helper{border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;background:#fff;border-radius:20px;align-items:center;gap:6px;padding:6px 12px;font-size:12px;display:flex;position:fixed;bottom:8px;right:16px;box-shadow:0 1px 2px #0000000d}.ai-helper-icon{background:var(--text-primary);border-radius:50%;justify-content:center;align-items:center;width:20px;height:20px;display:flex}.tooltip-card{border:.8px solid var(--border);-webkit-backdrop-filter:blur(16px);z-index:10;background:#ffffff80;border-radius:16px;align-items:flex-start;gap:4px;width:max-content;max-width:90vw;padding:16px;transition:transform .2s cubic-bezier(.4,0,.2,1),box-shadow .2s cubic-bezier(.4,0,.2,1);display:flex;position:absolute;top:80px;left:50%;transform:translate(-50%);box-shadow:0 20px 25px -5px #0000001a,0 8px 10px -6px #0000001a}.tooltip-card:hover{transform:translate(-50%)scale(1.02);box-shadow:0 25px 50px -12px #00000040}.tooltip-card .words-row--answer{flex-wrap:wrap;max-width:none}.tooltip-card .word-meaning,.tooltip-card .phonetic,.tooltip-card .pos-tag{white-space:nowrap}.tooltip-word-group{flex-direction:column;align-items:center;gap:2px;display:flex}.tooltip-phonetic{color:var(--text-secondary);background:#f3f4f64d;border-radius:3px;padding:1px 4px;font-family:Arial,sans-serif;font-size:12px;font-weight:500;line-height:1.4}.tooltip-word{color:var(--text-primary);font-family:Fredoka,sans-serif;font-size:24px;font-weight:500;line-height:1.3}.tooltip-underline{border-radius:9999px;width:100%;height:2px;margin-top:1px}.tooltip-underline--purple{background:#7c3aed}.tooltip-underline--blue{background:#3b82f6}.tooltip-pos{color:var(--text-secondary);border:.8px solid var(--border-strong);background:#fffc;border-radius:9999px;margin-top:2px;padding:1px 6px;font-size:10px;font-weight:500;line-height:1.4}.tooltip-meaning{color:var(--text-secondary);margin-top:2px;font-size:12px;font-weight:500;line-height:1.3}.cr-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:20;background:#1f1f2bd9;justify-content:center;align-items:flex-start;padding:32px 16px;display:flex;position:fixed;inset:0;overflow-y:auto}.cr-card{background:var(--bg-surface);border-radius:16px;width:100%;max-width:680px;padding:32px 36px;font-family:Fredoka,sans-serif}.cr-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.cr-header__title{color:var(--text-primary);margin:0;font-size:22px;font-weight:600}.cr-header__nav{gap:20px;display:flex}.cr-header__link{color:var(--text-tertiary);cursor:pointer;background:0 0;border:none;align-items:center;gap:6px;font-family:Fredoka,sans-serif;font-size:14px;display:flex}.cr-header__link:hover{color:var(--icon-color)}.cr-score-row{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.cr-score-left{align-items:baseline;gap:4px;display:flex}.cr-grade{color:var(--text-tertiary);font-size:64px;font-weight:700;line-height:1}.cr-score-divider{color:var(--border-strong);margin:0 4px;font-size:32px}.cr-score-value{color:var(--text-primary);font-size:40px;font-weight:700;line-height:1}.cr-score-right{gap:24px;display:flex}.cr-count{flex-direction:column;align-items:center;display:flex}.cr-count__value{color:var(--text-primary);font-size:28px;font-weight:700}.cr-count__value--good{color:#3b82f6}.cr-count__value--skip{color:#9ca3af}.cr-count__label{color:var(--text-muted);font-size:12px}.cr-stats{border:1px solid var(--border);border-radius:8px;align-items:center;margin-bottom:28px;padding:16px 0;display:flex}.cr-stats__item{flex-direction:column;flex:1;align-items:center;gap:4px;display:flex}.cr-stats__label{color:var(--text-muted);font-size:13px}.cr-stats__value{color:var(--text-primary);font-size:20px;font-weight:600}.cr-stats__divider{background:var(--border);width:1px;height:36px}.cr-analytics{margin-bottom:28px}.cr-analytics__title{color:var(--text-muted);margin:0 0 16px;font-size:15px;font-weight:500}.cr-analytics__rings{justify-content:center;gap:32px;display:flex}.cr-ring{flex-direction:column;align-items:center;display:flex}.cr-ring__svg{width:80px;height:80px;transform:rotate(-90deg)}.cr-ring__track{fill:none;stroke:var(--border);stroke-width:6px}.cr-ring__fill{fill:none;stroke:#10b981;stroke-width:6px;stroke-linecap:round;transition:stroke-dashoffset .6s}.cr-ring__value{color:#10b981;margin-top:-54px;font-size:18px;font-weight:600}.cr-ring__label{color:var(--text-muted);margin-top:38px;font-size:12px}.cr-errors{background:var(--bg-surface-hover);border-radius:8px;margin-bottom:24px;padding:16px 20px}.cr-errors__title{color:var(--text-tertiary);margin:0 0 12px;font-size:14px;font-weight:600}.cr-errors__list{flex-direction:column;gap:8px;margin:0;padding:0;list-style:none;display:flex}.cr-errors__item{align-items:baseline;gap:8px;font-size:14px;display:flex}.cr-errors__prompt{color:var(--text-tertiary);flex-shrink:0}.cr-errors__answer{color:var(--text-primary);font-weight:500}.cr-errors__badge{color:#ef4444;flex-shrink:0;margin-left:auto;font-size:12px}.cr-actions{justify-content:flex-end;gap:12px;display:flex}.cr-btn{cursor:pointer;border:none;border-radius:8px;padding:10px 24px;font-family:Fredoka,sans-serif;font-size:15px;font-weight:500}.cr-btn--ghost{background:var(--bg-surface-muted);color:var(--icon-color)}.cr-btn--ghost:hover{background:var(--border)}.preview-overlay{z-index:20;background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.preview-card{background:#fff;border-radius:16px;flex-direction:column;width:90%;max-width:800px;max-height:80vh;display:flex;overflow:hidden}.preview-header{flex-shrink:0;justify-content:space-between;align-items:center;padding:20px 24px 16px;display:flex}.preview-title{color:var(--text-primary);font-size:20px;font-weight:600}.preview-close{width:32px;height:32px;color:var(--text-tertiary);cursor:pointer;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;font-size:20px;display:flex}.preview-close:hover{background:var(--bg-surface-muted)}.preview-list{padding:0 8px 16px;overflow-y:auto}.preview-item{background:var(--bg-surface-hover);text-align:left;width:100%;font:inherit;color:inherit;cursor:pointer;border:none;border-radius:8px;justify-content:space-between;align-items:center;margin:0 0 2px;padding:14px 16px;display:flex}.preview-item:hover{background:var(--bg-surface-muted)}.preview-item:hover .preview-arrow{color:var(--color-primary);transform:translate(2px)}.preview-item:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.preview-sentence{color:var(--text-primary);font-family:Fredoka,sans-serif;font-size:16px;font-weight:500}.preview-arrow{color:var(--text-muted);flex-shrink:0;margin-left:12px;font-size:16px;transition:color .15s,transform .15s}.word-box--clickable{cursor:pointer}.word-box--clickable:hover .word-text,.word-box--active .word-text{color:#3b82f6;transition:color .15s}.slow-play-btn{cursor:pointer;background:0 0;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-self:center;align-items:center;width:40px;height:40px;margin-left:4px;transition:background .15s;display:flex;position:relative}.words-row--question>.slow-play-btn{align-self:flex-end;margin-left:4px}.words-row--answer>.slow-play-btn{align-self:flex-start;margin-top:65px;margin-left:4px}.slow-play-btn:hover{background:#00000014}.slow-play-btn__icon{font-size:22px;line-height:1}.slow-play-btn__tooltip{white-space:nowrap;color:var(--icon-color);background:#fff;border-radius:8px;align-items:center;gap:4px;padding:5px 10px;font-size:13px;display:none;position:absolute;top:0;left:calc(100% + 8px);box-shadow:0 2px 8px #0000001f}.slow-play-btn:hover .slow-play-btn__tooltip{display:flex}.word-popover-overlay{z-index:30;position:fixed;inset:0}.word-popover{z-index:50;background:#fff;border-radius:16px;flex-direction:column;min-width:280px;max-width:400px;max-height:min(70vh,520px);padding:20px 24px;font-family:Fredoka,system-ui,sans-serif;display:flex;position:fixed;box-shadow:0 20px 25px -5px #0000001a,0 8px 10px -6px #0000001a}.word-popover__scroll{flex:auto;min-height:0;margin-right:-8px;padding-right:8px;overflow-y:auto}.word-popover__word{margin-bottom:4px;font-size:28px;font-weight:600}.word-popover__phonetic-row{color:var(--text-tertiary);align-items:center;gap:8px;margin-bottom:4px;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:14px;display:flex}.word-popover__phonetic-label{color:var(--text-muted);min-width:16px;font-family:Fredoka,system-ui,sans-serif;font-size:13px;font-weight:500}.word-popover__phonetic-text{flex:1}.word-popover__play-btn{width:28px;height:28px;color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;transition:color .15s,background .15s;display:flex}.word-popover__play-btn:hover{color:#3b82f6;background:#3b82f614}.word-popover__divider{background:var(--border);height:1px;margin:8px 0 12px}.word-popover__section-title{color:var(--text-muted);margin-bottom:6px;font-size:14px;font-weight:500}.word-popover__meaning{color:var(--text-primary);font-size:15px;line-height:1.6}.word-popover__pos{color:var(--text-tertiary);font-weight:500}.word-popover__note{color:var(--text-tertiary);margin-top:6px;font-size:13px;line-height:1.5}.word-popover__cefr-row{margin-bottom:8px}.word-popover__cefr-chip{background:var(--bg-surface-muted);color:var(--text-secondary);letter-spacing:.04em;border-radius:999px;padding:2px 8px;font-size:12px;font-weight:600;display:inline-block}.word-popover__inflections{color:var(--text-secondary);margin-top:6px;font-size:13px;line-height:1.5}.word-popover__dict-loading{color:var(--text-tertiary);font-size:13px;font-style:italic}.word-popover__vocab-btn{color:#fff;cursor:pointer;background:#22c55e;border:none;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:100%;margin-top:16px;padding:10px 0;font-size:15px;font-weight:600;transition:background .15s;display:flex}.word-popover__vocab-btn:hover{background:#16a34a}.syntax-tooltip{z-index:40;pointer-events:none;background:#fff;border-radius:12px;min-width:240px;max-width:400px;padding:16px 20px;font-family:Noto Sans JP,Hiragino Sans,Meiryo,sans-serif;position:fixed;box-shadow:0 10px 25px -5px #0000001f,0 4px 10px -4px #00000014}.syntax-tooltip__header{justify-content:space-between;align-items:baseline;margin-bottom:8px;display:flex}.syntax-tooltip__title{color:var(--text-primary);align-items:center;gap:6px;font-size:16px;font-weight:700;display:flex}.syntax-tooltip__dot{border-radius:50%;flex-shrink:0;width:10px;height:10px;display:inline-block}.syntax-tooltip__english{color:var(--text-muted);font-size:14px;font-style:italic}.syntax-tooltip__body{color:var(--icon-color);font-size:14px;line-height:1.7}.hidden-input{opacity:0;pointer-events:none;width:0;height:0;position:absolute}.word-slot--active{border-bottom:1.6px solid #7c3aed}.word-text--active{color:#7c3aed}.word-slot--confirmed{border-bottom:1.6px solid #2563eb}.word-text--confirmed{color:#2563eb}.word-slot--empty{border-bottom:1.6px solid var(--border-strong);min-width:60px}.previous-word{color:var(--text-muted);-webkit-user-select:none;user-select:none;padding:0 4px 8px;font-size:36px;line-height:1}.score-timer--question{flex-shrink:0;justify-content:flex-end;align-items:center;gap:12px;padding:12px 24px 0;display:flex}.chat-assistant-btn{z-index:15;background:var(--color-primary);color:#fff;cursor:pointer;border:none;border-radius:24px;align-items:center;gap:8px;padding:10px 16px;font-family:Noto Sans JP,Fredoka,sans-serif;font-size:14px;font-weight:500;transition:background .15s,transform .15s,box-shadow .15s;display:flex;position:fixed;bottom:24px;right:24px;box-shadow:0 4px 12px #7c4dff59}.chat-assistant-btn:hover{background:var(--color-primary-hover);transform:translateY(-1px);box-shadow:0 6px 16px #7c4dff73}.chat-assistant-btn__label{white-space:nowrap}.chat-panel{z-index:16;background:var(--bg-surface);border:1px solid var(--border);border-radius:16px;flex-direction:column;width:380px;height:520px;animation:.2s ease-out chat-panel-in;display:flex;position:fixed;bottom:80px;right:24px;overflow:hidden;box-shadow:0 20px 40px #00000026,0 0 0 1px #0000000d}@keyframes chat-panel-in{0%{opacity:0;transform:translateY(12px)scale(.96)}to{opacity:1;transform:translateY(0)scale(1)}}.chat-header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:14px 16px;display:flex}.chat-header__info{flex-direction:column;gap:2px;display:flex}.chat-header__title{color:var(--text-primary);font-family:Noto Sans JP,Fredoka,sans-serif;font-size:15px;font-weight:600}.chat-header__status{color:var(--text-tertiary);align-items:center;gap:4px;font-size:12px;display:flex}.chat-header__dot{background:var(--color-ok);border-radius:50%;width:6px;height:6px}.chat-header__close{cursor:pointer;width:32px;height:32px;color:var(--text-tertiary);background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;transition:background .15s;display:flex}.chat-header__close:hover{background:var(--bg-surface-muted)}.chat-messages{flex-direction:column;flex:1;gap:10px;padding:16px;display:flex;overflow-y:auto}.chat-welcome{text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:8px;padding:20px 0;display:flex}.chat-welcome__icon{color:var(--text-tertiary);margin-bottom:4px}.chat-welcome__title{color:var(--text-primary);font-family:Noto Sans JP,Fredoka,sans-serif;font-size:16px;font-weight:600}.chat-welcome__desc{color:var(--text-tertiary);max-width:280px;font-family:Noto Sans JP,sans-serif;font-size:13px;line-height:1.5}.chat-suggestions{flex-direction:column;gap:8px;width:100%;margin-top:12px;padding:0 8px;display:flex}.chat-suggestion-btn{border:1px solid var(--border);background:var(--bg-surface);cursor:pointer;width:100%;color:var(--icon-color);text-align:left;border-radius:10px;padding:10px 14px;font-family:Noto Sans JP,sans-serif;font-size:13px;line-height:1.4;transition:background .15s,border-color .15s}.chat-suggestion-btn:hover:not(:disabled){background:var(--bg-surface-hover);border-color:var(--color-primary);color:var(--color-primary)}.chat-suggestion-btn:disabled{opacity:.5;cursor:not-allowed}.chat-suggestions--followup{align-self:flex-start;max-width:85%;margin-top:-4px}.chat-suggestions--followup .chat-suggestion-btn{background:var(--bg-surface)}.chat-bubble{word-break:break-word;border-radius:12px;max-width:85%;padding:10px 14px;font-family:Noto Sans JP,sans-serif;font-size:13px;line-height:1.6}.chat-bubble--user{background:var(--color-primary);color:#fff;border-bottom-right-radius:4px;align-self:flex-end}.chat-bubble--assistant{background:var(--bg-surface-muted);color:var(--text-primary);border-bottom-left-radius:4px;align-self:flex-start}.chat-bubble--loading{color:var(--text-secondary)}.chat-footer{border-top:1px solid var(--border);flex-shrink:0;padding:10px 16px 12px}.chat-usage{color:var(--text-tertiary);margin-bottom:6px;font-family:Noto Sans JP,sans-serif;font-size:12px;font-weight:500}.chat-error{background:var(--color-err-bg);color:var(--color-err);border-radius:8px;margin-bottom:6px;padding:8px 10px;font-family:Noto Sans JP,sans-serif;font-size:12px;font-weight:600;line-height:1.5}.chat-input-area{flex-shrink:0;align-items:center;gap:8px;padding:0;display:flex}.chat-input{border:1px solid var(--border);border-radius:8px;outline:none;flex:1;padding:8px 12px;font-family:Noto Sans JP,sans-serif;font-size:13px;transition:border-color .15s}.chat-input:focus{border-color:var(--color-primary)}.chat-input::placeholder{color:var(--text-muted)}.chat-send-btn{background:var(--color-primary);color:#fff;cursor:pointer;border:none;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;transition:background .15s;display:flex}.chat-send-btn:hover:not(:disabled){background:var(--color-primary-hover)}.chat-send-btn:disabled{opacity:.4;cursor:not-allowed}.stm-overlay{background:var(--scrim);background:color-mix(in srgb, var(--uchi-ink) 42%, transparent);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:1000;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.stm-modal{background:var(--bg-surface);border:1px solid var(--uchi-line);width:min(900px,100%);height:min(640px,100vh - 48px);box-shadow:0 40px 90px #3c322838, 0 0 0 1px var(--uchi-line);border-radius:18px;display:flex;position:relative;overflow:hidden}.stm-header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:20px 24px 16px;display:flex}.stm-header__title{color:var(--text-primary);font-family:var(--font-serif);margin:0;font-size:22px;font-weight:700;line-height:1.25}.stm-header__close{width:32px;height:32px;color:var(--text-secondary);cursor:pointer;background:0 0;border:0;border-radius:50%;place-items:center;display:grid}.stm-header__close:hover{color:var(--color-primary);background:var(--color-primary-ghost)}.stm-body{flex:1;min-height:0;display:flex}.stm-sidebar{background:var(--uchi-row-alt);border-right:1px solid var(--uchi-line);flex-direction:column;flex:0 0 240px;width:240px;min-height:0;padding:30px 18px 22px;display:flex;overflow-y:auto}.stm-sidebar__head{flex-shrink:0}.stm-sidebar__kicker{color:var(--uchi-ink-4);font-family:var(--font-mono);letter-spacing:.06em;margin:7px 0 0;font-size:10.5px;font-weight:600}.stm-sidebar__nav{flex-direction:column;gap:6px;margin-top:24px;display:flex}.stm-sidebar__item{width:100%;min-height:52px;color:var(--text-secondary);font:inherit;white-space:nowrap;cursor:pointer;text-align:left;background:0 0;border:1.5px solid #0000;border-radius:12px;grid-template-columns:36px minmax(0,1fr) 14px;align-items:center;gap:12px;padding:8px 10px;font-size:13.5px;font-weight:700;line-height:1.3;transition:background .14s,border-color .14s,box-shadow .14s,color .14s;display:grid;position:relative}.stm-sidebar__item>svg{box-sizing:border-box;width:36px;height:36px;color:var(--color-primary);background:var(--color-primary-ghost);border-radius:12px;padding:8px}.stm-sidebar__item span{text-overflow:ellipsis;min-width:0;overflow:hidden}.stm-sidebar__item:after{content:"";border-right:1.5px solid var(--uchi-ink-4);border-bottom:1.5px solid var(--uchi-ink-4);justify-self:center;width:7px;height:7px;transform:rotate(-45deg)}.stm-sidebar__item:hover{color:var(--color-primary);background:var(--bg-surface);border-color:var(--uchi-sage-mid)}.stm-sidebar__item--active{background:var(--bg-surface);border-color:var(--uchi-sage-mid);color:var(--color-primary);box-shadow:0 10px 20px #3c32280f}.stm-sidebar__item--active:after{background:var(--uchi-sage-mid);border:0;border-radius:50%;width:6px;height:6px;transform:none}.stm-sidebar__item--active:hover{background:var(--bg-surface);color:var(--color-primary)}.stm-panel{background:var(--bg-surface);flex-direction:column;flex:1;min-width:0;min-height:0;display:flex;position:relative}.stm-modal>.stm-header__close{z-index:3;color:var(--text-secondary);background:color-mix(in srgb, var(--bg-surface) 92%, transparent);border:1px solid var(--uchi-line);position:absolute;top:18px;right:18px;box-shadow:0 8px 18px #3c322814}.stm-content{scrollbar-color:var(--scrollbar-thumb) transparent;scrollbar-width:thin;flex:1;min-height:0;padding:52px 30px 28px;overflow:auto}.stm-section{background:var(--bg-surface);border:1px solid var(--uchi-line);border-radius:16px;margin-bottom:16px;padding:24px 30px;box-shadow:0 1px 3px #2e35280a}.stm-section__title{color:var(--text-primary-alt);margin:0 0 4px;font-size:15px;font-weight:700;line-height:1.4}.stm-section__desc{color:var(--text-tertiary);margin:0 0 22px;font-size:12.5px;font-weight:500;line-height:1.5}.stm-row{justify-content:space-between;align-items:center;gap:18px;min-height:44px;display:flex}.stm-row+.stm-row{margin-top:18px}.stm-row__label{color:var(--text-primary-alt);font-size:14px;font-weight:600;line-height:1.5}.stm-row__right{align-items:center;gap:10px;display:flex}.stm-select{min-width:180px;color:var(--text-primary-alt);background:var(--bg-surface);border:1px solid var(--uchi-line);border-radius:10px;justify-content:space-between;align-items:center;gap:8px;padding:10px 14px;font-size:13.5px;font-weight:600;display:flex}.stm-select--disabled{color:var(--text-tertiary);background:var(--uchi-row-alt);cursor:default}.stm-row__hint{color:var(--text-tertiary);margin:2px 0 0;font-size:12px;font-weight:500;line-height:1.5}.stm-icon-btn{width:44px;height:44px;color:var(--text-secondary);cursor:pointer;background:var(--bg-surface);border:1px solid var(--uchi-line);border-radius:10px;place-items:center;transition:background .14s,border-color .14s,color .14s;display:grid}.stm-icon-btn:hover{color:var(--color-primary);background:var(--color-primary-ghost);border-color:var(--uchi-sage-mid)}.stm-toggle{cursor:pointer;background:var(--border-strong);border:none;border-radius:999px;flex-shrink:0;width:56px;height:30px;padding:0;transition:background .16s,box-shadow .16s;position:relative}.stm-toggle--on{background:var(--color-primary);box-shadow:0 8px 16px #15564e24}.stm-toggle__thumb{background:var(--bg-surface);border-radius:50%;width:26px;height:26px;transition:transform .16s;position:absolute;top:2px;left:2px;box-shadow:0 1px 3px #00000026}.stm-toggle--on .stm-toggle__thumb{transform:translate(26px)}.stm-premium-btn{width:100%;min-height:58px;color:var(--course-on-primary);cursor:pointer;background:var(--color-primary);border:1px solid var(--color-primary);border-radius:12px;justify-content:center;align-items:center;gap:8px;margin-top:22px;padding:0 18px;font-family:inherit;font-size:15px;font-weight:800;transition:transform .12s,background .12s,box-shadow .12s;display:flex;box-shadow:0 8px 16px #15564e24}.stm-premium-btn:hover{background:var(--color-primary-hover);transform:translateY(-1px)}.pvm-modal{background:var(--bg-surface);border:1px solid var(--uchi-line);width:100%;max-width:560px;max-height:80vh;box-shadow:0 30px 70px #3c32282e, 0 0 0 1px var(--uchi-line);border-radius:18px;padding:24px 28px;overflow-y:auto}.pvm-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.pvm-header__title{color:var(--text-primary);font-family:var(--font-serif);margin:0;font-size:22px;font-weight:700;line-height:1.25}.pvm-subtitle{color:var(--text-primary-alt);margin:0 0 16px;font-size:15px;font-weight:700}.pvm-grid{grid-template-columns:1fr 1fr;gap:12px;margin-bottom:20px;display:grid}.pvm-card{background:var(--bg-surface);border:1px solid var(--uchi-line);border-radius:12px;flex-direction:column;gap:12px;padding:16px;display:flex}.pvm-card__info{flex-direction:column;gap:4px;display:flex}.pvm-card__name{color:var(--text-primary-alt);font-size:14px;font-weight:700;line-height:1.45}.pvm-card__desc{color:var(--text-tertiary);font-size:12px;font-weight:500}.pvm-card__play{color:var(--course-on-primary);cursor:pointer;background:var(--color-primary);border:1px solid var(--color-primary);border-radius:10px;justify-content:center;align-items:center;gap:6px;padding:10px;font-family:inherit;font-size:13px;font-weight:700;display:flex}.pvm-card__play:hover{background:var(--color-primary-hover)}.pvm-card__play--active{background:var(--uchi-rose-deep);border-color:var(--uchi-rose-deep)}.pvm-card__play--active:hover{background:var(--uchi-rose)}.pvm-upgrade{background:var(--color-primary-ghost);border:1px solid var(--uchi-line);border-radius:12px;padding:16px 20px}.pvm-upgrade__title{color:var(--color-primary);align-items:center;gap:6px;margin:0 0 10px;font-size:15px;font-weight:700;display:flex}.pvm-upgrade__list{margin:0;padding:0;list-style:none}.pvm-upgrade__list li{color:var(--text-secondary);font-size:13px;font-weight:500;line-height:1.8}.pvm-upgrade__list li:before{content:"・"}.stm-info-box{background:var(--color-primary-ghost);border:1px solid var(--uchi-line);border-radius:12px;margin-top:16px;padding:12px 16px}.stm-info-box p{color:var(--text-tertiary);margin:0;font-size:13px;font-weight:500;line-height:1.8}.stm-select-native{align-items:center;min-width:min(320px,48vw);display:inline-flex;position:relative}.stm-select-native select{appearance:none;width:100%;min-height:44px;color:var(--text-primary-alt);background:var(--bg-surface);border:1px solid var(--uchi-line);cursor:pointer;border-radius:10px;padding:10px 40px 10px 16px;font-size:13.5px;font-weight:600}.stm-select-native select:hover{border-color:var(--uchi-sage-mid)}.stm-select-native select:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-ghost);outline:none}.stm-select-native__icon{pointer-events:none;color:var(--text-muted);position:absolute;right:14px}.stm-slider{appearance:none;background:var(--uchi-progress-track);cursor:pointer;width:160px;height:6px;accent-color:var(--color-primary);border-radius:999px;outline:none}.stm-slider::-webkit-slider-thumb{appearance:none;background:var(--color-primary);cursor:pointer;border-radius:50%;width:18px;height:18px;box-shadow:0 1px 3px #00000026}.stm-slider::-moz-range-thumb{background:var(--color-primary);cursor:pointer;border:none;border-radius:50%;width:18px;height:18px;box-shadow:0 1px 3px #00000026}.stm-slider__value{color:var(--text-primary-alt);text-align:right;min-width:40px;font-size:13px;font-weight:700}.stm-theme-row{gap:12px;margin-top:12px;display:flex}.stm-theme-btn{border:1px solid var(--uchi-line);background:var(--bg-surface);width:48px;height:48px;color:var(--text-tertiary);cursor:pointer;border-radius:12px;justify-content:center;align-items:center;display:flex}.stm-theme-btn:hover{border-color:var(--uchi-sage-mid)}.stm-theme-btn--active{color:var(--color-primary);background:var(--color-primary-ghost);border-color:var(--color-primary);box-shadow:0 8px 16px #15564e14}.stm-bg-row{gap:16px;margin-top:12px;display:flex}.stm-bg-swatch{cursor:pointer;background:0 0;border:none;flex-direction:column;align-items:center;gap:8px;padding:0;display:flex}.stm-bg-swatch__color{border:2px solid var(--uchi-line);border-radius:10px;width:64px;height:48px}.stm-bg-swatch--active .stm-bg-swatch__color{border-color:var(--color-primary)}.stm-bg-swatch__label{color:var(--text-tertiary);font-size:12px;font-weight:600}.stm-bg-swatch--active .stm-bg-swatch__label{color:var(--color-primary)}.stm-font-preview{background:var(--uchi-row-alt);border:1px solid var(--uchi-line);border-radius:12px;margin-bottom:16px;padding:12px 16px}.stm-font-preview__label{color:var(--text-muted);margin-bottom:4px;font-size:12px;font-weight:500;display:block}.stm-font-preview__text{color:var(--text-primary-alt);font-size:16px;font-weight:500}.stm-radio-group{flex-direction:column;gap:8px;display:flex}.stm-radio{color:var(--text-primary-alt);cursor:pointer;background:var(--bg-surface);border:1px solid var(--uchi-line);border-radius:12px;align-items:center;gap:10px;padding:12px 14px;font-size:14px;font-weight:600;display:flex}.stm-radio input[type=radio]{display:none}.stm-radio__dot{border:2px solid var(--border-strong);border-radius:50%;flex-shrink:0;width:18px;height:18px;position:relative}.stm-radio--active .stm-radio__dot{border-color:var(--color-primary)}.stm-radio--active .stm-radio__dot:after{content:"";background:var(--color-primary);border-radius:50%;width:8px;height:8px;position:absolute;top:3px;left:3px}.stm-radio--active{border-color:var(--color-primary);background:var(--color-primary-ghost)}.stm-radio--card .stm-radio__preview{color:var(--text-tertiary);margin-left:4px}.stm-radio__icon{width:32px;height:32px;color:var(--text-tertiary);flex-shrink:0;justify-content:center;align-items:center;font-size:16px;font-weight:700;display:flex}.stm-coming-soon{color:var(--text-muted);text-align:center;background:var(--color-primary-ghost);border-radius:12px;margin-top:20px;padding:12px;font-size:13px;font-weight:500}@media (width<=780px){.stm-overlay{align-items:stretch;padding:12px}.stm-modal{height:calc(100vh - 24px);display:block;overflow-y:auto}.stm-sidebar{border-right:0;border-bottom:1px solid var(--uchi-line);width:100%;padding:24px 18px 18px}.stm-sidebar__nav{margin-top:18px}.stm-content{padding:20px 18px 22px}.stm-section{padding:20px 18px}}@media (width<=560px){.stm-sidebar__item{min-height:48px}.stm-row{flex-direction:column;align-items:stretch;gap:10px}.stm-row__right{justify-content:space-between;width:100%}.stm-select,.stm-select-native,.stm-select-native select{width:100%;min-width:0}.stm-slider{width:100%}.pvm-grid{grid-template-columns:1fr}}.erm-modal{background:var(--bg-surface);border-radius:16px;width:100%;max-width:520px;padding:24px 28px}.erm-header{justify-content:space-between;align-items:flex-start;margin-bottom:20px;display:flex}.erm-header__title{color:var(--text-primary-alt);margin:0 0 4px;font-size:18px;font-weight:700}.erm-header__desc{color:var(--text-tertiary);margin:0;font-size:13px;font-weight:500}.erm-context{border:1px solid var(--border);border-radius:10px;flex-direction:column;gap:8px;margin-bottom:20px;padding:14px 18px;display:flex}.erm-context__row{align-items:center;gap:10px;display:flex}.erm-context__tag{min-width:42px;height:24px;color:var(--text-tertiary);background:var(--bg-surface-muted);border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;font-size:11px;font-weight:700;display:inline-flex}.erm-context__tag--ja{color:var(--text-muted)}.erm-context__text{color:var(--text-primary-alt);font-size:15px;font-weight:600}.erm-label{color:var(--text-primary-alt);margin:0 0 12px;font-size:15px;font-weight:700}.erm-label__hint{color:var(--text-muted);margin-left:4px;font-size:13px;font-weight:500}.erm-categories{gap:10px;margin-bottom:20px;display:flex}.erm-category{border:1px solid var(--border);background:var(--bg-surface);cursor:pointer;text-align:left;border-radius:10px;flex:1;align-items:flex-start;gap:8px;padding:12px;display:flex}.erm-category:hover{border-color:var(--border-strong)}.erm-category--active{background:#f0f5ff;border-color:#3b82f6}.erm-category__check{border:2px solid var(--border-strong);border-radius:4px;flex-shrink:0;width:16px;height:16px;margin-top:2px;position:relative}.erm-category__check--on{background:#3b82f6;border-color:#3b82f6}.erm-category__check--on:after{content:"";border:2px solid #fff;border-width:0 2px 2px 0;width:4px;height:7px;position:absolute;top:1px;left:4px;transform:rotate(45deg)}.erm-category__label{color:var(--text-primary-alt);font-size:13px;font-weight:700;display:block}.erm-category__hint{color:var(--text-muted);margin-top:2px;font-size:11px;font-weight:500;display:block}.erm-textarea{border:1px solid var(--border);width:100%;color:var(--text-primary-alt);resize:vertical;box-sizing:border-box;border-radius:10px;margin-bottom:20px;padding:12px 14px;font-family:inherit;font-size:14px;font-weight:500}.erm-textarea::placeholder{color:var(--text-muted)}.erm-textarea:focus{border-color:#3b82f6;outline:none}.erm-actions{justify-content:flex-end;gap:10px;display:flex}.erm-btn{cursor:pointer;border-radius:8px;padding:10px 24px;font-family:inherit;font-size:14px;font-weight:600}.erm-btn--cancel{background:var(--bg-surface);border:1px solid var(--border);color:var(--text-primary-alt)}.erm-btn--cancel:hover{background:var(--bg-surface-hover)}.erm-btn--submit{color:#fff;background:#3b82f6;border:none}.erm-btn--submit:hover{background:#2563eb}.erm-btn--submit:disabled{opacity:.5;cursor:not-allowed}.stm-placeholder{justify-content:center;align-items:center;min-height:300px;display:flex}.stm-placeholder__text{color:var(--text-muted);font-size:15px;font-weight:500}.gp-resume-overlay{background:#1a1a2e;justify-content:center;align-items:center;min-height:100vh;display:flex}.gp-resume-dialog{text-align:center;background:#fff;border-radius:16px;max-width:380px;padding:32px}.gp-resume-dialog__title{color:var(--text-primary-alt);margin-bottom:8px;font-size:17px;font-weight:700}.gp-resume-dialog__desc{color:var(--text-tertiary);margin-bottom:24px;font-size:14px;font-weight:500}.gp-resume-dialog__actions{gap:12px;display:flex}.gp-resume-dialog__btn{cursor:pointer;border-radius:8px;flex:1;padding:10px 0;font-size:14px;font-weight:600}.gp-resume-dialog__btn--secondary{border:1px solid var(--border);color:var(--text-primary-alt);background:#fff}.gp-resume-dialog__btn--primary{color:#fff;background:#3b82f6;border:none}.gp-pause-overlay{z-index:2000;background:#0f172a8c;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.gp-pause-dialog{background:var(--bg-surface);border-radius:20px;width:100%;max-width:480px;padding:24px 28px;box-shadow:0 20px 50px #00000040,0 8px 16px #0000001a}.gp-pause-dialog__header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;margin-bottom:18px;padding-bottom:14px;display:flex}.gp-pause-dialog__title{color:var(--text-primary);margin:0;font-size:18px;font-weight:700}.gp-pause-dialog__close{width:32px;height:32px;color:var(--text-tertiary);cursor:pointer;background:0 0;border:none;border-radius:8px;font-size:22px}.gp-pause-dialog__close:hover{background:var(--bg-surface-hover)}.gp-pause-dialog__desc{color:var(--text-secondary);margin:0 0 22px;font-size:14px;font-weight:500;line-height:1.6}.gp-pause-dialog__actions{justify-content:flex-end;gap:10px;display:flex}.gp-pause-dialog__actions--split{justify-content:flex-end}.gp-pause-dialog__btn{font:inherit;cursor:pointer;border:none;border-radius:10px;padding:10px 24px;font-size:14px;font-weight:600;transition:background .15s}.gp-pause-dialog__btn--primary{background:var(--color-primary);color:#fff}.gp-pause-dialog__btn--primary:hover{background:var(--color-primary-hover)}.gp-pause-dialog__btn--secondary{background:var(--bg-surface);border:1px solid var(--border);color:var(--text-secondary)}.gp-pause-dialog__btn--secondary:hover{background:var(--bg-surface-hover);border-color:var(--border-strong)}.app-layout{--font-jp:var(--font-sans);--font-data:var(--font-sans);--font-en:var(--font-serif);--font-title:var(--font-serif);--app-font:var(--font-sans);--bg-page:var(--uchi-bg);--bg-sidebar:var(--uchi-bg);--bg-surface:var(--uchi-paper);--bg-surface-hover:var(--uchi-primary-soft);--bg-surface-muted:var(--uchi-row-alt);--text-primary:var(--uchi-ink);--text-primary-alt:var(--uchi-primary);--text-secondary:var(--uchi-ink-2);--text-tertiary:var(--uchi-ink-3);--text-muted:var(--uchi-ink-4);--border:var(--uchi-line);--border-strong:#d4cfc4;--icon-color:var(--uchi-ink-2);--color-primary:var(--uchi-primary);--color-primary-hover:var(--uchi-primary-hover);--color-primary-active:var(--uchi-primary-active);--color-primary-ghost:var(--uchi-primary-soft);--color-secondary:var(--uchi-sage);--color-secondary-hover:var(--uchi-sage-mid);--color-err:var(--uchi-rose);--color-accent:var(--uchi-cream);--color-accent-soft:var(--uchi-cream-soft);--color-divider:var(--uchi-line);--color-border-input:var(--uchi-line);--course-hero-from:var(--uchi-hero-from);--course-hero-to:var(--uchi-hero-mid);--course-active-pale:var(--uchi-primary-soft);--book-card-green:#dce4d0;--book-card-peach:#f2ddd4;--book-card-sand:var(--uchi-cream-soft);--book-card-mint:var(--uchi-primary-soft);--book-card-cream:var(--uchi-cream);--course-cover-shadow:#2e352829;--course-hero-divider:#1f4e4729;--course-hero-watermark:#1f4e470d;background:var(--bg-page);flex-direction:row;width:100vw;height:100vh;display:flex;overflow:hidden}.app-layout__main{--app-sidebar-offset:220px;background:var(--bg-page);overscroll-behavior:contain;min-width:0;min-height:0;box-shadow:none;scrollbar-width:thin;scrollbar-color:#00000014 transparent;border:none;border-radius:0;flex:1;margin:0;overflow:hidden auto}.app-layout__main::-webkit-scrollbar{width:6px}.app-layout__main::-webkit-scrollbar-track{background:0 0}.app-layout__main::-webkit-scrollbar-thumb{background:#00000014;border-radius:999px}.app-layout__main::-webkit-scrollbar-thumb:hover{background:#00000026}.app-layout__main--wide{--app-sidebar-offset:68px;margin-left:0}.page-topbar{z-index:20;background:var(--bg-page);border-bottom:1px solid var(--border);align-items:center;gap:16px;height:60px;padding:0 28px;display:flex;position:sticky;top:0}.page-topbar__left{flex:1;align-items:center;gap:12px;min-width:0;display:flex}.page-topbar__right{flex-shrink:0;align-items:center;gap:14px;display:flex}.page-topbar__toggle-btn{border:1px solid var(--border);width:30px;height:30px;color:var(--icon-color);cursor:pointer;background:0 0;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;transition:background .15s,color .15s;display:inline-flex}.page-topbar__toggle-btn:hover{background:var(--color-primary-ghost);color:var(--color-primary)}.page-topbar__title{color:var(--text-primary);letter-spacing:0;text-overflow:ellipsis;white-space:nowrap;margin:0;font-size:17px;font-weight:700;line-height:1.2;overflow:hidden}.page-topbar__breadcrumb{letter-spacing:0;align-items:center;gap:8px;min-width:0;font-size:17px;font-weight:700;display:flex;overflow:hidden}.page-topbar__breadcrumb-link{color:var(--text-muted);font-size:inherit;font-weight:inherit;letter-spacing:inherit;cursor:pointer;white-space:nowrap;background:0 0;border:none;padding:0;font-family:inherit;transition:color .15s}.page-topbar__breadcrumb-link:hover{color:var(--text-primary)}.page-topbar__breadcrumb-sep{color:var(--border-strong);flex-shrink:0;font-weight:500}.page-topbar__breadcrumb-current{color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.page-topbar__action-btn{min-height:30px;color:var(--icon-color);cursor:pointer;background:0 0;border:none;border-radius:999px;justify-content:center;align-items:center;gap:6px;padding:6px 10px;font-family:inherit;font-size:12.5px;font-weight:500;transition:background .15s,color .15s;display:inline-flex}.page-topbar__action-btn:hover{color:var(--color-primary)}.page-topbar--course-detail{background:var(--uchi-paper)}.page-topbar--course-detail .page-topbar__toggle-btn{display:none}.page-topbar--course-detail .page-topbar__breadcrumb{gap:10px;font-size:12.5px;font-weight:600}.page-topbar--course-detail .page-topbar__breadcrumb-link{color:var(--uchi-ink-2);font-weight:600}.page-topbar--course-detail .page-topbar__breadcrumb-current{color:var(--uchi-ink);font-weight:700}.page-topbar__profile{background:var(--color-primary);width:32px;height:32px;color:var(--course-on-primary);cursor:pointer;border:none;border-radius:999px;justify-content:center;align-items:center;transition:background .15s,transform .15s;display:inline-flex}.page-topbar__profile-initial{font-family:var(--font-serif);font-size:12px;font-weight:700;line-height:1}.page-topbar__profile:hover{background:var(--color-primary-hover);color:var(--course-on-primary);transform:translateY(-1px)}.page-topbar__notif-anchor{position:relative}.page-topbar__notif-dot{background:var(--color-err);border:1px solid var(--bg-page);color:#fff;pointer-events:none;border-radius:999px;justify-content:center;align-items:center;width:7px;min-width:7px;height:7px;padding:0;font-size:0;font-weight:700;line-height:1;display:inline-flex;position:absolute;top:4px;right:4px}.notif-panel{z-index:50;border:1px solid var(--border);background:var(--bg-surface);width:340px;max-height:420px;font-family:var(--app-font,var(--font-jp));border-radius:12px;position:absolute;top:calc(100% + 8px);right:0;overflow:hidden;box-shadow:0 8px 24px #2e352814}.notif-panel__header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:14px 16px;display:flex}.notif-panel__title{color:var(--text-primary-alt);align-items:center;gap:8px;font-size:14px;font-weight:700;display:flex}.notif-panel__badge{background:var(--color-err);color:#fff;font-feature-settings:"tnum";border-radius:999px;justify-content:center;align-items:center;min-width:18px;height:18px;padding:0 5px;font-size:11px;font-weight:700;display:inline-flex}.notif-panel__mark-read{color:var(--color-secondary);cursor:pointer;background:0 0;border:none;padding:0;font-family:inherit;font-size:12px;font-weight:600;transition:color .15s}.notif-panel__mark-read:hover{color:var(--color-secondary-hover)}.notif-panel__mark-read:disabled{color:var(--text-muted);cursor:default}.notif-panel__list{max-height:360px;overflow-y:auto}.notif-panel__item{border:none;border-bottom:1px solid var(--bg-surface-muted);text-align:left;cursor:pointer;background:0 0;gap:12px;width:100%;padding:14px 16px;font-family:inherit;transition:background .15s;display:flex}.notif-panel__item:last-child{border-bottom:none}.notif-panel__item:hover,.notif-panel__item--unread{background:var(--bg-surface-hover)}.notif-panel__icon{border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.notif-panel__icon--blue{background:var(--color-primary-ghost);color:var(--color-primary)}.notif-panel__icon--green{background:var(--color-ok-bg);color:var(--color-ok)}.notif-panel__icon--amber{background:var(--color-warn-bg);color:var(--color-warn)}.notif-panel__icon--purple{background:var(--color-primary-ghost);color:var(--color-primary)}.notif-panel__body{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.notif-panel__item-title{color:var(--text-primary-alt);font-size:13px;font-weight:700}.notif-panel__item-body{color:var(--text-tertiary);font-size:12px;font-weight:500;line-height:1.4}.notif-panel__item-time{color:var(--text-muted);margin-top:2px;font-size:11px;font-weight:500}.notif-panel__state{color:var(--text-tertiary);text-align:center;padding:28px 18px;font-size:12px;font-weight:600}.notif-panel__state--error{color:var(--color-err)}.page-topbar__profile-anchor{position:relative}.profile-panel{z-index:50;border:1px solid var(--border);background:var(--bg-surface);width:240px;font-family:var(--app-font,var(--font-jp));border-radius:12px;position:absolute;top:calc(100% + 8px);right:0;overflow:hidden;box-shadow:0 8px 24px #2e352814}.profile-panel__user{align-items:center;gap:12px;padding:16px;display:flex}.profile-panel__avatar{color:var(--text-muted);flex-shrink:0;line-height:0}.profile-panel__info{flex-direction:column;gap:2px;min-width:0;display:flex}.profile-panel__name{color:var(--text-primary-alt);font-size:14px;font-weight:700}.profile-panel__plan{color:var(--text-muted);font-size:12px;font-weight:500}.profile-panel__divider{background:var(--bg-surface-muted);height:1px}.profile-panel__menu{padding:6px}.profile-panel__item{width:100%;height:38px;color:var(--icon-color);cursor:pointer;text-align:left;background:0 0;border:none;border-radius:8px;align-items:center;gap:10px;padding:0 12px;font-family:inherit;font-size:13px;font-weight:600;transition:background .15s;display:flex}.profile-panel__item:hover{background:var(--bg-surface-hover)}.profile-panel__item--danger{color:var(--color-err)}.profile-panel__item--danger:hover{background:var(--color-err-bg)}@media (width<=767px){.page-topbar{gap:8px;padding:0 16px}.page-topbar__action-btn span{display:none}.page-topbar__action-btn{width:32px;padding:0}}.app-sidebar{border-right:1px solid var(--border);background:var(--bg-sidebar,var(--bg-surface));flex-direction:column;flex-shrink:0;width:220px;height:100vh;padding:0;transition:width .25s;display:flex;overflow:hidden}.app-sidebar--collapsed{width:68px}.app-sidebar__brand{min-height:74px;color:inherit;border-bottom:1px solid #0000;flex-shrink:0;align-items:center;gap:10px;padding:18px;text-decoration:none;display:flex}.app-sidebar__brand-mark{background:var(--color-primary);width:38px;height:38px;color:var(--course-on-primary);font-family:var(--font-serif);border:none;border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;font-size:17px;font-weight:700;display:inline-flex}.app-sidebar__brand-copy{white-space:nowrap;flex-direction:column;gap:1px;min-width:0;display:flex;overflow:hidden}.app-sidebar__brand-copy strong{color:var(--text-primary);font-size:15px;font-weight:700;line-height:1.1}.app-sidebar__brand-copy span{color:var(--text-muted);text-overflow:ellipsis;font-size:10px;font-weight:500;overflow:hidden}.app-sidebar--collapsed .app-sidebar__brand{justify-content:center;padding:0}.app-sidebar--collapsed .app-sidebar__brand-copy{display:none}.app-sidebar__surface{min-height:0;box-shadow:none;background:0 0;border:none;border-radius:0;flex-direction:column;flex:1;padding:4px 12px 16px;display:flex}.app-sidebar--collapsed .app-sidebar__surface{padding:12px 8px}.app-sidebar--collapsed .app-sidebar__tools,.app-sidebar--collapsed .app-sidebar__group-title{display:none}.app-sidebar--collapsed .app-sidebar__item{justify-content:center;width:52px;height:40px;margin:0 auto;padding:0}.app-sidebar--collapsed .app-sidebar__item-label,.app-sidebar--collapsed .app-sidebar__empty{display:none}.app-sidebar__upgrade{flex-shrink:0;margin-top:auto;padding-top:14px}.app-sidebar__upgrade-btn{background:var(--color-primary);width:100%;min-height:68px;color:var(--course-on-primary);cursor:pointer;border:none;border-radius:12px;justify-content:flex-start;align-items:center;gap:6px;padding:14px 16px;font-family:inherit;font-size:13px;font-weight:700;transition:opacity .15s;display:flex}.app-sidebar__upgrade-copy{flex-direction:column;align-items:flex-start;gap:4px;min-width:0;display:flex}.app-sidebar__upgrade-copy strong{color:inherit;font-size:13px;font-weight:700;line-height:1}.app-sidebar__upgrade-copy small{color:inherit;opacity:.85;font-size:10.5px;font-weight:500;line-height:1.2}.app-sidebar__upgrade-btn:hover{opacity:.9}.app-sidebar--collapsed .app-sidebar__upgrade-copy{display:none}.app-sidebar--collapsed .app-sidebar__upgrade-btn{width:44px;height:44px;min-height:44px;margin:0 auto;padding:0}.app-sidebar__footer{border-top:1px solid var(--bg-surface-muted);flex-direction:column;flex-shrink:0;gap:2px;padding:12px 16px 16px;display:flex}.app-sidebar--collapsed .app-sidebar__footer{align-items:center;padding:12px 8px 14px}.app-sidebar__footer-user{align-items:center;gap:10px;min-height:44px;padding:6px 10px;display:flex}.app-sidebar--collapsed .app-sidebar__footer-user{justify-content:center;padding:6px 0}.app-sidebar__footer-avatar{background:var(--bg-surface-muted);width:32px;height:32px;color:var(--text-tertiary);border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;font-size:13px;font-weight:800;display:inline-flex}.app-sidebar__footer-username{color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;font-size:13px;font-weight:700;overflow:hidden}.app-sidebar--collapsed .app-sidebar__footer-username{display:none}.app-sidebar__tools{margin-bottom:16px}.app-sidebar__search{border:1px solid var(--border);background:var(--bg-surface-hover);min-height:40px;color:var(--text-muted);border-radius:8px;align-items:center;gap:8px;padding:0 12px;display:flex}.app-sidebar__search input{width:100%;color:var(--text-primary);background:0 0;border:0;outline:none;font-size:13px}.app-sidebar__search input::placeholder{color:var(--text-muted)}.app-sidebar__filters{margin-top:12px}.app-sidebar__filters-label{color:var(--text-muted);align-items:center;gap:6px;margin-bottom:8px;font-size:12px;font-weight:600;display:inline-flex}.app-sidebar__filters-list{flex-wrap:wrap;gap:6px;display:flex}.app-sidebar__filter{border:1px solid var(--border);background:var(--bg-surface);min-height:28px;color:var(--text-tertiary);cursor:pointer;border-radius:999px;justify-content:center;align-items:center;padding:0 10px;font-size:12px;font-weight:600;transition:background .15s,color .15s;display:inline-flex}.app-sidebar__filter:hover{background:var(--bg-surface-hover)}.app-sidebar__filter--active{border-color:var(--color-primary);background:var(--color-primary);color:var(--course-on-primary)}.app-sidebar__nav{flex-direction:column;flex:1;gap:14px;min-height:0;display:flex;overflow:auto}.app-sidebar__group-title{color:var(--text-muted);letter-spacing:.4px;text-transform:none;margin-bottom:4px;padding:6px 10px 4px;font-size:10.5px;font-weight:600;display:inline-block}.app-sidebar__menu{flex-direction:column;gap:2px;list-style:none;display:flex}.app-sidebar__item{width:100%;min-height:34px;color:var(--icon-color);text-align:left;cursor:pointer;background:0 0;border:1px solid #0000;border-radius:8px;align-items:center;gap:10px;padding:8px 10px;transition:background .15s;display:flex}.app-sidebar__item:hover{background:var(--bg-surface-hover)}.app-sidebar__item--active{background:var(--color-primary-ghost);color:var(--color-primary);border-color:#0000;font-weight:600}.app-sidebar__item-icon{flex-shrink:0;justify-content:center;align-items:center;width:18px;display:inline-flex}.app-sidebar__item-label{min-width:0;font-size:13px;font-weight:600}.app-sidebar__empty{border:1px dashed var(--border);color:var(--text-muted);border-radius:10px;flex-direction:column;gap:4px;padding:14px;font-size:12px;display:flex}.app-sidebar__empty strong{color:var(--icon-color);font-size:13px}.app-placeholder{background:var(--bg-page);min-height:100%;color:var(--text-primary);padding:24px 28px 80px}.app-placeholder__title{color:var(--text-primary);margin:0 0 8px;font-size:28px;font-weight:800}.app-placeholder__text{color:var(--text-tertiary);font-size:15px;font-weight:600}.app-placeholder__button{border:1px solid var(--border);background:var(--bg-surface);color:var(--text-primary);cursor:pointer;border-radius:8px;padding:10px 18px;font-weight:800}.app-placeholder__button:hover{border-color:var(--color-primary);background:var(--color-primary-ghost);color:var(--color-primary)}@media (width<=767px){.app-sidebar{display:none}.app-layout__main{--app-sidebar-offset:0px;box-shadow:none;border:0;border-radius:0;margin:0}}.course-library-page{--course-page-bg:var(--bg-page);--course-page-surface:var(--bg-surface);--course-page-border:var(--border);--course-page-ink:var(--text-primary);--course-page-muted:var(--text-secondary);--course-page-accent:var(--color-primary);--course-page-green:var(--color-primary);--course-page-shadow:0 1px 3px var(--course-cover-shadow);background:var(--course-page-bg);min-height:100%;color:var(--course-page-ink);font-family:var(--app-font,var(--font-jp));padding:24px 28px 80px}.course-library-page__grid{display:grid}.course-library-page__toolbar{align-items:center;gap:10px;margin-bottom:16px;display:flex}.course-library-page__search{flex:1;max-width:360px;position:relative}.course-library-page__search-icon{color:var(--course-page-muted);pointer-events:none;position:absolute;top:50%;left:11px;transform:translateY(-50%)}.course-library-page__search-input{border:1px solid var(--course-page-border);background:var(--course-page-surface);width:100%;height:36px;color:var(--course-page-ink);border-radius:8px;outline:none;padding:0 12px 0 32px;font-family:inherit;font-size:13px;font-weight:600;transition:border-color .15s}.course-library-page__search-input::placeholder{color:var(--course-page-muted)}.course-library-page__search-input:focus{border-color:var(--course-page-accent)}.course-library-page__sort-button{border:1px solid var(--course-page-border);background:var(--course-page-surface);min-height:36px;color:var(--course-page-ink);cursor:pointer;border-radius:8px;align-items:center;gap:6px;padding:0 12px;font-family:inherit;font-size:13px;font-weight:700;transition:background .15s;display:inline-flex}.course-library-page__sort-button:hover{background:var(--bg-surface-muted)}.course-library-page__tags{scrollbar-width:none;gap:8px;margin-bottom:16px;display:flex;overflow-x:auto}.course-library-page__tags::-webkit-scrollbar{display:none}.course-library-page__tag{border:1px solid var(--course-page-border);background:var(--course-page-surface);min-height:34px;color:var(--course-page-muted);white-space:nowrap;cursor:pointer;border-radius:8px;justify-content:center;align-items:center;padding:0 16px;font-family:inherit;font-size:13px;font-weight:700;transition:background .15s,color .15s,border-color .15s;display:inline-flex}.course-library-page__tag:hover{background:var(--bg-surface-muted)}.course-library-page__tag--active{border-color:var(--course-page-green);background:var(--course-page-green);color:var(--course-on-primary)}.course-library-page__tag--active:hover{background:var(--color-primary-hover)}.course-library-page__grid{grid-template-columns:repeat(6,minmax(0,1fr));gap:12px}.course-library-card{border:1px solid var(--border);background:var(--bg-surface);box-shadow:none;text-align:left;cursor:pointer;border-radius:12px;padding:0;transition:background .15s,border-color .15s,transform .15s;position:relative;overflow:hidden}.course-library-card:focus-visible{outline:2px solid var(--course-page-accent);outline-offset:2px}.course-library-card:hover{border-color:var(--border-strong);transform:translateY(-1px)}.course-library-card__cover{background:linear-gradient(135deg, var(--uchi-hero-mid) 0%, var(--uchi-hero-to) 100%);width:100%;height:112px;position:relative;overflow:hidden}.course-library-card__cover-img{object-fit:cover;opacity:.92;width:100%;height:100%;display:block;position:absolute;inset:0}.course-library-card__tag{max-width:calc(100% - 24px);min-height:22px;color:var(--uchi-ink-2);text-overflow:ellipsis;white-space:nowrap;background:#ffffffb8;border:1px solid #fffc;border-radius:999px;padding:3px 10px;font-size:10.5px;font-weight:600;line-height:1.35;display:inline-block;position:absolute;top:10px;left:12px;overflow:hidden}.course-library-card__motif{opacity:.52;pointer-events:none;width:94px;height:72px;position:absolute;bottom:-12px;right:-10px}.course-library-card__motif span{background:var(--uchi-sage-mid);transform-origin:bottom;border-radius:50%;width:9px;height:30px;position:absolute}.course-library-card__motif span:first-child{bottom:6px;right:48px;transform:rotate(-26deg)}.course-library-card__motif span:nth-child(2){bottom:17px;right:32px;transform:rotate(24deg)}.course-library-card__motif span:nth-child(3){bottom:2px;right:18px;transform:rotate(45deg)}.course-library-card__body{padding:14px}.course-library-card__title{color:var(--text-primary);letter-spacing:0;text-overflow:ellipsis;white-space:nowrap;margin:0 0 4px;font-size:14.5px;font-weight:700;line-height:1.35;overflow:hidden}.course-library-card__description{color:var(--text-tertiary);text-overflow:ellipsis;white-space:nowrap;margin:0;font-size:11.5px;font-weight:500;line-height:1.45;overflow:hidden}.course-library-card__progress-row{grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:9px;margin-top:12px;display:grid}.course-library-card__progress{background:var(--color-divider);border-radius:999px;height:5px;overflow:hidden}.course-library-card__progress span{border-radius:inherit;background:var(--uchi-sage-mid);height:100%;display:block}.course-library-card__progress-text{color:var(--text-tertiary);font-variant-numeric:tabular-nums;font-size:10.5px;font-weight:600}@media (width<=1099px){.course-library-page__grid{grid-template-columns:repeat(4,minmax(0,1fr))}}@media (width<=899px){.course-library-page__grid{grid-template-columns:repeat(3,minmax(0,1fr))}}@media (width<=767px){.course-library-page{padding:16px}.course-library-page__grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.course-library-card{padding:8px}}@media (width<=479px){.course-library-page__grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.course-library-card{padding:6px}}.home-page{background:var(--uchi-bg);min-height:100%;color:var(--uchi-ink);font-family:var(--app-font,var(--font-jp));padding:22px 26px 40px}.home-dashboard{grid-template-columns:minmax(0,1fr) 320px;align-items:start;gap:20px;display:grid}.home-dashboard__main,.home-dashboard__side{flex-direction:column;gap:14px;min-width:0;display:flex}.home-hero{border:1px solid var(--uchi-line);background:var(--uchi-paper);border-radius:14px;grid-template-columns:minmax(0,1fr) 130px;min-height:230px;display:grid;position:relative;overflow:hidden}.home-hero--empty{grid-template-columns:minmax(0,1fr)}.home-hero__scene{background:linear-gradient(120deg, var(--uchi-hero-from) 0%, var(--uchi-hero-mid) 55%, var(--uchi-hero-to) 100%);position:absolute;inset:0 130px 0 0;overflow:hidden}.home-hero--empty .home-hero__scene{inset:0}.home-hero__content{z-index:1;flex-direction:column;justify-content:space-between;min-height:230px;padding:22px 26px;display:flex;position:relative}.home-hero__tag{color:var(--uchi-ink-2);background:#ffffffd9;border-radius:999px;align-self:flex-start;padding:5px 12px;font-size:11px;font-weight:600;line-height:1.35}.home-hero__copy{max-width:460px}.home-hero__copy h2{color:var(--uchi-ink);margin:0;font-size:30px;font-weight:700;line-height:1.15}.home-hero__copy p{color:var(--uchi-ink-2);margin:8px 0 0;font-size:12.5px;font-weight:500}.home-hero__progress-row{max-width:360px;color:var(--uchi-ink-2);align-items:center;gap:10px;margin-top:12px;font-size:11.5px;font-weight:500;display:flex}.home-hero__progress{background:#ffffffb3;border-radius:999px;flex:1;height:6px;overflow:hidden}.home-hero__progress span{border-radius:inherit;background:var(--uchi-sage-mid);height:100%;transition:width .4s;display:block}.home-hero__btn{background:var(--uchi-primary);color:var(--course-on-primary);cursor:pointer;border:0;border-radius:999px;align-items:center;gap:8px;margin-top:16px;padding:10px 22px;font-family:inherit;font-size:13px;font-weight:600;display:inline-flex}.home-hero__btn:hover{background:var(--uchi-primary-hover)}.home-hero__btn-icon{background:#ffffff38;border-radius:50%;justify-content:center;align-items:center;width:16px;height:16px;display:inline-flex}.home-hero__rail{z-index:1;border-left:1px solid var(--uchi-line);background:var(--uchi-paper);flex-direction:column;justify-content:space-around;min-width:0;padding:18px 10px;display:flex;position:relative}.home-hero-mini{border-bottom:1px solid var(--uchi-line);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:6px;min-height:50px;display:flex}.home-hero-mini:last-child{border-bottom:0}.home-hero-mini span{color:var(--uchi-sage-mid);font-size:11.5px;font-weight:600}.home-hero-mini strong{color:var(--uchi-ink);font-size:14px;font-weight:700}.home-hero-mini--rose span{color:var(--uchi-rose)}.home-hero-mini--deep span{color:var(--uchi-sage)}.home-hero__window,.home-hero__vase,.home-hero__cup,.home-hero__table-shadow,.home-hero__branch{pointer-events:none;position:absolute}.home-hero__window{border:1px solid var(--uchi-hero-window-line);background:linear-gradient(90deg, transparent 49%, var(--uchi-hero-window-line) 50%, transparent 51%), linear-gradient(0deg, transparent 49%, var(--uchi-hero-window-line) 50%, transparent 51%), var(--uchi-hero-window-fill);border-radius:2px;width:120px;height:130px;top:32px;right:58px}.home-hero__vase{border:1px solid var(--uchi-hero-vessel-border);background:var(--uchi-hero-ceramic);border-radius:11px 11px 21px 21px;width:50px;height:94px;bottom:52px;right:173px}.home-hero__vase:before,.home-hero__vase:after{background:var(--uchi-hero-stem);content:"";transform-origin:bottom;width:1.5px;height:96px;position:absolute;bottom:86px;left:22px}.home-hero__vase:before{transform:rotate(-13deg)}.home-hero__vase:after{transform:rotate(9deg)}.home-hero__cup{border:1px solid var(--uchi-hero-vessel-border);background:var(--uchi-hero-cup);border-radius:8px 8px 24px 24px;width:72px;height:42px;bottom:53px;right:70px}.home-hero__cup:before{background:var(--uchi-sage);width:58px;height:10px;box-shadow:inset 0 -3px 0 var(--uchi-sage-mid);content:"";border-radius:50%;position:absolute;top:-4px;left:7px}.home-hero__cup:after{border:2px solid var(--uchi-hero-vessel-border);content:"";border-left:0;border-radius:0 14px 14px 0;width:18px;height:22px;position:absolute;top:10px;right:-12px}.home-hero__table-shadow{background:var(--uchi-hero-table-shadow);border-radius:50%;width:180px;height:12px;bottom:42px;right:45px}.home-hero__branch{opacity:.42}.home-hero__branch:before,.home-hero__branch:after{background:var(--uchi-hero-branch-leaf);content:"";border-radius:50%;position:absolute}.home-hero__branch--left{border-left:1px solid var(--uchi-hero-branch-stem);width:78px;height:140px;top:14px;left:28px;transform:rotate(-18deg)}.home-hero__branch--left:before{width:10px;height:34px;top:20px;left:-10px;transform:rotate(-40deg)}.home-hero__branch--left:after{width:10px;height:36px;top:58px;left:8px;transform:rotate(-20deg)}.home-hero__branch--right{border-left:1px solid var(--uchi-hero-branch-stem);width:60px;height:105px;bottom:-8px;right:10px;transform:rotate(35deg)}.home-hero__branch--right:before{width:9px;height:32px;top:22px;left:-11px;transform:rotate(-28deg)}.home-hero__branch--right:after{width:9px;height:30px;top:50px;left:6px;transform:rotate(28deg)}.home-stat-row{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;display:grid}.home-stat-card{border:1px solid var(--uchi-line);background:var(--uchi-paper);border-radius:12px;align-items:center;gap:14px;min-height:112px;padding:14px 18px;display:flex}.home-stat-card__icon{border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:inline-flex}.home-stat-card__icon--cream{background:var(--uchi-cream-soft);color:var(--uchi-sage-mid)}.home-stat-card__icon--sage{color:#6e7f63;background:#eae5d3}.home-stat-card__icon--rose{color:var(--uchi-rose-deep);background:#f0dcd7}.home-stat-card div{flex-direction:column;min-width:0;display:flex}.home-stat-card__label{color:var(--uchi-ink-3);font-size:11.5px;font-weight:500}.home-stat-card strong{color:var(--uchi-ink);font-variant-numeric:tabular-nums;margin-top:2px;font-size:26px;font-weight:700;line-height:1}.home-stat-card em{color:var(--uchi-ink-2);margin-left:3px;font-size:13px;font-style:normal;font-weight:500}.home-stat-card small{color:var(--uchi-ink-4);margin-top:4px;font-size:10.5px;font-weight:500}.home-courses{border:1px solid var(--uchi-line);background:var(--uchi-paper);border-radius:12px;padding:14px 18px;position:relative;overflow:hidden}.home-courses:after{content:"";opacity:.75;border-left:1px solid #7a897459;width:42px;height:48px;position:absolute;bottom:-2px;right:14px;transform:rotate(22deg)}.home-courses__header{align-items:center;gap:12px;margin-bottom:8px;display:flex}.home-courses__title{color:var(--uchi-ink);font-size:13.5px;font-weight:700}.home-courses__link{color:var(--uchi-primary);cursor:pointer;background:0 0;border:0;align-items:center;gap:3px;margin-left:auto;font-family:inherit;font-size:11.5px;font-weight:500;display:inline-flex}.home-courses__list{z-index:1;flex-direction:column;display:flex;position:relative}.home-course-row{border:0;border-top:1px solid var(--uchi-line);min-height:52px;color:inherit;cursor:pointer;text-align:left;background:0 0;grid-template-columns:18px 14px minmax(150px,190px) minmax(120px,1fr) 44px 14px;align-items:center;gap:12px;font-family:inherit;display:grid}.home-course-row:hover{background:var(--uchi-row-alt)}.home-course-row__num{color:var(--uchi-ink-4);font-variant-numeric:tabular-nums;font-size:12px;font-weight:500}.home-course-row__dot{border-radius:3px;width:12px;height:12px}.home-course-row__title{color:var(--uchi-ink);text-overflow:ellipsis;white-space:nowrap;font-size:13px;font-weight:600;overflow:hidden}.home-course-row__bar{background:var(--uchi-progress-track);border-radius:999px;height:5px;overflow:hidden}.home-course-row__bar span{border-radius:inherit;height:100%;transition:width .4s;display:block}.home-course-row__count{color:var(--uchi-ink-3);text-align:right;font-variant-numeric:tabular-nums;font-size:11.5px;font-weight:500}.home-course-row__arrow{color:var(--uchi-ink-4)}.home-courses__empty{color:var(--uchi-ink-3);text-align:center;padding:32px 20px;font-size:13px;font-weight:500}.home-courses__empty p{margin:0 0 14px}.home-courses__empty-btn{border:1px solid var(--uchi-line);background:var(--uchi-paper);min-height:34px;color:var(--uchi-ink);cursor:pointer;border-radius:999px;align-items:center;gap:6px;padding:0 14px;font-family:inherit;font-size:13px;font-weight:700;display:inline-flex}.home-heatmap{border:1px solid var(--uchi-line);background:var(--uchi-paper);border-radius:12px;flex-direction:column;gap:10px;padding:14px 16px 16px;display:flex}.home-heatmap__header{justify-content:space-between;align-items:center;gap:10px;display:flex}.home-heatmap__title{color:var(--uchi-ink);font-size:13px;font-weight:700}.home-heatmap__nav{align-items:center;gap:8px;display:flex}.home-heatmap__month{color:var(--uchi-ink);font-feature-settings:"tnum";white-space:nowrap;font-size:12px;font-weight:600}.home-heatmap__nav-btn{border:1px solid var(--uchi-line);background:var(--uchi-paper);width:22px;height:22px;color:var(--uchi-ink-3);cursor:pointer;border-radius:999px;justify-content:center;align-items:center;transition:color .12s,border-color .12s;display:inline-flex}.home-heatmap__nav-btn:hover:not(:disabled){color:var(--uchi-primary);border-color:var(--uchi-primary);background:var(--uchi-primary-soft)}.home-heatmap__nav-btn:disabled{opacity:.25;cursor:not-allowed}.home-heatmap__grid{text-align:center;grid-template-columns:repeat(7,32px);justify-content:center;align-items:center;gap:8px;display:grid}.home-heatmap__wh{color:var(--uchi-ink-3);letter-spacing:0;padding:2px 0;font-size:10px;font-weight:600;line-height:18px}.home-heatmap__empty{width:32px;height:32px}.home-heatmap__cell{width:32px;height:32px;box-shadow:inset 0 0 0 1px color-mix(in srgb, var(--uchi-line) 54%, transparent);cursor:default;border-radius:6px;transition:transform .12s,box-shadow .12s;position:relative}.home-heatmap__cell:hover{box-shadow:inset 0 0 0 1px color-mix(in srgb, var(--uchi-primary) 34%, transparent), 0 4px 10px color-mix(in srgb, var(--uchi-ink) 8%, transparent);z-index:1;transform:scale(1.08)}.home-heatmap__cell--l0{background:var(--uchi-cream)}.home-heatmap__cell--l1{background:color-mix(in srgb, var(--uchi-sage) 34%, var(--uchi-paper))}.home-heatmap__cell--l2{background:color-mix(in srgb, var(--uchi-sage) 58%, var(--uchi-paper))}.home-heatmap__cell--l3{background:color-mix(in srgb, var(--uchi-sage-mid) 86%, var(--uchi-paper))}.home-heatmap__cell--today{outline:1.5px solid var(--uchi-sage-mid);outline-offset:2px}.home-heatmap__tooltip{z-index:10;background:var(--uchi-ink);color:var(--course-on-primary);white-space:nowrap;pointer-events:none;border-radius:6px;flex-direction:column;align-items:center;gap:2px;padding:6px 10px;animation:.1s ease-out hm-tip;display:flex;position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%)}.home-heatmap__tooltip:after{content:"";border:4px solid #0000;border-top-color:var(--uchi-ink);position:absolute;top:100%;left:50%;transform:translate(-50%)}.home-heatmap__tooltip-date{opacity:.65;font-size:10px;font-weight:700}.home-heatmap__tooltip-time{font-feature-settings:"tnum";font-size:12px;font-weight:700}@keyframes hm-tip{0%{opacity:0;transform:translate(-50%)translateY(3px)}to{opacity:1;transform:translate(-50%)translateY(0)}}.home-goal-card,.home-streak-card,.home-week-card{border:1px solid var(--uchi-line);background:var(--uchi-paper);border-radius:12px;padding:14px 16px}.home-goal-card__head{color:var(--uchi-ink);justify-content:space-between;align-items:center;font-size:13px;font-weight:700;display:flex}.home-goal-card__head strong{font-variant-numeric:tabular-nums;font-size:12px;font-weight:700}.home-goal-card__head small{color:var(--uchi-ink-3);font-size:11.5px;font-weight:500}.home-goal-card__bar{background:var(--uchi-progress-track);border-radius:999px;height:5px;margin-top:12px;overflow:hidden}.home-goal-card__bar span{border-radius:inherit;background:var(--uchi-sage);height:100%;transition:width .4s;display:block}.home-goal-card p{color:var(--uchi-ink-3);margin:10px 0 0;font-size:11px;font-weight:500}.home-streak-card h2,.home-week-card h2{color:var(--uchi-ink);margin:0 0 12px;font-size:13px;font-weight:700}.home-streak-card__grid{grid-template-columns:1fr 1fr;gap:10px;display:grid}.home-streak-card__tile{background:#eef1e9;border:1px solid #dfe4d6;border-radius:10px;min-height:84px;padding:10px 12px}.home-streak-card__tile--rose{background:#f6e4e0;border-color:#ecd2cd}.home-streak-card__tile span{color:var(--uchi-ink-2);font-size:10.5px;font-weight:500}.home-streak-card__tile--rose span{color:var(--uchi-rose-deep)}.home-streak-card__tile strong{color:var(--uchi-ink);font-variant-numeric:tabular-nums;margin-top:8px;font-size:30px;font-weight:700;line-height:1;display:block}.home-streak-card__tile small{color:var(--uchi-ink-2);margin-left:3px;font-size:12px;font-weight:500}.home-week-card__dots{text-align:center;grid-template-columns:repeat(7,minmax(0,1fr));gap:6px;display:grid}.home-week-card__day{flex-direction:column;align-items:center;gap:6px;min-width:0;display:flex}.home-week-card__day span{color:var(--uchi-ink-3);font-size:10.5px;font-weight:500}.home-week-card__dot{background:var(--uchi-cream);border-radius:50%;width:26px;height:26px}.home-week-card__dot--checked{background:#e5e8dd;justify-content:center;align-items:center;display:flex}.home-week-card__dot--checked:after{color:var(--uchi-sage-mid);content:"★";font-size:11px;line-height:1}.home-week-card__dot--today{border:1.5px solid var(--uchi-rose);background:0 0}.home-week-card__dot--today.home-week-card__dot--checked{border-color:var(--uchi-sage);background:#e5e8dd}@media (width<=1180px){.home-dashboard{grid-template-columns:minmax(0,1fr) 300px}.home-course-row{grid-template-columns:18px 14px minmax(130px,180px) minmax(100px,1fr) 42px 14px}}@media (width<=960px){.home-dashboard{grid-template-columns:minmax(0,1fr)}.home-dashboard__side{grid-template-columns:minmax(0,1fr);display:grid}}@media (width<=768px){.home-page{padding:16px 16px 40px}.home-hero,.home-hero--empty{grid-template-columns:minmax(0,1fr)}.home-hero__scene{inset:0}.home-hero__rail{display:none}.home-hero__copy h2{font-size:24px}.home-stat-row{grid-template-columns:1fr}.home-course-row{grid-template-columns:18px 14px minmax(0,1fr) 42px;gap:10px;padding:10px 0}.home-course-row__bar{grid-column:3/5}.home-course-row__arrow{display:none}}@media (width<=520px){.home-hero__window,.home-hero__vase,.home-hero__cup,.home-hero__table-shadow{opacity:.35}.home-courses__header{flex-direction:column;align-items:flex-start}.home-courses__link{margin-left:0}}@media (width<=380px){.home-heatmap__grid{grid-template-columns:repeat(7,28px);gap:6px}.home-heatmap__empty,.home-heatmap__cell{width:28px;height:28px}}.ll-page{--c-bg:var(--uchi-bg);--c-surface:var(--uchi-paper);--c-muted:var(--uchi-row-alt);--c-border:var(--uchi-line);--c-ink:var(--uchi-ink);--c-secondary:var(--uchi-ink-2);--c-tertiary:var(--uchi-ink-3);--c-accent:var(--uchi-primary);background:var(--c-bg);min-height:100%;color:var(--c-ink);font-family:var(--app-font,var(--font-jp));padding:26px 26px 40px}.ll-topbar-actions{align-items:center;gap:8px;display:flex}.ll-topbar-action{border:1px solid var(--uchi-line);background:var(--uchi-paper);min-height:32px;color:var(--uchi-ink-2);border-radius:999px;justify-content:center;align-items:center;gap:5px;padding:6px 12px;font-size:12px;font-weight:600;line-height:1;display:inline-flex}.ll-topbar-action:disabled{opacity:.72;cursor:not-allowed}.ll-topbar-action--icon{width:34px;padding:0}.ll-hero{border:1px solid var(--c-border);background:linear-gradient(120deg, var(--uchi-hero-from) 0%, var(--uchi-hero-mid) 60%, var(--uchi-hero-to) 100%);border-radius:16px;grid-template-columns:220px minmax(0,1fr) 260px;gap:24px;margin-bottom:28px;padding:22px;display:grid;position:relative;overflow:hidden}.ll-hero:after{opacity:.55;content:"";pointer-events:none;border:1px solid #1f4e471f;border-radius:50%;width:260px;height:200px;position:absolute;bottom:-34px;right:-14px}.ll-hero:before{border:1px solid color-mix(in srgb, var(--uchi-primary) 14%, transparent);content:"";pointer-events:none;border-radius:999px;width:86px;height:86px;position:absolute;bottom:26px;right:58px}.ll-hero__cover-card{z-index:1;border:1px solid color-mix(in srgb, var(--uchi-primary) 20%, transparent);background:linear-gradient(155deg, var(--uchi-primary) 0%, color-mix(in srgb, var(--uchi-primary) 74%, var(--uchi-sage) 26%) 100%);width:220px;height:260px;color:var(--uchi-cream-soft);border-radius:12px;flex-direction:column;flex-shrink:0;justify-content:space-between;padding:18px;display:flex;position:relative;overflow:hidden;box-shadow:0 18px 30px -12px #2e352866}.ll-hero__cover-card:after{border:1px solid color-mix(in srgb, var(--uchi-cream-soft) 20%, transparent);width:80px;height:80px;box-shadow:inset 0 0 0 16px color-mix(in srgb, var(--uchi-cream-soft) 6%, transparent);content:"";pointer-events:none;border-radius:999px;position:absolute;bottom:-15px;right:-15px}.ll-hero__cover-eyebrow,.ll-hero__cover-brand{color:color-mix(in srgb, var(--uchi-cream-soft) 68%, transparent);font-size:11px;font-weight:700;display:block}.ll-hero__cover-eyebrow{letter-spacing:1.5px}.ll-hero__cover-card strong{color:var(--uchi-cream-soft);margin-top:14px;font-size:19px;font-weight:800;line-height:1.26;display:block}.ll-hero__cover-subtitle{color:color-mix(in srgb, var(--uchi-cream-soft) 76%, transparent);margin-top:8px;font-size:11.5px;font-style:italic;font-weight:600;display:block}.ll-hero__main{z-index:1;flex-direction:column;justify-content:center;min-width:0;padding-top:4px;display:flex;position:relative}.ll-hero__tags{flex-wrap:wrap;gap:6px;margin-bottom:10px;display:flex}.ll-hero__tags span{border:1px solid color-mix(in srgb, var(--uchi-paper) 80%, transparent);background:color-mix(in srgb, var(--uchi-paper) 58%, transparent);min-height:24px;color:var(--uchi-ink-2);border-radius:999px;align-items:center;padding:3px 10px;font-size:10.5px;font-weight:700;display:inline-flex}.ll-hero__title{letter-spacing:0;color:var(--c-ink);margin:0 0 12px;font-size:28px;font-weight:700;line-height:1.2}.ll-hero__desc{max-width:560px;color:var(--c-secondary);margin:0;font-size:13px;font-weight:500;line-height:1.75}.ll-hero__meta{color:var(--c-secondary);font-feature-settings:"tnum";flex-wrap:wrap;align-items:center;gap:18px;margin-top:16px;font-size:11.5px;font-weight:600;display:flex}.ll-hero__side{z-index:1;flex-direction:column;align-self:flex-start;gap:10px;min-width:0;display:flex;position:relative}.ll-hero__progress{border:1px solid color-mix(in srgb, var(--uchi-paper) 90%, transparent);background:color-mix(in srgb, var(--uchi-paper) 72%, transparent);border-radius:12px;padding:16px}.ll-hero__progress-head{justify-content:space-between;align-items:baseline;gap:12px;margin-bottom:8px;display:flex}.ll-hero__progress-head span,.ll-hero__progress small{color:var(--uchi-ink-2);font-size:11px;font-weight:700}.ll-hero__progress-head strong{color:var(--uchi-primary);font-feature-settings:"tnum";font-size:16px;font-weight:800}.ll-hero__progress-track{background:color-mix(in srgb, var(--uchi-paper) 72%, transparent);border-radius:999px;height:6px;overflow:hidden}.ll-hero__progress-fill{background:var(--uchi-sage-mid);border-radius:999px;height:100%;transition:width .4s}.ll-hero__progress small{color:var(--uchi-ink-3);margin-top:6px;font-weight:600;display:block}.ll-hero__action{background:var(--c-accent);min-height:44px;color:var(--course-on-primary);cursor:pointer;border:none;border-radius:999px;justify-content:center;align-items:center;gap:8px;width:100%;padding:0 22px;font-family:inherit;font-size:13.5px;font-weight:700;transition:background .15s,transform .15s;display:inline-flex}.ll-hero__action:hover{background:var(--color-primary-hover);transform:translateY(-1px)}.ll-hero__action--outline{background:color-mix(in srgb, var(--uchi-paper) 72%, transparent);color:var(--c-ink);border:1px solid color-mix(in srgb, var(--uchi-paper) 90%, transparent)}.ll-hero__action--outline:hover{background:var(--uchi-paper);color:var(--c-accent)}.ll-hero__action:disabled{opacity:.6;cursor:not-allowed}.ll-outline{min-width:0}.ll-tabs{border-bottom:1px solid var(--c-border);align-items:center;gap:26px;display:flex}.ll-tab{color:var(--c-tertiary);cursor:pointer;background:0 0;border:0;border-bottom:2px solid #0000;margin:0 0 -1px;padding:12px 2px;font-family:inherit;font-size:13px;font-weight:700}.ll-tab--active{border-color:var(--uchi-primary);color:var(--c-ink)}.ll-tab:hover{color:var(--c-ink)}.ll-unit{align-items:baseline;gap:10px;margin:28px 0 14px;display:flex}.ll-unit__code{color:var(--c-tertiary);letter-spacing:1px;font-size:11px;font-weight:800}.ll-unit h2{color:var(--c-ink);margin:0;font-size:15px;font-weight:800}.ll-unit__line{background:var(--c-border);flex:1;height:1px;margin-left:8px}.ll-unit__range{color:var(--c-tertiary);font-feature-settings:"tnum";font-size:11px;font-weight:600}.ll-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;display:grid}.ll-card{border:1px solid var(--c-border);background:var(--c-surface);text-align:left;cursor:pointer;border-radius:12px;flex-direction:column;gap:0;min-height:166px;padding:0;font-family:inherit;transition:background .15s,border-color .15s,transform .15s;display:flex;position:relative;overflow:hidden}.ll-card:hover{border-color:color-mix(in srgb, var(--uchi-primary) 26%, var(--uchi-line));transform:translateY(-1px)}.ll-card[data-status=current]{border:2px solid var(--uchi-primary);box-shadow:0 8px 24px -18px #1f4e4759}.ll-card__head{justify-content:space-between;align-items:center;gap:12px;padding:12px 16px 0;display:flex}.ll-card__labels{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.ll-card__label{background:var(--c-muted);min-height:22px;color:var(--c-tertiary);letter-spacing:.5px;font-feature-settings:"tnum";border-radius:4px;align-items:center;padding:3px 8px;font-size:10px;font-weight:800;line-height:1.2;display:inline-flex}.ll-card__status{background:var(--uchi-tag-sage-bg);min-height:22px;color:var(--uchi-primary);border-radius:999px;align-items:center;padding:3px 8px;font-size:10px;font-weight:800;display:inline-flex}.ll-card__status--current{background:var(--uchi-primary);color:var(--course-on-primary)}.ll-card__check{border:1px solid var(--c-border);width:26px;height:26px;color:var(--course-on-primary);background:0 0;border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;font-size:13px;font-weight:700;display:inline-flex}.ll-card[data-status=completed] .ll-card__check,.ll-card[data-status=current] .ll-card__check{border-color:var(--uchi-sage);background:var(--uchi-sage)}.ll-card__body{flex:1;padding:10px 16px 14px}.ll-card__title{font-family:var(--font-serif);color:var(--c-ink);margin:0;font-size:16px;font-style:italic;font-weight:700;line-height:1.32}.ll-card__subtitle{color:var(--c-tertiary);margin:5px 0 0;font-size:12px;font-weight:500;line-height:1.5}.ll-card__footer{border-top:1px solid var(--c-border);background:var(--c-muted);color:var(--c-tertiary);flex-wrap:wrap;align-items:center;gap:8px;margin-top:auto;padding:10px 16px;font-size:11px;font-weight:500;display:flex}.ll-card__meta-item,.ll-card__complete{align-items:center;gap:6px;display:inline-flex}.ll-card__complete{color:var(--uchi-primary)}.ll-card__footer>span:not(.ll-card__footer-action):not(:last-child):after{content:"·";color:var(--uchi-ink-4);margin-left:8px}.ll-card__footer-action{color:var(--uchi-ink-2);white-space:nowrap;align-items:center;gap:4px;margin-left:auto;font-weight:700;display:inline-flex}.ll-card[data-status=current] .ll-card__footer-action{color:var(--uchi-primary)}.ll-card__adding{color:var(--c-accent);align-items:center;gap:6px;padding:20px 16px;font-size:12px;font-weight:700;display:inline-flex}@keyframes ll-spin{to{transform:rotate(360deg)}}.ll-card__spinner{animation:.8s linear infinite ll-spin}.ll-info{border:1px solid var(--c-border);background:var(--c-surface);border-radius:12px;margin-top:24px;overflow:hidden}.ll-info__row{border-top:1px solid var(--c-border);grid-template-columns:180px minmax(0,1fr);gap:16px;padding:12px 20px;font-size:12.5px;display:grid}.ll-info__row:first-child{border-top:0}.ll-info__row span{color:var(--c-tertiary);font-weight:700}.ll-info__row strong{color:var(--c-ink);font-weight:700}@media (width<=1279px){.ll-hero{grid-template-columns:200px minmax(0,1fr) 240px}.ll-hero__cover-card{width:200px;height:236px}.ll-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (width<=899px){.ll-hero{grid-template-columns:minmax(0,1fr)}.ll-hero__cover-card{width:180px;height:212px}.ll-hero__side{align-self:stretch}.ll-grid{grid-template-columns:1fr}}@media (width<=767px){.page-topbar--course-detail .page-topbar__toggle-btn{display:inline-flex}.ll-page{padding:20px 16px 64px}.ll-hero{gap:16px;padding:18px}.ll-hero__cover-card{width:min(170px,100%);height:204px}.ll-hero__title{font-size:24px}.ll-hero__desc{font-size:12.5px}.ll-tabs{gap:18px}.ll-unit{flex-wrap:wrap;align-items:flex-start}.ll-unit__line{display:none}.ll-unit__range{width:100%}.ll-grid{grid-template-columns:1fr}.ll-info__row{grid-template-columns:1fr;gap:4px}}.premium-page{--c-bg:var(--uchi-bg);--c-surface:var(--uchi-paper);--c-muted:var(--uchi-row-alt);--c-border:var(--uchi-line);--c-ink:var(--uchi-ink);--c-secondary:var(--uchi-ink-2);--c-tertiary:var(--uchi-ink-3);--c-accent:var(--uchi-primary);--c-shadow:none;background:var(--c-bg);min-height:100%;color:var(--c-ink);font-family:var(--app-font,var(--font-jp));flex-direction:column;align-items:center;gap:18px;padding:22px 26px 40px;display:flex}.premium-header{text-align:center;border:1px solid var(--c-border);background:linear-gradient(120deg, var(--uchi-hero-from) 0%, var(--uchi-hero-mid) 100%);border-radius:14px;width:min(100%,880px);max-width:880px;padding:24px 28px}.premium-header__icon{width:56px;height:56px;color:var(--uchi-rose);background:#ffffffad;border-radius:14px;justify-content:center;align-items:center;margin-bottom:16px;display:inline-flex}.premium-header__title{color:var(--c-ink);margin:0 0 8px;font-size:24px;font-weight:700;line-height:1.3}.premium-header__desc{color:var(--c-secondary);margin:0;font-size:14px;font-weight:500;line-height:1.7}.premium-status{grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;width:100%;max-width:880px;display:grid}.premium-status>div{border:1px solid var(--c-border);background:var(--c-surface);min-width:0;box-shadow:var(--c-shadow);border-radius:12px;padding:14px 16px}.premium-status__label{color:var(--c-tertiary);margin-bottom:4px;font-size:11px;font-weight:600;display:block}.premium-status strong{overflow-wrap:anywhere;color:var(--c-ink);font-size:15px;font-weight:800;display:block}.premium-status__note{color:var(--c-secondary);text-align:center;grid-column:1/-1;font-size:12px;font-weight:600}.premium-status__note--success{color:var(--color-ok)}.premium-portal{border:1px solid var(--c-border);background:var(--c-surface);min-height:40px;color:var(--c-ink);cursor:pointer;border-radius:10px;justify-content:center;align-items:center;padding:0 16px;font-family:inherit;font-size:13px;font-weight:700;transition:background .15s,border-color .15s;display:inline-flex}.premium-portal:hover:not(:disabled){background:var(--c-muted);border-color:var(--border-strong)}.premium-portal:disabled{opacity:.55;cursor:not-allowed}.premium-action-error{color:var(--color-err);text-align:center;margin:-18px 0 0;font-size:12px;font-weight:600}.premium-plans{grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;width:100%;max-width:880px;display:grid}.premium-plans__loading{grid-column:1/-1}.premium-plan{border:1px solid var(--c-border);background:var(--c-surface);box-shadow:var(--c-shadow);border-radius:12px;flex-direction:column;padding:24px;transition:border-color .15s,background .15s;display:flex;position:relative}.premium-plan:hover{border-color:var(--border-strong);background:var(--c-surface)}.premium-plan--highlighted{border-color:var(--c-accent);background:linear-gradient(180deg, var(--uchi-primary-soft) 0%, var(--uchi-paper) 42%);box-shadow:inset 0 3px 0 var(--c-accent)}.premium-plan--highlighted:hover{border-color:var(--c-accent);box-shadow:inset 0 3px 0 var(--c-accent)}.premium-plan__badge{background:var(--c-accent);height:22px;color:var(--course-on-primary);white-space:nowrap;border-radius:999px;align-items:center;gap:4px;padding:0 10px;font-size:11px;font-weight:700;display:inline-flex;position:absolute;top:-10px;left:50%;transform:translate(-50%)}.premium-plan__name{color:var(--c-ink);margin:0 0 12px;font-size:15px;font-weight:700}.premium-plan__price{align-items:baseline;gap:2px;margin-bottom:4px;display:flex}.premium-plan__price-value{color:var(--c-ink);font-feature-settings:"tnum";font-size:32px;font-weight:700;line-height:1}.premium-plan__price-unit{color:var(--c-secondary);font-size:14px;font-weight:600}.premium-plan__saving{color:var(--uchi-sage-mid);margin-bottom:4px;font-size:12px;font-weight:600;display:block}.premium-plan__features{flex-direction:column;flex:1;gap:10px;margin:20px 0;padding:0;list-style:none;display:flex}.premium-plan__feature{color:var(--c-ink);align-items:center;gap:8px;font-size:13px;font-weight:500;display:flex}.premium-plan__feature--disabled{color:var(--c-tertiary);text-decoration:line-through}.premium-plan__feature--disabled svg{opacity:.3}.premium-plan__cta{border:1px solid var(--c-border);background:var(--c-surface);height:40px;color:var(--c-ink);cursor:pointer;border-radius:999px;justify-content:center;align-items:center;gap:6px;font-family:inherit;font-size:14px;font-weight:800;transition:background .15s,border-color .15s;display:flex}.premium-plan__cta:hover:not(:disabled){background:var(--c-muted);border-color:var(--border-strong)}.premium-plan__cta:disabled{opacity:.55;cursor:not-allowed}.premium-plan__cta--current{color:var(--c-tertiary);cursor:default}.premium-plan__cta--primary{border-color:var(--c-accent);background:var(--c-accent);color:var(--course-on-primary)}.premium-plan__cta--primary:hover:not(:disabled){background:var(--color-primary-hover);border-color:var(--color-primary-hover)}.premium-footer{color:var(--c-tertiary);text-align:center;margin:0;font-size:12px;font-weight:600}@media (width<=899px){.premium-status,.premium-plans{grid-template-columns:1fr;max-width:400px}}@media (width<=768px){.premium-page{padding:20px 16px 64px}.premium-header__title{font-size:20px}}.vocab-page{--vocab-bg:var(--uchi-bg);--vocab-surface:var(--uchi-paper);--vocab-surface-muted:var(--uchi-row-alt);--vocab-surface-subtle:var(--uchi-primary-soft);--vocab-border:var(--uchi-line);--vocab-border-strong:#d4cfc4;--vocab-ink:var(--uchi-ink);--vocab-muted:var(--uchi-ink-2);--vocab-subtle:var(--uchi-ink-3);--vocab-accent:var(--uchi-primary);--vocab-accent-hover:var(--uchi-primary-hover);--vocab-accent-strong:var(--uchi-primary-active);--vocab-accent-soft:var(--uchi-primary-soft);--vocab-accent-text:var(--course-on-primary);--vocab-success:var(--uchi-sage-mid);--vocab-warning:var(--uchi-rose);--vocab-danger:var(--uchi-rose);--vocab-danger-soft:var(--uchi-tag-rose-bg);--vocab-shadow:none;--vocab-shadow-hover:none;--vocab-pill-bg:var(--uchi-cream-soft);background:var(--vocab-bg);min-height:100%;color:var(--vocab-ink);font-family:var(--app-font,var(--font-jp));padding:22px 26px 40px}.vocab-page__toolbar{flex-wrap:wrap;align-items:center;gap:12px;max-width:1280px;margin:0 auto 18px;display:flex}.vocab-page__capacity{background:var(--vocab-surface);border:1px solid var(--vocab-border);min-height:38px;box-shadow:var(--vocab-shadow);border-radius:12px;align-items:center;gap:12px;padding:0 16px;font-size:12.5px;display:inline-flex}.vocab-page__capacity-label{color:var(--vocab-muted);letter-spacing:0;font-weight:600}.vocab-page__capacity-value{color:var(--vocab-ink);font-family:var(--font-data);font-feature-settings:"tnum";font-weight:700}.vocab-page__capacity-bar{background:var(--vocab-pill-bg);border-radius:999px;width:80px;height:4px;overflow:hidden}.vocab-page__capacity-fill{background:var(--uchi-sage-mid);border-radius:999px;height:100%;transition:width .4s cubic-bezier(.4,0,.2,1)}.vocab-page__actions{flex-wrap:wrap;align-items:center;gap:8px;margin-left:auto;display:flex}.vocab-page__action-btn{border:1px solid var(--vocab-border);background:var(--vocab-surface);min-height:38px;color:var(--vocab-ink);cursor:pointer;border-radius:999px;align-items:center;gap:7px;padding:0 16px;font-family:inherit;font-size:12.5px;font-weight:700;transition:background .18s,border-color .18s,color .18s,transform .18s;display:inline-flex}.vocab-page__action-btn:hover{background:var(--vocab-surface-muted);border-color:var(--vocab-border-strong)}.vocab-page__action-btn--primary{background:var(--vocab-accent);border-color:var(--vocab-accent);color:var(--vocab-accent-text)}.vocab-page__action-btn--primary:hover{background:var(--vocab-accent-hover);border-color:var(--vocab-accent-hover);transform:translateY(-1px)}.vocab-page__filter-anchor{position:relative}.vocab-page__filter-trigger[aria-expanded=true]{background:var(--vocab-accent-soft);border-color:var(--vocab-accent);color:var(--vocab-accent)}.vocab-page__shelf{max-width:1280px;box-shadow:none;background:0 0;margin:0 auto;padding:0}.vocab-page__list{border:1px solid var(--vocab-border);background:var(--vocab-surface);border-radius:12px;flex-direction:column;gap:0;display:flex;overflow:hidden}.vocab-page__empty{text-align:center;color:var(--vocab-muted);background:var(--vocab-surface);border:1px solid var(--vocab-border);box-shadow:var(--vocab-shadow);border-radius:12px;padding:96px 24px;font-size:14px;line-height:1.8}.vocab-page__empty p{margin:0}.vocab-page__empty-sub{color:var(--vocab-subtle);font-size:13px;margin-top:8px!important}.vocab-page__empty kbd{background:var(--vocab-pill-bg);border:1px solid var(--vocab-border);color:var(--vocab-ink);border-radius:6px;margin:0 3px;padding:2px 8px;font-family:inherit;font-size:11px;font-weight:700;display:inline-block}.vocab-card{border:0;border-top:1px solid var(--vocab-border);background:var(--vocab-surface);border-radius:0;align-items:flex-start;gap:14px;padding:16px 18px;transition:background .15s,border-color .15s,transform .15s;display:flex}.vocab-card:first-child{border-top:0}.vocab-card:hover{background:var(--vocab-surface-muted);transform:none}.vocab-card--selected{background:var(--vocab-accent-soft)!important;border-color:var(--vocab-accent)!important}.vocab-card__content{flex-direction:column;flex:1;gap:4px;min-width:0;display:flex}.vocab-card__word-row{align-items:center;gap:6px;min-width:0;display:flex}.vocab-card__english{min-width:0;font-family:var(--font-serif);color:var(--vocab-ink);text-overflow:ellipsis;white-space:nowrap;flex:auto;margin:0;font-size:17px;font-weight:500;line-height:1.5;overflow:hidden}.vocab-card__entry-type{border:1px solid var(--vocab-border);background:var(--vocab-pill-bg);color:var(--vocab-muted);white-space:nowrap;border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;padding:2px 8px;font-size:11px;font-weight:800;line-height:1.4;display:inline-flex}.vocab-card__entry-type--word{border-color:var(--vocab-accent-soft);background:var(--vocab-accent-soft);color:var(--vocab-accent)}.vocab-card__entry-type--step{border-color:var(--vocab-border);background:var(--vocab-pill-bg);color:var(--vocab-muted)}.vocab-card__speak-btn{cursor:pointer;width:24px;height:24px;color:var(--vocab-subtle);background:0 0;border:none;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;transition:color .15s,background .15s;display:inline-flex}.vocab-card__speak-btn:hover{color:var(--vocab-accent);background:var(--vocab-accent-soft)}.vocab-card__japanese{color:var(--vocab-muted);text-overflow:ellipsis;white-space:nowrap;min-width:0;margin:0;font-size:12.5px;font-weight:500;line-height:1.5;overflow:hidden}.vocab-card__sentence{font-family:var(--font-serif);color:var(--vocab-subtle);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:0;font-size:12.5px;font-style:italic;font-weight:500;line-height:1.5;display:-webkit-box;overflow:hidden}.vocab-card__meta{color:var(--vocab-subtle);align-items:center;gap:4px;margin-top:4px;font-size:11.5px;font-weight:500;display:flex}.vocab-card__meta-sep{color:var(--vocab-border-strong)}.vocab-card__meta-practice{color:var(--vocab-accent);font-weight:700}.vocab-card__primary-btn{border:1px solid var(--vocab-border);height:30px;color:var(--vocab-muted);cursor:pointer;background:0 0;border-radius:999px;flex-shrink:0;padding:0 12px;font-family:inherit;font-size:12px;font-weight:600;transition:color .18s,background .18s,border-color .18s}.vocab-card__primary-btn:hover{background:var(--vocab-accent-soft);border-color:var(--vocab-accent);color:var(--vocab-accent)}.vocab-card__checkbox{cursor:pointer;flex-shrink:0;align-items:center;padding-top:4px;display:inline-flex}.vocab-card__checkbox input{opacity:0;pointer-events:none;position:absolute}.vocab-card__checkbox-box{border:1.5px solid var(--vocab-border-strong);background:var(--vocab-surface);border-radius:6px;width:20px;height:20px;transition:all .18s;display:inline-flex;position:relative}.vocab-card__checkbox input:checked+.vocab-card__checkbox-box{background:var(--vocab-accent);border-color:var(--vocab-accent)}.vocab-card__checkbox input:checked+.vocab-card__checkbox-box:after{content:"";border:solid var(--vocab-accent-text);border-width:0 2px 2px 0;width:6px;height:11px;position:absolute;top:1px;left:5px;transform:rotate(45deg)}.vocab-filter-panel{z-index:20;background:var(--vocab-surface);border:1px solid var(--vocab-border);border-radius:12px;min-width:300px;padding:18px;position:absolute;top:calc(100% + 10px);right:0;box-shadow:0 8px 24px #2e352814}.vocab-filter-panel__title{background:var(--vocab-accent-soft);min-height:28px;color:var(--vocab-accent);letter-spacing:0;border-radius:6px;align-items:center;gap:6px;margin-bottom:16px;padding:0 12px;font-size:12px;font-weight:800;display:inline-flex}.vocab-filter-panel__group{margin-bottom:18px}.vocab-filter-panel__group:last-of-type{margin-bottom:14px}.vocab-filter-panel__label{color:var(--vocab-muted);letter-spacing:0;margin-bottom:10px;font-size:12px;font-weight:700}.vocab-filter-panel__radios{flex-direction:column;gap:6px;display:flex}.vocab-filter-panel__radio{color:var(--vocab-ink);cursor:pointer;align-items:center;gap:8px;padding:4px 0;font-size:13px;display:flex}.vocab-filter-panel__radio input{accent-color:var(--vocab-accent)}.vocab-filter-panel__segmented,.vocab-filter-panel__chips{grid-template-columns:1fr 1fr;gap:8px;display:grid}.vocab-filter-panel__chip{border:1px solid var(--vocab-border);background:var(--vocab-surface);height:36px;color:var(--vocab-ink);cursor:pointer;border-radius:999px;padding:0 12px;font-family:inherit;font-size:12px;font-weight:700;transition:all .18s}.vocab-filter-panel__chip:hover{background:var(--vocab-surface-muted);border-color:var(--vocab-border-strong)}.vocab-filter-panel__chip--active{background:var(--vocab-accent-soft);border-color:var(--vocab-accent);color:var(--vocab-accent)}.vocab-filter-panel__footer{justify-content:space-between;gap:8px;margin-top:10px;display:flex}.vocab-filter-panel__btn{border:1px solid var(--vocab-border);background:var(--vocab-surface);height:40px;color:var(--vocab-ink);cursor:pointer;border-radius:999px;flex:1;font-family:inherit;font-size:13px;font-weight:700;transition:all .18s}.vocab-filter-panel__btn:hover{background:var(--vocab-surface-muted);border-color:var(--vocab-border-strong)}.vocab-filter-panel__btn--primary{background:var(--vocab-accent);border-color:var(--vocab-accent);color:var(--vocab-accent-text)}.vocab-filter-panel__btn--primary:hover{background:var(--vocab-accent-hover);border-color:var(--vocab-accent-hover)}.vocab-selection-bar{left:var(--app-sidebar-offset,0px);z-index:50;background:var(--vocab-surface);border-top:1px solid var(--vocab-border);justify-content:space-between;align-items:center;gap:16px;padding:18px 40px;font-family:inherit;transition:left .25s;display:flex;position:fixed;bottom:0;right:0;box-shadow:0 -8px 24px #2e352814}.vocab-selection-bar__info{color:var(--vocab-muted);font-size:13px}.vocab-selection-bar__count{color:var(--vocab-accent);font-weight:700}.vocab-selection-bar__actions{flex-wrap:wrap;gap:8px;display:flex}.vocab-selection-bar__btn{border:1px solid var(--vocab-border);background:var(--vocab-surface);height:40px;color:var(--vocab-ink);cursor:pointer;border-radius:999px;align-items:center;gap:6px;padding:0 18px;font-family:inherit;font-size:13px;font-weight:700;transition:all .18s;display:inline-flex}.vocab-selection-bar__btn:hover:not(:disabled){background:var(--vocab-surface-muted);border-color:var(--vocab-border-strong)}.vocab-selection-bar__btn:disabled{opacity:.4;cursor:not-allowed}.vocab-selection-bar__btn--danger:hover:not(:disabled){color:var(--vocab-danger);border-color:var(--vocab-danger);background:var(--vocab-danger-soft)}.vocab-selection-bar__btn--primary{background:var(--vocab-accent);border-color:var(--vocab-accent);color:var(--vocab-accent-text)}.vocab-selection-bar__btn--primary:hover:not(:disabled){background:var(--vocab-accent-hover);border-color:var(--vocab-accent-hover);transform:translateY(-1px)}.vocab-page--selecting{padding-bottom:120px}@media (width<=899px){.vocab-page{padding:24px 20px 64px}.vocab-page__actions{margin-left:0}.vocab-selection-bar{flex-direction:column;align-items:stretch;padding:16px 20px}.vocab-selection-bar__actions{justify-content:stretch}.vocab-selection-bar__btn{flex:1}}@media (width<=767px){.vocab-page{padding:20px 16px 64px}.vocab-card{padding:14px 16px}.vocab-card__japanese,.vocab-card__english{white-space:normal}}.typing-books{background:var(--bg-page);min-height:100%;color:var(--text-primary);font-family:var(--app-font,var(--font-jp));padding:24px 28px 80px}.typing-books__tags{scrollbar-width:none;gap:8px;margin-bottom:16px;display:flex;overflow-x:auto}.typing-books__tags::-webkit-scrollbar{display:none}.typing-books__tag{border:1px solid var(--border);background:var(--bg-surface);min-height:34px;color:var(--text-tertiary);white-space:nowrap;cursor:pointer;border-radius:8px;justify-content:center;align-items:center;padding:0 16px;font-family:inherit;font-size:13px;font-weight:700;transition:background .15s,color .15s,border-color .15s;display:inline-flex}.typing-books__tag:hover{background:var(--bg-surface-muted)}.typing-books__tag--active{border-color:var(--color-primary);background:var(--color-primary);color:var(--course-on-primary)}.typing-books__toolbar{align-items:center;gap:10px;margin-bottom:20px;display:flex}.typing-books__search{flex:1;max-width:360px;position:relative}.typing-books__search-icon{color:var(--text-tertiary);pointer-events:none;position:absolute;top:50%;left:11px;transform:translateY(-50%)}.typing-books__search-input{border:1px solid var(--border);background:var(--bg-surface);width:100%;height:36px;color:var(--text-primary);border-radius:8px;outline:none;padding:0 12px 0 32px;font-family:inherit;font-size:13px;font-weight:600;transition:border-color .15s,background .15s}.typing-books__search-input::placeholder{color:var(--text-tertiary)}.typing-books__search-input:focus{border-color:var(--color-primary);background:var(--bg-surface)}.typing-books__sort-btn{border:1px solid var(--border);background:var(--bg-surface);min-height:36px;color:var(--text-primary);cursor:pointer;border-radius:8px;align-items:center;gap:6px;padding:0 12px;font-family:inherit;font-size:13px;font-weight:700;transition:background .15s;display:inline-flex}.typing-books__sort-btn:hover{background:var(--bg-surface-muted)}.typing-books__grid{grid-template-columns:repeat(auto-fill,minmax(172px,1fr));gap:24px;display:grid}.typing-books__state{min-height:180px;color:var(--text-secondary);align-items:center;font-size:14px;font-weight:600;display:flex}.typing-books__state--error{color:var(--color-danger)}.typing-book-card{cursor:pointer;background:0 0;border:none;flex-direction:column;align-items:stretch;width:100%;padding:0;font-family:inherit;display:flex}.typing-book-card__cover{aspect-ratio:3/4;width:100%;box-shadow:0 8px 24px var(--course-cover-shadow);border-radius:6px;transition:transform .2s;position:relative;overflow:hidden}.typing-book-card:hover .typing-book-card__cover{transform:translateY(-2px)}.typing-book-card__cover-img{object-fit:cover;width:100%;height:100%;display:block}.typing-book-card__cover-title{color:var(--course-cover-muted-text);text-align:center;justify-content:center;align-items:center;padding:20px 16px;font-size:15px;font-weight:800;line-height:1.4;display:flex;position:absolute;inset:0}.typing-book-card__body{text-align:left;flex-direction:column;align-items:flex-start;gap:2px;width:100%;padding:10px 2px 0;display:flex}.typing-book-card__title-ja{color:var(--text-primary);font-size:13px;font-weight:800;line-height:1.3}.typing-book-card__author{color:var(--text-secondary);font-size:11px;font-weight:600}.typing-book-card__footer{align-items:center;gap:8px;margin-top:6px;display:flex}.typing-book-card__progress-text{color:var(--text-tertiary);font-size:11px;font-weight:700}.typing-book-card__progress-bar{background:var(--border);border-radius:2px;width:48px;height:4px;overflow:hidden}.typing-book-card__progress-fill{background:var(--color-primary);border-radius:2px;height:100%;transition:width .3s}@media (width<=768px){.typing-books{padding:20px 16px 64px}.typing-books__grid{grid-template-columns:repeat(auto-fill,minmax(138px,1fr));gap:20px}.typing-books__toolbar{flex-direction:column;align-items:stretch}.typing-books__search{max-width:none}}.plan-page{--c-bg:var(--bg-page);--c-surface:var(--bg-surface);--c-muted:var(--bg-surface-muted);--c-border:var(--border);--c-ink:var(--text-primary);--c-secondary:var(--text-secondary);--c-tertiary:var(--text-tertiary);--c-accent:var(--color-primary);--c-shadow:0 1px 3px var(--course-cover-shadow);background:var(--c-bg);min-height:100%;color:var(--c-ink);font-family:var(--app-font,var(--font-jp));padding:24px 28px 80px}.plan-page__hero{border:1px solid var(--c-border);background:linear-gradient(120deg, var(--uchi-hero-from) 0%, var(--uchi-hero-mid) 100%);border-radius:14px;grid-template-columns:minmax(0,1fr) auto auto;align-items:center;gap:26px;margin-bottom:16px;padding:20px 24px;display:grid;position:relative;overflow:hidden}.plan-page__hero:after{content:"";border:1px solid #1f4e471f;border-radius:50%;width:150px;height:150px;position:absolute;bottom:-38px;right:22px}.plan-page__hero-main,.plan-page__hero-stats,.plan-page__hero-action{z-index:1;position:relative}.plan-page__tag{background:var(--uchi-tag-sage-bg);min-height:24px;color:var(--uchi-primary);border-radius:999px;align-items:center;padding:0 10px;font-size:10.5px;font-weight:600;display:inline-flex}.plan-page__hero h1{color:var(--c-ink);margin:9px 0 4px;font-size:23px;font-weight:700;line-height:1.2}.plan-page__hero p,.plan-side-card p{color:var(--c-secondary);margin:0;font-size:12.5px;font-weight:600;line-height:1.6}.plan-page__hero-progress{background:#ffffffb8;border-radius:999px;width:min(360px,100%);height:6px;margin-top:14px;overflow:hidden}.plan-page__hero-progress span{border-radius:inherit;background:var(--c-accent);height:100%;display:block}.plan-page__hero small{color:var(--c-secondary);font-feature-settings:"tnum";margin-top:7px;font-size:11px;font-weight:700;display:block}.plan-page__hero-stats{grid-template-columns:repeat(3,auto);gap:24px;display:grid}.plan-page__hero-stats div{text-align:right;min-width:58px}.plan-page__hero-stats span{color:var(--c-secondary);font-size:10.5px;font-weight:700;display:block}.plan-page__hero-stats strong{color:var(--c-ink);font-feature-settings:"tnum";margin-top:4px;font-size:24px;font-weight:700;line-height:1;display:block}.plan-page__hero-stats small{color:var(--c-secondary);margin:0 0 0 2px;font-size:11px;display:inline}.plan-page__hero-action,.plan-side-card--next button{background:var(--c-accent);min-height:38px;color:var(--course-on-primary);cursor:pointer;border:0;border-radius:999px;justify-content:center;align-items:center;gap:7px;font-family:inherit;font-size:13px;font-weight:700;display:inline-flex}.plan-page__hero-action{padding:0 18px}.plan-page__layout{grid-template-columns:minmax(0,1fr) 320px;gap:16px;display:grid}.plan-page__main-panel,.plan-side-card{border:1px solid var(--c-border);background:var(--c-surface);border-radius:12px}.plan-page__main-panel{padding:18px 20px}.plan-page__section-head{justify-content:space-between;align-items:center;gap:16px;margin-bottom:14px;display:flex}.plan-page__section-head h2,.plan-side-card h2{color:var(--c-ink);margin:0;font-size:14px;font-weight:800}.plan-page__section-head p{color:var(--c-tertiary);margin:4px 0 0;font-size:11.5px;font-weight:600}.plan-page__side{flex-direction:column;gap:14px;display:flex}.plan-side-card{padding:16px 18px}.plan-side-card__row{border-top:1px solid var(--c-border);color:var(--c-secondary);justify-content:space-between;align-items:center;gap:12px;padding:11px 0;font-size:12px;font-weight:700;display:flex}.plan-side-card__row:first-of-type{margin-top:10px}.plan-side-card__row span{align-items:center;gap:7px;display:inline-flex}.plan-side-card__row strong{color:var(--c-ink);font-feature-settings:"tnum";font-size:14px;font-weight:800}.plan-side-card--next{background:linear-gradient(135deg, var(--uchi-tag-rose-bg) 0%, var(--uchi-cream-soft) 100%)}.plan-side-card--next h2{margin-top:10px;line-height:1.35}.plan-side-card--next button{min-height:34px;margin-top:14px;padding:0 14px}.plan-cards{flex-direction:column;gap:10px;display:flex}.plan-card{border:1px solid var(--c-border);background:var(--c-surface);box-shadow:inset 3px 0 0 var(--plan-card-tint);border-radius:10px;grid-template-rows:auto auto;grid-template-columns:128px minmax(0,1fr);gap:0 15px;padding:14px;transition:border-color .15s,background .15s;display:grid;position:relative}.plan-card:hover{border-color:var(--border-strong);background:var(--c-muted)}.plan-card__grip{color:var(--c-tertiary);cursor:grab;background:0 0;border:none;grid-area:1/1/-1;align-items:center;padding:0;transition:color .15s;display:flex}.plan-card__grip:hover{color:var(--c-secondary)}.plan-card__cover{border:1px solid var(--c-border);background:var(--c-muted);cursor:pointer;border-radius:12px;grid-area:1/1/-1;width:128px;height:94px;padding:0;overflow:hidden}.plan-card__cover img{object-fit:cover;width:100%;height:100%;display:block}.plan-card__body{cursor:pointer;font:inherit;text-align:left;background:0 0;border:none;flex-direction:column;grid-area:1/2;gap:6px;padding-top:2px;padding-right:44px;display:flex}.plan-card__title{color:var(--c-ink);font-size:16px;font-weight:700;line-height:1.3}.plan-card__desc{color:var(--c-secondary);-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:13px;font-weight:600;line-height:1.5;display:-webkit-box;overflow:hidden}.plan-card__delete{border:1px solid var(--c-border);background:var(--c-surface);width:34px;height:34px;color:var(--c-tertiary);cursor:pointer;border-radius:8px;justify-content:center;align-items:center;transition:color .15s,border-color .15s,background .15s;display:inline-flex;position:absolute;top:14px;right:14px}.plan-card__delete:hover{color:var(--color-err);border-color:var(--color-err);background:var(--color-err-bg)}.plan-card__footer{cursor:pointer;font:inherit;text-align:left;background:0 0;border:none;grid-area:2/2;align-items:center;gap:16px;padding-top:10px;display:flex}.plan-card__lessons{color:var(--c-secondary);white-space:nowrap;font-feature-settings:"tnum";flex-shrink:0;font-size:13px;font-weight:600}.plan-card__lessons strong{color:var(--c-ink);font-weight:700}.plan-card__bar{background:var(--border);border-radius:999px;flex:1;min-width:0;height:6px;overflow:hidden}.plan-card__bar-fill{background:var(--c-accent);border-radius:999px;height:100%;transition:width .4s}.plan-card__stats{flex-shrink:0;align-items:center;gap:16px;display:flex}.plan-card__stat{color:var(--c-secondary);white-space:nowrap;font-feature-settings:"tnum";align-items:center;gap:4px;font-size:12px;font-weight:600;display:inline-flex}.plan-card__stat strong{font-weight:700}.plan-card__stat--done strong{color:var(--c-accent)}.plan-card__stat--remaining strong{color:var(--c-tertiary)}.plan-card__badge{background:var(--color-ok);height:24px;color:var(--course-on-primary);border-radius:6px;align-items:center;padding:0 10px;font-size:11px;font-weight:700;display:inline-flex;position:absolute;top:14px;right:58px}.plan-empty{border:1px dashed var(--c-border);color:var(--c-tertiary);text-align:center;border-radius:10px;flex-direction:column;align-items:center;gap:14px;padding:48px 20px;font-size:14px;display:flex}.plan-empty p{margin:0}.plan-empty__btn{border:1px solid var(--c-border);background:var(--c-surface);color:var(--c-ink);cursor:pointer;border-radius:8px;align-items:center;gap:6px;padding:8px 16px;font-family:inherit;font-size:12.5px;font-weight:700;transition:border-color .15s,background .15s;display:inline-flex}.plan-empty__btn:hover{border-color:var(--c-ink);background:var(--c-muted)}@media (width<=768px){.plan-page{padding:20px 16px 64px}.plan-page__hero,.plan-page__layout{grid-template-columns:1fr}.plan-page__hero-stats{grid-template-columns:repeat(3,minmax(0,1fr))}.plan-page__hero-stats div{text-align:left}.plan-card{grid-template-columns:100px minmax(0,1fr);gap:0 12px;padding:16px}.plan-card__cover{width:100px;height:90px}.plan-card__title{font-size:14px}.plan-card__footer,.plan-card__stats{gap:10px}}@media (width<=480px){.plan-card{grid-template-columns:1fr}.plan-card__cover{display:none}.plan-card__body{grid-column:1}.plan-card__footer{flex-wrap:wrap;grid-column:1;gap:8px}.plan-card__desc{-webkit-line-clamp:1}}.toast{z-index:9999;color:#fff;pointer-events:none;background:#1e1e28eb;border-radius:999px;padding:12px 24px;font-size:14px;font-weight:500;animation:.22s ease-out toast-slide-in;position:fixed;bottom:120px;left:50%;transform:translate(-50%);box-shadow:0 6px 24px #00000040}.toast__message{white-space:nowrap}@keyframes toast-slide-in{0%{opacity:0;transform:translate(-50%,12px)}to{opacity:1;transform:translate(-50%)}}.typing-reader{--tr-bg:#1a1b2e;--tr-surface:#232440;--tr-text:#c8c8d8;--tr-text-dim:#6b6b80;--tr-accent:#7c3aed;--tr-correct:#a5b4fc;--tr-incorrect:var(--color-err);--tr-current-bg:#7c3aed4d;--tr-progress:var(--color-ok);background:var(--tr-bg);min-height:100vh;color:var(--tr-text);flex-direction:column;font-family:DM Sans,-apple-system,BlinkMacSystemFont,Hiragino Sans,system-ui,sans-serif;display:flex}.typing-reader__topbar{background:var(--tr-surface);border-bottom:1px solid #ffffff0f;flex-shrink:0;align-items:center;gap:16px;padding:12px 24px;display:flex}.typing-reader__back-btn{color:var(--tr-text);cursor:pointer;background:#ffffff0f;border:none;border-radius:8px;align-items:center;gap:6px;padding:6px 12px;font-family:inherit;font-size:13px;font-weight:500;transition:background .15s;display:flex}.typing-reader__back-btn:hover{background:#ffffff1f}.typing-reader__title{color:var(--tr-text);white-space:nowrap;text-overflow:ellipsis;flex:1;font-size:14px;font-weight:600;overflow:hidden}.typing-reader__topbar-stats{color:var(--tr-text-dim);align-items:center;gap:18px;font-size:13px;font-weight:500;display:flex}.typing-reader__topbar-stats strong{color:var(--tr-text);font-weight:600}.typing-reader__pause-btn{cursor:pointer;border:none;border-radius:8px;align-items:center;gap:4px;padding:6px 14px;font-family:inherit;font-size:13px;font-weight:600;transition:background .15s;display:flex}.typing-reader__pause-btn--active{background:var(--color-err);color:#fff}.typing-reader__pause-btn--paused{background:var(--tr-progress);color:#fff}.typing-reader__content{flex-direction:column;flex:1;align-items:center;padding:48px 32px;display:flex;overflow:hidden}.typing-text{width:100%;max-width:720px;max-height:100%;padding:8px 4px;overflow-y:auto}.typing-text__body{letter-spacing:.02em;word-break:break-word;font-family:JetBrains Mono,Fira Code,Consolas,monospace;font-size:22px;line-height:2}.letter{color:var(--tr-text-dim)}.letter.ok{color:var(--tr-correct)}.letter.error{color:var(--tr-incorrect);text-decoration:underline;-webkit-text-decoration-color:var(--tr-incorrect);text-decoration-color:var(--tr-incorrect);text-underline-offset:3px}.typing-text{position:relative;overflow-y:auto}.typing-text__caret{background:var(--tr-accent);pointer-events:none;z-index:1;opacity:0;will-change:left, top;border-radius:1px;width:2.5px;animation:1s step-end infinite caret-blink;position:absolute}@keyframes caret-blink{0%,50%{opacity:1}50.01%,to{opacity:0}}.typing-stats{background:var(--tr-surface);border-top:1px solid #ffffff0f;flex-shrink:0;padding:12px 24px 16px}.typing-stats__progress-track{background:#ffffff14;border-radius:2px;height:4px;margin-bottom:10px;overflow:hidden}.typing-stats__progress-fill{background:var(--tr-progress);border-radius:2px;height:100%;transition:width .3s}.typing-stats__metrics{justify-content:center;gap:40px;display:flex}.typing-stats__metric{flex-direction:column;align-items:center;gap:2px;display:flex}.typing-stats__metric-value{color:var(--tr-text);font-size:16px;font-weight:700}.typing-stats__metric-label{color:var(--tr-text-dim);text-transform:uppercase;letter-spacing:.04em;font-size:11px;font-weight:500}.typing-reader__complete{text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:24px;padding:48px 32px;display:flex}.typing-reader__complete-title{color:var(--tr-correct);font-size:28px;font-weight:700}.typing-reader__complete-stats{color:var(--tr-text);gap:32px;font-size:15px;display:flex}.typing-reader__complete-btn{background:var(--tr-accent);color:#fff;cursor:pointer;border:none;border-radius:10px;padding:10px 28px;font-family:inherit;font-size:14px;font-weight:600;transition:background .15s}.typing-reader__complete-btn:hover{background:#6d28d9}.typing-reader__paused-overlay{z-index:100;background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.typing-reader__paused-card{background:var(--tr-surface);border-radius:16px;flex-direction:column;align-items:center;gap:16px;padding:40px 48px;display:flex;box-shadow:0 8px 32px #0006}.typing-reader__paused-card h2{color:var(--tr-text);margin:0;font-size:22px;font-weight:700}.typing-reader__paused-card p{color:var(--tr-text-dim);margin:0;font-size:14px}@media (width<=768px){.typing-text__body{font-size:18px;line-height:1.8}.typing-reader__content{padding:32px 20px}.typing-stats__metrics{gap:24px}.typing-reader__topbar-stats{display:none}}.typing-chapters{background:var(--bg-page);min-height:100%;color:var(--text-primary);font-family:var(--app-font,var(--font-jp));padding:22px 26px 40px}.typing-chapters__hero{background:linear-gradient(100deg, var(--course-hero-from), var(--course-hero-to));border:1px solid var(--border);border-radius:14px;gap:24px;margin-bottom:18px;padding:20px;display:flex}.typing-chapters__hero-cover{aspect-ratio:3/4;border-radius:6px;flex-shrink:0;width:140px;overflow:hidden;box-shadow:0 8px 16px #2e352829}.typing-chapters__hero-cover img{object-fit:cover;width:100%;height:100%;display:block}.typing-chapters__hero-cover-placeholder{width:100%;height:100%;font-size:40px;font-family:var(--font-title);color:var(--course-cover-muted-text);justify-content:center;align-items:center;font-weight:700;display:flex}.typing-chapters__hero-info{flex-direction:column;flex:1;min-width:0;display:flex}.typing-chapters__hero-title{font-size:20px;font-family:var(--font-serif);color:var(--text-primary);margin:0 0 4px;font-weight:600;line-height:1.3}.typing-chapters__hero-author{color:var(--text-secondary);margin:0 0 18px;font-size:13px;font-weight:500}.typing-chapters__hero-stats{align-items:center;gap:20px;margin-bottom:18px;display:flex}.typing-chapters__hero-stat{flex-direction:column;gap:2px;display:flex}.typing-chapters__hero-stat-value{font-family:var(--font-data);color:var(--text-primary);font-size:16px;font-weight:700}.typing-chapters__hero-stat-label{color:var(--text-tertiary);letter-spacing:0;font-size:11px;font-weight:600}.typing-chapters__hero-divider{background:var(--border);width:1px;height:32px}.typing-chapters__hero-progress{margin-top:auto}.typing-chapters__hero-progress-track{background:var(--course-hero-progress-track);border-radius:999px;height:4px;margin-bottom:6px;overflow:hidden}.typing-chapters__hero-progress-fill{background:var(--uchi-sage-mid);border-radius:999px;height:100%;transition:width .4s}.typing-chapters__hero-progress-text{color:var(--text-secondary);font-size:12px;font-weight:600}.typing-chapters__list{border:1px solid var(--border);background:var(--bg-surface);border-radius:12px;flex-direction:column;gap:0;display:flex;overflow:hidden}.typing-chapter-item{background:var(--bg-surface);border:0;border-top:1px solid var(--border);cursor:pointer;text-align:left;border-radius:0;align-items:center;gap:16px;width:100%;min-height:64px;padding:12px 16px;font-family:inherit;transition:border-color .15s,background .15s,transform .15s;display:flex}.typing-chapter-item:hover{background:var(--uchi-row-alt);transform:none}.typing-chapter-item--completed{background:var(--uchi-primary-soft)}.typing-chapter-item:first-child{border-top:0}.typing-chapter-item__title{color:var(--text-primary);flex:1;font-size:14px;font-weight:700}.typing-chapter-item__meta{color:var(--text-tertiary);white-space:nowrap;font-size:12px;font-weight:500}.typing-chapter-item__status{white-space:nowrap;border-radius:999px;padding:4px 10px;font-size:11px;font-weight:600}.typing-chapter-item__status--pending{color:var(--text-muted);background:var(--bg-surface-muted)}.typing-chapter-item__status--in-progress{color:var(--color-primary);background:var(--color-primary-ghost)}.typing-chapter-item__status--completed{color:var(--color-ok);background:var(--color-ok-bg)}@media (width<=768px){.typing-chapters{padding:20px 16px 64px}.typing-chapters__hero{flex-direction:column;gap:16px;padding:16px}.typing-chapters__hero-cover{width:120px}.typing-chapters__hero-stats{justify-content:flex-start}.typing-chapters__hero-info{align-items:stretch}.typing-chapter-item{flex-wrap:wrap;padding:12px 16px}.typing-chapter-item__title{flex-basis:100%}}[data-theme=dark] .page{background-color:var(--exercise-bg,var(--bg-page))}[data-theme=dark] .progress-bar-track{border-color:var(--border-strong);background:var(--bg-surface)}[data-theme=dark] .score{color:var(--text-tertiary)}[data-theme=dark] .pos-tag{color:var(--text-secondary);border-color:var(--border-strong);background-color:#2a2a2ed9}[data-theme=dark] .previous-word{color:var(--text-muted)}[data-theme=dark] .word-slot--correct,[data-theme=dark] .word-slot--empty{border-bottom-color:var(--border-strong)}[data-theme=dark] .shortcut-label,[data-theme=dark] .combo-text{color:var(--text-secondary)}[data-theme=dark] .nav-arrow__tooltip{background:var(--bg-surface);color:var(--icon-color);box-shadow:0 2px 8px #0000004d}[data-theme=dark] .syntax-tooltip{background:var(--bg-surface);border-color:var(--border);box-shadow:0 8px 24px #0006}[data-theme=dark] .syntax-tooltip__english{color:var(--text-tertiary)}[data-theme=dark] .syntax-tooltip__body{color:var(--text-secondary)}[data-theme=dark] .tooltip-card{background:var(--bg-surface);border-color:var(--border);box-shadow:0 8px 24px #0006}[data-theme=dark] .app-sidebar{background:var(--bg-sidebar);border-right-color:var(--border)}[data-theme=dark] .app-sidebar__brand{border-bottom-color:var(--border)}[data-theme=dark] .app-sidebar__brand-copy strong{color:var(--text-primary)}[data-theme=dark] .app-sidebar__brand-copy span{color:var(--text-muted)}[data-theme=dark] .app-sidebar__search{background:var(--bg-surface-muted);border-color:var(--border);color:var(--text-muted)}[data-theme=dark] .app-sidebar__search input{color:var(--text-primary)}[data-theme=dark] .app-sidebar__search input::placeholder{color:var(--text-muted)}[data-theme=dark] .app-sidebar__filter{background:var(--bg-surface);border-color:var(--border);color:var(--text-tertiary)}[data-theme=dark] .app-sidebar__filter--active{background:var(--text-primary);border-color:var(--text-primary);color:var(--bg-page)}[data-theme=dark] .app-sidebar__footer{border-top-color:var(--border)}[data-theme=dark] .app-sidebar__footer-avatar{background:var(--bg-surface-muted);color:var(--text-tertiary)}[data-theme=dark] .nav-item{color:var(--text-tertiary)}[data-theme=dark] .nav-item:hover{background:var(--bg-surface-hover);color:var(--text-primary)}[data-theme=dark] .nav-item--active{color:var(--text-primary)}[data-theme=dark] .app-layout,[data-theme=dark] .app-layout__main{background:var(--bg-page)}[data-theme=dark] .app-layout__main::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb)}[data-theme=dark] .app-layout__main::-webkit-scrollbar-thumb:hover{background:var(--scrollbar-thumb-hover)}[data-theme=dark] .page-topbar{background:var(--bg-page);border-bottom-color:var(--border)}[data-theme=dark] .page-topbar__toggle-btn{border-color:var(--border);color:var(--icon-color);background:0 0}[data-theme=dark] .page-topbar__toggle-btn:hover{background:var(--bg-surface-hover)}[data-theme=dark] .page-topbar__action-btn{color:var(--icon-color);background:0 0;border-color:#0000}[data-theme=dark] .page-topbar__profile{background:var(--color-primary);color:var(--course-on-primary);border-color:#0000}[data-theme=dark] .stm-overlay{background:var(--scrim)}[data-theme=dark] .stm-header{border-bottom-color:var(--border)}[data-theme=dark] .stm-sidebar{border-right-color:var(--border)}[data-theme=dark] .stm-sidebar__item--active{background:var(--color-primary-ghost);color:var(--color-primary)}[data-theme=dark] .stm-section{border-color:var(--border)}[data-theme=dark] .stm-select{background:var(--bg-surface-muted);border-color:var(--border);color:var(--text-primary-alt)}[data-theme=dark] .stm-icon-btn{background:var(--bg-surface-muted);border-color:var(--border);color:var(--text-tertiary)}[data-theme=dark] .stm-toggle__thumb{background:var(--text-primary)}[data-theme=dark] .stm-theme-btn{background:var(--bg-surface-muted);border-color:var(--border);color:var(--text-tertiary)}[data-theme=dark] .stm-theme-btn--active{border-color:var(--color-primary);color:var(--color-primary);background:var(--color-primary-ghost)}[data-theme=dark] .stm-bg-swatch{border-color:var(--border)}[data-theme=dark] .stm-bg-swatch--active{border-color:var(--color-primary)}[data-theme=dark] .stm-bg-swatch__label{color:var(--text-secondary)}[data-theme=dark] .stm-font-preview{background:var(--bg-surface-muted);border-color:var(--border)}[data-theme=dark] .stm-font-preview__text{color:var(--text-primary)}[data-theme=dark] .stm-radio{color:var(--text-secondary)}[data-theme=dark] .stm-radio--active{color:var(--color-primary)}[data-theme=dark] .stm-radio--card{border-color:var(--border);background:var(--bg-surface-muted)}[data-theme=dark] .stm-radio--card.stm-radio--active{border-color:var(--color-primary);background:var(--color-primary-ghost)}[data-theme=dark] .stm-radio__preview{color:var(--text-primary)}[data-theme=dark] .stm-slider{background:var(--border-strong)}[data-theme=dark] .chat-panel{background:var(--bg-surface);border-color:var(--border)}[data-theme=dark] .chat-header{border-bottom-color:var(--border)}[data-theme=dark] .chat-msg--user{color:var(--text-primary);background:#3b82f626}[data-theme=dark] .chat-msg--bot{background:var(--bg-surface-muted);color:var(--text-primary)}[data-theme=dark] .chat-input{background:var(--bg-surface-muted);border-color:var(--border);color:var(--text-primary)}[data-theme=dark] .completion-overlay{background:var(--scrim)}[data-theme=dark] .completion-card{background:var(--bg-surface);color:var(--text-primary)}[data-theme=dark] .completion-card__label{color:var(--text-muted)}[data-theme=dark] .completion-card__value{color:var(--text-primary)}[data-theme=dark] .sp-overlay{background:var(--scrim)}[data-theme=dark] .sp-card{background:var(--bg-surface)}[data-theme=dark] .sp-card__title{color:var(--text-primary)}[data-theme=dark] .sp-row{border-bottom-color:var(--border)}[data-theme=dark] .sp-row__jp{color:var(--text-primary)}[data-theme=dark] .sp-row__en{color:var(--text-tertiary)}[data-theme=dark] .gp-resume-overlay{background:var(--scrim)}[data-theme=dark] .gp-resume-dialog{background:var(--bg-surface)}[data-theme=dark] .gp-resume-dialog__title{color:var(--text-primary)}[data-theme=dark] .gp-resume-dialog__desc{color:var(--text-secondary)}[data-theme=dark] .gp-resume-dialog__btn--secondary{background:var(--bg-surface-muted);color:var(--text-secondary);border-color:var(--border)}[data-theme=dark] .error-report-overlay{background:var(--scrim)}[data-theme=dark] .error-report-modal{background:var(--bg-surface)}[data-theme=dark] .error-report-modal__title{color:var(--text-primary)}[data-theme=dark] .error-report-modal__label{color:var(--text-secondary)}[data-theme=dark] .error-report-modal textarea{background:var(--bg-surface-muted);border-color:var(--border);color:var(--text-primary)}[data-theme=dark] .toast{background:var(--bg-surface);color:var(--text-primary);border-color:var(--border)}[data-theme=dark] .word-popover{background:var(--bg-surface);border-color:var(--border);box-shadow:0 8px 24px #0006}[data-theme=dark] .word-popover__word{color:var(--text-primary)}[data-theme=dark] .word-popover__phonetic{color:var(--text-tertiary)}[data-theme=dark] .word-popover__meaning{color:var(--text-secondary)}[data-theme=dark] .app-placeholder__text{color:var(--text-muted)}[data-theme=dark] .home-page,[data-theme=dark] .ll-page,[data-theme=dark] .premium-page,[data-theme=dark] .plan-page{--c-bg:var(--bg-page);--c-surface:var(--bg-surface);--c-muted:var(--bg-surface-hover);--c-border:var(--border);--c-ink:var(--text-primary-alt);--c-secondary:var(--text-tertiary);--c-tertiary:var(--text-muted);--c-accent:var(--color-primary)}[data-theme=dark] .vocab-page{--vocab-bg:var(--bg-page);--vocab-surface:var(--bg-surface);--vocab-surface-muted:var(--bg-surface-muted);--vocab-surface-subtle:var(--color-primary-ghost);--vocab-border:var(--border);--vocab-border-strong:var(--border-strong);--vocab-ink:var(--text-primary);--vocab-muted:var(--text-secondary);--vocab-subtle:var(--text-muted);--vocab-accent:var(--color-primary);--vocab-accent-hover:var(--color-primary-hover);--vocab-accent-strong:var(--color-primary-active);--vocab-accent-soft:var(--color-primary-ghost);--vocab-accent-text:var(--course-on-primary);--vocab-pill-bg:var(--bg-surface-muted)}[data-theme=dark] .course-list-page,[data-theme=dark] .lesson-list-page{background:var(--bg-page)}[data-theme=dark] .course-list-title,[data-theme=dark] .course-list-desc,[data-theme=dark] .lesson-list-desc{color:var(--text-tertiary)}[data-theme=dark] .lesson-list-meta{color:var(--text-muted)}[data-theme=dark] .course-card{background:var(--bg-surface);border-color:var(--border)}[data-theme=dark] .course-card:hover{background:var(--bg-surface-hover);box-shadow:0 8px 24px #0000004d}[data-theme=dark] .course-card__desc{color:var(--text-tertiary)}[data-theme=dark] .course-card__lesson-count{color:var(--text-muted)}[data-theme=dark] .course-card__progress-track{background:var(--border-strong)}[data-theme=dark] .lesson-card{background:var(--bg-surface);border-color:#0000}[data-theme=dark] .lesson-card:hover{background:var(--bg-surface-hover);box-shadow:0 4px 12px #0003}[data-theme=dark] .lesson-card--active{background:#7c4dff1a;border-color:#a78bfa}[data-theme=dark] .lesson-card--completed{background:#22c55e1a;border-color:#34d399}[data-theme=dark] .lesson-card__badge{color:var(--text-muted)}[data-theme=dark] .lesson-card__subtitle{color:var(--text-tertiary)}[data-theme=dark] .lesson-card__progress-track{background:var(--border-strong)}[data-theme=dark] .lesson-card__completed-badge{color:#34d399;background:#22c55e1f}[data-theme=dark] .login-page{background:var(--bg-page);color:var(--text-primary)}._root_mhzcs_1{color:var(--text-primary);justify-content:center;align-items:center;display:flex}._fullscreen_mhzcs_8{background:var(--bg-page);min-height:100vh;padding:32px}._inline_mhzcs_14{min-height:320px;padding:32px 28px}._compact_mhzcs_19{min-height:0;padding:0}._card_mhzcs_24{border:1px solid var(--border);background:var(--bg-surface);width:min(360px,100%);box-shadow:0 1px 3px color-mix(in srgb, var(--text-primary) 2%, transparent);border-radius:14px;padding:24px;animation:.4s ease-out _fadeUp_mhzcs_1}._compact_mhzcs_19 ._card_mhzcs_24{background:var(--bg-surface-muted);width:100%;box-shadow:none;border:0;border-radius:10px;padding:12px}._header_mhzcs_43{align-items:center;gap:14px;display:flex}._mark_mhzcs_49{background:var(--color-primary);width:36px;height:36px;color:var(--color-accent);font-family:var(--font-data);border-radius:10px;flex:none;justify-content:center;align-items:center;font-size:16px;font-weight:700;display:inline-flex}._compact_mhzcs_19 ._header_mhzcs_43{gap:10px}._compact_mhzcs_19 ._mark_mhzcs_49{border-radius:8px;width:28px;height:28px;font-size:12px}._title_mhzcs_75{color:var(--text-primary);margin:0;font-size:15px;font-weight:700;line-height:1.4}._compact_mhzcs_19 ._title_mhzcs_75{font-size:13px}._message_mhzcs_87{color:var(--text-secondary);margin:4px 0 0;font-size:13px;font-weight:500;line-height:1.6}._compact_mhzcs_19 ._message_mhzcs_87{font-size:12px}._track_mhzcs_99{background:var(--border);border-radius:999px;height:4px;margin-top:20px;overflow:hidden}._compact_mhzcs_19 ._track_mhzcs_99{height:3px;margin-top:12px}._bar_mhzcs_112{border-radius:inherit;background:var(--color-secondary);width:42%;height:100%;animation:1.25s ease-in-out infinite _loadingSweep_mhzcs_1;display:block}@keyframes _loadingSweep_mhzcs_1{0%{transform:translate(-120%)}to{transform:translate(260%)}}@keyframes _fadeUp_mhzcs_1{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@media (width<=767px){._fullscreen_mhzcs_8,._inline_mhzcs_14{padding:24px 16px}._card_mhzcs_24{padding:20px}}._content_1qm1g_1{flex-direction:column;gap:8px;display:flex}._paragraph_1qm1g_7{margin:0}._heading_1qm1g_11{color:var(--text-primary);margin:0 0 2px;font-size:14px;font-weight:700}._listItem_1qm1g_18{grid-template-columns:auto 1fr;align-items:start;gap:8px;display:grid}._marker_1qm1g_25{min-width:16px;color:var(--text-tertiary);text-align:right;font-weight:700}._strong_1qm1g_32{color:var(--text-primary);font-weight:700}._emphasis_1qm1g_37{color:var(--color-primary);font-style:italic}._code_1qm1g_42{background:var(--color-primary-ghost);color:var(--color-primary);font-family:var(--font-mono);border-radius:5px;padding:1px 5px;font-size:.94em;font-weight:600;display:inline-block}._shortcuts_1jj78_3{background:var(--bg-surface);border:1px solid var(--uchi-line);border-radius:16px;flex-direction:column;padding:20px 24px;display:flex;box-shadow:0 1px 3px #2e35280a}._header_1jj78_14{border-bottom:1px solid var(--uchi-line);justify-content:space-between;align-items:center;gap:16px;margin-bottom:2px;padding-bottom:14px;display:flex}._hint_1jj78_24{color:var(--text-secondary);margin:0;font-size:12.5px;font-weight:500;line-height:1.6}._reset_1jj78_32{border:1px solid var(--uchi-rose);background:var(--bg-surface);min-height:34px;color:var(--uchi-rose-deep);cursor:pointer;border-radius:10px;padding:0 14px;font-family:inherit;font-size:12px;font-weight:700;transition:background .15s,border-color .15s}._reset_1jj78_32:hover{background:var(--uchi-tag-rose-bg)}._row_1jj78_50{border-bottom:1px solid var(--uchi-line);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding:16px 0;display:flex}._row_1jj78_50:last-child{border-bottom:none}._label_1jj78_63{color:var(--text-primary-alt);font-size:14px;font-weight:600;line-height:1.5}._keys_1jj78_70{align-items:center;gap:4px;display:flex}._kbd_1jj78_76{border:1px solid var(--uchi-line);background:var(--uchi-row-alt);min-width:32px;height:28px;color:var(--text-secondary);border-radius:8px;justify-content:center;align-items:center;padding:0 8px;font-family:inherit;font-size:12px;font-weight:600;display:inline-flex}._edit_1jj78_92{min-height:30px;color:var(--course-on-primary);cursor:pointer;background:var(--color-primary);border:1px solid var(--color-primary);border-radius:10px;margin-left:10px;padding:0 12px;font-family:inherit;font-size:12px;font-weight:700;transition:background .15s,transform .15s}._edit_1jj78_92:hover:not(:disabled){background:var(--color-primary-hover);transform:translateY(-1px)}._edit_1jj78_92:disabled{opacity:.5;cursor:default}._recording_1jj78_116{border:1px dashed var(--color-primary);color:var(--color-primary);border-radius:8px;align-items:center;padding:4px 10px;font-size:12px;font-weight:600;animation:1.4s ease-in-out infinite _recording-pulse_1jj78_1;display:inline-flex}@keyframes _recording-pulse_1jj78_1{0%,to{opacity:1}50%{opacity:.55}}._error_1jj78_133{color:var(--uchi-rose-deep);flex-basis:100%;margin-top:6px;font-size:12px;font-weight:600}._rowFixed_1jj78_142{opacity:.6}@media (width<=560px){._shortcuts_1jj78_3{padding:18px}._header_1jj78_14{flex-direction:column;align-items:flex-start;gap:10px}._keys_1jj78_70{flex-wrap:wrap;justify-content:flex-start}}._backdrop_1sjoo_3{z-index:1000;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#28241e6b;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}._modal_1sjoo_15{background:var(--bg-surface);border:1px solid var(--uchi-line);width:min(940px,100%);max-height:92vh;box-shadow:0 40px 90px #3c322838, 0 0 0 1px var(--uchi-line);border-radius:18px;display:flex;overflow:hidden}._sidebar_1sjoo_28{border-right:1px solid var(--uchi-line);background:#fbfaf7;flex-direction:column;flex:0 0 300px;width:300px;padding:30px 22px;display:flex}._sidebarTitle_1sjoo_38{color:var(--text-primary);font-family:var(--font-serif);margin:0;font-size:22px;font-weight:400;line-height:1.25}._sidebarKicker_1sjoo_47{color:var(--uchi-ink-4);font-family:var(--font-mono);letter-spacing:.06em;margin:7px 0 0;font-size:10.5px;font-weight:500}._modeList_1sjoo_56{flex-direction:column;gap:6px;margin:24px 0 0;padding:0;list-style:none;display:flex}._modeButton_1sjoo_65{--pm-tone-bg:var(--uchi-primary-soft);--pm-tone-stroke:var(--uchi-sage-mid);--pm-tone-deep:var(--uchi-primary);width:100%;min-height:72px;color:var(--text-primary);font:inherit;text-align:left;cursor:pointer;background:0 0;border:1.5px solid #0000;border-radius:12px;grid-template-columns:40px 1fr 16px;align-items:center;gap:12px;padding:10px 12px;transition:background .14s,border-color .14s,box-shadow .14s;display:grid}._modeButton_1sjoo_65[data-tone=pacific]{--pm-tone-bg:#e6f1ef;--pm-tone-stroke:#6ea6a0;--pm-tone-deep:#2f6f69}._modeButton_1sjoo_65[data-tone=rose]{--pm-tone-bg:var(--uchi-tag-rose-bg);--pm-tone-stroke:var(--uchi-rose);--pm-tone-deep:var(--uchi-rose-deep)}._modeButton_1sjoo_65[data-tone=teal]{--pm-tone-bg:#e6eee4;--pm-tone-stroke:var(--uchi-sage-mid);--pm-tone-deep:#3d5e3a}._modeButton_1sjoo_65:hover,._modeButtonSelected_1sjoo_105{background:var(--bg-surface);border-color:var(--pm-tone-stroke)}._modeButtonSelected_1sjoo_105{box-shadow:0 10px 20px #3c32280f}._modeIconBox_1sjoo_114{width:40px;height:40px;color:var(--pm-tone-deep);background:var(--pm-tone-bg);border-radius:12px;place-items:center;display:grid}._modeText_1sjoo_124{flex-direction:column;gap:2px;min-width:0;display:flex}._modeTitle_1sjoo_131{color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;font-size:13.5px;font-weight:700;line-height:1.3;overflow:hidden}._modeButton_1sjoo_65>svg{color:var(--uchi-ink-4)}._activeDot_1sjoo_145{background:var(--pm-tone-stroke);border-radius:50%;justify-self:center;width:6px;height:6px}._lessonFoot_1sjoo_153{color:var(--text-secondary);flex-direction:column;gap:5px;margin-top:auto;display:flex}._lessonFoot_1sjoo_153 span{color:var(--uchi-ink-4);font-family:var(--font-mono);letter-spacing:.08em;font-size:10.5px;font-weight:700}._lessonFoot_1sjoo_153 strong{font-size:13px;font-weight:700;line-height:1.35}._detail_1sjoo_175{--pm-tone-bg:var(--uchi-primary-soft);--pm-tone-stroke:var(--uchi-sage-mid);--pm-tone-deep:var(--uchi-primary);background:var(--bg-surface);flex-direction:column;flex:1;min-width:0;display:flex}._detail_1sjoo_175[data-tone=pacific]{--pm-tone-bg:#e6f1ef;--pm-tone-stroke:#6ea6a0;--pm-tone-deep:#2f6f69}._detail_1sjoo_175[data-tone=rose]{--pm-tone-bg:var(--uchi-tag-rose-bg);--pm-tone-stroke:var(--uchi-rose);--pm-tone-deep:var(--uchi-rose-deep)}._detail_1sjoo_175[data-tone=teal]{--pm-tone-bg:#e6eee4;--pm-tone-stroke:var(--uchi-sage-mid);--pm-tone-deep:#3d5e3a}._hero_1sjoo_204{background:radial-gradient(circle at 78% 18%, #ffffffc2 0 38px, transparent 39px), linear-gradient(135deg, var(--course-hero-from) 0%, var(--course-hero-to) 100%);min-height:200px;position:relative;overflow:hidden}._heroGlyph_1sjoo_213{z-index:2;width:52px;height:52px;color:var(--pm-tone-deep);background:#ffffffe0;border-radius:12px;place-items:center;display:grid;position:absolute;top:32px;left:54px}._heroHill_1sjoo_227{background:#d0e6e1c2;border-radius:54% 46% 0 0/100% 100% 0 0;height:72px;position:absolute;bottom:-14px;left:60px;right:-120px}._heroMoon_1sjoo_237{border:1px solid #ffffff8c;border-radius:50%;width:148px;height:148px;position:absolute;top:14px;right:47px;box-shadow:0 0 0 22px #ffffff2e,0 0 0 48px #ffffff29}._heroMoon_1sjoo_237 i{background:#71b1ab29;border:18px solid #71b1ab24;border-radius:50%;position:absolute;inset:48px}._heroDotA_1sjoo_258,._heroDotB_1sjoo_259{background:#7fa0966b;border-radius:50%;width:5px;height:5px;position:absolute}._heroDotA_1sjoo_258{top:42px;left:142px}._heroDotB_1sjoo_259{top:96px;left:110px}._heroLineA_1sjoo_277,._heroLineB_1sjoo_278,._heroGrassA_1sjoo_279,._heroGrassB_1sjoo_280{border-color:#49807457;display:block;position:absolute}._heroLineA_1sjoo_277{border-top:1px solid;border-radius:50%;width:54px;height:16px;top:82px;left:100px}._heroLineB_1sjoo_278{border-left:2px solid;border-right:2px solid;width:30px;height:25px;bottom:38px;left:250px}._heroGrassA_1sjoo_279,._heroGrassB_1sjoo_280{border-left:8px solid #7e957538;border-radius:50%;width:24px;height:42px;bottom:12px;transform:rotate(34deg)}._heroGrassA_1sjoo_279{right:80px}._heroGrassB_1sjoo_280{height:28px;right:56px;transform:rotate(48deg)}._closeButton_1sjoo_324{z-index:3;width:32px;height:32px;color:var(--text-secondary);cursor:pointer;border:1px solid var(--uchi-line);background:#ffffffeb;border-radius:50%;place-items:center;display:grid;position:absolute;top:18px;right:18px;box-shadow:0 8px 18px #3c322814}._detailBody_1sjoo_341{flex-direction:column;flex:1;padding:24px 32px 28px;display:flex}._metaLine_1sjoo_348{flex-wrap:wrap;align-items:center;gap:12px;display:flex}._recommendBadge_1sjoo_355{color:var(--pm-tone-deep);background:var(--pm-tone-bg);border-radius:999px;align-items:center;gap:6px;padding:3px 10px;font-size:11px;font-weight:800;line-height:1.4;display:inline-flex}._recommendBadge_1sjoo_355:before{content:"";background:var(--pm-tone-stroke);border-radius:50%;width:6px;height:6px}._tagline_1sjoo_376{color:var(--uchi-ink-3);font-family:var(--font-mono);letter-spacing:.03em;font-size:10.5px;font-weight:500}._detailTitle_1sjoo_384{color:var(--text-primary);font-family:var(--font-serif);letter-spacing:-.02em;margin:12px 0 0;font-size:36px;font-weight:400;line-height:1.15}._detailDesc_1sjoo_394{color:var(--text-secondary);border-left:2px solid var(--pm-tone-stroke);margin:12px 0 0;padding-left:14px;font-size:13px;font-weight:400;line-height:1.75}._difficultySection_1sjoo_404{margin-top:24px}._difficultyHead_1sjoo_408{color:var(--text-secondary);justify-content:space-between;align-items:center;gap:16px;font-size:12.5px;font-weight:700;display:flex}._difficultyHead_1sjoo_408:before{content:"";border-bottom:2px solid var(--text-secondary);border-left:2px solid var(--text-secondary);width:12px;height:10px;transform:skew(-28deg)rotate(-45deg)}._difficultyHead_1sjoo_408 span{margin-right:auto}._difficultyHead_1sjoo_408 strong{color:var(--pm-tone-deep);font-size:11px;font-weight:700}._difficultyGrid_1sjoo_437{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-top:14px;display:grid}._difficultyCard_1sjoo_444{min-height:118px;color:var(--text-primary);font:inherit;text-align:center;cursor:pointer;background:var(--bg-surface);border:1px solid var(--uchi-line);border-radius:12px;flex-direction:column;justify-content:center;align-items:center;padding:16px 10px 14px;transition:background .14s,border-color .14s;display:flex;position:relative}._difficultyCard_1sjoo_444:hover,._difficultyCardSelected_1sjoo_463{border-color:var(--pm-tone-stroke)}._difficultyCardSelected_1sjoo_463{background:var(--pm-tone-bg);border-width:1.5px}._difficultyBadge_1sjoo_472{color:#fff;background:var(--uchi-rose);border-radius:999px;padding:3px 9px;font-size:9.5px;font-weight:800;line-height:1.2;position:absolute;top:-10px;right:8px}._difficultyName_1sjoo_485{color:var(--pm-tone-deep);font-size:16px;font-weight:800;line-height:1.4}._difficultyDesc_1sjoo_492{color:var(--text-tertiary);margin-top:3px;font-size:11.5px;font-weight:500;line-height:1.45}._bars_1sjoo_500{align-items:end;gap:3px;height:18px;margin-top:13px;display:inline-flex}._bars_1sjoo_500 i{background:var(--pm-tone-stroke);opacity:.52;border-radius:999px;width:4px}._bars_1sjoo_500 i:first-child{height:8px}._bars_1sjoo_500 i:nth-child(2){opacity:.82;height:12px}._bars_1sjoo_500 i:nth-child(3){opacity:.28;height:16px}._footer_1sjoo_529{border-top:1px solid var(--uchi-line);gap:12px;margin-top:auto;padding-top:20px;display:flex}._btnSecondary_1sjoo_537,._btnPrimary_1sjoo_538{min-height:46px;font:inherit;cursor:pointer;border-radius:12px;padding:0 28px;font-size:14px;font-weight:800;transition:transform .12s,box-shadow .12s,background .12s}._btnSecondary_1sjoo_537{min-width:186px;color:var(--uchi-rose-deep);background:var(--bg-surface);border:1px solid var(--uchi-rose)}._btnPrimary_1sjoo_538{color:#fff;background:var(--pm-tone-deep);border:1px solid var(--pm-tone-deep);flex:1;box-shadow:0 8px 16px #15564e24}._btnSecondary_1sjoo_537:hover,._btnPrimary_1sjoo_538:hover{transform:translateY(-1px)}._srOnly_1sjoo_569{white-space:nowrap;clip:rect(0, 0, 0, 0);border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}@media (width<=780px){._backdrop_1sjoo_3{align-items:stretch;padding:12px}._modal_1sjoo_15{max-height:calc(100vh - 24px);display:block;overflow-y:auto}._sidebar_1sjoo_28{border-right:0;border-bottom:1px solid var(--uchi-line);width:100%;padding:24px 18px 18px}._modeList_1sjoo_56{margin-top:18px}._lessonFoot_1sjoo_153{margin-top:20px}._hero_1sjoo_204{min-height:160px}._heroGlyph_1sjoo_213{left:28px}._heroHill_1sjoo_227{left:0;right:-24px}._heroMoon_1sjoo_237{right:-12px}._detailBody_1sjoo_341{padding:22px 18px 20px}._detailTitle_1sjoo_384{font-size:30px}._difficultyHead_1sjoo_408{align-items:flex-start}._difficultyHead_1sjoo_408 strong{text-align:right}._footer_1sjoo_529{flex-direction:column-reverse}._btnSecondary_1sjoo_537{min-width:0}}@media (width<=520px){._difficultyGrid_1sjoo_437{grid-template-columns:1fr}._modeButton_1sjoo_65{grid-template-columns:40px 1fr 16px}}._page_59cyy_1,._empty_59cyy_2{--bg-page:var(--exercise-bg-page);--bg-surface:var(--exercise-bg-surface);--bg-surface-hover:var(--exercise-bg-surface-hover);--bg-surface-muted:var(--exercise-bg-surface-muted);--text-primary:var(--exercise-text-primary);--text-primary-alt:var(--exercise-text-primary-alt);--text-secondary:var(--exercise-text-secondary);--text-tertiary:var(--exercise-text-tertiary);--text-muted:var(--exercise-text-muted);--border:var(--exercise-border);--border-strong:var(--exercise-border-strong);--icon-color:var(--exercise-icon-color);--color-primary:var(--exercise-primary);--color-primary-hover:var(--exercise-primary-hover);--color-primary-active:var(--exercise-primary-active);--color-primary-ghost:var(--exercise-primary-ghost);--color-secondary:var(--exercise-secondary);--color-secondary-hover:var(--exercise-secondary-hover);--color-input-bg:var(--exercise-input-bg);--color-border-input:var(--exercise-border-input)}._page_59cyy_1{background:var(--exercise-bg,var(--bg-page));width:100vw;height:100vh;color:var(--text-primary);font-family:var(--app-font,var(--font-jp));flex-direction:column;display:flex;overflow:hidden}._practiceMeta_59cyy_36{flex-shrink:0;justify-content:flex-start;align-items:center;gap:12px;padding:16px 30px 0;display:flex}._timerOnly_59cyy_45{align-items:center;gap:6px;display:flex}._timerOnly_59cyy_45 .timer-icon{width:22px;height:22px;color:var(--text-muted)}._timerOnly_59cyy_45 .timer{color:var(--text-muted);font-family:var(--font-data);font-size:22px;font-weight:700}._stepBubble_59cyy_64{border:3px solid var(--border);border-top-color:var(--color-secondary);width:40px;height:40px;color:var(--text-secondary);font-family:var(--font-data);border-radius:999px;justify-content:center;align-items:center;font-size:11px;font-weight:800;display:inline-flex}._peekButton_59cyy_79{z-index:5;border:1px solid var(--border);background:var(--bg-surface);width:56px;height:56px;color:var(--text-secondary);cursor:pointer;border-radius:18px;justify-content:center;align-items:center;transition:color .15s,border-color .15s,background .15s;display:inline-flex;position:fixed;top:106px;right:30px}._peekButton_59cyy_79:hover,._peekButton_59cyy_79[aria-pressed=true]{color:var(--color-primary);border-color:var(--border-strong);background:var(--bg-surface-hover)}._main_59cyy_104,._answerMain_59cyy_105{flex:1;width:min(1080px,100% - 32px);min-height:0;margin:0 auto}._main_59cyy_104{justify-content:center;align-items:center;padding-bottom:84px;display:flex}._answerMain_59cyy_105{justify-content:center;align-items:flex-start;padding-top:84px;padding-bottom:40px;display:flex;overflow:auto}._loading_59cyy_128,._empty_59cyy_2{min-height:100vh;color:var(--text-secondary);background:var(--exercise-bg,var(--bg-page));place-items:center;font-weight:600;display:grid}._recordStage_59cyy_138{text-align:center;flex-direction:column;align-items:center;gap:18px;width:min(420px,100%);display:flex;transform:translateY(56px)}._promptBlock_59cyy_148{flex-direction:column;align-items:center;gap:16px;width:100%;display:flex}._promptIcon_59cyy_156{color:var(--text-tertiary)}._promptInstruction_59cyy_160{color:var(--text-secondary);margin:0;font-size:14px;font-weight:600}._prompt_59cyy_148{clip:rect(0 0 0 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}._answerBox_59cyy_179{border:1px dashed var(--border-strong);background:var(--bg-surface-muted);text-align:left;border-radius:14px;flex-direction:column;gap:6px;width:min(620px,100%);padding:14px 16px;display:flex}._answerBox_59cyy_179 span{color:var(--text-tertiary);font-size:12px;font-weight:700}._answerBox_59cyy_179 strong{color:var(--text-primary);font-family:var(--font-en);font-size:22px;font-weight:700;line-height:1.4}._recordButton_59cyy_205{border:1px solid var(--color-primary);background:var(--color-primary);color:#fff;width:100px;height:100px;font:inherit;cursor:pointer;touch-action:none;border-radius:999px;justify-content:center;align-items:center;margin-top:42px;transition:transform .15s,background .15s,border-color .15s;display:flex}._recordButton_59cyy_205:hover:not(:disabled){background:var(--color-primary-hover);border-color:var(--color-primary-hover)}._recordButton_59cyy_205:disabled{cursor:wait;opacity:.75}._recordLabel_59cyy_232{flex-direction:column;align-items:center;gap:8px;display:flex}._recordLabel_59cyy_232 strong{color:var(--text-primary);font-size:16px;font-weight:700}._recordLabel_59cyy_232 span{color:var(--text-secondary);font-size:12px;font-weight:700;line-height:1.4}._recording_59cyy_252{background:var(--color-primary-active);border-color:var(--color-primary-active);transform:scale(.96)}._visuallyHidden_59cyy_258{clip:rect(0 0 0 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}._answerStage_59cyy_270{flex-direction:column;align-items:center;gap:28px;width:min(1080px,100%);display:flex}._metricGrid_59cyy_278{grid-template-columns:repeat(4,minmax(0,1fr));gap:20px;width:min(1080px,100%);display:grid}._metricCard_59cyy_285{border:1px solid var(--border);background:var(--bg-surface);border-radius:14px;flex-direction:column;gap:24px;min-height:128px;padding:20px 24px 22px;display:flex;box-shadow:0 1px 3px #00000005}._metricLabel_59cyy_297{color:var(--text-secondary);align-items:center;gap:10px;font-size:13px;font-weight:700;display:inline-flex}._metricCard_59cyy_285:first-child ._metricLabel_59cyy_297 svg{color:var(--color-secondary)}._metricCard_59cyy_285:nth-child(2) ._metricLabel_59cyy_297 svg{color:var(--color-primary)}._metricCard_59cyy_285:nth-child(3) ._metricLabel_59cyy_297 svg{color:var(--color-err)}._metricCard_59cyy_285:nth-child(4) ._metricLabel_59cyy_297 svg{color:var(--color-primary)}._metricCard_59cyy_285 strong{color:var(--text-primary);font-family:var(--font-data);font-size:28px;font-weight:700;line-height:1}._metricCard_59cyy_285 small{color:var(--text-tertiary);font-size:14px;font-weight:700}._answerCenter_59cyy_336{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:20px;width:min(720px,100%);min-height:220px;display:flex}._targetText_59cyy_347{color:var(--text-primary);font-family:var(--font-en);margin:0;font-size:30px;font-weight:700;line-height:1.45}._feedbackBlock_59cyy_356{border:1px solid var(--border);background:var(--bg-surface);text-align:left;border-radius:14px;flex-direction:column;gap:12px;width:min(620px,100%);padding:16px;display:flex}._feedbackBlock_59cyy_356 p{color:var(--text-primary);margin:0;font-size:14px;font-weight:600;line-height:1.7}._feedbackBlock_59cyy_356 dl{margin:0}._feedbackBlock_59cyy_356 div{flex-direction:column;gap:6px;display:flex}._feedbackBlock_59cyy_356 dt{color:var(--text-tertiary);font-size:12px;font-weight:700}._feedbackBlock_59cyy_356 dd{color:var(--text-primary);font-family:var(--font-en);margin:0;font-size:18px;font-weight:700;line-height:1.5}._feedbackHint_59cyy_401{color:var(--text-secondary);margin:0;font-size:14px;font-weight:600}@media (width<=760px){._main_59cyy_104,._answerMain_59cyy_105{width:min(100% - 24px,1080px)}._main_59cyy_104{padding-bottom:64px}._answerMain_59cyy_105{padding-top:32px}._practiceMeta_59cyy_36{padding-top:12px;padding-left:20px}._peekButton_59cyy_79{border-radius:16px;width:48px;height:48px;top:98px;right:18px}._recordStage_59cyy_138{transform:translateY(24px)}._recordButton_59cyy_205{margin-top:24px}._metricGrid_59cyy_278{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}._metricCard_59cyy_285{padding:14px}._targetText_59cyy_347{font-size:24px}}._panel_1j8xi_1{justify-content:center;align-items:flex-start;width:100%;display:flex}._frame_1j8xi_9{--letterbox-bg:#0f0f10;aspect-ratio:4/5;background:var(--letterbox-bg);border-radius:16px;justify-content:center;align-items:center;width:min(100%,80vh - 128px);max-height:calc(100vh - 160px);display:flex;position:relative;overflow:hidden}._player_1j8xi_27{aspect-ratio:16/9;width:100%;position:relative}._mount_1j8xi_27{width:100%;height:100%}._player_1j8xi_27 iframe{display:block;width:100%!important;height:100%!important}._captionsMask_1j8xi_48{z-index:2;background:var(--letterbox-bg);pointer-events:none;height:clamp(48px,14%,72px);position:absolute;bottom:0;left:0;right:0}._blocker_1j8xi_62{z-index:1;cursor:default;background:0 0;position:absolute;inset:0}._status_1j8xi_60{z-index:3;color:var(--text-secondary);background:var(--bg-surface);place-items:center;display:grid;position:absolute;inset:0}@media (width<=900px){._frame_1j8xi_9{width:100%;max-height:none}}._panel_14b1m_5{flex-direction:column;width:100%;min-height:100%;padding:24px 32px;display:flex}._inputArea_14b1m_13{flex-direction:column;flex:1;justify-content:center;align-items:stretch;gap:24px;padding:24px 0;display:flex}._page_2viia_1,._empty_2viia_2{--bg-page:var(--exercise-bg-page);--bg-surface:var(--exercise-bg-surface);--bg-surface-hover:var(--exercise-bg-surface-hover);--bg-surface-muted:var(--exercise-bg-surface-muted);--text-primary:var(--exercise-text-primary);--text-primary-alt:var(--exercise-text-primary-alt);--text-secondary:var(--exercise-text-secondary);--text-tertiary:var(--exercise-text-tertiary);--text-muted:var(--exercise-text-muted);--border:var(--exercise-border);--border-strong:var(--exercise-border-strong);--icon-color:var(--exercise-icon-color);--color-primary:var(--exercise-primary);--color-primary-hover:var(--exercise-primary-hover);--color-primary-active:var(--exercise-primary-active);--color-primary-ghost:var(--exercise-primary-ghost);--color-secondary:var(--exercise-secondary);--color-secondary-hover:var(--exercise-secondary-hover);--color-input-bg:var(--exercise-input-bg);--color-border-input:var(--exercise-border-input)}._page_2viia_1{background:var(--exercise-bg,var(--bg-page));min-height:100vh;color:var(--text-primary);font-family:var(--app-font,var(--font-jp));position:relative}._content_2viia_33{grid-template-columns:minmax(0,1fr) minmax(0,1.7fr);align-items:start;gap:48px;max-width:1536px;margin:0 auto;padding:24px;display:grid}@media (width<=900px){._content_2viia_33{grid-template-columns:1fr;gap:24px}}._empty_2viia_2{background:var(--exercise-bg,var(--bg-page));min-height:100vh;color:var(--text-secondary);font-family:var(--app-font,var(--font-jp));place-items:center;display:grid}._done_2viia_64{border:1px solid var(--border);background:var(--bg-surface);text-align:center;border-radius:20px;width:min(560px,100% - 32px);margin:40px auto;padding:32px}._doneButton_2viia_74{color:#fff;background:var(--color-primary);cursor:pointer;border:0;border-radius:9999px;margin-top:24px;padding:12px 24px;font-weight:700}._page_kefmi_1,._empty_kefmi_2{--bg-page:var(--exercise-bg-page);--bg-surface:var(--exercise-bg-surface);--bg-surface-hover:var(--exercise-bg-surface-hover);--bg-surface-muted:var(--exercise-bg-surface-muted);--text-primary:var(--exercise-text-primary);--text-primary-alt:var(--exercise-text-primary-alt);--text-secondary:var(--exercise-text-secondary);--text-tertiary:var(--exercise-text-tertiary);--text-muted:var(--exercise-text-muted);--border:var(--exercise-border);--border-strong:var(--exercise-border-strong);--icon-color:var(--exercise-icon-color);--color-primary:var(--exercise-primary);--color-primary-hover:var(--exercise-primary-hover);--color-primary-active:var(--exercise-primary-active);--color-primary-ghost:var(--exercise-primary-ghost);--color-secondary:var(--exercise-secondary);--color-secondary-hover:var(--exercise-secondary-hover);--color-input-bg:var(--exercise-input-bg);--color-border-input:var(--exercise-border-input)}._page_kefmi_1{background:var(--bg-page);height:100vh;color:var(--text-primary);flex-direction:column;display:flex;overflow:hidden}._layout_kefmi_34{flex:1;grid-template-columns:minmax(0,1fr) 360px;gap:20px;width:100%;max-width:1600px;min-height:0;margin:0 auto;padding:20px 24px 24px;display:grid;overflow:hidden}._playerColumn_kefmi_47{min-width:0;min-height:0;padding-right:4px;overflow-y:auto}._playerCard_kefmi_54{flex-direction:column;gap:16px;display:flex}._playerFrame_kefmi_60{border:1px solid var(--border);background:var(--bg-surface);aspect-ratio:16/9;border-radius:20px;position:relative;overflow:hidden}._playerMount_kefmi_69{width:100%;height:100%}._playerMount_kefmi_69 iframe{display:block;width:100%!important;height:100%!important}._playerShade_kefmi_80{background:linear-gradient(180deg, transparent 0%, color-mix(in srgb, var(--scrim) 22%, transparent) 34%, color-mix(in srgb, var(--scrim) 56%, transparent) 100%);pointer-events:none;z-index:1;height:42%;position:absolute;inset:auto 0 0}._status_kefmi_94{background:color-mix(in srgb, var(--bg-surface) 88%, transparent);color:var(--text-secondary);z-index:4;place-items:center;font-size:14px;font-weight:600;display:grid;position:absolute;inset:0}._centerPlay_kefmi_106{border:1px solid var(--border-strong);background:color-mix(in srgb, var(--bg-surface) 76%, transparent);width:84px;height:84px;color:var(--text-primary);cursor:pointer;z-index:5;border-radius:999px;justify-content:center;align-items:center;margin:auto;display:inline-flex;position:absolute;inset:0}._controlsCard_kefmi_123,._sidebar_kefmi_124{border:1px solid var(--border);background:var(--bg-surface);border-radius:20px}._captionOverlay_kefmi_130{pointer-events:none;z-index:3;justify-content:center;display:flex;position:absolute;bottom:12px;left:10px;right:10px}._captionCard_kefmi_141{border:1px solid color-mix(in srgb, var(--border-strong) 72%, transparent);background:color-mix(in srgb, var(--bg-surface) 92%, transparent);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);pointer-events:auto;border-radius:18px;width:100%;max-width:none;padding:10px 12px 12px;box-shadow:0 14px 32px #00000029}._captionMeta_kefmi_153{justify-content:space-between;align-items:center;gap:12px;margin-bottom:10px;display:flex}._captionIndex_kefmi_161,._captionTime_kefmi_162{color:var(--text-tertiary);font-size:11px;font-weight:700}._captionIndex_kefmi_161{font-family:var(--font-data)}._captionTime_kefmi_162{font-family:var(--font-mono)}._captionAnswer_kefmi_176{flex-direction:column;align-items:center;gap:8px;width:100%;display:flex}._captionAnswer_kefmi_176 .words-row--answer{justify-content:center;gap:10px 8px;width:100%;max-width:none}._captionAnswer_kefmi_176 .word-column{gap:0;min-width:0}._captionAnswer_kefmi_176 .phonetic-row{height:16px;margin-bottom:2px}._captionAnswer_kefmi_176 .phonetic{padding:1px 4px;font-size:9px}._captionAnswer_kefmi_176 .word-box{padding-bottom:2px}._captionAnswer_kefmi_176 .word-text{padding:1px 2px;font-size:clamp(15px,1.55vw,26px);line-height:1.03}._captionAnswer_kefmi_176 .word-underline-bar{height:2px;margin-top:0}._captionAnswer_kefmi_176 .pos-tag{margin-top:3px;padding:1px 5px;font-size:9px}._captionAnswer_kefmi_176 .word-meaning{max-width:78px;margin-top:3px;font-size:10px}._captionAnswer_kefmi_176 .word-box--clickable:hover .word-text,._captionAnswer_kefmi_176 .word-box--active .word-text{color:var(--color-primary)}._captionAnswer_kefmi_176 .japanese-sentence{margin-top:8px;font-size:clamp(14px,1.25vw,18px);line-height:1.4}._captionFallback_kefmi_244{text-align:center;flex-direction:column;align-items:center;gap:8px;display:flex}._captionFallbackEnglish_kefmi_252{font-family:var(--font-en);color:var(--text-primary);margin:0;font-size:clamp(22px,2.4vw,34px);line-height:1.25}._captionFallbackJapanese_kefmi_260{color:var(--text-secondary);margin:0;font-size:15px;line-height:1.6}._controlsCard_kefmi_123{flex-direction:column;gap:14px;padding:14px 16px 16px;display:flex}._controlsProgress_kefmi_274{background:var(--bg-surface-muted);border-radius:999px;height:6px;overflow:hidden}._controlsProgressFill_kefmi_281{background:var(--color-primary);border-radius:999px;height:100%;transition:width .25s}._controlsRow_kefmi_288{justify-content:space-between;align-items:center;gap:16px;display:flex}._controlsPrimary_kefmi_295{align-items:center;gap:10px;display:flex}._controlButton_kefmi_301{border:1px solid var(--border);background:var(--bg-surface);min-height:42px;color:var(--text-primary);cursor:pointer;border-radius:999px;justify-content:center;align-items:center;gap:8px;padding:0 14px;font-size:13px;font-weight:700;display:inline-flex}._controlButton_kefmi_301:disabled{cursor:default;color:var(--text-muted)}._controlButtonPrimary_kefmi_322{border-color:var(--color-primary);background:var(--color-primary);color:var(--bg-surface)}._controlsMeta_kefmi_328{color:var(--text-secondary);align-items:center;gap:14px;font-size:12px;font-weight:600;display:flex}._controlsMeta_kefmi_328 span:first-child{font-family:var(--font-mono)}._sidebar_kefmi_124{flex-direction:column;align-self:stretch;min-height:0;display:flex;overflow:hidden}._sidebarHeader_kefmi_349{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:10px;padding:18px 18px 14px;display:flex}._sidebarTitle_kefmi_358{color:var(--text-primary);margin:0;font-size:16px;font-weight:700}._sidebarCount_kefmi_365{color:var(--text-tertiary);font-size:12px;font-weight:700;font-family:var(--font-data)}._sidebarList_kefmi_372{overscroll-behavior:contain;scrollbar-gutter:stable;flex-direction:column;flex:1;gap:8px;min-height:0;padding:8px;display:flex;overflow-y:auto}._sidebarItem_kefmi_384{text-align:left;cursor:pointer;background:0 0;border:1px solid #0000;border-radius:16px;gap:4px;width:100%;padding:12px 12px 12px 14px;display:grid}._sidebarItemActive_kefmi_396{border-color:var(--color-primary);background:var(--color-primary-ghost)}._sidebarTime_kefmi_401{color:var(--color-primary);font-size:11px;font-weight:700;font-family:var(--font-data)}._sidebarEnglish_kefmi_408{font-family:var(--font-en);color:var(--text-primary);font-size:18px;line-height:1.25}._sidebarJapanese_kefmi_415{color:var(--text-secondary);font-size:13px;line-height:1.5}._empty_kefmi_2{background:var(--bg-page);min-height:100vh;color:var(--text-secondary);place-items:center;display:grid}@media (width<=1100px){._layout_kefmi_34{grid-template-columns:1fr;overflow-y:auto}._sidebar_kefmi_124{min-height:320px}._playerColumn_kefmi_47{padding-right:0;overflow:visible}}@media (width<=768px){._layout_kefmi_34{gap:16px;padding:16px}._controlsCard_kefmi_123,._sidebar_kefmi_124{border-radius:16px}._captionOverlay_kefmi_130{bottom:8px;left:8px;right:8px}._captionCard_kefmi_141{padding:8px 10px 10px}._captionMeta_kefmi_153{margin-bottom:8px}._controlsRow_kefmi_288{flex-direction:column;align-items:stretch}._controlsPrimary_kefmi_295,._controlsMeta_kefmi_328{justify-content:center}._captionAnswer_kefmi_176 .words-row--answer{gap:8px 6px}._captionAnswer_kefmi_176 .word-text{font-size:clamp(13px,4.2vw,20px)}._captionAnswer_kefmi_176 .word-meaning{max-width:62px;font-size:9px}._captionAnswer_kefmi_176 .japanese-sentence{margin-top:7px;font-size:13px}._sidebarHeader_kefmi_349{padding:16px}}._card_4ix3p_1{border:1px solid var(--uchi-line);background:var(--bg-surface);width:100%;min-width:0;color:var(--text-primary);text-align:left;cursor:pointer;border-radius:12px;grid-template-rows:150px auto;padding:0;font-family:inherit;transition:border-color .2s,background .2s,transform .2s;display:grid;position:relative;overflow:hidden}._card_4ix3p_1:hover{border-color:var(--uchi-sage-mid);transform:translateY(-2px)}._card_4ix3p_1:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}._badge_4ix3p_29{z-index:1;border:1px solid var(--uchi-line);background:var(--bg-surface);min-height:22px;color:var(--text-secondary);border-radius:999px;align-items:center;padding:0 10px;font-size:10px;font-weight:800;line-height:1;display:inline-flex;position:absolute;top:10px;left:12px}._coverWrap_4ix3p_47{background:var(--book-card-green);justify-content:center;align-items:center;display:flex}._green_4ix3p_54 ._coverWrap_4ix3p_47{background:var(--book-card-green)}._peach_4ix3p_58 ._coverWrap_4ix3p_47{background:var(--book-card-peach)}._sand_4ix3p_62 ._coverWrap_4ix3p_47{background:var(--book-card-sand)}._mint_4ix3p_66 ._coverWrap_4ix3p_47{background:var(--book-card-mint)}._cream_4ix3p_70 ._coverWrap_4ix3p_47{background:var(--book-card-cream)}._cover_4ix3p_47{aspect-ratio:3/4.2;width:78px;color:var(--bg-surface);box-shadow:0 8px 16px var(--course-cover-shadow);border-radius:3px;justify-content:center;align-items:center;display:flex;overflow:hidden}._coverImage_4ix3p_86{object-fit:cover;width:100%;height:100%}._coverTitle_4ix3p_92{font-family:Georgia, "Yu Mincho", var(--font-title), serif;text-align:center;-webkit-line-clamp:4;-webkit-box-orient:vertical;padding:10px 8px;font-size:9px;font-weight:700;line-height:1.1;display:-webkit-box;overflow:hidden}._body_4ix3p_105{flex-direction:column;gap:5px;min-width:0;padding:14px 13px 12px;display:flex}._title_4ix3p_113{color:var(--text-primary);font-family:Georgia, "Yu Mincho", var(--font-title), serif;text-overflow:ellipsis;white-space:nowrap;font-size:15px;font-weight:500;line-height:1.2;overflow:hidden}._titleJa_4ix3p_124{color:var(--text-secondary);text-overflow:ellipsis;white-space:nowrap;font-size:10px;font-weight:600;line-height:1.3;overflow:hidden}._author_4ix3p_134{color:var(--text-tertiary);text-overflow:ellipsis;white-space:nowrap;font-size:10px;font-weight:600;line-height:1.3;overflow:hidden}._meta_4ix3p_144{color:var(--text-tertiary);white-space:nowrap;align-items:center;gap:6px;margin-top:10px;font-size:10.5px;font-weight:600;display:inline-flex}._page_ag31n_1{--course-page-accent:var(--color-primary);background:var(--bg-page);min-height:100%;color:var(--text-primary);flex-direction:column;gap:20px;padding:22px 26px 40px;display:flex}._header_ag31n_13{grid-template-columns:minmax(0,1fr) 220px;align-items:start;gap:18px;display:grid}._headingGroup_ag31n_20{flex-direction:column;gap:8px;min-width:0;display:flex}._title_ag31n_27{color:var(--text-primary);letter-spacing:0;margin:0;font-size:22px;font-weight:700;line-height:1.25}._description_ag31n_36{color:var(--text-secondary);margin:0;font-size:12.5px;font-weight:500;line-height:1.6}._search_ag31n_44{align-items:center;min-width:0;display:flex;position:relative}._searchIcon_ag31n_51{color:var(--text-muted);pointer-events:none;position:absolute;left:14px}._searchInput_ag31n_58{border:1px solid var(--border);background:var(--color-input-bg);width:100%;height:32px;color:var(--text-primary);border-radius:999px;outline:none;padding:0 14px 0 36px;font-size:12px;font-weight:600;transition:border-color .2s,background .2s}._searchInput_ag31n_58::placeholder{color:var(--text-muted)}._searchInput_ag31n_58:focus{border-color:var(--color-primary);background:var(--bg-surface)}._tabs_ag31n_81{border-bottom:1px solid var(--border);grid-template-columns:repeat(2,minmax(0,1fr));gap:0;display:grid}._tab_ag31n_81{min-height:62px;color:var(--text-secondary);cursor:pointer;background:0 0;border:0;border-bottom:2px solid #0000;justify-content:flex-start;align-items:center;gap:12px;padding:0 16px 14px;font-family:inherit;transition:border-color .2s,color .2s;display:flex}._tab_ag31n_81:hover{color:var(--text-primary)}._tabActive_ag31n_108{border-bottom-color:var(--color-primary);color:var(--text-primary)}._tabIcon_ag31n_113{background:var(--book-card-cream);width:31px;height:33px;color:var(--text-tertiary);border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;display:inline-flex}._tabActive_ag31n_108 ._tabIcon_ag31n_113{background:var(--color-primary);color:var(--course-on-primary)}._tabCopy_ag31n_130{text-align:left;flex-direction:column;gap:5px;min-width:0;display:flex}._tabTitle_ag31n_138{color:inherit;align-items:baseline;gap:12px;font-size:15px;font-weight:800;line-height:1.1;display:flex}._tabMeta_ag31n_148{color:var(--text-tertiary);font-size:11px;font-weight:600;line-height:1.2}._count_ag31n_155{color:var(--text-muted);font-family:var(--font-data);font-size:11px;font-weight:800}._toolbar_ag31n_162{justify-content:space-between;align-items:center;gap:16px;display:flex}._filters_ag31n_169{flex-wrap:wrap;gap:8px;min-width:0;display:flex}._chip_ag31n_176{border:1px solid var(--border);background:var(--bg-surface);min-height:29px;color:var(--text-primary);cursor:pointer;border-radius:999px;align-items:center;padding:0 16px;font-family:inherit;font-size:11px;font-weight:800;transition:background .2s,border-color .2s,color .2s;display:inline-flex}._chip_ag31n_176:hover{border-color:var(--border-strong)}._chipActive_ag31n_196{border-color:var(--color-primary);background:var(--color-primary);color:var(--course-on-primary)}._sortButton_ag31n_202{border:1px solid var(--border);background:var(--bg-surface);min-height:30px;color:var(--text-primary);cursor:pointer;border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;gap:6px;padding:0 14px;font-family:inherit;font-size:11px;font-weight:800;transition:background .2s,border-color .2s,color .2s;display:inline-flex}._sortButton_ag31n_202:hover{border-color:var(--color-primary);color:var(--color-primary)}._courseGrid_ag31n_226{grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;display:grid}._bookSection_ag31n_232{flex-direction:column;gap:14px;display:flex}._sectionHeader_ag31n_238{justify-content:space-between;align-items:center;gap:12px;margin-top:2px;display:flex}._sectionHeader_ag31n_238>div{align-items:baseline;gap:12px;min-width:0;display:flex}._sectionTitle_ag31n_253{color:var(--text-primary);align-items:center;gap:6px;margin:0;font-size:13px;font-weight:800;line-height:1.2;display:inline-flex}._sectionCount_ag31n_264{color:var(--text-muted);font-size:11px;font-weight:700}._bookGrid_ag31n_270{grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;display:grid}._state_ag31n_276,._stateError_ag31n_277{border:1px solid var(--border);background:var(--bg-surface);min-height:160px;color:var(--text-secondary);border-radius:8px;align-items:center;padding:24px;font-size:14px;font-weight:700;display:flex}._stateError_ag31n_277{color:var(--color-err)}@media (width<=1099px){._courseGrid_ag31n_226,._bookGrid_ag31n_270{grid-template-columns:repeat(3,minmax(0,1fr))}}@media (width<=899px){._header_ag31n_13{grid-template-columns:1fr}._bookGrid_ag31n_270,._courseGrid_ag31n_226{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (width<=767px){._page_ag31n_1{gap:16px;padding:18px 16px 64px}._toolbar_ag31n_162{flex-direction:column;align-items:stretch}._sortButton_ag31n_202{width:100%}}@media (width<=559px){._tabs_ag31n_81{grid-template-columns:1fr}}@media (width<=479px){._courseGrid_ag31n_226,._bookGrid_ag31n_270{grid-template-columns:1fr}}._backdrop_4kl31_1{z-index:40;background:var(--scrim);justify-content:center;align-items:center;padding:24px;animation:.18s ease-out _fadeIn_4kl31_1;display:flex;position:fixed;inset:0}._modal_4kl31_13{border:1px solid var(--border);background:var(--bg-surface);border-radius:18px;width:min(100%,640px);animation:.18s ease-out _scaleIn_4kl31_1;overflow:hidden;box-shadow:0 12px 30px #00000014}._header_4kl31_23{border-bottom:1px solid var(--border);justify-content:space-between;align-items:flex-start;gap:16px;padding:26px 28px 18px;display:flex}._title_4kl31_32{color:var(--text-primary);margin:0;font-size:22px;font-weight:700;line-height:1.2}._summary_4kl31_40{color:var(--text-secondary);margin:8px 0 0;font-size:13px;font-weight:500;line-height:1.5}._closeButton_4kl31_48{border:1px solid var(--border);background:var(--bg-surface);width:36px;height:36px;color:var(--text-secondary);cursor:pointer;border-radius:10px;justify-content:center;align-items:center;transition:background .18s,border-color .18s,color .18s;display:inline-flex}._closeButton_4kl31_48:hover{border-color:var(--border-strong);background:var(--bg-surface-hover);color:var(--text-primary)}._body_4kl31_68{flex-direction:column;gap:24px;padding:24px 28px 28px;display:flex}._section_4kl31_75{flex-direction:column;gap:12px;display:flex}._sectionTitle_4kl31_81{color:var(--text-primary);margin:0;font-size:15px;font-weight:700}._quantityHeader_4kl31_88{justify-content:space-between;align-items:center;gap:12px;display:flex}._quantityHint_4kl31_95{color:var(--text-secondary);font-size:12px;font-weight:600}._optionGrid_4kl31_101{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}._optionButton_4kl31_107{border:1px solid var(--border);background:var(--bg-surface-muted);min-height:54px;color:var(--text-secondary);cursor:pointer;font:inherit;border-radius:14px;justify-content:center;align-items:center;gap:10px;font-size:14px;font-weight:700;transition:border-color .18s,background .18s,color .18s;display:inline-flex}._optionButton_4kl31_107:hover{border-color:var(--border-strong);background:var(--bg-surface-hover);color:var(--text-primary)}._optionButtonActive_4kl31_130,._optionButtonActive_4kl31_130:hover{border-color:var(--color-primary);background:var(--color-primary-ghost);color:var(--color-primary)}._optionIcon_4kl31_137{flex:none;justify-content:center;align-items:center;display:inline-flex}._optionLabel_4kl31_144{line-height:1.2}._quantityField_4kl31_148{border:1px solid var(--border);background:var(--bg-surface-muted);border-radius:14px;align-items:center;gap:10px;width:fit-content;padding:10px 14px;display:inline-flex}._quantityField_4kl31_148 input{width:88px;color:var(--text-primary);font:inherit;background:0 0;border:none;outline:none;font-size:16px;font-weight:700}._quantityField_4kl31_148 span{color:var(--text-secondary);font-size:13px;font-weight:700}._footer_4kl31_176{padding:0 28px 28px}._startButton_4kl31_180{border:1px solid var(--color-primary);background:var(--color-primary);color:#fff;cursor:pointer;width:100%;min-height:56px;font:inherit;border-radius:14px;font-size:16px;font-weight:700;transition:background .18s,border-color .18s}._startButton_4kl31_180:hover{border-color:var(--color-primary-hover);background:var(--color-primary-hover)}@media (width<=640px){._backdrop_4kl31_1{padding:16px}._header_4kl31_23{padding:22px 20px 16px}._body_4kl31_68{gap:20px;padding:20px}._footer_4kl31_176{padding:0 20px 20px}._optionGrid_4kl31_101{grid-template-columns:1fr}}._overlay_1ye5t_1{z-index:1200;background:var(--scrim);justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0;overflow:hidden}._card_1ye5t_13{z-index:1;border:1px solid var(--border);background:var(--bg-surface);border-radius:16px;width:min(520px,100%);padding:28px 24px 22px;position:relative;box-shadow:0 12px 32px #1c19291f}._confettiRail_1ye5t_24{pointer-events:none;width:min(30vw,360px);position:absolute;top:0;bottom:0;overflow:hidden}._confettiRailLeft_1ye5t_33{left:0}._confettiRailRight_1ye5t_37{right:0}._confettiPiece_1ye5t_41{top:calc(68% + var(--confetti-origin-y));width:var(--confetti-size);height:calc(var(--confetti-size) * 1.8);opacity:0;animation:_confettiBurst_1ye5t_1 var(--confetti-duration) cubic-bezier(.18, .72, .32, 1) 1 both;animation-delay:var(--confetti-delay);will-change:transform, opacity;border-radius:3px;position:absolute}._confettiPieceLeft_1ye5t_53{left:8px}._confettiPieceRight_1ye5t_57{right:8px}._confettiPieceDot_1ye5t_61{width:calc(var(--confetti-size) * 1.35);height:calc(var(--confetti-size) * 1.35);border-radius:999px}._confettiPiecePrimary_1ye5t_67{background:var(--color-primary)}._confettiPieceAccent_1ye5t_71{background:var(--color-accent)}._confettiPieceSurface_1ye5t_75{background:var(--bg-surface)}@keyframes _confettiBurst_1ye5t_1{0%{opacity:0;transform:translate(0,0)rotate(0)scale(.85)}10%{opacity:1}34%{transform:translate3d(var(--confetti-peak-x), var(--confetti-peak-y), 0) rotate(var(--confetti-mid-spin));opacity:1}72%{opacity:.96}to{transform:translate3d(var(--confetti-end-x), var(--confetti-end-y), 0) rotate(var(--confetti-spin)) scale(1.02);opacity:0}}@media (prefers-reduced-motion:reduce){._confettiPiece_1ye5t_41{opacity:0;animation:none}}._hero_1ye5t_111{text-align:center;flex-direction:column;align-items:center;gap:10px;display:flex}._heroIcon_1ye5t_119{background:var(--color-ok);color:#fff;border-radius:999px;justify-content:center;align-items:center;width:84px;height:84px;display:flex}._title_1ye5t_130{color:var(--text-primary);margin:0;font-size:28px;font-weight:700;line-height:1.18}._stats_1ye5t_138{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:24px;display:grid}._statCard_1ye5t_145{border:1px solid var(--border);background:var(--bg-surface);border-radius:14px;align-items:center;gap:14px;padding:16px 18px;display:flex;box-shadow:0 2px 10px #1c19290d}._statIcon_1ye5t_156{background:var(--color-primary-ghost);width:50px;height:50px;color:var(--color-primary);border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;display:inline-flex}._statIconSuccess_1ye5t_168{background:var(--color-ok-bg);color:var(--color-ok)}._statBody_1ye5t_173{min-width:0}._statLabel_1ye5t_177{color:var(--text-secondary);margin:0;font-size:14px;font-weight:600;line-height:1.4}._statValue_1ye5t_185{color:var(--text-primary);font-size:22px;font-weight:700;line-height:1.2;font-family:var(--font-data,"DM Sans", sans-serif);margin:4px 0 0}._statValueSuccess_1ye5t_194{color:var(--color-ok)}._actions_1ye5t_198{flex-direction:column;gap:12px;margin-top:18px;display:flex}._actionButton_1ye5t_205{border:1px solid var(--border);background:var(--bg-surface);width:100%;min-height:54px;color:var(--text-primary);cursor:pointer;border-radius:14px;justify-content:center;align-items:center;gap:10px;padding:12px 18px;font-size:16px;font-weight:700;line-height:1.4;transition:background-color .18s,border-color .18s,transform .18s;display:inline-flex}._actionButton_1ye5t_205:hover{background:var(--bg-surface-muted);border-color:var(--border-strong);transform:translateY(-1px)}._actionButtonPrimary_1ye5t_230{border-color:var(--color-primary-ghost);background:var(--color-primary-ghost)}._actionButtonPrimary_1ye5t_230:hover{border-color:var(--color-primary);background:var(--color-primary-ghost)}@media (width<=767px){._overlay_1ye5t_1{padding:16px}._card_1ye5t_13{border-radius:16px;width:min(420px,100%);padding:24px 18px 18px}._heroIcon_1ye5t_119{width:72px;height:72px}._title_1ye5t_130{font-size:24px}._stats_1ye5t_138{grid-template-columns:1fr}._statCard_1ye5t_145{padding:14px 16px}._statIcon_1ye5t_156{width:46px;height:46px}._statValue_1ye5t_185{font-size:20px}._actionButton_1ye5t_205{min-height:50px;font-size:15px}}._backdrop_nd7qu_1{z-index:50;background:var(--scrim);justify-content:center;align-items:center;padding:24px;animation:.18s ease-out _fadeIn_nd7qu_1;display:flex;position:fixed;inset:0}._dialog_nd7qu_13{border:1px solid var(--border);background:var(--bg-surface);border-radius:16px;width:min(100%,420px);padding:24px 26px 22px;animation:.18s ease-out _scaleIn_nd7qu_1;box-shadow:0 12px 30px #0000001f}._title_nd7qu_23{color:var(--text-primary);margin:0 0 8px;font-size:17px;font-weight:700;line-height:1.35}._message_nd7qu_31{color:var(--text-secondary);margin:0 0 20px;font-size:14px;font-weight:500;line-height:1.55}._actions_nd7qu_39{justify-content:flex-end;gap:10px;display:flex}._button_nd7qu_45{min-width:92px;font:inherit;cursor:pointer;border-radius:10px;padding:10px 18px;font-size:14px;font-weight:700;transition:background .15s,border-color .15s,color .15s,opacity .15s}._button_nd7qu_45:disabled{opacity:.55;cursor:progress}._cancel_nd7qu_61{border:1px solid var(--border);background:var(--bg-surface);color:var(--text-primary)}._cancel_nd7qu_61:hover:not(:disabled){border-color:var(--border-strong);background:var(--bg-surface-hover)}._confirm_nd7qu_72{border:1px solid var(--color-primary);background:var(--color-primary);color:#fff}._confirm_nd7qu_72:hover:not(:disabled){border-color:var(--color-primary-hover);background:var(--color-primary-hover)}._confirmDanger_nd7qu_83{border-color:var(--color-danger,#ef4444);background:var(--color-danger,#ef4444)}._confirmDanger_nd7qu_83:hover:not(:disabled){border-color:var(--color-danger-hover,#dc2626);background:var(--color-danger-hover,#dc2626)}@keyframes _fadeIn_nd7qu_1{0%{opacity:0}to{opacity:1}}@keyframes _scaleIn_nd7qu_1{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}._dashboard_3iqve_1{flex-direction:column;min-width:0;display:flex}._header_3iqve_7{padding:26px 26px 24px}._header_3iqve_7 h1{color:var(--uchi-ink);margin:0;font-size:22px;font-weight:800;line-height:1.2}._header_3iqve_7 p{color:var(--uchi-ink-2);margin:8px 0 0;font-size:12.5px;font-weight:500}._tabs_3iqve_26{border-bottom:1px solid var(--uchi-line);gap:26px;margin:0 26px;display:flex}._tab_3iqve_26{min-height:46px;color:var(--uchi-ink-3);cursor:pointer;background:0 0;border:0;border-bottom:2px solid #0000;align-items:center;gap:8px;margin-bottom:-1px;padding:0 18px;font-family:inherit;font-size:14px;font-weight:800;display:inline-flex}._tabActive_3iqve_50{border-bottom-color:var(--uchi-primary);color:var(--uchi-ink)}._tabIcon_3iqve_55{color:var(--uchi-primary);display:inline-flex}._count_3iqve_60{background:var(--uchi-primary-soft);min-width:24px;height:21px;color:var(--uchi-primary);font-variant-numeric:tabular-nums;border-radius:999px;justify-content:center;align-items:center;padding:0 7px;font-size:11px;font-weight:800;display:inline-flex}._panel_3iqve_75{padding:22px 26px 40px}._groups_3iqve_79{flex-direction:column;gap:24px;display:flex}._group_3iqve_79{flex-direction:column;gap:10px;display:flex}._groupTitle_3iqve_91{color:var(--uchi-ink-2);align-items:center;gap:8px;margin:0;font-size:12.5px;font-weight:800;display:inline-flex}._groupTitle_3iqve_91 span{color:var(--uchi-ink-3);font-variant-numeric:tabular-nums;font-size:11px}._list_3iqve_107{flex-direction:column;gap:10px;display:flex}._row_3iqve_113{border:1px solid var(--uchi-line);background:var(--uchi-paper);min-height:92px;box-shadow:0 1px 3px color-mix(in srgb, var(--uchi-ink) 4%, transparent);border-radius:10px;grid-template-columns:minmax(0,1fr) minmax(220px,280px) auto;align-items:center;gap:18px;padding:14px 20px;display:grid}._mainButton_3iqve_126{min-width:0;color:inherit;text-align:left;cursor:pointer;background:0 0;border:0;grid-template-columns:72px minmax(0,1fr);align-items:center;gap:18px;padding:0;font-family:inherit;display:grid}._courseThumb_3iqve_141,._bookThumb_3iqve_142{background:color-mix(in srgb, var(--plan-item-color) 34%, var(--uchi-paper));display:block;position:relative;overflow:hidden}._courseThumb_3iqve_141{border-radius:8px;width:56px;height:56px}._courseThumb_3iqve_141:after{background:color-mix(in srgb, var(--uchi-paper) 58%, transparent);content:"";border-radius:50%;width:30px;height:30px;position:absolute;bottom:-8px;right:-8px}._bookThumb_3iqve_142{border:1px solid color-mix(in srgb, var(--uchi-ink) 12%, transparent);background:var(--plan-item-color);width:44px;height:66px;box-shadow:inset 4px 0 0 color-mix(in srgb, var(--uchi-paper) 16%, transparent);border-radius:3px 5px 5px 3px;justify-self:center}._bookThumb_3iqve_142:after{border:1px solid color-mix(in srgb, var(--uchi-paper) 26%, transparent);content:"";border-radius:2px;position:absolute;inset:10px 8px}._rowCopy_3iqve_184{flex-direction:column;gap:6px;min-width:0;display:flex}._titleLine_3iqve_191{align-items:center;gap:8px;min-width:0;display:inline-flex}._titleLine_3iqve_191 strong{min-width:0;color:var(--uchi-ink);text-overflow:ellipsis;white-space:nowrap;font-size:14.5px;font-weight:800;line-height:1.35;overflow:hidden}._titleLine_3iqve_191 ._bookTitle_3iqve_209{font-family:var(--font-serif);font-size:16px;font-weight:700}._tag_3iqve_215{background:var(--uchi-tag-plain-bg);height:22px;color:var(--uchi-ink-2);border-radius:999px;flex-shrink:0;align-items:center;padding:0 9px;font-size:10.5px;font-weight:800;display:inline-flex}._metaLine_3iqve_228{min-width:0;color:var(--uchi-ink-3);text-overflow:ellipsis;white-space:nowrap;font-size:12px;font-weight:600;line-height:1.4;overflow:hidden}._progress_3iqve_239{min-width:0}._progressHeader_3iqve_243{color:var(--uchi-ink-3);justify-content:space-between;align-items:center;gap:12px;margin-bottom:7px;font-size:11px;font-weight:700;display:flex}._progressHeader_3iqve_243 strong{color:var(--uchi-ink-2);font-variant-numeric:tabular-nums;white-space:nowrap;font-size:12px;font-weight:800}._progressTrack_3iqve_262{background:var(--uchi-progress-track);border-radius:999px;height:5px;overflow:hidden}._progressTrack_3iqve_262 span{border-radius:inherit;background:var(--uchi-primary);height:100%;display:block}._actions_3iqve_276{justify-content:flex-end;align-items:center;gap:8px;display:inline-flex}._primaryButton_3iqve_283,._secondaryButton_3iqve_284,._removeButton_3iqve_285{border:1px solid var(--uchi-line);cursor:pointer;justify-content:center;align-items:center;font-family:inherit;font-weight:800;display:inline-flex}._primaryButton_3iqve_283{border-color:var(--uchi-primary);background:var(--uchi-primary);min-width:92px;min-height:36px;color:var(--uchi-paper);border-radius:999px;gap:7px;padding:0 16px;font-size:12px}._secondaryButton_3iqve_284{background:var(--uchi-paper);min-height:34px;color:var(--uchi-ink);border-radius:999px;padding:0 14px;font-size:12px}._removeButton_3iqve_285{width:34px;height:34px;color:var(--uchi-ink-3);opacity:0;background:0 0;border-radius:50%;padding:0;transition:opacity .15s,color .15s,border-color .15s}._row_3iqve_113:hover ._removeButton_3iqve_285,._removeButton_3iqve_285:focus-visible{opacity:1}._removeButton_3iqve_285:hover{border-color:var(--uchi-rose);color:var(--uchi-rose-deep)}._removeButton_3iqve_285:disabled{cursor:wait;opacity:.45}._state_3iqve_342,._stateError_3iqve_343{border:1px dashed var(--uchi-line);min-height:180px;color:var(--uchi-ink-3);border-radius:10px;flex-direction:column;justify-content:center;align-items:center;gap:14px;font-size:13px;font-weight:700;display:flex}._state_3iqve_342 p{margin:0}._stateError_3iqve_343{color:var(--uchi-rose-deep)}@media (width<=980px){._row_3iqve_113{grid-template-columns:minmax(0,1fr);gap:12px}._actions_3iqve_276{justify-content:flex-start}}@media (width<=640px){._header_3iqve_7,._panel_3iqve_75{padding-left:16px;padding-right:16px}._tabs_3iqve_26{margin-left:16px;margin-right:16px}._mainButton_3iqve_126{grid-template-columns:56px minmax(0,1fr);gap:12px}._courseThumb_3iqve_141{width:48px;height:48px}._bookThumb_3iqve_142{width:36px;height:54px}}._page_cwahb_1{background:var(--uchi-bg);min-height:calc(100vh - 60px)}._empty_cwahb_6{border:1px dashed var(--uchi-line);background:var(--uchi-paper);min-height:360px;color:var(--uchi-ink-3);border-radius:10px;flex-direction:column;justify-content:center;align-items:center;gap:14px;margin:26px;font-size:13px;font-weight:700;display:flex}._empty_cwahb_6 p{margin:0}._emptyButton_cwahb_26{border:1px solid var(--uchi-line);background:var(--uchi-paper);min-height:36px;color:var(--uchi-ink);cursor:pointer;border-radius:999px;align-items:center;gap:6px;padding:0 16px;font-family:inherit;font-size:12px;font-weight:800;display:inline-flex}._emptyButton_cwahb_26:hover{border-color:var(--uchi-primary);color:var(--uchi-primary)}._page_1o9uv_1{background:var(--bg-page);min-height:100%;color:var(--text-primary);padding:22px 26px 40px}._intro_1o9uv_8,._flow_1o9uv_9,._memo_1o9uv_10{border:1px solid var(--border);background:var(--bg-surface);border-radius:12px;max-width:1040px;margin:0 auto}._intro_1o9uv_8{background:linear-gradient(120deg, var(--uchi-hero-from) 0%, var(--uchi-hero-mid) 100%);grid-template-columns:minmax(0,1fr) auto;align-items:end;gap:24px;padding:24px 26px;display:grid;overflow:hidden}._introMain_1o9uv_28{min-width:0}._kicker_1o9uv_32{color:var(--uchi-ink-2);background:#ffffffad;border-radius:999px;margin-bottom:10px;padding:4px 10px;font-size:11px;font-weight:700;display:inline-flex}._title_1o9uv_43{max-width:620px;color:var(--text-primary);margin:0;font-size:22px;font-weight:700;line-height:1.45}._lead_1o9uv_52{max-width:720px;color:var(--text-secondary);margin:12px 0 0;font-size:13px;font-weight:500;line-height:1.8}._actions_1o9uv_61{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:10px;display:flex}._primaryButton_1o9uv_69,._secondaryButton_1o9uv_70{min-height:40px;font:inherit;cursor:pointer;border-radius:999px;justify-content:center;align-items:center;gap:8px;padding:0 16px;font-size:13px;font-weight:700;transition:background .16s,border-color .16s,transform .16s,color .16s;display:inline-flex}._primaryButton_1o9uv_69{border:1px solid var(--color-primary);background:var(--color-primary);color:var(--course-on-primary)}._primaryButton_1o9uv_69:hover{background:var(--color-primary-hover);border-color:var(--color-primary-hover);transform:translateY(-1px)}._secondaryButton_1o9uv_70{border:1px solid var(--border);background:var(--bg-surface);color:var(--text-primary)}._secondaryButton_1o9uv_70:hover{border-color:var(--border-strong);background:var(--bg-surface-hover)}._flow_1o9uv_9,._memo_1o9uv_10{margin-top:18px;padding:18px 20px}._sectionHeader_1o9uv_114{color:var(--text-secondary);align-items:center;gap:8px;margin-bottom:16px;display:flex}._sectionHeader_1o9uv_114 h2{color:var(--text-primary);margin:0;font-size:14px;font-weight:700}._steps_1o9uv_129{flex-direction:column;gap:10px;display:flex}._step_1o9uv_129{border:1px solid var(--border);background:var(--uchi-row-alt);border-radius:12px;grid-template-columns:48px minmax(0,1fr);align-items:start;gap:14px;padding:16px 18px;display:grid}._stepNumber_1o9uv_146{background:var(--uchi-primary-soft);width:42px;min-height:30px;color:var(--uchi-primary);font-family:var(--font-data);border-radius:999px;justify-content:center;align-items:center;font-size:13px;font-weight:700;display:inline-flex}._stepBody_1o9uv_160{min-width:0}._stepBody_1o9uv_160 h3,._memoItem_1o9uv_165 h3{color:var(--text-primary);margin:0;font-size:14px;font-weight:700;line-height:1.5}._stepBody_1o9uv_160 p,._memoItem_1o9uv_165 p{color:var(--text-secondary);margin:6px 0 0;font-size:12.5px;font-weight:500;line-height:1.7}._memoList_1o9uv_182{grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;display:grid}._memoItem_1o9uv_165{border:1px solid var(--border);background:var(--bg-surface);border-radius:12px;align-items:flex-start;gap:12px;min-width:0;padding:16px;display:flex}._memoIcon_1o9uv_199{background:var(--uchi-primary-soft);width:34px;height:34px;color:var(--uchi-primary);border-radius:10px;flex:0 0 34px;justify-content:center;align-items:center;display:inline-flex}@media (width<=860px){._intro_1o9uv_8{grid-template-columns:1fr;align-items:start}._actions_1o9uv_61{justify-content:flex-start}._memoList_1o9uv_182{grid-template-columns:1fr}}@media (width<=640px){._page_1o9uv_1{padding:20px 16px 64px}._intro_1o9uv_8,._flow_1o9uv_9,._memo_1o9uv_10{padding:18px}._title_1o9uv_43{font-size:19px}._actions_1o9uv_61,._primaryButton_1o9uv_69,._secondaryButton_1o9uv_70{width:100%}._step_1o9uv_129{grid-template-columns:1fr;gap:10px}}._page_1v1rn_3{background:var(--bg-page);min-height:100%;color:var(--text-primary);padding:22px 26px 40px}._toolbar_1v1rn_10{flex-wrap:wrap;align-items:center;gap:12px;max-width:1280px;margin:0 auto 24px;display:flex}._summary_1v1rn_19{background:var(--bg-surface);border:1px solid var(--border);border-radius:12px;align-items:center;gap:10px;min-height:38px;padding:0 16px;font-size:12.5px;display:inline-flex}._summaryLabel_1v1rn_31{color:var(--text-secondary);letter-spacing:0;font-weight:600}._summaryValue_1v1rn_37,._summaryCount_1v1rn_38{font-feature-settings:"tnum";font-weight:700}._summaryValue_1v1rn_37{color:var(--text-primary)}._summaryCount_1v1rn_38{color:var(--uchi-rose)}._summaryDivider_1v1rn_51{color:var(--border-strong)}._actions_1v1rn_55{flex-wrap:wrap;align-items:center;gap:8px;margin-left:auto;display:flex}._switchGroup_1v1rn_63{border:1px solid var(--border);background:var(--bg-surface);height:40px;color:var(--text-primary);cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:8px;align-items:center;gap:8px;padding:0 14px;font-size:13px;font-weight:700;transition:background .18s,border-color .18s;display:inline-flex}._switchGroup_1v1rn_63:hover{background:var(--bg-surface-muted);border-color:var(--border-strong)}._switchGroup_1v1rn_63 input[type=checkbox]{cursor:pointer;width:16px;height:16px;accent-color:var(--color-primary)}._secondaryButton_1v1rn_92,._startButton_1v1rn_93,._deleteSelectionButton_1v1rn_94{cursor:pointer;border-radius:999px;justify-content:center;align-items:center;gap:7px;min-height:38px;padding:0 16px;font-size:12.5px;font-weight:700;transition:background .18s,transform .18s,border-color .18s,color .18s;display:inline-flex}._secondaryButton_1v1rn_92{border:1px solid var(--border);background:var(--bg-surface);color:var(--text-primary)}._secondaryButton_1v1rn_92:hover:not(:disabled){border-color:var(--border-strong);background:var(--bg-surface-hover)}._startButton_1v1rn_93{border:1px solid var(--color-primary);background:var(--color-primary);color:var(--course-on-primary)}._startButton_1v1rn_93:hover:not(:disabled){background:var(--color-primary-hover);border-color:var(--color-primary-hover);transform:translateY(-1px)}._deleteSelectionButton_1v1rn_94{border:1px solid var(--color-err);color:var(--color-err);background:0 0}._deleteSelectionButton_1v1rn_94:hover:not(:disabled){background:var(--color-err-bg)}._secondaryButton_1v1rn_92:disabled,._startButton_1v1rn_93:disabled,._deleteSelectionButton_1v1rn_94:disabled{border-color:var(--text-muted);background:var(--text-muted);color:var(--course-on-primary);box-shadow:none;cursor:not-allowed;transform:none}._deleteSelectionButton_1v1rn_94:disabled{border-color:var(--text-muted)}._statusBar_1v1rn_156{border-radius:12px;max-width:1280px;margin:0 auto 12px;padding:10px 14px;font-size:12.5px;font-weight:600}._loading_1v1rn_165{background:var(--bg-surface-muted);color:var(--text-secondary)}._error_1v1rn_170{background:var(--color-err-bg);color:var(--color-err)}._info_1v1rn_175{background:var(--uchi-cream-soft);color:var(--uchi-ink-2)}._shelf_1v1rn_180{max-width:1280px;margin:0 auto}._cardList_1v1rn_185{border:1px solid var(--border);background:var(--bg-surface);border-radius:12px;flex-direction:column;gap:0;display:flex;overflow:hidden}._section_1v1rn_195{margin-top:18px}._sectionHeader_1v1rn_199{justify-content:space-between;align-items:baseline;gap:12px;margin-bottom:10px;display:flex}._sectionTitle_1v1rn_207{color:var(--text-secondary);margin:0;font-size:14px;font-weight:800}._sectionCount_1v1rn_214{color:var(--text-tertiary);font-size:13px}._reviewCard_1v1rn_219{border:0;border-top:1px solid var(--border);background:var(--bg-surface);border-radius:0;align-items:flex-start;gap:14px;width:100%;padding:16px 18px;transition:border-color .15s,background .15s,transform .15s;display:flex}._reviewCard_1v1rn_219:first-child{border-top:0}._reviewCard_1v1rn_219:hover{background:var(--uchi-row-alt);transform:none}._reviewCardButton_1v1rn_241{text-align:left;cursor:pointer;font:inherit}._reviewCardSelected_1v1rn_247,._reviewCardSelected_1v1rn_247:hover{border-color:var(--color-primary);background:var(--uchi-primary-soft)}._selectIndicator_1v1rn_253{border:1px solid var(--border-strong);background:var(--bg-surface);color:#0000;border-radius:999px;flex:0 0 22px;justify-content:center;align-items:center;width:22px;height:22px;margin-top:2px;font-size:12px;font-weight:700;transition:background .15s,border-color .15s,color .15s;display:inline-flex}._selectIndicatorSelected_1v1rn_270{border-color:var(--color-primary);background:var(--color-primary);color:var(--course-on-primary)}._reviewCardContent_1v1rn_276{flex-direction:column;flex:1;gap:4px;min-width:0;display:flex}._reviewCardTopRow_1v1rn_284{align-items:center;gap:6px;min-width:0;display:flex}._reviewCardEnglish_1v1rn_291{min-width:0;font-family:var(--font-serif);color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;flex:auto;margin:0;font-size:16px;font-weight:500;line-height:1.5;overflow:hidden}._modePill_1v1rn_305,._dueBadge_1v1rn_306{white-space:nowrap;border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;padding:2px 8px;font-size:10.5px;font-weight:600;line-height:1.4;display:inline-flex}._modePill_1v1rn_305{border:1px solid var(--uchi-primary-soft);background:var(--uchi-primary-soft);color:var(--color-primary)}._dueBadge_1v1rn_306{background:var(--uchi-tag-rose-bg);color:var(--uchi-rose-deep)}._reviewCardJapanese_1v1rn_331{color:var(--text-secondary);text-overflow:ellipsis;white-space:nowrap;margin:0;font-size:12px;font-weight:500;line-height:1.5;overflow:hidden}._reviewCardMeta_1v1rn_342{color:var(--text-tertiary);flex-wrap:wrap;align-items:center;gap:4px;margin-top:4px;font-size:11.5px;font-weight:500;display:flex}._reviewCardMetaSep_1v1rn_353{color:var(--border-strong)}._reviewCardMetaPractice_1v1rn_357{color:var(--color-primary);font-weight:700}._groupGrid_1v1rn_362{grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;display:grid}._groupCard_1v1rn_368{background:var(--bg-surface);border:1px solid var(--border);border-radius:12px;flex-direction:column;transition:border-color .15s,transform .15s;display:flex;position:relative;overflow:hidden}._groupCard_1v1rn_368:hover{border-color:var(--border-strong);transform:translateY(-2px)}._groupOpenButton_1v1rn_384{width:100%;color:inherit;text-align:left;cursor:pointer;font:inherit;background:0 0;border:0;flex-direction:column;flex:1;padding:0;display:flex}._groupOpenButton_1v1rn_384:focus-visible{outline:2px solid var(--color-primary);outline-offset:-2px}._groupCover_1v1rn_403{background:linear-gradient(135deg, var(--uchi-hero-mid), var(--uchi-hero-to));width:100%;height:112px;position:relative;overflow:hidden}._groupCover_1v1rn_403 img{object-fit:cover;width:100%;height:100%;display:block}._groupTag_1v1rn_418{max-width:calc(100% - 20px);color:var(--uchi-ink-2);text-overflow:ellipsis;white-space:nowrap;background:#ffffffb8;border-radius:999px;padding:3px 8px;font-size:10.5px;font-weight:600;position:absolute;top:10px;right:10px;overflow:hidden}._groupMain_1v1rn_434{flex-direction:column;flex:1;gap:8px;min-width:0;padding:14px 16px 16px;display:flex}._groupTitle_1v1rn_443{color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;font-size:14.5px;font-weight:700;overflow:hidden}._groupDescription_1v1rn_452{min-height:36px;color:var(--text-secondary);-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:11.5px;font-weight:500;line-height:1.5;display:-webkit-box;overflow:hidden}._groupMeta_1v1rn_464{color:var(--text-tertiary);font-size:11.5px;font-weight:600}._groupProgressTrack_1v1rn_470{background:var(--border);border-radius:999px;width:100%;height:5px;overflow:hidden}._groupProgressFill_1v1rn_478{border-radius:inherit;background:var(--uchi-sage-mid);height:100%;display:block}._groupCardActions_1v1rn_485{position:absolute;bottom:8px;right:8px}._deleteButton_1v1rn_491{width:32px;height:32px;color:var(--text-tertiary);cursor:pointer;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;transition:background .15s,color .15s;display:inline-flex}._deleteButton_1v1rn_491:hover{background:var(--color-err-bg);color:var(--color-err)}._backButton_1v1rn_510{border:1px solid var(--border);background:var(--bg-surface);min-height:38px;color:var(--text-primary);cursor:pointer;border-radius:999px;align-items:center;gap:7px;margin-bottom:14px;padding:0 14px;font-size:13px;font-weight:600;transition:background .15s,border-color .15s;display:inline-flex}._backButton_1v1rn_510:hover{border-color:var(--border-strong);background:var(--bg-surface-hover)}._courseSummaryCard_1v1rn_532{border:1px solid var(--border);background:var(--bg-surface);border-radius:12px;align-items:center;gap:18px;margin-bottom:20px;padding:18px;display:flex}._courseSummaryCover_1v1rn_543{aspect-ratio:16/9;object-fit:cover;background:var(--bg-surface-muted);border-radius:8px;flex:0 0 160px;width:160px}._courseSummaryMain_1v1rn_552{flex:1;min-width:0}._courseSummaryTitle_1v1rn_557{color:var(--text-primary);margin:0 0 6px;font-size:18px;font-weight:700}._courseSummaryDescription_1v1rn_564{color:var(--text-secondary);margin:0;font-size:12.5px;font-weight:500;line-height:1.6}._courseSummaryMeta_1v1rn_572{color:var(--color-primary);margin:8px 0 0;font-size:13px;font-weight:700}._deleteOutlineButton_1v1rn_579{border:1px solid var(--color-err);min-height:36px;color:var(--color-err);cursor:pointer;background:0 0;border-radius:999px;justify-content:center;align-items:center;gap:6px;padding:0 12px;font-size:12px;font-weight:600;transition:background .15s;display:inline-flex}._deleteOutlineButton_1v1rn_579:hover{background:var(--color-err-bg)}._selectionBar_1v1rn_600{border:1px solid var(--border);background:var(--bg-surface);border-radius:12px;justify-content:space-between;align-items:center;gap:16px;margin-top:20px;padding:16px 18px;display:flex;position:sticky;bottom:20px;box-shadow:0 8px 24px #2e352814}._selectionSummary_1v1rn_615{align-items:baseline;gap:8px;display:inline-flex}._selectionSummaryCount_1v1rn_621{color:var(--color-primary);font-size:24px;font-weight:800;font-family:var(--font-data)}._selectionSummaryLabel_1v1rn_628{color:var(--text-secondary);font-size:13px;font-weight:700}._selectionActions_1v1rn_634{flex-wrap:wrap;align-items:center;gap:10px;display:flex}._empty_1v1rn_641{text-align:center;background:var(--bg-surface);border:1px solid var(--border);max-width:1280px;color:var(--text-secondary);border-radius:12px;margin:0 auto;padding:96px 24px;font-size:14px;line-height:1.8}._empty_1v1rn_641 p{margin:0}._emptySub_1v1rn_658{color:var(--text-tertiary);font-size:13px;margin-top:8px!important}@media (width<=768px){._page_1v1rn_3{padding:20px 16px 32px}._groupGrid_1v1rn_362{grid-template-columns:repeat(2,minmax(0,1fr))}._courseSummaryCard_1v1rn_532{flex-direction:column;align-items:flex-start}._courseSummaryCover_1v1rn_543{flex-basis:auto;width:100%}._selectionBar_1v1rn_600{flex-direction:column;align-items:stretch}._selectionActions_1v1rn_634{width:100%}._selectionActions_1v1rn_634>button{flex:1}}@media (width<=640px){._toolbar_1v1rn_10{gap:8px}._actions_1v1rn_55{width:100%;margin-left:0}._secondaryButton_1v1rn_92,._startButton_1v1rn_93{flex:1;min-width:120px}._summary_1v1rn_19{flex-wrap:wrap;justify-content:center;width:100%;padding-top:10px;padding-bottom:10px}._reviewCardTopRow_1v1rn_284{flex-wrap:wrap}}@media (width<=520px){._groupGrid_1v1rn_362{grid-template-columns:1fr}}._typeTabs_1v1rn_732{border-bottom:1px solid var(--border);gap:26px;max-width:1280px;margin:0 auto 18px;display:flex}._typeTab_1v1rn_732,._typeTabActive_1v1rn_741{min-height:42px;color:var(--text-secondary);cursor:pointer;background:0 0;border:0;border-bottom:2px solid #0000;border-radius:0;padding:0 2px;font-size:13px;font-weight:600}._typeTabActive_1v1rn_741{border-bottom-color:var(--color-primary);color:var(--text-primary)}._scopeTabs_1v1rn_759{gap:8px;max-width:1280px;margin:0 auto 14px;display:flex}._scopeTab_1v1rn_759,._scopeTabActive_1v1rn_767{border:1px solid var(--border);background:var(--bg-surface);min-height:38px;color:var(--text-secondary);cursor:pointer;border-radius:999px;padding:0 16px;font-size:13px;font-weight:600;transition:background .15s,border-color .15s,color .15s}._scopeTab_1v1rn_759:hover{border-color:var(--border-strong);background:var(--bg-surface-hover)}._scopeTabActive_1v1rn_767{border-color:var(--color-primary);background:var(--color-primary);color:var(--course-on-primary)}._videoReviewSummary_1v1rn_791{flex:1;align-items:center;gap:12px;min-width:0;display:flex}._videoReviewThumb_1v1rn_799{aspect-ratio:16/9;object-fit:cover;border:1px solid var(--border);background:var(--bg-surface-muted);border-radius:10px;width:96px}._videoReviewText_1v1rn_808{min-width:0}._videoReviewTime_1v1rn_812{color:var(--text-secondary);margin:4px 0 0;font-size:.85rem;font-weight:700}._backdrop_19vh6_1{z-index:50;background:var(--scrim);justify-content:center;align-items:center;padding:24px;animation:.18s ease-out _fadeIn_19vh6_1;display:flex;position:fixed;inset:0}._modal_19vh6_13{border:1px solid var(--border);background:var(--bg-surface);border-radius:16px;flex-direction:column;width:min(100%,620px);max-height:min(90vh,820px);animation:.18s ease-out _scaleIn_19vh6_1;display:flex;overflow:hidden;box-shadow:0 12px 30px #0000001f}._header_19vh6_26{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:16px;padding:24px 28px;display:flex}._title_19vh6_35{color:var(--text-primary);margin:0;font-size:22px;font-weight:700;line-height:1.2}._closeButton_19vh6_43{width:36px;height:36px;color:var(--text-secondary);cursor:pointer;background:0 0;border:0;border-radius:10px;justify-content:center;align-items:center;transition:background .15s,color .15s;display:inline-flex}._closeButton_19vh6_43:hover{background:var(--bg-surface-hover);color:var(--text-primary)}._body_19vh6_62{flex-direction:column;gap:24px;padding:24px 28px;display:flex;overflow:auto}._section_19vh6_70{border:1px solid var(--border);background:var(--bg-surface);border-radius:14px;flex-direction:column;gap:14px;padding:20px;display:flex}._sectionTitle_19vh6_80{color:var(--text-primary);margin:0;font-size:16px;font-weight:700}._select_19vh6_87{border:1px solid var(--border);background:var(--bg-surface);width:100%;min-height:46px;color:var(--text-primary);font:inherit;border-radius:10px;padding:0 14px;font-size:14px;font-weight:600}._quotaRow_19vh6_100,._toggleRow_19vh6_101{justify-content:space-between;align-items:center;gap:16px;display:flex}._modeList_19vh6_108{flex-direction:column;gap:14px;display:flex}._quotaRow_19vh6_100{border:1px solid var(--border);border-radius:12px;min-height:64px;padding:12px 14px}._quotaLabel_19vh6_121,._toggleTitle_19vh6_122{color:var(--text-primary);font-size:14px;font-weight:700;display:block}._quotaInputGroup_19vh6_129{color:var(--text-secondary);align-items:center;gap:8px;font-size:13px;font-weight:700;display:inline-flex}._quotaInputGroup_19vh6_129 input{border:1px solid var(--border);background:var(--bg-surface);width:108px;min-height:42px;color:var(--text-primary);font:inherit;text-align:right;border-radius:10px;padding:0 12px;font-size:15px;font-weight:700}._toggleDescription_19vh6_152{color:var(--text-secondary);margin-top:4px;font-size:13px;font-weight:500;display:block}._sectionNote_19vh6_160{color:var(--text-secondary);margin:0;font-size:12px;font-weight:500;line-height:1.5}._toggleRow_19vh6_101 input{appearance:none;background:radial-gradient(circle at 13px 13px, var(--bg-surface) 0 9px, transparent 10px), var(--border);cursor:pointer;border:0;border-radius:999px;flex:0 0 46px;width:46px;height:26px;transition:background .15s}._toggleRow_19vh6_101 input:checked{background:radial-gradient(circle at 33px 13px, var(--bg-surface) 0 9px, transparent 10px), var(--color-primary)}._toggleRow_19vh6_101 input:focus-visible{outline:2px solid var(--color-primary);outline-offset:3px}._footer_19vh6_193{grid-template-columns:1fr 1fr;gap:12px;padding:0 28px 28px;display:grid}._resetButton_19vh6_200,._saveButton_19vh6_201{min-height:46px;font:inherit;cursor:pointer;border-radius:10px;font-size:14px;font-weight:700;transition:background .15s,border-color .15s,color .15s}._resetButton_19vh6_200{border:1px solid var(--border);background:var(--bg-surface);color:var(--text-primary)}._resetButton_19vh6_200:hover{border-color:var(--border-strong);background:var(--bg-surface-hover)}._saveButton_19vh6_201{border:1px solid var(--color-primary);background:var(--color-primary);color:var(--bg-surface)}._saveButton_19vh6_201:hover{border-color:var(--color-primary-hover);background:var(--color-primary-hover)}@media (width<=640px){._backdrop_19vh6_1{padding:16px}._header_19vh6_26,._body_19vh6_62{padding-left:20px;padding-right:20px}._footer_19vh6_193{grid-template-columns:1fr;padding:0 20px 20px}._quotaRow_19vh6_100,._toggleRow_19vh6_101{flex-direction:column;align-items:flex-start}}._page_1v005_1{flex-direction:column;gap:18px;max-width:720px;margin:0 auto;padding:20px 18px 32px;display:flex}._progressBar_1v005_10{color:var(--text-secondary);justify-content:space-between;align-items:center;font-size:13px;font-weight:600;display:flex}._progressTrack_1v005_19{background:var(--bg-surface-muted);border-radius:999px;flex:1;height:6px;margin:0 12px;overflow:hidden}._progressFill_1v005_28{background:var(--color-primary);height:100%;transition:width .25s}._card_1v005_34{background:var(--bg-surface);border:1px solid var(--border);border-radius:14px;flex-direction:column;gap:16px;padding:24px 22px;display:flex}._prompt_1v005_44{color:var(--text-primary);font-size:18px;font-weight:700;line-height:1.5}._meta_1v005_51{color:var(--text-tertiary);font-size:12px;font-weight:500}._input_1v005_57{background:var(--color-input-bg);border:1px solid var(--color-border-input);width:100%;color:var(--text-primary);border-radius:10px;outline:none;padding:12px 14px;font-family:inherit;font-size:16px;transition:border-color .15s,background .15s}._input_1v005_57:focus{border-color:var(--color-primary);background:var(--bg-surface)}._correct_1v005_75{border-color:var(--color-ok);background:var(--color-ok-bg)}._wrong_1v005_80{border-color:var(--color-err);background:var(--color-err-bg)}._feedback_1v005_85{border-radius:10px;flex-direction:column;gap:6px;padding:12px 14px;font-size:14px;font-weight:600;display:flex}._feedbackOk_1v005_95{background:var(--color-ok-bg);color:var(--color-ok)}._feedbackErr_1v005_100{background:var(--color-err-bg);color:var(--color-err)}._feedbackAnswer_1v005_105{color:var(--text-primary);font-size:15px;font-weight:700}._feedbackSubtle_1v005_111{color:var(--text-secondary);font-size:13px;font-weight:500}._actions_1v005_117{justify-content:flex-end;gap:10px;display:flex}._button_1v005_123{cursor:pointer;border:none;border-radius:10px;padding:10px 20px;font-size:14px;font-weight:700;transition:background .15s}._buttonPrimary_1v005_133{background:var(--color-primary);color:#fff}._buttonPrimary_1v005_133:hover{background:var(--color-primary-hover)}._buttonPrimary_1v005_133:disabled{background:var(--text-muted);cursor:not-allowed}._buttonGhost_1v005_145{background:var(--bg-surface-muted);color:var(--text-secondary)}._buttonGhost_1v005_145:hover{background:var(--bg-surface-hover)}._empty_1v005_153{text-align:center;background:var(--bg-surface);border:1px solid var(--border);color:var(--text-tertiary);border-radius:14px;padding:48px 20px;font-weight:500}._summary_1v005_163{text-align:center;background:var(--bg-surface);border:1px solid var(--border);border-radius:14px;flex-direction:column;gap:16px;padding:32px 20px;display:flex}._summaryTitle_1v005_174{color:var(--text-primary);font-size:20px;font-weight:700}._summaryStats_1v005_180{color:var(--text-secondary);justify-content:center;gap:32px;font-size:14px;font-weight:500;display:flex}._summaryStatValue_1v005_189{color:var(--color-primary);margin-bottom:4px;font-size:24px;font-weight:700;display:block}._summaryActions_1v005_197{justify-content:center;gap:10px;margin-top:12px;display:flex}._page_w0ydl_1{background:var(--bg-page);color:var(--text-primary);flex-direction:column;gap:16px;padding:22px 26px 40px;display:flex}._panel_w0ydl_10{background:var(--bg-surface);border:1px solid var(--border);box-shadow:none;border-radius:12px;padding:18px 20px}._sectionHeader_w0ydl_18{align-items:center;gap:14px;margin-bottom:18px;display:flex}._sectionHeader_w0ydl_18 h2{color:var(--text-primary);font-size:14px;font-weight:700;line-height:1.35}._sectionHeader_w0ydl_18 p{color:var(--text-secondary);margin-top:2px;font-size:11.5px;font-weight:500}._iconBox_w0ydl_39{background:var(--color-primary-ghost);color:var(--color-primary);border-radius:10px;justify-content:center;align-items:center;width:38px;height:38px;display:inline-flex}._investmentGrid_w0ydl_50{grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;display:grid}._statCard_w0ydl_56{background:var(--bg-surface);border:1px solid var(--border);border-radius:12px;justify-content:space-between;align-items:center;min-height:92px;padding:16px 18px;display:flex}._statCard_w0ydl_56:first-child{background:linear-gradient(135deg, var(--uchi-hero-mid) 0%, var(--uchi-hero-to) 100%)}._statCard_w0ydl_56:nth-child(3){background:linear-gradient(135deg, var(--uchi-tag-rose-bg) 0%, var(--uchi-cream-soft) 100%)}._statLabel_w0ydl_75{color:var(--text-secondary);margin-bottom:8px;font-size:11.5px;font-weight:600;display:block}._statValue_w0ydl_83{color:var(--text-primary);font-family:var(--font-data);font-size:27px;font-weight:700;line-height:1.1;display:block}._statIcon_w0ydl_92{background:var(--color-primary-ghost);color:var(--color-primary);border-radius:10px;flex:none;justify-content:center;align-items:center;width:44px;height:44px;display:inline-flex}._toolbar_w0ydl_104{justify-content:space-between;align-items:center;gap:14px;margin-bottom:18px;display:flex}._segmented_w0ydl_112,._rangeButtons_w0ydl_113{background:var(--uchi-row-alt);border:1px solid var(--border);border-radius:999px;gap:4px;padding:4px;display:inline-flex}._segment_w0ydl_112,._segmentActive_w0ydl_123,._rangeButton_w0ydl_113,._rangeActive_w0ydl_125{color:var(--text-secondary);cursor:pointer;background:0 0;border:0;border-radius:999px;min-height:30px;padding:6px 12px;font-size:12px;font-weight:600}._segmentActive_w0ydl_123,._rangeActive_w0ydl_125{background:var(--bg-surface);color:var(--color-primary);box-shadow:none}._notice_w0ydl_144{border:1px solid var(--border);color:var(--text-secondary);border-radius:12px;justify-content:space-between;align-items:center;margin-bottom:14px;padding:14px;font-size:13px;font-weight:500;display:flex}._notice_w0ydl_144 button{background:var(--color-primary);color:var(--course-on-primary);cursor:pointer;border:0;border-radius:999px;padding:8px 12px;font-size:12px;font-weight:700}._chartBox_w0ydl_168{border:1px solid var(--border);background:var(--bg-surface);border-radius:12px;min-height:260px;position:relative}._chart_w0ydl_168{color:var(--color-primary);width:100%;height:auto;display:block}._chartGrid_w0ydl_183,._chartAxis_w0ydl_184{stroke:var(--border);stroke-width:1px}._chartArea_w0ydl_189{fill:var(--uchi-primary-soft)}._chartLine_w0ydl_193{fill:none;stroke:var(--color-primary);stroke-linecap:round;stroke-linejoin:round;stroke-width:3px}._chartDot_w0ydl_201{fill:var(--bg-surface);stroke:var(--color-primary);stroke-width:3px}._chartLabel_w0ydl_207{fill:var(--text-tertiary);font-family:var(--font-data);text-anchor:middle;font-size:12px;font-weight:700}._emptyChartText_w0ydl_215{color:var(--text-tertiary);font-size:13px;font-weight:700;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}._calendarLayout_w0ydl_225{grid-template-columns:minmax(0,1fr) 220px;gap:20px;display:grid}._calendarScroll_w0ydl_231{padding-bottom:8px;overflow-x:auto}._yearGrid_w0ydl_236{grid-template-columns:repeat(4,minmax(148px,1fr));gap:18px 16px;min-width:680px;display:grid}._monthBlock_w0ydl_243{min-width:0}._monthLabel_w0ydl_247{color:var(--text-secondary);margin-bottom:8px;font-size:12px;font-weight:700;display:block}._monthGrid_w0ydl_255{grid-template-columns:repeat(7,12px);gap:5px;display:grid}._emptyDay_w0ydl_261,._dayCell_w0ydl_262{width:12px;height:12px}._dayCell_w0ydl_262{border:1px solid var(--border);cursor:pointer;border-radius:3px;padding:0}._dayCell_w0ydl_262:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}._level0_w0ydl_279{background:var(--uchi-tag-plain-bg);border-color:var(--border)}._level1_w0ydl_284{background:var(--uchi-primary-soft);border-color:var(--uchi-primary-soft)}._level2_w0ydl_289{background:var(--uchi-hero-to);border-color:var(--uchi-hero-to)}._level3_w0ydl_294{background:var(--uchi-sage);border-color:var(--uchi-sage)}._level4_w0ydl_299{background:var(--color-primary);border-color:var(--color-primary)}._yearSide_w0ydl_304{border-left:1px solid var(--border);flex-direction:column;gap:18px;padding-left:20px;display:flex}._sideCard_w0ydl_312{border-bottom:1px solid var(--border);padding-bottom:18px}._sideCard_w0ydl_312 h3{color:var(--text-primary);margin-bottom:10px;font-size:14px;font-weight:700}._sideCard_w0ydl_312 p,._legendRow_w0ydl_325{color:var(--text-secondary);align-items:center;gap:8px;font-size:13px;font-weight:600;line-height:1.7;display:flex}._legendDot_w0ydl_335{border-radius:3px;width:12px;height:12px;display:inline-flex}._yearButtons_w0ydl_342{flex-direction:column;gap:8px;display:flex}._yearButton_w0ydl_342,._yearButtonActive_w0ydl_349{background:var(--bg-surface);border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;font-family:var(--font-data);border-radius:10px;min-height:36px;font-size:13px;font-weight:700}._yearButtonActive_w0ydl_349{background:var(--color-primary-ghost);border-color:var(--color-primary);color:var(--color-primary)}@media (width<=960px){._investmentGrid_w0ydl_50{grid-template-columns:repeat(2,minmax(0,1fr))}._calendarLayout_w0ydl_225{grid-template-columns:1fr}._yearSide_w0ydl_304{border-left:0;border-top:1px solid var(--border);grid-template-columns:1fr 1fr;padding-top:18px;padding-left:0;display:grid}._yearButtons_w0ydl_342{flex-direction:row;grid-column:1/-1}}@media (width<=768px){._page_w0ydl_1{padding:18px 16px 64px}._toolbar_w0ydl_104{flex-direction:column;align-items:flex-start}._investmentGrid_w0ydl_50{grid-template-columns:1fr}}._panel_15iol_1{border:1px solid var(--border);background:var(--bg-surface);width:100%;max-width:760px;color:var(--text-primary);box-shadow:0 1px 3px var(--course-cover-shadow);border-radius:10px;padding:18px}._header_15iol_12{align-items:flex-start;gap:12px;margin-bottom:16px;display:flex}._icon_15iol_19{background:var(--color-primary-ghost);width:34px;height:34px;color:var(--color-primary);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;display:inline-flex}._title_15iol_31{color:var(--text-primary);margin:0 0 4px;font-size:15px;font-weight:800}._desc_15iol_38{color:var(--text-secondary);margin:0;font-size:13px;font-weight:500;line-height:1.6}._note_15iol_46{color:var(--text-secondary);margin:0;font-size:13px;font-weight:600}._linkRow_15iol_53{gap:8px;margin-bottom:14px;display:flex}._linkInput_15iol_59{border:1px solid var(--border);background:var(--color-input-bg);min-width:0;color:var(--text-primary);font-size:13px;font-weight:600;font-family:var(--font-mono);border-radius:10px;flex:1;padding:10px 12px}._copyButton_15iol_72{border:1px solid var(--color-primary);background:var(--color-primary);min-width:98px;color:var(--course-on-primary);font-size:13px;font-weight:700;font-family:var(--font-jp);cursor:pointer;border-radius:10px;justify-content:center;align-items:center;gap:6px;padding:0 14px;transition:background .15s,border-color .15s,transform .1s;display:inline-flex}._copyButton_15iol_72:hover{background:var(--color-primary-hover);border-color:var(--color-primary-hover)}._copyButton_15iol_72:active{transform:scale(.98)}._error_15iol_99{color:var(--color-err);margin:-6px 0 12px;font-size:12px;font-weight:600}._metrics_15iol_106{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;display:grid}._metric_15iol_106{border:1px solid var(--border);background:var(--bg-surface-muted);border-radius:10px;min-width:0;padding:12px}._metricLabel_15iol_120{color:var(--text-tertiary);margin-bottom:4px;font-size:11px;font-weight:600;display:block}._metricValue_15iol_128{overflow-wrap:anywhere;color:var(--text-primary);font-size:14px;font-weight:700;display:block}._next_15iol_136{color:var(--color-primary);margin:12px 0 0;font-size:12px;font-weight:700}@media (width<=768px){._linkRow_15iol_53{flex-direction:column}._copyButton_15iol_72{min-height:40px}._metrics_15iol_106{grid-template-columns:1fr}}._page_4woxl_1{--reader-bg:var(--uchi-bg);--reader-paper:var(--uchi-paper);--reader-line:var(--uchi-line);--reader-ink:var(--uchi-ink);--reader-ink-2:var(--uchi-ink-2);--reader-ink-3:var(--uchi-ink-3);--reader-ink-4:var(--uchi-ink-4);--reader-sage:var(--uchi-primary);--reader-sage-mid:var(--uchi-sage-mid);--reader-rose:var(--uchi-rose-deep);--reader-row:var(--uchi-row-alt);z-index:230;background:var(--reader-bg);color:var(--reader-ink);--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;font-family:var(--font-sans);flex-direction:column;display:flex;position:fixed;inset:0;overflow:hidden}._topbar_4woxl_26{border-bottom:1px solid var(--reader-line);background:var(--reader-paper);flex-shrink:0;align-items:center;gap:16px;padding:14px 28px;display:flex}._backButton_4woxl_36{color:var(--reader-ink-2);cursor:pointer;font:inherit;background:0 0;border:0;align-items:center;gap:6px;font-size:13px;font-weight:500;display:inline-flex}._backButton_4woxl_36:hover{color:var(--reader-sage)}._divider_4woxl_53{background:var(--reader-line);flex-shrink:0;width:1px;height:18px}._bookMeta_4woxl_60{align-items:center;gap:10px;min-width:0;display:flex}._miniCover_4woxl_67{background:linear-gradient(135deg, var(--reader-sage-mid) 0%, color-mix(in srgb, var(--reader-sage-mid) 70%, var(--reader-sage) 30%) 100%);width:22px;height:30px;box-shadow:1px 2px 4px color-mix(in srgb, var(--reader-ink-2) 20%, transparent);border-radius:2px;flex-shrink:0}._bookText_4woxl_80{min-width:0}._bookTitle_4woxl_84{color:var(--reader-ink);font-family:var(--font-serif);text-overflow:ellipsis;white-space:nowrap;font-size:13px;line-height:1.2;overflow:hidden}._chapterSubtitle_4woxl_94{color:var(--reader-ink-3);text-overflow:ellipsis;white-space:nowrap;margin-top:1px;font-size:10.5px;line-height:1.2;overflow:hidden}._spacer_4woxl_104{flex:1;min-width:16px}._stats_4woxl_109{color:var(--reader-ink-3);font-variant-numeric:tabular-nums;white-space:nowrap;align-items:center;gap:18px;font-size:11.5px;display:flex}._stats_4woxl_109 b{color:var(--reader-ink);font-weight:700}._translationButton_4woxl_124{border:1px solid var(--reader-line);background:var(--reader-paper);color:var(--reader-ink-2);cursor:pointer;font:inherit;white-space:nowrap;border-radius:999px;align-items:center;gap:5px;padding:5px 12px;font-size:11.5px;font-weight:600;display:inline-flex}._translationButton_4woxl_124 span{background:var(--reader-ink-4);border-radius:50%;width:5px;height:5px}._translationButtonActive_4woxl_147{border-color:var(--reader-sage);background:var(--reader-sage);color:var(--reader-paper)}._translationButtonActive_4woxl_147 span{background:var(--reader-paper)}._progressTrack_4woxl_157{background:var(--reader-line);flex-shrink:0;height:2px}._progressFill_4woxl_163{background:var(--reader-sage);height:100%;transition:width .25s}._reader_4woxl_169{z-index:1;flex:1;min-height:0;position:relative;overflow:hidden}._readerInner_4woxl_177{flex-direction:column;height:100%;padding-top:56px;display:flex}._chapterHeading_4woxl_184{text-align:center;flex-shrink:0;width:100%;max-width:720px;margin:0 auto 36px;padding:0 40px}._chapterHeading_4woxl_184 p{color:var(--reader-ink-3);letter-spacing:1.5px;font-size:10.5px;font-weight:700}._chapterHeading_4woxl_184 h1{color:var(--reader-ink);font-family:var(--font-serif);letter-spacing:0;margin-top:8px;font-size:24px;font-style:italic;font-weight:500;line-height:1.2}._chapterHeading_4woxl_184 div{background:var(--reader-line);width:32px;height:1px;margin:16px auto 0}._page_4woxl_1 .typing-text{flex:1;width:100%;max-width:none;min-height:0;padding:0 0 220px;position:relative;overflow-y:auto}._page_4woxl_1 .typing-text__body{width:100%;max-width:720px;color:var(--reader-ink-3);font-family:var(--font-serif);letter-spacing:0;overflow-wrap:anywhere;text-align:left;word-break:normal;margin:0 auto;padding:0 40px;font-size:22px;font-weight:400;line-height:1.95}._page_4woxl_1 .letter{color:var(--reader-ink-3);text-underline-offset:4px;text-decoration-thickness:1px;transition:color .1s}._page_4woxl_1 .letter.ok{color:var(--reader-sage-mid)}._page_4woxl_1 .letter.error{color:var(--reader-rose);text-decoration:underline;-webkit-text-decoration-color:var(--reader-rose);text-decoration-color:var(--reader-rose)}._page_4woxl_1 .letter.current{background:color-mix(in srgb, var(--reader-sage) 12%, transparent);box-shadow:inset 2px 0 0 var(--reader-sage);color:var(--reader-ink)}._page_4woxl_1 .typing-text__caret{z-index:1;background:var(--reader-sage);width:2px;box-shadow:0 0 0 4px color-mix(in srgb, var(--reader-sage) 12%, transparent);opacity:0;pointer-events:none;will-change:left, top;border-radius:1px;position:absolute}._translationPanel_4woxl_279{border:1px solid var(--reader-line);background:var(--reader-paper);border-radius:12px;width:calc(100% - 80px);max-width:640px;margin:32px auto 120px;padding:20px 24px}._translationPanel_4woxl_279 p{color:var(--reader-ink-3);letter-spacing:1.2px;font-size:10.5px;font-weight:700}._translationPanel_4woxl_279 div{color:var(--reader-ink-2);font-family:var(--font-serif);letter-spacing:0;margin-top:10px;font-size:15px;line-height:1.95}._selectionToolbar_4woxl_305{z-index:260;border:1px solid var(--reader-line);background:var(--reader-paper);max-width:min(420px,100vw - 24px);box-shadow:0 8px 24px color-mix(in srgb, var(--reader-ink) 16%, transparent);border-radius:999px;align-items:center;gap:8px;padding:6px;display:flex;position:fixed}._selectionText_4woxl_319{max-width:220px;color:var(--reader-ink-2);text-overflow:ellipsis;white-space:nowrap;padding-left:10px;font-size:12px;font-weight:600;overflow:hidden}._selectionButton_4woxl_330{background:var(--reader-sage);color:var(--reader-paper);cursor:pointer;font:inherit;white-space:nowrap;border:0;border-radius:999px;padding:7px 14px;font-size:12px;font-weight:700}._selectionButton_4woxl_330:disabled{cursor:default;opacity:.68}._manualOverlay_4woxl_348{z-index:270;background:color-mix(in srgb, var(--reader-ink) 38%, transparent);justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}._manualDialog_4woxl_359{border:1px solid var(--reader-line);background:var(--reader-paper);width:min(420px,100%);box-shadow:0 18px 44px color-mix(in srgb, var(--reader-ink) 22%, transparent);border-radius:16px;padding:28px}._manualEyebrow_4woxl_368{color:var(--reader-rose);font-size:11px;font-weight:700}._manualDialog_4woxl_359 h2{color:var(--reader-ink);font-family:var(--font-serif);letter-spacing:0;margin-top:6px;font-size:24px;font-weight:500}._manualSelected_4woxl_383{border:1px solid var(--reader-line);background:var(--reader-row);color:var(--reader-ink-2);font-family:var(--font-serif);border-radius:10px;margin-top:16px;padding:12px 14px;font-size:15px;line-height:1.7}._manualNotice_4woxl_395{color:var(--reader-ink-2);margin-top:10px;font-size:12px;font-weight:600;line-height:1.6}._manualField_4woxl_403{flex-direction:column;gap:8px;margin-top:16px;display:flex}._manualField_4woxl_403 span{color:var(--reader-ink-3);font-size:11px;font-weight:700}._manualField_4woxl_403 textarea{border:1px solid var(--reader-line);background:var(--reader-paper);color:var(--reader-ink);font:inherit;resize:vertical;border-radius:10px;outline:none;min-height:104px;padding:10px 12px;font-size:14px;font-weight:500;line-height:1.7}._manualField_4woxl_403 textarea:focus{border-color:var(--reader-sage);box-shadow:0 0 0 3px color-mix(in srgb, var(--reader-sage) 14%, transparent)}._manualActions_4woxl_436{justify-content:flex-end;gap:10px;margin-top:20px;display:flex}._manualActions_4woxl_436 ._primaryButton_4woxl_443{margin-top:0}._secondaryButton_4woxl_447{border:1px solid var(--reader-line);background:var(--reader-paper);color:var(--reader-ink-2);cursor:pointer;font:inherit;border-radius:999px;justify-content:center;align-items:center;padding:10px 18px;font-size:13px;font-weight:700;display:inline-flex}._secondaryButton_4woxl_447:hover{background:var(--reader-row)}._keyHints_4woxl_466{z-index:6;color:var(--reader-ink-3);letter-spacing:.3px;pointer-events:auto;justify-content:center;gap:18px;font-size:10.5px;display:flex;position:absolute;bottom:20px;left:0;right:0}._keyHintButton_4woxl_481{color:inherit;cursor:pointer;font:inherit;letter-spacing:inherit;background:0 0;border:0;padding:0}._keyHints_4woxl_466 kbd{border:1px solid var(--reader-line);background:var(--reader-paper);color:var(--reader-ink-2);font-family:var(--font-mono);border-radius:4px;margin-right:4px;padding:2px 6px;font-size:10px}._complete_4woxl_502{text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;padding:48px 32px;display:flex}._completeEyebrow_4woxl_512{color:var(--reader-ink-3);letter-spacing:1.5px;font-size:10.5px;font-weight:700}._completeTitle_4woxl_519{color:var(--reader-ink);font-family:var(--font-serif);letter-spacing:0;margin-top:8px;font-size:32px;font-weight:500}._completeStats_4woxl_528{color:var(--reader-ink-2);font-variant-numeric:tabular-nums;gap:22px;margin-top:18px;font-size:12.5px;display:flex}._primaryButton_4woxl_443{background:var(--reader-sage);min-width:140px;color:var(--reader-paper);cursor:pointer;font:inherit;border:0;border-radius:999px;justify-content:center;align-items:center;gap:6px;margin-top:24px;padding:10px 24px;font-size:13px;font-weight:700;display:inline-flex}._primaryButton_4woxl_443:hover{background:var(--uchi-primary-hover)}._pausedOverlay_4woxl_559{z-index:240;background:color-mix(in srgb, var(--reader-ink) 42%, transparent);-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);justify-content:center;align-items:center;display:flex;position:fixed;inset:0}._pausedCard_4woxl_570{border:1px solid var(--reader-line);background:var(--reader-paper);width:min(360px,100vw - 40px);box-shadow:0 18px 44px color-mix(in srgb, var(--reader-ink) 22%, transparent);text-align:center;border-radius:16px;flex-direction:column;align-items:center;padding:36px 40px;display:flex}._pausedCard_4woxl_570 h2{color:var(--reader-ink);font-family:var(--font-serif);letter-spacing:0;font-size:24px;font-weight:500}._pausedCard_4woxl_570 p{color:var(--reader-ink-2);margin-top:10px;font-size:12.5px;line-height:1.7}@media (width<=768px){._topbar_4woxl_26{gap:10px;padding:12px 16px}._divider_4woxl_53{display:none}._stats_4woxl_109{gap:10px}._stats_4woxl_109 span:nth-child(2){display:none}._translationButton_4woxl_124{padding:5px 10px}._bookTitle_4woxl_84{max-width:150px}._readerInner_4woxl_177{padding-top:40px}._chapterHeading_4woxl_184{margin-bottom:28px;padding:0 24px}._chapterHeading_4woxl_184 h1{font-size:22px}._page_4woxl_1 .typing-text{padding-bottom:180px}._page_4woxl_1 .typing-text__body{padding:0 24px;font-size:19px;line-height:1.9}._translationPanel_4woxl_279{width:calc(100% - 48px)}._keyHints_4woxl_466{gap:12px;bottom:16px}}@media (width<=560px){._topbar_4woxl_26{flex-wrap:wrap}._bookMeta_4woxl_60{order:3;width:100%}._spacer_4woxl_104{display:none}._stats_4woxl_109{margin-left:auto}._stats_4woxl_109 span:first-child{display:none}._chapterSubtitle_4woxl_94{white-space:normal}._keyHints_4woxl_466 span:first-child{display:none}}._card_18i5x_1{background:0 0;border:none;width:100%;padding:0;display:block;position:relative}._mainButton_18i5x_10{border:1px solid var(--border);background:var(--bg-surface);width:100%;font:inherit;color:inherit;cursor:pointer;text-align:left;border-radius:12px;align-items:stretch;padding:0;transition:background .2s,border-color .2s,transform .2s;display:flex;overflow:hidden}._card_18i5x_1:hover ._mainButton_18i5x_10{border-color:var(--border-strong);background:var(--bg-surface);transform:translateY(-1px)}._mainButton_18i5x_10:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}._strip_18i5x_37{flex-shrink:0;width:4px}._body_18i5x_42{flex:1;min-width:0;padding:14px 48px 14px 16px}._title_18i5x_48{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;margin:0 0 8px;font-size:14.5px;font-weight:700;overflow:hidden}._meta_18i5x_58{align-items:center;gap:8px;display:flex}._tag_18i5x_64{background:var(--uchi-primary-soft);color:var(--uchi-primary);border-radius:999px;padding:2px 8px;font-size:11px;font-weight:600;display:inline-block}._count_18i5x_74{color:var(--text-tertiary);font-size:12px;font-weight:500}._deleteBtn_18i5x_80{width:28px;height:28px;color:var(--text-tertiary);cursor:pointer;opacity:0;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;padding:0;transition:opacity .15s,background .15s,color .15s;display:flex;position:absolute;top:10px;right:10px}._card_18i5x_1:hover ._deleteBtn_18i5x_80,._card_18i5x_1:focus-within ._deleteBtn_18i5x_80{opacity:1}._deleteBtn_18i5x_80:hover{background:var(--color-err-bg);color:var(--color-err)}._backdrop_pvtad_1{z-index:50;background:var(--scrim);justify-content:center;align-items:center;padding:24px;animation:.18s ease-out _fadeIn_pvtad_1;display:flex;position:fixed;inset:0}._dialog_pvtad_13{border:1px solid var(--border);background:var(--bg-surface);width:min(100%,460px);box-shadow:0 8px 24px var(--course-cover-shadow);border-radius:10px;padding:24px 26px 22px;animation:.18s ease-out _scaleIn_pvtad_1}._heading_pvtad_23{color:var(--text-primary);margin:0 0 20px;font-size:17px;font-weight:800}._label_pvtad_30{color:var(--text-secondary);margin-bottom:14px;font-size:12px;font-weight:600;display:block}._input_pvtad_38{border:1px solid var(--color-border-input);background:var(--color-input-bg);width:100%;color:var(--text-primary);font:inherit;box-sizing:border-box;border-radius:10px;outline:none;margin-top:6px;padding:10px 12px;font-size:13px;font-weight:600;transition:border-color .15s;display:block}._input_pvtad_38:focus{border-color:var(--color-primary)}._textarea_pvtad_59{border:1px solid var(--color-border-input);background:var(--color-input-bg);width:100%;color:var(--text-primary);font:inherit;resize:vertical;box-sizing:border-box;border-radius:10px;outline:none;margin-top:6px;padding:10px 12px;font-size:13px;font-weight:600;transition:border-color .15s;display:block}._textarea_pvtad_59:focus{border-color:var(--color-primary)}._colorSection_pvtad_81{margin-bottom:20px}._swatches_pvtad_85{gap:8px;margin-top:8px;display:flex}._swatch_pvtad_85{cursor:pointer;border:2px solid #0000;border-radius:8px;width:28px;height:28px;padding:0;transition:border-color .15s,transform .15s}._swatch_pvtad_85:hover{transform:scale(1.1)}._swatchActive_pvtad_105{border-color:var(--color-primary)}._actions_pvtad_109{justify-content:flex-end;gap:10px;margin-top:4px;display:flex}._cancelBtn_pvtad_116{border:1px solid var(--border);background:var(--bg-surface);min-width:92px;color:var(--text-primary);font:inherit;cursor:pointer;border-radius:10px;padding:10px 18px;font-size:14px;font-weight:700;transition:background .15s,border-color .15s}._cancelBtn_pvtad_116:hover{border-color:var(--border-strong);background:var(--bg-surface-hover)}._saveBtn_pvtad_135{border:1px solid var(--color-primary);background:var(--color-primary);min-width:92px;color:var(--course-on-primary);font:inherit;cursor:pointer;border-radius:10px;padding:10px 18px;font-size:14px;font-weight:700;transition:background .15s,border-color .15s,opacity .15s}._saveBtn_pvtad_135:hover:not(:disabled){border-color:var(--color-primary-hover);background:var(--color-primary-hover)}._saveBtn_pvtad_135:disabled{opacity:.5;cursor:not-allowed}@keyframes _fadeIn_pvtad_1{0%{opacity:0}to{opacity:1}}@keyframes _scaleIn_pvtad_1{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}._page_19fr1_1{background:var(--bg-page);min-height:100vh;color:var(--text-primary)}._content_19fr1_7{padding:22px 26px 40px}._header_19fr1_11{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}._heading_19fr1_18{color:var(--text-primary);margin:0;font-size:14px;font-weight:700}._createBtn_19fr1_25{background:var(--color-primary);color:var(--course-on-primary);font:inherit;cursor:pointer;border:none;border-radius:999px;align-items:center;gap:6px;padding:8px 16px;font-size:13px;font-weight:700;transition:background .15s;display:inline-flex}._createBtn_19fr1_25:hover{background:var(--color-primary-hover)}._createBtn_19fr1_25:active{transform:scale(.97)}._grid_19fr1_49{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px;display:grid}._status_19fr1_55{color:var(--text-tertiary);font-size:13px;font-weight:600}._empty_19fr1_61{flex-direction:column;align-items:center;gap:8px;padding:60px 20px;display:flex}._emptyIcon_19fr1_69{margin-bottom:4px;font-size:32px}._emptyTitle_19fr1_74{color:var(--text-primary);margin:0;font-size:15px;font-weight:700}._emptyHint_19fr1_81{color:var(--text-tertiary);margin:0 0 12px;font-size:13px;font-weight:600}._backdrop_n1nej_1{z-index:50;background:var(--scrim);justify-content:center;align-items:center;padding:24px;animation:.18s ease-out _fadeIn_n1nej_1;display:flex;position:fixed;inset:0}._dialog_n1nej_13{border:1px solid var(--border);background:var(--bg-surface);width:min(100%,420px);box-shadow:0 8px 24px var(--course-cover-shadow);border-radius:10px;padding:24px 26px 22px;animation:.18s ease-out _scaleIn_n1nej_1}._heading_n1nej_23{color:var(--text-primary);margin:0 0 20px;font-size:17px;font-weight:800}._label_n1nej_30{color:var(--text-secondary);margin-bottom:14px;font-size:12px;font-weight:600;display:block}._input_n1nej_38{border:1px solid var(--color-border-input);background:var(--color-input-bg);width:100%;color:var(--text-primary);font:inherit;box-sizing:border-box;border-radius:10px;outline:none;margin-top:6px;padding:10px 12px;font-size:13px;font-weight:600;transition:border-color .15s;display:block}._input_n1nej_38:focus{border-color:var(--color-primary)}._actions_n1nej_59{justify-content:flex-end;gap:10px;margin-top:6px;display:flex}._cancelBtn_n1nej_66{border:1px solid var(--border);background:var(--bg-surface);min-width:92px;color:var(--text-primary);font:inherit;cursor:pointer;border-radius:10px;padding:10px 18px;font-size:14px;font-weight:700;transition:background .15s,border-color .15s}._cancelBtn_n1nej_66:hover{border-color:var(--border-strong);background:var(--bg-surface-hover)}._saveBtn_n1nej_85{border:1px solid var(--color-primary);background:var(--color-primary);min-width:92px;color:var(--course-on-primary);font:inherit;cursor:pointer;border-radius:10px;padding:10px 18px;font-size:14px;font-weight:700;transition:background .15s,border-color .15s,opacity .15s}._saveBtn_n1nej_85:hover:not(:disabled){border-color:var(--color-primary-hover);background:var(--color-primary-hover)}._saveBtn_n1nej_85:disabled{opacity:.5;cursor:not-allowed}@keyframes _fadeIn_n1nej_1{0%{opacity:0}to{opacity:1}}@keyframes _scaleIn_n1nej_1{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}._page_a3188_1{background:var(--bg-page);min-height:100vh;color:var(--text-primary)}._content_a3188_7{padding:22px 26px 40px}._courseInfo_a3188_11{border:1px solid var(--border);background:var(--bg-surface);border-radius:12px;align-items:flex-start;gap:12px;margin-bottom:24px;padding:16px;display:flex}._backBtn_a3188_22{border:1px solid var(--border);background:var(--bg-surface);width:32px;height:32px;color:var(--text-secondary);cursor:pointer;border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;padding:0;transition:background .15s;display:flex}._backBtn_a3188_22:hover{background:var(--bg-surface-hover)}._courseText_a3188_42{flex:1;min-width:0}._courseTitleRow_a3188_47{align-items:center;gap:8px;margin-bottom:6px;display:flex}._colorDot_a3188_54{border-radius:4px;flex-shrink:0;width:10px;height:10px}._courseTitle_a3188_47{color:var(--text-primary);margin:0;font-size:16px;font-weight:700}._editBtn_a3188_68{width:28px;height:28px;color:var(--text-tertiary);cursor:pointer;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;padding:0;transition:background .15s,color .15s;display:flex}._editBtn_a3188_68:hover{background:var(--bg-surface-hover);color:var(--color-primary)}._courseDesc_a3188_88{color:var(--text-secondary);margin:0 0 6px;font-size:13px;font-weight:500;line-height:1.5}._tag_a3188_96{background:var(--uchi-primary-soft);color:var(--uchi-primary);border-radius:999px;padding:2px 8px;font-size:11px;font-weight:600;display:inline-block}._sectionHeader_a3188_106{justify-content:space-between;align-items:center;margin-bottom:14px;display:flex}._sectionTitle_a3188_113{color:var(--text-primary);margin:0;font-size:14px;font-weight:700}._addBtn_a3188_120{border:1px solid var(--border);background:var(--bg-surface);color:var(--text-primary);font:inherit;cursor:pointer;border-radius:999px;align-items:center;gap:6px;padding:6px 14px;font-size:12px;font-weight:700;transition:background .15s,border-color .15s;display:inline-flex}._addBtn_a3188_120:hover{border-color:var(--border-strong);background:var(--bg-surface-hover)}._status_a3188_141{color:var(--text-tertiary);font-size:13px;font-weight:600}._emptyHint_a3188_147{color:var(--text-tertiary);text-align:center;padding:32px 0;font-size:13px;font-weight:600}._list_a3188_155{flex-direction:column;gap:8px;margin:0;padding:0;list-style:none;display:flex}._lessonRow_a3188_164{border:1px solid var(--border);background:var(--bg-surface);border-radius:12px;align-items:center;transition:background .2s,border-color .2s,transform .2s;display:flex}._lessonRow_a3188_164:hover{border-color:var(--border-strong);background:var(--uchi-row-alt);transform:none}._lessonBtn_a3188_179{font:inherit;cursor:pointer;text-align:left;background:0 0;border:none;flex:1;align-items:center;gap:12px;min-width:0;padding:14px 16px;display:flex}._lessonTitle_a3188_193{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:700;overflow:hidden}._lessonSub_a3188_202{color:var(--text-tertiary);white-space:nowrap;text-overflow:ellipsis;font-size:12px;font-weight:500;overflow:hidden}._lessonCount_a3188_211{color:var(--text-tertiary);flex-shrink:0;margin-left:auto;font-size:12px;font-weight:600}._deleteBtn_a3188_219{width:32px;height:32px;color:var(--text-tertiary);cursor:pointer;opacity:0;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;margin-right:10px;padding:0;transition:opacity .15s,background .15s,color .15s;display:flex}._lessonRow_a3188_164:hover ._deleteBtn_a3188_219{opacity:1}._deleteBtn_a3188_219:hover{background:var(--color-err-bg);color:var(--color-err)}._row_1ab6w_1{border-radius:10px;align-items:center;transition:background .15s;display:flex}._row_1ab6w_1:hover{background:var(--uchi-row-alt)}._selected_1ab6w_12{background:var(--uchi-primary-soft);border-left:3px solid var(--color-primary)}._btn_1ab6w_17{font:inherit;cursor:pointer;text-align:left;background:0 0;border:none;flex:1;align-items:center;gap:8px;min-width:0;padding:8px 10px;display:flex}._badge_1ab6w_31{background:var(--uchi-cream-soft);width:24px;height:20px;color:var(--text-tertiary);border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;font-size:10px;font-weight:700;display:inline-flex}._text_1ab6w_45{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:500;overflow:hidden}._deleteBtn_1ab6w_54{width:26px;height:26px;color:var(--text-tertiary);cursor:pointer;opacity:0;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;margin-right:6px;padding:0;transition:opacity .15s,background .15s,color .15s;display:flex}._row_1ab6w_1:hover ._deleteBtn_1ab6w_54{opacity:1}._deleteBtn_1ab6w_54:hover{background:var(--color-err-bg);color:var(--color-err)}._placeholder_16ymr_1{justify-content:center;align-items:center;min-height:200px;display:flex}._placeholderText_16ymr_8{color:var(--text-tertiary);font-size:14px;font-weight:600}._form_16ymr_14{flex-direction:column;display:flex}._heading_16ymr_19{color:var(--text-primary);margin:0 0 16px;font-size:15px;font-weight:700}._label_16ymr_26{color:var(--text-secondary);margin-bottom:14px;font-size:12px;font-weight:600;display:block}._textarea_16ymr_34{border:1px solid var(--color-border-input);background:var(--color-input-bg);width:100%;color:var(--text-primary);font:inherit;resize:vertical;box-sizing:border-box;border-radius:12px;outline:none;margin-top:6px;padding:10px 12px;font-size:13px;font-weight:500;transition:border-color .15s;display:block}._textarea_16ymr_34:focus{border-color:var(--color-primary)}._actions_16ymr_56{justify-content:flex-end;gap:10px;margin-top:6px;display:flex}._cancelBtn_16ymr_63{border:1px solid var(--border);background:var(--bg-surface);min-width:92px;color:var(--text-primary);font:inherit;cursor:pointer;border-radius:999px;padding:10px 18px;font-size:14px;font-weight:700;transition:background .15s,border-color .15s}._cancelBtn_16ymr_63:hover{border-color:var(--border-strong);background:var(--bg-surface-hover)}._saveBtn_16ymr_82{border:1px solid var(--color-primary);background:var(--color-primary);min-width:92px;color:var(--course-on-primary);font:inherit;cursor:pointer;border-radius:999px;padding:10px 18px;font-size:14px;font-weight:700;transition:background .15s,border-color .15s,opacity .15s}._saveBtn_16ymr_82:hover:not(:disabled){border-color:var(--color-primary-hover);background:var(--color-primary-hover)}._saveBtn_16ymr_82:disabled{opacity:.5;cursor:not-allowed}._page_15bdu_1{background:var(--bg-page);min-height:100vh;color:var(--text-primary)}._content_15bdu_7{padding:22px 26px 40px}._status_15bdu_11{color:var(--text-tertiary);font-size:13px;font-weight:600}._split_15bdu_17{gap:20px;min-height:480px;display:flex}._left_15bdu_23{border:1px solid var(--border);background:var(--bg-surface);border-radius:12px;flex-direction:column;flex:0 0 35%;max-width:35%;padding:16px;display:flex;overflow-y:auto}._leftHeader_15bdu_35{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}._leftTitle_15bdu_42{color:var(--text-primary);margin:0;font-size:14px;font-weight:700}._addBtn_15bdu_49{border:1px solid var(--border);background:var(--bg-surface);color:var(--text-primary);font:inherit;cursor:pointer;border-radius:999px;align-items:center;gap:4px;padding:6px 12px;font-size:12px;font-weight:600;transition:background .15s,border-color .15s;display:inline-flex}._addBtn_15bdu_49:hover{border-color:var(--border-strong);background:var(--bg-surface-hover)}._emptyHint_15bdu_70{color:var(--text-tertiary);text-align:center;padding:32px 0;font-size:13px;font-weight:600}._sentenceList_15bdu_78{flex-direction:column;gap:4px;margin:0;padding:0;list-style:none;display:flex}._right_15bdu_87{border:1px solid var(--border);background:var(--bg-surface);border-radius:12px;flex:1;min-width:0;padding:20px}@media (width<=768px){._split_15bdu_17{flex-direction:column}._left_15bdu_23{flex:none;max-width:100%;max-height:300px}}._nav_17nnf_1{z-index:100;background:var(--uchi-bg);border-bottom:1px solid var(--border);padding:0 28px;position:sticky;top:0}._inner_17nnf_10{justify-content:space-between;align-items:center;max-width:1100px;height:56px;margin:0 auto;display:flex}._brand_17nnf_19{align-items:center;gap:10px;display:flex}._logo_17nnf_25{background:var(--color-primary);width:32px;height:32px;color:var(--course-on-primary);font-family:var(--font-serif);border-radius:10px;justify-content:center;align-items:center;font-size:16px;font-weight:700;display:flex}._brandName_17nnf_39{color:var(--text-primary);font-size:17px;font-weight:700}._badge_17nnf_45{background:var(--uchi-primary-soft);color:var(--uchi-primary);border-radius:999px;padding:2px 8px;font-size:10px;font-weight:600}._actions_17nnf_54{align-items:center;gap:12px;display:flex}._themeBtn_17nnf_60{border:1px solid var(--border);width:36px;height:36px;color:var(--icon-color);cursor:pointer;background:0 0;border-radius:10px;justify-content:center;align-items:center;transition:background .2s;display:flex}._themeBtn_17nnf_60:hover{background:var(--bg-surface-hover)}._ctaBtn_17nnf_78{background:var(--color-primary);color:var(--course-on-primary);font-size:14px;font-weight:700;font-family:var(--font-jp);cursor:pointer;border:none;border-radius:999px;padding:8px 18px;transition:background .2s}._ctaBtn_17nnf_78:hover{background:var(--color-primary-hover)}._ctaBtn_17nnf_78:active{transform:scale(.97)}@media (width<=480px){._badge_17nnf_45{display:none}}._section_ofzuw_1{background:var(--uchi-bg);padding:80px 28px 60px}._inner_ofzuw_6{grid-template-columns:1fr 1fr;align-items:center;gap:48px;max-width:1100px;margin:0 auto;display:grid}._content_ofzuw_16{flex-direction:column;align-items:flex-start;display:flex}._tag_ofzuw_22{background:var(--uchi-primary-soft);color:var(--uchi-primary);border-radius:999px;margin-bottom:16px;padding:4px 12px;font-size:12px;font-weight:700;display:inline-block}._heading_ofzuw_33{color:var(--text-primary);font-size:38px;font-weight:700;line-height:1.3;font-family:var(--font-jp);margin:0 0 16px}._subtitle_ofzuw_42{color:var(--text-secondary);margin:0 0 28px;font-size:16px;font-weight:500;line-height:1.7}._cta_ofzuw_50{background:var(--color-primary);color:var(--course-on-primary);font-size:16px;font-weight:700;font-family:var(--font-jp);cursor:pointer;border:none;border-radius:999px;align-items:center;gap:8px;padding:14px 28px;transition:background .2s;display:inline-flex}._cta_ofzuw_50:hover{background:var(--color-primary-hover)}._cta_ofzuw_50:active{transform:scale(.97)}._hint_ofzuw_74{color:var(--text-tertiary);margin-top:12px;font-size:13px;font-weight:600}._videoWrap_ofzuw_82{border:1px solid var(--border);box-shadow:none;border-radius:12px;overflow:hidden}._video_ofzuw_82{border-radius:12px;width:100%;height:auto;display:block}@media (width<=1024px){._inner_ofzuw_6{grid-template-columns:1fr;gap:40px}._content_ofzuw_16{text-align:center;align-items:center}}@media (width<=768px){._section_ofzuw_1{padding:60px 16px 40px}._heading_ofzuw_33{font-size:28px}._subtitle_ofzuw_42{font-size:15px}}@media (width<=480px){._cta_ofzuw_50{justify-content:center;width:100%}}._wrapper_1vo1w_1{max-width:600px;margin:0 auto;padding:32px 40px}._actions_1vo1w_7{justify-content:flex-end;gap:12px;margin-top:24px;display:flex}._ctaBtn_1vo1w_14{background:var(--color-primary);color:var(--course-on-primary);font-size:15px;font-weight:800;font-family:var(--font-jp);cursor:pointer;border:none;border-radius:10px;align-items:center;gap:6px;padding:12px 24px;transition:background .2s;display:inline-flex}._ctaBtn_1vo1w_14:hover{background:var(--color-primary-hover)}._ctaBtn_1vo1w_14:active{transform:scale(.97)}@media (width<=768px){._wrapper_1vo1w_1{padding:24px 16px}}._section_yacke_1{background:var(--bg-surface);padding:60px 16px}._inner_yacke_6{max-width:1200px;margin:0 auto}._label_yacke_11{letter-spacing:0;color:var(--color-primary);text-transform:none;text-align:center;margin-bottom:8px;font-size:11px;font-weight:700}._title_yacke_21{color:var(--text-primary);font-size:26px;font-weight:700;font-family:var(--font-jp);text-align:center;margin:0 0 10px}._subtitle_yacke_30{color:var(--text-secondary);text-align:center;margin:0 0 32px;font-size:14px;font-weight:500}._demoCard_yacke_39{background:var(--bg-surface);border:1px solid var(--border);max-width:100%;box-shadow:none;border-radius:12px;flex-direction:column;margin:0 auto;display:flex;position:relative;overflow:hidden}._demoHeader_yacke_53{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:18px 36px;display:flex}._headerLeft_yacke_61{color:var(--text-secondary);font-size:15px;font-weight:600;font-family:var(--font-data);flex-shrink:0}._progressTrack_yacke_69{background:var(--border);border-radius:4px;flex:1;height:7px;margin:0 28px;overflow:hidden}._progressFill_yacke_78{background:var(--color-secondary);border-radius:4px;height:100%;transition:width .4s}._score_yacke_85{color:var(--color-warn);font-size:22px;font-weight:700;font-family:var(--font-data);flex-shrink:0}._scoreBounce_yacke_93{animation:.3s ease-out _scorePop_yacke_1}@keyframes _scorePop_yacke_1{0%{transform:scale(1)}50%{transform:scale(1.3)}to{transform:scale(1)}}._demoBody_yacke_104{flex:1;min-height:560px;padding:0}._demoBody_yacke_104 .main-content--question{flex-direction:column;justify-content:center;align-items:center;min-height:540px;padding:48px;display:flex}._demoBody_yacke_104 .japanese-sentence--question{margin-bottom:36px;font-size:26px}._demoBody_yacke_104 .words-row--question{justify-content:center;gap:16px}._demoBody_yacke_104 .main-content{flex-direction:column;justify-content:center;align-items:center;min-height:540px;padding:40px 48px;display:flex}._demoBody_yacke_104 .words-row--answer{justify-content:center}._demoBody_yacke_104 .japanese-sentence{font-size:20px}@media (width<=768px){._section_yacke_1{padding:60px 16px}._title_yacke_21{font-size:22px}._demoHeader_yacke_53{padding:14px 16px}._demoBody_yacke_104{min-height:320px}._demoBody_yacke_104 .main-content--question{min-height:300px;padding:32px 16px}._demoBody_yacke_104 .main-content{min-height:300px;padding:28px 16px}}._section_1r4qe_1{background:var(--bg-page);padding:80px 28px}._inner_1r4qe_6{max-width:1100px;margin:0 auto}._label_1r4qe_11{letter-spacing:0;color:var(--color-primary);text-transform:none;margin-bottom:8px;font-size:11px;font-weight:700}._title_1r4qe_20{color:var(--text-primary);font-size:26px;font-weight:700;font-family:var(--font-jp);margin:0 0 32px}._grid_1r4qe_28{grid-template-columns:repeat(3,1fr);gap:20px;display:grid}._card_1r4qe_34{background:var(--bg-surface);border:1px solid var(--border);border-radius:12px;padding:28px 24px;transition:transform .2s}._card_1r4qe_34:hover{transform:translateY(-1px)}._iconWrap_1r4qe_46{background:var(--uchi-primary-soft);width:44px;height:44px;color:var(--uchi-primary);border-radius:10px;justify-content:center;align-items:center;margin-bottom:16px;display:flex}._cardTitle_1r4qe_58{color:var(--text-primary);font-size:16px;font-weight:700;font-family:var(--font-jp);margin:0 0 8px}._cardDesc_1r4qe_66{color:var(--text-secondary);margin:0;font-size:14px;font-weight:500;line-height:1.6}@media (width<=768px){._section_1r4qe_1{padding:60px 16px}._grid_1r4qe_28{grid-template-columns:1fr;gap:16px}._title_1r4qe_20{font-size:22px}}._section_g1ox1_1{background:var(--bg-surface);padding:80px 28px}._inner_g1ox1_6{max-width:1100px;margin:0 auto}._label_g1ox1_11{letter-spacing:0;color:var(--color-primary);text-transform:none;margin-bottom:8px;font-size:11px;font-weight:700}._title_g1ox1_20{color:var(--text-primary);font-size:26px;font-weight:700;font-family:var(--font-jp);margin:0 0 32px}._steps_g1ox1_28{grid-template-columns:repeat(3,1fr);gap:24px;display:grid}._step_g1ox1_28{flex-direction:column;align-items:flex-start;gap:12px;display:flex}._number_g1ox1_41{background:var(--uchi-primary-soft);width:36px;height:36px;color:var(--uchi-primary);font-size:16px;font-weight:700;font-family:var(--font-data);border-radius:50%;justify-content:center;align-items:center;display:flex}._stepTitle_g1ox1_55{color:var(--text-primary);font-size:16px;font-weight:700;font-family:var(--font-jp);margin:0}._stepDesc_g1ox1_63{color:var(--text-secondary);margin:0;font-size:14px;font-weight:500;line-height:1.6}@media (width<=768px){._section_g1ox1_1{padding:60px 16px}._steps_g1ox1_28{grid-template-columns:1fr;gap:24px}._title_g1ox1_20{font-size:22px}}._section_12pl5_1{text-align:center;border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:linear-gradient(120deg, var(--uchi-hero-from) 0%, var(--uchi-hero-mid) 100%);color:var(--text-primary);padding:80px 28px}._inner_12pl5_10{max-width:600px;margin:0 auto}._icon_12pl5_15{color:var(--color-primary);margin-bottom:16px;font-size:48px}._title_12pl5_21{font-size:28px;font-weight:700;font-family:var(--font-jp);margin:0 0 10px}._subtitle_12pl5_28{color:var(--text-secondary);margin:0 0 28px;font-size:15px;font-weight:500}._button_12pl5_35{border:1px solid var(--color-primary);background:var(--color-primary);color:var(--course-on-primary);font-size:16px;font-weight:700;font-family:var(--font-jp);cursor:pointer;border-radius:999px;align-items:center;gap:8px;padding:14px 32px;transition:all .2s;display:inline-flex}._button_12pl5_35:hover{border-color:var(--color-primary-hover);background:var(--color-primary-hover)}._button_12pl5_35:active{transform:scale(.97)}@media (width<=768px){._section_12pl5_1{padding:60px 16px}._title_12pl5_21{font-size:22px}}@media (width<=480px){._button_12pl5_35{justify-content:center;width:100%}}._footer_avso6_1{border-top:1px solid var(--border);background:var(--bg-surface);padding:32px 28px}._inner_avso6_7{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:20px;max-width:1100px;margin:0 auto;display:flex}._brand_avso6_17{align-items:center;gap:10px;display:flex}._logo_avso6_23{background:var(--color-primary);width:28px;height:28px;color:var(--course-on-primary);border-radius:6px;justify-content:center;align-items:center;font-size:14px;font-weight:800;display:flex}._brandName_avso6_36{color:var(--text-primary);font-size:15px;font-weight:800}._links_avso6_42{gap:20px;margin:0;padding:0;list-style:none;display:flex}._link_avso6_42{color:var(--text-tertiary);cursor:pointer;font-size:13px;font-weight:600;font-family:var(--font-jp);background:0 0;border:none;padding:0;text-decoration:none;transition:color .2s}._link_avso6_42:hover{color:var(--text-secondary)}._copyright_avso6_67{color:var(--text-muted);font-size:12px;font-weight:600}@media (width<=768px){._inner_avso6_7{text-align:center;flex-direction:column;align-items:center;gap:16px}}._root_16l3m_1{background:var(--bg-page);width:100vw;height:100vh;color:var(--text-primary);overflow:hidden auto}._form_wfev8_1{flex-direction:column;gap:16px;display:flex}._label_wfev8_7{color:var(--text-primary);flex-direction:column;gap:6px;font-size:13px;font-weight:600;display:flex}._input_wfev8_16{border:1px solid var(--border);background:var(--color-input-bg);color:var(--text-primary);font-size:14px;font-weight:500;font-family:var(--font-jp);border-radius:12px;outline:none;padding:11px 14px;transition:border-color .2s,box-shadow .2s}._input_wfev8_16:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-ghost)}._input_wfev8_16::placeholder{color:var(--text-tertiary);font-weight:500}._hint_wfev8_39{border:1px solid var(--border);background:var(--uchi-primary-soft);color:var(--uchi-primary);border-radius:10px;margin:-4px 0 0;padding:8px 12px;font-size:12px;font-weight:700}._error_wfev8_50{color:var(--color-err);background:var(--color-err-bg);border-radius:10px;margin:0;padding:8px 12px;font-size:13px;font-weight:600}._button_wfev8_60{background:var(--color-primary);color:var(--course-on-primary);font-size:15px;font-weight:700;font-family:var(--font-jp);cursor:pointer;border:none;border-radius:999px;margin-top:4px;padding:12px 0;transition:background .2s,transform .1s}._button_wfev8_60:hover{background:var(--color-primary-hover)}._button_wfev8_60:active{transform:scale(.97)}._button_wfev8_60:disabled{opacity:.6;cursor:not-allowed}._wrap_29hxg_1{flex-direction:column;gap:10px;display:flex}._btn_29hxg_7{border:1px solid var(--border);background:var(--bg-surface);width:100%;color:var(--text-primary);font-size:14px;font-weight:700;font-family:var(--font-jp);cursor:pointer;border-radius:10px;justify-content:center;align-items:center;gap:10px;padding:11px 0;transition:background .2s,border-color .2s;display:flex}._btn_29hxg_7:hover{background:var(--bg-surface-hover);border-color:var(--border-strong)}._btn_29hxg_7:active{transform:scale(.98)}._icon_29hxg_34{flex-shrink:0;width:18px;height:18px}._btnLine_29hxg_41{color:#fff;background:#06c755;border-color:#06c755}._btnLine_29hxg_41:hover{background:#05b34c;border-color:#05b34c}._btnTwitter_29hxg_53{background:var(--text-primary);border-color:var(--text-primary);color:var(--bg-surface)}._btnTwitter_29hxg_53:hover{opacity:.9;background:var(--text-primary);border-color:var(--text-primary)}._root_17iy2_1{background:linear-gradient(160deg,#1a1a2e 0%,#2a1a3e 100%);border-radius:20px;flex-direction:column;justify-content:center;align-items:center;width:100%;max-width:520px;height:440px;padding:32px 24px;display:flex;position:relative;overflow:hidden}._glow_17iy2_17{filter:blur(30px);pointer-events:none;background:radial-gradient(circle,#5b4fc766,#0000 60%);border-radius:50%;width:400px;height:400px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}._prompt_17iy2_31{z-index:2;flex-direction:column;align-items:center;gap:6px;margin-bottom:10px;display:flex;position:relative}._promptLabel_17iy2_41{letter-spacing:.2em;text-transform:uppercase;color:#ffffff80;font-size:10px;font-weight:700;font-family:var(--font-data)}._promptText_17iy2_50{color:#ffffffd9;font-size:14px;font-weight:500;font-family:var(--font-jp)}._typingBox_17iy2_58{z-index:2;align-items:center;min-height:40px;margin-bottom:24px;padding:0 4px;display:flex;position:relative}._typed_17iy2_68{color:#fff;font-size:26px;font-weight:600;font-family:var(--font-en);letter-spacing:-.01em;line-height:1.2}._cursor_17iy2_77{background:#fff;width:2px;height:24px;margin-left:3px;animation:.9s infinite _blink_17iy2_1;display:inline-block}@keyframes _blink_17iy2_1{0%,50%{opacity:1}51%,to{opacity:0}}._keyboard_17iy2_92{z-index:2;transform-origin:bottom;background:#ffffff0f;border:1px solid #ffffff1a;border-radius:16px;flex-direction:column;gap:6px;padding:18px;display:flex;position:relative;transform:perspective(800px)rotateX(25deg);box-shadow:inset 0 1px #ffffff1a,0 20px 40px #0000004d}._keyRow_17iy2_109{justify-content:center;gap:6px;display:flex}._keyRow_17iy2_109:nth-child(2){padding-left:16px}._keyRow_17iy2_109:nth-child(3){padding-left:32px}._key_17iy2_92{color:#ffffffbf;width:32px;height:32px;font-size:11px;font-weight:700;font-family:var(--font-data);background:#ffffff14;border:1px solid #ffffff1f;border-radius:7px;justify-content:center;align-items:center;transition:all 80ms;display:flex;box-shadow:inset 0 -2px #0003,0 1px 2px #0003}._keySpace_17iy2_141{border-radius:6px;width:180px;height:24px}._keyPressed_17iy2_147{background:var(--color-primary);border-color:var(--color-primary-hover);color:#fff;transform:translateY(2px);box-shadow:inset 0 -1px #0003,0 0 20px #5b4fc799,0 0 40px #5b4fc74d}._floatWord_17iy2_159{font-size:14px;font-weight:600;font-family:var(--font-en);color:#ffffff40;z-index:1;pointer-events:none;font-style:italic;position:absolute}._word1_17iy2_170{animation:5s ease-in-out infinite _float1_17iy2_1;top:15%;left:10%}._word2_17iy2_176{animation:6s ease-in-out infinite _float2_17iy2_1;top:25%;right:12%}._word3_17iy2_182{animation:5.5s ease-in-out infinite _float3_17iy2_1;bottom:20%;right:8%}@keyframes _float1_17iy2_1{0%,to{opacity:.25;transform:translateY(0)rotate(-3deg)}50%{opacity:.4;transform:translateY(-10px)rotate(-3deg)}}@keyframes _float2_17iy2_1{0%,to{opacity:.2;transform:translateY(0)rotate(4deg)}50%{opacity:.35;transform:translateY(-12px)rotate(4deg)}}@keyframes _float3_17iy2_1{0%,to{opacity:.25;transform:translateY(0)rotate(-2deg)}50%{opacity:.4;transform:translateY(-8px)rotate(-2deg)}}@media (width<=768px){._root_17iy2_1{max-width:360px;height:320px;padding:20px 16px}._typed_17iy2_68{font-size:18px}._key_17iy2_92{width:24px;height:24px;font-size:9px}._keySpace_17iy2_141{width:120px;height:18px}._keyboard_17iy2_92{gap:4px;padding:12px}._keyRow_17iy2_109{gap:4px}}._wrap_h2dyu_1{justify-content:center;width:100%;max-width:560px;animation:.6s ease-out _floatIn_h2dyu_1;display:flex}@keyframes _floatIn_h2dyu_1{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}._root_dvr14_1{background:var(--bg-page);min-height:100vh;display:flex}._left_dvr14_9{background:linear-gradient(120deg, var(--uchi-hero-from) 0%, var(--uchi-hero-mid) 100%);flex-direction:column;flex:1;justify-content:center;align-items:center;padding:48px 40px;display:flex;position:relative;overflow:hidden}._backBtn_dvr14_22{border:1px solid var(--border);background:var(--bg-surface);color:var(--text-secondary);font-size:13px;font-weight:700;font-family:var(--font-jp);cursor:pointer;z-index:1;border-radius:999px;align-items:center;gap:6px;padding:8px 14px;transition:all .2s;display:flex;position:absolute;top:24px;left:24px}._backBtn_dvr14_22:hover{background:var(--bg-surface-hover);color:var(--text-primary);border-color:var(--border-strong)}._backLabel_dvr14_48{line-height:1}._brandArea_dvr14_52{text-align:center;z-index:1;animation:.5s ease-out _fadeUp_dvr14_1;position:relative}._logoRow_dvr14_59{justify-content:center;align-items:center;gap:10px;margin-bottom:16px;display:flex}._logo_dvr14_59{background:var(--color-primary);width:40px;height:40px;color:var(--course-on-primary);font-family:var(--font-serif);border-radius:10px;justify-content:center;align-items:center;font-size:19px;font-weight:700;display:flex}._logoText_dvr14_81{color:var(--text-primary);font-size:20px;font-weight:700}._welcome_dvr14_87{color:var(--text-primary);letter-spacing:0;margin-bottom:8px;font-size:26px;font-weight:700}._tagline_dvr14_95{color:var(--text-secondary);margin-bottom:28px;font-size:14px;font-weight:500}._socialProof_dvr14_103{background:var(--bg-surface);border:1px solid var(--border);border-radius:12px;justify-content:center;align-items:center;gap:20px;padding:14px 24px;animation:.5s ease-out .15s both _fadeUp_dvr14_1;display:flex}._proofItem_dvr14_115{flex-direction:column;align-items:center;gap:2px;display:flex}._proofNumber_dvr14_122{color:var(--text-primary);font-size:16px;font-weight:700;font-family:var(--font-data)}._proofLabel_dvr14_129{color:var(--text-tertiary);font-size:11px;font-weight:600}._proofDivider_dvr14_135{background:var(--border);width:1px;height:28px}._right_dvr14_143{flex:1;justify-content:center;align-items:center;padding:48px 40px;display:flex}._formWrapper_dvr14_151{width:400px;max-width:100%;animation:.5s ease-out .1s both _fadeUp_dvr14_1}._formCard_dvr14_157{background:var(--bg-surface);border:1px solid var(--border);box-shadow:none;border-radius:12px;padding:32px}._formTitle_dvr14_165{color:var(--text-primary);margin-bottom:6px;font-size:22px;font-weight:700}._formSub_dvr14_172{color:var(--text-secondary);margin-bottom:24px;font-size:13px;font-weight:500;line-height:1.5}._dividerRow_dvr14_181{align-items:center;gap:12px;margin-top:20px;display:flex}._dividerLine_dvr14_188{background:var(--border);flex:1;height:1px}._dividerText_dvr14_194{color:var(--text-tertiary);flex-shrink:0;font-size:12px;font-weight:600}._switchRow_dvr14_202{text-align:center;margin-top:16px}._switchText_dvr14_207{color:var(--text-secondary);font-size:13px;font-weight:600}._switchLink_dvr14_213{color:var(--color-primary);cursor:pointer;font-size:13px;font-weight:700;font-family:var(--font-jp);background:0 0;border:none;padding:0;transition:opacity .2s}._switchLink_dvr14_213:hover{text-decoration:underline}._terms_dvr14_230{text-align:center;color:var(--text-tertiary);margin-top:16px;font-size:11px;font-weight:600;line-height:1.6}._termsLink_dvr14_239{color:var(--text-secondary);cursor:pointer;font-size:11px;font-weight:600;font-family:var(--font-jp);text-underline-offset:2px;background:0 0;border:none;padding:0;text-decoration:underline}._termsLink_dvr14_239:hover{color:var(--color-primary)}@keyframes _fadeUp_dvr14_1{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@media (width<=960px){._left_dvr14_9,._right_dvr14_143{padding:32px 24px}}@media (width<=768px){._root_dvr14_1{flex-direction:column}._left_dvr14_9{min-height:auto;padding:80px 24px 32px}._backBtn_dvr14_22{top:16px;left:16px}._welcome_dvr14_87{font-size:22px}._socialProof_dvr14_103{gap:14px;padding:12px 18px}._right_dvr14_143,._formCard_dvr14_157{padding:24px}}
