:root{
  --rice:#f7f3ea; --rice2:#efe9da; --ink:#1c1a17; --ink2:#4a463f;
  --gold:#b8893a; --gold-soft:#d8b46a; --line:#e0d8c6;
  --blue:#2f5c8f; --green:#5b7a4b; --red:#9e3b32; --card:#fffdf8;
  --shadow:0 1px 2px rgba(40,30,10,.05),0 10px 30px rgba(40,30,10,.07);
  --serif:"Songti SC","Noto Serif SC",Georgia,serif;
  --sans:-apple-system,"PingFang SC","Helvetica Neue",Arial,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
body{background:var(--rice);color:var(--ink);font-family:var(--sans);min-height:100vh;-webkit-font-smoothing:antialiased}
a{color:var(--gold);text-decoration:none}

/* top bar */
.bar{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;border-bottom:1px solid var(--line);background:rgba(247,243,234,.92);backdrop-filter:blur(8px);position:sticky;top:0;z-index:5}
.bar .l{display:flex;align-items:center;gap:11px}
.av{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,var(--gold),var(--gold-soft));display:flex;align-items:center;justify-content:center;color:#fff;font-family:var(--serif);font-weight:600;font-size:17px}
.bar b{font-family:var(--serif);font-size:15px}.bar small{display:block;color:var(--ink2);font-size:11.5px}
.bar .r{display:flex;align-items:center;gap:12px}
.pill{font-size:11px;color:var(--gold);border:1px solid var(--gold-soft);border-radius:999px;padding:3px 10px}
.btn{border:1px solid var(--gold-soft);background:#fff;color:var(--gold);border-radius:10px;padding:8px 16px;font-size:13.5px;cursor:pointer;font-family:var(--serif)}
.btn:hover{background:var(--gold);color:#fff}
.btn.primary{background:var(--gold);color:#fff;border-color:var(--gold)}
.btn.primary:hover{background:#a5772f}
.btn:disabled{opacity:.5;cursor:not-allowed}

/* auth */
.center{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px}
.authcard{width:100%;max-width:400px;background:var(--card);border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow);padding:30px}
.authcard h1{font-family:var(--serif);font-size:22px;margin-bottom:4px}
.authcard .sub{color:var(--ink2);font-size:13px;margin-bottom:20px}
.tabs{display:flex;gap:8px;margin-bottom:18px}
.tabs .tab{flex:1;text-align:center;padding:8px;border-radius:10px;cursor:pointer;font-size:14px;color:var(--ink2);border:1px solid var(--line)}
.tabs .tab.on{background:var(--gold);color:#fff;border-color:var(--gold)}
label{display:block;font-size:12.5px;color:var(--ink2);margin:12px 0 5px}
input,select,textarea{width:100%;border:1px solid var(--line);border-radius:12px;padding:11px 14px;font-size:14.5px;font-family:var(--sans);background:#fff;outline:none;color:var(--ink)}
input:focus,select:focus,textarea:focus{border-color:var(--gold-soft)}
.err{color:var(--red);font-size:13px;margin-top:12px;min-height:18px}
.full{width:100%;margin-top:18px;justify-content:center}

/* chat */
.app{display:flex;flex-direction:column;height:100vh}
.prog{height:3px;background:var(--rice2)}.prog i{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--gold-soft),var(--gold));transition:width .3s}
.chat{flex:1;overflow-y:auto;padding:24px 0}
.inner{max-width:720px;margin:0 auto;padding:0 20px;display:flex;flex-direction:column;gap:14px}
.msg{display:flex;gap:10px;max-width:88%;animation:rise .25s ease}
@keyframes rise{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.msg.u{align-self:flex-end;flex-direction:row-reverse}
.msg .ic{width:28px;height:28px;border-radius:50%;flex:none;display:flex;align-items:center;justify-content:center;font-size:13px;font-family:var(--serif);font-weight:600}
.msg.a .ic{background:linear-gradient(135deg,var(--gold),var(--gold-soft));color:#fff}
.msg.u .ic{background:var(--rice2);color:var(--ink2)}
.bub{padding:12px 15px;border-radius:15px;font-size:14.5px;line-height:1.6;white-space:pre-wrap}
.msg.a .bub{background:var(--card);border:1px solid var(--line);border-bottom-left-radius:5px;box-shadow:var(--shadow)}
.msg.u .bub{background:var(--gold);color:#fff;border-bottom-right-radius:5px}
.dock{border-top:1px solid var(--line);background:var(--card);padding:14px 0}
.dockin{max-width:720px;margin:0 auto;padding:0 20px}
.row{display:flex;gap:10px;align-items:flex-end}
.row textarea{resize:none}
.send{border:none;background:var(--gold);color:#fff;border-radius:12px;padding:11px 20px;font-size:14px;cursor:pointer;font-family:var(--serif);white-space:nowrap}
.send:hover{background:#a5772f}.send:disabled{opacity:.5;cursor:not-allowed}
.hint{font-size:12px;color:var(--ink2);margin-top:7px}

/* summary / cards */
.summary{background:var(--card);border:1px solid var(--gold-soft);border-radius:16px;padding:24px;box-shadow:var(--shadow)}
.summary h3{font-family:var(--serif);font-size:20px;margin-bottom:4px}
.summary .sub{color:var(--ink2);font-size:13px;margin-bottom:16px}
.sblock{border-top:1px solid var(--line);padding:12px 0}
.sblock .k{font-size:11.5px;letter-spacing:1px;text-transform:uppercase;color:var(--gold);font-weight:700;margin-bottom:4px}
.sblock .v{font-size:14px;color:var(--ink2);white-space:pre-wrap}
.conf{font-size:11.5px;color:var(--red);text-align:center;margin-top:14px}

/* admin */
.wrap{max-width:1000px;margin:0 auto;padding:24px 20px}
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px}
.tile{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:16px;box-shadow:var(--shadow);cursor:pointer;transition:.12s}
.tile:hover{border-color:var(--gold-soft);transform:translateY(-1px)}
.tile h4{font-family:var(--serif);font-size:16px;margin-bottom:6px}
.tile .meta{font-size:12.5px;color:var(--ink2);display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}
.tag{font-size:11px;border-radius:999px;padding:2px 9px;border:1px solid var(--line);color:var(--ink2)}
.tag.done{color:var(--green);border-color:var(--green)}
.tag.ongoing{color:var(--blue);border-color:var(--blue)}
.tag.scored{color:var(--gold);border-color:var(--gold-soft)}
.modal-bg{position:fixed;inset:0;background:rgba(28,26,23,.45);display:flex;align-items:flex-start;justify-content:center;padding:40px 16px;overflow-y:auto;z-index:10}
.modal{width:100%;max-width:760px;background:var(--rice);border-radius:18px;box-shadow:var(--shadow);padding:26px}
.modal h2{font-family:var(--serif);font-size:20px}
.modal .close{float:right;cursor:pointer;color:var(--ink2);font-size:22px;line-height:1}
.scorebox{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:14px}
.scorebox label{margin:0 0 4px}
.muted{color:var(--ink2);font-size:13px}
pre.summary-text{white-space:pre-wrap;font-family:var(--sans);font-size:13.5px;color:var(--ink2);background:#fff;border:1px solid var(--line);border-radius:12px;padding:14px;line-height:1.6}

/* 审计：完整对话记录 */
.transcript{border:1px solid var(--line);border-radius:12px;background:#fff;max-height:420px;overflow-y:auto;padding:14px;display:flex;flex-direction:column;gap:10px}
.tx{display:flex;flex-direction:column;gap:3px;max-width:92%}
.tx .meta-line{font-size:10.5px;color:#9a9384;letter-spacing:.3px}
.tx .b{padding:9px 12px;border-radius:12px;font-size:13.5px;line-height:1.55;white-space:pre-wrap}
.tx.user{align-self:flex-end;align-items:flex-end}
.tx.user .b{background:var(--gold);color:#fff;border-bottom-right-radius:4px}
.tx.assistant .b{background:var(--rice2);color:var(--ink);border:1px solid var(--line);border-bottom-left-radius:4px}
.tx.system{align-self:center}
.tx.system .b{background:transparent;color:#9a9384;font-size:11.5px;padding:2px 0}
.tx .think{font-size:12px;color:#8a8474;font-style:italic;background:#faf7ef;border-left:2px solid var(--gold-soft);padding:6px 10px;border-radius:6px;white-space:pre-wrap}
.tx .tool{font-size:12px;color:var(--blue);background:#f0f4f9;border:1px solid #d6e0ee;border-radius:8px;padding:6px 10px;font-family:ui-monospace,Menlo,monospace}
.tx .tool.err{color:var(--red);background:#fbf0ef;border-color:#e8cfcc}
details.think summary{cursor:pointer;font-size:11.5px;color:#9a8a5a;list-style:none}
details.think summary::-webkit-details-marker{display:none}
