:root{--bg: #f7f4ee;--surface: #fffdf8;--ink: #1c1917;--ink-soft: #57534e;--ink-muted: #a8a29e;--accent: #b04a2f;--accent-soft: #f5e7e0;--line: #e7e5e4;--shadow-sm: 0 1px 2px rgba(28, 25, 23, .04), 0 1px 3px rgba(28, 25, 23, .06);--shadow-md: 0 4px 12px rgba(28, 25, 23, .08), 0 2px 4px rgba(28, 25, 23, .04);--r: 12px;--r-sm: 8px;--r-pill: 999px}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{background:var(--bg);color:var(--ink);font-family:Noto Sans JP,ui-sans-serif,system-ui,-apple-system,Hiragino Sans,Yu Gothic,sans-serif;font-size:16px;line-height:1.6;-webkit-font-smoothing:antialiased}button{font:inherit;cursor:pointer}input,textarea{font:inherit}.shell{min-height:100vh;display:flex;flex-direction:column}.topbar{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;background:var(--surface);border-bottom:1px solid var(--line)}.topbar-brand{font-size:14px;letter-spacing:.16em;color:var(--ink-soft)}.topbar-trail{font-size:13px;color:var(--ink-muted)}.main{flex:1;display:flex;align-items:stretch;justify-content:center;padding:32px 20px}.container{width:100%;max-width:720px}.container-wide{max-width:880px}h1,h2,h3{font-weight:600;letter-spacing:.01em}h1{font-size:28px;margin:0 0 12px}h2{font-size:20px;margin:0 0 8px}.lede{color:var(--ink-soft);margin:0 0 28px}.muted{color:var(--ink-muted)}.btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:var(--accent);color:#fff;border:0;padding:12px 20px;border-radius:var(--r-sm);font-weight:600;transition:transform .05s,opacity .15s}.btn:hover{opacity:.92}.btn:active{transform:translateY(1px)}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-ghost{background:transparent;color:var(--ink-soft);border:1px solid var(--line)}.btn-ghost:hover{background:var(--surface)}.input,.textarea{width:100%;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-sm);padding:10px 12px;outline:none;transition:border-color .15s,box-shadow .15s}.input:focus,.textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.textarea{min-height:96px;resize:vertical}.field{margin-bottom:20px}.field-label{display:block;font-size:13px;font-weight:600;color:var(--ink-soft);margin-bottom:8px;letter-spacing:.02em}.field-hint{font-size:12px;color:var(--ink-muted);margin-top:4px}.chips{display:flex;flex-wrap:wrap;gap:8px}.chip{padding:6px 14px;border-radius:var(--r-pill);border:1px solid var(--line);background:var(--surface);color:var(--ink-soft);font-size:14px;transition:background .12s,border-color .12s,color .12s}.chip[aria-pressed=true]{background:var(--accent);border-color:var(--accent);color:#fff}.phase-row{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.phase-row label{display:flex;align-items:center;gap:10px;border:1px solid var(--line);border-radius:var(--r-sm);padding:12px;background:var(--surface);cursor:pointer}.phase-row label.selected{border-color:var(--accent);background:var(--accent-soft)}.phase-row input{accent-color:var(--accent)}.match-grid{display:grid;grid-template-columns:1fr;gap:14px}.match-card{display:grid;grid-template-columns:64px 1fr auto;gap:16px;align-items:start;padding:18px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r);transition:border-color .15s,box-shadow .15s;cursor:pointer;text-align:left;width:100%;-webkit-appearance:none;-moz-appearance:none;appearance:none;font:inherit;color:inherit}.match-card:hover{border-color:var(--accent);box-shadow:var(--shadow-md)}.avatar{width:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,#ddd6c8,#c8b9a3);display:flex;align-items:center;justify-content:center;font-size:24px;color:var(--ink-soft);font-weight:600;flex-shrink:0}.match-name{display:flex;align-items:baseline;gap:8px;margin-bottom:4px}.match-name h2{margin:0}.virtual-badge{font-size:11px;font-weight:600;letter-spacing:.04em;color:var(--accent);background:var(--accent-soft);padding:2px 8px;border-radius:var(--r-pill);white-space:nowrap}.match-headline{font-size:14px;color:var(--ink-soft);margin:0 0 10px}.match-reason{font-size:14px;color:var(--ink);line-height:1.55;margin:0}.match-score{font-size:11px;color:var(--ink-muted);font-variant-numeric:tabular-nums;white-space:nowrap}.chat-shell{display:flex;flex-direction:column;height:calc(100vh - 60px);max-width:720px;margin:0 auto;padding:0 16px}.chat-header{display:flex;align-items:center;gap:12px;padding:14px 0;border-bottom:1px solid var(--line)}.chat-feed{flex:1;overflow-y:auto;padding:20px 0;display:flex;flex-direction:column;gap:18px}.bubble{max-width:100%;padding:12px 16px;border-radius:var(--r);line-height:1.65;white-space:pre-wrap;overflow-wrap:anywhere}.bubble-user{align-self:flex-end;background:var(--accent);color:#fff;max-width:82%;border-bottom-right-radius:4px}.bubble-assistant{align-self:flex-start;background:var(--surface);border:1px solid var(--line);max-width:92%;border-bottom-left-radius:4px}.citations{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px;font-size:12px}.citation-chip{background:var(--accent-soft);color:var(--accent);padding:3px 10px;border-radius:var(--r-pill);text-decoration:none;border:1px solid transparent;transition:border-color .12s}.citation-chip:hover{border-color:var(--accent)}.chat-input{padding:12px 0 16px;border-top:1px solid var(--line);display:flex;gap:8px;background:var(--bg)}.chat-input .textarea{min-height:40px;max-height:160px}.thinking{align-self:flex-start;display:inline-flex;gap:4px;padding:12px 16px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r)}.thinking span{width:6px;height:6px;border-radius:50%;background:var(--ink-muted);animation:bounce 1.2s infinite}.thinking span:nth-child(2){animation-delay:.15s}.thinking span:nth-child(3){animation-delay:.3s}@keyframes bounce{0%,60%,to{transform:translateY(0);opacity:.4}30%{transform:translateY(-3px);opacity:1}}.error{background:#fef0e8;border:1px solid #f3c1ad;color:#8a3919;padding:12px 16px;border-radius:var(--r-sm);font-size:14px;margin:16px 0}.row{display:flex;gap:10px;align-items:center}.spacer{flex:1}.center{display:flex;align-items:center;justify-content:center}.gate-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:32px;max-width:420px;width:100%;box-shadow:var(--shadow-md)}@media (max-width: 640px){.phase-row{grid-template-columns:1fr}.match-card{grid-template-columns:56px 1fr}.match-card .match-score{grid-column:2;margin-top:4px}}
