:root{color-scheme:light;font-family:Inter,Noto Sans JP,Segoe UI,sans-serif;color:#111827;background:#f5f7fb;font-synthesis:none;text-rendering:optimizeLegibility}*{box-sizing:border-box}body{margin:0;min-width:320px;background:linear-gradient(180deg,#f8fbff,#eef4ff)}button,input,select,textarea{font:inherit}button{cursor:pointer}.auth-shell{min-height:100vh;display:grid;grid-template-columns:minmax(0,1fr) minmax(380px,440px);gap:28px;width:min(1180px,calc(100% - 32px));margin:0 auto;padding:24px 0;align-items:center}.auth-hero,.auth-panel,.panel,.welcome-panel,.stat-card{background:#fff;border:1px solid #dbe3ef;border-radius:8px;box-shadow:0 18px 48px #1e293b14}.auth-hero{position:relative;overflow:hidden;padding:34px;min-height:auto}.brand-mark{display:inline-flex;align-items:center;gap:10px;font-weight:900;color:#172033}.brand-button{border:0;background:transparent;padding:0;min-height:0;text-align:left}.brand-button:hover span{color:#2563eb}.brand-mark svg{color:#2563eb}.brand-mark.small{font-size:18px}.auth-hero h1{max-width:620px;margin:64px 0 16px;font-size:42px;line-height:1.15;letter-spacing:0}.auth-hero p{max-width:560px;font-size:17px}.auth-hero p,.welcome-panel p,.section-heading p,.panel-title p{color:#536179;line-height:1.7}.hero-illustration{position:relative;right:auto;bottom:auto;width:min(100%,540px);height:280px;margin-top:34px;margin-left:auto;background:linear-gradient(135deg,#e0f2fe,#eef2ff 56%,#fff7ed);border-radius:8px}.bubble{position:absolute;background:#fff;border:2px solid #b9c5ff;border-radius:8px;color:#3155dd;font-weight:900;padding:12px 18px;box-shadow:0 10px 30px #3155dd26}.bubble.hello{left:36px;top:34px;font-size:24px}.bubble.jp{right:34px;top:88px}.learner-face{position:absolute;width:116px;height:116px;left:45%;top:112px;border-radius:50%;background:radial-gradient(circle at 38px 44px,#111827 0 4px,transparent 5px),radial-gradient(circle at 76px 44px,#111827 0 4px,transparent 5px),radial-gradient(circle at 59px 72px,#ef8f6b 0 20px,transparent 21px),linear-gradient(#6b3a2b 0,#6b3a2b 32%,#ffd6bc 33%,#ffd6bc);border:8px solid #6d4adf;transform:translate(-50%)}.desk{position:absolute;left:20%;right:20%;bottom:54px;height:34px;background:#c88648;border-radius:8px}.floating{position:absolute;color:#7c3aed}.floating.book{left:68px;bottom:104px}.floating.star{right:86px;bottom:116px}.auth-panel{padding:30px;align-self:center}.segmented{display:grid;grid-template-columns:1fr 1fr;gap:6px;padding:6px;background:#eef2ff;border-radius:8px}.segmented button{border:0;border-radius:8px;padding:12px 14px;background:transparent;color:#4b5563;font-weight:800}.segmented button.active{background:#fff;color:#1d4ed8;box-shadow:0 6px 18px #2563eb24}.segmented.compact{max-width:260px}.auth-form,.ai-form{display:grid;gap:16px;margin-top:22px}label{display:grid;gap:8px;font-weight:800;color:#263244}input,select,textarea{border:1px solid #d6deeb;border-radius:8px;background:#fff;padding:13px 14px;outline:none}textarea{min-height:128px;resize:vertical}input:focus,select:focus,textarea:focus{border-color:#2563eb;box-shadow:0 0 0 4px #2563eb1f}.primary-button,.ghost-button,.icon-button{display:inline-flex;align-items:center;justify-content:center;gap:8px;border-radius:8px;border:0;min-height:44px;font-weight:900}.primary-button{background:#2563eb;color:#fff;padding:0 18px}.primary-button.full{width:100%}.primary-button:disabled{background:#94a3b8;cursor:not-allowed}.ghost-button{background:#f8fafc;color:#334155;border:1px solid #dbe3ef;padding:0 14px}.icon-button{width:36px;min-height:36px;color:#2563eb;background:#eff6ff}.error-text,.banner-error{color:#b91c1c;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;padding:10px 12px;margin:0}.app-shell{width:min(1240px,calc(100% - 32px));margin:0 auto;padding:18px 0 48px}.topbar{position:sticky;top:12px;z-index:5;display:flex;align-items:center;justify-content:space-between;gap:18px;padding:12px 16px;background:#ffffffeb;border:1px solid #dde4f0;border-radius:8px;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.topbar nav{display:flex;gap:18px}.topbar a{color:#334155;text-decoration:none;font-weight:800}.welcome-panel{display:grid;grid-template-columns:minmax(0,1fr) 170px;align-items:center;gap:20px;margin:18px 0;padding:22px}.eyebrow{color:#2563eb;font-weight:900}.welcome-panel h1{margin:8px 0;font-size:28px;line-height:1.22;letter-spacing:0}.streak-card{display:grid;place-items:center;gap:8px;min-height:132px;background:#fff7ed;border-radius:8px;color:#a16207}.streak-card strong{color:#7c2d12}.stats-row{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:18px}.stat-card{display:grid;grid-template-columns:40px 1fr auto;align-items:center;gap:12px;padding:14px}.stat-card svg{color:#2563eb;background:#eff6ff;padding:8px;width:40px;height:40px;border-radius:8px}.stat-card span{color:#64748b;font-weight:800}.stat-card strong{font-size:24px}.panel{padding:18px}.section-heading{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:16px}.section-heading.inline{align-items:baseline}.section-heading h2,.panel-title h2{margin:0;letter-spacing:0}.section-heading h2{color:#5b21b6}.panel-title{display:flex;align-items:center;gap:12px;margin-bottom:16px}.panel-title svg{color:#2563eb;flex:0 0 auto}.topic-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:10px}.topic-card{display:grid;grid-template-columns:34px 1fr;align-items:center;gap:8px 10px;min-height:74px;padding:12px;border:1px solid #dbe3ef;border-radius:8px;background:#fff;color:#111827;text-align:left}.topic-card span{grid-column:2;color:#64748b;font-size:14px}.topic-card.selected{border-color:#2563eb;box-shadow:inset 0 0 0 1px #2563eb,0 12px 26px #2563eb1f}.topic-card.blue svg{color:#2563eb}.topic-card.coral svg{color:#f97316}.topic-card.brown svg{color:#8b5e34}.topic-card.indigo svg{color:#4f46e5}.topic-card.rose svg{color:#e11d48}.topic-card.green svg{color:#16a34a}.topic-card.slate svg{color:#475569}.study-layout{display:grid;grid-template-columns:minmax(0,1fr) minmax(410px,.8fr);gap:18px;margin-top:18px;align-items:start}.practice-stack{display:grid;gap:18px}.table-wrap{overflow-x:auto;max-height:640px}.vocab-tools{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:12px;align-items:center;margin-bottom:12px}.vocab-tools input{min-height:42px}.vocab-tools span{color:#64748b;font-weight:800;white-space:nowrap}table{width:100%;border-collapse:collapse;min-width:700px}th,td{border-bottom:1px solid #e5ebf5;padding:11px 10px;text-align:left;vertical-align:top}th{color:#475569;font-size:14px;position:sticky;top:0;background:#fff}.progress-line{height:10px;background:#e5e7eb;border-radius:999px;overflow:hidden}.progress-line span{display:block;height:100%;background:#22c55e}.quiz-question{color:#475569;margin-top:16px;margin-bottom:8px}.quiz-word{display:block;margin:8px 0 4px;color:#2563eb;font-size:40px;text-align:center}.quiz-hint{display:block;text-align:center;color:#64748b;font-size:15px;font-weight:800;margin-bottom:16px}.options{display:grid;gap:10px}.options button{border:1px solid #dbe3ef;border-radius:8px;background:#fff;min-height:50px;text-align:left;padding:0 16px;font-weight:750}.options button:hover{border-color:#93c5fd;background:#f8fbff}.options button.chosen{border-color:#22c55e;background:#f0fdf4}.result-box{display:grid;grid-template-columns:30px 1fr;gap:10px;margin:16px 0;padding:14px;border-radius:8px}.result-box p{margin:4px 0 0;line-height:1.55}.result-box.correct{background:#ecfdf5;border:1px solid #bbf7d0;color:#166534}.result-box.wrong{background:#fff1f2;border:1px solid #fecdd3;color:#be123c}.kanji-layout{display:grid;grid-template-columns:132px 1fr;gap:16px;align-items:center}.kanji-info{display:grid;gap:8px}.kanji-large{display:grid;place-items:center;width:108px;height:108px;border-radius:8px;background:#eef2ff;color:#1d4ed8;font-size:72px;font-weight:900}.kanji-info p,.kanji-info small{color:#536179;line-height:1.5}.canvas-wrap{position:relative;width:min(100%,300px);aspect-ratio:1;margin-left:auto;background:linear-gradient(#e2e8f0 1px,transparent 1px),linear-gradient(90deg,#e2e8f0 1px,transparent 1px);background-size:50% 50%;border:1px solid #cbd5e1;border-radius:8px;overflow:hidden}.canvas-wrap:before,.canvas-wrap:after{content:"";position:absolute;background:#cbd5e1;opacity:.8;pointer-events:none}.canvas-wrap:before{width:1px;top:0;bottom:0;left:50%}.canvas-wrap:after{height:1px;left:0;right:0;top:50%}.canvas-wrap canvas{position:relative;z-index:2;width:100%;height:100%;touch-action:none}.kanji-guide{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;color:#2563eb1f;font-size:220px;font-weight:900;line-height:1;pointer-events:none}.kanji-actions{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:14px}.review-card{position:relative;margin-top:18px;border-radius:8px;padding:18px;line-height:1.6}.review-card.good{background:#ecfdf5;border:1px solid #bbf7d0}.review-card.needs-work{background:#fff7ed;border:1px solid #fed7aa}.score-pill{position:absolute;right:14px;top:14px;background:#111827;color:#fff;border-radius:999px;padding:4px 10px;font-weight:900}blockquote{margin:8px 0;padding:12px;background:#ffffffb8;border-left:4px solid #2563eb;border-radius:8px}@media(max-width:1180px){.auth-shell,.study-layout{grid-template-columns:1fr}.topic-grid{grid-template-columns:repeat(4,minmax(130px,1fr))}.auth-panel{width:min(100%,520px);justify-self:center}}@media(max-width:760px){.auth-shell{width:min(100%,calc(100% - 24px));padding:12px 0}.app-shell{width:100%;padding:12px}.welcome-panel,.stats-row,.kanji-layout{grid-template-columns:1fr}.auth-hero{min-height:auto;padding:24px}.auth-hero h1,.welcome-panel h1{font-size:28px}.topbar{position:static;align-items:flex-start;flex-direction:column}.topbar nav{flex-wrap:wrap}.topic-grid{grid-template-columns:repeat(2,minmax(120px,1fr))}.study-layout,.kanji-actions{grid-template-columns:1fr}.canvas-wrap{margin-left:0}}
