:root{--bg: #f1f5f9;--surface: #ffffff;--surface-2: #f8fafc;--sidebar-bg: #1e293b;--sidebar-fg: #e2e8f0;--sidebar-muted: #94a3b8;--sidebar-hover: #334155;--sidebar-active: #475569;--header-bg: #0f172a;--header-fg: #f8fafc;--ink: #0f172a;--muted: #64748b;--border: #e2e8f0;--primary: #2563eb;--primary-hover: #1d4ed8;--primary-soft: #eff6ff;--user-bubble: #2563eb;--user-bubble-fg: #ffffff;--assistant-bubble: #f1f5f9;--assistant-bubble-fg: #0f172a;--danger: #dc2626;--good: #16a34a;--radius: 6px;--status-online: #22c55e}@media (prefers-color-scheme: dark){:root{--bg: #0b1220;--surface: #111827;--surface-2: #0f172a;--sidebar-bg: #0b1220;--sidebar-fg: #e2e8f0;--sidebar-muted: #7c8aa0;--sidebar-hover: #1e293b;--sidebar-active: #273449;--header-bg: #0b1220;--header-fg: #f1f5f9;--ink: #e5e9f0;--muted: #94a3b8;--border: #1f2a3a;--primary: #3b82f6;--primary-hover: #2563eb;--primary-soft: #16243d;--user-bubble: #2563eb;--user-bubble-fg: #ffffff;--assistant-bubble: #1b2536;--assistant-bubble-fg: #e5e9f0}}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Hiragino Sans,Noto Sans JP,sans-serif;background:var(--bg);color:var(--ink);font-size:14px;line-height:1.55;-webkit-font-smoothing:antialiased}button{font-family:inherit}.app{display:grid;grid-template-columns:280px 1fr;height:100%;overflow:hidden}.sidebar{background:var(--sidebar-bg);color:var(--sidebar-fg);display:flex;flex-direction:column;min-height:0;border-right:1px solid rgba(0,0,0,.2)}.sidebar-head{padding:12px;border-bottom:1px solid rgba(255,255,255,.08)}.sidebar-title{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--sidebar-muted);padding:4px 6px 8px;font-weight:600}.btn-new{width:100%;display:flex;align-items:center;gap:8px;padding:9px 12px;background:var(--sidebar-hover);color:var(--sidebar-fg);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius);cursor:pointer;font-size:13px;font-weight:500;transition:background .12s}.btn-new:hover{background:var(--sidebar-active)}.conv-list{flex:1;overflow-y:auto;padding:8px;min-height:0}.conv-empty{color:var(--sidebar-muted);font-size:12px;padding:16px 8px;text-align:center}.conv-item{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:var(--radius);cursor:pointer;color:var(--sidebar-fg);margin-bottom:2px;transition:background .12s}.conv-item:hover{background:var(--sidebar-hover)}.conv-item.active{background:var(--sidebar-active)}.conv-item .conv-icon{color:var(--sidebar-muted);flex:0 0 auto}.conv-item .conv-name{flex:1;font-size:13px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.conv-item .conv-del{flex:0 0 auto;background:transparent;border:none;color:var(--sidebar-muted);cursor:pointer;padding:4px;border-radius:4px;opacity:0;display:inline-flex;transition:opacity .12s,color .12s,background .12s}.conv-item:hover .conv-del{opacity:1}.conv-item .conv-del:hover{color:#fca5a5;background:#ffffff14}.main{display:flex;flex-direction:column;min-width:0;min-height:0;background:var(--surface)}.header{display:flex;align-items:center;gap:10px;padding:0 16px;height:52px;background:var(--header-bg);color:var(--header-fg);flex:0 0 auto}.header .logo{display:inline-flex;color:var(--header-fg)}.header h1{font-size:15px;font-weight:600;margin:0;letter-spacing:.01em}.header .status{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:#cbd5e1}.status-dot{width:8px;height:8px;border-radius:50%;background:var(--sidebar-muted)}.status-dot.online{background:var(--status-online);box-shadow:0 0 0 3px #22c55e2e}.status-dot.connecting{background:#eab308}.header .spacer{flex:1}.pipeline-badge{display:inline-block;margin-left:10px;padding:1px 7px;font-size:10px;font-weight:500;line-height:18px;color:#94a3b8;background:#ffffff12;border:1px solid rgba(148,163,184,.25);border-radius:10px;white-space:nowrap;letter-spacing:.02em}.lang-select{font-size:12px;padding:4px 6px;border-radius:var(--radius);border:1px solid rgba(255,255,255,.18);background:#ffffff14;color:var(--header-fg)}.lang-select option{color:#111}.menu-btn{display:none;background:transparent;border:none;color:var(--header-fg);cursor:pointer;padding:4px}.messages{flex:1;overflow-y:auto;padding:20px 0;min-height:0}.msg-row{max-width:820px;margin:0 auto;padding:8px 20px;display:flex;flex-direction:column}.msg-row.user{align-items:flex-end}.msg-row.assistant{align-items:flex-start}.msg-meta{font-size:11px;color:var(--muted);margin-bottom:3px;font-weight:600}.bubble{max-width:92%;padding:10px 13px;border-radius:var(--radius);white-space:pre-wrap;word-break:break-word}.bubble.user{background:var(--user-bubble);color:var(--user-bubble-fg);border-bottom-right-radius:2px}.bubble.assistant{background:var(--assistant-bubble);color:var(--assistant-bubble-fg);border:1px solid var(--border);border-bottom-left-radius:2px}.bubble.error{border-color:var(--danger);color:var(--danger);background:transparent}.markdown p{margin:0 0 8px}.markdown p:last-child{margin-bottom:0}.markdown ul,.markdown ol{margin:6px 0;padding-left:20px}.markdown code{background:#64748b29;padding:1px 5px;border-radius:4px;font-size:.9em}.markdown pre{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);padding:10px;overflow-x:auto}.markdown pre code{background:transparent;padding:0}.markdown a{color:var(--primary)}.markdown table{border-collapse:collapse}.markdown th,.markdown td{border:1px solid var(--border);padding:4px 8px}.talk p{margin:0 0 8px}.talk p:last-child{margin-bottom:0}.answer-extra{margin-top:8px;max-width:92%;align-self:flex-start}.spot-map{height:220px;width:100%;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;background:var(--surface-2)}.spot-map .leaflet-pane,.spot-map .leaflet-top,.spot-map .leaflet-bottom{z-index:1}.spot-map .leaflet-control-attribution{font-size:10px;background:#fffc}.spot-pin{background:transparent;border:none}.spot-map-loading{height:220px;width:100%;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface-2)}.spot-chips{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.spot-chip{display:inline-flex;align-items:center;gap:4px;padding:3px 9px 3px 7px;font-size:12px;color:var(--ink);background:var(--surface-2);border:1px solid var(--border);border-radius:12px}.spot-chip svg{color:var(--primary);flex:0 0 auto}.sources-line{display:inline-flex;align-items:center;gap:5px;margin-top:6px;font-size:11px;color:var(--muted)}.sources-line svg{flex:0 0 auto}.msg-actions{display:flex;align-items:center;gap:4px;margin-top:6px}.icon-btn{display:inline-flex;align-items:center;justify-content:center;gap:4px;padding:5px 8px;font-size:12px;background:transparent;border:1px solid var(--border);border-radius:var(--radius);color:var(--muted);cursor:pointer;transition:background .12s,color .12s,border-color .12s}.icon-btn:hover{background:var(--surface-2);color:var(--ink)}.icon-btn:disabled{cursor:default}.icon-btn.selected-up{color:var(--good);border-color:var(--good);background:#16a34a14}.icon-btn.selected-down{color:var(--danger);border-color:var(--danger);background:#dc262614}.icon-btn.retry{color:var(--danger);border-color:var(--danger)}.icon-btn.playing{color:var(--primary);border-color:var(--primary);background:var(--primary-soft)}.fb-note{font-size:11px;color:var(--muted);align-self:center;margin-left:4px}.fb-note.err{color:var(--danger)}.settings-wrap{position:relative;display:inline-flex}.settings-btn{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;background:#ffffff14;border:1px solid rgba(255,255,255,.18);border-radius:var(--radius);color:var(--header-fg);cursor:pointer;margin-right:8px;transition:background .12s}.settings-btn:hover{background:#ffffff29}.settings-pop{position:absolute;top:calc(100% + 8px);right:0;width:280px;background:var(--surface);color:var(--ink);border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 8px 24px #0f172a2e;padding:14px;z-index:40}.settings-pop-title{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);font-weight:600;margin-bottom:10px}.settings-row{display:flex;align-items:center;justify-content:space-between;gap:10px;cursor:pointer}.settings-row-label{font-size:13px;font-weight:500;color:var(--ink)}.settings-desc{margin:8px 0 0;font-size:11px;line-height:1.5;color:var(--muted)}.toggle{position:relative;flex:0 0 auto;display:inline-flex}.toggle input{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;margin:0;cursor:pointer}.toggle-track{width:38px;height:22px;border-radius:11px;background:var(--border);transition:background .14s;display:inline-flex;align-items:center;padding:2px}.toggle.on .toggle-track{background:var(--primary)}.toggle-thumb{width:18px;height:18px;border-radius:50%;background:#fff;box-shadow:0 1px 2px #00000040;transition:transform .14s}.toggle.on .toggle-thumb{transform:translate(16px)}.composer{flex:0 0 auto;border-top:1px solid var(--border);background:var(--surface);padding:12px 20px 16px}.composer-inner{max-width:820px;margin:0 auto;display:flex;align-items:flex-end;gap:8px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);padding:6px 6px 6px 12px;transition:border-color .12s,box-shadow .12s}.composer-inner:focus-within{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-soft)}.composer textarea{flex:1;border:none;outline:none;resize:none;background:transparent;color:var(--ink);font-size:14px;line-height:1.5;max-height:180px;padding:6px 0}.composer textarea::placeholder{color:var(--muted)}.send-btn{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;flex:0 0 auto;border:none;border-radius:var(--radius);background:var(--primary);color:#fff;cursor:pointer;transition:background .12s,opacity .12s}.send-btn:hover{background:var(--primary-hover)}.send-btn:disabled{opacity:.45;cursor:default}.typing{display:inline-flex;gap:4px;padding:2px 0}.typing-dot{width:6px;height:6px;border-radius:50%;background:var(--muted);animation:typing-bounce 1.2s infinite ease-in-out}.typing-dot:nth-child(2){animation-delay:.2s}.typing-dot:nth-child(3){animation-delay:.4s}@keyframes typing-bounce{0%,60%,to{transform:translateY(0);opacity:.4}30%{transform:translateY(-4px);opacity:1}}.scrim{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a80;z-index:20}@media (max-width: 768px){.app{grid-template-columns:1fr}.menu-btn{display:inline-flex}.sidebar{position:fixed;top:0;left:0;bottom:0;width:280px;z-index:30;transform:translate(-100%);transition:transform .2s ease}.sidebar.open{transform:translate(0)}.scrim.show{display:block}.msg-row{padding:8px 14px}.composer{padding:10px 14px 14px}}
