:root{--bg:#1c1b22;--panel:#26252e;--ink:#ecebf0;--muted:#9a98a8;--accent:#ff5c8d;--accent-ink:#fff;--ok:#4ade80;--bad:#f87171;--border:#38363f;--radius:10px;color-scheme:dark}*{box-sizing:border-box}body,html{margin:0;padding:0}body{background:var(--bg);color:var(--ink);line-height:1.5;font-family:system-ui,Segoe UI,Hiragino Kaku Gothic ProN,Meiryo,sans-serif}a{color:var(--accent)}.jp{font-family:Hiragino Kaku Gothic ProN,Yu Gothic,Meiryo,sans-serif}.muted{color:var(--muted)}.app-header{padding:1rem 1.5rem;border-bottom:1px solid var(--border)}.app-header-row{display:flex;align-items:center;justify-content:space-between;gap:1rem}.app-title{margin:0 0 .75rem;font-size:1.3rem}.tabs{display:flex;gap:.5rem;flex-wrap:wrap}.tab{text-decoration:none;background:transparent;color:var(--muted);border:1px solid var(--border);border-radius:999px;padding:.35rem 1rem;font-size:.95rem}.tab.active{background:var(--accent);color:var(--accent-ink);border-color:var(--accent)}.app-main{max-width:820px;margin:0 auto;padding:1.5rem}.btn-ghost{background:transparent;color:var(--ink);border:1px solid var(--border);border-radius:var(--radius);padding:.4rem .9rem;cursor:pointer;font:inherit}.btn-ghost:hover{border-color:var(--accent)}.card{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);padding:1rem 1.2rem;margin-bottom:1.25rem}.field{display:grid;grid-gap:.35rem;gap:.35rem;margin-bottom:.9rem;font-size:.95rem}.field.checkbox{display:flex;align-items:center;gap:.5rem}input,select,textarea{background:var(--bg);color:var(--ink);border:1px solid var(--border);border-radius:8px;padding:.5rem .6rem;font:inherit}textarea{width:100%;resize:vertical}.btn-primary{background:var(--accent);color:var(--accent-ink);border:none;border-radius:var(--radius);padding:.55rem 1.2rem;cursor:pointer;font:inherit}.btn-ghost:disabled,.btn-primary:disabled{opacity:.5;cursor:default}.row{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap}.status{font-size:.9rem;min-height:1.2em}.status.ok{color:var(--ok)}.status.bad{color:var(--bad)}.bank-list{border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.bank-row{display:grid;grid-template-columns:1.4fr 1.4fr 2fr .6fr 1fr;grid-gap:.5rem;gap:.5rem;padding:.5rem .8rem;border-bottom:1px solid var(--border);font-size:.95rem}.bank-row:last-child{border-bottom:none}.bank-row.bank-head{background:var(--panel);color:var(--muted);font-size:.8rem;text-transform:uppercase;letter-spacing:.04em}.bank-row .jp{font-size:1.05rem}.prompt{font-size:1.4rem;margin:.75rem 0;padding:1rem;background:var(--panel);border-radius:var(--radius)}.prompt rt{font-size:.6em;color:var(--muted)}.hints{margin:0 0 .75rem;padding:.5rem .8rem;background:var(--panel);border-left:3px solid var(--accent);border-radius:6px;font-size:.95rem}.hints-label{color:var(--muted);font-size:.85rem;margin-bottom:.25rem}.hints ul{margin:0;padding-left:1.2rem}.feedback{margin-top:.75rem;font-weight:600}.feedback.ok{color:var(--ok)}.feedback.bad{color:var(--bad)}.feedback .correct-answer,.feedback .reasons{color:var(--ink);font-weight:400;margin:.4rem 0 0}.feedback .reasons{padding-left:1.2rem}.question-assessment{color:var(--muted);font-weight:400;font-size:.9em;margin:.4rem 0 0}.question-assessment.warn{color:var(--bad)}.chat-log{gap:.5rem;max-height:55vh;overflow-y:auto;padding:.5rem 0;margin:.5rem 0}.chat-log,.chat-msg{display:flex;flex-direction:column}.chat-msg{max-width:85%}.chat-msg.user{align-self:flex-end;align-items:flex-end}.bubble{padding:.5rem .8rem;border-radius:12px;font-size:1.05rem}.bubble.assistant{background:var(--panel)}.bubble.user{background:var(--accent);color:var(--accent-ink)}.annotation{margin-top:.25rem;font-size:.85rem;padding:.35rem .6rem;border-radius:6px;background:var(--panel)}.annotation .ann-label{color:var(--muted);font-size:.75rem;text-transform:uppercase;letter-spacing:.04em}.annotation ul{margin:.2rem 0 0;padding-left:1.1rem}.annotation.corrections{border-left:3px solid var(--bad)}.annotation.hints{border-left:3px solid var(--accent)}.conj-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(13rem,1fr));grid-gap:.6rem;gap:.6rem}.conj-cell{display:flex;flex-direction:column;gap:.15rem;text-align:left;background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);padding:.7rem .8rem;cursor:pointer;color:var(--ink);font:inherit}.conj-cell:hover{border-color:var(--accent)}.conj-label{font-weight:600}.conj-jp{font-size:1.05rem}.conj-desc{font-size:.82rem}.conj-count{font-size:.78rem;margin-top:.2rem}.particle-blank{color:var(--accent);padding:0 .2rem}.particle-options{display:flex;flex-wrap:wrap;gap:.5rem;margin:.75rem 0}.particle-opt{background:var(--panel);color:var(--ink);border:1px solid var(--border);border-radius:8px;padding:.5rem 1.1rem;font-size:1.2rem;min-width:3.5rem;cursor:pointer}.particle-opt:hover:not(:disabled){border-color:var(--accent)}.particle-opt.correct{border-color:var(--ok);color:var(--ok)}.particle-opt.wrong{border-color:var(--bad);color:var(--bad)}.explanation{margin-top:.75rem;padding:.6rem .9rem;background:var(--panel);border-left:3px solid var(--accent);border-radius:6px;font-size:.95rem}.explanation p:first-child{margin-top:0}.explanation p:last-child{margin-bottom:0}.score-entry{border:1px solid var(--border);border-radius:var(--radius);margin-bottom:.5rem;overflow:hidden}.score-row{display:grid;grid-template-columns:2fr 1fr 1fr;grid-gap:.5rem;gap:.5rem;width:100%;text-align:left;background:var(--panel);color:var(--ink);border:none;padding:.6rem .9rem;cursor:pointer;font:inherit}.score-row:hover{color:var(--accent)}.score-detail{padding:.75rem .9rem}.detail-item{padding:.5rem 0;border-bottom:1px solid var(--border)}.detail-item:last-child{border-bottom:none}.detail-item .reasons{margin:.3rem 0 0;padding-left:1.2rem}.ok{color:var(--ok)}.bad{color:var(--bad)}