:root{color-scheme:light;--bg: #f4f6f8;--panel: #ffffff;--panel-soft: #f9fbfd;--text: #142033;--muted: #6f7a8a;--line: #e4e8ef;--accent: #1f6feb;--accent-hover: #195cc7;--assistant: #eef5ff;--user: #e9f8ef;--shadow: 0 14px 40px rgba(20, 32, 51, .08)}*{box-sizing:border-box}html,body,#app{width:100%;height:100%;margin:0}body{font-family:Inter,Segoe UI,PingFang SC,Hiragino Sans GB,Microsoft YaHei,sans-serif;color:var(--text);background:radial-gradient(circle at top left,rgba(31,111,235,.1),transparent 28%),radial-gradient(circle at bottom right,rgba(31,111,235,.08),transparent 20%),var(--bg)}button,textarea{font:inherit}.app-shell{display:grid;grid-template-columns:320px 1fr;height:100%;gap:16px;padding:16px}.sidebar,.chat-area{background:#ffffffc7;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid rgba(228,232,239,.9);border-radius:20px;box-shadow:var(--shadow)}.sidebar{display:flex;flex-direction:column;gap:16px;padding:18px;overflow:hidden}.brand{display:flex;align-items:center;gap:12px}.brand h1,.chat-header h2{margin:0;font-size:20px;line-height:1.2}.brand p,.chat-header p,.muted,.role-desc,.session-meta,.bubble-meta,.empty-state{color:var(--muted)}.brand p{margin:4px 0 0;font-size:13px}.brand-badge{width:44px;height:44px;display:grid;place-items:center;border-radius:14px;background:linear-gradient(135deg,var(--accent),#6ea8fe);color:#fff;font-weight:700;letter-spacing:.05em;box-shadow:0 10px 24px #1f6feb42}.brand-info{display:flex;flex-direction:column;gap:6px;flex:1;min-width:0}.user-switcher{display:flex;align-items:center;gap:6px;margin-top:4px}.user-switcher label{font-size:12px;color:var(--muted);white-space:nowrap}.user-switcher input,.user-switcher select{flex:1;min-width:0;padding:4px 8px;font-size:13px;border:1px solid var(--border, #d0d7de);border-radius:6px;background:var(--input-bg, #fff);color:inherit;cursor:pointer}.user-switcher input:focus,.user-switcher select:focus{outline:none;border-color:var(--accent)}.switcher-btn{padding:4px 10px;font-size:12px;border:1px solid var(--border, #d0d7de);border-radius:6px;background:var(--accent);color:#fff;cursor:pointer;white-space:nowrap}.switcher-btn:hover{filter:brightness(1.1)}.primary-btn,.send-btn{border:none;border-radius:14px;cursor:pointer;transition:.18s ease}.primary-btn{padding:14px 16px;background:var(--accent);color:#fff;font-weight:600}.test-actions{display:grid;grid-template-columns:1fr;gap:8px}.secondary-btn{border:1px solid var(--line);border-radius:12px;padding:11px 12px;background:#fff;color:var(--text);cursor:pointer;font-weight:600;transition:.18s ease}.primary-btn:hover:not(:disabled),.send-btn:hover:not(:disabled),.secondary-btn:hover:not(:disabled){transform:translateY(-1px)}.primary-btn:hover:not(:disabled){background:var(--accent-hover)}.primary-btn:disabled,.secondary-btn:disabled,.send-btn:disabled{opacity:.6;cursor:not-allowed}.panel{display:flex;flex-direction:column;gap:12px;min-height:0}.panel-title{font-size:13px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted)}.session-list,.role-list{display:flex;flex-direction:column;gap:10px;overflow:auto}.session-item,.role-item{width:100%;text-align:left;border:1px solid var(--line);background:var(--panel);border-radius:16px;padding:12px;cursor:pointer;transition:.18s ease}.session-item:hover,.role-item:hover{border-color:#1f6feb59;transform:translateY(-1px)}.session-item.active,.role-item.selected{border-color:#1f6feb8c;box-shadow:0 10px 22px #1f6feb1a}.session-title,.role-name{font-weight:600;margin-bottom:4px}.session-meta{display:flex;justify-content:space-between;gap:8px;font-size:12px}.session-id-copy{cursor:pointer;text-decoration:underline dotted;text-underline-offset:2px}.session-id-copy:hover{color:#4a90e2}.role-desc{font-size:13px;line-height:1.5}.chat-area{display:grid;grid-template-rows:auto 1fr auto auto;min-width:0;overflow:hidden}.chat-header{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:18px 22px;border-bottom:1px solid var(--line);background:linear-gradient(180deg,#fffffff0,#ffffffb8)}.chat-header p{margin:6px 0 0;font-size:13px}.state-strip{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.state-strip span{min-height:24px;padding:4px 8px;border:1px solid #d7dde5;border-radius:6px;background:#f7f9fb;color:#5a6470;font-size:12px;line-height:16px}.state-panel{display:grid;gap:6px;margin-top:8px;max-width:920px}.state-group{display:grid;grid-template-columns:120px 1fr;gap:8px;align-items:start}.state-label{padding-top:4px;color:#7a838e;font-size:12px;font-weight:700}.state-tags{display:flex;flex-wrap:wrap;gap:6px}.state-tags span{min-height:24px;max-width:360px;overflow-wrap:anywhere;padding:4px 8px;border:1px solid #d7dde5;border-radius:6px;background:#fff;color:#4e5863;font-size:12px;line-height:16px}.state-tags span.ok{border-color:#b9e3c7;background:#eefaf2;color:#17633d}.state-tags span.danger{border-color:#f1c4c4;background:#fff1f1;color:#9c2f2f}.memory-details{max-width:760px}.memory-details summary{display:flex;flex-wrap:wrap;gap:6px;align-items:center;width:fit-content;min-height:26px;padding:4px 8px;border:1px solid #d7dde5;border-radius:6px;background:#f7f9fb;color:#5a6470;font-size:12px;font-weight:700;cursor:pointer;list-style:none}.memory-details summary::-webkit-details-marker{display:none}.memory-details summary:before{content:">";color:#8b95a1}.memory-details[open] summary:before{content:"v"}.memory-details summary span{font-weight:500}.memory-tags{max-height:132px;margin-top:6px;overflow:auto;padding-right:4px}.status-pill{padding:8px 12px;border-radius:999px;font-size:12px;color:#6d7480;background:#edf1f5}.status-pill.online{color:#12623a;background:#ddf6e7}.message-list{overflow:auto;padding:20px 22px}.welcome-card{max-width:560px;border:1px dashed var(--line);background:var(--panel-soft);border-radius:18px;padding:28px;color:var(--muted)}.welcome-card h3{margin:0 0 10px;color:var(--text)}.message-row{display:flex;align-items:flex-end;gap:12px;margin-bottom:18px}.message-row.user{flex-direction:row-reverse}.avatar{width:36px;height:36px;border-radius:50%;display:grid;place-items:center;font-size:12px;font-weight:700;color:#fff;flex:0 0 auto}.assistant .avatar{background:linear-gradient(135deg,#4b79ff,#2fb0ff)}.user .avatar{background:linear-gradient(135deg,#20b26b,#55cc8c)}.bubble{max-width:min(720px,calc(100% - 56px));padding:14px 16px;border-radius:18px;border:1px solid var(--line);background:#fff}.assistant .bubble{background:var(--assistant)}.user .bubble{background:var(--user)}.bubble-text{white-space:pre-wrap;line-height:1.7}.bubble-translation{margin-top:10px;padding-top:10px;border-top:1px solid rgba(111,122,138,.18);color:#4d5968;font-size:14px;line-height:1.65;white-space:pre-wrap}.bubble-translation.loading{color:var(--muted);font-style:italic}.message-tags{display:flex;flex-wrap:wrap;gap:5px;margin-top:8px}.message-tags span{min-height:22px;max-width:100%;overflow-wrap:anywhere;padding:3px 7px;border:1px solid rgba(130,142,156,.28);border-radius:6px;background:#ffffff9e;color:#5d6671;font-size:11px;line-height:15px}.message-debug{margin-top:8px;border-top:1px solid rgba(111,122,138,.18);padding-top:8px}.message-debug summary{cursor:pointer;color:#5d6671;font-size:12px;-webkit-user-select:none;user-select:none}.debug-grid{display:grid;gap:8px;margin-top:8px;max-height:280px;overflow:auto}.debug-grid div{border:1px solid rgba(130,142,156,.24);border-radius:6px;background:#ffffff9e;padding:8px}.debug-grid .post-enforcer-log{border-color:#dc8c3c80;background:#fff4e6b3}.debug-grid strong{display:block;margin-bottom:5px;color:#3f4a57;font-size:12px}.debug-grid pre{margin:0;white-space:pre-wrap;overflow-wrap:anywhere;color:#374151;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:11px;line-height:1.45}.bubble-meta{display:flex;gap:10px;margin-top:8px;font-size:12px}.composer{display:grid;grid-template-columns:1fr auto;gap:12px;padding:16px 22px 20px;border-top:1px solid var(--line);background:#ffffffe0}.composer-input{min-height:92px;resize:none;border:1px solid var(--line);border-radius:16px;padding:14px 16px;outline:none;background:#fff}.composer-input:focus{border-color:#1f6feb8c;box-shadow:0 0 0 4px #1f6feb14}.send-btn{align-self:end;padding:14px 20px;background:#142033;color:#fff;font-weight:600}.error-banner{margin:0 22px 20px;padding:12px 14px;border-radius:14px;background:#fff1f1;border:1px solid #ffd4d4;color:#a33}.empty-state{font-size:13px;padding:6px 2px}@media(max-width:960px){.app-shell{grid-template-columns:1fr;height:auto;min-height:100%}.sidebar{order:2}.chat-area{order:1;min-height:72vh}}@media(max-width:640px){.app-shell{padding:10px;gap:10px}.sidebar,.chat-header,.message-list,.composer{padding-left:14px;padding-right:14px}.composer,.state-group{grid-template-columns:1fr}.send-btn{width:100%}}.batch-panel{flex-shrink:0}.batch-inputs{display:flex;flex-direction:column;gap:6px}.batch-inputs label{font-size:12px;color:var(--muted);display:flex;justify-content:space-between;align-items:center;gap:8px}.batch-inputs input[type=number]{width:72px;background:var(--surface);border:1px solid var(--border);border-radius:6px;color:var(--text);padding:3px 6px;font-size:13px}.batch-progress{display:flex;flex-direction:column;gap:4px}.batch-bar-wrap{height:6px;background:var(--border);border-radius:3px;overflow:hidden}.batch-bar{height:100%;background:var(--accent);border-radius:3px;transition:width .4s}.batch-stat{font-size:11px;color:var(--muted)}.batch-table-wrap{overflow-x:auto;max-height:240px;overflow-y:auto}.batch-table{width:100%;border-collapse:collapse;font-size:11px}.batch-table th{padding:4px 6px;text-align:left;color:var(--muted);border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--surface)}.batch-table td{padding:3px 6px;border-bottom:1px solid var(--border);white-space:nowrap}.batch-table .row-error td{color:#e57373}.batch-table .row-contact td:nth-child(5){color:#81c784;font-weight:600}.err-cell{max-width:120px;overflow:hidden;text-overflow:ellipsis;color:#e57373}
