@import url("https://fonts.googleapis.com/css2?family=Fredoka:wght@400;500;600&family=Nunito:wght@400;600&display=swap");:root{--color-background:#f5ddd0;--color-surface:#fff7f2;--color-border:#e8c9ba;--color-text-primary:#3d2c23;--color-text-muted:#9b7a70;--color-primary:#3db54a;--color-primary-hover:#35a241;--color-accent:#29b5e8;--color-accent-hover:#1fa3d4;--color-success:#3db54a;--color-warning:#e8a85c;--color-error:#e85c5c;--color-wordmark-start:#3db54a;--color-wordmark-end:#29b5e8;--font-display:"Fredoka",sans-serif;--font-body:"Nunito",sans-serif;--type-display-size:32px;--type-display-weight:600;--type-display-line-height:1.2;--type-display-letter-spacing:-0.02em;--type-h1-size:26px;--type-h1-weight:600;--type-h1-line-height:1.3;--type-h1-letter-spacing:-0.01em;--type-h2-size:20px;--type-h2-weight:500;--type-h2-line-height:1.4;--type-h2-letter-spacing:0;--type-h3-size:16px;--type-h3-weight:500;--type-h3-line-height:1.4;--type-h3-letter-spacing:0;--type-body-size:15px;--type-body-weight:400;--type-body-line-height:1.6;--type-body-letter-spacing:0;--type-caption-size:12px;--type-caption-weight:400;--type-caption-line-height:1.4;--type-caption-letter-spacing:0.01em;--type-label-size:11px;--type-label-weight:600;--type-label-line-height:1.2;--type-label-letter-spacing:0.06em;--spacing-xs:4px;--spacing-sm:8px;--spacing-md:12px;--spacing-base:16px;--spacing-lg:20px;--spacing-xl:24px;--spacing-2xl:30px;--spacing-3xl:36px;--radius-sm:8px;--radius-md:16px;--radius-lg:24px;--radius-pill:9999px;--shadow-sm:0 1px 3px rgba(61,44,35,.08);--shadow-md:0 4px 12px rgba(61,44,35,.1);--shadow-lg:0 8px 24px rgba(61,44,35,.12);--animation-fast:120ms;--animation-normal:200ms;--animation-slow:350ms;--animation-spring:450ms;--animation-easing:cubic-bezier(0.4,0,0.2,1)}[data-theme=dark]{--color-background:#151e18;--color-surface:#243028;--color-border:#3a4a3f;--color-text-primary:#f0ebe4;--color-text-muted:#a89e94;--color-primary:#5ec269;--color-primary-hover:#4db85a;--color-accent:#e8a85c;--color-accent-hover:#d4964e;--color-success:#5ec269;--color-warning:#e8a85c;--color-error:#e85c5c;--color-wordmark-start:#5ec269;--color-wordmark-end:#e8a85c;--shadow-sm:0 1px 3px rgba(0,0,0,.2);--shadow-md:0 4px 12px rgba(0,0,0,.25);--shadow-lg:0 8px 24px rgba(0,0,0,.3)}@media (prefers-color-scheme:dark){:root:not([data-theme=light]){--color-background:#151e18;--color-surface:#243028;--color-border:#3a4a3f;--color-text-primary:#f0ebe4;--color-text-muted:#a89e94;--color-primary:#5ec269;--color-primary-hover:#4db85a;--color-accent:#e8a85c;--color-accent-hover:#d4964e;--color-success:#5ec269;--color-warning:#e8a85c;--color-error:#e85c5c;--color-wordmark-start:#5ec269;--color-wordmark-end:#e8a85c;--shadow-sm:0 1px 3px rgba(0,0,0,.2);--shadow-md:0 4px 12px rgba(0,0,0,.25);--shadow-lg:0 8px 24px rgba(0,0,0,.3)}}.knowledge-detail{display:flex;flex-direction:column;gap:8px}.knowledge-prompt-section{display:flex;flex-direction:column;gap:4px}.knowledge-prompt-value{font-family:var(--font-body);font-size:18px;font-weight:800;color:var(--color-text-primary);line-height:1.3}.knowledge-answer-section{display:flex;flex-direction:column;gap:4px;padding-top:6px;border-top:2px solid var(--color-border)}.knowledge-answer-value{font-family:var(--font-body);font-size:15px;font-weight:600;color:#5a3020;line-height:1.4}.knowledge-generic{margin:0;display:flex;flex-direction:column;gap:6px}.knowledge-generic-row{display:flex;gap:8px;align-items:baseline}.knowledge-generic-key{font-family:var(--font-body);font-size:11px;font-weight:800;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.06em;min-width:80px;flex-shrink:0}.knowledge-generic-value{font-family:var(--font-body);font-size:14px;font-weight:600;color:var(--color-text-primary);margin:0}.review-card{display:flex;flex-direction:column;gap:20px}.review-header{justify-content:space-between;gap:12px}.review-header,.review-prompt{display:flex;align-items:center}.review-prompt{flex-direction:column;gap:6px;padding:24px;background:var(--color-surface);border:2px solid var(--color-border);border-radius:14px;min-height:100px;justify-content:center;text-align:center}.review-prompt-value{font-family:var(--font-body);font-size:28px;font-weight:800;color:var(--color-text-primary);line-height:1.25}.review-answer{display:flex;flex-direction:column;gap:6px;padding:20px 24px;background:rgba(61,181,74,.06);border:2px solid rgba(61,181,74,.22);border-radius:14px;text-align:center;align-items:center}.review-answer-value{font-family:var(--font-body);font-size:20px;font-weight:700;color:#2a8a35;line-height:1.4}.review-score-buttons{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}.review-page-heading{font-family:var(--font-display);font-size:32px;font-weight:600;margin:0;color:var(--color-text-primary)}.review-summary{gap:24px;padding:32px 28px;background:var(--color-surface);border-radius:var(--radius-md);box-shadow:var(--shadow-md)}.review-summary,.review-summary-header{display:flex;flex-direction:column;align-items:center}.review-summary-header{gap:4px}.review-summary-title{font-family:var(--font-display);font-size:28px;font-weight:600;margin:0;color:var(--color-text-primary)}.review-summary-count{font-family:var(--font-body);font-size:15px;font-weight:600;color:var(--color-text-muted)}.review-summary-stats{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;width:100%}.review-stat{flex:1 1;min-width:90px;display:flex;flex-direction:column;align-items:center;gap:4px;padding:16px 12px;border-radius:14px}.review-stat-number{font-family:var(--font-display);font-size:36px;font-weight:600;line-height:1}.review-stat-label{font-family:var(--font-body);font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.04em}.review-stat-mastered{background:rgba(61,181,74,.08);border:2px solid rgba(61,181,74,.18)}.review-stat-mastered .review-stat-label,.review-stat-mastered .review-stat-number{color:#2a8a35}.review-stat-strengthened{background:rgba(41,181,232,.08);border:2px solid rgba(41,181,232,.18)}.review-stat-strengthened .review-stat-label,.review-stat-strengthened .review-stat-number{color:#1a7da0}.review-stat-improve{background:hsla(26,40%,65%,.12);border:2px solid hsla(26,40%,65%,.25)}.review-stat-improve .review-stat-label,.review-stat-improve .review-stat-number{color:#8a6040}.review-summary-next{display:flex;flex-direction:column;align-items:center;gap:2px;padding:14px 24px;background:var(--color-surface);border-radius:12px;width:100%}.review-summary-next-label{font-family:var(--font-body);font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted)}.review-summary-next-time{font-family:var(--font-display);font-size:22px;font-weight:500;color:#5a3020}.morpheme-review{display:flex;flex-direction:column;align-items:center;gap:18px}.morpheme-review-prompt{font-family:var(--font-body);font-size:22px;font-weight:600;color:#5a3020;margin:0;text-align:center}.morpheme-review-prompt strong{font-size:28px;font-weight:800;color:var(--color-text-primary)}.kanji-writer-canvas{background:var(--color-surface);border:2px solid var(--color-border);border-radius:14px;display:flex;align-items:center;justify-content:center;cursor:crosshair;transition:border-color .2s,box-shadow .2s}.kanji-writer-canvas:hover{border-color:#d4b0a0}.kanji-writer-canvas:active{border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(61,181,74,.12)}.kanji-writer-fallback{background:var(--color-surface);border:2px solid var(--color-border);border-radius:14px;display:flex;align-items:center;justify-content:center}.kanji-writer-static{font-size:64px;color:var(--color-text-muted)}.morpheme-kanji{font-size:68px;font-weight:600;line-height:1;color:var(--color-text-primary);text-align:center}.morpheme-meaning{font-family:var(--font-body);font-size:20px;font-weight:700;color:#5a3020;text-align:center}.morpheme-radicals{display:flex;gap:8px;justify-content:center;flex-wrap:wrap}.morpheme-radical-chip{display:inline-flex;align-items:center;gap:5px;padding:5px 12px;background:rgba(61,181,74,.08);border:1px solid rgba(61,181,74,.2);border-radius:var(--radius-pill);font-size:14px;font-weight:600;color:#2a8a35}.morpheme-radical-char{font-size:18px}.morpheme-radical-meaning{color:#5a3020;font-weight:500}.cloze-readings,.morpheme-readings{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}.cloze-reading,.morpheme-reading{font-family:var(--font-body);font-size:17px;font-weight:600;color:var(--color-text-muted);letter-spacing:.03em}.cloze-reading-line{display:flex;align-items:center;gap:10px;justify-content:center;margin:0}.cloze-correct-kanji-inline{font-size:28px;font-weight:700;color:#2a8a35}.morpheme-result-feedback{font-family:var(--font-body);font-size:15px;font-weight:600;color:var(--color-text-muted);margin:0;text-align:center}.cloze-review{display:flex;flex-direction:column;align-items:center;gap:22px}.cloze-sentence{font-family:var(--font-body);font-size:26px;font-weight:700;color:var(--color-text-primary);text-align:center;line-height:1.5;margin:0;padding:20px 24px;background:var(--color-surface);border:2px solid var(--color-border);border-radius:14px;width:100%}.cloze-choices{display:grid;grid-template-columns:1fr 1fr;grid-gap:12px;gap:12px;width:100%;max-width:340px}.cloze-choice{font-family:var(--font-body);font-size:36px;font-weight:700;color:var(--color-text-primary);padding:16px 12px;background:var(--color-surface);border:2px solid var(--color-border);border-radius:14px;cursor:pointer;transition:border-color .15s,background .15s,transform .1s,box-shadow .15s;text-align:center;line-height:1}.cloze-choice:hover:not(:disabled){border-color:#d4b0a0;background:var(--color-surface);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.cloze-choice:active:not(:disabled){transform:translateY(0)}.cloze-choice:disabled{cursor:default}.cloze-choice.cloze-correct{background:rgba(61,181,74,.1);border-color:var(--color-primary);color:#2a8a35}.cloze-choice.cloze-wrong{background:rgba(195,57,43,.08);border-color:var(--color-error);color:var(--color-error)}.cloze-choice.cloze-dimmed{opacity:.4}.cloze-explanation{display:flex;flex-direction:column;align-items:center;gap:10px;padding:18px 24px;background:rgba(61,181,74,.06);border:2px solid rgba(61,181,74,.18);border-radius:14px;width:100%}.cloze-correct-kanji{font-size:44px;font-weight:700;color:#2a8a35;line-height:1}.cloze-full-sentence{font-size:18px;font-weight:600;color:var(--color-text-primary)}.cloze-full-sentence,.cloze-story{font-family:var(--font-body);text-align:center;line-height:1.5;margin:0}.cloze-story{font-size:14px;font-weight:500;color:var(--color-text-muted);font-style:italic}.usage-detail{display:flex;flex-direction:column;align-items:center;gap:12px}.usage-kanji{font-size:56px;font-weight:600;line-height:1;color:var(--color-text-primary);text-align:center}.usage-sentence{font-size:18px;font-weight:600;color:#5a3020}.usage-sentence,.usage-story{font-family:var(--font-body);text-align:center;line-height:1.5}.usage-story{font-size:14px;font-weight:500;color:var(--color-text-muted);font-style:italic;padding:12px 16px;background:var(--color-surface);border-radius:10px;margin:0}[data-theme=dark] .review-answer{background:rgba(94,194,105,.06);border-color:rgba(94,194,105,.22)}[data-theme=dark] .cloze-explanation{background:rgba(94,194,105,.06);border-color:rgba(94,194,105,.18)}[data-theme=dark] .cloze-choice.cloze-correct{background:rgba(94,194,105,.1)}[data-theme=dark] .cloze-choice.cloze-wrong{background:rgba(232,92,92,.08)}[data-theme=dark] .btn.secondary{background:hsla(30,10%,62%,.18);color:var(--color-text-primary)}[data-theme=dark] .btn.secondary:hover:not(:disabled){background:hsla(30,10%,62%,.28)}[data-theme=dark] .review-stat-mastered{background:rgba(94,194,105,.08);border-color:rgba(94,194,105,.18)}[data-theme=dark] .review-stat-strengthened{background:rgba(41,181,232,.08);border-color:rgba(41,181,232,.18)}[data-theme=dark] .review-stat-improve{background:hsla(30,10%,62%,.1);border-color:hsla(30,10%,62%,.2)}[data-theme=dark] .kanji-writer-canvas:active{box-shadow:0 0 0 3px rgba(94,194,105,.15)}[data-theme=dark] .morpheme-radical-chip{background:rgba(94,194,105,.08);border-color:rgba(94,194,105,.2)}[data-theme=dark] .knowledge-answer-value,[data-theme=dark] .morpheme-meaning,[data-theme=dark] .morpheme-radical-meaning,[data-theme=dark] .morpheme-review-prompt,[data-theme=dark] .review-summary-next-time,[data-theme=dark] .usage-sentence{color:var(--color-text-primary)}[data-theme=dark] .cloze-choice.cloze-correct,[data-theme=dark] .cloze-correct-kanji,[data-theme=dark] .cloze-correct-kanji-inline,[data-theme=dark] .morpheme-radical-chip,[data-theme=dark] .review-answer-value,[data-theme=dark] .review-stat-mastered .review-stat-label,[data-theme=dark] .review-stat-mastered .review-stat-number{color:var(--color-primary)}[data-theme=dark] .review-stat-strengthened .review-stat-label,[data-theme=dark] .review-stat-strengthened .review-stat-number{color:#4ec8f0}[data-theme=dark] .review-stat-improve .review-stat-label,[data-theme=dark] .review-stat-improve .review-stat-number{color:var(--color-text-muted)}[data-theme=dark] .cloze-choice:hover:not(:disabled),[data-theme=dark] .kanji-writer-canvas:hover{border-color:var(--color-primary)}*{box-sizing:border-box}body,html{margin:0;padding:0;font-family:var(--font-body);background:var(--color-background);color:var(--color-text-primary)}a{color:var(--color-primary);text-decoration:none}a:hover{text-decoration:underline}main{max-width:960px;margin:0 auto;padding:24px}.card{background:var(--color-surface);border-radius:var(--radius-md);padding:20px;box-shadow:var(--shadow-md)}.row{align-items:center}.col,.row{display:flex;gap:12px}.col{flex-direction:column}.input{border:2px solid var(--color-border);border-radius:var(--radius-pill);padding:12px 18px;font-size:15px;font-family:var(--font-body);font-weight:600;background:var(--color-surface);outline:none;color:var(--color-text-primary);transition:border-color .2s,box-shadow .2s}.input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(61,181,74,.15)}.input::placeholder{color:var(--color-text-muted);font-weight:500}.btn{border:0;border-radius:var(--radius-pill);padding:11px 22px;background:var(--color-primary);color:#fff;font-family:var(--font-body);font-weight:700;font-size:15px;cursor:pointer;transition:background .2s,transform .15s;white-space:nowrap}.btn:hover:not(:disabled){background:var(--color-primary-hover);transform:scale(1.03)}.btn:disabled{opacity:.5;cursor:default}.btn.secondary{background:hsla(23,35%,55%,.18);color:#5a3020}.btn.secondary:hover:not(:disabled){background:hsla(23,35%,55%,.28);transform:scale(1.03)}.err{color:var(--color-error);font-weight:600}.err,.muted{font-size:14px;font-family:var(--font-body)}.muted{color:var(--color-text-muted);font-weight:500}main.auth-main{max-width:100%;min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px}.auth-card{width:100%;max-width:400px;background:var(--color-surface);border-radius:var(--radius-lg);padding:40px 36px;box-shadow:var(--shadow-lg)}.auth-wordmark{font-family:var(--font-display);font-size:46px;font-weight:600;line-height:1;background:linear-gradient(130deg,var(--color-wordmark-start) 0,var(--color-wordmark-end) 65%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;display:block;text-align:center;margin-bottom:6px}.auth-tagline{font-size:14px;font-weight:500;color:var(--color-text-muted);margin:0 0 28px;text-align:center}.auth-card h1{font-family:var(--font-display);font-size:26px;font-weight:500;margin:0 0 4px;color:var(--color-text-primary)}.dashboard-main{max-width:960px}.dashboard-layout,.dashboard-main{position:relative}.dashboard-main h1{font-family:var(--font-display);font-size:30px;font-weight:600;margin:0;color:var(--color-text-primary)}.collapsible-card{gap:10px}.collapsible-header,.dashboard-topic-row{justify-content:space-between;align-items:center}.dashboard-topic-row{display:flex;padding:8px 12px;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-background);text-decoration:none;color:var(--color-text-primary);font-size:14px;transition:border-color .15s}.dashboard-topic-row:hover{border-color:var(--color-primary)}.chevron-btn{border:2px solid var(--color-border);border-radius:var(--radius-pill);background:var(--color-surface);width:32px;height:32px;font-size:13px;color:var(--color-text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,border-color .15s;padding:0}.chevron-btn:hover{background:var(--color-background);border-color:#d4a090}.inbox-item{border:2px solid var(--color-border);border-radius:12px;color:inherit;text-align:left;padding:12px 16px;display:flex;flex-direction:column;gap:4px;cursor:pointer;transition:border-color .15s,background .15s}.inbox-item,.inbox-item:hover{background:var(--color-surface)}.inbox-item:hover{border-color:var(--color-border)}.inbox-item.selected{border-color:var(--color-primary);background:rgba(61,181,74,.06)}.inbox-detail-panel{position:fixed;top:88px;left:clamp(16px,calc(50% + 500px),calc(100vw - 360px));width:340px;max-height:calc(100vh - 110px);overflow:auto;box-shadow:var(--shadow-lg);z-index:20}.prompt-preview{margin:0;border:2px solid var(--color-border);border-radius:12px;background:var(--color-surface);padding:10px;white-space:pre-wrap;font-size:12px;line-height:1.45;max-height:180px;overflow:auto;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,monospace}.kb-item-type{display:inline-flex;align-items:center;padding:4px 12px;border-radius:var(--radius-pill);font-size:12px;font-weight:800;font-family:var(--font-body);letter-spacing:.05em;text-transform:uppercase;background:rgba(61,181,74,.13);color:#2a8a35;border:1px solid rgba(61,181,74,.28)}.kb-item-data{margin:0;white-space:pre-wrap;font-size:13px;line-height:1.55;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,monospace;background:var(--color-surface);border:2px solid var(--color-border);border-radius:12px;padding:12px 14px;color:#5a3020}.kb-recall-bar{display:flex;align-items:center;gap:10px;margin-top:4px}.kb-recall-track{flex:1 1;height:6px;background:var(--color-border);border-radius:var(--radius-pill);overflow:hidden}.kb-recall-fill{height:100%;background:var(--color-primary);border-radius:var(--radius-pill);transition:width .4s ease}.kb-page-header{display:flex;justify-content:space-between;align-items:center;gap:16px;margin-bottom:8px}.kb-page-header h1{flex:1 1;font-family:var(--font-display);font-size:32px;font-weight:600;margin:0;color:var(--color-text-primary);line-height:1.15}.kb-detail-main{max-width:1300px}.kb-detail-layout{display:grid;grid-template-columns:minmax(0,1.05fr) minmax(340px,.95fr);grid-gap:18px;gap:18px;align-items:start}.kb-detail-left{display:flex;flex-direction:column;gap:18px;min-width:0}.kb-topics-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));grid-gap:10px;gap:10px}.kb-topic-card{display:flex;flex-direction:column;gap:6px;padding:14px;border:2px solid var(--color-border);border-radius:14px;background:var(--color-background);text-decoration:none;color:var(--color-text-primary);transition:border-color .15s,box-shadow .15s}.kb-topic-card:hover{border-color:var(--color-primary);box-shadow:0 2px 8px rgba(180,100,60,.1)}.kb-topic-card-title{font-weight:600;font-size:14px;line-height:1.3}.kb-topic-card-count{font-size:12px;color:var(--color-text-muted)}.kb-section-heading{margin:0;font-family:var(--font-display);font-size:23px;font-weight:500;color:var(--color-text-primary)}.kb-topic-group{display:flex;flex-direction:column;gap:10px}.kb-topic-group-title{font-family:var(--font-display);font-size:16px;font-weight:700;color:var(--color-text-primary);margin:8px 0 0;padding-bottom:6px;border-bottom:1px solid var(--color-border)}.kb-topic-group-title:first-of-type{margin-top:0}.kb-detail-knowledge-item{border:2px solid var(--color-border);border-radius:14px;background:var(--color-surface);padding:14px}.kb-detail-graph-card{position:-webkit-sticky;position:sticky;top:86px;height:calc(100vh - 104px);display:flex;flex-direction:column;min-height:360px}.kb-detail-graph-canvas{margin-top:8px;flex:1 1;min-height:0;border:2px solid var(--color-border);border-radius:14px;overflow:hidden;background:hsla(0,0%,100%,.35)}@media (max-width:1200px){.inbox-detail-panel{position:fixed;top:auto;left:12px;right:12px;bottom:12px;width:auto;max-height:50vh;overflow:auto;box-shadow:var(--shadow-lg);z-index:30}.dashboard-main.with-floating-panel{padding-bottom:calc(50vh + 28px)}}.kb-create-root{position:relative;min-height:100vh;width:100%;overflow:hidden;background:var(--color-background);color:var(--color-text-primary);display:flex;flex-direction:column;font-family:var(--font-body)}.kb-create-canvas{position:fixed;inset:0;width:100%;height:100%;pointer-events:none;z-index:0;opacity:.35}.kb-create-content{position:relative;z-index:1;min-height:100vh;display:flex;flex-direction:column}.kb-landing{flex:1 1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px;gap:20px}.kb-landing-title{font-family:var(--font-display);font-size:clamp(40px,7vw,68px);font-weight:600;color:var(--color-text-primary);text-align:center;line-height:1.1;margin:0;letter-spacing:.01em;animation:kbLandingEnter .55s cubic-bezier(.22,1,.36,1) both}.kb-landing-title span{color:var(--color-primary)}.kb-landing-sub{font-family:var(--font-body);font-size:17px;font-weight:500;color:var(--color-text-muted);text-align:center;margin:-8px 0 4px;animation:kbLandingEnter .55s cubic-bezier(.22,1,.36,1) .08s both}.kb-create-input-wrap{animation:kbLandingEnter .55s cubic-bezier(.22,1,.36,1) .16s both}@keyframes kbLandingEnter{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}.kb-create-input-wrap{position:relative;width:min(100%,560px)}.kb-create-input{width:100%;background:var(--color-surface);border:2px solid var(--color-border);border-radius:var(--radius-pill);padding:18px 70px 18px 24px;font-size:17px;font-family:var(--font-body);font-weight:600;color:var(--color-text-primary);outline:none;box-shadow:var(--shadow-md);transition:border-color .2s ease,box-shadow .2s ease}.kb-create-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 4px rgba(61,181,74,.15),0 4px 20px rgba(180,100,60,.08)}.kb-create-input::placeholder{color:var(--color-text-muted);font-weight:500}.kb-create-submit{position:absolute;top:50%;right:12px;transform:translateY(-50%);border:none;border-radius:var(--radius-pill);padding:10px 20px;min-width:44px;background:var(--color-primary);color:#fff;font-family:var(--font-body);font-weight:800;font-size:18px;cursor:pointer;transition:background .2s ease,transform .15s ease;line-height:1}.kb-create-submit:hover:not(:disabled){background:var(--color-primary-hover);transform:translateY(-50%) scale(1.06)}.kb-create-submit:disabled{opacity:.45;cursor:default}.kb-topic-header{position:-webkit-sticky;position:sticky;top:0;z-index:5;width:100%;padding:14px 28px;border-bottom:2px solid hsla(20,50%,65%,.18);font-family:var(--font-display);font-size:20px;font-weight:500;letter-spacing:.01em;color:var(--color-text-primary);background:hsla(21,65%,89%,.9);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);animation:fadeSlideDown .28s ease}@keyframes fadeSlideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.kb-clarification{flex:1 1;min-height:calc(100vh - 54px);display:grid;grid-template-columns:1fr 1fr;border-top:2px solid hsla(20,50%,65%,.15)}.kb-chat-col{padding:36px 32px;border-right:2px solid hsla(20,50%,65%,.15);display:flex;flex-direction:column;gap:24px;background:hsla(0,0%,100%,.38)}.kb-graph-col{position:-webkit-sticky;position:sticky;top:54px;height:calc(100vh - 54px);background:hsla(0,0%,100%,.22)}.kb-history-item{display:flex;flex-direction:column;gap:8px;opacity:.72}.kb-history-question{margin:0;font-family:var(--font-display);font-weight:400;color:var(--color-text-muted);font-size:15px;line-height:1.5}.kb-history-answer{margin:0;font-family:var(--font-body);font-weight:600;color:#7a6050;font-size:14px;line-height:1.5;border-left:3px solid var(--color-border);padding-left:12px}.kb-active-question{margin:0 0 18px;font-family:var(--font-display);font-size:26px;font-weight:500;line-height:1.35;color:var(--color-text-primary);letter-spacing:.01em}.kb-answer-input{width:100%;border:none;border-bottom:2px solid var(--color-border);background:transparent;color:var(--color-text-primary);font-family:var(--font-body);font-size:16px;font-weight:700;padding:10px 0;outline:none;transition:border-color .2s ease}.kb-answer-input:focus{border-bottom-color:var(--color-primary)}.kb-answer-input::placeholder{color:var(--color-text-muted);font-weight:500}.kb-cursor-line{width:42px;height:3px;margin-top:6px;background:var(--color-primary);border-radius:var(--radius-pill);animation:cursorPulse 1s ease-in-out infinite}@keyframes cursorPulse{0%,to{opacity:.25}50%{opacity:1}}.kb-graph-section{min-height:100vh;display:flex;flex-direction:column;border-top:2px solid hsla(20,50%,65%,.15);background:linear-gradient(180deg,var(--color-background) 0,var(--color-surface) 50%,var(--color-background) 100%)}.kb-graph-building-label{padding:14px 28px;border-bottom:2px solid hsla(20,50%,65%,.15);font-family:var(--font-body);font-weight:800;color:var(--color-text-muted);font-size:11px;letter-spacing:.1em;text-transform:uppercase}.kb-graph-full{flex:1 1;min-height:calc(100vh - 51px)}.kb-curriculum-section{padding:56px 24px 80px;max-width:1300px;width:100%;margin:0 auto;animation:fadeIn .4s ease}.kb-curriculum-layout{display:grid;grid-template-columns:minmax(0,1fr) minmax(360px,.95fr);grid-gap:22px;gap:22px;align-items:start}.kb-curriculum-main{min-width:0}.kb-curriculum-graph-pane{position:-webkit-sticky;position:sticky;top:80px;border:2px solid hsla(20,50%,65%,.15);border-radius:var(--radius-md);overflow:hidden;background:hsla(0,0%,100%,.3)}.kb-curriculum-graph{height:min(68vh,620px)}.kb-curriculum-heading{margin:0 0 12px;font-family:var(--font-display);font-size:44px;font-weight:600;color:var(--color-text-primary);letter-spacing:.01em;line-height:1.1}.kb-curriculum-desc{margin:0 0 36px;font-family:var(--font-body);color:var(--color-text-muted);line-height:1.7;font-size:16px;font-weight:500}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.kb-timeline{position:relative;display:flex;flex-direction:column;gap:14px;margin-top:8px;padding-left:28px}.kb-timeline:before{content:"";position:absolute;left:7px;top:4px;bottom:4px;width:3px;background:linear-gradient(180deg,var(--color-primary) 0,var(--color-border) 100%);border-radius:var(--radius-pill)}.kb-module-node{position:relative;background:var(--color-surface);border-radius:var(--radius-md);padding:16px 18px 14px;opacity:0;animation:fadeIn .3s ease forwards;box-shadow:var(--shadow-md);transition:transform .18s ease,box-shadow .18s ease}.kb-module-node:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.kb-module-dot{position:absolute;left:-26px;top:20px;width:12px;height:12px;border-radius:var(--radius-pill);border:3px solid var(--color-background);box-shadow:0 0 0 2px rgba(0,0,0,.08)}.kb-tier-primary{background:var(--color-primary)}.kb-tier-secondary{background:var(--color-accent)}.kb-tier-tertiary{background:#c9a080}.kb-module-title{font-family:var(--font-body);font-size:16px;font-weight:800;color:var(--color-text-primary);margin-bottom:4px;line-height:1.3}.kb-module-meta{font-family:var(--font-body);color:var(--color-text-muted);font-size:13px;font-weight:600}.kb-module-sources{margin-top:10px;display:flex;flex-wrap:wrap;gap:6px}.kb-source-chip{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:var(--radius-pill);font-family:var(--font-body);font-size:11px;font-weight:700;line-height:1}.kb-source-chip.primary{background:rgba(61,181,74,.14);border:1px solid rgba(61,181,74,.3);color:#2a8a35}.kb-source-chip.secondary{background:rgba(41,181,232,.14);border:1px solid rgba(41,181,232,.3);color:#1a7da0}.kb-source-chip.tertiary{background:rgba(180,130,80,.12);border:1px solid rgba(180,130,80,.28);color:#7a5030}.kb-topology-node{position:relative;width:100%}.kb-topology-node-label{display:block;width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.kb-topology-node-tooltip{bottom:calc(100% + 12px);transform:translateX(-50%) translateY(6px);min-width:200px;max-width:280px;border:2px solid var(--color-border);border-radius:12px;color:#6a4330;box-shadow:var(--shadow-lg);padding:10px 12px;font-family:var(--font-body);font-size:12px;font-weight:600;line-height:1.4;white-space:normal;opacity:0;pointer-events:none;transition:opacity .15s ease,transform .15s ease;z-index:20}.kb-topology-node-tooltip,.kb-topology-node-tooltip:after{position:absolute;left:50%;background:var(--color-surface)}.kb-topology-node-tooltip:after{content:"";top:100%;transform:translateX(-50%);width:10px;height:10px;border-right:2px solid var(--color-border);border-bottom:2px solid var(--color-border);rotate:45deg}.kb-topology-node:hover .kb-topology-node-tooltip{opacity:1;transform:translateX(-50%) translateY(0)}@media (max-width:1100px){.kb-detail-layout{grid-template-columns:1fr}.kb-detail-graph-card{position:relative;top:0;max-height:none}.kb-detail-graph-canvas{min-height:44vh}.kb-curriculum-layout{grid-template-columns:1fr}.kb-curriculum-graph-pane{position:relative;top:0}.kb-curriculum-graph{height:48vh}}@media (max-width:960px){.kb-clarification{grid-template-columns:1fr}.kb-chat-col{border-right:none;border-bottom:2px solid hsla(20,50%,65%,.15);padding:24px}.kb-graph-col{position:relative;top:0;height:48vh}.kb-curriculum-heading{font-size:32px}}.theme-toggle{position:fixed;bottom:20px;right:20px;width:40px;height:40px;border:2px solid var(--color-border);border-radius:var(--radius-pill);background:var(--color-surface);color:var(--color-text-muted);font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:border-color var(--animation-normal) var(--animation-easing),background var(--animation-normal) var(--animation-easing);z-index:50}.theme-toggle:hover{border-color:var(--color-primary);background:var(--color-background)}[data-theme=dark] .kb-topic-header{background:rgba(21,30,24,.9);border-bottom-color:rgba(58,74,63,.4)}[data-theme=dark] .kb-chat-col{background:rgba(36,48,40,.38)}[data-theme=dark] .kb-graph-col{background:rgba(36,48,40,.22)}[data-theme=dark] .kb-detail-graph-canvas{background:rgba(36,48,40,.35)}[data-theme=dark] .kb-curriculum-graph-pane{background:rgba(36,48,40,.3);border-color:rgba(58,74,63,.4)}[data-theme=dark] .kb-clarification{border-top-color:rgba(58,74,63,.35)}[data-theme=dark] .kb-chat-col{border-right-color:rgba(58,74,63,.35)}[data-theme=dark] .kb-graph-section{border-top-color:rgba(58,74,63,.35)}[data-theme=dark] .kb-graph-building-label{border-bottom-color:rgba(58,74,63,.35)}[data-theme=dark] .inbox-item.selected{background:rgba(94,194,105,.06)}[data-theme=dark] .input:focus{box-shadow:0 0 0 3px rgba(94,194,105,.2)}[data-theme=dark] .kb-create-input:focus{box-shadow:0 0 0 4px rgba(94,194,105,.2),0 4px 20px rgba(0,0,0,.2)}[data-theme=dark] .kb-source-chip.primary{background:rgba(94,194,105,.14);border-color:rgba(94,194,105,.3)}[data-theme=dark] .kb-source-chip.secondary{background:rgba(41,181,232,.14);border-color:rgba(41,181,232,.3)}[data-theme=dark] .kb-source-chip.tertiary{background:hsla(30,10%,62%,.12);border-color:hsla(30,10%,62%,.28)}[data-theme=dark] .kb-item-data{color:var(--color-text-primary)}[data-theme=dark] .kb-item-type,[data-theme=dark] .kb-source-chip.primary{color:var(--color-primary)}[data-theme=dark] .kb-source-chip.secondary{color:#4ec8f0}[data-theme=dark] .kb-history-answer,[data-theme=dark] .kb-source-chip.tertiary{color:var(--color-text-muted)}[data-theme=dark] .kb-topology-node-tooltip{color:var(--color-text-primary)}[data-theme=dark] .chevron-btn:hover{border-color:var(--color-border)}@media (max-width:960px){[data-theme=dark] .kb-chat-col{border-bottom-color:rgba(58,74,63,.35)}}.manabi-logo{display:inline-flex;cursor:pointer}.manabi-logo .node{transition:transform .4s cubic-bezier(.34,1.56,.64,1),opacity .3s;transform-origin:center;transform-box:fill-box}.manabi-logo .node-line{transition:stroke-opacity .3s ease}.manabi-logo .sparkle-glisten{opacity:0;transition:opacity .3s ease}.manabi-logo:hover .node{transform:scale(1.35)}.manabi-logo:hover .node-line{stroke-opacity:.7!important}.manabi-logo:hover .sparkle-glisten{opacity:1;animation:glisten .8s ease-in-out}@keyframes glisten{0%{opacity:0;transform:translateX(-30px)}50%{opacity:.6}to{opacity:0;transform:translateX(30px)}}