:root{--text:#475569;--text-h:#0f172a;--text-soft:#64748b;--bg:#f8fafc;--surface:#ffffffeb;--field:#fff;--muted:#f1f5f9;--border:#dbe3ec;--shadow:0 18px 48px #0f172a14;--sans:Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;font:16px/1.5 var(--sans);color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}body{margin:0}button,textarea{font:inherit}h1,h2,p{margin-top:0}h1,h2{color:var(--text-h);letter-spacing:0}h1{font-size:clamp(40px,7vw,76px);font-weight:850;line-height:.95}h2{font-size:24px}@media (prefers-color-scheme:dark){:root{--text:#cbd5e1;--text-h:#f8fafc;--text-soft:#94a3b8;--bg:#0f172a;--surface:#0f172ae0;--field:#111827;--muted:#162033;--border:#263449;--shadow:0 18px 48px #00000042}}.app-shell{box-sizing:border-box;background:linear-gradient(135deg, #16653414, transparent 38%), linear-gradient(315deg, #0f172a14, transparent 42%), var(--bg);min-height:100svh;padding:32px}.workspace{width:min(1120px,100%);margin:0 auto}.layout,.result-panel{border:1px solid var(--border);background:var(--surface);box-shadow:var(--shadow)}.intro{max-width:740px;margin:8px 0 28px}.intro h1{margin:0 0 12px}.intro p{max-width:620px;color:var(--text)}.layout{border-radius:8px;grid-template-columns:minmax(280px,360px) minmax(0,1fr);gap:24px;padding:24px;display:grid}.character-panel h2,.composer label,.result-heading h2{margin:0 0 14px;font-size:18px;font-weight:750;line-height:1.2}.character-grid{gap:14px;display:grid}.character-card{width:100%;color:var(--text-h);background:var(--muted);text-align:left;cursor:pointer;border:2px solid #0000;border-radius:8px;grid-template-columns:92px 1fr;align-items:center;gap:14px;padding:10px;transition:border-color .16s,box-shadow .16s,transform .16s;display:grid}.character-card:hover{border-color:#22c55e6b;transform:translateY(-1px)}.character-card:focus-visible{outline-offset:3px;outline:3px solid #22c55e4d}.character-card.selected{border-color:#22c55e;box-shadow:0 0 0 4px #22c55e29}.portrait-wrap{aspect-ratio:1;background:#d1d5db;border-radius:8px;width:92px;overflow:hidden}.portrait-wrap img{object-fit:cover;object-position:50% 14%;width:100%;height:100%;display:block}.character-copy{gap:5px;display:grid}.character-copy strong{color:var(--text-h);font-size:17px}.character-copy span{color:var(--text);font-size:14px;line-height:1.35}.composer{flex-direction:column;display:flex}.composer textarea{resize:vertical;box-sizing:border-box;border:1px solid var(--border);background:var(--field);width:100%;min-height:210px;color:var(--text-h);font:inherit;border-radius:8px;padding:16px;line-height:1.5}.composer textarea:focus{border-color:#22c55e;outline:3px solid #22c55e3d}.submit-button{color:#fff;min-height:46px;font:inherit;cursor:pointer;background:#15803d;border:0;border-radius:8px;align-self:flex-start;margin-top:16px;padding:0 18px;font-weight:750}.submit-button:hover:not(:disabled){background:#166534}.submit-button:disabled{cursor:not-allowed;opacity:.58}.result-panel{border-radius:8px;margin-top:24px;padding:24px}.result-heading{justify-content:space-between;align-items:baseline;gap:16px;display:flex}.result-actions{align-items:center;gap:10px;display:flex}.result-actions span{color:var(--text-soft);font-size:14px}.read-button{border:1px solid var(--border);background:var(--muted);min-height:34px;color:var(--text-h);font:inherit;cursor:pointer;border-radius:8px;padding:0 12px;font-size:14px;font-weight:750}.read-button:hover:not(:disabled){border-color:#22c55e80}.read-button:disabled{cursor:not-allowed;opacity:.5}.result-text,.result-placeholder{min-height:96px;color:var(--text-h);white-space:pre-wrap;overflow-wrap:anywhere;margin:0}.result-placeholder{color:var(--text-soft)}@media (width<=760px){.app-shell{padding:18px}.intro{margin:34px 0 22px}.layout{grid-template-columns:1fr;padding:16px}.character-card{grid-template-columns:78px 1fr}.portrait-wrap{width:78px}.submit-button{width:100%}.result-heading{align-items:flex-start}.result-actions{flex-direction:column;align-items:flex-end}}
