:root{
  --bg:#f5f6f8; --card:#fff; --ink:#1f2733; --muted:#6b7686; --line:#e3e7ee;
  --brand:#1f5fcf; --brand-d:#1748a3; --ok:#1f9d57; --warn:#d98a00; --err:#d23b3b; --info:#6b7686;
}
*{box-sizing:border-box}
body{margin:0;font-family:-apple-system,"PingFang SC","Microsoft YaHei",Segoe UI,sans-serif;background:var(--bg);color:var(--ink);font-size:15px;line-height:1.6}
a{color:var(--brand);text-decoration:none}
a:hover{text-decoration:underline}
.container{max-width:1080px;margin:0 auto;padding:24px 20px 60px}
.topbar{display:flex;align-items:center;gap:18px;background:#fff;border-bottom:1px solid var(--line);padding:0 22px;height:54px;position:sticky;top:0;z-index:20}
.brand{font-weight:700;color:var(--ink);font-size:16px}
.nav-links{display:flex;gap:16px;flex:1}
.nav-links a{color:var(--muted);font-size:14px}
.nav-links a:hover{color:var(--brand)}
.nav-right{display:flex;align-items:center;gap:14px}
.who{font-size:14px;color:var(--muted)}
.role-tag{margin-left:6px;padding:1px 7px;border-radius:10px;font-size:12px;background:#eef3fb;color:var(--brand)}
.role-tag.admin{background:#fdeeee;color:var(--err)}
.link-btn,.badge-btn{background:none;border:none;color:var(--muted);cursor:pointer;font-size:14px;padding:0}
.link-btn:hover{color:var(--err)}
.badge{background:var(--err);color:#fff;border-radius:9px;padding:0 6px;font-size:12px}
.foot{text-align:center;color:#a3acba;font-size:12px;padding:24px}

h1{font-size:22px;margin:0 0 4px}
h2{font-size:17px;margin:26px 0 12px;padding-bottom:6px;border-bottom:1px solid var(--line)}
h3{font-size:15px;margin:16px 0 8px}
.sub{color:var(--muted);font-size:13px;margin:0 0 18px}

.card{background:var(--card);border:1px solid var(--line);border-radius:10px;padding:18px 20px;margin-bottom:16px}
.grid{display:grid;gap:14px}
.grid.cols-2{grid-template-columns:1fr 1fr}
.grid.cols-4{grid-template-columns:repeat(4,1fr)}
@media(max-width:720px){.grid.cols-2,.grid.cols-4{grid-template-columns:1fr}}

.stat{background:#fff;border:1px solid var(--line);border-radius:10px;padding:16px}
.stat .n{font-size:26px;font-weight:700}
.stat .l{color:var(--muted);font-size:13px}

table{width:100%;border-collapse:collapse;font-size:14px}
th,td{text-align:left;padding:9px 10px;border-bottom:1px solid var(--line);vertical-align:top}
th{color:var(--muted);font-weight:600;font-size:13px}
tr:hover td{background:#fafbfc}

.btn{display:inline-block;background:var(--brand);color:#fff;border:none;border-radius:7px;padding:8px 16px;font-size:14px;cursor:pointer}
.btn:hover{background:var(--brand-d);text-decoration:none;color:#fff}
.btn.sm{padding:5px 11px;font-size:13px}
.btn.ghost{background:#fff;color:var(--brand);border:1px solid var(--brand)}
.btn.danger{background:var(--err)}
.btn.gray{background:#eef1f5;color:var(--ink)}

label{display:block;font-size:13px;color:var(--muted);margin:10px 0 4px}
input[type=text],input[type=number],input[type=password],select,textarea{
  width:100%;padding:8px 10px;border:1px solid var(--line);border-radius:7px;font-size:14px;font-family:inherit;background:#fff}
textarea{min-height:64px;resize:vertical}
.row{display:flex;gap:14px;flex-wrap:wrap}
.row > div{flex:1;min-width:160px}
.checks{display:flex;gap:14px;flex-wrap:wrap;margin-top:6px}
.checks label{display:inline-flex;align-items:center;gap:5px;margin:0;color:var(--ink)}
.checks input{width:auto}

.tag{display:inline-block;padding:1px 9px;border-radius:11px;font-size:12px;font-weight:600}
.tag.created{background:#eef1f5;color:#6b7686}
.tag.questionnaire_sent{background:#fff4e0;color:#b9770a}
.tag.questionnaire_done{background:#e7f4ec;color:#1f9d57}
.tag.finalized{background:#eaf0fc;color:#1f5fcf}

.pill{display:inline-block;padding:1px 8px;border-radius:10px;font-size:12px}
.pill.error{background:#fdecec;color:var(--err)}
.pill.warn{background:#fef3e0;color:var(--warn)}
.pill.info{background:#eef1f5;color:var(--info)}
.pill.pass{background:#e7f4ec;color:var(--ok)}
.pill.na{background:#f0f0f0;color:#999}

.msg{background:#eaf3ff;border:1px solid #cfe1fb;color:#1748a3;padding:10px 14px;border-radius:8px;margin-bottom:14px;font-size:14px}
.muted{color:var(--muted)}
.mono{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:13px;background:#f6f7f9;padding:2px 6px;border-radius:5px;word-break:break-all}
.linkbox{display:flex;gap:8px;align-items:center;background:#f6f8fb;border:1px dashed #c7d3e6;border-radius:8px;padding:10px 12px}
.linkbox input{font-family:ui-monospace,monospace;font-size:13px}

.report{background:#fff;border:1px solid var(--line);border-radius:10px;padding:8px 24px}
.report h2{border:none;color:var(--brand)}
.report blockquote{border-left:3px solid var(--warn);background:#fffaf0;margin:10px 0;padding:8px 14px;color:#7a5c14}
.report code{background:#f6f7f9;padding:1px 5px;border-radius:4px}
.finding{border:1px solid var(--line);border-left-width:4px;border-radius:7px;padding:10px 14px;margin-bottom:8px}
.finding.error{border-left-color:var(--err)}
.finding.warn{border-left-color:var(--warn)}
.finding.info,.finding.pass{border-left-color:var(--ok)}
.finding .ft{font-weight:600}
.finding ul{margin:6px 0 0;padding-left:20px;color:var(--muted)}
.spin{display:inline-block;width:14px;height:14px;border:2px solid #cbd5e3;border-top-color:var(--brand);border-radius:50%;animation:sp 0.8s linear infinite;vertical-align:-2px}
@keyframes sp{to{transform:rotate(360deg)}}

/* 意向专业大类(同步自填报系统) */
.majorbox{border:1px solid var(--line);border-radius:8px;background:#fafbfc;overflow:hidden}
.majsearch{border:0;border-bottom:1px solid var(--line);width:100%;padding:9px 11px;font-size:14px;background:#fff}
.majscroll{max-height:280px;overflow:auto;padding:8px 10px}
.majsec{font-weight:700;color:var(--brand);font-size:13px;margin:8px 0 5px;padding-bottom:3px;border-bottom:1px dashed var(--line)}
.majgroup{margin-bottom:7px;display:flex;flex-wrap:wrap;align-items:center;gap:3px}
.majglabel{font-size:12px;color:var(--muted);min-width:58px}
.majchip{display:inline-flex;align-items:center;gap:4px;font-size:13px;background:#fff;border:1px solid var(--line);border-radius:14px;padding:2px 10px;cursor:pointer}
.majchip input{margin:0;width:auto}
.majchip:has(input:checked){background:#eef4ff;border-color:var(--brand);color:var(--brand);font-weight:600}

/* 拖拽排序(院校所在地意向) */
.ranklist{border:1px solid var(--line);border-radius:8px;padding:8px;background:#fafbfc}
.rl-item{display:flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--line);border-radius:7px;padding:9px 11px;margin-bottom:6px;cursor:grab;font-size:14px;user-select:none;box-shadow:0 1px 2px rgba(20,30,50,.04)}
.rl-item:last-child{margin-bottom:0}
.rl-item.dragging{opacity:.45;border-style:dashed}
.rl-handle{color:#c2c9d4;font-size:15px;cursor:grab}
.rl-rank{color:var(--brand);font-weight:700;min-width:22px}
.rl-name{flex:1}
.rl-del{background:none;border:none;color:#c0506a;font-size:19px;cursor:pointer;line-height:1;padding:0 2px}
.rl-del:hover{color:#b8373d}
.rl-pool-wrap{margin-top:8px;border-top:1px dashed var(--line);padding-top:8px}
.rl-pool-label{font-size:12px;margin-bottom:5px}
.rl-pool{display:flex;flex-wrap:wrap;gap:6px}
.rl-add{background:#eef1f5;border:1px dashed #c7d3e6;border-radius:6px;padding:4px 10px;font-size:13px;cursor:pointer;color:#55606e}
.rl-add:hover{background:#e3ebfa;color:var(--brand)}
.qsection{font-weight:700;font-size:15px;color:var(--brand);margin:22px 0 6px;padding-bottom:5px;border-bottom:2px solid #e6edfa}
.qsection:first-of-type{margin-top:4px}
.opt{display:block;padding:8px 11px;border:1px solid var(--line);border-radius:7px;margin-bottom:6px;cursor:pointer;font-size:14px}
.opt:hover{background:#f6f8fb}
.opt input{margin-right:6px;width:auto}
.scale{display:flex;gap:8px;flex-wrap:wrap}
.scale .opt{flex:1;min-width:92px;text-align:center;margin-bottom:0}
.assess-card{border-left:4px solid #7c4dff}
.bar{height:8px;border-radius:5px;background:#eef1f5;overflow:hidden;margin:3px 0}
.bar > span{display:block;height:100%;background:var(--brand)}

/* 服务流程步骤条 */
.flow-card{padding:0;overflow:hidden}
.flow-head{display:flex;justify-content:space-between;align-items:center;padding:13px 20px;background:linear-gradient(180deg,#f6f9fe,#fff);border-bottom:1px solid #eef1f6}
.flow-head h3{font-size:16px}
.stepper{position:relative;display:flex;padding:24px 8px 20px}
.sstep{flex:1;display:flex;justify-content:center;margin:0;min-width:0}
.sbtn{display:flex;flex-direction:column;align-items:center;gap:9px;background:none;border:none;cursor:pointer;width:100%;padding:0;font-family:inherit}
.sdot{position:relative;z-index:1;width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:17px;background:#fff;color:#9aa6b5;border:2px solid #e3e7ee;transition:.2s}
.stitle{font-size:14px;font-weight:600;color:#7a8595;text-align:center;line-height:1.25}
.ssub{font-size:11px;color:#aeb6c2;text-align:center;line-height:1.3}
.strack,.sprog{position:absolute;top:43px;height:4px;border-radius:3px;z-index:0}
.strack{left:calc(100% / (var(--steps) * 2) + 8px);width:calc(100% - 100% / var(--steps) - 16px);background:#e7eaf1}
.sprog{left:calc(100% / (var(--steps) * 2) + 8px);width:calc(var(--cur) / var(--steps) * (100% - 16px));background:linear-gradient(90deg,#3ddc84,#1f9d57);transition:width .35s}
.sstep.done .sdot{background:linear-gradient(135deg,#46d985,#1f9d57);color:#fff;border-color:transparent;box-shadow:0 4px 10px rgba(31,157,87,.3)}
.sstep.done .stitle{color:#1f9d57}
.sstep.cur .sdot{background:linear-gradient(135deg,#5b9cf5,#1f5fcf);color:#fff;border-color:transparent;box-shadow:0 0 0 5px rgba(31,95,207,.14),0 5px 12px rgba(31,95,207,.36);transform:scale(1.14)}
.sstep.cur .stitle{color:var(--brand);font-weight:700}
.sbtn:hover .sdot{border-color:var(--brand)}
.sstep.todo:hover .sdot{background:#eef4ff;color:var(--brand)}
@media(max-width:560px){.sdot{width:34px;height:34px;font-size:15px}.strack,.sprog{top:39px}.stitle{font-size:12px}.ssub{display:none}}
.stage-badge{display:inline-block;background:#fff3df;color:#b9770a;border-radius:6px;padding:1px 8px;font-size:12px;font-weight:600;margin-right:6px;vertical-align:2px}

/* 沟通/面谈记录 */
.log-item{border:1px solid var(--line);border-radius:8px;padding:10px 12px;margin-bottom:8px;background:#fafbfc}
.log-meta{font-size:12px;color:var(--muted);margin-bottom:5px}
.log-body{font-size:13px;white-space:pre-wrap;line-height:1.7}

/* 档案编辑 + 历史 */
.edit-grid{display:grid;grid-template-columns:1fr 300px;gap:18px}
@media(max-width:820px){.edit-grid{grid-template-columns:1fr}}
.edit-history{border-left:1px solid var(--line);padding-left:16px;max-height:520px;overflow:auto}
@media(max-width:820px){.edit-history{border-left:none;border-top:1px solid var(--line);padding-left:0;padding-top:12px}}
.hist-item{border-bottom:1px dashed var(--line);padding:8px 0}
.hist-meta{font-size:12px;color:var(--muted);margin-bottom:4px}
.hist-change{font-size:12px;line-height:1.7}
.hist-field{display:inline-block;background:#eef1f5;border-radius:4px;padding:0 5px;margin-right:4px;color:#55606e}
.hist-old{color:#b35;text-decoration:line-through;opacity:.8}
.hist-new{color:#1f9d57;font-weight:600}

.login-wrap{max-width:360px;margin:80px auto}
.login-wrap .card{padding:28px}
.center{text-align:center}
