/* ===== QuantumAI · Claude-style UI ===== */
:root{
  --bg:#faf9f5;            /* warm cream main */
  --sidebar:#f0eee6;       /* slightly darker warm */
  --panel:#ffffff;
  --ink:#28261b;           /* primary text */
  --ink2:#5a574d;          /* secondary */
  --mut:#8a8678;           /* muted */
  --line:#e6e3d8;          /* hairline */
  --line2:#dad6c8;
  --accent:#cc785c;        /* Claude coral */
  --accent-d:#b15c3f;
  --accent-soft:#f5e9e2;
  --user-bub:#ece9df;
  --code-bg:#f6f4ee;
  --radius:14px;
  --serif:"Fraunces","Newsreader",Georgia,serif;
  --sans:-apple-system,BlinkMacSystemFont,"Segoe UI","PingFang SC","Microsoft YaHei",system-ui,sans-serif;
}
/* 深色模式（Claude 暖炭灰） */
[data-theme="dark"]{
  --bg:#262624; --sidebar:#1f1e1d; --panel:#30302e;
  --ink:#ece8e0; --ink2:#bdb6aa; --mut:#8f897c;
  --line:#3a3935; --line2:#47453f;
  --accent:#d98a6a; --accent-d:#e6a385; --accent-soft:#3a2c25;
  --user-bub:#35332f; --code-bg:#1d1c1a;
}
[data-theme="dark"] #modes button:hover,
[data-theme="dark"] #settingsBtn:hover,
[data-theme="dark"] #themeBtn:hover,
[data-theme="dark"] .copy-btn:hover{background:#34322d}
[data-theme="dark"] .thinking-box{background:#2c2a27}
[data-theme="dark"] .prose code{background:#3a3833}
[data-theme="dark"] .prose pre .code-head,
[data-theme="dark"] .prose th{background:#282724}
[data-theme="dark"] .kb-track{background:#3a3833}
[data-theme="dark"] dialog::backdrop{background:#00000088}

*{box-sizing:border-box}
html,body{height:100%}
body{margin:0;font-family:var(--sans);background:var(--bg);color:var(--ink);
  font-size:15px;line-height:1.65;-webkit-font-smoothing:antialiased}
#app{display:flex;height:100vh;overflow:hidden}

/* ---------- 侧边栏 ---------- */
#sidebar{width:264px;flex-shrink:0;background:var(--sidebar);border-right:1px solid var(--line);
  display:flex;flex-direction:column;padding:18px 14px}
.brand{display:flex;align-items:center;gap:11px;padding:6px 8px 16px}
.logo{font-size:22px;color:var(--accent);line-height:1}
.brand-txt strong{font-family:var(--serif);font-weight:600;font-size:19px;letter-spacing:.2px;display:block}
.brand-txt small{color:var(--mut);font-size:11.5px}
.new-chat{width:100%;background:var(--accent);color:#fff;border:none;border-radius:10px;
  padding:11px;font-size:14px;font-weight:600;cursor:pointer;margin-bottom:20px;transition:.15s}
.new-chat:hover{background:var(--accent-d)}
.modes-label{font-size:11px;text-transform:uppercase;letter-spacing:1.2px;color:var(--mut);
  padding:0 8px 8px;font-weight:600}
#modes{display:flex;flex-direction:column;gap:2px;flex:1;overflow-y:auto}
#modes button{display:grid;grid-template-columns:24px 1fr;grid-template-rows:auto auto;
  gap:0 8px;text-align:left;background:none;border:none;border-radius:10px;padding:9px 10px;
  cursor:pointer;color:var(--ink2);transition:.12s}
#modes button i{grid-row:1/3;font-size:16px;font-style:normal;align-self:center}
#modes button span{font-size:14px;font-weight:600;color:var(--ink)}
#modes button em{font-size:11px;color:var(--mut);font-style:normal}
#modes button:hover{background:#e8e5d9}
#modes button.active{background:var(--accent-soft)}
#modes button.active span{color:var(--accent-d)}
.side-foot{border-top:1px solid var(--line);padding-top:12px;margin-top:8px;
  display:flex;flex-direction:column;gap:8px}
.status{display:flex;align-items:center;gap:7px;font-size:12px;color:var(--mut);padding:0 8px}
.status .dot{width:8px;height:8px;border-radius:50%;background:#bbb;transition:.2s}
.status.ok .dot{background:#6cae6c;box-shadow:0 0 0 3px #6cae6c22}
.status.bad .dot{background:#d06c5c;box-shadow:0 0 0 3px #d06c5c22}
#settingsBtn,#themeBtn{background:none;border:none;text-align:left;padding:7px 8px;border-radius:8px;
  cursor:pointer;color:var(--ink2);font-size:13px;width:100%}
#settingsBtn:hover,#themeBtn:hover{background:#e8e5d9}

/* ---------- 主区 ---------- */
#main{flex:1;display:flex;flex-direction:column;min-width:0}
#topbar{display:flex;align-items:center;justify-content:space-between;
  padding:16px 32px;border-bottom:1px solid var(--line);background:var(--bg)}
#topbar h2{margin:0;font-size:16px;font-weight:600}
#topbar p{margin:2px 0 0;font-size:12.5px;color:var(--mut)}
.model-chip{font-size:12px;color:var(--ink2);background:var(--panel);border:1px solid var(--line2);
  padding:5px 12px;border-radius:999px}

.thread{flex:1;overflow-y:auto;padding:28px 0;scroll-behavior:smooth}
.msg{max-width:740px;margin:0 auto 26px;padding:0 32px;display:flex;gap:15px}
.msg .avatar{width:28px;height:28px;border-radius:7px;flex-shrink:0;display:grid;place-items:center;
  font-size:14px;font-weight:700;margin-top:2px}
.msg.user .avatar{background:var(--ink);color:#fff}
.msg.bot .avatar{background:var(--accent);color:#fff}
.msg .body{flex:1;min-width:0;padding-top:2px}
.msg .role{font-size:12px;color:var(--mut);font-weight:600;margin-bottom:4px}
.msg.user .bubble{background:var(--user-bub);border-radius:12px;padding:11px 15px;display:inline-block;
  white-space:pre-wrap}
.thinking-box{background:#f3f1e8;border:1px solid var(--line);border-left:3px solid var(--accent);
  border-radius:8px;padding:10px 13px;margin-bottom:10px;font-size:13px;color:var(--ink2);
  white-space:pre-wrap;max-height:200px;overflow:auto}
.thinking-box .tlabel{font-size:11px;color:var(--accent-d);font-weight:600;margin-bottom:4px}

/* markdown 渲染 */
.prose{color:var(--ink)}
.prose p{margin:0 0 12px}
.prose h1,.prose h2,.prose h3{font-family:var(--serif);font-weight:600;margin:18px 0 8px;line-height:1.3}
.prose h1{font-size:22px}.prose h2{font-size:19px}.prose h3{font-size:16px}
.prose ul,.prose ol{margin:0 0 12px;padding-left:22px}
.prose li{margin:3px 0}
.prose code{background:#efece2;padding:1.5px 6px;border-radius:5px;font-size:13px;
  font-family:"SF Mono",ui-monospace,Menlo,monospace}
.prose pre{background:#f6f4ee;border:1px solid var(--line2);border-radius:10px;
  padding:0;margin:0 0 14px;overflow:hidden;position:relative}
.prose pre .code-head{display:flex;justify-content:space-between;align-items:center;
  padding:7px 13px;border-bottom:1px solid var(--line);font-size:11.5px;color:var(--mut);background:#f0ede3}
.prose pre code{display:block;background:none;padding:14px;font-size:13px;line-height:1.6;
  overflow-x:auto;border-radius:0}
.copy-btn{background:none;border:1px solid var(--line2);border-radius:6px;padding:2px 9px;
  font-size:11px;cursor:pointer;color:var(--ink2)}
.copy-btn:hover{background:#e6e2d6}
.prose table{border-collapse:collapse;margin:0 0 14px;font-size:13.5px;width:100%}
.prose th,.prose td{border:1px solid var(--line2);padding:6px 11px;text-align:left}
.prose th{background:#f0ede3}
.prose blockquote{border-left:3px solid var(--line2);margin:0 0 12px;padding:2px 14px;color:var(--ink2)}
.prose a{color:var(--accent-d)}
.cursor{display:inline-block;width:7px;height:15px;background:var(--accent);
  vertical-align:text-bottom;animation:blink 1s steps(2) infinite;border-radius:1px}
@keyframes blink{50%{opacity:0}}

/* 智能体工具轨迹 */
.tool-trace{background:#f3f1e8;border:1px solid var(--line);border-radius:10px;padding:10px 13px;margin-bottom:12px}
.tt-head{font-size:12px;font-weight:600;color:var(--accent-d);margin-bottom:6px}
.tt-step{font-size:12.5px;margin:4px 0;border-top:1px solid var(--line);padding-top:6px}
.tt-step summary{cursor:pointer;color:var(--ink2);font-weight:500;list-style:none}
.tt-step summary::-webkit-details-marker{display:none}
.tt-step summary::before{content:"▸ ";color:var(--accent)}
.tt-step[open] summary::before{content:"▾ "}
.tt-run{color:var(--accent-d);font-size:11px;font-weight:400}
.tt-io{margin:5px 0 2px;color:var(--mut);font-size:11.5px}
.tt-io code{display:block;background:var(--code-bg);border:1px solid var(--line2);border-radius:6px;
  padding:6px 9px;margin-top:2px;color:var(--ink2);font-size:11.5px;white-space:pre-wrap;word-break:break-all}
[data-theme="dark"] .tool-trace{background:#2c2a27}

/* 检索结果卡 */
.hit{border:1px solid var(--line);border-radius:10px;padding:12px 15px;margin-bottom:10px;background:var(--panel)}
.hit .meta{font-size:11.5px;color:var(--accent-d);font-weight:600;margin-bottom:5px}
.hit .txt{font-size:13px;color:var(--ink2);white-space:pre-wrap}

/* ---------- 知识库仪表盘 ---------- */
.kb-view{max-width:760px;margin:0 auto;padding:8px 32px 40px;animation:fade .4s ease}
.kb-head{text-align:center;padding:18px 0 24px}
.kb-total{font-family:var(--serif);font-size:52px;font-weight:600;color:var(--accent);line-height:1}
.kb-total-l{color:var(--mut);font-size:13px;margin-top:2px}
.kb-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px}
.kb-card{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:15px 18px;margin-bottom:14px}
.kb-card h4{margin:0 0 12px;font-size:13px;font-weight:600;color:var(--ink)}
.kb-card h4 small{color:var(--mut);font-weight:400;font-size:11.5px}
.kb-bar{display:flex;align-items:center;gap:10px;margin:7px 0;font-size:12.5px}
.kb-bl{width:170px;color:var(--ink2);flex-shrink:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.kb-track{flex:1;height:8px;background:#efece2;border-radius:5px;overflow:hidden}
.kb-fill{display:block;height:100%;background:linear-gradient(90deg,var(--accent),#e0a890);border-radius:5px;transition:width .5s}
.kb-bv{width:38px;text-align:right;color:var(--mut)}
.kb-src{display:flex;flex-wrap:wrap;gap:7px}
.kb-pill{font-size:12px;background:var(--accent-soft);color:var(--accent-d);padding:3px 11px;border-radius:999px}
.kb-absorb-box .kb-absorb-row{font-size:13px;color:var(--ink2);margin-bottom:11px}
.kb-absorb-box select{padding:5px 9px;border-radius:7px;border:1px solid var(--line2);font-family:inherit}
.kb-presets{display:flex;flex-wrap:wrap;gap:8px}
.kb-src-label{font-size:11.5px;color:var(--mut);margin:13px 0 7px}
.kb-absorb{background:var(--panel);border:1px solid var(--accent);color:var(--accent-d);border-radius:999px;
  padding:7px 15px;font-size:13px;cursor:pointer;transition:.15s;font-family:inherit}
.kb-absorb:hover:not(:disabled){background:var(--accent-soft)}
.kb-absorb:disabled{opacity:.45;cursor:wait;border-color:var(--line2);color:var(--mut)}
.kb-prog{margin-top:13px;font-size:13px;color:var(--ink2);min-height:18px}

/* API 平台目录 + Playground */
.pg-out{margin-top:10px;font-size:13.5px;color:var(--ink2)}
.cmp-pick{display:flex;flex-wrap:wrap;gap:10px;margin-top:8px}
.job-view{border:1px solid var(--accent);background:none;color:var(--accent-d);border-radius:6px;
  padding:1px 9px;font-size:11.5px;cursor:pointer}
.job-view:hover{background:var(--accent-soft)}
#job-list table td{vertical-align:middle}
#cmp-out .gw-card .prose{font-size:13px;margin-top:6px}
.pg-out pre{margin:0 0 8px}
.studio-view select,.kb-card select{max-width:100%}
/* API 平台目录 */
.gw-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.gw-card{border:1px solid var(--line);border-radius:10px;padding:11px 13px;background:var(--bg)}
.gw-top{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:5px}
.gw-id{font-size:12.5px;font-weight:600;color:var(--accent-d);background:none;padding:0}
.gw-badge{font-size:10.5px;padding:2px 8px;border-radius:999px;font-weight:600;flex-shrink:0}
.gw-desc{font-size:12px;color:var(--ink2);line-height:1.5;margin-bottom:5px}
.gw-cap{font-size:11px;color:var(--mut)}
@media (max-width:760px){.gw-grid{grid-template-columns:1fr}}

/* 对话历史 */
.hist-card{position:relative;background:var(--panel);border:1px solid var(--line);border-radius:10px;
  padding:12px 15px;margin-bottom:8px;cursor:pointer;transition:.12s}
.hist-card:hover{border-color:var(--accent);box-shadow:0 4px 12px #00000008}
.hc-title{font-size:14px;font-weight:600;color:var(--ink);margin-bottom:3px;padding-right:26px;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.hc-meta{font-size:11.5px;color:var(--mut)}
.hc-del{position:absolute;top:10px;right:11px;background:none;border:none;color:var(--mut);
  cursor:pointer;font-size:13px;line-height:1}
.hc-del:hover{color:var(--accent-d)}

/* ---------- 欢迎页 ---------- */
.welcome{max-width:760px;margin:6vh auto 0;text-align:center;padding:0 32px;
  animation:fade .5s ease}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1}}
.hero-logo{font-size:46px;color:var(--accent);margin-bottom:14px}
.welcome h1{font-family:var(--serif);font-weight:500;font-size:34px;margin:0 0 10px;letter-spacing:.3px}
.grad{background:linear-gradient(95deg,var(--accent),#9b6bd4);-webkit-background-clip:text;
  background-clip:text;color:transparent}
.hero-sub{color:var(--mut);font-size:14.5px;margin:0 0 34px}
.cards{display:grid;grid-template-columns:1fr 1fr;gap:12px;text-align:left}
.cards button{background:var(--panel);border:1px solid var(--line);border-radius:12px;
  padding:15px 17px;cursor:pointer;transition:.15s;font-family:inherit}
.cards button:hover{border-color:var(--accent);transform:translateY(-2px);
  box-shadow:0 6px 18px #00000008}
.cards .ct{font-size:14px;font-weight:600;color:var(--ink);margin-bottom:3px}
.cards .cd{font-size:12.5px;color:var(--mut)}

/* ---------- 选项条 + 输入 ---------- */
.opt-bar{max-width:740px;margin:0 auto;padding:8px 32px 0;display:flex;flex-direction:column;gap:7px}
.opt-row{display:flex;align-items:center;gap:9px;flex-wrap:wrap}
.opt-label{font-size:12px;color:var(--mut);flex-shrink:0}
.opt-hint{font-size:11.5px;color:var(--mut);margin-left:auto}
/* 代码工坊表单 */
.studio-view .st-algo{width:100%;resize:vertical;border:1px solid var(--line2);border-radius:10px;
  padding:11px 14px;font-family:inherit;font-size:14px;background:var(--panel);color:var(--ink);margin-bottom:12px}
.st-field{display:flex;align-items:center;gap:9px;flex-wrap:wrap;margin-bottom:11px}
#st-result{margin-top:6px}
#st-result .content{max-width:100%}
#codegenBar select,.studio-view select{padding:4px 8px;border:1px solid var(--line2);border-radius:7px;
  font-family:inherit;font-size:12.5px;background:var(--panel);color:var(--ink)}
#codegenBar input[type=number],.studio-view input[type=number]{width:62px;padding:4px 8px;
  border:1px solid var(--line2);border-radius:7px;font-family:inherit;font-size:12.5px;
  background:var(--panel);color:var(--ink)}
.chips{display:flex;gap:6px}
.chips button{border:1px solid var(--line2);background:var(--panel);border-radius:999px;
  padding:4px 13px;font-size:12.5px;cursor:pointer;color:var(--ink2)}
.chips button.active{background:var(--accent-soft);border-color:var(--accent);color:var(--accent-d);font-weight:600}
.opt-ck{font-size:12.5px;color:var(--ink2);display:flex;align-items:center;gap:5px;cursor:pointer}

.composer{max-width:740px;margin:10px auto 0;width:100%;padding:0 32px;display:flex;
  align-items:flex-end;gap:10px}
.composer textarea{flex:1;resize:none;border:1px solid var(--line2);border-radius:16px;
  padding:13px 17px;font-family:inherit;font-size:15px;line-height:1.5;background:var(--panel);
  color:var(--ink);max-height:200px;box-shadow:0 1px 3px #0000000a;transition:.15s}
.composer textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
#send{width:42px;height:42px;border-radius:50%;border:none;background:var(--accent);color:#fff;
  font-size:19px;cursor:pointer;flex-shrink:0;transition:.15s}
#send:hover{background:var(--accent-d)}
#send:disabled{background:#d8d4c8;cursor:default}
.composer-hint{max-width:740px;margin:7px auto 14px;padding:0 32px;text-align:center;
  font-size:11.5px;color:var(--mut)}

/* ---------- 弹窗 ---------- */
dialog{border:1px solid var(--line2);border-radius:16px;padding:24px;background:var(--panel);
  color:var(--ink);width:380px;box-shadow:0 20px 60px #00000022}
dialog::backdrop{background:#28261b55;backdrop-filter:blur(2px)}
dialog h3{margin:0 0 14px;font-family:var(--serif);font-weight:600}
dialog label{display:block;font-size:13px;color:var(--ink2);margin:12px 0}
dialog input{width:100%;margin-top:5px;padding:9px 12px;border:1px solid var(--line2);
  border-radius:9px;font-family:inherit;font-size:14px}
dialog menu{display:flex;gap:8px;justify-content:flex-end;padding:0;margin:20px 0 0}
dialog button{padding:8px 18px;border-radius:9px;border:1px solid var(--line2);background:var(--bg);
  color:var(--ink);cursor:pointer;font-size:14px}
dialog button.primary{background:var(--accent);color:#fff;border-color:var(--accent)}

.menu-btn{display:none;background:none;border:none;font-size:22px;cursor:pointer;
  margin-right:10px;color:var(--ink);line-height:1}
@media (max-width:760px){
  .menu-btn{display:block}
  #topbar{align-items:center}
  #sidebar{position:fixed;left:0;top:0;bottom:0;z-index:50;transform:translateX(-100%);
    transition:transform .22s ease;box-shadow:2px 0 20px #0000001f}
  #app.nav-open #sidebar{transform:translateX(0)}
  #app.nav-open .nav-scrim{position:fixed;inset:0;background:#0006;z-index:40}
  .cards{grid-template-columns:1fr}
  .kb-grid,.gw-grid{grid-template-columns:1fr}
}
::-webkit-scrollbar{width:9px;height:9px}
::-webkit-scrollbar-thumb{background:#d8d4c6;border-radius:5px;border:2px solid var(--bg)}
